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 76803c43..3af679ee 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 @@ -448,47 +448,47 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// /// - /// - /// Configures the input to the batch request. - /// - /// - /// Required. The user-defined name of this batch. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// 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. - /// /// /// 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. + /// + /// + /// Configures the input to the batch request. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task BatchesUpdateEmbedContentBatchAsync( string batchesId, string? updateMask = default, - global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - string? displayName = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, string? priority = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, string? model = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? displayName = default, + global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentBatch { - InputConfig = inputConfig, - DisplayName = displayName, - Output = output, Priority = priority, + Output = output, Model = model, BatchStats = batchStats, + DisplayName = displayName, + InputConfig = inputConfig, }; 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 168987f5..2bd58a50 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,15 +448,15 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Stats about the batch. /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// @@ -472,9 +472,9 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( public async global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, string? model = default, global::Google.Gemini.BatchStats? batchStats = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, string? priority = default, string? displayName = default, global::Google.Gemini.InputConfig? inputConfig = default, @@ -483,9 +483,9 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( { var __request = new global::Google.Gemini.GenerateContentBatch { + Output = output, Model = model, BatchStats = batchStats, - Output = output, Priority = priority, DisplayName = displayName, InputConfig = inputConfig, 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 458c98b4..9c08ecc6 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,9 +425,6 @@ 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. - /// /// /// Input only. New TTL for this resource, input only. /// @@ -440,11 +437,8 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Metadata on the usage of the cached content. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// 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. @@ -452,33 +446,39 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// 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. + /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsCreateAsync( - string? expireTime = default, string? ttl = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? displayName = default, + string? expireTime = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { - ExpireTime = expireTime, Ttl = ttl, Model = model, ToolConfig = toolConfig, Contents = contents, - UsageMetadata = usageMetadata, - DisplayName = displayName, + ExpireTime = expireTime, SystemInstruction = systemInstruction, Tools = tools, + UsageMetadata = usageMetadata, + DisplayName = displayName, }; return await CachedContentsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs index 5fe73e58..b4b9f894 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,9 +448,6 @@ 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. - /// /// /// Input only. New TTL for this resource, input only. /// @@ -463,11 +460,8 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Metadata on the usage of the cached content. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// 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. @@ -475,35 +469,41 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// 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. + /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, - string? expireTime = default, string? ttl = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? displayName = default, + string? expireTime = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { - ExpireTime = expireTime, Ttl = ttl, Model = model, ToolConfig = toolConfig, Contents = contents, - UsageMetadata = usageMetadata, - DisplayName = displayName, + ExpireTime = expireTime, SystemInstruction = systemInstruction, Tools = tools, + UsageMetadata = usageMetadata, + DisplayName = displayName, }; 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..6961b234 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. /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CorporaPermissionsCreateAsync( string corporaId, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { + Role = role, GranteeType = granteeType, EmailAddress = emailAddress, - Role = role, }; return await CorporaPermissionsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs index ed2f0c85..a64bbbc9 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( /// /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -474,17 +474,17 @@ partial void ProcessCorporaPermissionsPatchResponseContent( string permissionsId, string corporaId, string? updateMask = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { + Role = role, GranteeType = granteeType, EmailAddress = emailAddress, - Role = role, }; return await CorporaPermissionsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs index 43d7debf..cac3d401 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,23 +435,29 @@ 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. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -459,42 +465,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.GenerateContentRequest { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 b1295ade..543836e4 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,23 +435,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -459,42 +465,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.GenerateContentRequest { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 71ba0b04..0ec89699 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,23 +376,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -400,42 +406,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = 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 { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; var __enumerable = DynamicStreamGenerateContentAsStreamAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs index 7dac3545..9f8368aa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs @@ -425,25 +425,25 @@ partial void ProcessFileSearchStoresCreateResponseContent( /// /// Creates an empty `FileSearchStore`. /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. - /// /// /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task FileSearchStoresCreateAsync( - string? embeddingModel = default, string? displayName = default, + string? embeddingModel = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.FileSearchStore { - EmbeddingModel = embeddingModel, DisplayName = displayName, + EmbeddingModel = embeddingModel, }; return await FileSearchStoresCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs index 6eebaf77..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 @@ -438,28 +438,28 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// + /// + /// Custom metadata to be associated with the file. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, string? fileName = default, - global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, + global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { FileName = fileName, - CustomMetadata = customMetadata, ChunkingConfig = chunkingConfig, + CustomMetadata = customMetadata, }; return await FileSearchStoresImportFileAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs index a38cd0ce..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 @@ -435,36 +435,36 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// /// /// Optional. Display name of the created document. /// + /// + /// 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 /// - /// - /// Custom metadata to be associated with the data. + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, - string? mimeType = default, 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) { var __request = new global::Google.Gemini.UploadToFileSearchStoreRequest { - MimeType = mimeType, DisplayName = displayName, - ChunkingConfig = chunkingConfig, CustomMetadata = customMetadata, + ChunkingConfig = chunkingConfig, + MimeType = mimeType, }; return await MediaUploadToFileSearchStoreAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs index 8f046cd9..c4e0cb91 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs @@ -440,28 +440,28 @@ partial void ProcessModelsEmbedContentResponseContent( /// /// 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. - /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Configurations for the EmbedContent request. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, string? model = default, - global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { Model = model, - EmbedContentConfig = embedContentConfig, Content = content, + EmbedContentConfig = embedContentConfig, }; return await ModelsEmbedContentAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs index eea0a6e0..26cf654d 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,23 +435,29 @@ 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. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -459,42 +465,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.GenerateContentRequest { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 09973100..eb0d2986 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,23 +435,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -459,42 +465,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.GenerateContentRequest { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 9391050d..6d71c9ce 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,23 +376,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -400,42 +406,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = 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 { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 ef49c6d8..12637ff8 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,11 +438,14 @@ 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. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// 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. /// /// /// Optional. A short description of this model. @@ -450,49 +453,46 @@ partial void ProcessTunedModelsCreateResponseContent( /// /// 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. /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// - /// - /// 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. + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, - int? topK = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - float? temperature = default, - string? baseModel = default, + string? displayName = default, global::Google.Gemini.TuningTask? tuningTask = default, float? topP = default, + string? description = default, + float? temperature = default, + int? topK = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - string? displayName = default, + string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { - TopK = topK, - ReaderProjectNumbers = readerProjectNumbers, - Description = description, - Temperature = temperature, - BaseModel = baseModel, + DisplayName = displayName, TuningTask = tuningTask, TopP = topP, + Description = description, + Temperature = temperature, + TopK = topK, TunedModelSource = tunedModelSource, - DisplayName = displayName, + BaseModel = baseModel, + ReaderProjectNumbers = readerProjectNumbers, }; 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 9d8c10e5..4e468526 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,23 +435,29 @@ 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. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -459,42 +465,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.GenerateContentRequest { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 e4654220..98c2c751 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,11 +448,14 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// 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. /// /// /// Optional. A short description of this model. @@ -460,20 +463,17 @@ 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. /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// - /// - /// 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. + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// 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, - int? topK = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - float? temperature = default, - string? baseModel = default, + string? displayName = default, global::Google.Gemini.TuningTask? tuningTask = default, float? topP = default, + string? description = default, + float? temperature = default, + int? topK = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - string? displayName = default, + string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { - TopK = topK, - ReaderProjectNumbers = readerProjectNumbers, - Description = description, - Temperature = temperature, - BaseModel = baseModel, + DisplayName = displayName, TuningTask = tuningTask, TopP = topP, + Description = description, + Temperature = temperature, + TopK = topK, TunedModelSource = tunedModelSource, - DisplayName = displayName, + BaseModel = baseModel, + ReaderProjectNumbers = readerProjectNumbers, }; 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..2f74e3cc 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. /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsPermissionsCreateAsync( string tunedModelsId, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { + Role = role, GranteeType = granteeType, EmailAddress = emailAddress, - Role = role, }; return await TunedModelsPermissionsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs index 2e627ccb..d4207544 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( /// /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -474,17 +474,17 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( string tunedModelsId, string permissionsId, string? updateMask = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { + Role = role, GranteeType = granteeType, EmailAddress = emailAddress, - Role = role, }; return await TunedModelsPermissionsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs index d9ae6d75..348420a2 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,23 +435,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -459,42 +465,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.GenerateContentRequest { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 108fcfdb..b12fc5f3 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,23 +376,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -400,42 +406,36 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = 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 { - CachedContent = cachedContent, SystemInstruction = systemInstruction, - SafetySettings = safetySettings, - Store = store, - GenerationConfig = generationConfig, Tools = tools, - ServiceTier = serviceTier, - Contents = contents, + GenerationConfig = generationConfig, + CachedContent = cachedContent, Model = model, ToolConfig = toolConfig, + Store = store, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + Contents = contents, }; 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 85d533ec..c6bcab7b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs @@ -41,36 +41,36 @@ public partial interface IGeminiClient /// /// /// - /// - /// Configures the input to the batch request. - /// - /// - /// Required. The user-defined name of this batch. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// 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. - /// /// /// 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. + /// + /// + /// Configures the input to the batch request. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task BatchesUpdateEmbedContentBatchAsync( string batchesId, string? updateMask = default, - global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - string? displayName = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, string? priority = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, string? model = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, + string? displayName = default, + global::Google.Gemini.InputEmbedContentConfig? inputConfig = 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 d11732bb..7322bd89 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,15 +41,15 @@ public partial interface IGeminiClient /// /// /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Stats about the batch. /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// /// /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// @@ -65,9 +65,9 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, string? model = default, global::Google.Gemini.BatchStats? batchStats = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, string? priority = default, string? displayName = default, global::Google.Gemini.InputConfig? inputConfig = 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 2299d626..2795ff09 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,9 +31,6 @@ 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. - /// /// /// Input only. New TTL for this resource, input only. /// @@ -46,11 +43,8 @@ public partial interface IGeminiClient /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Metadata on the usage of the cached content. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. @@ -58,19 +52,25 @@ public partial interface IGeminiClient /// /// 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. + /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsCreateAsync( - string? expireTime = default, string? ttl = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? displayName = default, + string? expireTime = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, + string? displayName = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs index 04215ff0..8de442f8 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,9 +41,6 @@ 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. - /// /// /// Input only. New TTL for this resource, input only. /// @@ -56,11 +53,8 @@ public partial interface IGeminiClient /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Metadata on the usage of the cached content. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// 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. @@ -68,21 +62,27 @@ public partial interface IGeminiClient /// /// 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. + /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, - string? expireTime = default, string? ttl = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? displayName = default, + string? expireTime = default, global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = 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.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs index 742c7e66..d00a997c 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. /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CorporaPermissionsCreateAsync( string corporaId, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs index b57a43d0..61d0e8e4 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 /// /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -62,9 +62,9 @@ public partial interface IGeminiClient string permissionsId, string corporaId, string? updateMask = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs index f27d4d21..b1817d8e 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,23 +36,29 @@ 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. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -60,27 +66,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.DynamicStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs index f226350d..df5ed7b9 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,23 +36,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -60,27 +66,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.DynamicStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs index ac8e67cd..c78f3f35 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -22,23 +22,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -46,27 +52,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.FileSearchStoresCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs index 456dc9c7..9edab07f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs @@ -31,18 +31,18 @@ public partial interface IGeminiClient /// /// Creates an empty `FileSearchStore`. /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. - /// /// /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task FileSearchStoresCreateAsync( - string? embeddingModel = default, string? displayName = default, + string? embeddingModel = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs index f429f259..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 @@ -39,20 +39,20 @@ public partial interface IGeminiClient /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// + /// + /// Custom metadata to be associated with the file. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, string? fileName = default, - global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, + global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs index b22e288f..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 @@ -36,27 +36,27 @@ public partial interface IGeminiClient /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// /// /// Optional. Display name of the created document. /// + /// + /// 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 /// - /// - /// Custom metadata to be associated with the data. + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, - string? mimeType = default, 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.ModelsEmbedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs index 93f07c6e..2f5b194e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs @@ -41,20 +41,20 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Configurations for the EmbedContent request. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, string? model = default, - global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs index 6ecf4fa1..c00ee1fa 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,23 +36,29 @@ 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. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -60,27 +66,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.ModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs index 20e19a8f..24fad0cd 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,23 +36,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -60,27 +66,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.ModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs index 2bb56b25..5af80539 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -22,23 +22,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -46,27 +52,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.TunedModelsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs index 3673d8f0..c1b3e6a8 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,11 +36,14 @@ 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. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// 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. /// /// /// Optional. A short description of this model. @@ -48,35 +51,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. /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// - /// - /// 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. + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, - int? topK = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - float? temperature = default, - string? baseModel = default, + string? displayName = default, global::Google.Gemini.TuningTask? tuningTask = default, float? topP = default, + string? description = default, + float? temperature = default, + int? topK = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - string? displayName = default, + string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = 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 43cc827e..3a04e4a4 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,23 +36,29 @@ 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. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -60,27 +66,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.TunedModelsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs index 84d42938..c6f74f53 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,11 +41,14 @@ public partial interface IGeminiClient /// /// /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// 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. /// /// /// Optional. A short description of this model. @@ -53,20 +56,17 @@ 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. /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` - /// - /// - /// 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. + /// + /// 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. /// /// /// Tuned model as a source for training a new model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// 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, - int? topK = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? description = default, - float? temperature = default, - string? baseModel = default, + string? displayName = default, global::Google.Gemini.TuningTask? tuningTask = default, float? topP = default, + string? description = default, + float? temperature = default, + int? topK = default, global::Google.Gemini.TunedModelSource? tunedModelSource = default, - string? displayName = default, + string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = 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..201791e7 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. /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsPermissionsCreateAsync( string tunedModelsId, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs index 065efa6e..e32f3684 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 /// /// /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -62,9 +62,9 @@ public partial interface IGeminiClient string tunedModelsId, string permissionsId, string? updateMask = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, - global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs index 3189825f..ad7decd0 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,23 +36,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -60,27 +66,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.TunedModelsStreamGenerateContentAsStream.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs index 3fcfb69f..933dd828 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -22,23 +22,29 @@ 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`. /// /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Optional. A list of `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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -46,27 +52,21 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// 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? cachedContent = default, global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? safetySettings = default, - bool? store = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, - global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, + string? cachedContent = default, string? model = default, global::Google.Gemini.ToolConfig? toolConfig = default, + bool? store = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = 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.JsonSerializerContext.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs index 76004338..ccb94869 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs @@ -13,49 +13,45 @@ namespace Google.Gemini DefaultIgnoreCondition = global::System.Text.Json.Serialization.JsonIgnoreCondition.WhenWritingNull, Converters = new global::System.Type[] { - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), @@ -65,425 +61,429 @@ namespace Google.Gemini typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), 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.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.Dataset))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.McpServer))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] - [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.CustomLongRunningOperation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] + [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.GenerateContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] + [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(bool))] + [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.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListGeneratedFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFile))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.CountTokensResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] + [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::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCorporaResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.LogprobsResultCandidate))] - [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.TransferOwnershipRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListPermissionsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] - [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.AsyncBatchEmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.GroundingAttribution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] - [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.CountTokensRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] + [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.FunctionDeclaration))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [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.UrlContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListModelsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] - [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.ResponseFormatConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] + [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.MultiSpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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.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.Interval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequests))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.FunctionResponsePart))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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.SafetyRating))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingProbability), TypeInfoPropertyName = "SafetyRatingProbability2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRatingCategory), TypeInfoPropertyName = "SafetyRatingCategory2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] - [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.EmbedContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [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.TunedModel))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] + [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.CitationSource))] + [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.TransferOwnershipResponse))] + [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.LogprobsResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [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(double))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] [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.GroundingMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRating))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponsePart))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseBlob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListPermissionsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Permission))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] [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.GenerationConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] - [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.ListTunedModelsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.MultiSpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomMetadata))] - [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.InputEmbedContentConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ResponseFormatConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigResponseModalitie), TypeInfoPropertyName = "GenerationConfigResponseModalitie2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] - [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.TunedModelSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] + [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.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.GoogleAiGenerativelanguageV1betaGroundingSupport))] + [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.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseDisabledSafetyPolicie), TypeInfoPropertyName = "ComputerUseDisabledSafetyPolicie2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] - [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.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatImageSize), TypeInfoPropertyName = "ImageResponseFormatImageSize2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatMimeType), TypeInfoPropertyName = "ImageResponseFormatMimeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatAspectRatio), TypeInfoPropertyName = "ImageResponseFormatAspectRatio2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatDelivery), TypeInfoPropertyName = "ImageResponseFormatDelivery2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListModelsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] - [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.Web))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] - [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.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigResponseModalitie), TypeInfoPropertyName = "GenerationConfigResponseModalitie2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.GoogleAiGenerativelanguageV1betaSegment))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [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.InlinedEmbedContentResponse))] + [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.InputConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] + [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.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseDisabledSafetyPolicie), TypeInfoPropertyName = "ComputerUseDisabledSafetyPolicie2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [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.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.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatDelivery), TypeInfoPropertyName = "AudioResponseFormatDelivery2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatMimeType), TypeInfoPropertyName = "AudioResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [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 e674acae..c0fd2390 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,1187 +28,1187 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type0 { get; set; } + public global::Google.Gemini.Dataset? Type0 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type1 { get; set; } + public global::Google.Gemini.TuningExamples? Type1 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type2 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type2 { get; set; } /// /// /// - public string? Type3 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type3 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type4 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type4 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type5 { get; set; } + public string? Type5 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type6 { get; set; } + public global::Google.Gemini.SearchTypes? Type6 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type7 { get; set; } + public global::Google.Gemini.WebSearch? Type7 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type8 { get; set; } + public global::Google.Gemini.ImageSearch? Type8 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type9 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type9 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type10 { get; set; } + public global::Google.Gemini.File? Type10 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type11 { get; set; } + public global::Google.Gemini.SafetySetting? Type11 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type12 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type12 { get; set; } /// /// /// - public int? Type13 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type13 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type14 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type14 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type15 { get; set; } + public global::Google.Gemini.ModelStatus? Type15 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type16 { get; set; } + public global::Google.Gemini.PromptFeedback? Type16 { get; set; } /// /// /// - public object? Type17 { get; set; } + public global::System.Collections.Generic.IList? Type17 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type18 { get; set; } + public global::Google.Gemini.Candidate? Type18 { get; set; } /// /// /// - public bool? Type19 { get; set; } + public global::Google.Gemini.UsageMetadata? Type19 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type20 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type20 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type21 { get; set; } + public global::System.Collections.Generic.IList? Type21 { get; set; } /// /// /// - public global::Google.Gemini.File? Type22 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type22 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type23 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type23 { get; set; } /// /// /// - public float? Type24 { get; set; } + public global::System.Collections.Generic.IList? Type24 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type25 { get; set; } + public global::Google.Gemini.LogprobsResult? Type25 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type26 { get; set; } + public float? Type26 { get; set; } /// /// /// - public global::Google.Gemini.Model? Type27 { get; set; } + public global::System.Collections.Generic.IList? Type27 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type28 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type28 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type29 { get; set; } + public global::System.Collections.Generic.IList? Type29 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type30 { get; set; } + public global::Google.Gemini.TopCandidates? Type30 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchState? Type31 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type31 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type32 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type32 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type33 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type33 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type34 { get; set; } + public global::System.Collections.Generic.Dictionary? Type34 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type35 { get; set; } + public bool? Type35 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type36 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type36 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type37 { get; set; } + public global::Google.Gemini.VoiceConfig? Type37 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type38 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type38 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type39 { get; set; } + public global::Google.Gemini.InlinedResponse? Type39 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type40 { get; set; } + public global::Google.Gemini.Status? Type40 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type41 { get; set; } + public object? Type41 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type42 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type42 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type43 { get; set; } + public int? Type43 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type44 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type44 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type45 { get; set; } + public global::System.Collections.Generic.IList? Type45 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type46 { get; set; } + public global::Google.Gemini.GeneratedFile? Type46 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesRequest? Type47 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type47 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type48 { get; set; } + public global::System.Collections.Generic.IList? Type48 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type49 { get; set; } + public global::Google.Gemini.FileSearchStore? Type49 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type50 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type50 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type51 { get; set; } + public global::System.Collections.Generic.IList? Type51 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type52 { get; set; } + public global::Google.Gemini.ModalityTokenCount? Type52 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type53 { get; set; } + public global::Google.Gemini.Maps? Type53 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type54 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type54 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type55 { get; set; } + public global::Google.Gemini.CachedContent? Type55 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type56 { get; set; } + public global::Google.Gemini.ToolConfig? Type56 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type57 { get; set; } + public global::System.Collections.Generic.IList? Type57 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type58 { get; set; } + public global::Google.Gemini.Content? Type58 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type59 { get; set; } + public global::System.Collections.Generic.IList? Type59 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type60 { get; set; } + public global::Google.Gemini.Tool? Type60 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type61 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type61 { get; set; } /// /// /// - public global::Google.Gemini.Part? Type62 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type62 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type63 { get; set; } + public global::Google.Gemini.InlinedResponses? Type63 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type64 { get; set; } + public global::Google.Gemini.TunedModelSource? Type64 { get; set; } /// /// /// - public byte[]? Type65 { get; set; } + public global::Google.Gemini.ToolResponse? Type65 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type66 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type66 { get; set; } /// /// /// - public global::Google.Gemini.VideoMetadata? Type67 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type67 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type68 { get; set; } + public global::Google.Gemini.CodeExecution? Type68 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type69 { get; set; } + public global::System.Collections.Generic.IList? Type69 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type70 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type70 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type71 { get; set; } + public global::Google.Gemini.GoogleSearch? Type71 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type72 { get; set; } + public global::Google.Gemini.FileSearch? Type72 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type73 { get; set; } + public global::Google.Gemini.GoogleMaps? Type73 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type74 { get; set; } + public global::Google.Gemini.ComputerUse? Type74 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type75 { get; set; } + public global::Google.Gemini.UrlContext? Type75 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type76 { get; set; } + public global::System.Collections.Generic.IList? Type76 { get; set; } /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type77 { get; set; } + public global::Google.Gemini.McpServer? Type77 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type78 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type78 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type79 { get; set; } + public global::System.Collections.Generic.IList? Type79 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type80 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type80 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormat? Type81 { get; set; } + public byte[]? Type81 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormatMimeType? Type82 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type82 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type83 { get; set; } + public global::System.Collections.Generic.IList? Type83 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type84 { get; set; } + public global::Google.Gemini.Document? Type84 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type85 { get; set; } + public global::Google.Gemini.Interval? Type85 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type86 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type86 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type87 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type87 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type88 { get; set; } + public global::Google.Gemini.InlinedRequests? Type88 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type89 { get; set; } + public global::System.Collections.Generic.IList? Type89 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type90 { get; set; } + public global::Google.Gemini.InlinedRequest? Type90 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type91 { get; set; } + public global::System.Collections.Generic.IList? Type91 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type92 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type92 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type93 { get; set; } + public global::Google.Gemini.LatLng? Type93 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type94 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type94 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type95 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type95 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type96 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type96 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type97 { get; set; } + public global::Google.Gemini.EmbedContentConfig? Type97 { get; set; } /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type98 { get; set; } + public global::Google.Gemini.EmbedContentConfigTaskType? Type98 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type99 { get; set; } + public global::System.Collections.Generic.IList? Type99 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type100 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type100 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type101 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type101 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type102 { get; set; } + public global::System.Collections.Generic.IList? Type102 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type103 { get; set; } + public global::Google.Gemini.UrlMetadata? Type103 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type104 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type104 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensRequest? Type105 { get; set; } + public global::System.Collections.Generic.IList? Type105 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type106 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type106 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type107 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type107 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type108 { get; set; } + public global::System.Collections.Generic.IList? Type108 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type109 { get; set; } + public global::Google.Gemini.TuningExample? Type109 { get; set; } /// /// /// - public global::Google.Gemini.WebSearch? Type110 { get; set; } + public global::Google.Gemini.TunedModel? Type110 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type111 { get; set; } + public global::Google.Gemini.TuningTask? Type111 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type112 { get; set; } + public global::Google.Gemini.TunedModelState? Type112 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type113 { get; set; } + public global::System.Collections.Generic.IList? Type113 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type114 { get; set; } + public global::Google.Gemini.FileData? Type114 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type115 { get; set; } + public global::Google.Gemini.UsageMetadataServiceTier? Type115 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type116 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type116 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCount? Type117 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type117 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type118 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type118 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type119 { get; set; } + public global::Google.Gemini.Empty? Type119 { get; set; } /// /// /// - public double? Type120 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type120 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type121 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type121 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type122 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type122 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type123 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type123 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type124 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type124 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type125 { get; set; } + public global::System.Collections.Generic.IList? Type125 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type126 { get; set; } + public global::Google.Gemini.CustomMetadata? Type126 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type127 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type127 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type128 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type128 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type129 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type129 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type130 { get; set; } + public global::Google.Gemini.GeneratedFileState? Type130 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type131 { get; set; } + public global::System.Collections.Generic.IList? Type131 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type132 { get; set; } + public global::System.Collections.Generic.IList? Type132 { get; set; } /// /// /// - public global::Google.Gemini.ContentEmbedding? Type133 { get; set; } + public global::Google.Gemini.CitationSource? Type133 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type134 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type134 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type135 { get; set; } + public global::System.Collections.Generic.IList? Type135 { get; set; } /// /// /// - public global::Google.Gemini.ResponseFormatConfig? Type136 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type136 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormat? Type137 { get; set; } + public global::Google.Gemini.Schema? Type137 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormat? Type138 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type138 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type139 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type139 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type140 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type140 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type141 { get; set; } + public double? Type141 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type142 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type142 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type143 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type143 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type144 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type144 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type145 { get; set; } + public global::Google.Gemini.StringList? Type145 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type146 { get; set; } + public global::Google.Gemini.CitationMetadata? Type146 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type147 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type147 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type148 { get; set; } + public global::System.Collections.Generic.IList? Type148 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type149 { get; set; } + public global::Google.Gemini.SafetyRating? Type149 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type150 { get; set; } + public global::System.Collections.Generic.IList? Type150 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type151 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type151 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type152 { get; set; } + public global::System.Collections.Generic.IList? Type152 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type153 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type153 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type154 { get; set; } + public global::Google.Gemini.Operation? Type154 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type155 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type155 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type156 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type156 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type157 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type157 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type158 { get; set; } + public global::System.Collections.Generic.IList? Type158 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type159 { get; set; } + public global::Google.Gemini.Permission? Type159 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type160 { get; set; } + public global::System.Collections.Generic.IList? Type160 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type161 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type161 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type162 { get; set; } + public global::Google.Gemini.Hyperparameters? Type162 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type163 { get; set; } + public global::Google.Gemini.Image? Type163 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type164 { get; set; } + public global::System.Collections.Generic.IList? Type164 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type165 { get; set; } + public global::Google.Gemini.Part? Type165 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type166 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type166 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type167 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type167 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatMimeType? Type168 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type168 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatDelivery? Type169 { get; set; } + public global::Google.Gemini.GenerationConfig? Type169 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type170 { get; set; } + public global::Google.Gemini.TranslationConfig? Type170 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type171 { get; set; } + public global::Google.Gemini.ResponseFormatConfig? Type171 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type172 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type172 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type173 { get; set; } + public global::System.Collections.Generic.IList? Type173 { get; set; } /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type174 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type174 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type175 { get; set; } + public global::Google.Gemini.SpeechConfig? Type175 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type176 { get; set; } + public global::Google.Gemini.ImageConfig? Type176 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type177 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type177 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type178 { get; set; } + public global::Google.Gemini.RetrievedContext? Type178 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type179 { get; set; } + public global::System.Collections.Generic.IList? Type179 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type180 { get; set; } + public global::Google.Gemini.ToolCall? Type180 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type181 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type181 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type182 { get; set; } + public global::Google.Gemini.RegisterFilesRequest? Type182 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type183 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type183 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type184 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type184 { get; set; } /// /// /// - public global::Google.Gemini.ReviewSnippet? Type185 { get; set; } + public global::Google.Gemini.DocumentState? Type185 { get; set; } /// /// /// - public global::Google.Gemini.TranslationConfig? Type186 { get; set; } + public global::System.Collections.Generic.IList? Type186 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type187 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type187 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type188 { get; set; } + public global::System.Collections.Generic.IList? Type188 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type189 { get; set; } + public global::Google.Gemini.GroundingChunk? Type189 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type190 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type190 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type191 { get; set; } + public global::Google.Gemini.TextResponseFormat? Type191 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type192 { get; set; } + public global::Google.Gemini.AudioResponseFormat? Type192 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type193 { get; set; } + public global::Google.Gemini.ImageResponseFormat? Type193 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type194 { get; set; } + public global::Google.Gemini.Corpus? Type194 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type195 { get; set; } + public global::System.Collections.Generic.IList? Type195 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfig? Type196 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type196 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type197 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type197 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type198 { get; set; } + public global::System.Collections.Generic.IList? Type198 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type199 { get; set; } + public global::Google.Gemini.Model? Type199 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type200 { get; set; } + public global::Google.Gemini.FunctionCall? Type200 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type201 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type201 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type202 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type202 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type203 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type203 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type204 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type204 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type205 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? Type205 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type206 { get; set; } + public global::Google.Gemini.Web? Type206 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatImageSize? Type207 { get; set; } + public global::Google.Gemini.VideoMetadata? Type207 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatMimeType? Type208 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type208 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatAspectRatio? Type209 { get; set; } + public global::System.Collections.Generic.IList? Type209 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatDelivery? Type210 { get; set; } + public global::Google.Gemini.FileSource? Type210 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type211 { get; set; } + public global::Google.Gemini.FileState? Type211 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfigTaskType? Type212 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type212 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type213 { get; set; } + public global::System.Collections.Generic.IList? Type213 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type214 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type214 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type215 { get; set; } + public global::Google.Gemini.FunctionResponse? Type215 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type216 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type216 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type217 { get; set; } + public global::System.Collections.Generic.IList? Type217 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type218 { get; set; } + public global::Google.Gemini.InputConfig? Type218 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type219 { get; set; } + public global::Google.Gemini.BatchStats? Type219 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type220 { get; set; } + public global::Google.Gemini.GenerateContentBatchState? Type220 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type221 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type221 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type222 { get; set; } + public global::System.Collections.Generic.IList? Type222 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type223 { get; set; } + public global::System.Collections.Generic.IList? Type223 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type224 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type224 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type225 { get; set; } + public global::Google.Gemini.TextResponseFormatMimeType? Type225 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type226 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type226 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type227 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type227 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type228 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type228 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type229 { get; set; } + public global::System.Collections.Generic.IList? Type229 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type230 { get; set; } + public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type230 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type231 { get; set; } + public global::Google.Gemini.ExecutableCode? Type231 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type232 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type232 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type233 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type233 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type234 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type234 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type235 { get; set; } + public global::Google.Gemini.SchemaType? Type235 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type236 { get; set; } + public global::System.Collections.Generic.IList? Type236 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type237 { get; set; } + public global::System.Collections.Generic.Dictionary? Type237 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type238 { get; set; } + public global::Google.Gemini.ImageResponseFormatDelivery? Type238 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type239 { get; set; } + public global::Google.Gemini.ImageResponseFormatAspectRatio? Type239 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type240 { get; set; } + public global::Google.Gemini.ImageResponseFormatMimeType? Type240 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadataServiceTier? Type241 { get; set; } + public global::Google.Gemini.ImageResponseFormatImageSize? Type241 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type242 { get; set; } + public global::Google.Gemini.PermissionRole? Type242 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type243 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type243 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type244 { get; set; } + public global::Google.Gemini.AudioResponseFormatDelivery? Type244 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type245 { get; set; } + public global::Google.Gemini.AudioResponseFormatMimeType? Type245 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type246 { get; set; } + public global::Google.Gemini.Blob? Type246 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFileState? Type247 { get; set; } + public global::System.Collections.Generic.IList? Type247 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type248 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type248 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type249 { get; set; } + public global::System.Collections.Generic.IList? Type249 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType0 { get; set; } + public global::System.Collections.Generic.List? ListType0 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType1 { get; set; } + public global::System.Collections.Generic.List? ListType1 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType2 { get; set; } + public global::System.Collections.Generic.List? ListType2 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType3 { get; set; } + public global::System.Collections.Generic.List? ListType3 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType4 { get; set; } + public global::System.Collections.Generic.List? ListType4 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType5 { get; set; } + public global::System.Collections.Generic.List? ListType5 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType6 { get; set; } + public global::System.Collections.Generic.List? ListType6 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType7 { get; set; } + public global::System.Collections.Generic.List? ListType7 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType8 { get; set; } + public global::System.Collections.Generic.List? ListType8 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType9 { get; set; } + public global::System.Collections.Generic.List? ListType9 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType10 { get; set; } + public global::System.Collections.Generic.List? ListType10 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType11 { get; set; } + public global::System.Collections.Generic.List? ListType11 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType12 { get; set; } + public global::System.Collections.Generic.List? ListType12 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType13 { get; set; } + public global::System.Collections.Generic.List? ListType13 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType14 { get; set; } + public global::System.Collections.Generic.List? ListType14 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType15 { get; set; } + public global::System.Collections.Generic.List? ListType15 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType16 { get; set; } + public global::System.Collections.Generic.List? ListType16 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType17 { get; set; } + public global::System.Collections.Generic.List? ListType17 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType18 { get; set; } + public global::System.Collections.Generic.List? ListType18 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType19 { get; set; } + public global::System.Collections.Generic.List? ListType19 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType20 { get; set; } + public global::System.Collections.Generic.List? ListType20 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType21 { get; set; } + public global::System.Collections.Generic.List? ListType21 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType22 { get; set; } + public global::System.Collections.Generic.List? ListType22 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType23 { get; set; } + public global::System.Collections.Generic.List? ListType23 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType24 { get; set; } + public global::System.Collections.Generic.List? ListType24 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType25 { get; set; } + public global::System.Collections.Generic.List? ListType25 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType26 { get; set; } + public global::System.Collections.Generic.List? ListType26 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType27 { get; set; } + public global::System.Collections.Generic.List? ListType27 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType28 { get; set; } + public global::System.Collections.Generic.List? ListType28 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType29 { get; set; } + public global::System.Collections.Generic.List? ListType29 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType30 { get; set; } + public global::System.Collections.Generic.List? ListType30 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType31 { get; set; } + public global::System.Collections.Generic.List? ListType31 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType32 { get; set; } + public global::System.Collections.Generic.List? ListType32 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType33 { get; set; } + public global::System.Collections.Generic.List? ListType33 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType34 { get; set; } + public global::System.Collections.Generic.List? ListType34 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType35 { get; set; } + public global::System.Collections.Generic.List? ListType35 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType36 { get; set; } + public global::System.Collections.Generic.List? ListType36 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType37 { get; set; } + public global::System.Collections.Generic.List? ListType37 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType38 { get; set; } + public global::System.Collections.Generic.List? ListType38 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType39 { get; set; } + public global::System.Collections.Generic.List? ListType39 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType40 { get; set; } + public global::System.Collections.Generic.List? ListType40 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType41 { get; set; } + public global::System.Collections.Generic.List? ListType41 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType42 { get; set; } + public global::System.Collections.Generic.List? ListType42 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType43 { get; set; } + public global::System.Collections.Generic.List? ListType43 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType44 { get; set; } + public global::System.Collections.Generic.List? ListType44 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType45 { get; set; } + public global::System.Collections.Generic.List? ListType45 { get; set; } } } \ No newline at end of file diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs index 31aabb54..5f9a1bf9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class AttributionSourceId { - /// - /// Identifier for a part within a `GroundingPassage`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingPassage")] - public global::Google.Gemini.GroundingPassageId? GroundingPassage { get; set; } - /// /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. /// [global::System.Text.Json.Serialization.JsonPropertyName("semanticRetrieverChunk")] public global::Google.Gemini.SemanticRetrieverChunk? SemanticRetrieverChunk { get; set; } + /// + /// Identifier for a part within a `GroundingPassage`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingPassage")] + public global::Google.Gemini.GroundingPassageId? GroundingPassage { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class AttributionSourceId /// /// Initializes a new instance of the class. /// - /// - /// Identifier for a part within a `GroundingPassage`. - /// /// /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. /// + /// + /// Identifier for a part within a `GroundingPassage`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AttributionSourceId( - global::Google.Gemini.GroundingPassageId? groundingPassage, - global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk) + global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk, + global::Google.Gemini.GroundingPassageId? groundingPassage) { - this.GroundingPassage = groundingPassage; this.SemanticRetrieverChunk = semanticRetrieverChunk; + this.GroundingPassage = groundingPassage; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs index 7c0d35d4..129d85bd 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 @@ -9,11 +9,10 @@ namespace Google.Gemini public sealed partial class AudioResponseFormat { /// - /// Optional. The MIME type of the audio output. + /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter))] - public global::Google.Gemini.AudioResponseFormatMimeType? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("bitRate")] + public int? BitRate { get; set; } /// /// Optional. The delivery mode for the audio output. @@ -23,16 +22,17 @@ public sealed partial class AudioResponseFormat public global::Google.Gemini.AudioResponseFormatDelivery? Delivery { get; set; } /// - /// Optional. Sample rate in Hz. + /// Optional. The MIME type of the audio output. /// - [global::System.Text.Json.Serialization.JsonPropertyName("sampleRate")] - public int? SampleRate { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter))] + public global::Google.Gemini.AudioResponseFormatMimeType? MimeType { get; set; } /// - /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). + /// Optional. Sample rate in Hz. /// - [global::System.Text.Json.Serialization.JsonPropertyName("bitRate")] - public int? BitRate { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sampleRate")] + public int? SampleRate { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -43,31 +43,31 @@ public sealed partial class AudioResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. The MIME type of the audio output. + /// + /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). /// /// /// Optional. The delivery mode for the audio output. /// + /// + /// Optional. The MIME type of the audio output. + /// /// /// Optional. Sample rate in Hz. /// - /// - /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AudioResponseFormat( - global::Google.Gemini.AudioResponseFormatMimeType? mimeType, + int? bitRate, global::Google.Gemini.AudioResponseFormatDelivery? delivery, - int? sampleRate, - int? bitRate) + global::Google.Gemini.AudioResponseFormatMimeType? mimeType, + int? sampleRate) { - this.MimeType = mimeType; + this.BitRate = bitRate; this.Delivery = delivery; + this.MimeType = mimeType; this.SampleRate = sampleRate; - this.BitRate = bitRate; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs index 1bd6145a..7db4b5ba 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchEmbedContentsResponse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class BatchEmbedContentsResponse { + /// + /// Metadata on the usage of the embedding request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } + /// /// Output only. The embeddings for each request, in the same order as provided in the batch request.
/// Included only in responses @@ -15,12 +21,6 @@ public sealed partial class BatchEmbedContentsResponse [global::System.Text.Json.Serialization.JsonPropertyName("embeddings")] public global::System.Collections.Generic.IList? Embeddings { get; set; } - /// - /// Metadata on the usage of the embedding request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class BatchEmbedContentsResponse /// /// Initializes a new instance of the class. /// + /// + /// Metadata on the usage of the embedding request. + /// /// /// Output only. The embeddings for each request, in the same order as provided in the batch request.
/// Included only in responses /// - /// - /// Metadata on the usage of the embedding request. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchEmbedContentsResponse( - global::System.Collections.Generic.IList? embeddings, - global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata) + global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata, + global::System.Collections.Generic.IList? embeddings) { - this.Embeddings = embeddings; this.UsageMetadata = usageMetadata; + this.Embeddings = embeddings; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs index 561bc548..f2b3d072 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 @@ -23,18 +23,18 @@ public sealed partial class BatchStats public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] + public string? PendingRequestCount { get; set; } /// - /// 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 @@ -53,27 +53,27 @@ public sealed partial class BatchStats /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - /// /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses /// + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchStats( string? requestCount, string? successfulRequestCount, - string? failedRequestCount, - string? pendingRequestCount) + string? pendingRequestCount, + string? failedRequestCount) { this.RequestCount = requestCount; this.SuccessfulRequestCount = successfulRequestCount; - this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; + this.FailedRequestCount = failedRequestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs index 48ff1978..c5a183f8 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,23 +9,17 @@ 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. + /// Input only. New TTL for this resource, input only. /// - [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] - public string? ExpireTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] + public string? Ttl { get; set; } /// - /// Output only. When the cache entry was last updated in UTC time.
+ /// Output only. Creation time of the cache entry.
/// Included only in responses ///
- [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; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` @@ -40,22 +34,23 @@ public sealed partial class CachedContent public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } /// - /// Optional. Input only. Immutable. The content to cache. + /// Output only. When the cache entry was last updated in UTC time.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Metadata on the usage of the cached content. + /// Optional. Input only. Immutable. The content to cache. /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] + public string? ExpireTime { 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. @@ -63,13 +58,6 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] public global::Google.Gemini.Content? SystemInstruction { get; set; } - /// - /// Output only. Creation time of the cache entry.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } - /// /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// @@ -83,6 +71,18 @@ public sealed partial class CachedContent [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Metadata on the usage of the cached content. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -92,38 +92,32 @@ 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. - /// - /// - /// 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. Creation time of the cache entry.
+ /// Included only in responses + /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// + /// + /// Output only. When the cache entry was last updated in UTC time.
+ /// Included only in responses + /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Metadata on the usage of the cached content. - /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Output only. Creation time of the cache entry.
- /// Included only in responses - /// /// /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// @@ -131,35 +125,41 @@ public sealed partial class CachedContent /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
/// Included only in responses /// + /// + /// Metadata on the usage of the cached content. + /// + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( - string? expireTime, - string? updateTime, string? ttl, + string? createTime, string? model, global::Google.Gemini.ToolConfig? toolConfig, + string? updateTime, global::System.Collections.Generic.IList? contents, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, - string? displayName, + string? expireTime, global::Google.Gemini.Content? systemInstruction, - string? createTime, global::System.Collections.Generic.IList? tools, - string? name) + string? name, + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, + string? displayName) { - this.ExpireTime = expireTime; - this.UpdateTime = updateTime; this.Ttl = ttl; + this.CreateTime = createTime; this.Model = model; this.ToolConfig = toolConfig; + this.UpdateTime = updateTime; this.Contents = contents; - this.UsageMetadata = usageMetadata; - this.DisplayName = displayName; + this.ExpireTime = expireTime; this.SystemInstruction = systemInstruction; - this.CreateTime = createTime; this.Tools = tools; this.Name = name; + this.UsageMetadata = usageMetadata; + this.DisplayName = displayName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs index bd369d2d..2bfff63d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Candidate.g.cs @@ -9,10 +9,16 @@ 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. + /// A collection of source attributions for a piece of content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { 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; } /// /// Logprobs Result @@ -21,17 +27,36 @@ public sealed partial class Candidate public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is 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. Index of the candidate in the list of response candidates.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] - public string? FinishMessage { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("index")] + public int? Index { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] - public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + + /// + /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] + public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + + /// + /// 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; } /// /// Output only. Average log probability score of the candidate.
@@ -56,36 +81,11 @@ public sealed partial class Candidate public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("index")] - public int? Index { get; set; } - - /// - /// A collection of source attributions for a piece of content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("citationMetadata")] - public global::Google.Gemini.CitationMetadata? CitationMetadata { get; set; } - - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] - public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } - - /// - /// 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; } - - /// - /// Metadata returned to client when grounding is enabled. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] - public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] + public string? FinishMessage { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -96,18 +96,31 @@ 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. + /// + /// A collection of source attributions for a piece of content. + /// + /// + /// Metadata related to url context retrieval tool. /// /// /// Logprobs Result /// - /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// + /// Metadata returned to client when grounding is enabled. + /// + /// + /// Output only. Index of the candidate in the list of response candidates.
/// Included only in responses /// - /// - /// Metadata related to url context retrieval tool. + /// + /// List of ratings for the safety of a response candidate. There is at most one rating per category. + /// + /// + /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// Included only in responses + /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// /// /// Output only. Average log probability score of the candidate.
@@ -121,52 +134,39 @@ public sealed partial class Candidate /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses /// - /// - /// 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. - /// - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// + /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
/// Included only in responses /// - /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. - /// - /// - /// Metadata returned to client when grounding is enabled. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( - global::Google.Gemini.Content? content, - global::Google.Gemini.LogprobsResult? logprobsResult, - string? finishMessage, + global::Google.Gemini.CitationMetadata? citationMetadata, global::Google.Gemini.UrlContextMetadata? urlContextMetadata, + global::Google.Gemini.LogprobsResult? logprobsResult, + global::Google.Gemini.GroundingMetadata? groundingMetadata, + int? index, + global::System.Collections.Generic.IList? safetyRatings, + global::System.Collections.Generic.IList? groundingAttributions, + global::Google.Gemini.Content? content, double? avgLogprobs, int? tokenCount, global::Google.Gemini.CandidateFinishReason? finishReason, - int? index, - global::Google.Gemini.CitationMetadata? citationMetadata, - global::System.Collections.Generic.IList? groundingAttributions, - global::System.Collections.Generic.IList? safetyRatings, - global::Google.Gemini.GroundingMetadata? groundingMetadata) + string? finishMessage) { - this.Content = content; - this.LogprobsResult = logprobsResult; - this.FinishMessage = finishMessage; + this.CitationMetadata = citationMetadata; this.UrlContextMetadata = urlContextMetadata; + this.LogprobsResult = logprobsResult; + this.GroundingMetadata = groundingMetadata; + this.Index = index; + this.SafetyRatings = safetyRatings; + this.GroundingAttributions = groundingAttributions; + this.Content = content; this.AvgLogprobs = avgLogprobs; this.TokenCount = tokenCount; this.FinishReason = finishReason; - this.Index = index; - this.CitationMetadata = citationMetadata; - this.GroundingAttributions = groundingAttributions; - this.SafetyRatings = safetyRatings; - this.GroundingMetadata = groundingMetadata; + this.FinishMessage = finishMessage; } /// 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 b3bb7af5..c06cc88c 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,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class CitationSource { - /// - /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("license")] - public string? License { get; set; } - /// /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. /// [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] public int? StartIndex { get; set; } + /// + /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("license")] + public string? License { get; set; } + /// /// Optional. End of the attributed segment, exclusive. /// @@ -41,12 +41,12 @@ public sealed partial class CitationSource /// /// Initializes a new instance of the class. /// - /// - /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. - /// /// /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. /// + /// + /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. + /// /// /// Optional. End of the attributed segment, exclusive. /// @@ -57,13 +57,13 @@ public sealed partial class CitationSource [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( - string? license, int? startIndex, + string? license, int? endIndex, string? uri) { - this.License = license; this.StartIndex = startIndex; + this.License = license; this.EndIndex = endIndex; this.Uri = uri; } 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 f9d08bc6..857028fb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs @@ -9,11 +9,10 @@ namespace Google.Gemini public sealed partial class CodeExecutionResult { /// - /// Required. Outcome of the code execution. + /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// - [global::System.Text.Json.Serialization.JsonPropertyName("outcome")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter))] - public global::Google.Gemini.CodeExecutionResultOutcome? Outcome { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } /// /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. @@ -22,10 +21,11 @@ public sealed partial class CodeExecutionResult 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. + /// Required. Outcome of the code execution. /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outcome")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter))] + public global::Google.Gemini.CodeExecutionResultOutcome? Outcome { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -36,26 +36,26 @@ public sealed partial class CodeExecutionResult /// /// Initializes a new instance of the class. /// - /// - /// Required. Outcome of the code execution. + /// + /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// /// /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. /// - /// - /// 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( - global::Google.Gemini.CodeExecutionResultOutcome? outcome, + string? id, string? output, - string? id) + global::Google.Gemini.CodeExecutionResultOutcome? outcome) { - this.Outcome = outcome; - this.Output = output; this.Id = id; + this.Output = output; + this.Outcome = outcome; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs index 908b858b..e99db76e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs @@ -9,10 +9,11 @@ namespace Google.Gemini public sealed partial class ComputerUse { /// - /// Optional. Disabled safety policies for computer use. + /// Required. The environment being operated. /// - [global::System.Text.Json.Serialization.JsonPropertyName("disabledSafetyPolicies")] - public global::System.Collections.Generic.IList? DisabledSafetyPolicies { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("environment")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter))] + public global::Google.Gemini.ComputerUseEnvironment? Environment { get; set; } /// /// Optional. Whether enable the prompt injection detection check on computer-use request. @@ -21,11 +22,10 @@ public sealed partial class ComputerUse public bool? EnablePromptInjectionDetection { get; set; } /// - /// Required. The environment being operated. + /// Optional. Disabled safety policies for computer use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("environment")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter))] - public global::Google.Gemini.ComputerUseEnvironment? Environment { get; set; } + [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,14 +42,14 @@ public sealed partial class ComputerUse /// /// Initializes a new instance of the class. /// - /// - /// Optional. Disabled safety policies for computer use. + /// + /// Required. The environment being operated. /// /// /// Optional. Whether enable the prompt injection detection check on computer-use request. /// - /// - /// Required. The environment being operated. + /// + /// 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,14 +58,14 @@ public sealed partial class ComputerUse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ComputerUse( - global::System.Collections.Generic.IList? disabledSafetyPolicies, - bool? enablePromptInjectionDetection, global::Google.Gemini.ComputerUseEnvironment? environment, + bool? enablePromptInjectionDetection, + global::System.Collections.Generic.IList? disabledSafetyPolicies, global::System.Collections.Generic.IList? excludedPredefinedFunctions) { - this.DisabledSafetyPolicies = disabledSafetyPolicies; - this.EnablePromptInjectionDetection = enablePromptInjectionDetection; this.Environment = environment; + this.EnablePromptInjectionDetection = enablePromptInjectionDetection; + this.DisabledSafetyPolicies = disabledSafetyPolicies; this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs index 2381f72d..941fe884 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ContentEmbedding { - /// - /// The embedding values. This is for 3P users only and will not be populated for 1P calls. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("values")] - public global::System.Collections.Generic.IList? Values { get; set; } - /// /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). /// [global::System.Text.Json.Serialization.JsonPropertyName("shape")] public global::System.Collections.Generic.IList? Shape { get; set; } + /// + /// The embedding values. This is for 3P users only and will not be populated for 1P calls. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("values")] + public global::System.Collections.Generic.IList? Values { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ContentEmbedding /// /// Initializes a new instance of the class. /// - /// - /// The embedding values. This is for 3P users only and will not be populated for 1P calls. - /// /// /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). /// + /// + /// The embedding values. This is for 3P users only and will not be populated for 1P calls. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ContentEmbedding( - global::System.Collections.Generic.IList? values, - global::System.Collections.Generic.IList? shape) + global::System.Collections.Generic.IList? shape, + global::System.Collections.Generic.IList? values) { - this.Values = values; this.Shape = shape; + this.Values = values; } /// 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 dbdad75a..4b6bb2e1 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 @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class Corpus { /// - /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
+ /// Output only. The Timestamp of when the `Corpus` 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. The Timestamp of when the `Corpus` was last updated.
+ /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// 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" @@ -29,11 +29,11 @@ public sealed partial class Corpus public string? DisplayName { get; set; } /// - /// Output only. The Timestamp of when the `Corpus` was created.
+ /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,34 +44,34 @@ public sealed partial class Corpus /// /// Initializes a new instance of the class. /// - /// - /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
- /// Included only in responses - /// /// /// Output only. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses /// + /// + /// Output only. The Timestamp of when the `Corpus` was created.
+ /// Included only in responses + /// /// /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// - /// - /// Output only. The Timestamp of when the `Corpus` was created.
+ /// + /// 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 /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Corpus( - string? name, string? updateTime, + string? createTime, string? displayName, - string? createTime) + string? name) { - this.Name = name; this.UpdateTime = updateTime; - this.DisplayName = displayName; this.CreateTime = createTime; + this.DisplayName = displayName; + this.Name = name; } /// 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 b0eccb71..609093fd 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 @@ -9,17 +9,10 @@ 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 cached content.
- /// Included only in responses + /// Number of tokens in the cached part of the prompt (the cached content). ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] + public int? CachedContentTokenCount { get; set; } /// /// Output only. List of modalities that were processed in the request input.
@@ -29,10 +22,17 @@ public sealed partial class CountTokensResponse public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } /// - /// Number of tokens in the cached part of the prompt (the cached content). + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] - public int? CachedContentTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] + public int? TotalTokens { get; set; } + + /// + /// Output only. List of modalities that were processed in the cached content.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] + public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -43,6 +43,13 @@ public sealed partial class CountTokensResponse /// /// Initializes a new instance of the class. /// + /// + /// Number of tokens in the cached part of the prompt (the cached content). + /// + /// + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses + /// /// /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. /// @@ -50,26 +57,19 @@ public sealed partial class CountTokensResponse /// Output only. List of modalities that were processed in the cached content.
/// Included only in responses /// - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - /// - /// - /// Number of tokens in the cached part of the prompt (the cached content). - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( - int? totalTokens, - global::System.Collections.Generic.IList? cacheTokensDetails, + int? cachedContentTokenCount, global::System.Collections.Generic.IList? promptTokensDetails, - int? cachedContentTokenCount) + int? totalTokens, + global::System.Collections.Generic.IList? cacheTokensDetails) { + this.CachedContentTokenCount = cachedContentTokenCount; + this.PromptTokensDetails = promptTokensDetails; this.TotalTokens = totalTokens; this.CacheTokensDetails = cacheTokensDetails; - this.PromptTokensDetails = promptTokensDetails; - 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 0d6a0782..ed4a4e7e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class CustomLongRunningOperation { /// - /// 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). /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// /// 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`. @@ -21,16 +21,16 @@ public sealed partial class CustomLongRunningOperation public object? Response { get; set; } /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } + [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). + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } /// /// 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. @@ -47,18 +47,18 @@ public sealed partial class CustomLongRunningOperation /// /// Initializes a new instance of the class. /// - /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// + /// + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// @@ -66,16 +66,16 @@ public sealed partial class CustomLongRunningOperation [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( - string? name, + global::Google.Gemini.Status? error, object? response, + string? name, object? metadata, - global::Google.Gemini.Status? error, bool? done) { - this.Name = name; + this.Error = error; this.Response = response; + this.Name = name; this.Metadata = metadata; - this.Error = error; this.Done = done; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs index 1ff420e8..037ed548 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 @@ -9,16 +9,16 @@ namespace Google.Gemini public sealed partial class CustomMetadata { /// - /// 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; } /// - /// Required. The key of the metadata to store. + /// The numeric value of the metadata to store. /// - [global::System.Text.Json.Serialization.JsonPropertyName("key")] - public string? Key { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] + public float? NumericValue { get; set; } /// /// 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. + /// Required. The key 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("key")] + public string? Key { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -41,31 +41,31 @@ public sealed partial class CustomMetadata /// /// Initializes a new instance of the class. /// + /// + /// User provided string values assigned to a single metadata key. + /// /// /// The numeric value of the metadata to store. /// - /// - /// Required. The key of the metadata to store. - /// /// /// The string value of the metadata to store. /// - /// - /// User provided string values assigned to a single metadata key. + /// + /// Required. The key of the metadata to store. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomMetadata( + global::Google.Gemini.StringList? stringListValue, float? numericValue, - string? key, string? stringValue, - global::Google.Gemini.StringList? stringListValue) + string? key) { + this.StringListValue = stringListValue; this.NumericValue = numericValue; - this.Key = key; this.StringValue = stringValue; - this.StringListValue = stringListValue; + this.Key = key; } /// 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 1d5827ba..cb5c9b13 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,31 +9,32 @@ namespace Google.Gemini public sealed partial class Document { /// - /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` + /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } /// - /// Output only. The size of raw bytes ingested into the Document.
+ /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. The mime type of the Document.
+ /// Output only. Current state of the `Document`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] + public global::Google.Gemini.DocumentState? State { get; set; } /// - /// 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; } /// /// 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" @@ -42,25 +43,24 @@ public sealed partial class Document public string? DisplayName { get; set; } /// - /// Output only. Current state of the `Document`.
- /// Included only in responses + /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` ///
- [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; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + /// Output only. The size of raw bytes ingested into the Document.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// - /// Output only. The Timestamp of when the `Document` was created.
+ /// Output only. The mime type of the Document.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -71,56 +71,56 @@ public sealed partial class Document /// /// Initializes a new instance of the class. /// - /// - /// 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` + /// + /// 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.
+ /// + /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses /// - /// - /// Output only. The mime type of the Document.
+ /// + /// Output only. Current state of the `Document`.
/// Included only in responses /// - /// - /// 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 /// /// /// 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 + /// + /// 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` /// - /// - /// 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.
+ /// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Document` was created.
+ /// + /// Output only. The mime type of the Document.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( - string? name, - string? sizeBytes, - string? mimeType, + global::System.Collections.Generic.IList? customMetadata, string? updateTime, - string? displayName, global::Google.Gemini.DocumentState? state, - global::System.Collections.Generic.IList? customMetadata, - string? createTime) + string? createTime, + string? displayName, + string? name, + string? sizeBytes, + string? mimeType) { - this.Name = name; - this.SizeBytes = sizeBytes; - this.MimeType = mimeType; + this.CustomMetadata = customMetadata; this.UpdateTime = updateTime; - this.DisplayName = displayName; this.State = state; - this.CustomMetadata = customMetadata; this.CreateTime = createTime; + this.DisplayName = displayName; + this.Name = name; + this.SizeBytes = sizeBytes; + this.MimeType = mimeType; } /// 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 d10eeb34..e455116e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs @@ -9,38 +9,29 @@ namespace Google.Gemini public sealed partial class EmbedContentBatch { /// - /// Configures the input to the batch request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] - public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } - - /// - /// Required. The user-defined name of this batch. + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Output only. The state of the batch.
- /// Included only in responses + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] - public global::Google.Gemini.EmbedContentBatchState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// - /// 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. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Output only. The time at which the batch was last updated.
@@ -50,22 +41,19 @@ public sealed partial class EmbedContentBatch public string? UpdateTime { get; set; } /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.EmbedContentBatchOutput? Output { 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. + /// Output only. The state of the batch.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] + public global::Google.Gemini.EmbedContentBatchState? State { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// Output only. The time at which the batch was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Stats about the batch. @@ -74,11 +62,23 @@ public sealed partial class EmbedContentBatch public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } /// - /// Output only. The time at which the batch processing completed.
+ /// 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("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// Configures the input to the batch request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] + public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -89,71 +89,71 @@ public sealed partial class EmbedContentBatch /// /// Initializes a new instance of the class. /// - /// - /// Configures the input to the batch request. - /// - /// - /// Required. The user-defined name of this batch. - /// - /// - /// Output only. The state of the batch.
+ /// + /// Output only. The time at which the batch processing completed.
/// Included only in responses /// - /// - /// Output only. The time at which the batch was created.
- /// Included only in responses + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Output only. The time at which the batch was last updated.
/// 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. + /// + /// Output only. The state of the batch.
+ /// Included only in responses /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Output only. The time at which the batch was created.
+ /// Included only in responses /// /// /// Stats about the batch. /// - /// - /// Output only. The time at which the batch processing completed.
+ /// + /// Required. The user-defined name of this batch. + /// + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// + /// + /// Configures the input to the batch request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( - global::Google.Gemini.InputEmbedContentConfig? inputConfig, - string? displayName, - global::Google.Gemini.EmbedContentBatchState? state, - string? createTime, - string? name, - string? updateTime, - global::Google.Gemini.EmbedContentBatchOutput? output, + string? endTime, string? priority, + global::Google.Gemini.EmbedContentBatchOutput? output, string? model, + string? updateTime, + global::Google.Gemini.EmbedContentBatchState? state, + string? createTime, global::Google.Gemini.EmbedContentBatchStats? batchStats, - string? endTime) + string? displayName, + string? name, + global::Google.Gemini.InputEmbedContentConfig? inputConfig) { - this.InputConfig = inputConfig; - this.DisplayName = displayName; - this.State = state; - this.CreateTime = createTime; - this.Name = name; - this.UpdateTime = updateTime; - this.Output = output; + this.EndTime = endTime; this.Priority = priority; + this.Output = output; this.Model = model; + this.UpdateTime = updateTime; + this.State = state; + this.CreateTime = createTime; this.BatchStats = batchStats; - this.EndTime = endTime; + this.DisplayName = displayName; + this.Name = name; + this.InputConfig = inputConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs index de6eaccb..f4312aaa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchOutput.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class EmbedContentBatchOutput { - /// - /// The responses to the requests in the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] - public global::Google.Gemini.InlinedEmbedContentResponses? InlinedResponses { get; set; } - /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses @@ -21,6 +15,12 @@ public sealed partial class EmbedContentBatchOutput [global::System.Text.Json.Serialization.JsonPropertyName("responsesFile")] public string? ResponsesFile { get; set; } + /// + /// The responses to the requests in the batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] + public global::Google.Gemini.InlinedEmbedContentResponses? InlinedResponses { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class EmbedContentBatchOutput /// /// Initializes a new instance of the class. /// - /// - /// The responses to the requests in the batch. - /// /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses /// + /// + /// The responses to the requests in the batch. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchOutput( - global::Google.Gemini.InlinedEmbedContentResponses? inlinedResponses, - string? responsesFile) + string? responsesFile, + global::Google.Gemini.InlinedEmbedContentResponses? inlinedResponses) { - this.InlinedResponses = inlinedResponses; this.ResponsesFile = responsesFile; + this.InlinedResponses = inlinedResponses; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs index 9d780df3..808cd82f 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 @@ -23,18 +23,18 @@ public sealed partial class EmbedContentBatchStats public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] + public string? PendingRequestCount { get; set; } /// - /// 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 @@ -53,27 +53,27 @@ public sealed partial class EmbedContentBatchStats /// Output only. The number of requests that were successfully processed.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - /// /// /// Output only. The number of requests that are still pending processing.
/// 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? failedRequestCount) { this.RequestCount = requestCount; this.SuccessfulRequestCount = successfulRequestCount; - this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; + 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 64719a26..70e3f4b1 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,22 +9,23 @@ namespace Google.Gemini public sealed partial class EmbedContentConfig { /// - /// Optional. Whether to enable OCR for document content. + /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. /// - [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] - public bool? DocumentOcr { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] + public bool? AutoTruncate { get; set; } /// - /// Optional. Whether to extract audio from video content. + /// Optional. The task type of the embedding. /// - [global::System.Text.Json.Serialization.JsonPropertyName("audioTrackExtraction")] - public bool? AudioTrackExtraction { 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 silently truncate the input content if it's longer than the maximum sequence length. + /// Optional. The title for the text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] - public bool? AutoTruncate { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. @@ -33,17 +34,16 @@ public sealed partial class EmbedContentConfig 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. The title for the text. + /// Optional. Whether to extract audio from video content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("audioTrackExtraction")] + public bool? AudioTrackExtraction { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -54,41 +54,41 @@ public sealed partial class EmbedContentConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Whether to enable OCR for document content. - /// - /// - /// Optional. Whether to extract audio from video content. - /// /// /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. /// - /// - /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. - /// /// /// Optional. The task type of the embedding. /// /// /// 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. + /// + /// + /// Optional. Whether to enable OCR for document content. + /// + /// + /// Optional. Whether to extract audio from video content. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentConfig( - bool? documentOcr, - bool? audioTrackExtraction, bool? autoTruncate, - int? outputDimensionality, global::Google.Gemini.EmbedContentConfigTaskType? taskType, - string? title) + string? title, + int? outputDimensionality, + bool? documentOcr, + bool? audioTrackExtraction) { - this.DocumentOcr = documentOcr; - this.AudioTrackExtraction = audioTrackExtraction; this.AutoTruncate = autoTruncate; - this.OutputDimensionality = outputDimensionality; this.TaskType = taskType; this.Title = title; + this.OutputDimensionality = outputDimensionality; + this.DocumentOcr = documentOcr; + this.AudioTrackExtraction = audioTrackExtraction; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs index 51bf3523..d56eec99 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 @@ -16,18 +16,6 @@ public sealed partial class EmbedContentRequest [global::System.Text.Json.Serialization.JsonPropertyName("model")] public string? Model { get; set; } - /// - /// Configurations for the EmbedContent request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] - public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } - - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { get; set; } - /// /// Optional. Deprecated: Please use EmbedContentConfig.title instead. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// @@ -42,6 +30,12 @@ public sealed partial class EmbedContentRequest [global::System.Obsolete("This property marked as deprecated.")] public int? OutputDimensionality { get; set; } + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("content")] + public global::Google.Gemini.Content? Content { get; set; } + /// /// Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). /// @@ -50,6 +44,12 @@ public sealed partial class EmbedContentRequest [global::System.Obsolete("This property marked as deprecated.")] public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } + /// + /// Configurations for the EmbedContent request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] + public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -62,23 +62,23 @@ public sealed partial class EmbedContentRequest /// /// 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. - /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// + /// + /// Configurations for the EmbedContent request. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( string? model, - global::Google.Gemini.EmbedContentConfig? embedContentConfig, - global::Google.Gemini.Content? content) + global::Google.Gemini.Content? content, + global::Google.Gemini.EmbedContentConfig? embedContentConfig) { this.Model = model; - this.EmbedContentConfig = embedContentConfig; this.Content = content; + this.EmbedContentConfig = embedContentConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs index 358665ad..b4676a70 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class ExecutableCode { - /// - /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Required. Programming language of the `code`. /// @@ -21,6 +15,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; } + /// + /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Required. The code to be executed. /// @@ -36,12 +36,12 @@ public sealed partial class ExecutableCode /// /// Initializes a new instance of the class. /// - /// - /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. - /// /// /// Required. Programming language of the `code`. /// + /// + /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. + /// /// /// Required. The code to be executed. /// @@ -49,12 +49,12 @@ public sealed partial class ExecutableCode [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ExecutableCode( - string? id, global::Google.Gemini.ExecutableCodeLanguage? language, + string? id, string? code) { - this.Id = id; this.Language = language; + this.Id = id; 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 25d6240a..4fd3ae7d 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 @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class File { - /// - /// Output only. Size of the file in bytes.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { 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` /// @@ -22,45 +15,44 @@ public sealed partial class File public string? Name { get; set; } /// - /// Output only. The uri of the `File`.
+ /// Output only. Size of the file in bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// - /// Output only. The timestamp of when the `File` was created.
+ /// 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("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] + public string? ExpirationTime { get; set; } /// - /// Source of the File. + /// Output only. SHA-256 hash of the uploaded bytes.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("source")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] - public global::Google.Gemini.FileSource? Source { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] + public byte[]? Sha256Hash { get; set; } /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// Output only. MIME type of the file.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// - /// Output only. The timestamp of when the `File` was last updated.
- /// Included only in responses + /// Metadata for a video `File`. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } /// - /// Output only. SHA-256 hash of the uploaded bytes.
- /// Included only in responses + /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] - public byte[]? Sha256Hash { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Output only. The download uri of the `File`.
@@ -70,38 +62,46 @@ public sealed partial class File public string? DownloadUri { get; set; } /// - /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// Output only. The uri of the `File`.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// - /// Output only. Processing state of the File.
- /// Included only in responses + /// Source of the File. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] - public global::Google.Gemini.FileState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("source")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] + public global::Google.Gemini.FileSource? Source { get; set; } /// - /// Metadata for a video `File`. + /// Output only. The timestamp of when the `File` was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Output only. MIME type of the file.
+ /// Output only. The timestamp of when the `File` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// Output only. Processing state of the File.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] - public string? ExpirationTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] + public global::Google.Gemini.FileState? State { get; set; } + + /// + /// 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 @@ -112,90 +112,90 @@ public sealed partial class File /// /// Initializes a new instance of the class. /// - /// - /// Output only. Size of the file in bytes.
- /// Included only in responses - /// /// /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` /// - /// - /// Output only. The uri of the `File`.
- /// Included only in responses - /// - /// - /// Output only. The timestamp of when the `File` was created.
+ /// + /// Output only. Size of the file in bytes.
/// Included only in responses /// - /// - /// Source of the File. - /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - /// - /// Output only. The timestamp of when the `File` was last updated.
+ /// + /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
/// Included only in responses /// /// /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses /// - /// - /// Output only. The download uri of the `File`.
+ /// + /// Output only. MIME type of the file.
/// Included only in responses /// + /// + /// Metadata for a video `File`. + /// /// /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" /// - /// - /// Output only. Processing state of the File.
+ /// + /// Output only. The download uri of the `File`.
/// Included only in responses /// - /// - /// Metadata for a video `File`. + /// + /// Output only. The uri of the `File`.
+ /// Included only in responses /// - /// - /// Output only. MIME type of the file.
+ /// + /// Source of the File. + /// + /// + /// Output only. The timestamp of when the `File` was created.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// + /// Output only. The timestamp of when the `File` was last updated.
/// Included only in responses /// + /// + /// Output only. Processing state of the File.
+ /// 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 File( - string? sizeBytes, string? name, + string? sizeBytes, + string? expirationTime, + byte[]? sha256Hash, + string? mimeType, + global::Google.Gemini.VideoFileMetadata? videoMetadata, + string? displayName, + string? downloadUri, string? uri, - string? createTime, global::Google.Gemini.FileSource? source, - global::Google.Gemini.Status? error, + string? createTime, string? updateTime, - byte[]? sha256Hash, - string? downloadUri, - string? displayName, global::Google.Gemini.FileState? state, - global::Google.Gemini.VideoFileMetadata? videoMetadata, - string? mimeType, - string? expirationTime) + global::Google.Gemini.Status? error) { - this.SizeBytes = sizeBytes; this.Name = name; + this.SizeBytes = sizeBytes; + this.ExpirationTime = expirationTime; + this.Sha256Hash = sha256Hash; + this.MimeType = mimeType; + this.VideoMetadata = videoMetadata; + this.DisplayName = displayName; + this.DownloadUri = downloadUri; this.Uri = uri; - this.CreateTime = createTime; this.Source = source; - this.Error = error; + this.CreateTime = createTime; this.UpdateTime = updateTime; - this.Sha256Hash = sha256Hash; - this.DownloadUri = downloadUri; - this.DisplayName = displayName; this.State = state; - this.VideoMetadata = videoMetadata; - this.MimeType = mimeType; - this.ExpirationTime = expirationTime; + this.Error = error; } /// 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 622cf6d6..9d971733 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class FileSearch { + /// + /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStoreNames")] + public global::System.Collections.Generic.IList? FileSearchStoreNames { get; set; } + /// /// Optional. The number of semantic retrieval chunks to retrieve. /// @@ -20,12 +26,6 @@ public sealed partial class FileSearch [global::System.Text.Json.Serialization.JsonPropertyName("metadataFilter")] public string? MetadataFilter { get; set; } - /// - /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStoreNames")] - public global::System.Collections.Generic.IList? FileSearchStoreNames { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class FileSearch /// /// Initializes a new instance of the class. /// + /// + /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` + /// /// /// Optional. The number of semantic retrieval chunks to retrieve. /// /// /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. /// - /// - /// Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123` - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearch( + global::System.Collections.Generic.IList? fileSearchStoreNames, int? topK, - string? metadataFilter, - global::System.Collections.Generic.IList? fileSearchStoreNames) + string? metadataFilter) { + this.FileSearchStoreNames = fileSearchStoreNames; this.TopK = topK; this.MetadataFilter = metadataFilter; - this.FileSearchStoreNames = fileSearchStoreNames; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs index 66965a20..ce8d4783 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,17 +9,11 @@ namespace Google.Gemini public sealed partial class FileSearchStore { /// - /// 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; } - - /// - /// 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; } + [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] + public string? ActiveDocumentsCount { get; set; } /// /// Output only. The number of documents in the `FileSearchStore` that are being processed.
@@ -28,6 +22,13 @@ public sealed partial class FileSearchStore [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.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + /// /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
/// Included only in responses @@ -36,18 +37,16 @@ public sealed partial class FileSearchStore public string? SizeBytes { get; set; } /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
- /// Included only in responses + /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
- /// Included only in responses + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] - public string? FailedDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] + public string? EmbeddingModel { get; set; } /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
@@ -57,17 +56,18 @@ public sealed partial class FileSearchStore public string? CreateTime { get; set; } /// - /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] - public string? ActiveDocumentsCount { 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 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 /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. - /// /// /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses /// - /// - /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
- /// Included only in responses - /// /// /// Output only. 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 number of documents in the `FileSearchStore` that have failed processing.
+ /// + /// 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" + /// + /// + /// 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 created.
/// 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 Timestamp of when the `FileSearchStore` was last updated.
+ /// Included only in responses /// - /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearchStore( - string? updateTime, - string? embeddingModel, + string? activeDocumentsCount, string? pendingDocumentsCount, - string? sizeBytes, string? name, - string? failedDocumentsCount, - string? createTime, + string? sizeBytes, string? displayName, - string? activeDocumentsCount) + string? embeddingModel, + string? createTime, + string? updateTime, + string? failedDocumentsCount) { - this.UpdateTime = updateTime; - this.EmbeddingModel = embeddingModel; + this.ActiveDocumentsCount = activeDocumentsCount; this.PendingDocumentsCount = pendingDocumentsCount; - this.SizeBytes = sizeBytes; this.Name = name; - this.FailedDocumentsCount = failedDocumentsCount; - this.CreateTime = createTime; + this.SizeBytes = sizeBytes; this.DisplayName = displayName; - this.ActiveDocumentsCount = activeDocumentsCount; + this.EmbeddingModel = embeddingModel; + this.CreateTime = createTime; + this.UpdateTime = updateTime; + this.FailedDocumentsCount = failedDocumentsCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs index f039747f..aeca76b6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCall.g.cs @@ -14,18 +14,18 @@ public sealed partial class FunctionCall [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Optional. The function parameters and values in JSON object format. /// [global::System.Text.Json.Serialization.JsonPropertyName("args")] public object? Args { get; set; } + /// + /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class FunctionCall /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// - /// - /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. - /// /// /// Optional. The function parameters and values in JSON object format. /// + /// + /// Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionCall( string? name, - string? id, - object? args) + object? args, + string? id) { this.Name = name; - this.Id = id; this.Args = args; + this.Id = id; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCallingConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCallingConfig.g.cs index a03827d5..7f933512 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCallingConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionCallingConfig.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class FunctionCallingConfig { + /// + /// 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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("allowedFunctionNames")] + public global::System.Collections.Generic.IList? AllowedFunctionNames { get; set; } + /// /// Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO. /// @@ -15,12 +21,6 @@ public sealed partial class FunctionCallingConfig [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter))] public global::Google.Gemini.FunctionCallingConfigMode? Mode { get; set; } - /// - /// 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("allowedFunctionNames")] - public global::System.Collections.Generic.IList? AllowedFunctionNames { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class FunctionCallingConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO. - /// /// /// 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. /// + /// + /// Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionCallingConfig( - global::Google.Gemini.FunctionCallingConfigMode? mode, - global::System.Collections.Generic.IList? allowedFunctionNames) + global::System.Collections.Generic.IList? allowedFunctionNames, + global::Google.Gemini.FunctionCallingConfigMode? mode) { - this.Mode = mode; this.AllowedFunctionNames = allowedFunctionNames; + this.Mode = mode; } /// 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 3d4e41d8..4a8da013 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,10 +9,10 @@ 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. + /// Required. A brief description of the function. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { 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`. @@ -20,6 +20,12 @@ public sealed partial class FunctionDeclaration [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] public object? ResponseJsonSchema { get; set; } + /// + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { 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). /// @@ -27,16 +33,16 @@ public sealed partial class FunctionDeclaration public global::Google.Gemini.Schema? Response { 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("parameters")] - public global::Google.Gemini.Schema? Parameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] + public object? ParametersJsonSchema { 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("parameters")] + public global::Google.Gemini.Schema? Parameters { get; set; } /// /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. @@ -45,12 +51,6 @@ public sealed partial class FunctionDeclaration [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } - /// - /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] - public object? ParametersJsonSchema { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -60,46 +60,46 @@ public sealed partial class FunctionDeclaration /// /// Initializes a new instance of the class. /// - /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// + /// Required. A brief description of the function. /// /// /// 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. + /// /// /// 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`. + /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - /// - /// Required. A brief description of the function. - /// /// /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// - /// - /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( - string? name, + string? description, object? responseJsonSchema, + string? name, global::Google.Gemini.Schema? response, + object? parametersJsonSchema, global::Google.Gemini.Schema? parameters, - string? description, - global::Google.Gemini.FunctionDeclarationBehavior? behavior, - object? parametersJsonSchema) + global::Google.Gemini.FunctionDeclarationBehavior? behavior) { - this.Name = name; + this.Description = description; this.ResponseJsonSchema = responseJsonSchema; + this.Name = name; this.Response = response; + this.ParametersJsonSchema = parametersJsonSchema; this.Parameters = parameters; - this.Description = description; this.Behavior = behavior; - this.ParametersJsonSchema = parametersJsonSchema; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs index 119f283d..df6ca316 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class FunctionResponse { - /// - /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("willContinue")] - public bool? WillContinue { get; set; } - /// /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// @@ -21,10 +15,17 @@ public sealed partial class FunctionResponse 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. + /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("willContinue")] + public bool? WillContinue { get; set; } + + /// + /// Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("scheduling")] + [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. @@ -39,11 +40,10 @@ public sealed partial class FunctionResponse public string? Name { get; set; } /// - /// Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. + /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. /// - [global::System.Text.Json.Serialization.JsonPropertyName("scheduling")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter))] - public global::Google.Gemini.FunctionResponseScheduling? Scheduling { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -54,14 +54,14 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// - /// - /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. - /// /// /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// - /// - /// 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. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. + /// + /// + /// Optional. 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. @@ -69,26 +69,26 @@ 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. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. + /// + /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( - bool? willContinue, string? id, - object? response, + bool? willContinue, + global::Google.Gemini.FunctionResponseScheduling? scheduling, global::System.Collections.Generic.IList? parts, string? name, - global::Google.Gemini.FunctionResponseScheduling? scheduling) + object? response) { - this.WillContinue = willContinue; this.Id = id; - this.Response = response; + this.WillContinue = willContinue; + this.Scheduling = scheduling; this.Parts = parts; this.Name = name; - this.Scheduling = scheduling; + this.Response = response; } /// 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 b158ec74..6699ef8a 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,11 +9,10 @@ namespace Google.Gemini public sealed partial class GenerateContentBatch { /// - /// Output only. The time at which the batch processing completed.
- /// Included only in responses + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. @@ -22,43 +21,45 @@ public sealed partial class GenerateContentBatch public string? Model { get; set; } /// - /// Stats about the batch. + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.BatchStats? BatchStats { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// Output only. The state of the batch.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter))] + public global::Google.Gemini.GenerateContentBatchState? State { get; set; } /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// Output only. The time at which the batch was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Output only. The time at which the batch was last updated.
- /// Included only in responses + /// Stats about the batch. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [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}`.
+ /// Output only. The time at which the batch processing completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { 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; } /// /// Required. The user-defined name of this batch. @@ -67,12 +68,11 @@ public sealed partial class GenerateContentBatch public string? DisplayName { get; set; } /// - /// Output only. The state of the batch.
+ /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter))] - public global::Google.Gemini.GenerateContentBatchState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Configures the input to the batch request. @@ -89,39 +89,39 @@ 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 - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Stats about the batch. - /// /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Output only. The time at which the batch was last updated.
/// Included only in responses /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// + /// Output only. The state of the batch.
/// Included only in responses /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// + /// + /// Stats about the batch. + /// + /// + /// 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 user-defined name of this batch. /// - /// - /// Output only. The state of the batch.
+ /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// /// @@ -131,28 +131,28 @@ public sealed partial class GenerateContentBatch [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( - string? endTime, - string? model, - global::Google.Gemini.BatchStats? batchStats, global::Google.Gemini.GenerateContentBatchOutput? output, - string? priority, + string? model, string? updateTime, - string? name, + global::Google.Gemini.GenerateContentBatchState? state, string? createTime, + global::Google.Gemini.BatchStats? batchStats, + string? endTime, + string? priority, string? displayName, - global::Google.Gemini.GenerateContentBatchState? state, + string? name, global::Google.Gemini.InputConfig? inputConfig) { - this.EndTime = endTime; - this.Model = model; - this.BatchStats = batchStats; this.Output = output; - this.Priority = priority; + this.Model = model; this.UpdateTime = updateTime; - this.Name = name; + this.State = state; this.CreateTime = createTime; + this.BatchStats = batchStats; + this.EndTime = endTime; + this.Priority = priority; this.DisplayName = displayName; - this.State = state; + this.Name = name; this.InputConfig = inputConfig; } 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 93dd3a12..5a8a3b66 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,6 +8,24 @@ namespace Google.Gemini /// public sealed partial class GenerateContentRequest { + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } + + /// + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } + + /// + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] + public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } + /// /// 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}` /// @@ -15,16 +33,16 @@ public sealed partial class GenerateContentRequest public string? CachedContent { get; set; } /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } + [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. + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] - public global::System.Collections.Generic.IList? SafetySettings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] + public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. @@ -33,16 +51,10 @@ public sealed partial class GenerateContentRequest public bool? Store { get; set; } /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] - public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } - - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// Optional. 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("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] + public global::System.Collections.Generic.IList? SafetySettings { get; set; } /// /// Optional. The service tier of the request. @@ -57,18 +69,6 @@ public sealed partial class GenerateContentRequest [global::System.Text.Json.Serialization.JsonPropertyName("contents")] public global::System.Collections.Generic.IList? Contents { 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; } - - /// - /// 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 /// @@ -78,23 +78,29 @@ public sealed partial class GenerateContentRequest /// /// 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. + /// + /// + /// 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}` /// - /// - /// 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 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. - /// - /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. @@ -102,37 +108,31 @@ 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. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentRequest( - string? cachedContent, global::Google.Gemini.Content? systemInstruction, - global::System.Collections.Generic.IList? safetySettings, - bool? store, - global::Google.Gemini.GenerationConfig? generationConfig, global::System.Collections.Generic.IList? tools, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, - global::System.Collections.Generic.IList? contents, + global::Google.Gemini.GenerationConfig? generationConfig, + string? cachedContent, string? model, - global::Google.Gemini.ToolConfig? toolConfig) + global::Google.Gemini.ToolConfig? toolConfig, + bool? store, + global::System.Collections.Generic.IList? safetySettings, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, + global::System.Collections.Generic.IList? contents) { - this.CachedContent = cachedContent; this.SystemInstruction = systemInstruction; - this.SafetySettings = safetySettings; - this.Store = store; - this.GenerationConfig = generationConfig; this.Tools = tools; - this.ServiceTier = serviceTier; - this.Contents = contents; + this.GenerationConfig = generationConfig; + this.CachedContent = cachedContent; this.Model = model; this.ToolConfig = toolConfig; + this.Store = store; + this.SafetySettings = safetySettings; + this.ServiceTier = serviceTier; + this.Contents = contents; } /// 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 d6e53c84..1c0fe35e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs @@ -9,30 +9,36 @@ namespace Google.Gemini public sealed partial class GenerateContentResponse { /// - /// Output only. The model version used to generate the response.
+ /// Output only. response_id is used to identify each response.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("modelVersion")] - public string? ModelVersion { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] + public string? ResponseId { get; set; } /// - /// Candidate responses from the model. + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] - public global::System.Collections.Generic.IList? Candidates { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] + public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } /// - /// Output only. response_id is used to identify each response.
+ /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] + public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } + + /// + /// Output only. The model version used to generate the response.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] - public string? ResponseId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("modelVersion")] + public string? ModelVersion { get; set; } /// - /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. + /// Candidate responses from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] - public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] + public global::System.Collections.Generic.IList? Candidates { get; set; } /// /// Metadata on the generation request's token usage. @@ -40,12 +46,6 @@ public sealed partial class GenerateContentResponse [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; } - /// /// 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. /// - /// - /// Output only. The model version used to generate the response.
- /// Included only in responses - /// - /// - /// Candidate responses from the model. - /// /// /// Output only. response_id is used to identify each response.
/// Included only in responses /// + /// + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. + /// /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// + /// + /// Output only. The model version used to generate the response.
+ /// Included only in responses + /// + /// + /// Candidate responses from the model. + /// /// /// 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. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentResponse( - string? modelVersion, - global::System.Collections.Generic.IList? candidates, string? responseId, + global::Google.Gemini.ModelStatus? modelStatus, global::Google.Gemini.PromptFeedback? promptFeedback, - global::Google.Gemini.UsageMetadata? usageMetadata, - global::Google.Gemini.ModelStatus? modelStatus) + string? modelVersion, + global::System.Collections.Generic.IList? candidates, + global::Google.Gemini.UsageMetadata? usageMetadata) { - this.ModelVersion = modelVersion; - this.Candidates = candidates; this.ResponseId = responseId; + this.ModelStatus = modelStatus; this.PromptFeedback = promptFeedback; + this.ModelVersion = modelVersion; + this.Candidates = candidates; this.UsageMetadata = usageMetadata; - this.ModelStatus = modelStatus; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs index ba1e6221..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 @@ -9,10 +9,16 @@ namespace Google.Gemini public sealed partial class GeneratedFile { /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// MIME type of the generatedFile. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Output only. The state of the GeneratedFile.
@@ -23,16 +29,10 @@ public sealed partial class GeneratedFile public global::Google.Gemini.GeneratedFileState? State { get; set; } /// - /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - - /// - /// 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). /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -43,32 +43,32 @@ public sealed partial class GeneratedFile /// /// Initializes a new instance of the class. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - /// - /// Output only. The state of the GeneratedFile.
- /// Included only in responses - /// /// /// Identifier. The name of the generated file. Example: `generatedFiles/abc-123` /// /// /// MIME type of the generatedFile. /// + /// + /// Output only. The state of the GeneratedFile.
+ /// Included only in responses + /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GeneratedFile( - global::Google.Gemini.Status? error, - global::Google.Gemini.GeneratedFileState? state, string? name, - string? mimeType) + string? mimeType, + global::Google.Gemini.GeneratedFileState? state, + global::Google.Gemini.Status? error) { - this.Error = error; - this.State = state; this.Name = name; this.MimeType = mimeType; + 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 6d84bfc7..8ae3e6ce 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,34 +9,34 @@ namespace Google.Gemini public sealed partial class GenerationConfig { /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] - public int? CandidateCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] + public int? MaxOutputTokens { get; set; } /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// Optional. 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("enableEnhancedCivicAnswers")] - public bool? EnableEnhancedCivicAnswers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { 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 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("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// Config for speech generation and transcription. + /// 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("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] + public int? Logprobs { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// 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("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// /// Config for translation features. @@ -44,12 +44,6 @@ public sealed partial class GenerationConfig [global::System.Text.Json.Serialization.JsonPropertyName("translationConfig")] public global::Google.Gemini.TranslationConfig? TranslationConfig { get; set; } - /// - /// Config for image generation features. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] - public global::Google.Gemini.ImageConfig? ImageConfig { 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. /// @@ -57,34 +51,28 @@ public sealed partial class GenerationConfig public string? ResponseMimeType { get; set; } /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("seed")] - public int? Seed { 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. + /// 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("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] + public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { 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. + /// 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("presencePenalty")] - public float? PresencePenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] + public global::Google.Gemini.Schema? ResponseSchema { 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. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] - public float? FrequencyPenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("seed")] + public int? Seed { get; set; } /// /// Optional. If specified, the media resolution specified will be used. @@ -94,52 +82,64 @@ public sealed partial class GenerationConfig public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } /// - /// Config for thinking features. + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } /// - /// Optional. If true, export the logprobs results in response. + /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseLogprobs")] - public bool? ResponseLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] + public global::System.Collections.Generic.IList? ResponseModalities { get; set; } /// - /// Optional. 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. 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("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] + public float? PresencePenalty { get; set; } /// - /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. + /// Optional. 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("maxOutputTokens")] - public int? MaxOutputTokens { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] + public int? CandidateCount { 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). + /// Config for speech generation and transcription. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] - public global::Google.Gemini.Schema? ResponseSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// Optional. 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("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// - /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. + /// Config for image generation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] - public global::System.Collections.Generic.IList? ResponseModalities { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] + public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } /// - /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] - public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] + public float? FrequencyPenalty { get; set; } + + /// + /// Optional. If true, export the logprobs results in response. + /// + [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] + public bool? EnableEnhancedCivicAnswers { 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. 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. Enables enhanced civic answers. It may not be available for all models. + /// + /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. /// - /// - /// Optional. The 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 number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - /// - /// Config for speech generation and transcription. + /// + /// Optional. 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. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. /// /// /// Config for translation features. /// - /// - /// Config for image generation features. - /// /// /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. /// - /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. - /// - /// - /// 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. + /// + /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. /// - /// - /// 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. + /// + /// 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. 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. /// - /// - /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. + /// + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// /// /// Optional. If specified, the media resolution specified will be used. /// - /// - /// Config for thinking features. + /// + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - /// - /// Optional. If true, export the logprobs results in response. + /// + /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// - /// - /// Optional. 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. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. /// - /// - /// Optional. The maximum number of tokens to 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. 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) /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// Config for speech generation and transcription. /// - /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// + /// Optional. The maximum 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 requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. + /// + /// Config for image generation features. /// - /// - /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. + /// + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. + /// + /// + /// Optional. If true, export the logprobs results in response. + /// + /// + /// Optional. Enables enhanced civic answers. It may not be available for all models. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - int? candidateCount, - bool? enableEnhancedCivicAnswers, + int? maxOutputTokens, + float? temperature, + int? topK, + int? logprobs, global::System.Collections.Generic.IList? stopSequences, - global::Google.Gemini.SpeechConfig? speechConfig, - object? responseJsonSchema, global::Google.Gemini.TranslationConfig? translationConfig, - global::Google.Gemini.ImageConfig? imageConfig, string? responseMimeType, + global::Google.Gemini.ResponseFormatConfig? responseFormat, + global::Google.Gemini.Schema? responseSchema, + global::Google.Gemini.ThinkingConfig? thinkingConfig, int? seed, - float? topP, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + object? responseJsonSchema, + global::System.Collections.Generic.IList? responseModalities, float? presencePenalty, - int? logprobs, + int? candidateCount, + global::Google.Gemini.SpeechConfig? speechConfig, + float? topP, + global::Google.Gemini.ImageConfig? imageConfig, float? frequencyPenalty, - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, - global::Google.Gemini.ThinkingConfig? thinkingConfig, bool? responseLogprobs, - float? temperature, - int? maxOutputTokens, - global::Google.Gemini.Schema? responseSchema, - int? topK, - global::System.Collections.Generic.IList? responseModalities, - global::Google.Gemini.ResponseFormatConfig? responseFormat) + bool? enableEnhancedCivicAnswers) { - this.CandidateCount = candidateCount; - this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; + this.MaxOutputTokens = maxOutputTokens; + this.Temperature = temperature; + this.TopK = topK; + this.Logprobs = logprobs; this.StopSequences = stopSequences; - this.SpeechConfig = speechConfig; - this.ResponseJsonSchema = responseJsonSchema; this.TranslationConfig = translationConfig; - this.ImageConfig = imageConfig; this.ResponseMimeType = responseMimeType; + this.ResponseFormat = responseFormat; + this.ResponseSchema = responseSchema; + this.ThinkingConfig = thinkingConfig; this.Seed = seed; - this.TopP = topP; + this.MediaResolution = mediaResolution; + this.ResponseJsonSchema = responseJsonSchema; + this.ResponseModalities = responseModalities; this.PresencePenalty = presencePenalty; - this.Logprobs = logprobs; + this.CandidateCount = candidateCount; + this.SpeechConfig = speechConfig; + this.TopP = topP; + this.ImageConfig = imageConfig; this.FrequencyPenalty = frequencyPenalty; - this.MediaResolution = mediaResolution; - this.ThinkingConfig = thinkingConfig; this.ResponseLogprobs = responseLogprobs; - this.Temperature = temperature; - this.MaxOutputTokens = maxOutputTokens; - this.ResponseSchema = responseSchema; - this.TopK = topK; - this.ResponseModalities = responseModalities; - this.ResponseFormat = responseFormat; + this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; } /// 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 ca7295fb..76f51a2d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs @@ -9,16 +9,11 @@ namespace Google.Gemini public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport { /// - /// 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; } - - /// - /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). + /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunkIndices")] - public global::System.Collections.Generic.IList? GroundingChunkIndices { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] + public global::System.Collections.Generic.IList? RenderedParts { get; set; } /// /// Segment of the content. @@ -27,11 +22,16 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Segment { get; set; } /// - /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
- /// Included only in responses + /// Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] - public global::System.Collections.Generic.IList? RenderedParts { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("confidenceScores")] + public global::System.Collections.Generic.IList? ConfidenceScores { get; set; } + + /// + /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunkIndices")] + public global::System.Collections.Generic.IList? GroundingChunkIndices { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -42,32 +42,32 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// /// Initializes a new instance of the class. /// + /// + /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
+ /// Included only in responses + /// + /// + /// 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. /// /// /// 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). /// - /// - /// Segment of the content. - /// - /// - /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaGroundingSupport( - global::System.Collections.Generic.IList? confidenceScores, - global::System.Collections.Generic.IList? groundingChunkIndices, + global::System.Collections.Generic.IList? renderedParts, global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? segment, - global::System.Collections.Generic.IList? renderedParts) + global::System.Collections.Generic.IList? confidenceScores, + global::System.Collections.Generic.IList? groundingChunkIndices) { + this.RenderedParts = renderedParts; + this.Segment = segment; this.ConfidenceScores = confidenceScores; this.GroundingChunkIndices = groundingChunkIndices; - this.Segment = segment; - this.RenderedParts = renderedParts; } /// 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 84982784..d11d25a6 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,18 +8,18 @@ namespace Google.Gemini /// 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] - public int? StartIndex { get; set; } - /// /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. /// [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] public int? EndIndex { get; set; } + /// + /// The text corresponding to the segment from the response. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } + /// /// The index of a Part object within its parent Content object. /// @@ -27,10 +27,10 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment public int? PartIndex { get; set; } /// - /// The text corresponding to the segment from the response. + /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] + public int? StartIndex { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -41,31 +41,31 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// Initializes a new instance of the class. /// - /// - /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. - /// /// /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. /// + /// + /// The text corresponding to the segment from the response. + /// /// /// The index of a Part object within its parent Content object. /// - /// - /// The text corresponding to the segment from the response. + /// + /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaSegment( - int? startIndex, int? endIndex, + string? text, int? partIndex, - string? text) + int? startIndex) { - this.StartIndex = startIndex; this.EndIndex = endIndex; - this.PartIndex = partIndex; this.Text = text; + this.PartIndex = partIndex; + this.StartIndex = startIndex; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs index 72c07004..74828ec0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GoogleSearch { - /// - /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeRangeFilter")] - public global::Google.Gemini.Interval? TimeRangeFilter { get; set; } - /// /// Different types of search that can be enabled on the GoogleSearch tool. /// [global::System.Text.Json.Serialization.JsonPropertyName("searchTypes")] public global::Google.Gemini.SearchTypes? SearchTypes { get; set; } + /// + /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("timeRangeFilter")] + public global::Google.Gemini.Interval? TimeRangeFilter { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class GoogleSearch /// /// Initializes a new instance of the class. /// - /// - /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. - /// /// /// Different types of search that can be enabled on the GoogleSearch tool. /// + /// + /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleSearch( - global::Google.Gemini.Interval? timeRangeFilter, - global::Google.Gemini.SearchTypes? searchTypes) + global::Google.Gemini.SearchTypes? searchTypes, + global::Google.Gemini.Interval? timeRangeFilter) { - this.TimeRangeFilter = timeRangeFilter; this.SearchTypes = searchTypes; + this.TimeRangeFilter = timeRangeFilter; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs index 97cd54fa..d679dfec 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class GroundingChunk { - /// - /// Chunk from the web. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("web")] - public global::Google.Gemini.Web? Web { get; set; } - - /// - /// Chunk from context retrieved by the file search tool. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievedContext")] - public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } - /// /// Chunk from image search. /// @@ -32,6 +20,18 @@ public sealed partial class GroundingChunk [global::System.Text.Json.Serialization.JsonPropertyName("maps")] public global::Google.Gemini.Maps? Maps { get; set; } + /// + /// Chunk from the web. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("web")] + public global::Google.Gemini.Web? Web { get; set; } + + /// + /// Chunk from context retrieved by the file search tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievedContext")] + public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// - /// - /// Chunk from the web. - /// - /// - /// Chunk from context retrieved by the file search tool. - /// /// /// Chunk from image search. /// /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// + /// + /// Chunk from the web. + /// + /// + /// Chunk from context retrieved by the file search tool. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( - global::Google.Gemini.Web? web, - global::Google.Gemini.RetrievedContext? retrievedContext, global::Google.Gemini.Image? image, - global::Google.Gemini.Maps? maps) + global::Google.Gemini.Maps? maps, + global::Google.Gemini.Web? web, + global::Google.Gemini.RetrievedContext? retrievedContext) { - this.Web = web; - this.RetrievedContext = retrievedContext; this.Image = image; this.Maps = maps; + this.Web = web; + this.RetrievedContext = retrievedContext; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs index b6243540..eb6a73bd 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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GroundingChunkCustomMetadata { - /// - /// Optional. The string value of the metadata. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] - public string? StringValue { get; set; } - /// /// A list of string values. /// @@ -26,6 +20,12 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] public float? NumericValue { get; set; } + /// + /// Optional. The string value of the metadata. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] + public string? StringValue { get; set; } + /// /// The key of the metadata. /// @@ -41,15 +41,15 @@ public sealed partial class GroundingChunkCustomMetadata /// /// Initializes a new instance of the class. /// - /// - /// Optional. The string value of the metadata. - /// /// /// A list of string values. /// /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// + /// + /// Optional. The string value of the metadata. + /// /// /// The key of the metadata. /// @@ -57,14 +57,14 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( - string? stringValue, global::Google.Gemini.GroundingChunkStringList? stringListValue, float? numericValue, + string? stringValue, string? key) { - this.StringValue = stringValue; this.StringListValue = stringListValue; this.NumericValue = numericValue; + this.StringValue = stringValue; 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 96c70922..aa06966a 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 @@ -14,24 +14,6 @@ public sealed partial class GroundingMetadata [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] public global::System.Collections.Generic.IList? ImageSearchQueries { 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; } - - /// - /// Metadata related to retrieval in the grounding flow. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] - public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } - /// /// List of grounding support. /// @@ -50,6 +32,24 @@ public sealed partial class GroundingMetadata [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; } + + /// + /// Metadata related to retrieval in the grounding flow. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] + public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -62,15 +62,6 @@ public sealed partial class GroundingMetadata /// /// Image search queries used for grounding. /// - /// - /// 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. - /// - /// - /// Metadata related to retrieval in the grounding flow. - /// /// /// List of grounding support. /// @@ -80,25 +71,34 @@ public sealed partial class GroundingMetadata /// /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// + /// + /// 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. + /// + /// + /// Metadata related to retrieval in the grounding flow. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingMetadata( global::System.Collections.Generic.IList? imageSearchQueries, - global::Google.Gemini.SearchEntryPoint? searchEntryPoint, - global::System.Collections.Generic.IList? groundingChunks, - global::Google.Gemini.RetrievalMetadata? retrievalMetadata, global::System.Collections.Generic.IList? groundingSupports, global::System.Collections.Generic.IList? webSearchQueries, - string? googleMapsWidgetContextToken) + string? googleMapsWidgetContextToken, + global::Google.Gemini.SearchEntryPoint? searchEntryPoint, + global::System.Collections.Generic.IList? groundingChunks, + global::Google.Gemini.RetrievalMetadata? retrievalMetadata) { this.ImageSearchQueries = imageSearchQueries; - this.SearchEntryPoint = searchEntryPoint; - this.GroundingChunks = groundingChunks; - this.RetrievalMetadata = retrievalMetadata; this.GroundingSupports = groundingSupports; this.WebSearchQueries = webSearchQueries; this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; + this.SearchEntryPoint = searchEntryPoint; + this.GroundingChunks = groundingChunks; + this.RetrievalMetadata = retrievalMetadata; } /// 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 0e2e64fa..6e7a62aa 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 @@ -9,16 +9,10 @@ namespace Google.Gemini public sealed partial class Hyperparameters { /// - /// 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; } - - /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] - public int? BatchSize { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("epochCount")] + public int? EpochCount { 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. @@ -27,10 +21,16 @@ public sealed partial class Hyperparameters 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. + /// 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("epochCount")] - public int? EpochCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("learningRate")] + public float? LearningRate { get; set; } + + /// + /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] + public int? BatchSize { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -41,31 +41,31 @@ public sealed partial class Hyperparameters /// /// Initializes a new instance of the class. /// + /// + /// 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 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. + /// /// /// 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. /// /// /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. /// - /// - /// Optional. Immutable. The learning rate 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. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Hyperparameters( - float? learningRate, - int? batchSize, + int? epochCount, float? learningRateMultiplier, - int? epochCount) + float? learningRate, + int? batchSize) { + this.EpochCount = epochCount; + this.LearningRateMultiplier = learningRateMultiplier; this.LearningRate = learningRate; this.BatchSize = batchSize; - this.LearningRateMultiplier = learningRateMultiplier; - 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 8b77ffb1..da9c30a4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class Image { /// - /// The 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 web page URI for attribution. @@ -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 @@ -41,8 +41,8 @@ public sealed partial class Image /// /// Initializes a new instance of the class. /// - /// - /// 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 web page URI for attribution. @@ -50,22 +50,22 @@ public sealed partial class Image /// /// 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? title, + string? domain, string? sourceUri, string? imageUri, - string? domain) + string? title) { - this.Title = title; + this.Domain = domain; this.SourceUri = sourceUri; this.ImageUri = imageUri; - this.Domain = domain; + 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 85b4c838..5ee4d1e3 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 @@ -9,18 +9,11 @@ namespace Google.Gemini public sealed partial class ImageResponseFormat { /// - /// 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 MIME type of the image output. + /// Optional. The delivery mode for the image output. /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter))] - public global::Google.Gemini.ImageResponseFormatMimeType? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter))] + public global::Google.Gemini.ImageResponseFormatDelivery? Delivery { get; set; } /// /// Optional. The aspect ratio for the image output. @@ -30,11 +23,18 @@ public sealed partial class ImageResponseFormat public global::Google.Gemini.ImageResponseFormatAspectRatio? AspectRatio { get; set; } /// - /// Optional. The delivery mode for the image output. + /// Optional. The MIME type of the image output. /// - [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter))] - public global::Google.Gemini.ImageResponseFormatDelivery? Delivery { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + [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; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,31 +45,31 @@ public sealed partial class ImageResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. The size of the image output. - /// - /// - /// Optional. The MIME type of the image output. + /// + /// Optional. The delivery mode for the image output. /// /// /// Optional. The aspect ratio for the image output. /// - /// - /// Optional. The delivery mode for the image output. + /// + /// Optional. The MIME type of the image output. + /// + /// + /// Optional. The size of the image output. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImageResponseFormat( - global::Google.Gemini.ImageResponseFormatImageSize? imageSize, - global::Google.Gemini.ImageResponseFormatMimeType? mimeType, + global::Google.Gemini.ImageResponseFormatDelivery? delivery, global::Google.Gemini.ImageResponseFormatAspectRatio? aspectRatio, - global::Google.Gemini.ImageResponseFormatDelivery? delivery) + global::Google.Gemini.ImageResponseFormatMimeType? mimeType, + global::Google.Gemini.ImageResponseFormatImageSize? imageSize) { - this.ImageSize = imageSize; - this.MimeType = mimeType; - this.AspectRatio = aspectRatio; this.Delivery = delivery; + this.AspectRatio = aspectRatio; + this.MimeType = mimeType; + this.ImageSize = imageSize; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs index 963b5b19..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 @@ -14,18 +14,18 @@ public sealed partial class ImportFileRequest [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] public string? FileName { get; set; } - /// - /// Custom metadata to be associated with the file. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } + /// + /// Custom metadata to be associated with the file. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class ImportFileRequest /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// + /// + /// Custom metadata to be associated with the file. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( string? fileName, - global::System.Collections.Generic.IList? customMetadata, - global::Google.Gemini.ChunkingConfig? chunkingConfig) + global::Google.Gemini.ChunkingConfig? chunkingConfig, + global::System.Collections.Generic.IList? customMetadata) { this.FileName = fileName; - this.CustomMetadata = customMetadata; this.ChunkingConfig = chunkingConfig; + this.CustomMetadata = customMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs index c4006720..1dc7eb0f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class InlinedEmbedContentResponse { - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// The response to an `EmbedContentRequest`. /// @@ -27,6 +21,12 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,9 +36,6 @@ public sealed partial class InlinedEmbedContentResponse /// /// Initializes a new instance of the class. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// The response to an `EmbedContentRequest`. /// @@ -46,17 +43,20 @@ public sealed partial class InlinedEmbedContentResponse /// Output only. The metadata associated with the request.
/// Included only in responses /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentResponse( - global::Google.Gemini.Status? error, global::Google.Gemini.EmbedContentResponse? response, - object? metadata) + object? metadata, + global::Google.Gemini.Status? error) { - this.Error = error; this.Response = response; this.Metadata = metadata; + this.Error = error; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs index 291135b2..8b0a0b22 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class InlinedResponse { /// - /// 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`. + /// 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("response")] - public global::Google.Gemini.GenerateContentResponse? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// /// Output only. The metadata associated with the request.
@@ -22,10 +22,10 @@ public sealed partial class InlinedResponse public object? Metadata { get; set; } /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.GenerateContentResponse? Response { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -36,27 +36,27 @@ public sealed partial class InlinedResponse /// /// Initializes a new instance of the class. /// - /// - /// 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`. + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// Output only. The metadata associated with the request.
/// Included only in responses /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + /// Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedResponse( - global::Google.Gemini.GenerateContentResponse? response, + global::Google.Gemini.Status? error, object? metadata, - global::Google.Gemini.Status? error) + global::Google.Gemini.GenerateContentResponse? response) { - this.Response = response; - this.Metadata = metadata; this.Error = error; + this.Metadata = metadata; + this.Response = response; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs index 5ce34e69..afe10fd0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class Interval { - /// - /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } - /// /// Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end. /// [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] public string? EndTime { get; set; } + /// + /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Interval /// /// Initializes a new instance of the class. /// - /// - /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. - /// /// /// Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end. /// + /// + /// Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Interval( - string? startTime, - string? endTime) + string? endTime, + string? startTime) { - this.StartTime = startTime; this.EndTime = endTime; + this.StartTime = startTime; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs index 6a5dbdc2..7bff6270 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListCorporaResponse { - /// - /// The returned corpora. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("corpora")] - public global::System.Collections.Generic.IList? Corpora { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned corpora. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("corpora")] + public global::System.Collections.Generic.IList? Corpora { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListCorporaResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned corpora. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned corpora. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCorporaResponse( - global::System.Collections.Generic.IList? corpora, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? corpora) { - this.Corpora = corpora; this.NextPageToken = nextPageToken; + this.Corpora = corpora; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs index 965fc58d..af0c7343 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListFileSearchStoresResponse { - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// The returned rag_stores. /// [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStores")] public global::System.Collections.Generic.IList? FileSearchStores { get; set; } + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] + public string? NextPageToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListFileSearchStoresResponse /// /// Initializes a new instance of the class. /// - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// /// /// The returned rag_stores. /// + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFileSearchStoresResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? fileSearchStores) + global::System.Collections.Generic.IList? fileSearchStores, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.FileSearchStores = fileSearchStores; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs index 31720695..56d16d70 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListFilesResponse { - /// - /// The list of `File`s. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("files")] - public global::System.Collections.Generic.IList? Files { get; set; } - /// /// A token that can be sent as a `page_token` into a subsequent `ListFiles` call. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The list of `File`s. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("files")] + public global::System.Collections.Generic.IList? Files { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListFilesResponse /// /// Initializes a new instance of the class. /// - /// - /// The list of `File`s. - /// /// /// A token that can be sent as a `page_token` into a subsequent `ListFiles` call. /// + /// + /// The list of `File`s. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFilesResponse( - global::System.Collections.Generic.IList? files, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? files) { - this.Files = files; this.NextPageToken = nextPageToken; + this.Files = files; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs index 04f787fa..b6386440 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class ListOperationsResponse { /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("unreachable")] - public global::System.Collections.Generic.IList? Unreachable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("operations")] + public global::System.Collections.Generic.IList? Operations { get; set; } /// /// The standard List next-page token. @@ -21,10 +21,10 @@ public sealed partial class ListOperationsResponse public string? NextPageToken { get; set; } /// - /// A list of operations that matches the specified filter in the request. + /// Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("operations")] - public global::System.Collections.Generic.IList? Operations { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("unreachable")] + public global::System.Collections.Generic.IList? Unreachable { 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. /// - /// - /// 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. /// - /// - /// A list of operations that matches the specified filter in the request. + /// + /// Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListOperationsResponse( - global::System.Collections.Generic.IList? unreachable, + global::System.Collections.Generic.IList? operations, string? nextPageToken, - global::System.Collections.Generic.IList? operations) + global::System.Collections.Generic.IList? unreachable) { - this.Unreachable = unreachable; - this.NextPageToken = nextPageToken; this.Operations = operations; + this.NextPageToken = nextPageToken; + this.Unreachable = unreachable; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListTunedModelsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListTunedModelsResponse.g.cs index 920b8335..3c572fa7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListTunedModelsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListTunedModelsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListTunedModelsResponse { - /// - /// The returned Models. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("tunedModels")] - public global::System.Collections.Generic.IList? TunedModels { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned Models. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tunedModels")] + public global::System.Collections.Generic.IList? TunedModels { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListTunedModelsResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned Models. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned Models. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListTunedModelsResponse( - global::System.Collections.Generic.IList? tunedModels, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? tunedModels) { - this.TunedModels = tunedModels; this.NextPageToken = nextPageToken; + this.TunedModels = tunedModels; } /// 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 926abc0e..1c8dd068 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,18 +8,18 @@ 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("logProbabilitySum")] public float? LogProbabilitySum { 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; } + /// /// Length = total number of decoding steps. /// @@ -35,12 +35,12 @@ 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. The chosen candidates may or may not be in top_candidates. + /// /// /// Length = total number of decoding steps. /// @@ -48,12 +48,12 @@ public sealed partial class LogprobsResult [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResult( - global::System.Collections.Generic.IList? chosenCandidates, float? logProbabilitySum, + global::System.Collections.Generic.IList? chosenCandidates, global::System.Collections.Generic.IList? topCandidates) { - this.ChosenCandidates = chosenCandidates; this.LogProbabilitySum = logProbabilitySum; + this.ChosenCandidates = chosenCandidates; this.TopCandidates = topCandidates; } 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 63dcd47f..0f6ce7d3 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs @@ -9,16 +9,10 @@ namespace Google.Gemini public sealed partial class Maps { /// - /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] - public string? PlaceId { get; set; } - - /// - /// URI reference of the place. + /// Text description of the place answer. /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// /// Title of the place. @@ -26,18 +20,24 @@ public sealed partial class Maps [global::System.Text.Json.Serialization.JsonPropertyName("title")] public string? Title { get; set; } - /// - /// Text description of the place answer. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } - /// /// Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: "does Bar Foo have Wifi" or "is Foo Bar wheelchair accessible?"). Currently we only support review snippets as sources. /// [global::System.Text.Json.Serialization.JsonPropertyName("placeAnswerSources")] public global::Google.Gemini.PlaceAnswerSources? PlaceAnswerSources { get; set; } + /// + /// URI reference of the place. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } + + /// + /// 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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -47,36 +47,36 @@ public sealed partial class Maps /// /// Initializes a new instance of the class. /// - /// - /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. - /// - /// - /// URI reference of the place. + /// + /// Text description of the place answer. /// /// /// Title of the place. /// - /// - /// Text description of the place answer. - /// /// /// 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. + /// + /// + /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Maps( - string? placeId, - string? uri, - string? title, string? text, - global::Google.Gemini.PlaceAnswerSources? placeAnswerSources) + string? title, + global::Google.Gemini.PlaceAnswerSources? placeAnswerSources, + string? uri, + string? placeId) { - this.PlaceId = placeId; - this.Uri = uri; - this.Title = title; this.Text = text; + this.Title = title; this.PlaceAnswerSources = placeAnswerSources; + this.Uri = uri; + this.PlaceId = placeId; } /// 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 81f2890f..a3dd51b0 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 @@ -14,30 +14,24 @@ public sealed partial class Model [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// A short description of the model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } - /// /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. /// [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] public float? Temperature { get; set; } - /// - /// Maximum number of input tokens allowed for this model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] - public int? InputTokenLimit { get; set; } - /// /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. /// [global::System.Text.Json.Serialization.JsonPropertyName("topK")] public int? TopK { get; set; } + /// + /// A short description of the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } + /// /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// @@ -45,34 +39,34 @@ public sealed partial class Model public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("version")] - public string? Version { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] + public float? MaxTemperature { get; set; } /// - /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. + /// For [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("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// - /// Maximum number of output tokens available for this model. + /// Maximum number of input tokens allowed for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] - public int? OutputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] + public int? InputTokenLimit { get; set; } /// - /// Whether the model supports thinking. + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] - public bool? Thinking { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { get; set; } /// - /// 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 name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` @@ -81,10 +75,16 @@ public sealed partial class Model public string? BaseModelId { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] - public float? MaxTemperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// Maximum number of output tokens available for this model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] + public int? OutputTokenLimit { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -98,73 +98,73 @@ public sealed partial class Model /// /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` /// - /// - /// A short description of the model. - /// /// /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. /// - /// - /// Maximum number of input tokens allowed for this 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. /// + /// + /// A short description of the model. + /// /// /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// - /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// + /// The maximum temperature this model can use. /// - /// - /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. + /// + /// For [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. /// - /// - /// Maximum number of output tokens available for this model. + /// + /// Maximum number of input tokens allowed for this model. + /// + /// + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// /// /// Whether the model supports thinking. /// - /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. - /// /// /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// - /// - /// 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. + /// + /// + /// Maximum number of output tokens available for this model. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( string? name, - string? description, float? temperature, - int? inputTokenLimit, int? topK, + string? description, global::System.Collections.Generic.IList? supportedGenerationMethods, + float? maxTemperature, + float? topP, + int? inputTokenLimit, string? version, - string? displayName, - int? outputTokenLimit, bool? thinking, - float? topP, string? baseModelId, - float? maxTemperature) + string? displayName, + int? outputTokenLimit) { this.Name = name; - this.Description = description; this.Temperature = temperature; - this.InputTokenLimit = inputTokenLimit; this.TopK = topK; + this.Description = description; this.SupportedGenerationMethods = supportedGenerationMethods; + this.MaxTemperature = maxTemperature; + this.TopP = topP; + this.InputTokenLimit = inputTokenLimit; this.Version = version; - this.DisplayName = displayName; - this.OutputTokenLimit = outputTokenLimit; this.Thinking = thinking; - this.TopP = topP; this.BaseModelId = baseModelId; - this.MaxTemperature = maxTemperature; + this.DisplayName = displayName; + this.OutputTokenLimit = outputTokenLimit; } /// 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 7e0b11df..a94d4e4f 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 @@ -8,24 +8,18 @@ namespace Google.Gemini /// public sealed partial class Operation { - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. - /// - [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). /// [global::System.Text.Json.Serialization.JsonPropertyName("error")] public global::Google.Gemini.Status? Error { get; set; } + /// + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// @@ -33,10 +27,16 @@ public sealed partial class Operation public object? Response { get; set; } /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// 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("name")] - public string? Name { 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ public sealed partial class Operation /// /// Initializes a new instance of the class. /// - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. - /// - /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. - /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// + /// + /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// - /// - /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. + /// + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// + /// + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Operation( - object? metadata, - bool? done, global::Google.Gemini.Status? error, + string? name, object? response, - string? name) + object? metadata, + bool? done) { - this.Metadata = metadata; - this.Done = done; this.Error = error; - this.Response = response; this.Name = name; + this.Response = response; + this.Metadata = metadata; + this.Done = done; } /// 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 dbe4bd35..ce77c0b9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs @@ -11,46 +11,46 @@ namespace Google.Gemini public sealed partial class Part { /// - /// Optional. Indicates if the part is thought from the model. + /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] + public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] - public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] + public byte[]? ThoughtSignature { 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`. + /// Inline text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] - public global::Google.Gemini.ToolCall? ToolCall { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// 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("thoughtSignature")] - public byte[]? ThoughtSignature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] + public global::Google.Gemini.ToolCall? ToolCall { 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`. + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] - public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] + public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } /// - /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. + /// Optional. Indicates if the part is thought from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] - public object? PartMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thought")] + public bool? Thought { get; set; } /// - /// Inline text. + /// URI based data. /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] + public global::Google.Gemini.FileData? FileData { get; set; } /// /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. @@ -60,16 +60,16 @@ public sealed partial class Part public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } /// - /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. + /// 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("functionCall")] - public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] + public object? PartMetadata { 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. + /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] - public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] + public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } /// /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. @@ -78,16 +78,16 @@ public sealed partial class Part public global::Google.Gemini.Blob? InlineData { get; set; } /// - /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. + /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. /// - [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] - public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] + public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } /// - /// URI based data. + /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] - public global::Google.Gemini.FileData? FileData { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] + public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -98,71 +98,71 @@ public sealed partial class Part /// /// Initializes a new instance of the class. /// - /// - /// Optional. Indicates if the part is thought from the model. + /// + /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// - /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// + /// + /// Inline text. /// /// /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. /// - /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - /// - /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. + /// + /// Optional. Indicates if the part is thought from the model. + /// + /// + /// URI based data. /// /// /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. /// - /// - /// Inline text. - /// - /// - /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. - /// - /// - /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. + /// + /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. /// /// /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// - /// - /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. + /// + /// 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. /// - /// - /// URI based data. + /// + /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Part( - bool? thought, - global::Google.Gemini.CodeExecutionResult? codeExecutionResult, - global::Google.Gemini.ToolCall? toolCall, + global::Google.Gemini.FunctionCall? functionCall, byte[]? thoughtSignature, - global::Google.Gemini.ToolResponse? toolResponse, - object? partMetadata, string? text, - global::Google.Gemini.FunctionCall? functionCall, - global::Google.Gemini.FunctionResponse? functionResponse, - global::Google.Gemini.Blob? inlineData, + global::Google.Gemini.ToolCall? toolCall, + global::Google.Gemini.CodeExecutionResult? codeExecutionResult, + bool? thought, + global::Google.Gemini.FileData? fileData, + object? partMetadata, global::Google.Gemini.ExecutableCode? executableCode, - global::Google.Gemini.FileData? fileData) + global::Google.Gemini.Blob? inlineData, + global::Google.Gemini.FunctionResponse? functionResponse, + global::Google.Gemini.ToolResponse? toolResponse) { - this.Thought = thought; - this.CodeExecutionResult = codeExecutionResult; - this.ToolCall = toolCall; + this.FunctionCall = functionCall; this.ThoughtSignature = thoughtSignature; - this.ToolResponse = toolResponse; - this.PartMetadata = partMetadata; this.Text = text; - this.FunctionCall = functionCall; - this.FunctionResponse = functionResponse; - this.InlineData = inlineData; - this.ExecutableCode = executableCode; + this.ToolCall = toolCall; + this.CodeExecutionResult = codeExecutionResult; + this.Thought = thought; this.FileData = fileData; + this.PartMetadata = partMetadata; + this.ExecutableCode = executableCode; + this.InlineData = inlineData; + this.FunctionResponse = functionResponse; + this.ToolResponse = toolResponse; } /// 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 01d0b8ae..853a7614 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 @@ -9,17 +9,11 @@ namespace Google.Gemini public sealed partial class Permission { /// - /// Optional. Immutable. The type of the grantee. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("granteeType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter))] - public global::Google.Gemini.PermissionGranteeType? GranteeType { get; set; } - - /// - /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. + /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] - public string? EmailAddress { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Required. The role granted by this permission. @@ -29,11 +23,17 @@ public sealed partial class Permission public global::Google.Gemini.PermissionRole? Role { get; set; } /// - /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
- /// Included only in responses + /// Optional. Immutable. The type of the grantee. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("granteeType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter))] + public global::Google.Gemini.PermissionGranteeType? GranteeType { get; set; } + + /// + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] + public string? EmailAddress { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,32 +44,32 @@ public sealed partial class Permission /// /// Initializes a new instance of the class. /// + /// + /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
+ /// Included only in responses + /// + /// + /// Required. The role granted by this permission. + /// /// /// Optional. Immutable. The type of the grantee. /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Required. The role granted by this permission. - /// - /// - /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Permission( - global::Google.Gemini.PermissionGranteeType? granteeType, - string? emailAddress, + string? name, global::Google.Gemini.PermissionRole? role, - string? name) + global::Google.Gemini.PermissionGranteeType? granteeType, + string? emailAddress) { + this.Name = name; + this.Role = role; this.GranteeType = granteeType; this.EmailAddress = emailAddress; - this.Role = role; - this.Name = name; } /// 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 7fd83425..cb73b58e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs @@ -14,18 +14,18 @@ public sealed partial class ResponseFormatConfig [global::System.Text.Json.Serialization.JsonPropertyName("text")] public global::Google.Gemini.TextResponseFormat? Text { get; set; } - /// - /// Configuration for image output format. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("image")] - public global::Google.Gemini.ImageResponseFormat? Image { get; set; } - /// /// Configuration for audio output format. /// [global::System.Text.Json.Serialization.JsonPropertyName("audio")] public global::Google.Gemini.AudioResponseFormat? Audio { get; set; } + /// + /// Configuration for image output format. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("image")] + public global::Google.Gemini.ImageResponseFormat? Image { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class ResponseFormatConfig /// /// Configuration for text output format. /// - /// - /// Configuration for image output format. - /// /// /// Configuration for audio output format. /// + /// + /// Configuration for image output format. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ResponseFormatConfig( global::Google.Gemini.TextResponseFormat? text, - global::Google.Gemini.ImageResponseFormat? image, - global::Google.Gemini.AudioResponseFormat? audio) + global::Google.Gemini.AudioResponseFormat? audio, + global::Google.Gemini.ImageResponseFormat? image) { this.Text = text; - this.Image = image; this.Audio = audio; + this.Image = image; } /// 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 29bde405..deec4b8b 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,36 +8,24 @@ namespace Google.Gemini /// public sealed partial class RetrievedContext { - /// - /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mediaId")] - public string? MediaId { get; set; } - - /// - /// Optional. URI reference of the semantic retrieval document. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// Optional. Title of the document. /// [global::System.Text.Json.Serialization.JsonPropertyName("title")] public string? Title { get; set; } - /// - /// Optional. User-provided metadata about the retrieved context. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// /// Optional. Text of the chunk. /// [global::System.Text.Json.Serialization.JsonPropertyName("text")] public string? Text { 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. Page number of the retrieved context, if applicable. /// @@ -45,10 +33,22 @@ public sealed partial class RetrievedContext public int? PageNumber { get; set; } /// - /// 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} /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStore")] - public string? FileSearchStore { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mediaId")] + public string? MediaId { get; set; } + + /// + /// Optional. URI reference of the semantic retrieval document. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } + + /// + /// Optional. User-provided metadata about the retrieved context. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -59,46 +59,46 @@ public sealed partial class RetrievedContext /// /// Initializes a new instance of the class. /// - /// - /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} - /// - /// - /// Optional. URI reference of the semantic retrieval document. - /// /// /// Optional. Title of the document. /// - /// - /// Optional. User-provided metadata about the retrieved context. - /// /// /// Optional. Text of the chunk. /// + /// + /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` + /// /// /// 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. User-provided metadata about the retrieved context. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievedContext( - string? mediaId, - string? uri, string? title, - global::System.Collections.Generic.IList? customMetadata, string? text, + string? fileSearchStore, int? pageNumber, - string? fileSearchStore) + string? mediaId, + string? uri, + global::System.Collections.Generic.IList? customMetadata) { - this.MediaId = mediaId; - this.Uri = uri; this.Title = title; - this.CustomMetadata = customMetadata; this.Text = text; - this.PageNumber = pageNumber; this.FileSearchStore = fileSearchStore; + this.PageNumber = pageNumber; + this.MediaId = mediaId; + this.Uri = uri; + this.CustomMetadata = customMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs index ce8ec4f0..9183515b 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 { - /// - /// A link that corresponds to the user review on Google Maps. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] - public string? GoogleMapsUri { get; set; } - /// /// The ID of the review snippet. /// @@ -26,6 +20,12 @@ public sealed partial class ReviewSnippet [global::System.Text.Json.Serialization.JsonPropertyName("title")] public string? Title { get; set; } + /// + /// A link that corresponds to the user review on Google Maps. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] + public string? GoogleMapsUri { 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. /// - /// - /// A link that corresponds to the user review on Google Maps. - /// /// /// The ID of the review snippet. /// /// /// Title of the review. /// + /// + /// A link that corresponds to the user review on Google Maps. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ReviewSnippet( - string? googleMapsUri, string? reviewId, - string? title) + string? title, + string? googleMapsUri) { - this.GoogleMapsUri = googleMapsUri; this.ReviewId = reviewId; this.Title = title; + this.GoogleMapsUri = googleMapsUri; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs index a27d7d79..7eb80d6f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetyRating.g.cs @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class SafetyRating { + /// + /// Required. The category for this rating. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("category")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter))] + public global::Google.Gemini.SafetyRatingCategory? Category { get; set; } + /// /// Required. The probability of harm for this content. /// @@ -21,13 +28,6 @@ public sealed partial class SafetyRating [global::System.Text.Json.Serialization.JsonPropertyName("blocked")] public bool? Blocked { get; set; } - /// - /// Required. The category for this rating. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("category")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter))] - public global::Google.Gemini.SafetyRatingCategory? Category { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -37,26 +37,26 @@ public sealed partial class SafetyRating /// /// Initializes a new instance of the class. /// + /// + /// Required. The category for this rating. + /// /// /// Required. The probability of harm for this content. /// /// /// Was this content blocked because of this rating? /// - /// - /// Required. The category for this rating. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SafetyRating( + global::Google.Gemini.SafetyRatingCategory? category, global::Google.Gemini.SafetyRatingProbability? probability, - bool? blocked, - global::Google.Gemini.SafetyRatingCategory? category) + bool? blocked) { + this.Category = category; this.Probability = probability; this.Blocked = blocked; - this.Category = category; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs index cd94e37d..a38788ee 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 @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Schema { - /// - /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("default")] - public object? Default { get; set; } - /// /// Optional. The title of the schema. /// @@ -27,28 +21,41 @@ public sealed partial class Schema public double? Maximum { get; set; } /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// Optional. Maximum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] - public string? MaxProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] + public string? MaxLength { get; set; } /// - /// Optional. Properties of Type.OBJECT. + /// Optional. Required properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("required")] + public global::System.Collections.Generic.IList? Required { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] - public string? MinLength { 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. Required properties of Type.OBJECT. + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("items")] + public global::Google.Gemini.Schema? Items { get; set; } + + /// + /// Optional. Maximum number of the elements for Type.ARRAY. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] + public string? MaxItems { get; set; } + + /// + /// 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("description")] + public string? Description { get; set; } /// /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. @@ -57,22 +64,22 @@ public sealed partial class Schema public string? Pattern { get; set; } /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} /// - [global::System.Text.Json.Serialization.JsonPropertyName("format")] - public string? Format { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { get; set; } /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] - public string? MaxItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("format")] + public string? Format { get; set; } /// - /// Optional. Maximum length of the Type.STRING + /// Optional. Minimum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] - public string? MaxLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] + public string? MinProperties { get; set; } /// /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. @@ -81,29 +88,28 @@ public sealed partial class Schema public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } /// - /// Required. Data type. + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - [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("anyOf")] + public global::System.Collections.Generic.IList? AnyOf { get; set; } /// - /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} + /// Optional. 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("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] - public string? MinItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] + public double? Minimum { get; set; } /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { get; set; } /// /// Optional. Indicates if the value may be null. @@ -112,34 +118,28 @@ public sealed partial class Schema public bool? Nullable { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("items")] - public global::Google.Gemini.Schema? Items { get; set; } - - /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// Optional. Maximum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("example")] - public object? Example { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] + public string? MaxProperties { get; set; } /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// Optional. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] - public global::System.Collections.Generic.IList? AnyOf { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// Optional. Minimum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] - public string? MinProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] + public string? MinItems { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// Optional. Example of the object. Will only populated when the object is the root. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] - public double? Minimum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("example")] + public object? Example { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,121 +150,121 @@ public sealed partial class Schema /// /// Initializes a new instance of the class. /// - /// - /// Optional. 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 title of the schema. /// /// /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - /// - /// Optional. Maximum number of the properties for Type.OBJECT. - /// - /// - /// Optional. Properties of Type.OBJECT. - /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// + /// Optional. Maximum length of the Type.STRING /// /// /// Optional. Required properties of Type.OBJECT. /// + /// + /// Required. Data type. + /// + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// + /// Optional. Maximum number of the elements for Type.ARRAY. + /// + /// + /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// /// /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. /// + /// + /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} + /// /// /// Optional. 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. Maximum length of the Type.STRING + /// + /// Optional. Minimum number of the properties for Type.OBJECT. /// /// /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. /// - /// - /// Required. Data type. + /// + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - /// - /// 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. 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. Minimum number of the elements for Type.ARRAY. + /// + /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// /// /// Optional. Indicates if the value may be null. /// - /// - /// 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. Example of the object. Will only populated when the object is the root. + /// + /// Optional. Maximum number of the properties for Type.OBJECT. /// - /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// + /// Optional. Properties of Type.OBJECT. /// - /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// + /// Optional. Minimum number of the elements for Type.ARRAY. /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// + /// Optional. Example of the object. Will only populated when the object is the root. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( - object? @default, string? title, double? maximum, - string? maxProperties, - global::System.Collections.Generic.Dictionary? properties, - string? minLength, + string? maxLength, global::System.Collections.Generic.IList? required, + global::Google.Gemini.SchemaType? type, + global::Google.Gemini.Schema? items, + string? maxItems, + string? description, string? pattern, + global::System.Collections.Generic.IList? @enum, string? format, - string? maxItems, - string? maxLength, + string? minProperties, global::System.Collections.Generic.IList? propertyOrdering, - global::Google.Gemini.SchemaType? type, - global::System.Collections.Generic.IList? @enum, - string? minItems, - string? description, - bool? nullable, - global::Google.Gemini.Schema? items, - object? example, global::System.Collections.Generic.IList? anyOf, - string? minProperties, - double? minimum) + object? @default, + double? minimum, + string? minLength, + bool? nullable, + string? maxProperties, + global::System.Collections.Generic.Dictionary? properties, + string? minItems, + object? example) { - this.Default = @default; this.Title = title; this.Maximum = maximum; - this.MaxProperties = maxProperties; - this.Properties = properties; - this.MinLength = minLength; + this.MaxLength = maxLength; this.Required = required; + this.Type = type; + this.Items = items; + this.MaxItems = maxItems; + this.Description = description; this.Pattern = pattern; + this.Enum = @enum; this.Format = format; - this.MaxItems = maxItems; - this.MaxLength = maxLength; + this.MinProperties = minProperties; this.PropertyOrdering = propertyOrdering; - this.Type = type; - this.Enum = @enum; - this.MinItems = minItems; - this.Description = description; - this.Nullable = nullable; - this.Items = items; - this.Example = example; this.AnyOf = anyOf; - this.MinProperties = minProperties; + this.Default = @default; this.Minimum = minimum; + this.MinLength = minLength; + this.Nullable = nullable; + this.MaxProperties = maxProperties; + this.Properties = properties; + this.MinItems = minItems; + this.Example = example; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchEntryPoint.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchEntryPoint.g.cs index 22a069a1..c68b5741 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchEntryPoint.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchEntryPoint.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SearchEntryPoint { - /// - /// Optional. Base64 encoded JSON representing array of tuple. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sdkBlob")] - public byte[]? SdkBlob { get; set; } - /// /// Optional. Web content snippet that can be embedded in a web page or an app webview. /// [global::System.Text.Json.Serialization.JsonPropertyName("renderedContent")] public string? RenderedContent { get; set; } + /// + /// Optional. Base64 encoded JSON representing array of tuple. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sdkBlob")] + public byte[]? SdkBlob { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class SearchEntryPoint /// /// Initializes a new instance of the class. /// - /// - /// Optional. Base64 encoded JSON representing array of tuple. - /// /// /// Optional. Web content snippet that can be embedded in a web page or an app webview. /// + /// + /// Optional. Base64 encoded JSON representing array of tuple. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SearchEntryPoint( - byte[]? sdkBlob, - string? renderedContent) + string? renderedContent, + byte[]? sdkBlob) { - this.SdkBlob = sdkBlob; this.RenderedContent = renderedContent; + this.SdkBlob = sdkBlob; } /// 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 d6775134..d40cd9d8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class Status { /// - /// A list of messages that carry the error details. There is a common set of message types for APIs to use. + /// The status code, which should be an enum value of google.rpc.Code. /// - [global::System.Text.Json.Serialization.JsonPropertyName("details")] - public global::System.Collections.Generic.IList? Details { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("code")] + public int? Code { get; set; } /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. @@ -21,10 +21,10 @@ public sealed partial class Status public string? Message { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("code")] - public int? Code { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("details")] + public global::System.Collections.Generic.IList? Details { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -35,26 +35,26 @@ public sealed partial class Status /// /// Initializes a new instance of the class. /// - /// - /// A list of messages that carry the error details. There is a common set of message types for APIs to use. + /// + /// The status code, which should be an enum value of google.rpc.Code. /// /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// - /// - /// 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( - global::System.Collections.Generic.IList? details, + int? code, string? message, - int? code) + global::System.Collections.Generic.IList? details) { - this.Details = details; - this.Message = message; this.Code = code; + this.Message = message; + this.Details = details; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs index c768ba76..23bd44ba 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs @@ -8,18 +8,6 @@ namespace Google.Gemini /// public sealed partial class StreamableHttpTransport { - /// - /// HTTP timeout for regular operations. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] - public string? Timeout { get; set; } - - /// - /// Whether to close the client session when the transport closes. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("terminateOnClose")] - public bool? TerminateOnClose { get; set; } - /// /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// @@ -32,6 +20,18 @@ public sealed partial class StreamableHttpTransport [global::System.Text.Json.Serialization.JsonPropertyName("headers")] public global::System.Collections.Generic.Dictionary? Headers { get; set; } + /// + /// HTTP timeout for regular operations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] + public string? Timeout { get; set; } + + /// + /// Whether to close the client session when the transport closes. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("terminateOnClose")] + public bool? TerminateOnClose { get; set; } + /// /// Timeout for SSE read operations. /// @@ -47,18 +47,18 @@ public sealed partial class StreamableHttpTransport /// /// Initializes a new instance of the class. /// - /// - /// HTTP timeout for regular operations. - /// - /// - /// Whether to close the client session when the transport closes. - /// /// /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// + /// + /// HTTP timeout for regular operations. + /// + /// + /// Whether to close the client session when the transport closes. + /// /// /// Timeout for SSE read operations. /// @@ -66,16 +66,16 @@ public sealed partial class StreamableHttpTransport [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public StreamableHttpTransport( - string? timeout, - bool? terminateOnClose, string? url, global::System.Collections.Generic.Dictionary? headers, + string? timeout, + bool? terminateOnClose, string? sseReadTimeout) { - this.Timeout = timeout; - this.TerminateOnClose = terminateOnClose; this.Url = url; this.Headers = headers; + this.Timeout = timeout; + this.TerminateOnClose = terminateOnClose; this.SseReadTimeout = sseReadTimeout; } 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 9c79c78d..771cfd47 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,58 +9,58 @@ namespace Google.Gemini public sealed partial class Tool { /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// Tool to retrieve public web data for grounding, powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] - public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] + public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } /// - /// Tool to support URL context retrieval. + /// 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("urlContext")] - public global::Google.Gemini.UrlContext? UrlContext { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecution")] + public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] - public global::Google.Gemini.FileSearch? FileSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] + public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } /// - /// Computer Use tool type. + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] - public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] + public global::Google.Gemini.GoogleSearch? GoogleSearch { 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. + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// - [global::System.Text.Json.Serialization.JsonPropertyName("codeExecution")] - public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] + public global::Google.Gemini.FileSearch? FileSearch { get; set; } /// - /// Tool to retrieve public web data for grounding, powered by Google. + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] - public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { 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; } /// - /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. + /// Tool to support URL context retrieval. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] - public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] + public global::Google.Gemini.UrlContext? UrlContext { get; set; } /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// Optional. MCP Servers to connect to. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] - public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] + public global::System.Collections.Generic.IList? McpServers { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -71,56 +71,56 @@ public sealed partial class Tool /// /// Initializes a new instance of the class. /// + /// + /// Tool to retrieve public web data for grounding, powered by Google. + /// + /// + /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. + /// + /// + /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. + /// /// /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - /// - /// Tool to support URL context retrieval. - /// /// /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// + /// + /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// /// /// Computer Use tool type. /// - /// - /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. - /// - /// - /// Tool to retrieve public web data for grounding, powered by Google. + /// + /// Tool to support URL context retrieval. /// /// /// Optional. MCP Servers to connect to. /// - /// - /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. - /// - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Tool( + global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, + global::Google.Gemini.CodeExecution? codeExecution, + global::System.Collections.Generic.IList? functionDeclarations, global::Google.Gemini.GoogleSearch? googleSearch, - global::Google.Gemini.UrlContext? urlContext, global::Google.Gemini.FileSearch? fileSearch, + global::Google.Gemini.GoogleMaps? googleMaps, global::Google.Gemini.ComputerUse? computerUse, - global::Google.Gemini.CodeExecution? codeExecution, - global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, - global::System.Collections.Generic.IList? mcpServers, - global::System.Collections.Generic.IList? functionDeclarations, - global::Google.Gemini.GoogleMaps? googleMaps) + global::Google.Gemini.UrlContext? urlContext, + global::System.Collections.Generic.IList? mcpServers) { + this.GoogleSearchRetrieval = googleSearchRetrieval; + this.CodeExecution = codeExecution; + this.FunctionDeclarations = functionDeclarations; this.GoogleSearch = googleSearch; - this.UrlContext = urlContext; this.FileSearch = fileSearch; + this.GoogleMaps = googleMaps; this.ComputerUse = computerUse; - this.CodeExecution = codeExecution; - this.GoogleSearchRetrieval = googleSearchRetrieval; + this.UrlContext = urlContext; this.McpServers = mcpServers; - this.FunctionDeclarations = functionDeclarations; - this.GoogleMaps = googleMaps; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs index dc3026af..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 @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ToolCall { + /// + /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Required. The type of tool that was called. /// @@ -15,12 +21,6 @@ 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. Unique identifier of the tool call. The server returns the tool response with the matching `id`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// @@ -36,12 +36,12 @@ public sealed partial class ToolCall /// /// Initializes a new instance of the class. /// - /// - /// Required. The type of tool that was called. - /// /// /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. /// + /// + /// Required. The type of tool that was called. + /// /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// @@ -49,12 +49,12 @@ public sealed partial class ToolCall [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolCall( - global::Google.Gemini.ToolCallToolType? toolType, string? id, + global::Google.Gemini.ToolCallToolType? toolType, object? args) { - this.ToolType = toolType; this.Id = id; + 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 247efaa6..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,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ToolConfig { + /// + /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("includeServerSideToolInvocations")] + public bool? IncludeServerSideToolInvocations { get; set; } + /// /// Configuration for specifying function calling behavior. /// @@ -20,12 +26,6 @@ public sealed partial class ToolConfig [global::System.Text.Json.Serialization.JsonPropertyName("retrievalConfig")] public global::Google.Gemini.RetrievalConfig? RetrievalConfig { get; set; } - /// - /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("includeServerSideToolInvocations")] - public bool? IncludeServerSideToolInvocations { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ToolConfig /// /// Initializes a new instance of the class. /// + /// + /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. + /// /// /// Configuration for specifying function calling behavior. /// /// /// Retrieval config. /// - /// - /// Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolConfig( + bool? includeServerSideToolInvocations, global::Google.Gemini.FunctionCallingConfig? functionCallingConfig, - global::Google.Gemini.RetrievalConfig? retrievalConfig, - bool? includeServerSideToolInvocations) + global::Google.Gemini.RetrievalConfig? retrievalConfig) { + this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; this.FunctionCallingConfig = functionCallingConfig; this.RetrievalConfig = retrievalConfig; - this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs index a19a61c7..3cf6fa00 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class ToolResponse { + /// + /// Optional. The identifier of the tool call this response is for. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// @@ -21,12 +27,6 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonPropertyName("response")] public object? Response { get; set; } - /// - /// Optional. The identifier of the tool call this response is for. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ToolResponse /// /// Initializes a new instance of the class. /// + /// + /// Optional. The identifier of the tool call this response is for. + /// /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// /// /// Optional. The tool response. /// - /// - /// Optional. The identifier of the tool call this response is for. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolResponse( + string? id, global::Google.Gemini.ToolResponseToolType? toolType, - object? response, - string? id) + object? response) { + this.Id = id; this.ToolType = toolType; this.Response = response; - this.Id = id; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs index 5beb53ed..d44936b6 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,22 +9,24 @@ namespace Google.Gemini public sealed partial class TunedModel { /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Optional. List of project numbers that have read access to the tuned model. + /// Tuning tasks that create tuned models. /// - [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] - public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] + public global::Google.Gemini.TuningTask? TuningTask { get; set; } /// - /// Optional. A short description of this model. + /// Output only. The state of the tuned model.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { 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; } /// /// Output only. The timestamp when this model was updated.
@@ -34,42 +36,42 @@ public sealed partial class TunedModel public string? UpdateTime { get; set; } /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. + /// 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("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// - /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
+ /// Output only. The timestamp when this model was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// Optional. A short description of this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] - public string? BaseModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Output only. The timestamp when this model was created.
+ /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Tuning tasks that create tuned models. + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] - public global::Google.Gemini.TuningTask? TuningTask { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { 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. 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("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// /// Tuned model as a source for training a new model. @@ -78,18 +80,16 @@ public sealed partial class TunedModel public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] + public string? BaseModel { get; set; } /// - /// Output only. The state of the tuned model.
- /// Included only in responses + /// Optional. List of project numbers that have read access to the tuned model. ///
- [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("readerProjectNumbers")] + public global::System.Collections.Generic.IList? ReaderProjectNumbers { 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. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Tuning tasks that create tuned models. /// - /// - /// Optional. A short description of this model. + /// + /// Output only. The state of the tuned model.
+ /// Included only in responses /// /// /// Output only. The timestamp when this model was updated.
/// Included only in responses /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
+ /// + /// Output only. The timestamp when this model was created.
/// Included only in responses /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// Optional. A short description of this model. /// - /// - /// Output only. The timestamp when this model was created.
+ /// + /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
/// Included only in responses /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// 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. 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. /// /// /// Tuned model as a source for training a new model. /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` /// - /// - /// Output only. The state of the tuned model.
- /// Included only in responses + /// + /// Optional. List of project numbers that have read access to the tuned model. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModel( - int? topK, - global::System.Collections.Generic.IList? readerProjectNumbers, - string? description, - string? updateTime, - float? temperature, - string? name, - string? baseModel, - string? createTime, + string? displayName, global::Google.Gemini.TuningTask? tuningTask, + global::Google.Gemini.TunedModelState? state, + string? updateTime, float? topP, + string? createTime, + string? description, + string? name, + float? temperature, + int? topK, global::Google.Gemini.TunedModelSource? tunedModelSource, - string? displayName, - global::Google.Gemini.TunedModelState? state) + string? baseModel, + global::System.Collections.Generic.IList? readerProjectNumbers) { - this.TopK = topK; - this.ReaderProjectNumbers = readerProjectNumbers; - this.Description = description; - this.UpdateTime = updateTime; - this.Temperature = temperature; - this.Name = name; - this.BaseModel = baseModel; - this.CreateTime = createTime; + this.DisplayName = displayName; this.TuningTask = tuningTask; + this.State = state; + this.UpdateTime = updateTime; this.TopP = topP; + this.CreateTime = createTime; + this.Description = description; + this.Name = name; + this.Temperature = temperature; + this.TopK = topK; this.TunedModelSource = tunedModelSource; - this.DisplayName = displayName; - this.State = state; + this.BaseModel = baseModel; + this.ReaderProjectNumbers = readerProjectNumbers; } /// 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 09f2011b..d2aae8fd 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 @@ -16,18 +16,18 @@ public sealed partial class TuningSnapshot public int? Step { get; set; } /// - /// Output only. The epoch this step was part of.
+ /// Output only. The timestamp when this metric was computed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] - public int? Epoch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] + public string? ComputeTime { get; set; } /// - /// Output only. The timestamp when this metric was computed.
+ /// Output only. The epoch this step was part of.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] - public string? ComputeTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] + public int? Epoch { get; set; } /// /// Output only. The mean loss of the training examples for this step.
@@ -49,14 +49,14 @@ public sealed partial class TuningSnapshot /// Output only. The tuning step.
/// Included only in responses /// - /// - /// 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 /// + /// + /// Output only. The epoch this step was part of.
+ /// Included only in responses + /// /// /// Output only. The mean loss of the training examples for this step.
/// Included only in responses @@ -66,13 +66,13 @@ public sealed partial class TuningSnapshot #endif public TuningSnapshot( int? step, - int? epoch, string? computeTime, + int? epoch, float? meanLoss) { this.Step = step; - this.Epoch = epoch; this.ComputeTime = computeTime; + this.Epoch = epoch; 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 89d9187a..3e3bc586 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,13 +8,6 @@ namespace Google.Gemini ///
public sealed partial class TuningTask { - /// - /// Output only. The timestamp when tuning this model started.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } - /// /// Output only. The timestamp when tuning this model completed.
/// Included only in responses @@ -23,10 +16,11 @@ public sealed partial class TuningTask public string? CompleteTime { get; set; } /// - /// Dataset for training or validation. + /// Output only. Metrics collected during tuning.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("trainingData")] - public global::Google.Gemini.Dataset? TrainingData { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("snapshots")] + public global::System.Collections.Generic.IList? Snapshots { get; set; } /// /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance @@ -35,11 +29,17 @@ public sealed partial class TuningTask public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } /// - /// Output only. Metrics collected during tuning.
+ /// Output only. The timestamp when tuning this model started.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("snapshots")] - public global::System.Collections.Generic.IList? Snapshots { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } + + /// + /// Dataset for training or validation. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("trainingData")] + public global::Google.Gemini.Dataset? TrainingData { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -50,39 +50,39 @@ public sealed partial class TuningTask /// /// Initializes a new instance of the class. /// - /// - /// Output only. The timestamp when tuning this model started.
- /// Included only in responses - /// /// /// Output only. The timestamp when tuning this model completed.
/// Included only in responses /// - /// - /// Dataset for training or validation. + /// + /// Output only. Metrics collected during tuning.
+ /// Included only in responses /// /// /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance /// - /// - /// Output only. Metrics collected during tuning.
+ /// + /// Output only. The timestamp when tuning this model started.
/// Included only in responses /// + /// + /// Dataset for training or validation. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( - string? startTime, string? completeTime, - global::Google.Gemini.Dataset? trainingData, + global::System.Collections.Generic.IList? snapshots, global::Google.Gemini.Hyperparameters? hyperparameters, - global::System.Collections.Generic.IList? snapshots) + string? startTime, + global::Google.Gemini.Dataset? trainingData) { - this.StartTime = startTime; this.CompleteTime = completeTime; - this.TrainingData = trainingData; - this.Hyperparameters = hyperparameters; this.Snapshots = snapshots; + this.Hyperparameters = hyperparameters; + this.StartTime = startTime; + this.TrainingData = trainingData; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs index e01110fc..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 @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class UploadToFileSearchStoreRequest { - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } - /// /// Optional. Display name of the created document. /// [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] public string? DisplayName { get; set; } + /// + /// Custom metadata to be associated with the data. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -27,10 +27,10 @@ public sealed partial class UploadToFileSearchStoreRequest public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } /// - /// Custom metadata to be associated with the data. + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -41,31 +41,31 @@ public sealed partial class UploadToFileSearchStoreRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// /// /// Optional. Display name of the created document. /// + /// + /// 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 /// - /// - /// Custom metadata to be associated with the data. + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UploadToFileSearchStoreRequest( - string? mimeType, string? displayName, + global::System.Collections.Generic.IList? customMetadata, global::Google.Gemini.ChunkingConfig? chunkingConfig, - global::System.Collections.Generic.IList? customMetadata) + string? mimeType) { - this.MimeType = 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 92ed5e03..8be9fd58 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class UrlMetadata { - /// - /// Retrieved url by the tool. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievedUrl")] - public string? RetrievedUrl { get; set; } - /// /// Status of the url retrieval. /// @@ -21,6 +15,12 @@ public sealed partial class UrlMetadata [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter))] public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? UrlRetrievalStatus { get; set; } + /// + /// Retrieved url by the tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievedUrl")] + public string? RetrievedUrl { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class UrlMetadata /// /// Initializes a new instance of the class. /// - /// - /// Retrieved url by the tool. - /// /// /// Status of the url retrieval. /// + /// + /// Retrieved url by the tool. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UrlMetadata( - string? retrievedUrl, - global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus) + global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus, + string? retrievedUrl) { - this.RetrievedUrl = retrievedUrl; this.UrlRetrievalStatus = urlRetrievalStatus; + this.RetrievedUrl = retrievedUrl; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs index da53dbe5..91d539eb 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 @@ -8,6 +8,18 @@ namespace Google.Gemini /// public sealed partial class UsageMetadata { + /// + /// Number of tokens in the cached part of the prompt (the cached content) + /// + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] + public int? CachedContentTokenCount { get; set; } + + /// + /// Total token count for the generation request (prompt + thoughts + response candidates). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] + public int? TotalTokenCount { get; set; } + /// /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses @@ -15,6 +27,26 @@ public sealed partial class UsageMetadata [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + /// + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses + ///
+ [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.
+ /// Included only in responses + ///
+ [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. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } + /// /// Total number of tokens across all the generated response candidates. /// @@ -28,13 +60,6 @@ public sealed partial class UsageMetadata [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] public int? ToolUsePromptTokenCount { get; set; } - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] - public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } - /// /// Output only. Number of tokens of thoughts for thinking models.
/// Included only in responses @@ -50,12 +75,6 @@ public sealed partial class UsageMetadata [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter))] public global::Google.Gemini.UsageMetadataServiceTier? ServiceTier { get; set; } - /// - /// Number of tokens in the cached part of the prompt (the cached content) - /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] - public int? CachedContentTokenCount { get; set; } - /// /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses @@ -63,25 +82,6 @@ public sealed partial class UsageMetadata [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } - /// - /// Total token count for the generation request (prompt + thoughts + response candidates). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] - public int? TotalTokenCount { get; set; } - - /// - /// Output only. List of modalities that were returned in the response.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] - public global::System.Collections.Generic.IList? CandidatesTokensDetails { 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. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } - /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
/// Included only in responses @@ -105,10 +105,27 @@ public sealed partial class UsageMetadata /// /// Initializes a new instance of the class. /// + /// + /// 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 of the cached content in the request input.
/// Included only in responses /// + /// + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses + /// + /// + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses + /// + /// + /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + /// /// /// Total number of tokens across all the generated response candidates. /// @@ -116,10 +133,6 @@ public sealed partial class UsageMetadata /// Output only. Number of tokens present in tool-use prompt(s).
/// Included only in responses /// - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - /// /// /// Output only. Number of tokens of thoughts for thinking models.
/// Included only in responses @@ -128,23 +141,10 @@ public sealed partial class UsageMetadata /// Output only. Service tier of the request.
/// Included only in responses /// - /// - /// Number of tokens in the cached part of the prompt (the cached content) - /// /// /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses /// - /// - /// Total token count for the generation request (prompt + thoughts + response candidates). - /// - /// - /// Output only. List of modalities that were returned in the response.
- /// Included only in responses - /// - /// - /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. - /// /// /// Output only. 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? cachedContentTokenCount, + int? totalTokenCount, global::System.Collections.Generic.IList? cacheTokensDetails, + global::System.Collections.Generic.IList? candidatesTokensDetails, + global::System.Collections.Generic.IList? promptTokensDetails, + int? promptTokenCount, int? candidatesTokenCount, int? toolUsePromptTokenCount, - global::System.Collections.Generic.IList? promptTokensDetails, int? thoughtsTokenCount, global::Google.Gemini.UsageMetadataServiceTier? serviceTier, - int? cachedContentTokenCount, global::System.Collections.Generic.IList? toolUsePromptTokensDetails, - int? totalTokenCount, - global::System.Collections.Generic.IList? candidatesTokensDetails, - int? promptTokenCount, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { + this.CachedContentTokenCount = cachedContentTokenCount; + this.TotalTokenCount = totalTokenCount; this.CacheTokensDetails = cacheTokensDetails; + this.CandidatesTokensDetails = candidatesTokensDetails; + this.PromptTokensDetails = promptTokensDetails; + this.PromptTokenCount = promptTokenCount; this.CandidatesTokenCount = candidatesTokenCount; this.ToolUsePromptTokenCount = toolUsePromptTokenCount; - this.PromptTokensDetails = promptTokensDetails; this.ThoughtsTokenCount = thoughtsTokenCount; this.ServiceTier = serviceTier; - this.CachedContentTokenCount = cachedContentTokenCount; this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; - this.TotalTokenCount = totalTokenCount; - this.CandidatesTokensDetails = candidatesTokensDetails; - this.PromptTokenCount = promptTokenCount; 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 011001b8..9220677a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs @@ -9,13 +9,6 @@ namespace Google.Gemini [global::System.Obsolete("This model marked as deprecated.")] public sealed partial class VideoMetadata { - /// - /// Optional. The start offset of the video. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] - [global::System.Obsolete("This property marked as deprecated.")] - public string? StartOffset { get; set; } - /// /// Optional. The end offset of the video. /// @@ -30,6 +23,13 @@ public sealed partial class VideoMetadata [global::System.Obsolete("This property marked as deprecated.")] public double? Fps { get; set; } + /// + /// Optional. The start offset of the video. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] + [global::System.Obsolete("This property marked as deprecated.")] + public string? StartOffset { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,26 +39,26 @@ public sealed partial class VideoMetadata /// /// Initializes a new instance of the class. /// - /// - /// Optional. The start offset of the video. - /// /// /// Optional. The end offset of the video. /// /// /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. /// + /// + /// Optional. The start offset of the video. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public VideoMetadata( - string? startOffset, string? endOffset, - double? fps) + double? fps, + string? startOffset) { - this.StartOffset = startOffset; this.EndOffset = endOffset; this.Fps = fps; + this.StartOffset = startOffset; } /// 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 057e2a36..10b0d5ec 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. 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; } /// - /// 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; } /// /// 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. URI reference of the chunk.
- /// Included only in responses - /// /// /// Output only. Title of the chunk.
/// Included only in responses /// + /// + /// Output only. URI reference of the chunk.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Web( - string? uri, - string? title) + string? title, + string? uri) { - this.Uri = uri; this.Title = title; + this.Uri = uri; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index 9ed7dd86..2503b8ee 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,15 +11,40 @@ } ], "paths": { - "/cachedContents": { + "/fileSearchStores": { + "post": { + "description": "Creates an empty `FileSearchStore`.", + "operationId": "fileSearchStores.create", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/FileSearchStore" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/FileSearchStore" + } + } + } + } + } + }, "get": { - "description": "Lists CachedContents.", - "operationId": "cachedContents.list", + "description": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.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 `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", "schema": { "type": "integer", "format": "int32" @@ -28,7 +53,7 @@ { "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 `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" } @@ -40,21 +65,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}:importFile": { "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", + "description": "Imports a `File` from File Service to a `FileSearchStore`.", + "operationId": "fileSearchStores.importFile", + "parameters": [ + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -65,7 +104,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Operation" } } } @@ -73,19 +112,19 @@ } } }, - "/cachedContents/{cachedContentsId}": { - "delete": { - "description": "Deletes CachedContent resource.", - "operationId": "cachedContents.delete", + "/fileSearchStores/{fileSearchStoresId}": { + "get": { + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "cachedContentsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", + "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -95,25 +134,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/FileSearchStore" } } } } } }, - "get": { - "description": "Reads CachedContent resource.", - "operationId": "cachedContents.get", + "delete": { + "description": "Deletes a `FileSearchStore`.", + "operationId": "fileSearchStores.delete", "parameters": [ { - "name": "cachedContentsId", + "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 resource name referring to the content cache entry. Format: `cachedContents/{id}`", + "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -123,53 +170,45 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Empty" } } } } } - }, - "patch": { - "description": "Updates CachedContent resource (only expiration is updatable).", - "operationId": "cachedContents.patch", + } + }, + "/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": "cachedContentsId", + "name": "operationsId", "in": "path", "required": true, - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { - "type": "string", - "pattern": "^cachedContents/[^/]+$" + "type": "string" } }, { - "name": "updateMask", - "in": "query", - "description": "The list of fields to update.", + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CachedContent" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Operation" } } } @@ -177,49 +216,27 @@ } } }, - "/batches/{batchesId}:cancel": { - "post": { - "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", - "operationId": "batches.cancel", + "/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": "batchesId", + "name": "operationsId", "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" - } - } + "type": "string" } - } - } - } - }, - "/batches/{batchesId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "batches.get", - "parameters": [ + }, { - "name": "batchesId", + "name": "fileSearchStoresId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" } } ], @@ -235,19 +252,37 @@ } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { "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", + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.delete", "parameters": [ { - "name": "batchesId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation resource to be deleted.", + "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": "^batches/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], @@ -263,49 +298,37 @@ } } } - } - }, - "/batches/{batchesId}:updateEmbedContentBatch": { - "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", + }, + "get": { + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.get", "parameters": [ { - "name": "batchesId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" + "type": "string" } }, { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "name": "documentsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Document" } } } @@ -313,42 +336,36 @@ } } }, - "/batches": { + "/fileSearchStores/{fileSearchStoresId}/documents": { "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "batches.list", + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", "parameters": [ { - "name": "filter", + "name": "pageSize", "in": "query", - "description": "The standard list filter.", + "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": "string" + "type": "integer", + "format": "int32" } }, { - "name": "pageSize", + "name": "pageToken", "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "The standard list 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": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", "schema": { - "type": "boolean" + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -358,7 +375,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/ListDocumentsResponse" } } } @@ -366,36 +383,15 @@ } } }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", - "parameters": [ - { - "name": "batchesId", - "in": "path", - "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", - "schema": { - "type": "string", - "format": "google-fieldmask" - } - } - ], + "/files": { + "post": { + "description": "Creates a `File`.", + "operationId": "media.upload", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/CreateFileRequest" } } } @@ -406,27 +402,32 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/CreateFileResponse" } } } } } - } - }, - "/tunedModels/{tunedModelsId}": { - "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", + }, + "get": { + "description": "Lists the metadata for `File`s owned by the requesting project.", + "operationId": "files.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "name": "pageSize", + "in": "query", + "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListFiles` call.", + "schema": { + "type": "string" } } ], @@ -436,34 +437,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListFilesResponse" } } } } } - }, - "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", + } + }, + "/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": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -471,7 +465,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" } } } @@ -482,25 +476,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CustomLongRunningOperation" } } } } } - }, - "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.get", + } + }, + "/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": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "The name of the operation resource to be cancelled.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -510,7 +506,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Empty" } } } @@ -518,56 +514,28 @@ } } }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" - } - } + "pattern": "^batches/[^/]+$" } - } - } - } - }, - "/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": "tunedModelId", + "name": "updateMask", "in": "query", - "description": "Optional. The unique id for the tuned model if specified. This value should be up to 40 characters, the first character must be a letter, the last could be a letter or a number. The id must match the regular expression: `[a-z]([a-z0-9-]{0,38}[a-z0-9])?`.", + "description": "Optional. The list of fields to update.", "schema": { - "type": "string" + "type": "string", + "format": "google-fieldmask" } } ], @@ -575,7 +543,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -586,21 +554,23 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/EmbedContentBatch" } } } } } - }, + } + }, + "/batches": { "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.list", + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "batches.list", "parameters": [ { "name": "filter", "in": "query", - "description": "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", + "description": "The standard list filter.", "schema": { "type": "string" } @@ -608,7 +578,7 @@ { "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": "The standard list page size.", "schema": { "type": "integer", "format": "int32" @@ -617,10 +587,18 @@ { "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": "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": { @@ -629,7 +607,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -637,77 +615,57 @@ } } }, - "/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", + "/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": "tunedModelsId", + "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": "^tunedModels/[^/]+$" + "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" } } } } } - } - }, - "/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", + }, + "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": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], - "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" } } } @@ -715,19 +673,28 @@ } } }, - "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { - "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "tunedModels.asyncBatchEmbedContent", + "/batches/{batchesId}:updateGenerateContentBatch": { + "patch": { + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", "parameters": [ { - "name": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -735,7 +702,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -746,7 +713,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -754,71 +721,47 @@ } } }, - "/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", + "/files/{filesId}": { + "delete": { + "description": "Deletes the `File`.", + "operationId": "files.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^files/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/tunedModels/{tunedModelsId}/operations/{operationsId}": { + }, "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "tunedModels.operations.get", + "description": "Gets the metadata for the given `File`.", + "operationId": "files.get", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "operationsId", + "name": "filesId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The name of the `File` to get. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/operations/[^/]+$" + "pattern": "^files/[^/]+$" } } ], @@ -828,7 +771,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/File" } } } @@ -836,52 +779,46 @@ } } }, - "/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" + "/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" + } } - }, + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/RegisterFilesResponse" + } + } + } + } + } + } + }, + "/cachedContents/{cachedContentsId}": { + "delete": { + "description": "Deletes CachedContent resource.", + "operationId": "cachedContents.delete", + "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "The name of the operation's parent resource.", + "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "The standard list page token.", - "schema": { - "type": "string" - } - }, - { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", - "schema": { - "type": "boolean" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -891,27 +828,34 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/tunedModels/{tunedModelsId}/permissions": { - "post": { - "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", + }, + "patch": { + "description": "Updates CachedContent resource (only expiration is updatable).", + "operationId": "cachedContents.patch", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -919,7 +863,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/CachedContent" } } } @@ -930,7 +874,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/CachedContent" } } } @@ -938,34 +882,17 @@ } }, "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.list", + "description": "Reads CachedContent resource.", + "operationId": "cachedContents.get", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", - "schema": { - "type": "string" - } - }, - { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -975,7 +902,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/CachedContent" } } } @@ -983,27 +910,26 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "/cachedContents": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + "description": "Lists CachedContents.", + "operationId": "cachedContents.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of cached contents to return. The service may return fewer than this value. If unspecified, some default (under maximum) number of items will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.", "schema": { - "type": "string" + "type": "integer", + "format": "int32" } }, { - "name": "permissionsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, 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", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "type": "string" } } ], @@ -1013,50 +939,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } } } }, - "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" - } - } - ], + "post": { + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/CachedContent" } } } @@ -1067,43 +964,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" - } - } - } - } - } - }, - "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" + "$ref": "#/components/schemas/CachedContent" } } } @@ -1186,38 +1047,65 @@ } } }, - "/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", + "/corpora/{corporaId}": { + "get": { + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", "parameters": [ { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Corpus" + } } } } - }, + } + }, + "delete": { + "description": "Deletes a `Corpus`.", + "operationId": "corpora.delete", + "parameters": [ + { + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `Corpus` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Corpus` contains any `Document`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+$" + } + } + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -1225,27 +1113,50 @@ } } }, - "/models/{modelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", + "/corpora": { + "get": { + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.list", "parameters": [ { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `Corpora` to return (per page). The service may return fewer `Corpora`. If unspecified, at most 10 `Corpora` will be returned. The maximum size limit is 20 `Corpora` per page.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListCorpora` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListCorpora` must match the call that provided the page token.", + "schema": { + "type": "string" } } ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListCorporaResponse" + } + } + } + } + } + }, + "post": { + "description": "Creates an empty `Corpus`.", + "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/Corpus" } } } @@ -1256,7 +1167,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Corpus" } } } @@ -1264,19 +1175,19 @@ } } }, - "/models/{modelsId}:asyncBatchEmbedContent": { + "/corpora/{corporaId}/permissions": { "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "models.asyncBatchEmbedContent", + "description": "Create a permission to a specific resource.", + "operationId": "corpora.permissions.create", "parameters": [ { - "name": "modelsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -1284,7 +1195,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -1295,23 +1206,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/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": "Lists permissions for the specific resource.", + "operationId": "corpora.permissions.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of `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" @@ -1320,10 +1229,20 @@ { "name": "pageToken", "in": "query", - "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", "schema": { "type": "string" } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+$" + } } ], "responses": { @@ -1332,7 +1251,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListModelsResponse" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } @@ -1340,19 +1259,36 @@ } } }, - "/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", + "/corpora/{corporaId}/permissions/{permissionsId}": { + "patch": { + "description": "Updates the permission.", + "operationId": "corpora.permissions.patch", "parameters": [ { - "name": "modelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -1360,7 +1296,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -1371,85 +1307,79 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/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": "modelsId", + }, + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", + "parameters": [ + { + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/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", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "parameters": [ { - "name": "modelsId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CountTokensRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -1457,43 +1387,37 @@ } } }, - "/models/{modelsId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "models.streamGenerateContent", + "/corpora/{corporaId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "corpora.operations.get", "parameters": [ { - "name": "modelsId", + "name": "operationsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/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" } } } @@ -1501,19 +1425,19 @@ } } }, - "/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", + "/tunedModels/{tunedModelsId}": { + "delete": { + "description": "Deletes a tuned model.", + "operationId": "tunedModels.delete", "parameters": [ { - "name": "modelsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1523,35 +1447,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/Empty" } } } } } - } - }, - "/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": "Gets information about a specific TunedModel.", + "operationId": "tunedModels.get", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "modelsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1561,70 +1475,53 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/TunedModel" } } } } } - } - }, - "/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", + }, + "patch": { + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "modelsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation's parent resource.", + "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/[^/]+$" - } - }, - { - "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" + "pattern": "^tunedModels/[^/]+$" } }, { - "name": "returnPartialSuccess", + "name": "updateMask", "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.", + "description": "Optional. The list of fields to update.", "schema": { - "type": "boolean" + "type": "string", + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TunedModel" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/TunedModel" } } } @@ -1632,19 +1529,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/[^/]+$" } } ], @@ -1652,7 +1549,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -1663,12 +1560,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1676,19 +1568,17 @@ } } }, - "/dynamic/{dynamicId}:generateContent": { + "/tunedModels": { "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": "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": "dynamicId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "name": "tunedModelId", + "in": "query", + "description": "Optional. The unique id for the tuned model if specified. This value should be up to 40 characters, the first character must be a letter, the last could be a letter or a number. The id must match the regular expression: `[a-z]([a-z0-9-]{0,38}[a-z0-9])?`.", "schema": { - "type": "string", - "pattern": "^dynamic/[^/]+$" + "type": "string" } } ], @@ -1696,7 +1586,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/TunedModel" } } } @@ -1707,34 +1597,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - } - } - } - } - } - }, - "/files": { - "post": { - "description": "Creates a `File`.", - "operationId": "media.upload", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CreateFileRequest" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CreateFileResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1742,13 +1605,21 @@ } }, "get": { - "description": "Lists the metadata for `File`s owned by the requesting project.", - "operationId": "files.list", + "description": "Lists created tuned models.", + "operationId": "tunedModels.list", "parameters": [ + { + "name": "filter", + "in": "query", + "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", + "schema": { + "type": "string" + } + }, { "name": "pageSize", "in": "query", - "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", + "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", "schema": { "type": "integer", "format": "int32" @@ -1757,7 +1628,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token from a previous `ListFiles` call.", + "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", "schema": { "type": "string" } @@ -1769,7 +1640,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFilesResponse" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } @@ -1777,19 +1648,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { + "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { "post": { - "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", - "operationId": "media.uploadToFileSearchStore", + "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": "fileSearchStoresId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1797,7 +1668,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -1808,7 +1679,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" + "$ref": "#/components/schemas/Operation" } } } @@ -1816,15 +1687,27 @@ } } }, - "/corpora": { + "/tunedModels/{tunedModelsId}:streamGenerateContent": { "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "tunedModels.streamGenerateContent", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1835,42 +1718,51 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.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. The maximum number of `Corpora` to return (per page). The service may return fewer `Corpora`. If unspecified, at most 10 `Corpora` will be returned. The maximum size limit is 20 `Corpora` per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListCorpora` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListCorpora` must match the call that provided the page token.", + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TransferOwnershipRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } @@ -1878,55 +1770,91 @@ } } }, - "/corpora/{corporaId}": { - "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.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": "corporaId", + "name": "tunedModelsId", "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": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + } + }, + "/tunedModels/{tunedModelsId}/operations": { + "get": { + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "tunedModels.operations.list", "parameters": [ { - "name": "force", + "name": "filter", "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `Corpus` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Corpus` contains any `Document`s.", + "description": "The standard list filter.", "schema": { - "type": "boolean" + "type": "string" } }, { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "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" } } ], @@ -1936,7 +1864,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -1944,13 +1872,13 @@ } } }, - "/corpora/{corporaId}/operations/{operationsId}": { + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { "get": { "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "corpora.operations.get", + "operationId": "tunedModels.operations.get", "parameters": [ { - "name": "operationsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1958,13 +1886,13 @@ } }, { - "name": "corporaId", + "name": "operationsId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+/operations/[^/]+$" } } ], @@ -1982,36 +1910,27 @@ } } }, - "/corpora/{corporaId}/permissions": { - "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.list", + "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { + "delete": { + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.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.", + "name": "tunedModelsId", + "in": "path", + "required": true, "schema": { "type": "string" } }, { - "name": "corporaId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -2021,33 +1940,50 @@ "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", + "patch": { + "description": "Updates the permission.", + "operationId": "tunedModels.permissions.patch", "parameters": [ { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "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": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" + }, + { + "name": "updateMask", + "in": "query", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "schema": { + "type": "string", + "format": "google-fieldmask" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" } } } @@ -2064,15 +2000,13 @@ } } } - } - }, - "/corpora/{corporaId}/permissions/{permissionsId}": { - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + }, + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "tunedModels.permissions.get", "parameters": [ { - "name": "permissionsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -2080,13 +2014,13 @@ } }, { - "name": "corporaId", + "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": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -2096,33 +2030,44 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Permission" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}/permissions": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "corpora.permissions.get", + "description": "Lists permissions for the specific resource.", + "operationId": "tunedModels.permissions.list", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, + "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": "tunedModelsId", "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 parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -2132,42 +2077,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } } } }, - "patch": { - "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", + "post": { + "description": "Create a permission to a specific resource.", + "operationId": "tunedModels.permissions.create", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "corporaId", + "name": "tunedModelsId", "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 parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -2194,73 +2122,71 @@ } } }, - "/files/{filesId}": { - "get": { - "description": "Gets the metadata for the given `File`.", - "operationId": "files.get", + "/dynamic/{dynamicId}:streamGenerateContent": { + "post": { + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "dynamic.streamGenerateContent", "parameters": [ { - "name": "filesId", + "name": "dynamicId", "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": "^dynamic/[^/]+$" } } ], + "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" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes the `File`.", - "operationId": "files.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": "filesId", + "name": "dynamicId", "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": "^dynamic/[^/]+$" } } ], - "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" } } } @@ -2271,7 +2197,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -2279,65 +2205,43 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}": { - "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.delete", + "/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", "parameters": [ { - "name": "force", - "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", - "schema": { - "type": "boolean" - } - }, - { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `FileSearchStore`. 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/[^/]+$" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" - } + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" } } } - } - }, - "get": { - "description": "Gets information about a specific `FileSearchStore`.", - "operationId": "fileSearchStores.get", - "parameters": [ - { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", - "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+$" - } - } - ], + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -2345,15 +2249,15 @@ } } }, - "/fileSearchStores": { + "/models": { "get": { - "description": "Lists all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.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 `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": "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" @@ -2362,7 +2266,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": "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" } @@ -2374,21 +2278,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" + "$ref": "#/components/schemas/ListModelsResponse" } } } } } - }, + } + }, + "/models/{modelsId}:asyncBatchEmbedContent": { "post": { - "description": "Creates an empty `FileSearchStore`.", - "operationId": "fileSearchStores.create", + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "models.asyncBatchEmbedContent", + "parameters": [ + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string", + "pattern": "^models/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" } } } @@ -2399,7 +2317,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Operation" } } } @@ -2407,19 +2325,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { + "/models/{modelsId}:embedContent": { "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "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", + "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 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/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -2427,7 +2345,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/EmbedContentRequest" } } } @@ -2438,7 +2356,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -2446,37 +2364,77 @@ } } }, - "/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}: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", + "name": "modelsId", "in": "path", "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } - }, + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" + } + } + } + } + } + } + }, + "/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": "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" } } } @@ -2484,27 +2442,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { + "/models/{modelsId}": { "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", + "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": "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 resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -2514,7 +2464,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Model" } } } @@ -2522,71 +2472,130 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.delete", + "/models/{modelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "models.batchGenerateContent", "parameters": [ { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } - }, - { - "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" + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" + } } - }, + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Operation" + } + } + } + } + } + } + }, + "/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": "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 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/BatchEmbedContentsRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/BatchEmbedContentsResponse" } } } } } - }, + } + }, + "/models/{modelsId}/operations": { "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.get", + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "models.operations.list", "parameters": [ { - "name": "fileSearchStoresId", - "in": "path", - "required": true, + "name": "filter", + "in": "query", + "description": "The standard list filter.", "schema": { "type": "string" } }, { - "name": "documentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^models/[^/]+$" + } + }, + { + "name": "pageSize", + "in": "query", + "description": "The standard list page size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "The standard list page token.", + "schema": { + "type": "string" + } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" } } ], @@ -2596,7 +2605,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -2604,36 +2613,27 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents": { + "/models/{modelsId}/operations/{operationsId}": { "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "models.operations.get", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", + "name": "operationsId", + "in": "path", + "required": true, "schema": { "type": "string" } }, { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^models/[^/]+/operations/[^/]+$" } } ], @@ -2643,7 +2643,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -2654,2058 +2654,1991 @@ }, "components": { "schemas": { - "ListCachedContentsResponse": { - "description": "Response with CachedContents list.", + "Dataset": { "properties": { - "cachedContents": { - "items": { - "$ref": "#/components/schemas/CachedContent" - }, - "type": "array", - "description": "List of cached contents." - }, - "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" + "examples": { + "$ref": "#/components/schemas/TuningExamples", + "description": "Optional. Inline examples with simple input/output text." } }, - "type": "object" + "type": "object", + "description": "Dataset for training or validation." }, - "ListOperationsResponse": { - "description": "The response message for Operations.ListOperations.", + "AsyncBatchEmbedContentRequest": { + "description": "Request for an `AsyncBatchEmbedContent` operation.", + "type": "object", "properties": { - "unreachable": { - "type": "array", - "items": { - "type": "string" - }, - "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations." - }, - "nextPageToken": { - "description": "The standard List next-page token.", + "batch": { + "description": "Required. The batch to create.", + "$ref": "#/components/schemas/EmbedContentBatch" + } + } + }, + "TransferOwnershipRequest": { + "properties": { + "emailAddress": { + "description": "Required. The email address of the user to whom the tuned model is being transferred to.", "type": "string" + } + }, + "type": "object", + "description": "Request to transfer the ownership of the tuned model." + }, + "SearchTypes": { + "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "properties": { + "webSearch": { + "$ref": "#/components/schemas/WebSearch", + "description": "Optional. Enables web search. Only text results are returned." }, - "operations": { - "items": { - "$ref": "#/components/schemas/Operation" - }, - "type": "array", - "description": "A list of operations that matches the specified filter in the request." + "imageSearch": { + "description": "Optional. Enables image search. Image bytes are returned.", + "$ref": "#/components/schemas/ImageSearch" } }, "type": "object" }, - "McpServer": { - "type": "object", - "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 6", + "CreateFileRequest": { "properties": { - "streamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses.", - "$ref": "#/components/schemas/StreamableHttpTransport" - }, - "name": { - "description": "The name of the MCPServer.", - "type": "string" + "file": { + "$ref": "#/components/schemas/File", + "description": "Optional. Metadata for the file to create." } - } + }, + "type": "object", + "description": "Request for `CreateFile`." }, - "RetrievedContext": { - "description": "Chunk from context retrieved by the file search tool.", + "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": { - "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" - }, - "title": { - "description": "Optional. Title of the document.", - "type": "string" - }, - "customMetadata": { - "description": "Optional. User-provided metadata about the retrieved context.", - "type": "array", - "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" - } - }, - "text": { - "description": "Optional. Text of the chunk.", - "type": "string" - }, - "pageNumber": { - "type": "integer", - "description": "Optional. Page number of the retrieved context, if applicable.", - "format": "int32" + "category": { + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "enum": [ + "HARM_CATEGORY_UNSPECIFIED", + "HARM_CATEGORY_DEROGATORY", + "HARM_CATEGORY_TOXICITY", + "HARM_CATEGORY_VIOLENCE", + "HARM_CATEGORY_SEXUAL", + "HARM_CATEGORY_MEDICAL", + "HARM_CATEGORY_DANGEROUS", + "HARM_CATEGORY_HARASSMENT", + "HARM_CATEGORY_HATE_SPEECH", + "HARM_CATEGORY_SEXUALLY_EXPLICIT", + "HARM_CATEGORY_DANGEROUS_CONTENT", + "HARM_CATEGORY_CIVIC_INTEGRITY" + ], + "x-enum-descriptions": [ + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "type": "string", + "description": "Required. The category for this setting." }, - "fileSearchStore": { - "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", - "type": "string" + "threshold": { + "description": "Required. Controls the probability threshold at which harm is blocked.", + "x-enum-descriptions": [ + "Threshold is unspecified.", + "Content with NEGLIGIBLE will be allowed.", + "Content with NEGLIGIBLE and LOW will be allowed.", + "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", + "All content will be allowed.", + "Turn off the safety filter." + ], + "type": "string", + "enum": [ + "HARM_BLOCK_THRESHOLD_UNSPECIFIED", + "BLOCK_LOW_AND_ABOVE", + "BLOCK_MEDIUM_AND_ABOVE", + "BLOCK_ONLY_HIGH", + "BLOCK_NONE", + "OFF" + ] } }, "type": "object" }, - "EmbedContentBatchOutput": { + "GenerateContentResponse": { "type": "object", - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", "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.", + "responseId": { + "type": "string", + "description": "Output only. response_id is used to identify each response.", + "readOnly": true + }, + "modelStatus": { + "description": "Output only. The current model status of this model.", "readOnly": true, - "$ref": "#/components/schemas/InlinedEmbedContentResponses" + "$ref": "#/components/schemas/ModelStatus" }, - "responsesFile": { + "promptFeedback": { + "description": "Returns the prompt's feedback related to the content filters.", + "$ref": "#/components/schemas/PromptFeedback" + }, + "modelVersion": { "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": "Output only. The model version used to generate the response.", + "readOnly": true + }, + "candidates": { + "description": "Candidate responses from the model.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Candidate" + } + }, + "usageMetadata": { + "$ref": "#/components/schemas/UsageMetadata", + "description": "Output only. Metadata on the generation requests' token usage.", "readOnly": true } - } + }, + "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`." }, - "CustomLongRunningOperation": { - "type": "object", + "PlaceAnswerSources": { + "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", "properties": { - "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" - }, - "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." + "reviewSnippets": { + "type": "array", + "items": { + "$ref": "#/components/schemas/ReviewSnippet" }, - "type": "object" - }, - "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." - } - }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - }, - "done": { - "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", - "type": "boolean" + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps." } - } + }, + "type": "object" }, "ListFilesResponse": { "description": "Response for `ListFiles`.", + "type": "object", "properties": { + "nextPageToken": { + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", + "type": "string" + }, "files": { "description": "The list of `File`s.", + "type": "array", "items": { "$ref": "#/components/schemas/File" - }, - "type": "array" - }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", - "type": "string" + } } - }, - "type": "object" + } }, - "RetrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", + "LogprobsResult": { "properties": { - "googleSearchDynamicRetrievalScore": { - "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", + "logProbabilitySum": { + "type": "number", "format": "float", - "type": "number" + "description": "Sum of log probabilities for all tokens." + }, + "chosenCandidates": { + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" + }, + "type": "array", + "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates." + }, + "topCandidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TopCandidates" + }, + "description": "Length = total number of decoding steps." } }, - "type": "object" + "type": "object", + "description": "Logprobs Result" }, - "InlinedEmbedContentResponse": { - "description": "The response to a single request in the batch.", - "properties": { + "EmbedContentBatchOutput": { + "type": "object", + "properties": { + "responsesFile": { + "type": "string", + "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", + "readOnly": true + }, + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", + "readOnly": true, + "$ref": "#/components/schemas/InlinedEmbedContentResponses" + } + }, + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field." + }, + "StreamableHttpTransport": { + "properties": { + "url": { + "type": "string", + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"" + }, + "headers": { + "type": "object", + "additionalProperties": { + "type": "string" + }, + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed." + }, + "timeout": { + "description": "HTTP timeout for regular operations.", + "type": "string", + "format": "google-duration" + }, + "terminateOnClose": { + "description": "Whether to close the client session when the transport closes.", + "type": "boolean" + }, + "sseReadTimeout": { + "description": "Timeout for SSE read operations.", + "format": "google-duration", + "type": "string" + } + }, + "type": "object", + "description": "A transport that can stream HTTP requests and responses. Next ID: 6" + }, + "SpeakerVoiceConfig": { + "description": "The configuration for a single speaker in a multi speaker setup.", + "properties": { + "speaker": { + "type": "string", + "description": "Required. The name of the speaker to use. Should be the same as in the prompt." + }, + "voiceConfig": { + "description": "Required. The configuration for the voice to use.", + "$ref": "#/components/schemas/VoiceConfig" + } + }, + "type": "object" + }, + "RegisterFilesResponse": { + "properties": { + "files": { + "description": "The registered files to be used when calling GenerateContent.", + "type": "array", + "items": { + "$ref": "#/components/schemas/File" + } + } + }, + "type": "object", + "description": "Response for `RegisterFiles`." + }, + "InlinedResponse": { + "type": "object", + "properties": { "error": { "description": "Output only. The error encountered while processing the request.", "readOnly": true, "$ref": "#/components/schemas/Status" }, - "response": { - "$ref": "#/components/schemas/EmbedContentResponse", - "description": "Output only. The response to the request.", - "readOnly": true - }, "metadata": { - "type": "object", "description": "Output only. The metadata associated with the request.", "readOnly": true, "additionalProperties": { "description": "Properties of the object." - } + }, + "type": "object" + }, + "response": { + "description": "Output only. The response to the request.", + "readOnly": true, + "$ref": "#/components/schemas/GenerateContentResponse" } }, - "type": "object" + "description": "The response to a single request in the batch." }, - "Model": { + "GoogleAiGenerativelanguageV1betaSegment": { + "description": "Segment of the content.", "type": "object", - "description": "Information about a Generative Language Model.", "properties": { - "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" - }, - "description": { - "description": "A short description of the model.", - "type": "string" + "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" }, - "temperature": { - "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model.", - "format": "float", - "type": "number" + "text": { + "type": "string", + "description": "The text corresponding to the segment from the response." }, - "inputTokenLimit": { - "description": "Maximum number of input tokens allowed for this model.", + "partIndex": { + "description": "The index of a Part object within its parent Content object.", "format": "int32", "type": "integer" }, - "topK": { + "startIndex": { + "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", "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" + } + } + }, + "ListGeneratedFilesResponse": { + "description": "Response for `ListGeneratedFiles`.", + "properties": { + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." }, - "supportedGenerationMethods": { + "generatedFiles": { "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/GeneratedFile" }, - "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`." + "description": "The list of `GeneratedFile`s." + } + }, + "type": "object" + }, + "ListFileSearchStoresResponse": { + "properties": { + "fileSearchStores": { + "description": "The returned rag_stores.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FileSearchStore" + } }, - "version": { - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", + "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": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`." + }, + "CountTokensResponse": { + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", + "properties": { + "cachedContentTokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content)." }, - "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" + "promptTokensDetails": { + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "type": "array", + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true }, - "outputTokenLimit": { + "totalTokens": { + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", "type": "integer", - "description": "Maximum number of output tokens available for this model.", "format": "int32" }, - "thinking": { - "description": "Whether the model supports thinking.", - "type": "boolean" + "cacheTokensDetails": { + "description": "Output only. List of modalities that were processed in the cached content.", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "type": "array" + } + }, + "type": "object" + }, + "Maps": { + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", + "type": "object", + "properties": { + "text": { + "description": "Text description of the place answer.", + "type": "string" }, - "topP": { - "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", - "format": "float", - "type": "number" + "title": { + "description": "Title of the place.", + "type": "string" }, - "baseModelId": { - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "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" }, - "maxTemperature": { - "type": "number", - "description": "The maximum temperature this model can use.", - "format": "float" + "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" } } }, - "GenerateContentBatch": { + "VoiceConfig": { + "properties": { + "prebuiltVoiceConfig": { + "description": "The configuration for the prebuilt voice to use.", + "$ref": "#/components/schemas/PrebuiltVoiceConfig" + } + }, + "type": "object", + "description": "The configuration for the voice to use." + }, + "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.", "type": "object", - "description": "A resource representing a batch of `GenerateContent` requests.", "properties": { - "endTime": { - "description": "Output only. The time at which the batch processing completed.", + "ttl": { + "format": "google-duration", + "type": "string", + "description": "Input only. New TTL for this resource, input only." + }, + "createTime": { + "description": "Output only. Creation time of the cache entry.", "readOnly": true, - "format": "google-datetime", - "type": "string" + "type": "string", + "format": "google-datetime" }, "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", "type": "string" }, - "batchStats": { - "$ref": "#/components/schemas/BatchStats", - "description": "Output only. Stats about the batch.", - "readOnly": true - }, - "output": { - "description": "Output only. The output of the batch request.", - "readOnly": true, - "$ref": "#/components/schemas/GenerateContentBatchOutput" - }, - "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" + "toolConfig": { + "$ref": "#/components/schemas/ToolConfig", + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools." }, "updateTime": { - "type": "string", - "description": "Output only. The time at which the batch was last updated.", - "readOnly": true, - "format": "google-datetime" - }, - "name": { - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "description": "Output only. When the cache entry was last updated in UTC time.", "readOnly": true, + "format": "google-datetime", "type": "string" }, - "createTime": { - "description": "Output only. The time at which the batch was created.", - "readOnly": true, + "contents": { + "items": { + "$ref": "#/components/schemas/Content" + }, + "type": "array", + "description": "Optional. Input only. Immutable. The content to cache." + }, + "expireTime": { + "type": "string", "format": "google-datetime", - "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." }, - "displayName": { - "description": "Required. The user-defined name of this batch.", + "systemInstruction": { + "$ref": "#/components/schemas/Content", + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." + }, + "tools": { + "items": { + "$ref": "#/components/schemas/Tool" + }, + "type": "array", + "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response" + }, + "name": { + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", + "readOnly": true, "type": "string" }, - "state": { + "usageMetadata": { + "description": "Output only. Metadata on the usage of the cached content.", "readOnly": true, - "description": "Output only. The state of the batch.", - "type": "string", - "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" - ] + "$ref": "#/components/schemas/CachedContentUsageMetadata" }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputConfig" + "displayName": { + "type": "string", + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters." } } }, - "FileData": { - "type": "object", - "description": "URI based data.", + "GenerateContentBatchOutput": { "properties": { - "mimeType": { - "description": "Optional. The IANA standard MIME type of the source data.", - "type": "string" + "responsesFile": { + "type": "string", + "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", + "readOnly": true }, - "fileUri": { - "description": "Required. URI.", - "type": "string" + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", + "readOnly": true, + "$ref": "#/components/schemas/InlinedResponses" } - } - }, - "Empty": { + }, "type": "object", - "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", - "properties": {} + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field." }, - "StringList": { + "TunedModelSource": { + "description": "Tuned model as a source for training a new model.", "type": "object", - "description": "User provided string values assigned to a single metadata key.", "properties": { - "values": { - "items": { - "type": "string" - }, - "type": "array", - "description": "The string values of the metadata to store." + "tunedModel": { + "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`", + "type": "string" + }, + "baseModel": { + "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", + "readOnly": true, + "type": "string" } } }, - "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.", + "ToolResponse": { "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" - }, - "updateTime": { + "id": { "type": "string", - "description": "Output only. When the cache entry was last updated in UTC time.", - "readOnly": true, - "format": "google-datetime" + "description": "Optional. The identifier of the tool call this response is for." }, - "ttl": { + "toolType": { "type": "string", - "description": "Input only. New TTL for this resource, input only.", - "format": "google-duration" + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ], + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", + "x-enum-descriptions": [ + "Unspecified tool type.", + "Google search tool, maps to Tool.google_search.search_types.web_search.", + "Image search tool, maps to Tool.google_search.search_types.image_search.", + "URL context tool, maps to Tool.url_context.", + "Google maps tool, maps to Tool.google_maps.", + "File search tool, maps to Tool.file_search." + ] }, - "model": { - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", - "type": "string" + "response": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The tool response." + } + }, + "type": "object", + "description": "The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`." + }, + "Tool": { + "properties": { + "googleSearchRetrieval": { + "$ref": "#/components/schemas/GoogleSearchRetrieval", + "description": "Optional. Retrieval tool that is powered by Google search." }, - "toolConfig": { - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", - "$ref": "#/components/schemas/ToolConfig" + "codeExecution": { + "$ref": "#/components/schemas/CodeExecution", + "description": "Optional. Enables the model to execute code as part of generation." }, - "contents": { - "description": "Optional. Input only. Immutable. The content to cache.", - "type": "array", + "functionDeclarations": { + "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", "items": { - "$ref": "#/components/schemas/Content" - } + "$ref": "#/components/schemas/FunctionDeclaration" + }, + "type": "array" }, - "usageMetadata": { - "$ref": "#/components/schemas/CachedContentUsageMetadata", - "description": "Output only. Metadata on the usage of the cached content.", - "readOnly": true + "googleSearch": { + "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", + "$ref": "#/components/schemas/GoogleSearch" }, - "displayName": { - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", - "type": "string" + "fileSearch": { + "$ref": "#/components/schemas/FileSearch", + "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora." }, - "systemInstruction": { - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only.", - "$ref": "#/components/schemas/Content" + "googleMaps": { + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", + "$ref": "#/components/schemas/GoogleMaps" }, - "createTime": { - "type": "string", - "description": "Output only. Creation time of the cache entry.", - "readOnly": true, - "format": "google-datetime" + "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." }, - "tools": { - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", - "type": "array", - "items": { - "$ref": "#/components/schemas/Tool" - } + "urlContext": { + "$ref": "#/components/schemas/UrlContext", + "description": "Optional. Tool to support URL context retrieval." }, - "name": { - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", - "readOnly": true, - "type": "string" + "mcpServers": { + "description": "Optional. MCP Servers to connect to.", + "items": { + "$ref": "#/components/schemas/McpServer" + }, + "type": "array" } }, - "type": "object" + "type": "object", + "description": "Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. Next ID: 16" }, - "CreateFileResponse": { + "ImageSearch": { + "description": "Image search for grounding and related configurations.", "type": "object", - "description": "Response for `CreateFile`.", + "properties": {} + }, + "MultiSpeakerVoiceConfig": { "properties": { - "file": { - "description": "Metadata for the created file.", - "$ref": "#/components/schemas/File" + "speakerVoiceConfigs": { + "description": "Required. All the enabled speaker voices.", + "type": "array", + "items": { + "$ref": "#/components/schemas/SpeakerVoiceConfig" + } } - } + }, + "type": "object", + "description": "The configuration for the multi-speaker setup." }, - "ExecutableCode": { - "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated.", + "SearchEntryPoint": { + "description": "Google search entry point.", "properties": { - "id": { - "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`.", + "renderedContent": { + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", "type": "string" }, - "language": { - "description": "Required. Programming language of the `code`.", + "sdkBlob": { "type": "string", - "x-enum-descriptions": [ - "Unspecified language. This value should not be used.", - "Python >= 3.10, with numpy and simpy available. Python is the default language." - ], - "enum": [ - "LANGUAGE_UNSPECIFIED", - "PYTHON" - ] - }, - "code": { - "description": "Required. The code to be executed.", - "type": "string" + "format": "byte", + "description": "Optional. Base64 encoded JSON representing array of tuple." } }, "type": "object" }, - "GroundingChunkStringList": { + "ListDocumentsResponse": { "type": "object", - "description": "A list of string values.", "properties": { - "values": { + "documents": { + "description": "The returned `Document`s.", "items": { - "type": "string" + "$ref": "#/components/schemas/Document" }, + "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.", + "type": "string" + } + }, + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`." + }, + "TopCandidates": { + "description": "Candidates with top log probabilities at each decoding step.", + "properties": { + "candidates": { + "description": "Sorted by log probability in descending order.", "type": "array", - "description": "The string values of the list." + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" + } } - } + }, + "type": "object" }, - "GenerateContentBatchOutput": { + "GoogleSearch": { "type": "object", - "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", "properties": { - "inlinedResponses": { - "$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.", - "readOnly": true + "searchTypes": { + "$ref": "#/components/schemas/SearchTypes", + "description": "Optional. The set of search types to enable. If not set, web search is enabled by default." }, - "responsesFile": { - "type": "string", - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", - "readOnly": true + "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" } - } + }, + "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google." }, - "RegisterFilesRequest": { + "DynamicRetrievalConfig": { + "description": "Describes the options to customize dynamic retrieval.", "type": "object", - "description": "Request for `RegisterFiles`.", "properties": { - "uris": { - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", - "items": { - "type": "string" - }, - "type": "array" + "mode": { + "description": "The mode of the predictor to be used in dynamic retrieval.", + "x-enum-descriptions": [ + "Always trigger retrieval.", + "Run retrieval only when system decides it is necessary." + ], + "type": "string", + "enum": [ + "MODE_UNSPECIFIED", + "MODE_DYNAMIC" + ] + }, + "dynamicThreshold": { + "format": "float", + "type": "number", + "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used." } } }, - "ListCorporaResponse": { - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", + "ReviewSnippet": { + "type": "object", "properties": { - "corpora": { - "items": { - "$ref": "#/components/schemas/Corpus" - }, - "type": "array", - "description": "The returned corpora." + "reviewId": { + "type": "string", + "description": "The ID of the review snippet." }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "title": { + "type": "string", + "description": "Title of the review." + }, + "googleMapsUri": { + "description": "A link that corresponds to the user review on Google Maps.", "type": "string" } }, + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps." + }, + "InlinedRequests": { + "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/InlinedRequest" + } + } + }, "type": "object" }, - "AttributionSourceId": { - "type": "object", - "description": "Identifier for the source contributing to this attribution.", + "Status": { "properties": { - "groundingPassage": { - "description": "Identifier for an inline passage.", - "$ref": "#/components/schemas/GroundingPassageId" + "code": { + "description": "The status code, which should be an enum value of google.rpc.Code.", + "type": "integer", + "format": "int32" }, - "semanticRetrieverChunk": { - "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", - "$ref": "#/components/schemas/SemanticRetrieverChunk" + "message": { + "type": "string", + "description": "A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client." + }, + "details": { + "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", + "type": "array", + "items": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object" + } + } + }, + "type": "object", + "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors)." + }, + "WebSearch": { + "type": "object", + "properties": {}, + "description": "Standard web search for grounding and related configurations." + }, + "GoogleMaps": { + "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", + "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" } } }, - "LogprobsResultCandidate": { + "RetrievalConfig": { + "description": "Retrieval config.", "type": "object", - "description": "Candidate for the logprobs token and score.", "properties": { - "logProbability": { - "type": "number", - "description": "The candidate's log probability.", - "format": "float" + "latLng": { + "$ref": "#/components/schemas/LatLng", + "description": "Optional. The location of the user." }, - "tokenId": { - "description": "The candidate\u2019s token id value.", - "format": "int32", - "type": "integer" + "languageCode": { + "type": "string", + "description": "Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt)." + } + } + }, + "EmbedContentResponse": { + "description": "The response to an `EmbedContentRequest`.", + "type": "object", + "properties": { + "embedding": { + "$ref": "#/components/schemas/ContentEmbedding", + "description": "Output only. The embedding generated from the input content.", + "readOnly": true }, - "token": { - "description": "The candidate\u2019s token string value.", - "type": "string" + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" } } }, - "Maps": { + "EmbedContentConfig": { + "description": "Configurations for the EmbedContent request.", "type": "object", - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", "properties": { - "placeId": { - "description": "The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place.", - "type": "string" + "autoTruncate": { + "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", + "type": "boolean" }, - "uri": { - "description": "URI reference of the place.", - "type": "string" + "taskType": { + "type": "string", + "enum": [ + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ], + "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." + ] }, "title": { - "description": "Title of the place.", - "type": "string" + "type": "string", + "description": "Optional. The title for the text." }, - "text": { - "description": "Text description of the place answer.", - "type": "string" + "outputDimensionality": { + "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end.", + "format": "int32", + "type": "integer" }, - "placeAnswerSources": { - "description": "Sources that provide answers about the features of a given place in Google Maps.", - "$ref": "#/components/schemas/PlaceAnswerSources" + "documentOcr": { + "type": "boolean", + "description": "Optional. Whether to enable OCR for document content." + }, + "audioTrackExtraction": { + "type": "boolean", + "description": "Optional. Whether to extract audio from video content." } } }, - "TransferOwnershipRequest": { - "description": "Request to transfer the ownership of the tuned model.", + "InlinedResponses": { + "type": "object", "properties": { - "emailAddress": { - "description": "Required. The email address of the user to whom the tuned model is being transferred to.", - "type": "string" + "inlinedResponses": { + "items": { + "$ref": "#/components/schemas/InlinedResponse" + }, + "type": "array", + "description": "Output only. The responses to the requests in the batch.", + "readOnly": true } }, - "type": "object" + "description": "The responses to the requests in the batch." }, - "ListPermissionsResponse": { - "description": "Response from `ListPermissions` containing a paginated list of permissions.", + "RetrievalMetadata": { "properties": { - "permissions": { - "description": "Returned permissions.", + "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" + } + }, + "type": "object", + "description": "Metadata related to retrieval in the grounding flow." + }, + "UrlContextMetadata": { + "type": "object", + "properties": { + "urlMetadata": { "type": "array", "items": { - "$ref": "#/components/schemas/Permission" - } - }, - "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" + "$ref": "#/components/schemas/UrlMetadata" + }, + "description": "List of url context." } }, - "type": "object" + "description": "Metadata related to url context retrieval tool." }, - "EmbedContentBatchStats": { - "description": "Stats about the batch.", + "BatchEmbedContentsRequest": { + "type": "object", "properties": { - "requestCount": { - "description": "Output only. The number of requests in the batch.", - "readOnly": true, - "format": "int64", - "type": "string" - }, - "successfulRequestCount": { - "description": "Output only. The number of requests that were successfully processed.", - "readOnly": true, - "format": "int64", - "type": "string" - }, - "failedRequestCount": { - "type": "string", - "description": "Output only. The number of requests that failed to be processed.", - "readOnly": true, - "format": "int64" - }, - "pendingRequestCount": { - "type": "string", - "description": "Output only. The number of requests that are still pending processing.", - "readOnly": true, - "format": "int64" + "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`." } }, - "type": "object" + "description": "Batch request to get embeddings from the model for a list of prompts." }, - "Part": { + "VideoFileMetadata": { + "description": "Metadata for a video `File`.", "type": "object", - "description": "A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", "properties": { - "thought": { - "description": "Optional. Indicates if the part is thought from the model.", - "type": "boolean" - }, - "codeExecutionResult": { - "description": "Result of executing the `ExecutableCode`.", - "$ref": "#/components/schemas/CodeExecutionResult" - }, - "toolCall": { - "description": "Server-side tool call. This field is populated when the model predicts a tool invocation that should be executed on the server. The client is expected to echo this message back to the API.", - "$ref": "#/components/schemas/ToolCall" - }, - "thoughtSignature": { + "videoDuration": { "type": "string", - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", - "format": "byte" - }, - "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" - }, - "partMetadata": { - "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" - }, - "text": { - "description": "Inline text.", - "type": "string" - }, - "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" - }, - "functionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", - "$ref": "#/components/schemas/FunctionCall" - }, - "functionResponse": { - "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model.", - "$ref": "#/components/schemas/FunctionResponse" - }, - "mediaResolution": { - "description": "Optional. Media resolution for the input media.", - "$ref": "#/components/schemas/MediaResolution" - }, - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/Blob" - }, - "executableCode": { - "description": "Code generated by the model that is meant to be executed.", - "$ref": "#/components/schemas/ExecutableCode" - }, - "fileData": { - "description": "URI based data.", - "$ref": "#/components/schemas/FileData" + "format": "google-duration", + "description": "Duration of the video." } } }, - "FunctionResponseBlob": { - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", + "TuningExamples": { + "type": "object", "properties": { - "mimeType": { - "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats).", - "type": "string" - }, - "data": { - "description": "Raw bytes for media formats.", - "format": "byte", - "type": "string" + "examples": { + "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type.", + "items": { + "$ref": "#/components/schemas/TuningExample" + }, + "type": "array" } }, - "type": "object" + "description": "A set of tuning examples. Can be training or validation data." }, "GoogleSearchRetrieval": { "description": "Tool to retrieve public web data for grounding, powered by Google.", + "type": "object", "properties": { "dynamicRetrievalConfig": { "description": "Specifies the dynamic retrieval configuration for the given source.", "$ref": "#/components/schemas/DynamicRetrievalConfig" } - }, - "type": "object" - }, - "AsyncBatchEmbedContentRequest": { - "description": "Request for an `AsyncBatchEmbedContent` operation.", - "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/EmbedContentBatch" - } - }, - "type": "object" - }, - "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" + } }, - "FunctionCallingConfig": { - "description": "Configuration for specifying function calling behavior.", + "TuningExample": { + "type": "object", "properties": { - "mode": { - "enum": [ - "MODE_UNSPECIFIED", - "AUTO", - "ANY", - "NONE", - "VALIDATED" - ], + "textInput": { "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." + "description": "Optional. Text model input." }, - "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" - } + "output": { + "description": "Required. The expected model output.", + "type": "string" } }, - "type": "object" + "description": "A single example for tuning." }, - "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`.", + "TunedModel": { + "description": "A fine-tuned model created using ModelService.CreateTunedModel.", "properties": { - "toolType": { - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", + "displayName": { "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." - ], - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ] + "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces." }, - "response": { - "description": "Optional. The tool response.", - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" + "tuningTask": { + "description": "Required. The tuning task that creates the tuned model.", + "$ref": "#/components/schemas/TuningTask" }, - "id": { - "description": "Optional. The identifier of the tool call this response is for.", - "type": "string" - } - }, - "type": "object" - }, - "SemanticRetrieverChunk": { - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", - "properties": { - "source": { + "state": { "type": "string", - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", - "readOnly": true + "description": "Output only. The state of the tuned model.", + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" + ], + "readOnly": true, + "x-enum-descriptions": [ + "The default value. This value is unused.", + "The model is being created.", + "The model is ready to be used.", + "The model failed to be created." + ] }, - "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 when this model was updated.", "readOnly": true, + "format": "google-datetime", "type": "string" - } - }, - "type": "object" - }, - "BatchStats": { - "description": "Stats about the batch.", - "properties": { - "requestCount": { - "description": "Output only. The number of requests in the batch.", + }, + "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" + }, + "createTime": { + "description": "Output only. The timestamp when this model was created.", "readOnly": true, - "format": "int64", + "type": "string", + "format": "google-datetime" + }, + "description": { + "description": "Optional. A short description of this model.", "type": "string" }, - "successfulRequestCount": { + "name": { "type": "string", - "description": "Output only. The number of requests that were successfully processed.", - "readOnly": true, - "format": "int64" + "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 }, - "failedRequestCount": { - "type": "string", - "description": "Output only. The number of requests that failed to be processed.", - "readOnly": true, - "format": "int64" + "temperature": { + "format": "float", + "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." }, - "pendingRequestCount": { - "type": "string", - "description": "Output only. The number of requests that are still pending processing.", - "readOnly": true, - "format": "int64" + "topK": { + "format": "int32", + "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." + }, + "tunedModelSource": { + "$ref": "#/components/schemas/TunedModelSource", + "description": "Optional. TunedModel to use as the starting point for training the new model." + }, + "baseModel": { + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", + "type": "string" + }, + "readerProjectNumbers": { + "type": "array", + "items": { + "type": "string", + "format": "int64" + }, + "description": "Optional. List of project numbers that have read access to the tuned model." } }, "type": "object" }, - "TextResponseFormat": { + "FileData": { + "description": "URI based data.", "type": "object", - "description": "Configuration for text output format.", "properties": { "mimeType": { - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "APPLICATION_JSON", - "TEXT_PLAIN" - ], "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "JSON output format.", - "Plain text output format." - ], - "description": "Optional. The MIME type of the text output." + "description": "Optional. The IANA standard MIME type of the source data." }, - "schema": { - "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." + "fileUri": { + "description": "Required. URI.", + "type": "string" } } }, - "ListFileSearchStoresResponse": { - "type": "object", - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", + "UsageMetadata": { + "description": "Metadata on the generation request's token usage.", + "type": "object", "properties": { - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" + "cachedContentTokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content)" }, - "fileSearchStores": { + "totalTokenCount": { + "description": "Total token count for the generation request (prompt + thoughts + response candidates).", + "format": "int32", + "type": "integer" + }, + "cacheTokensDetails": { + "description": "Output only. List of modalities of the cached content in the request input.", + "readOnly": true, "type": "array", "items": { - "$ref": "#/components/schemas/FileSearchStore" - }, - "description": "The returned rag_stores." - } - } - }, - "GroundingAttribution": { - "description": "Attribution for a source that contributed to an answer.", - "properties": { - "sourceId": { - "$ref": "#/components/schemas/AttributionSourceId", - "description": "Output only. Identifier for the source contributing to this attribution.", - "readOnly": true + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "content": { - "description": "Grounding source content that makes up this attribution.", - "$ref": "#/components/schemas/Content" - } - }, - "type": "object" - }, - "FileSearchStore": { - "description": "A `FileSearchStore` is a collection of `Document`s.", - "properties": { - "updateTime": { - "type": "string", - "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "candidatesTokensDetails": { + "description": "Output only. List of modalities that were returned in the response.", "readOnly": true, - "format": "google-datetime" + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "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" + "promptTokensDetails": { + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "pendingDocumentsCount": { - "type": "string", - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", + "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" + }, + "candidatesTokenCount": { + "description": "Total number of tokens across all the generated response candidates.", + "format": "int32", + "type": "integer" + }, + "toolUsePromptTokenCount": { + "description": "Output only. Number of tokens present in tool-use prompt(s).", "readOnly": true, - "format": "int64" + "format": "int32", + "type": "integer" }, - "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`.", + "thoughtsTokenCount": { + "description": "Output only. Number of tokens of thoughts for thinking models.", "readOnly": true, - "format": "int64" + "type": "integer", + "format": "int32" }, - "name": { + "serviceTier": { + "description": "Output only. Service tier of the request.", "type": "string", - "description": "Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the \"fileSearchStores/\" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.", - "readOnly": true - }, - "failedDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", "readOnly": true, - "format": "int64", - "type": "string" + "x-enum-descriptions": [ + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." + ], + "enum": [ + "unspecified", + "standard", + "flex", + "priority" + ] }, - "createTime": { - "type": "string", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", + "toolUsePromptTokensDetails": { + "description": "Output only. List of modalities that were processed for tool-use request inputs.", "readOnly": true, - "format": "google-datetime" + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "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" + "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 }, - "activeDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "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, - "format": "int64", - "type": "string" + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } } - }, - "type": "object" + } }, - "GroundingChunk": { - "description": "A `GroundingChunk` represents a segment of supporting evidence that grounds the model's response. It can be a chunk from the web, a retrieved context from a file, or information from Google Maps.", + "InputEmbedContentConfig": { "properties": { - "web": { - "description": "Grounding chunk from the web.", - "$ref": "#/components/schemas/Web" - }, - "retrievedContext": { - "description": "Optional. Grounding chunk from context retrieved by the file search tool.", - "$ref": "#/components/schemas/RetrievedContext" - }, - "image": { - "description": "Optional. Grounding chunk from image search.", - "$ref": "#/components/schemas/Image" + "fileName": { + "type": "string", + "description": "The name of the `File` containing the input requests." }, - "maps": { - "description": "Optional. Grounding chunk from Google Maps.", - "$ref": "#/components/schemas/Maps" + "requests": { + "$ref": "#/components/schemas/InlinedEmbedContentRequests", + "description": "The requests to be processed in the batch." } }, - "type": "object" - }, - "ImageSearch": { - "description": "Image search for grounding and related configurations.", - "properties": {}, - "type": "object" - }, - "Interval": { "type": "object", - "description": "Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time.", + "description": "Configures the input to the batch request." + }, + "CustomLongRunningOperation": { "properties": { - "startTime": { - "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start.", - "format": "google-datetime", - "type": "string" + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." }, - "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", + "response": { + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object" + }, + "name": { + "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.", "type": "string" - } - } - }, - "CreateFileRequest": { - "type": "object", - "description": "Request for `CreateFile`.", - "properties": { - "file": { - "description": "Optional. Metadata for the file to create.", - "$ref": "#/components/schemas/File" - } - } - }, - "RegisterFilesResponse": { - "description": "Response for `RegisterFiles`.", - "properties": { - "files": { - "type": "array", - "items": { - "$ref": "#/components/schemas/File" + }, + "metadata": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." }, - "description": "The registered files to be used when calling GenerateContent." + "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." + }, + "done": { + "type": "boolean", + "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available." } }, "type": "object" }, - "PrebuiltVoiceConfig": { - "description": "The configuration for the prebuilt speaker to use.", - "properties": { - "voiceName": { - "description": "The name of the preset voice to use.", - "type": "string" - } - }, - "type": "object" + "Empty": { + "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", + "type": "object", + "properties": {} }, - "InlinedEmbedContentRequest": { + "EmbedContentBatchStats": { "type": "object", - "description": "The request to be processed in the batch.", "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/EmbedContentRequest" + "requestCount": { + "format": "int64", + "type": "string", + "description": "Output only. The number of requests in the batch.", + "readOnly": true }, - "metadata": { - "type": "object", - "description": "Optional. The metadata to be associated with the request.", - "additionalProperties": { - "description": "Properties of the object." - } + "successfulRequestCount": { + "type": "string", + "format": "int64", + "description": "Output only. The number of requests that were successfully processed.", + "readOnly": true + }, + "pendingRequestCount": { + "description": "Output only. The number of requests that are still pending processing.", + "readOnly": true, + "format": "int64", + "type": "string" + }, + "failedRequestCount": { + "format": "int64", + "type": "string", + "description": "Output only. The number of requests that failed to be processed.", + "readOnly": true } - } + }, + "description": "Stats about the batch." }, - "GroundingMetadata": { - "description": "Metadata returned to client when grounding is enabled.", + "ThinkingConfig": { "properties": { - "imageSearchQueries": { - "items": { - "type": "string" - }, - "type": "array", - "description": "Image search queries used for grounding." - }, - "searchEntryPoint": { - "description": "Optional. Google search entry for the following-up web searches.", - "$ref": "#/components/schemas/SearchEntryPoint" - }, - "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" - }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" - }, - "groundingSupports": { - "description": "List of grounding support.", - "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - }, - "type": "array" + "thinkingBudget": { + "description": "The number of thoughts tokens that the model should generate.", + "type": "integer", + "format": "int32" }, - "webSearchQueries": { - "description": "Web search queries for the following-up web search.", - "items": { - "type": "string" - }, - "type": "array" + "thinkingLevel": { + "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", + "x-enum-descriptions": [ + "Default value.", + "Little to no thinking.", + "Low thinking level.", + "Medium thinking level.", + "High thinking level." + ], + "type": "string", + "enum": [ + "THINKING_LEVEL_UNSPECIFIED", + "MINIMAL", + "LOW", + "MEDIUM", + "HIGH" + ] }, - "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" + "includeThoughts": { + "type": "boolean", + "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available." } }, - "type": "object" + "type": "object", + "description": "Config for thinking features." }, - "SafetySetting": { + "EmbedContentBatch": { + "description": "A resource representing a batch of `EmbedContent` requests.", "type": "object", - "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked.", "properties": { - "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" - ], + "endTime": { + "description": "Output only. The time at which the batch processing completed.", + "readOnly": true, "type": "string", - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ], - "description": "Required. The category for this setting." + "format": "google-datetime" }, - "threshold": { + "priority": { + "type": "string", + "format": "int64", + "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0." + }, + "output": { + "description": "Output only. The output of the batch request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchOutput" + }, + "model": { + "type": "string", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + }, + "updateTime": { + "description": "Output only. The time at which the batch was last updated.", + "readOnly": true, + "type": "string", + "format": "google-datetime" + }, + "state": { + "description": "Output only. The state of the batch.", "type": "string", + "readOnly": true, "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." + "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": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" - ], - "description": "Required. Controls the probability threshold at which harm is blocked." + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ] + }, + "createTime": { + "description": "Output only. The time at which the batch was created.", + "readOnly": true, + "type": "string", + "format": "google-datetime" + }, + "batchStats": { + "description": "Output only. Stats about the batch.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchStats" + }, + "displayName": { + "description": "Required. The user-defined name of this batch.", + "type": "string" + }, + "name": { + "type": "string", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "readOnly": true + }, + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputEmbedContentConfig" } } }, - "CountTokensRequest": { + "UploadToFileSearchStoreRequest": { "type": "object", - "description": "Counts the number of tokens in the `prompt` sent to a model. Models may tokenize text differently, so each model may return a different `token_count`.", "properties": { - "contents": { + "displayName": { + "type": "string", + "description": "Optional. Display name of the created document." + }, + "customMetadata": { + "type": "array", "items": { - "$ref": "#/components/schemas/Content" + "$ref": "#/components/schemas/CustomMetadata" }, - "type": "array", - "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" - } - } - }, - "GoogleSearch": { - "type": "object", - "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "properties": { - "timeRangeFilter": { - "description": "Optional. Filter search results to a specific time range. If customers set a start time, they must set an end time (and vice versa).", - "$ref": "#/components/schemas/Interval" + "description": "Custom metadata to be associated with the data." }, - "searchTypes": { - "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", - "$ref": "#/components/schemas/SearchTypes" - } - } - }, - "WhiteSpaceConfig": { - "description": "Configuration for a white space chunking algorithm [white space delimited].", - "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" + "chunkingConfig": { + "$ref": "#/components/schemas/ChunkingConfig", + "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters." }, - "maxOverlapTokens": { - "type": "integer", - "description": "Maximum number of overlapping tokens between two adjacent chunks.", - "format": "int32" + "mimeType": { + "type": "string", + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content." } }, - "type": "object" - }, - "UrlContext": { - "type": "object", - "description": "Tool to support URL context retrieval.", - "properties": {} + "description": "Request for `UploadToFileSearchStore`." }, - "SearchTypes": { + "GroundingAttribution": { "type": "object", - "description": "Different types of search that can be enabled on the GoogleSearch tool.", "properties": { - "webSearch": { - "description": "Optional. Enables web search. Only text results are returned.", - "$ref": "#/components/schemas/WebSearch" + "sourceId": { + "$ref": "#/components/schemas/AttributionSourceId", + "description": "Output only. Identifier for the source contributing to this attribution.", + "readOnly": true }, - "imageSearch": { - "description": "Optional. Enables image search. Image bytes are returned.", - "$ref": "#/components/schemas/ImageSearch" + "content": { + "description": "Grounding source content that makes up this attribution.", + "$ref": "#/components/schemas/Content" } - } + }, + "description": "Attribution for a source that contributed to an answer." }, - "ImageConfig": { + "GeneratedFile": { + "description": "A file generated on behalf of a user.", "type": "object", - "description": "Config for image generation features.", "properties": { - "imageSize": { - "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`.", + "name": { + "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", "type": "string" }, - "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" - } - } - }, - "CodeExecution": { - "type": "object", - "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", - "properties": {} - }, - "ListModelsResponse": { - "type": "object", - "description": "Response from `ListModel` containing a paginated list of Models.", - "properties": { - "models": { - "description": "The returned Models.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Model" - } + "mimeType": { + "type": "string", + "description": "MIME type of the generatedFile." }, - "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" + "state": { + "description": "Output only. The state of the GeneratedFile.", + "type": "string", + "readOnly": true, + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "Being generated.", + "Generated and is ready for download.", + "Failed to generate the GeneratedFile." + ], + "enum": [ + "STATE_UNSPECIFIED", + "GENERATING", + "GENERATED", + "FAILED" + ] + }, + "error": { + "$ref": "#/components/schemas/Status", + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state." } } }, - "CountTokensResponse": { - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", + "ContentEmbedding": { + "description": "A list of floats representing an embedding.", + "type": "object", "properties": { - "totalTokens": { - "type": "integer", - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", - "format": "int32" - }, - "cacheTokensDetails": { + "shape": { + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "integer", + "format": "int32" }, - "type": "array", - "description": "Output only. List of modalities that were processed in the cached content.", - "readOnly": true + "type": "array" }, - "promptTokensDetails": { - "type": "array", + "values": { + "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "number", + "format": "float" }, - "description": "Output only. List of modalities that were processed in the request input.", - "readOnly": true - }, - "cachedContentTokenCount": { - "type": "integer", - "description": "Number of tokens in the cached part of the prompt (the cached content).", - "format": "int32" + "type": "array" } - }, - "type": "object" + } }, - "BatchGenerateContentRequest": { - "description": "Request for a `BatchGenerateContent` operation.", + "CachedContentUsageMetadata": { "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/GenerateContentBatch" + "totalTokenCount": { + "description": "Total number of tokens that the cached content consumes.", + "type": "integer", + "format": "int32" } }, - "type": "object" + "type": "object", + "description": "Metadata on the usage of the cached content." }, - "Schema": { + "CitationSource": { + "description": "A citation to a source for a portion of a specific response.", "type": "object", - "description": "The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema).", "properties": { - "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." + "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" }, - "title": { - "description": "Optional. The title of the schema.", + "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" }, - "maximum": { - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", - "format": "double", - "type": "number" - }, - "maxProperties": { - "type": "string", - "description": "Optional. Maximum number of the properties for Type.OBJECT.", - "format": "int64" - }, - "properties": { - "type": "object", - "description": "Optional. Properties of Type.OBJECT.", - "additionalProperties": { - "$ref": "#/components/schemas/Schema" - } + "endIndex": { + "description": "Optional. End of the attributed segment, exclusive.", + "format": "int32", + "type": "integer" }, - "minLength": { - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", - "format": "int64", + "uri": { + "description": "Optional. URI that is attributed as a source for a portion of the text.", "type": "string" - }, - "required": { + } + } + }, + "ListCachedContentsResponse": { + "type": "object", + "properties": { + "cachedContents": { + "description": "List of cached contents.", "items": { - "type": "string" + "$ref": "#/components/schemas/CachedContent" }, - "type": "array", - "description": "Optional. Required properties of Type.OBJECT." + "type": "array" }, - "pattern": { - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", + "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": "Response with CachedContents list." + }, + "TransferOwnershipResponse": { + "description": "Response from `TransferOwnership`.", + "properties": {}, + "type": "object" + }, + "FunctionDeclaration": { + "description": "Structured representation of a function declaration as defined by the [OpenAPI 3.03 specification](https://spec.openapis.org/oas/v3.0.3). Included in this declaration are the function name and parameters. This FunctionDeclaration is a representation of a block of code that can be used as a `Tool` by the model and executed by the client.", + "properties": { + "description": { + "type": "string", + "description": "Required. A brief description of the function." }, - "format": { - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", + "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`." + }, + "name": { + "description": "Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128.", "type": "string" }, - "maxItems": { - "type": "string", - "description": "Optional. Maximum number of the elements for Type.ARRAY.", - "format": "int64" + "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" }, - "maxLength": { - "type": "string", - "description": "Optional. Maximum length of the Type.STRING", - "format": "int64" + "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`." }, - "propertyOrdering": { - "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response.", - "type": "array", - "items": { - "type": "string" - } + "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": { + "behavior": { + "type": "string", "enum": [ - "TYPE_UNSPECIFIED", - "STRING", - "NUMBER", - "INTEGER", - "BOOLEAN", - "ARRAY", - "OBJECT", - "NULL" + "UNSPECIFIED", + "BLOCKING", + "NON_BLOCKING" ], - "type": "string", + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", "x-enum-descriptions": [ - "Not specified, should not be used.", - "String type.", - "Number type.", - "Integer type.", - "Boolean type.", - "Array type.", - "Object type.", - "Null type." - ], - "description": "Required. Data type." - }, - "enum": { - "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}", - "items": { - "type": "string" - }, - "type": "array" + "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." + ] + } + }, + "type": "object" + }, + "GroundingChunkCustomMetadata": { + "properties": { + "stringListValue": { + "description": "Optional. A list of string values for the metadata.", + "$ref": "#/components/schemas/GroundingChunkStringList" }, - "minItems": { - "description": "Optional. Minimum number of the elements for Type.ARRAY.", - "format": "int64", - "type": "string" + "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" }, - "description": { - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "stringValue": { + "description": "Optional. The string value of the metadata.", "type": "string" }, - "nullable": { - "description": "Optional. Indicates if the value may be null.", - "type": "boolean" - }, - "items": { - "description": "Optional. Schema of the elements of Type.ARRAY.", - "$ref": "#/components/schemas/Schema" - }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." + "key": { + "type": "string", + "description": "The key of the metadata." + } + }, + "type": "object", + "description": "User provided metadata about the GroundingFact." + }, + "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": { + "latitude": { + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", + "format": "double", + "type": "number" }, - "anyOf": { - "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", + "longitude": { + "type": "number", + "format": "double", + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0]." + } + }, + "type": "object" + }, + "ChunkingConfig": { + "description": "Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto", + "type": "object", + "properties": { + "whiteSpaceConfig": { + "description": "White space chunking configuration.", + "$ref": "#/components/schemas/WhiteSpaceConfig" + } + } + }, + "CountTokensRequest": { + "type": "object", + "properties": { + "contents": { + "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set.", "items": { - "$ref": "#/components/schemas/Schema" + "$ref": "#/components/schemas/Content" }, "type": "array" }, - "minProperties": { - "description": "Optional. Minimum number of the properties for Type.OBJECT.", - "format": "int64", - "type": "string" - }, - "minimum": { - "type": "number", - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "format": "double" + "generateContentRequest": { + "$ref": "#/components/schemas/GenerateContentRequest", + "description": "Optional. The overall input given to the `Model`. This includes the prompt as well as other model steering information like [system instructions](https://ai.google.dev/gemini-api/docs/system-instructions), and/or function declarations for [function calling](https://ai.google.dev/gemini-api/docs/function-calling). `Model`s/`Content`s and `generate_content_request`s are mutually exclusive. You can either send `Model` + `Content`s or a `generate_content_request`, but never both." } - } + }, + "description": "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`." }, - "Hyperparameters": { - "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", + "CustomMetadata": { + "description": "User provided metadata stored as key-value pairs.", "properties": { - "learningRate": { - "type": "number", - "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples.", - "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" + "stringListValue": { + "description": "The StringList value of the metadata to store.", + "$ref": "#/components/schemas/StringList" }, - "learningRateMultiplier": { + "numericValue": { + "description": "The numeric value of the metadata to store.", "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" }, - "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" + "stringValue": { + "type": "string", + "description": "The string value of the metadata to store." + }, + "key": { + "description": "Required. The key of the metadata to store.", + "type": "string" } }, "type": "object" }, - "Dataset": { + "Candidate": { + "description": "A response candidate generated from the model.", "type": "object", - "description": "Dataset for training or validation.", - "properties": { - "examples": { - "description": "Optional. Inline examples with simple input/output text.", - "$ref": "#/components/schemas/TuningExamples" - } - } - }, - "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": { - "modelVersion": { - "type": "string", - "description": "Output only. The model version used to generate the response.", + "citationMetadata": { + "$ref": "#/components/schemas/CitationMetadata", + "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data.", "readOnly": true }, - "candidates": { - "description": "Candidate responses from the model.", - "items": { - "$ref": "#/components/schemas/Candidate" - }, - "type": "array" + "urlContextMetadata": { + "description": "Output only. Metadata related to url context retrieval tool.", + "readOnly": true, + "$ref": "#/components/schemas/UrlContextMetadata" }, - "responseId": { - "type": "string", - "description": "Output only. response_id is used to identify each response.", + "logprobsResult": { + "$ref": "#/components/schemas/LogprobsResult", + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", "readOnly": true }, - "promptFeedback": { - "description": "Returns the prompt's feedback related to the content filters.", - "$ref": "#/components/schemas/PromptFeedback" + "groundingMetadata": { + "$ref": "#/components/schemas/GroundingMetadata", + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", + "readOnly": true }, - "usageMetadata": { - "$ref": "#/components/schemas/UsageMetadata", - "description": "Output only. Metadata on the generation requests' token usage.", + "index": { + "type": "integer", + "format": "int32", + "description": "Output only. Index of the candidate in the list of response candidates.", "readOnly": true }, - "modelStatus": { - "description": "Output only. The current model status of this model.", - "readOnly": true, - "$ref": "#/components/schemas/ModelStatus" - } - }, - "type": "object" - }, - "ContentEmbedding": { - "description": "A list of floats representing an embedding.", - "properties": { - "values": { - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "safetyRatings": { + "type": "array", "items": { - "type": "number", - "format": "float" + "$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." }, - "shape": { - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", + "groundingAttributions": { + "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", + "readOnly": true, "items": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/GroundingAttribution" }, "type": "array" - } - }, - "type": "object" - }, - "ResponseFormatConfig": { - "type": "object", - "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality.", - "properties": { - "text": { - "description": "Optional. Text output format configuration.", - "$ref": "#/components/schemas/TextResponseFormat" }, - "image": { - "description": "Optional. Image output format configuration.", - "$ref": "#/components/schemas/ImageResponseFormat" + "content": { + "$ref": "#/components/schemas/Content", + "description": "Output only. Generated content returned from the model.", + "readOnly": true }, - "audio": { - "description": "Optional. Audio output format configuration.", - "$ref": "#/components/schemas/AudioResponseFormat" - } - } - }, - "UrlContextMetadata": { - "type": "object", - "description": "Metadata related to url context retrieval tool.", - "properties": { - "urlMetadata": { - "type": "array", - "items": { - "$ref": "#/components/schemas/UrlMetadata" - }, - "description": "List of url context." - } - } - }, - "InlinedResponse": { - "description": "The response to a single request in the batch.", - "properties": { - "response": { - "description": "Output only. The response to the request.", + "avgLogprobs": { + "format": "double", + "type": "number", + "description": "Output only. Average log probability score of the candidate.", + "readOnly": true + }, + "tokenCount": { + "description": "Output only. Token count for this candidate.", "readOnly": true, - "$ref": "#/components/schemas/GenerateContentResponse" + "format": "int32", + "type": "integer" }, - "metadata": { - "description": "Output only. The metadata associated with the request.", + "finishReason": { + "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", + "type": "string", "readOnly": true, - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" + "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" + ] }, - "error": { - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request.", - "readOnly": true + "finishMessage": { + "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.", + "readOnly": true, + "type": "string" } - }, - "type": "object" + } }, - "InlinedRequests": { + "InlinedEmbedContentRequests": { "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { "requests": { - "items": { - "$ref": "#/components/schemas/InlinedRequest" - }, + "description": "Required. The requests to be processed in the batch.", "type": "array", - "description": "Required. The requests to be processed in the batch." + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentRequest" + } } }, "type": "object" }, - "InlinedEmbedContentResponses": { + "WhiteSpaceConfig": { + "description": "Configuration for a white space chunking algorithm [white space delimited].", "type": "object", - "description": "The responses to the requests in the batch.", "properties": { - "inlinedResponses": { - "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" - }, - "type": "array", - "description": "Output only. The responses to the requests in the batch.", - "readOnly": true + "maxTokensPerChunk": { + "description": "Maximum number of tokens per chunk. Tokens are defined as words for this chunking algorithm. Note: we are defining tokens as words split by whitespace as opposed to the output of a tokenizer. The context window of the latest gemini embedding model as of 2025-04-17 is currently 8192 tokens. We assume that the average word is 5 characters. Therefore, we set the upper limit to 2**9, which is 512 words, or 2560 tokens, assuming worst case a character per token. This is a conservative estimate meant to prevent context window overflow.", + "type": "integer", + "format": "int32" + }, + "maxOverlapTokens": { + "type": "integer", + "format": "int32", + "description": "Maximum number of overlapping tokens between two adjacent chunks." } } }, - "FunctionResponse": { + "Operation": { "type": "object", - "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", "properties": { - "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" + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." }, - "id": { - "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`.", + "name": { + "description": "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" }, "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." - } - }, - "parts": { - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", - "type": "array", - "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - } + "description": "Properties of the object. Contains field @type with type URL." + }, + "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`." }, - "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" + "metadata": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object", + "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any." }, - "scheduling": { - "type": "string", - "x-enum-descriptions": [ - "This value is unused.", - "Only add the result to the conversation context, do not interrupt or trigger generation.", - "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", - "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." - ], - "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" - ], - "description": "Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE." + "done": { + "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" } - } + }, + "description": "This resource represents a long-running operation that is the result of a network API call." }, - "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.", + "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": { - "latitude": { - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", - "format": "double", - "type": "number" - }, - "longitude": { - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", - "format": "double", - "type": "number" + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/FunctionResponseBlob" } }, "type": "object" }, - "SafetyRating": { - "description": "Safety rating for a piece of content. The safety rating contains the category of harm and the harm probability level in that category for a piece of content. Content is classified for safety across a number of harm categories and the probability of the harm classification is included here.", + "ListPermissionsResponse": { + "type": "object", "properties": { - "probability": { - "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." - ], - "enum": [ - "HARM_PROBABILITY_UNSPECIFIED", - "NEGLIGIBLE", - "LOW", - "MEDIUM", - "HIGH" - ], - "description": "Required. The probability of harm for this content." - }, - "blocked": { - "description": "Was this content blocked because of this rating?", - "type": "boolean" + "permissions": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Permission" + }, + "description": "Returned permissions." }, - "category": { - "description": "Required. The category for this rating.", + "nextPageToken": { "type": "string", - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ], - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ] + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." } }, - "type": "object" + "description": "Response from `ListPermissions` containing a paginated list of permissions." }, - "TopCandidates": { + "TuningTask": { "type": "object", - "description": "Candidates with top log probabilities at each decoding step.", "properties": { - "candidates": { + "completeTime": { + "description": "Output only. The timestamp when tuning this model completed.", + "readOnly": true, + "format": "google-datetime", + "type": "string" + }, + "snapshots": { + "description": "Output only. Metrics collected during tuning.", + "readOnly": true, "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" + "$ref": "#/components/schemas/TuningSnapshot" }, - "type": "array", - "description": "Sorted by log probability in descending order." - } - } - }, - "SearchEntryPoint": { - "type": "object", - "description": "Google search entry point.", - "properties": { - "sdkBlob": { + "type": "array" + }, + "hyperparameters": { + "$ref": "#/components/schemas/Hyperparameters", + "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used." + }, + "startTime": { "type": "string", - "description": "Optional. Base64 encoded JSON representing array of tuple.", - "format": "byte" + "format": "google-datetime", + "description": "Output only. The timestamp when tuning this model started.", + "readOnly": true }, - "renderedContent": { - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", - "type": "string" + "trainingData": { + "$ref": "#/components/schemas/Dataset", + "description": "Required. Input only. Immutable. The model training data." } - } + }, + "description": "Tuning tasks that create tuned models." }, - "FunctionDeclaration": { + "Image": { "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.", "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.", + "domain": { + "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", "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`." - }, - "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" + "sourceUri": { + "description": "The web page URI for attribution.", + "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" + "imageUri": { + "type": "string", + "description": "The image asset URL." }, - "description": { - "description": "Required. A brief description of the function.", + "title": { + "description": "The title of the web page that the image is from.", "type": "string" + } + }, + "description": "Chunk from image search." + }, + "Content": { + "description": "The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn.", + "properties": { + "parts": { + "items": { + "$ref": "#/components/schemas/Part" + }, + "type": "array", + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types." }, - "behavior": { - "enum": [ - "UNSPECIFIED", - "BLOCKING", - "NON_BLOCKING" - ], + "role": { "type": "string", - "x-enum-descriptions": [ - "This value is unused.", - "If set, the system will wait to receive the function response before continuing the conversation.", - "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." - ], - "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method." - }, - "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`." + "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset." } - } + }, + "type": "object" }, - "Candidate": { + "TuningSnapshot": { + "description": "Record for a single tuning step.", "type": "object", - "description": "A response candidate generated from the model.", "properties": { - "content": { - "description": "Output only. Generated content returned from the model.", + "step": { + "description": "Output only. The tuning step.", "readOnly": true, - "$ref": "#/components/schemas/Content" + "type": "integer", + "format": "int32" }, - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", - "readOnly": true, - "$ref": "#/components/schemas/LogprobsResult" - }, - "finishMessage": { - "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.", - "readOnly": true, - "type": "string" - }, - "urlContextMetadata": { - "$ref": "#/components/schemas/UrlContextMetadata", - "description": "Output only. Metadata related to url context retrieval tool.", - "readOnly": true - }, - "avgLogprobs": { - "description": "Output only. Average log probability score of the candidate.", - "readOnly": true, - "format": "double", - "type": "number" - }, - "tokenCount": { - "type": "integer", - "description": "Output only. Token count for this candidate.", - "readOnly": true, - "format": "int32" - }, - "finishReason": { - "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", + "computeTime": { + "format": "google-datetime", "type": "string", - "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" - ], + "description": "Output only. The timestamp when this metric was computed.", "readOnly": true }, - "index": { - "description": "Output only. Index of the candidate in the list of response candidates.", + "epoch": { + "description": "Output only. The epoch this step was part of.", "readOnly": true, "format": "int32", "type": "integer" }, - "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.", + "meanLoss": { + "description": "Output only. The mean loss of the training examples for this step.", "readOnly": true, - "$ref": "#/components/schemas/CitationMetadata" - }, - "groundingAttributions": { - "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.", - "readOnly": true - }, - "safetyRatings": { - "description": "List of ratings for the safety of a response candidate. There is at most one rating per category.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SafetyRating" - } - }, - "groundingMetadata": { - "$ref": "#/components/schemas/GroundingMetadata", - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", - "readOnly": true + "type": "number", + "format": "float" } } }, - "GroundingPassageId": { - "description": "Identifier for a part within a `GroundingPassage`.", - "properties": { - "passageId": { - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", - "readOnly": true, - "type": "string" - }, - "partIndex": { - "type": "integer", - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", - "readOnly": true, - "format": "int32" - } - }, - "type": "object" - }, - "CodeExecutionResult": { + "AttributionSourceId": { + "description": "Identifier for the source contributing to this attribution.", "type": "object", - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", "properties": { - "outcome": { - "description": "Required. Outcome of the code execution.", - "type": "string", - "x-enum-descriptions": [ - "Unspecified status. This value should not be used.", - "Code execution completed successfully. `output` contains the stdout, if any.", - "Code execution failed. `output` contains the stderr and stdout, if any.", - "Code execution ran for too long, and was cancelled. There may or may not be a partial `output` present." - ], - "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" - ] - }, - "output": { - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", - "type": "string" + "semanticRetrieverChunk": { + "$ref": "#/components/schemas/SemanticRetrieverChunk", + "description": "Identifier for a `Chunk` fetched via Semantic Retriever." }, - "id": { - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", - "type": "string" + "groundingPassage": { + "$ref": "#/components/schemas/GroundingPassageId", + "description": "Identifier for an inline passage." } } }, - "WebSearch": { - "type": "object", - "description": "Standard web search for grounding and related configurations.", - "properties": {} - }, "ModalityTokenCount": { - "type": "object", "description": "Represents token counting info for a single modality.", "properties": { - "tokenCount": { - "description": "Number of tokens.", - "format": "int32", - "type": "integer" - }, "modality": { - "description": "The modality associated with this token count.", "type": "string", - "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." - ], "enum": [ "MODALITY_UNSPECIFIED", "TEXT", @@ -4713,918 +4646,748 @@ "VIDEO", "AUDIO", "DOCUMENT" + ], + "description": "The modality associated with this token count.", + "x-enum-descriptions": [ + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." ] + }, + "tokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens." } - } + }, + "type": "object" }, - "GenerateContentRequest": { + "GroundingChunkStringList": { + "description": "A list of string values.", "type": "object", - "description": "Request to generate a completion from the model.", "properties": { - "cachedContent": { - "description": "Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}`", - "type": "string" + "values": { + "description": "The string values of the list.", + "type": "array", + "items": { + "type": "string" + } + } + } + }, + "GenerationConfig": { + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "properties": { + "maxOutputTokens": { + "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function.", + "type": "integer", + "format": "int32" }, - "systemInstruction": { - "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", - "$ref": "#/components/schemas/Content" + "temperature": { + "type": "number", + "format": "float", + "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]." }, - "safetySettings": { + "topK": { + "type": "integer", + "format": "int32", + "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests." + }, + "logprobs": { + "type": "integer", + "format": "int32", + "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]." + }, + "stopSequences": { "items": { - "$ref": "#/components/schemas/SafetySetting" + "type": "string" }, "type": "array", - "description": "Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications." + "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." }, - "store": { - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", - "type": "boolean" + "translationConfig": { + "description": "Optional. Config for translation.", + "$ref": "#/components/schemas/TranslationConfig" }, - "generationConfig": { - "description": "Optional. Configuration options for model generation and outputs.", - "$ref": "#/components/schemas/GenerationConfig" + "responseMimeType": { + "type": "string", + "description": "Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types." }, - "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." + "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." }, - "serviceTier": { - "description": "Optional. The service tier of the request.", + "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." + }, + "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." + }, + "seed": { + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "format": "int32", + "type": "integer" + }, + "mediaResolution": { + "type": "string", "enum": [ - "unspecified", - "standard", - "flex", - "priority" + "MEDIA_RESOLUTION_UNSPECIFIED", + "MEDIA_RESOLUTION_LOW", + "MEDIA_RESOLUTION_MEDIUM", + "MEDIA_RESOLUTION_HIGH" ], - "type": "string", + "description": "Optional. If specified, the media resolution specified will be used.", "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "Media resolution has not been set.", + "Media resolution set to low (64 tokens).", + "Media resolution set to medium (256 tokens).", + "Media resolution set to high (zoomed reframing with 256 tokens)." ] }, - "contents": { - "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Content" - } - }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." }, - "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" - } - } - }, - "AudioResponseFormat": { - "description": "Configuration for audio output format.", - "properties": { - "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." - ], - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "AUDIO_MP3", - "AUDIO_OGG_OPUS", - "AUDIO_L16", - "AUDIO_WAV", - "AUDIO_ALAW", - "AUDIO_MULAW" - ], - "description": "Optional. The MIME type of the audio output." + "responseModalities": { + "items": { + "type": "string", + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "AUDIO", + "VIDEO" + ], + "x-enum-descriptions": [ + "Default value.", + "Indicates the model should return text.", + "Indicates the model should return images.", + "Indicates the model should return audio.", + "Indicates the model should return video." + ] + }, + "type": "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." }, - "delivery": { - "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." - ], - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" - ], - "description": "Optional. The delivery mode for the audio output." + "presencePenalty": { + "description": "Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary.", + "format": "float", + "type": "number" }, - "sampleRate": { - "description": "Optional. Sample rate in Hz.", + "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" }, - "bitRate": { - "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus).", - "format": "int32", - "type": "integer" + "speechConfig": { + "description": "Optional. The speech generation config.", + "$ref": "#/components/schemas/SpeechConfig" + }, + "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" + }, + "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" + }, + "frequencyPenalty": { + "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit.", + "type": "number", + "format": "float" + }, + "responseLogprobs": { + "type": "boolean", + "description": "Optional. If true, export the logprobs results in response." + }, + "enableEnhancedCivicAnswers": { + "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", + "type": "boolean" } }, "type": "object" }, - "ListTunedModelsResponse": { - "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "ToolConfig": { "properties": { - "tunedModels": { - "items": { - "$ref": "#/components/schemas/TunedModel" - }, - "type": "array", - "description": "The returned Models." + "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" }, - "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" + "functionCallingConfig": { + "description": "Optional. Function calling config.", + "$ref": "#/components/schemas/FunctionCallingConfig" + }, + "retrievalConfig": { + "description": "Optional. Retrieval config.", + "$ref": "#/components/schemas/RetrievalConfig" } }, - "type": "object" + "type": "object", + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request." }, - "Corpus": { + "RetrievedContext": { + "description": "Chunk from context retrieved by the file search tool.", "type": "object", - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", "properties": { - "name": { + "title": { + "description": "Optional. Title of the document.", + "type": "string" + }, + "text": { "type": "string", - "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", - "readOnly": true + "description": "Optional. Text of the chunk." }, - "updateTime": { + "fileSearchStore": { "type": "string", - "description": "Output only. The Timestamp of when the `Corpus` was last updated.", - "readOnly": true, - "format": "google-datetime" + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`" }, - "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\"", + "pageNumber": { + "description": "Optional. Page number of the retrieved context, if applicable.", + "format": "int32", + "type": "integer" + }, + "mediaId": { + "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}", "type": "string" }, - "createTime": { - "description": "Output only. The Timestamp of when the `Corpus` was created.", - "readOnly": true, - "format": "google-datetime", + "uri": { + "description": "Optional. URI reference of the semantic retrieval document.", "type": "string" + }, + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + }, + "description": "Optional. User-provided metadata about the retrieved context." } } }, - "VideoMetadata": { - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", + "Hyperparameters": { + "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", + "type": "object", "properties": { - "startOffset": { - "type": "string", - "description": "Optional. The start offset of the video.", - "format": "google-duration" + "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" }, - "endOffset": { - "description": "Optional. The end offset of the video.", - "format": "google-duration", - "type": "string" + "learningRateMultiplier": { + "type": "number", + "format": "float", + "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used." }, - "fps": { + "learningRate": { "type": "number", - "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": "object", - "deprecated": true - }, - "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" + "format": "float", + "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples." + }, + "batchSize": { + "type": "integer", + "format": "int32", + "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples." } - }, - "type": "object" + } }, - "Web": { - "description": "Chunk from the web.", + "ToolCall": { "properties": { - "uri": { + "id": { "type": "string", - "description": "Output only. URI reference of the chunk.", - "readOnly": true + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`." }, - "title": { - "description": "Output only. Title of the chunk.", - "readOnly": true, - "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." + ], + "type": "string", + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ] + }, + "args": { + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object", + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}" } }, - "type": "object" + "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`." }, - "MultiSpeakerVoiceConfig": { - "description": "The configuration for the multi-speaker setup.", + "RegisterFilesRequest": { + "type": "object", "properties": { - "speakerVoiceConfigs": { - "description": "Required. All the enabled speaker voices.", - "type": "array", + "uris": { "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" - } + "type": "string" + }, + "type": "array", + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`." } }, - "type": "object" + "description": "Request for `RegisterFiles`." }, - "CustomMetadata": { - "description": "User provided metadata stored as key-value pairs.", + "BatchGenerateContentRequest": { + "type": "object", "properties": { - "numericValue": { - "type": "number", - "description": "The numeric value of the metadata to store.", - "format": "float" - }, - "key": { - "description": "Required. The key of the metadata to store.", - "type": "string" - }, - "stringValue": { - "description": "The string value of the metadata to store.", - "type": "string" - }, - "stringListValue": { - "description": "The StringList value of the metadata to store.", - "$ref": "#/components/schemas/StringList" + "batch": { + "$ref": "#/components/schemas/GenerateContentBatch", + "description": "Required. The batch to create." } }, - "type": "object" + "description": "Request for a `BatchGenerateContent` operation." }, - "CitationMetadata": { - "description": "A collection of source attributions for a piece of content.", + "Document": { + "description": "A `Document` is a collection of `Chunk`s.", "properties": { - "citationSources": { - "description": "Citations to sources for a specific response.", + "customMetadata": { + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", "items": { - "$ref": "#/components/schemas/CitationSource" + "$ref": "#/components/schemas/CustomMetadata" }, "type": "array" - } - }, - "type": "object" - }, - "EmbedContentBatch": { - "description": "A resource representing a batch of `EmbedContent` requests.", - "properties": { - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputEmbedContentConfig" }, - "displayName": { - "description": "Required. The user-defined name of this batch.", + "updateTime": { + "description": "Output only. The Timestamp of when the `Document` was last updated.", + "readOnly": true, + "format": "google-datetime", "type": "string" }, "state": { - "description": "Output only. The state of the batch.", - "type": "string", + "readOnly": true, "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." + "The default value. This value is used if the state is omitted.", + "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", + "All `Chunks` of the `Document` is processed and available for querying.", + "Some `Chunks` of the `Document` failed processing." ], "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" ], - "readOnly": true + "description": "Output only. Current state of the `Document`.", + "type": "string" }, "createTime": { - "description": "Output only. The time at which the batch was created.", + "description": "Output only. The Timestamp of when the `Document` was created.", "readOnly": true, - "format": "google-datetime", - "type": "string" - }, - "name": { - "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "readOnly": true - }, - "updateTime": { "type": "string", - "description": "Output only. The time at which the batch was last updated.", - "readOnly": true, "format": "google-datetime" }, - "output": { - "description": "Output only. The output of the batch request.", - "readOnly": true, - "$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", - "type": "string" + "displayName": { + "type": "string", + "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"" }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "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" }, - "batchStats": { - "$ref": "#/components/schemas/EmbedContentBatchStats", - "description": "Output only. Stats about the batch.", + "sizeBytes": { + "type": "string", + "format": "int64", + "description": "Output only. The size of raw bytes ingested into the Document.", "readOnly": true }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "readOnly": true, - "format": "google-datetime", - "type": "string" + "mimeType": { + "type": "string", + "description": "Output only. The mime type of the Document.", + "readOnly": true } }, "type": "object" }, - "ImportFileRequest": { - "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`.", + "GroundingMetadata": { + "description": "Metadata returned to client when grounding is enabled.", "properties": { - "fileName": { - "description": "Required. The name of the `File` to import. Example: `files/abc-123`", - "type": "string" - }, - "customMetadata": { + "imageSearchQueries": { + "description": "Image search queries used for grounding.", + "type": "array", "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, + "type": "string" + } + }, + "groundingSupports": { + "description": "List of grounding support.", "type": "array", - "description": "Custom metadata to be associated with the file." + "items": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" + } }, - "chunkingConfig": { - "description": "Optional. Config for telling the service how to chunk the file. If not provided, the service will use default parameters.", - "$ref": "#/components/schemas/ChunkingConfig" - } - }, - "type": "object" - }, - "PlaceAnswerSources": { - "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.", - "properties": { - "reviewSnippets": { - "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", + "webSearchQueries": { "items": { - "$ref": "#/components/schemas/ReviewSnippet" + "type": "string" }, - "type": "array" - } - } - }, - "TranslationConfig": { - "type": "object", - "description": "Config for translation features.", - "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" + "type": "array", + "description": "Web search queries for the following-up web search." }, - "targetLanguageCode": { - "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\").", + "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" - } - } - }, - "SpeechConfig": { - "description": "Config for speech generation and transcription.", - "properties": { - "voiceConfig": { - "description": "The configuration in case of single-voice output.", - "$ref": "#/components/schemas/VoiceConfig" }, - "multiSpeakerVoiceConfig": { - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" + "searchEntryPoint": { + "$ref": "#/components/schemas/SearchEntryPoint", + "description": "Optional. Google search entry for the following-up web searches." }, - "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" + "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" + }, + "retrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", + "$ref": "#/components/schemas/RetrievalMetadata" } }, "type": "object" }, - "UploadToFileSearchStoreRequest": { - "type": "object", - "description": "Request for `UploadToFileSearchStore`.", + "EmbedContentRequest": { "properties": { - "mimeType": { - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", + "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" }, - "displayName": { - "description": "Optional. Display name of the created document.", + "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, "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" + "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, + "type": "integer", + "format": "int32" }, - "customMetadata": { - "description": "Custom metadata to be associated with the data.", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "type": "array" - } - } - }, - "ToolCall": { - "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`.", - "properties": { - "toolType": { - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ], + "content": { + "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", + "$ref": "#/components/schemas/Content" + }, + "taskType": { + "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", + "deprecated": true, "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." + "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": "Required. The type of tool that was called." - }, - "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", - "type": "string" + "enum": [ + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ] }, - "args": { - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" + "embedContentConfig": { + "description": "Optional. Configuration for the EmbedContent request.", + "$ref": "#/components/schemas/EmbedContentConfig" } - } + }, + "type": "object", + "description": "Request containing the `Content` for the model to embed." }, - "TuningTask": { - "description": "Tuning tasks that create tuned models.", + "ResponseFormatConfig": { "properties": { - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", - "readOnly": true, - "format": "google-datetime", - "type": "string" - }, - "completeTime": { - "description": "Output only. The timestamp when tuning this model completed.", - "readOnly": true, - "format": "google-datetime", - "type": "string" - }, - "trainingData": { - "description": "Required. Input only. Immutable. The model training data.", - "$ref": "#/components/schemas/Dataset" + "text": { + "$ref": "#/components/schemas/TextResponseFormat", + "description": "Optional. Text output format configuration." }, - "hyperparameters": { - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", - "$ref": "#/components/schemas/Hyperparameters" + "audio": { + "description": "Optional. Audio output format configuration.", + "$ref": "#/components/schemas/AudioResponseFormat" }, - "snapshots": { - "items": { - "$ref": "#/components/schemas/TuningSnapshot" - }, - "type": "array", - "description": "Output only. Metrics collected during tuning.", - "readOnly": true + "image": { + "$ref": "#/components/schemas/ImageResponseFormat", + "description": "Optional. Image output format configuration." } }, - "type": "object" + "type": "object", + "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality." }, - "TunedModelSource": { - "description": "Tuned model as a source for training a new model.", + "Corpus": { + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", "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`", + "updateTime": { + "description": "Output only. The Timestamp of when the `Corpus` was last updated.", + "readOnly": true, + "format": "google-datetime", "type": "string" }, - "baseModel": { - "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", + "createTime": { + "description": "Output only. The Timestamp of when the `Corpus` was created.", "readOnly": true, + "type": "string", + "format": "google-datetime" + }, + "displayName": { + "description": "Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"", "type": "string" + }, + "name": { + "type": "string", + "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", + "readOnly": true } }, "type": "object" }, - "InlinedResponses": { - "description": "The responses to the requests in the batch.", + "CitationMetadata": { + "description": "A collection of source attributions for a piece of content.", "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "readOnly": true, + "citationSources": { + "description": "Citations to sources for a specific response.", "items": { - "$ref": "#/components/schemas/InlinedResponse" + "$ref": "#/components/schemas/CitationSource" }, "type": "array" } }, "type": "object" }, - "EmbedContentRequest": { - "description": "Request containing the `Content` for the model to embed.", - "properties": { - "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" - }, - "embedContentConfig": { - "description": "Optional. Configuration for the EmbedContent request.", - "$ref": "#/components/schemas/EmbedContentConfig" - }, - "content": { - "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", - "$ref": "#/components/schemas/Content" - }, - "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.", - "type": "string", - "deprecated": true - }, - "outputDimensionality": { - "description": "Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`).", - "format": "int32", - "type": "integer", - "deprecated": true - }, - "taskType": { - "deprecated": true, - "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", - "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": "object" - }, - "ComputerUse": { + "FunctionCallingConfig": { + "description": "Configuration for specifying function calling behavior.", "type": "object", - "description": "Computer Use tool type.", "properties": { - "disabledSafetyPolicies": { - "description": "Optional. Disabled safety policies for computer use.", + "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", - "x-enum-descriptions": [ - "Unspecified safety policy.", - "Safety policy for financial transactions.", - "Safety policy for sensitive data modification.", - "Safety policy for communication tools (e.g. Gmail, Chat, Meet).", - "Safety policy for account creation.", - "Safety policy for data modification.", - "Safety policy for user consent management.", - "Safety policy for legal terms and agreements." - ], - "enum": [ - "SAFETY_POLICY_UNSPECIFIED", - "FINANCIAL_TRANSACTIONS", - "SENSITIVE_DATA_MODIFICATION", - "COMMUNICATION_TOOL", - "ACCOUNT_CREATION", - "DATA_MODIFICATION", - "USER_CONSENT_MANAGEMENT", - "LEGAL_TERMS_AND_AGREEMENTS" - ] - }, - "type": "array" - }, - "enablePromptInjectionDetection": { - "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", - "type": "boolean" + "type": "string" + } }, - "environment": { + "mode": { "type": "string", - "x-enum-descriptions": [ - "Defaults to browser.", - "Operates in a web browser.", - "Operates in a mobile environment.", - "Operates in a desktop environment." - ], "enum": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER", - "ENVIRONMENT_MOBILE", - "ENVIRONMENT_DESKTOP" + "MODE_UNSPECIFIED", + "AUTO", + "ANY", + "NONE", + "VALIDATED" ], - "description": "Required. The environment being operated." - }, - "excludedPredefinedFunctions": { - "type": "array", - "items": { - "type": "string" - }, - "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions." + "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\"." + ] } } }, - "InputEmbedContentConfig": { - "description": "Configures the input to the batch request.", - "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", - "type": "string" - }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedEmbedContentRequests" - } - }, - "type": "object" - }, - "ListDocumentsResponse": { - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", + "ListModelsResponse": { "properties": { - "documents": { - "items": { - "$ref": "#/components/schemas/Document" - }, + "models": { + "description": "The returned Models.", "type": "array", - "description": "The returned `Document`s." + "items": { + "$ref": "#/components/schemas/Model" + } }, "nextPageToken": { "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", "type": "string" } }, - "type": "object" - }, - "InputConfig": { "type": "object", - "description": "Configures the input to the batch request.", + "description": "Response from `ListModel` containing a paginated list of Models." + }, + "FunctionCall": { "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", + "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" }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedRequests" + "args": { + "description": "Optional. The function parameters and values in JSON object format.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" + }, + "id": { + "type": "string", + "description": "Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`." } - } - }, - "TunedModel": { + }, "type": "object", - "description": "A fine-tuned model created using ModelService.CreateTunedModel.", + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values." + }, + "PrebuiltVoiceConfig": { "properties": { - "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" - }, - "readerProjectNumbers": { - "items": { - "type": "string", - "format": "int64" - }, - "type": "array", - "description": "Optional. List of project numbers that have read access to the tuned model." - }, - "description": { - "description": "Optional. A short description of this model.", - "type": "string" - }, - "updateTime": { - "description": "Output only. The timestamp when this model was updated.", - "readOnly": true, - "format": "google-datetime", - "type": "string" - }, - "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": { - "type": "string", - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", - "readOnly": true - }, - "baseModel": { - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", - "type": "string" - }, - "createTime": { - "description": "Output only. The timestamp when this model was created.", - "readOnly": true, - "format": "google-datetime", - "type": "string" - }, - "tuningTask": { - "description": "Required. The tuning task that creates the tuned model.", - "$ref": "#/components/schemas/TuningTask" - }, - "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": { - "description": "Optional. TunedModel to use as the starting point for training the new model.", - "$ref": "#/components/schemas/TunedModelSource" - }, - "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" - }, - "state": { - "description": "Output only. The state of the tuned model.", + "voiceName": { "type": "string", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "The model is being created.", - "The model is ready to be used.", - "The model failed to be created." - ], - "enum": [ - "STATE_UNSPECIFIED", - "CREATING", - "ACTIVE", - "FAILED" - ], - "readOnly": true + "description": "The name of the preset voice to use." } - } - }, - "ReviewSnippet": { + }, "type": "object", - "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", + "description": "The configuration for the prebuilt speaker to use." + }, + "CreateFileResponse": { "properties": { - "googleMapsUri": { - "description": "A link that corresponds to the user review on Google Maps.", - "type": "string" - }, - "reviewId": { - "description": "The ID of the review snippet.", - "type": "string" - }, - "title": { - "description": "Title of the review.", - "type": "string" + "file": { + "$ref": "#/components/schemas/File", + "description": "Metadata for the created file." } - } + }, + "type": "object", + "description": "Response for `CreateFile`." }, - "ImageResponseFormat": { - "description": "Configuration for image output format.", + "ModelStatus": { + "type": "object", "properties": { - "imageSize": { - "description": "Optional. The size of the image output.", - "enum": [ - "IMAGE_SIZE_UNSPECIFIED", - "IMAGE_SIZE_FIVE_TWELVE", - "IMAGE_SIZE_ONE_K", - "IMAGE_SIZE_TWO_K", - "IMAGE_SIZE_FOUR_K" + "modelStage": { + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false ], - "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "512px image size.", - "1K image size.", - "2K image size.", - "4K image size." - ] - }, - "mimeType": { "enum": [ - "MIME_TYPE_UNSPECIFIED", - "IMAGE_JPEG" + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" ], - "type": "string", "x-enum-descriptions": [ - "Default value. This value is unused.", - "JPEG image format." + "Unspecified model stage.", + "The underlying model is subject to lots of tunings.", + "Models in this stage are for experimental purposes only.", + "Models in this stage are more mature than experimental models.", + "Models in this stage are considered stable and ready for production use.", + "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", + "Models in this stage are deprecated. These models cannot be used.", + "Models in this stage are retired. These models cannot be used." ], - "description": "Optional. The MIME type of the image output." + "type": "string", + "description": "The stage of the underlying model." }, - "aspectRatio": { + "message": { + "description": "A message explaining the model status.", + "type": "string" + }, + "retirementTime": { + "description": "The time at which the model will be retired.", "type": "string", + "format": "google-datetime" + } + }, + "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable." + }, + "UrlMetadata": { + "type": "object", + "properties": { + "urlRetrievalStatus": { + "description": "Status of the url retrieval.", "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" - ], - "description": "Optional. The aspect ratio for the image output." - }, - "delivery": { - "description": "Optional. The delivery mode for the image output.", - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" + "Url retrieval is successful.", + "Url retrieval is failed due to error.", + "Url retrieval is failed because the content is behind paywall.", + "Url retrieval is failed because the content is unsafe." ], "type": "string", - "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": [ + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" ] + }, + "retrievedUrl": { + "description": "Retrieved url by the tool.", + "type": "string" } }, - "type": "object" + "description": "Context of the a single url retrieval." }, - "GroundingChunkCustomMetadata": { - "type": "object", - "description": "User provided metadata about the GroundingFact.", + "FileSearch": { "properties": { - "stringValue": { - "description": "Optional. The string value of the metadata.", - "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`" }, - "stringListValue": { - "description": "Optional. A list of string values for the metadata.", - "$ref": "#/components/schemas/GroundingChunkStringList" + "topK": { + "description": "Optional. The number of semantic retrieval chunks to retrieve.", + "type": "integer", + "format": "int32" }, - "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" + "metadataFilter": { + "type": "string", + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks." + } + }, + "type": "object", + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API." + }, + "ImportFileRequest": { + "properties": { + "fileName": { + "type": "string", + "description": "Required. The name of the `File` to import. Example: `files/abc-123`" }, - "key": { - "description": "The key of the metadata.", - "type": "string" + "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." + }, + "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`." }, "PromptFeedback": { - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", "properties": { "blockReason": { - "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", + "type": "string", "enum": [ "BLOCK_REASON_UNSPECIFIED", "SAFETY", @@ -5633,7 +5396,7 @@ "PROHIBITED_CONTENT", "IMAGE_SAFETY" ], - "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.", @@ -5651,1280 +5414,1517 @@ } } }, + "type": "object", + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`." + }, + "UrlContext": { + "description": "Tool to support URL context retrieval.", + "type": "object", + "properties": {} + }, + "Web": { + "description": "Chunk from the web.", + "properties": { + "title": { + "description": "Output only. Title of the chunk.", + "readOnly": true, + "type": "string" + }, + "uri": { + "type": "string", + "description": "Output only. URI reference of the chunk.", + "readOnly": true + } + }, "type": "object" }, - "EmbedContentConfig": { + "InlinedRequest": { + "description": "The request to be processed in the batch.", + "properties": { + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/GenerateContentRequest" + }, + "metadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The metadata to be associated with the request." + } + }, + "type": "object" + }, + "VideoMetadata": { + "deprecated": true, + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", + "properties": { + "endOffset": { + "type": "string", + "format": "google-duration", + "description": "Optional. The end offset of the video." + }, + "fps": { + "format": "double", + "type": "number", + "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]." + }, + "startOffset": { + "format": "google-duration", + "type": "string", + "description": "Optional. The start offset of the video." + } + }, + "type": "object" + }, + "BatchEmbedContentsResponse": { "type": "object", - "description": "Configurations for the EmbedContent request.", "properties": { - "documentOcr": { - "description": "Optional. Whether to enable OCR for document content.", - "type": "boolean" + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" }, - "audioTrackExtraction": { - "description": "Optional. Whether to extract audio from video content.", - "type": "boolean" + "embeddings": { + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/ContentEmbedding" + }, + "type": "array" + } + }, + "description": "The response to a `BatchEmbedContentsRequest`." + }, + "Model": { + "type": "object", + "properties": { + "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" }, - "autoTruncate": { - "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", - "type": "boolean" + "temperature": { + "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model.", + "format": "float", + "type": "number" }, - "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" + "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" }, - "taskType": { - "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ], + "description": { + "description": "A short description of the model.", + "type": "string" + }, + "supportedGenerationMethods": { + "type": "array", + "items": { + "type": "string" + }, + "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`." + }, + "maxTemperature": { + "description": "The maximum temperature this model can use.", + "format": "float", + "type": "number" + }, + "topP": { + "format": "float", + "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." + }, + "inputTokenLimit": { + "description": "Maximum number of input tokens allowed for this model.", + "format": "int32", + "type": "integer" + }, + "version": { "type": "string", - "x-enum-descriptions": [ - "Unset value, which will default to one of the other enum values.", - "Specifies the given text is a query in a search/retrieval setting.", - "Specifies the given text is a document from the corpus being searched.", - "Specifies the given text will be used for STS.", - "Specifies that the given text will be classified.", - "Specifies that the embeddings will be used for clustering.", - "Specifies that the given text will be used for question answering.", - "Specifies that the given text will be used for fact verification.", - "Specifies that the given text will be used for code retrieval." - ], - "description": "Optional. The task type of the embedding." + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)" + }, + "thinking": { + "description": "Whether the model supports thinking.", + "type": "boolean" + }, + "baseModelId": { + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "type": "string" + }, + "displayName": { + "type": "string", + "description": "The human-readable name of the model. E.g. \"Gemini 1.5 Flash\". The name can be up to 128 characters long and can consist of any UTF-8 characters." }, - "title": { - "description": "Optional. The title for the text.", - "type": "string" + "outputTokenLimit": { + "description": "Maximum number of output tokens available for this model.", + "type": "integer", + "format": "int32" } - } + }, + "description": "Information about a Generative Language Model." }, - "CachedContentUsageMetadata": { - "description": "Metadata on the usage of the cached content.", + "GroundingPassageId": { "properties": { - "totalTokenCount": { - "description": "Total number of tokens that the cached content consumes.", + "passageId": { + "type": "string", + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", + "readOnly": true + }, + "partIndex": { "format": "int32", - "type": "integer" + "type": "integer", + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", + "readOnly": true } }, - "type": "object" + "type": "object", + "description": "Identifier for a part within a `GroundingPassage`." }, - "TuningExample": { + "SpeechConfig": { + "description": "Config for speech generation and transcription.", "type": "object", - "description": "A single example for tuning.", "properties": { - "textInput": { - "description": "Optional. Text model input.", - "type": "string" + "voiceConfig": { + "description": "The configuration in case of single-voice output.", + "$ref": "#/components/schemas/VoiceConfig" }, - "output": { - "description": "Required. The expected model output.", + "multiSpeakerVoiceConfig": { + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig", + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field." + }, + "languageCode": { + "description": "Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`.", "type": "string" } } }, - "BatchEmbedContentsRequest": { - "type": "object", - "description": "Batch request to get embeddings from the model for a list of prompts.", - "properties": { - "requests": { - "items": { - "$ref": "#/components/schemas/EmbedContentRequest" - }, - "type": "array", - "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`." - } - } - }, - "BatchEmbedContentsResponse": { - "description": "The response to a `BatchEmbedContentsRequest`.", - "properties": { - "embeddings": { - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", - "readOnly": true, - "items": { - "$ref": "#/components/schemas/ContentEmbedding" - }, - "type": "array" - }, - "usageMetadata": { - "description": "Output only. The usage metadata for the request.", - "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata" - } - }, - "type": "object" - }, "File": { - "type": "object", - "description": "A file uploaded to the API. Next ID: 15", "properties": { + "name": { + "type": "string", + "description": "Immutable. Identifier. The `File` resource name. The ID (name excluding the \"files/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456`" + }, "sizeBytes": { + "format": "int64", "type": "string", "description": "Output only. Size of the file in bytes.", + "readOnly": true + }, + "expirationTime": { + "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", "readOnly": true, - "format": "int64" + "type": "string", + "format": "google-datetime" }, - "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" + "sha256Hash": { + "description": "Output only. SHA-256 hash of the uploaded bytes.", + "readOnly": true, + "type": "string", + "format": "byte" }, - "uri": { - "description": "Output only. The uri of the `File`.", + "mimeType": { + "description": "Output only. MIME type of the file.", "readOnly": true, "type": "string" }, - "createTime": { + "videoMetadata": { + "$ref": "#/components/schemas/VideoFileMetadata", + "description": "Output only. Metadata for a video.", + "readOnly": true + }, + "displayName": { "type": "string", - "description": "Output only. The timestamp of when the `File` was created.", + "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\"" + }, + "downloadUri": { + "description": "Output only. The download uri of the `File`.", "readOnly": true, - "format": "google-datetime" + "type": "string" + }, + "uri": { + "type": "string", + "description": "Output only. The uri of the `File`.", + "readOnly": true }, "source": { "description": "Source of the File.", - "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" - ], - "type": "string", "x-enum-descriptions": [ "Used if source is not specified.", "Indicates the file is uploaded by the user.", "Indicates the file is generated by Google.", "Indicates the file is a registered, i.e. a Google Cloud Storage file." + ], + "type": "string", + "enum": [ + "SOURCE_UNSPECIFIED", + "UPLOADED", + "GENERATED", + "REGISTERED" ] }, - "error": { - "description": "Output only. Error status if File processing failed.", - "readOnly": true, - "$ref": "#/components/schemas/Status" - }, - "updateTime": { - "description": "Output only. The timestamp of when the `File` was last updated.", + "createTime": { + "description": "Output only. The timestamp of when the `File` was created.", "readOnly": true, "format": "google-datetime", "type": "string" }, - "sha256Hash": { - "type": "string", - "description": "Output only. SHA-256 hash of the uploaded bytes.", - "readOnly": true, - "format": "byte" - }, - "downloadUri": { + "updateTime": { + "format": "google-datetime", "type": "string", - "description": "Output only. The download uri of the `File`.", + "description": "Output only. The timestamp of when the `File` was last updated.", "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" - }, "state": { - "readOnly": true, - "description": "Output only. Processing state of the File.", "enum": [ "STATE_UNSPECIFIED", "PROCESSING", "ACTIVE", "FAILED" ], - "type": "string", + "readOnly": true, "x-enum-descriptions": [ "The default value. This value is used if the state is omitted.", "File is being processed and cannot be used for inference yet.", "File is processed and available for inference.", "File failed processing." - ] + ], + "type": "string", + "description": "Output only. Processing state of the File." }, - "videoMetadata": { - "description": "Output only. Metadata for a video.", + "error": { + "$ref": "#/components/schemas/Status", + "description": "Output only. Error status if File processing failed.", + "readOnly": true + } + }, + "type": "object", + "description": "A file uploaded to the API. Next ID: 15" + }, + "ListTunedModelsResponse": { + "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "properties": { + "nextPageToken": { + "type": "string", + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." + }, + "tunedModels": { + "description": "The returned Models.", + "type": "array", + "items": { + "$ref": "#/components/schemas/TunedModel" + } + } + }, + "type": "object" + }, + "InlinedEmbedContentResponse": { + "description": "The response to a single request in the batch.", + "properties": { + "response": { + "$ref": "#/components/schemas/EmbedContentResponse", + "description": "Output only. The response to the request.", + "readOnly": true + }, + "metadata": { + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object", + "description": "Output only. The metadata associated with the request.", + "readOnly": true + }, + "error": { + "$ref": "#/components/schemas/Status", + "description": "Output only. The error encountered while processing the request.", + "readOnly": true + } + }, + "type": "object" + }, + "EmbeddingUsageMetadata": { + "description": "Metadata on the usage of the embedding request.", + "type": "object", + "properties": { + "promptTokenCount": { + "description": "Output only. Number of tokens in the prompt.", "readOnly": true, - "$ref": "#/components/schemas/VideoFileMetadata" + "format": "int32", + "type": "integer" }, - "mimeType": { - "description": "Output only. MIME type of the file.", + "promptTokenDetails": { + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true + } + } + }, + "FileSearchStore": { + "properties": { + "activeDocumentsCount": { + "format": "int64", + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "readOnly": true + }, + "pendingDocumentsCount": { + "format": "int64", + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", + "readOnly": true + }, + "name": { + "description": "Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the \"fileSearchStores/\" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.", + "readOnly": true, + "type": "string" + }, + "sizeBytes": { + "description": "Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.", + "readOnly": true, + "format": "int64", + "type": "string" + }, + "displayName": { + "type": "string", + "description": "Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"" + }, + "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" + }, + "createTime": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", "readOnly": true, + "format": "google-datetime", "type": "string" }, - "expirationTime": { + "updateTime": { "type": "string", - "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", - "readOnly": true, - "format": "google-datetime" + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "readOnly": true + }, + "failedDocumentsCount": { + "format": "int64", + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "readOnly": true } - } + }, + "type": "object", + "description": "A `FileSearchStore` is a collection of `Document`s." }, - "Operation": { + "FunctionResponse": { "type": "object", - "description": "This resource represents a long-running operation that is the result of a network API call.", "properties": { - "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." - } + "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" }, - "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.", + "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" }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" + "scheduling": { + "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.", + "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." + ] + }, + "parts": { + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionResponsePart" + }, + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types." + }, + "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" }, "response": { + "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model. Multimedia can be included by using a subobject containing a single \"$ref\" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal.", "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": "Properties of the 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" } - } + }, + "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." }, - "Status": { - "type": "object", - "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", + "TranslationConfig": { "properties": { - "details": { - "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", - "items": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } - }, - "type": "array" - }, - "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" + "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" }, - "code": { - "description": "The status code, which should be an enum value of google.rpc.Code.", - "format": "int32", - "type": "integer" + "targetLanguageCode": { + "type": "string", + "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\")." } - } + }, + "type": "object", + "description": "Config for translation features." }, - "RetrievalConfig": { + "FunctionResponseBlob": { "type": "object", - "description": "Retrieval config.", "properties": { - "latLng": { - "description": "Optional. The location of the user.", - "$ref": "#/components/schemas/LatLng" + "mimeType": { + "type": "string", + "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats)." }, - "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" + "data": { + "format": "byte", + "type": "string", + "description": "Raw bytes for media formats." } - } + }, + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field." }, - "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", + "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": {} + }, + "InputConfig": { + "description": "Configures the input to the batch request.", "properties": { - "googleSearch": { - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "$ref": "#/components/schemas/GoogleSearch" - }, - "urlContext": { - "description": "Optional. Tool to support URL context retrieval.", - "$ref": "#/components/schemas/UrlContext" - }, - "fileSearch": { - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", - "$ref": "#/components/schemas/FileSearch" - }, - "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" - }, - "codeExecution": { - "description": "Optional. Enables the model to execute code as part of generation.", - "$ref": "#/components/schemas/CodeExecution" - }, - "googleSearchRetrieval": { - "description": "Optional. Retrieval tool that is powered by Google search.", - "$ref": "#/components/schemas/GoogleSearchRetrieval" - }, - "mcpServers": { - "type": "array", - "items": { - "$ref": "#/components/schemas/McpServer" - }, - "description": "Optional. MCP Servers to connect to." - }, - "functionDeclarations": { - "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", - "items": { - "$ref": "#/components/schemas/FunctionDeclaration" - }, - "type": "array" + "fileName": { + "description": "The name of the `File` containing the input requests.", + "type": "string" }, - "googleMaps": { - "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", - "$ref": "#/components/schemas/GoogleMaps" + "requests": { + "$ref": "#/components/schemas/InlinedRequests", + "description": "The requests to be processed in the batch." } }, "type": "object" }, - "EmbedContentResponse": { + "BatchStats": { + "description": "Stats about the batch.", "type": "object", - "description": "The response to an `EmbedContentRequest`.", "properties": { - "embedding": { - "description": "Output only. The embedding generated from the input content.", + "requestCount": { + "description": "Output only. The number of requests in the batch.", "readOnly": true, - "$ref": "#/components/schemas/ContentEmbedding" + "format": "int64", + "type": "string" }, - "usageMetadata": { - "$ref": "#/components/schemas/EmbeddingUsageMetadata", - "description": "Output only. The usage metadata for the request.", + "successfulRequestCount": { + "description": "Output only. The number of requests that were successfully processed.", + "readOnly": true, + "format": "int64", + "type": "string" + }, + "pendingRequestCount": { + "description": "Output only. The number of requests that are still pending processing.", + "readOnly": true, + "type": "string", + "format": "int64" + }, + "failedRequestCount": { + "format": "int64", + "type": "string", + "description": "Output only. The number of requests that failed to be processed.", "readOnly": true } } }, - "Document": { - "description": "A `Document` is a collection of `Chunk`s.", + "InlinedEmbedContentRequest": { + "description": "The request to be processed in the batch.", "properties": { - "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" + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/EmbedContentRequest" }, - "sizeBytes": { - "type": "string", - "description": "Output only. The size of raw bytes ingested into the Document.", - "readOnly": true, - "format": "int64" + "metadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The metadata to be associated with the request." + } + }, + "type": "object" + }, + "GenerateContentBatch": { + "description": "A resource representing a batch of `GenerateContent` requests.", + "type": "object", + "properties": { + "output": { + "$ref": "#/components/schemas/GenerateContentBatchOutput", + "description": "Output only. The output of the batch request.", + "readOnly": true }, - "mimeType": { - "description": "Output only. The mime type of the Document.", - "readOnly": true, + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "type": "string" }, "updateTime": { - "type": "string", - "description": "Output only. The Timestamp of when the `Document` was last updated.", + "description": "Output only. The time at which the batch was last updated.", "readOnly": true, + "type": "string", "format": "google-datetime" }, - "displayName": { - "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"", - "type": "string" - }, "state": { - "readOnly": true, - "description": "Output only. Current state of the `Document`.", "type": "string", - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", - "All `Chunks` of the `Document` is processed and available for querying.", - "Some `Chunks` of the `Document` failed processing." - ], + "description": "Output only. The state of the batch.", "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" - ] - }, - "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" - } + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "readOnly": true, + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ] }, "createTime": { - "type": "string", - "description": "Output only. The Timestamp of when the `Document` was created.", + "description": "Output only. The time at which the batch was created.", "readOnly": true, - "format": "google-datetime" - } - }, - "type": "object" - }, - "InlinedEmbedContentRequests": { - "type": "object", - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", - "properties": { - "requests": { - "items": { - "$ref": "#/components/schemas/InlinedEmbedContentRequest" - }, - "type": "array", - "description": "Required. The requests to be processed in the batch." - } - } - }, - "EmbeddingUsageMetadata": { - "description": "Metadata on the usage of the embedding request.", - "properties": { - "promptTokenCount": { - "type": "integer", - "description": "Output only. Number of tokens in the prompt.", + "format": "google-datetime", + "type": "string" + }, + "batchStats": { + "description": "Output only. Stats about the batch.", "readOnly": true, - "format": "int32" + "$ref": "#/components/schemas/BatchStats" }, - "promptTokenDetails": { - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "type": "array", - "description": "Output only. List of modalities that were processed in the request input.", + "endTime": { + "format": "google-datetime", + "type": "string", + "description": "Output only. The time at which the batch processing completed.", "readOnly": true + }, + "priority": { + "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0.", + "type": "string", + "format": "int64" + }, + "displayName": { + "type": "string", + "description": "Required. The user-defined name of this batch." + }, + "name": { + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "readOnly": true, + "type": "string" + }, + "inputConfig": { + "$ref": "#/components/schemas/InputConfig", + "description": "Required. Input configuration of the instances on which batch processing are performed." } - }, - "type": "object" + } }, - "TuningSnapshot": { + "GroundingChunk": { + "description": "A `GroundingChunk` represents a segment of supporting evidence that grounds the model's response. It can be a chunk from the web, a retrieved context from a file, or information from Google Maps.", "type": "object", - "description": "Record for a single tuning step.", "properties": { - "step": { - "type": "integer", - "description": "Output only. The tuning step.", - "readOnly": true, - "format": "int32" + "image": { + "description": "Optional. Grounding chunk from image search.", + "$ref": "#/components/schemas/Image" }, - "epoch": { - "type": "integer", - "description": "Output only. The epoch this step was part of.", - "readOnly": true, - "format": "int32" + "maps": { + "$ref": "#/components/schemas/Maps", + "description": "Optional. Grounding chunk from Google Maps." }, - "computeTime": { - "type": "string", - "description": "Output only. The timestamp when this metric was computed.", - "readOnly": true, - "format": "google-datetime" + "web": { + "$ref": "#/components/schemas/Web", + "description": "Grounding chunk from the web." }, - "meanLoss": { - "description": "Output only. The mean loss of the training examples for this step.", - "readOnly": true, - "format": "float", - "type": "number" + "retrievedContext": { + "description": "Optional. Grounding chunk from context retrieved by the file search tool.", + "$ref": "#/components/schemas/RetrievedContext" } } }, - "TuningExamples": { + "ImageConfig": { + "description": "Config for image generation features.", "type": "object", - "description": "A set of tuning examples. Can be training or validation data.", "properties": { - "examples": { - "type": "array", - "items": { - "$ref": "#/components/schemas/TuningExample" - }, - "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type." + "imageSize": { + "type": "string", + "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`." + }, + "aspectRatio": { + "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided.", + "type": "string" } } }, - "FunctionResponsePart": { - "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", + "SemanticRetrieverChunk": { "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/FunctionResponseBlob" + "source": { + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "readOnly": true, + "type": "string" + }, + "chunk": { + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", + "readOnly": true, + "type": "string" } }, - "type": "object" + "type": "object", + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`." }, - "GenerationConfig": { + "GoogleAiGenerativelanguageV1betaGroundingSupport": { + "description": "Grounding support.", "type": "object", - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", "properties": { - "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" + "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 }, - "enableEnhancedCivicAnswers": { - "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", - "type": "boolean" + "segment": { + "description": "Segment of the content this support belongs to.", + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" }, - "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.", + "confidenceScores": { + "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices.", "type": "array", "items": { - "type": "string" + "format": "float", + "type": "number" } }, - "speechConfig": { - "description": "Optional. The speech generation config.", - "$ref": "#/components/schemas/SpeechConfig" - }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." - }, - "translationConfig": { - "description": "Optional. Config for translation.", - "$ref": "#/components/schemas/TranslationConfig" - }, - "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" - }, - "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": { - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", - "format": "int32", - "type": "integer" - }, - "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" - }, - "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" - }, - "logprobs": { - "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20].", - "format": "int32", - "type": "integer" - }, - "frequencyPenalty": { - "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit.", - "format": "float", - "type": "number" - }, - "mediaResolution": { - "description": "Optional. If specified, the media resolution specified will be used.", - "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" - ], - "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)." - ] - }, - "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" - }, - "responseLogprobs": { - "description": "Optional. If true, export the logprobs results in response.", - "type": "boolean" - }, - "temperature": { - "description": "Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0].", - "format": "float", - "type": "number" - }, - "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" - }, - "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" - }, - "topK": { - "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", - "format": "int32", - "type": "integer" - }, - "responseModalities": { - "description": "Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text.", + "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": { - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "AUDIO", - "VIDEO" - ], - "type": "string", - "x-enum-descriptions": [ - "Default value.", - "Indicates the model should return text.", - "Indicates the model should return images.", - "Indicates the model should return audio.", - "Indicates the model should return video." - ] - }, - "type": "array" - }, - "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" + "type": "integer", + "format": "int32" + } } } }, - "ListGeneratedFilesResponse": { + "ListCorporaResponse": { + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", "type": "object", - "description": "Response for `ListGeneratedFiles`.", "properties": { "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", + "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" }, - "generatedFiles": { + "corpora": { "items": { - "$ref": "#/components/schemas/GeneratedFile" + "$ref": "#/components/schemas/Corpus" }, "type": "array", - "description": "The list of `GeneratedFile`s." + "description": "The returned corpora." } } }, - "Content": { - "description": "The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn.", + "GenerateContentRequest": { "properties": { - "parts": { + "systemInstruction": { + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", + "$ref": "#/components/schemas/Content" + }, + "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/Part" - }, - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types." + "$ref": "#/components/schemas/Tool" + } }, - "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.", + "generationConfig": { + "$ref": "#/components/schemas/GenerationConfig", + "description": "Optional. Configuration options for model generation and outputs." + }, + "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" - } - }, - "type": "object" - }, - "InlinedRequest": { - "description": "The request to be processed in the batch.", - "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/GenerateContentRequest" }, - "metadata": { - "description": "Optional. The metadata to be associated with the request.", - "additionalProperties": { - "description": "Properties of the object." + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "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" + }, + "store": { + "type": "boolean", + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." + }, + "safetySettings": { + "type": "array", + "items": { + "$ref": "#/components/schemas/SafetySetting" }, - "type": "object" + "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." + }, + "serviceTier": { + "type": "string", + "enum": [ + "unspecified", + "standard", + "flex", + "priority" + ], + "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." + ] + }, + "contents": { + "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + } } }, - "type": "object" + "type": "object", + "description": "Request to generate a completion from the model." }, - "Blob": { - "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", + "TextResponseFormat": { "properties": { "mimeType": { - "description": "The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). //", - "type": "string" + "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." + ], + "type": "string", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "APPLICATION_JSON", + "TEXT_PLAIN" + ] }, - "data": { - "description": "Raw bytes for media formats.", - "format": "byte", - "type": "string" + "schema": { + "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." } }, - "type": "object" - }, - "VoiceConfig": { "type": "object", - "description": "The configuration for the voice to use.", - "properties": { - "prebuiltVoiceConfig": { - "description": "The configuration for the prebuilt voice to use.", - "$ref": "#/components/schemas/PrebuiltVoiceConfig" - } - } + "description": "Configuration for text output format." }, - "Image": { + "SafetyRating": { "type": "object", - "description": "Chunk from image search.", "properties": { - "title": { - "description": "The title of the web page that the image is from.", - "type": "string" - }, - "sourceUri": { - "description": "The web page URI for attribution.", - "type": "string" + "category": { + "description": "Required. The category for this rating.", + "type": "string", + "x-enum-descriptions": [ + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], + "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" + ] }, - "imageUri": { - "description": "The image asset URL.", - "type": "string" + "probability": { + "description": "Required. The probability of harm for this content.", + "x-enum-descriptions": [ + "Probability is unspecified.", + "Content has a negligible chance of being unsafe.", + "Content has a low chance of being unsafe.", + "Content has a medium chance of being unsafe.", + "Content has a high chance of being unsafe." + ], + "type": "string", + "enum": [ + "HARM_PROBABILITY_UNSPECIFIED", + "NEGLIGIBLE", + "LOW", + "MEDIUM", + "HIGH" + ] }, - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", - "type": "string" + "blocked": { + "type": "boolean", + "description": "Was this content blocked because of this rating?" } - } + }, + "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." }, - "VideoFileMetadata": { - "description": "Metadata for a video `File`.", + "StringList": { "properties": { - "videoDuration": { - "description": "Duration of the video.", - "format": "google-duration", - "type": "string" + "values": { + "items": { + "type": "string" + }, + "type": "array", + "description": "The string values of the metadata to store." } }, - "type": "object" + "type": "object", + "description": "User provided string values assigned to a single metadata key." }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { - "description": "Grounding support.", + "ComputerUse": { + "description": "Computer Use tool type.", "properties": { - "confidenceScores": { - "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices.", - "type": "array", - "items": { - "type": "number", - "format": "float" - } + "environment": { + "type": "string", + "enum": [ + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER", + "ENVIRONMENT_MOBILE", + "ENVIRONMENT_DESKTOP" + ], + "description": "Required. The environment being operated.", + "x-enum-descriptions": [ + "Defaults to browser.", + "Operates in a web browser.", + "Operates in a mobile environment.", + "Operates in a desktop environment." + ] }, - "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).", + "enablePromptInjectionDetection": { + "type": "boolean", + "description": "Optional. Whether enable the prompt injection detection check on computer-use request." + }, + "disabledSafetyPolicies": { + "description": "Optional. Disabled safety policies for computer use.", "items": { - "type": "integer", - "format": "int32" + "type": "string", + "enum": [ + "SAFETY_POLICY_UNSPECIFIED", + "FINANCIAL_TRANSACTIONS", + "SENSITIVE_DATA_MODIFICATION", + "COMMUNICATION_TOOL", + "ACCOUNT_CREATION", + "DATA_MODIFICATION", + "USER_CONSENT_MANAGEMENT", + "LEGAL_TERMS_AND_AGREEMENTS" + ], + "x-enum-descriptions": [ + "Unspecified safety policy.", + "Safety policy for financial transactions.", + "Safety policy for sensitive data modification.", + "Safety policy for communication tools (e.g. Gmail, Chat, Meet).", + "Safety policy for account creation.", + "Safety policy for data modification.", + "Safety policy for user consent management.", + "Safety policy for legal terms and agreements." + ] }, "type": "array" }, - "segment": { - "description": "Segment of the content this support belongs to.", - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" - }, - "renderedParts": { - "type": "array", + "excludedPredefinedFunctions": { + "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions.", "items": { - "type": "integer", - "format": "int32" + "type": "string" }, - "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 + "type": "array" } }, "type": "object" }, - "Permission": { - "type": "object", - "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", + "ExecutableCode": { "properties": { - "granteeType": { - "description": "Optional. Immutable. The type of the grantee.", + "language": { + "type": "string", "enum": [ - "GRANTEE_TYPE_UNSPECIFIED", - "USER", - "GROUP", - "EVERYONE" + "LANGUAGE_UNSPECIFIED", + "PYTHON" ], - "type": "string", + "description": "Required. Programming language of the `code`.", "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." + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." ] }, - "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" + "id": { + "type": "string", + "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." }, - "role": { + "code": { + "type": "string", + "description": "Required. The code to be executed." + } + }, + "type": "object", + "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated." + }, + "CodeExecutionResult": { + "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", + "properties": { + "id": { "type": "string", + "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id." + }, + "output": { + "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", + "type": "string" + }, + "outcome": { + "description": "Required. Outcome of the code execution.", "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 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": [ - "ROLE_UNSPECIFIED", - "OWNER", - "WRITER", - "READER" - ], - "description": "Required. The role granted by this permission." + "OUTCOME_UNSPECIFIED", + "OUTCOME_OK", + "OUTCOME_FAILED", + "OUTCOME_DEADLINE_EXCEEDED" + ] + } + }, + "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", + "properties": { + "streamableHttpTransport": { + "$ref": "#/components/schemas/StreamableHttpTransport", + "description": "A transport that can stream HTTP requests and responses." }, "name": { "type": "string", - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", - "readOnly": true + "description": "The name of the MCPServer." } - } + }, + "type": "object" }, - "UsageMetadata": { + "Schema": { "type": "object", - "description": "Metadata on the generation request's token usage.", "properties": { - "cacheTokensDetails": { - "description": "Output only. List of modalities of the cached content in the request input.", - "readOnly": true, - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "type": "array" + "title": { + "type": "string", + "description": "Optional. The title of the schema." }, - "candidatesTokenCount": { - "description": "Total number of tokens across all the generated response candidates.", - "format": "int32", - "type": "integer" + "maximum": { + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "format": "double", + "type": "number" }, - "toolUsePromptTokenCount": { - "type": "integer", - "description": "Output only. Number of tokens present in tool-use prompt(s).", - "readOnly": true, - "format": "int32" + "maxLength": { + "format": "int64", + "type": "string", + "description": "Optional. Maximum length of the Type.STRING" }, - "promptTokensDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "readOnly": true, + "required": { "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "string" }, - "type": "array" - }, - "thoughtsTokenCount": { - "type": "integer", - "description": "Output only. Number of tokens of thoughts for thinking models.", - "readOnly": true, - "format": "int32" + "type": "array", + "description": "Optional. Required properties of Type.OBJECT." }, - "serviceTier": { - "type": "string", + "type": { + "description": "Required. Data type.", "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "Not specified, should not be used.", + "String type.", + "Number type.", + "Integer type.", + "Boolean type.", + "Array type.", + "Object type.", + "Null type." ], + "type": "string", "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ], - "description": "Output only. Service tier of the request.", - "readOnly": true + "TYPE_UNSPECIFIED", + "STRING", + "NUMBER", + "INTEGER", + "BOOLEAN", + "ARRAY", + "OBJECT", + "NULL" + ] }, - "cachedContentTokenCount": { - "type": "integer", - "description": "Number of tokens in the cached part of the prompt (the cached content)", - "format": "int32" + "items": { + "description": "Optional. Schema of the elements of Type.ARRAY.", + "$ref": "#/components/schemas/Schema" }, - "toolUsePromptTokensDetails": { - "description": "Output only. List of modalities that were processed for tool-use request inputs.", - "readOnly": true, - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "type": "array" + "maxItems": { + "description": "Optional. Maximum number of the elements for Type.ARRAY.", + "format": "int64", + "type": "string" }, - "totalTokenCount": { - "type": "integer", - "description": "Total token count for the generation request (prompt + thoughts + response candidates).", - "format": "int32" + "description": { + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "type": "string" }, - "candidatesTokensDetails": { - "description": "Output only. List of modalities that were returned in the response.", - "readOnly": true, + "pattern": { + "type": "string", + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression." + }, + "enum": { + "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "string" }, "type": "array" }, - "promptTokenCount": { - "type": "integer", - "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content.", - "format": "int32" - }, - "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" - } - } - } - }, - "UrlMetadata": { - "type": "object", - "description": "Context of the a single url retrieval.", - "properties": { - "retrievedUrl": { - "description": "Retrieved url by the tool.", - "type": "string" - }, - "urlRetrievalStatus": { - "enum": [ - "URL_RETRIEVAL_STATUS_UNSPECIFIED", - "URL_RETRIEVAL_STATUS_SUCCESS", - "URL_RETRIEVAL_STATUS_ERROR", - "URL_RETRIEVAL_STATUS_PAYWALL", - "URL_RETRIEVAL_STATUS_UNSAFE" - ], + "format": { "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Url retrieval is successful.", - "Url retrieval is failed due to error.", - "Url retrieval is failed because the content is behind paywall.", - "Url retrieval is failed because the content is unsafe." - ], - "description": "Status of the url retrieval." - } - } - }, - "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.", + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." + }, + "minProperties": { + "description": "Optional. Minimum number of the properties for Type.OBJECT.", + "format": "int64", "type": "string" }, - "id": { - "description": "Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`.", + "propertyOrdering": { + "items": { + "type": "string" + }, + "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." + }, + "anyOf": { + "items": { + "$ref": "#/components/schemas/Schema" + }, + "type": "array", + "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." + }, + "minimum": { + "format": "double", + "type": "number", + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER" + }, + "minLength": { + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "format": "int64", "type": "string" }, - "args": { - "type": "object", - "description": "Optional. The function parameters and values in JSON object format.", - "additionalProperties": { - "description": "Properties of the object." - } - } - }, - "type": "object" - }, - "ThinkingConfig": { - "description": "Config for thinking features.", - "properties": { - "thinkingBudget": { - "type": "integer", - "description": "The number of thoughts tokens that the model should generate.", - "format": "int32" + "nullable": { + "type": "boolean", + "description": "Optional. Indicates if the value may be null." }, - "thinkingLevel": { - "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", + "maxProperties": { + "description": "Optional. Maximum number of the properties for Type.OBJECT.", "type": "string", - "x-enum-descriptions": [ - "Default value.", - "Little to no thinking.", - "Low thinking level.", - "Medium thinking level.", - "High thinking level." - ], - "enum": [ - "THINKING_LEVEL_UNSPECIFIED", - "MINIMAL", - "LOW", - "MEDIUM", - "HIGH" - ] + "format": "int64" }, - "includeThoughts": { - "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", - "type": "boolean" + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + }, + "type": "object" + }, + "minItems": { + "description": "Optional. Minimum number of the elements for Type.ARRAY.", + "format": "int64", + "type": "string" + }, + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." } }, - "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)." }, - "CitationSource": { - "description": "A citation to a source for a portion of a specific response.", + "LogprobsResultCandidate": { "properties": { - "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" + "logProbability": { + "description": "The candidate's log probability.", + "format": "float", + "type": "number" }, - "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.", + "tokenId": { "format": "int32", - "type": "integer" - }, - "endIndex": { "type": "integer", - "description": "Optional. End of the attributed segment, exclusive.", - "format": "int32" + "description": "The candidate\u2019s token id value." }, - "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", - "type": "string" + "token": { + "type": "string", + "description": "The candidate\u2019s token string value." } }, - "type": "object" + "type": "object", + "description": "Candidate for the logprobs token and score." }, - "SpeakerVoiceConfig": { + "ImageResponseFormat": { + "description": "Configuration for image output format.", "type": "object", - "description": "The configuration for a single speaker in a multi speaker setup.", "properties": { - "voiceConfig": { - "description": "Required. The configuration for the voice to use.", - "$ref": "#/components/schemas/VoiceConfig" + "delivery": { + "type": "string", + "enum": [ + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" + ], + "description": "Optional. The delivery mode for the image output.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Image data is returned inline in the response.", + "Image data is returned as a URI." + ] }, - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" + "aspectRatio": { + "type": "string", + "enum": [ + "ASPECT_RATIO_UNSPECIFIED", + "ASPECT_RATIO_ONE_BY_ONE", + "ASPECT_RATIO_TWO_BY_THREE", + "ASPECT_RATIO_THREE_BY_TWO", + "ASPECT_RATIO_THREE_BY_FOUR", + "ASPECT_RATIO_FOUR_BY_THREE", + "ASPECT_RATIO_FOUR_BY_FIVE", + "ASPECT_RATIO_FIVE_BY_FOUR", + "ASPECT_RATIO_NINE_BY_SIXTEEN", + "ASPECT_RATIO_SIXTEEN_BY_NINE", + "ASPECT_RATIO_TWENTY_ONE_BY_NINE", + "ASPECT_RATIO_ONE_BY_EIGHT", + "ASPECT_RATIO_EIGHT_BY_ONE", + "ASPECT_RATIO_ONE_BY_FOUR", + "ASPECT_RATIO_FOUR_BY_ONE" + ], + "description": "Optional. The aspect ratio for the image output.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "1:1 aspect ratio.", + "2:3 aspect ratio.", + "3:2 aspect ratio.", + "3:4 aspect ratio.", + "4:3 aspect ratio.", + "4:5 aspect ratio.", + "5:4 aspect ratio.", + "9:16 aspect ratio.", + "16:9 aspect ratio.", + "21:9 aspect ratio.", + "1:8 aspect ratio.", + "8:1 aspect ratio.", + "1:4 aspect ratio.", + "4:1 aspect ratio." + ] + }, + "mimeType": { + "description": "Optional. The MIME type of the image output.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "JPEG image format." + ], + "type": "string", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "IMAGE_JPEG" + ] + }, + "imageSize": { + "description": "Optional. The size of the image output.", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "512px image size.", + "1K image size.", + "2K image size.", + "4K image size." + ], + "type": "string", + "enum": [ + "IMAGE_SIZE_UNSPECIFIED", + "IMAGE_SIZE_FIVE_TWELVE", + "IMAGE_SIZE_ONE_K", + "IMAGE_SIZE_TWO_K", + "IMAGE_SIZE_FOUR_K" + ] } } }, - "StreamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses. Next ID: 6", + "Permission": { "properties": { - "timeout": { - "description": "HTTP timeout for regular operations.", - "format": "google-duration", - "type": "string" - }, - "terminateOnClose": { - "description": "Whether to close the client session when the transport closes.", - "type": "boolean" - }, - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", - "type": "string" + "name": { + "type": "string", + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "readOnly": true }, - "headers": { - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", - "additionalProperties": { - "type": "string" - }, - "type": "object" + "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." + ], + "type": "string", + "enum": [ + "ROLE_UNSPECIFIED", + "OWNER", + "WRITER", + "READER" + ] }, - "sseReadTimeout": { + "granteeType": { + "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." + ], "type": "string", - "description": "Timeout for SSE read operations.", - "format": "google-duration" - } - }, - "type": "object" - }, - "FileSearch": { - "type": "object", - "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", - "properties": { - "topK": { - "description": "Optional. The number of semantic retrieval chunks to retrieve.", - "format": "int32", - "type": "integer" + "enum": [ + "GRANTEE_TYPE_UNSPECIFIED", + "USER", + "GROUP", + "EVERYONE" + ] }, - "metadataFilter": { - "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", + "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" - }, - "fileSearchStoreNames": { - "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", - "type": "array", - "items": { - "type": "string" - } } - } + }, + "type": "object", + "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete" }, - "DynamicRetrievalConfig": { - "description": "Describes the options to customize dynamic retrieval.", + "AudioResponseFormat": { + "description": "Configuration for audio output format.", + "type": "object", "properties": { - "dynamicThreshold": { - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", - "format": "float", - "type": "number" + "bitRate": { + "format": "int32", + "type": "integer", + "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus)." }, - "mode": { + "delivery": { + "type": "string", "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" ], - "type": "string", + "description": "Optional. The delivery mode for the audio output.", "x-enum-descriptions": [ - "Always trigger retrieval.", - "Run retrieval only when system decides it is necessary." + "Default value. This value is unused.", + "Audio data is returned inline in the response.", + "Audio data is returned as a URI." + ] + }, + "mimeType": { + "type": "string", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "AUDIO_MP3", + "AUDIO_OGG_OPUS", + "AUDIO_L16", + "AUDIO_WAV", + "AUDIO_ALAW", + "AUDIO_MULAW" ], - "description": "The mode of the predictor to be used in dynamic retrieval." + "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." + ] + }, + "sampleRate": { + "type": "integer", + "format": "int32", + "description": "Optional. Sample rate in Hz." } - }, - "type": "object" + } }, - "GoogleAiGenerativelanguageV1betaSegment": { + "Part": { + "description": "A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", "type": "object", - "description": "Segment of the content.", "properties": { - "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" - }, - "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" + "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" }, - "partIndex": { - "description": "The index of a Part object within its parent Content object.", - "format": "int32", - "type": "integer" + "thoughtSignature": { + "format": "byte", + "type": "string", + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." }, "text": { - "description": "The text corresponding to the segment from the response.", + "description": "Inline text.", "type": "string" + }, + "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." + }, + "codeExecutionResult": { + "$ref": "#/components/schemas/CodeExecutionResult", + "description": "Result of executing the `ExecutableCode`." + }, + "thought": { + "type": "boolean", + "description": "Optional. Indicates if the part is thought from the model." + }, + "fileData": { + "$ref": "#/components/schemas/FileData", + "description": "URI based data." + }, + "mediaResolution": { + "description": "Optional. Media resolution for the input media.", + "$ref": "#/components/schemas/MediaResolution" + }, + "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" + }, + "partMetadata": { + "type": "object", + "additionalProperties": { + "description": "Properties of the 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." + }, + "executableCode": { + "$ref": "#/components/schemas/ExecutableCode", + "description": "Code generated by the model that is meant to be executed." + }, + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/Blob" + }, + "functionResponse": { + "$ref": "#/components/schemas/FunctionResponse", + "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model." + }, + "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" } } }, - "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.", + "InlinedEmbedContentResponses": { + "description": "The responses to the requests in the batch.", "properties": { - "modelStage": { - "type": "string", - "x-enum-descriptions": [ - "Unspecified model stage.", - "The underlying model is subject to lots of tunings.", - "Models in this stage are for experimental purposes only.", - "Models in this stage are more mature than experimental models.", - "Models in this stage are considered stable and ready for production use.", - "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", - "Models in this stage are deprecated. These models cannot be used.", - "Models in this stage are retired. These models cannot be used." - ], - "enumDeprecated": [ - false, - true, - false, - false, - false, - false, - true, - false - ], - "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" - ], - "description": "The stage of the underlying model." - }, - "message": { - "description": "A message explaining the model status.", - "type": "string" - }, - "retirementTime": { - "description": "The time at which the model will be retired.", - "format": "google-datetime", - "type": "string" + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentResponse" + } } }, "type": "object" }, - "GeneratedFile": { - "description": "A file generated on behalf of a user.", + "Blob": { "properties": { - "error": { - "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", - "$ref": "#/components/schemas/Status" - }, - "state": { - "enum": [ - "STATE_UNSPECIFIED", - "GENERATING", - "GENERATED", - "FAILED" - ], - "type": "string", - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "Being generated.", - "Generated and is ready for download.", - "Failed to generate the GeneratedFile." - ], - "description": "Output only. The state of the GeneratedFile.", - "readOnly": true - }, - "name": { - "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", + "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" }, - "mimeType": { - "description": "MIME type of the generatedFile.", + "data": { + "description": "Raw bytes for media formats.", + "format": "byte", "type": "string" } }, - "type": "object" + "type": "object", + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field." }, - "ToolConfig": { - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", + "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.", + "type": "object", "properties": { - "functionCallingConfig": { - "description": "Optional. Function calling config.", - "$ref": "#/components/schemas/FunctionCallingConfig" - }, - "retrievalConfig": { - "description": "Optional. Retrieval config.", - "$ref": "#/components/schemas/RetrievalConfig" + "endTime": { + "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end.", + "type": "string", + "format": "google-datetime" }, - "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" + "startTime": { + "type": "string", + "format": "google-datetime", + "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start." } - }, - "type": "object" + } }, - "LogprobsResult": { - "description": "Logprobs Result", + "ListOperationsResponse": { "properties": { - "chosenCandidates": { - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", - "type": "array", + "operations": { + "description": "A list of operations that matches the specified filter in the request.", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - } + "$ref": "#/components/schemas/Operation" + }, + "type": "array" }, - "logProbabilitySum": { - "type": "number", - "description": "Sum of log probabilities for all tokens.", - "format": "float" + "nextPageToken": { + "type": "string", + "description": "The standard List next-page token." }, - "topCandidates": { - "type": "array", + "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": { - "$ref": "#/components/schemas/TopCandidates" + "type": "string" }, - "description": "Length = total number of decoding steps." + "type": "array" } }, - "type": "object" - }, - "TransferOwnershipResponse": { "type": "object", - "description": "Response from `TransferOwnership`.", - "properties": {} + "description": "The response message for Operations.ListOperations." } } }