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 72a5c18..8d9daf0 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 @@ -400,18 +400,18 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// Configures the input to the batch request. /// - /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Required. The user-defined name of this batch. /// + /// + /// 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. /// @@ -422,10 +422,10 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( string batchesId, string? updateMask = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, + string? model = default, string? displayName = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, string? priority = default, - string? model = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) @@ -433,10 +433,10 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( var __request = new global::Google.Gemini.EmbedContentBatch { InputConfig = inputConfig, - Output = output, + Model = model, DisplayName = displayName, + Output = output, Priority = priority, - Model = model, BatchStats = batchStats, }; 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 956b26e..b467380 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 @@ -397,8 +397,14 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// Required. The user-defined name of this batch. + /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// + /// + /// Configures the input to the batch request. /// /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. @@ -406,14 +412,8 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// Stats about the batch. /// - /// - /// Configures the input to the batch request. - /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - /// - /// Required. The 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. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -421,23 +421,23 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( public async global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, - string? priority = default, + string? displayName = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, + global::Google.Gemini.InputConfig? inputConfig = default, string? model = default, global::Google.Gemini.BatchStats? batchStats = default, - global::Google.Gemini.InputConfig? inputConfig = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? displayName = default, + string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentBatch { - Priority = priority, + DisplayName = displayName, + Output = output, + InputConfig = inputConfig, Model = model, BatchStats = batchStats, - InputConfig = inputConfig, - Output = output, - DisplayName = displayName, + Priority = priority, }; return await BatchesUpdateGenerateContentBatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs index 2a0d907..0b406f8 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 @@ -380,60 +380,60 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Creates CachedContent resource. /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// Optional. Input only. Immutable. The content to cache. + /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsCreateAsync( + global::System.Collections.Generic.IList? tools = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.ToolConfig? toolConfig = default, string? ttl = default, + string? expireTime = default, string? displayName = default, + global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? contents = default, - string? expireTime = default, string? model = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { + Tools = tools, + Contents = contents, ToolConfig = toolConfig, Ttl = ttl, + ExpireTime = expireTime, DisplayName = displayName, + SystemInstruction = systemInstruction, UsageMetadata = usageMetadata, - Contents = contents, - ExpireTime = expireTime, Model = model, - SystemInstruction = systemInstruction, - Tools = tools, }; 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 307bf7c..3e44b9f 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 @@ -397,62 +397,62 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// Optional. Input only. Immutable. The content to cache. + /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, + global::System.Collections.Generic.IList? tools = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.ToolConfig? toolConfig = default, string? ttl = default, + string? expireTime = default, string? displayName = default, + global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? contents = default, - string? expireTime = default, string? model = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { + Tools = tools, + Contents = contents, ToolConfig = toolConfig, Ttl = ttl, + ExpireTime = expireTime, DisplayName = displayName, + SystemInstruction = systemInstruction, UsageMetadata = usageMetadata, - Contents = contents, - ExpireTime = expireTime, Model = model, - SystemInstruction = systemInstruction, - Tools = tools, }; 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 61a7c63..d1e3781 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 @@ -387,12 +387,12 @@ partial void ProcessCorporaPermissionsCreateResponseContent( /// Create a permission to a specific resource. /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -401,16 +401,16 @@ partial void ProcessCorporaPermissionsCreateResponseContent( /// public async global::System.Threading.Tasks.Task CorporaPermissionsCreateAsync( string corporaId, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, + GranteeType = granteeType, Role = role, }; 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 d104c54..0c41cb4 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 @@ -404,12 +404,12 @@ partial void ProcessCorporaPermissionsPatchResponseContent( /// /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -420,16 +420,16 @@ partial void ProcessCorporaPermissionsPatchResponseContent( string permissionsId, string corporaId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, + GranteeType = granteeType, Role = role, }; 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 dc56879..47f56a5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs @@ -387,66 +387,66 @@ partial void ProcessDynamicGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 739f543..e2ce8ed 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs @@ -387,66 +387,66 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 073adb6..3eef65f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -360,66 +360,66 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; var __enumerable = DynamicStreamGenerateContentAsStreamAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs index 0cfa326..2c7044c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs @@ -387,12 +387,12 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// /// /// Custom metadata to be associated with the file. /// + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -401,16 +401,16 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// public async global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, - string? fileName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? fileName = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { - FileName = fileName, CustomMetadata = customMetadata, + FileName = fileName, ChunkingConfig = chunkingConfig, }; 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 f63e183..a838335 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs @@ -387,36 +387,36 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - /// - /// Optional. 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. /// + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. + /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, - global::Google.Gemini.ChunkingConfig? chunkingConfig = default, - string? mimeType = default, string? displayName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? mimeType = default, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.UploadToFileSearchStoreRequest { - ChunkingConfig = chunkingConfig, - MimeType = mimeType, DisplayName = displayName, CustomMetadata = customMetadata, + MimeType = mimeType, + ChunkingConfig = chunkingConfig, }; 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 d42400e..f728e4e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs @@ -387,41 +387,41 @@ partial void ProcessModelsEmbedContentResponseContent( /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). + /// + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). /// /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// + /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// /// 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, - int? outputDimensionality = default, + global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, string? title = default, - string? model = default, + int? outputDimensionality = default, global::Google.Gemini.Content? content = default, - global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, + string? model = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { - OutputDimensionality = outputDimensionality, + TaskType = taskType, Title = title, - Model = model, + OutputDimensionality = outputDimensionality, Content = content, - TaskType = taskType, + Model = model, }; return await ModelsEmbedContentAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs index 0a3f5f8..80bb7a9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs @@ -387,66 +387,66 @@ partial void ProcessModelsGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 2556760..96b8d34 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs @@ -387,66 +387,66 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 1c80e74..f55db17 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -360,66 +360,66 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 15dda91..18cf74a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs @@ -390,61 +390,61 @@ partial void ProcessTunedModelsCreateResponseContent( /// Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222 /// /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. - /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// 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. + /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Tuned model as a source for training a new model. /// - /// - /// Optional. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Tuning tasks that create tuned models. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// + /// Optional. A short description of this model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, - string? displayName = default, - int? topK = default, string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, float? temperature = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + int? topK = default, + float? topP = default, global::Google.Gemini.TuningTask? tuningTask = default, + string? displayName = default, string? description = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = 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 { - DisplayName = displayName, - TopK = topK, BaseModel = baseModel, + ReaderProjectNumbers = readerProjectNumbers, Temperature = temperature, + TunedModelSource = tunedModelSource, + TopK = topK, + TopP = topP, TuningTask = tuningTask, + DisplayName = displayName, Description = description, - TopP = topP, - TunedModelSource = tunedModelSource, - 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 e12bd6d..e372e6c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs @@ -387,66 +387,66 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 65c9756..80a70a0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs @@ -397,32 +397,32 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. - /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// 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. + /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Tuned model as a source for training a new model. /// - /// - /// Optional. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Tuning tasks that create tuned models. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// + /// Optional. A short description of this model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -430,29 +430,29 @@ partial void ProcessTunedModelsPatchResponseContent( public async global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, - string? displayName = default, - int? topK = default, string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, float? temperature = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + int? topK = default, + float? topP = default, global::Google.Gemini.TuningTask? tuningTask = default, + string? displayName = default, string? description = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = 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 { - DisplayName = displayName, - TopK = topK, BaseModel = baseModel, + ReaderProjectNumbers = readerProjectNumbers, Temperature = temperature, + TunedModelSource = tunedModelSource, + TopK = topK, + TopP = topP, TuningTask = tuningTask, + DisplayName = displayName, Description = description, - TopP = topP, - TunedModelSource = tunedModelSource, - 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 00e6a37..bf7732b 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 @@ -387,12 +387,12 @@ partial void ProcessTunedModelsPermissionsCreateResponseContent( /// Create a permission to a specific resource. /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -401,16 +401,16 @@ partial void ProcessTunedModelsPermissionsCreateResponseContent( /// public async global::System.Threading.Tasks.Task TunedModelsPermissionsCreateAsync( string tunedModelsId, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, + GranteeType = granteeType, Role = role, }; 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 03fa5f1..cfa7963 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 @@ -404,12 +404,12 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( /// /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -420,16 +420,16 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( string tunedModelsId, string permissionsId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = default, global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { - GranteeType = granteeType, EmailAddress = emailAddress, + GranteeType = granteeType, Role = role, }; 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 c3b3a10..a6d5bd8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs @@ -387,66 +387,66 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 6a66237..b4637aa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -360,66 +360,66 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, [global::System.Runtime.CompilerServices.EnumeratorCancellation] global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - Store = store, - Model = model, - SystemInstruction = systemInstruction, Tools = tools, - CachedContent = cachedContent, - SafetySettings = safetySettings, - GenerationConfig = generationConfig, Contents = contents, - ServiceTier = serviceTier, + GenerationConfig = generationConfig, ToolConfig = toolConfig, + SafetySettings = safetySettings, + ServiceTier = serviceTier, + SystemInstruction = systemInstruction, + Model = model, + Store = store, + CachedContent = cachedContent, }; 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 18cbfa3..2d2f1a0 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 @@ -28,18 +28,18 @@ public partial interface IGeminiClient /// /// Configures the input to the batch request. /// - /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// /// /// Required. The user-defined name of this batch. /// + /// + /// 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. /// @@ -50,10 +50,10 @@ public partial interface IGeminiClient string batchesId, string? updateMask = default, global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, + string? model = default, string? displayName = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, string? priority = default, - string? model = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = 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 c412d2f..09f67f6 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 @@ -25,8 +25,14 @@ public partial interface IGeminiClient /// /// /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// Required. The user-defined name of this batch. + /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// + /// + /// Configures the input to the batch request. /// /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. @@ -34,14 +40,8 @@ public partial interface IGeminiClient /// /// Stats about the batch. /// - /// - /// Configures the input to the batch request. - /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - /// - /// Required. The 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. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -49,12 +49,12 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task BatchesUpdateGenerateContentBatchAsync( string batchesId, string? updateMask = default, - string? priority = default, + string? displayName = default, + global::Google.Gemini.GenerateContentBatchOutput? output = default, + global::Google.Gemini.InputConfig? inputConfig = default, string? model = default, global::Google.Gemini.BatchStats? batchStats = default, - global::Google.Gemini.InputConfig? inputConfig = default, - global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? displayName = default, + string? priority = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs index 3af7ef1..79598e1 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 @@ -19,46 +19,46 @@ public partial interface IGeminiClient /// /// Creates CachedContent resource. /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// Optional. Input only. Immutable. The content to cache. + /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsCreateAsync( + global::System.Collections.Generic.IList? tools = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.ToolConfig? toolConfig = default, string? ttl = default, + string? expireTime = default, string? displayName = default, + global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? contents = default, - string? expireTime = default, string? model = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs index 9e54f7c..7834b68 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 @@ -25,48 +25,48 @@ public partial interface IGeminiClient /// /// /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// Optional. Input only. Immutable. The content to cache. + /// /// /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Input only. New TTL for this resource, input only. /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// /// /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// /// /// Metadata on the usage of the cached content. /// - /// - /// Optional. Input only. Immutable. The content to cache. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, + global::System.Collections.Generic.IList? tools = default, + global::System.Collections.Generic.IList? contents = default, global::Google.Gemini.ToolConfig? toolConfig = default, string? ttl = default, + string? expireTime = default, string? displayName = default, + global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - global::System.Collections.Generic.IList? contents = default, - string? expireTime = default, string? model = default, - global::Google.Gemini.Content? systemInstruction = default, - global::System.Collections.Generic.IList? tools = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs index 92284c1..1bcb45a 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 @@ -22,12 +22,12 @@ public partial interface IGeminiClient /// Create a permission to a specific resource. /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -36,8 +36,8 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task CorporaPermissionsCreateAsync( string corporaId, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 07ba825..5c1f72e 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 @@ -28,12 +28,12 @@ public partial interface IGeminiClient /// /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -44,8 +44,8 @@ public partial interface IGeminiClient string permissionsId, string corporaId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 c60d7a5..87d15a2 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 c9abc36..aeb551a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 1797979..9c2fdb0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 30e4cb8..6000c80 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs @@ -22,12 +22,12 @@ public partial interface IGeminiClient /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// /// /// Custom metadata to be associated with the file. /// + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -36,8 +36,8 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, - string? fileName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? fileName = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs index 40b7306..08b19fb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs @@ -22,27 +22,27 @@ public partial interface IGeminiClient /// Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document. /// /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - /// - /// Optional. 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. /// + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. + /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task MediaUploadToFileSearchStoreAsync( string fileSearchStoresId, - global::Google.Gemini.ChunkingConfig? chunkingConfig = default, - string? mimeType = default, string? displayName = default, global::System.Collections.Generic.IList? customMetadata = default, + string? mimeType = default, + global::Google.Gemini.ChunkingConfig? chunkingConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs index 76a0867..a86eeb0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs @@ -22,31 +22,31 @@ public partial interface IGeminiClient /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). + /// + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). /// /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// + /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// /// 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, - int? outputDimensionality = default, + global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, string? title = default, - string? model = default, + int? outputDimensionality = default, global::Google.Gemini.Content? content = default, - global::Google.Gemini.EmbedContentRequestTaskType? taskType = default, + string? model = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs index d603d15..85f7992 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 4dafcc7..12f3340 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 6a1dc5d..2a11299 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 f27f3f5..1ee7518 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs @@ -22,47 +22,47 @@ public partial interface IGeminiClient /// Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222 /// /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. - /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// 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. + /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Tuned model as a source for training a new model. /// - /// - /// Optional. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Tuning tasks that create tuned models. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// + /// Optional. A short description of this model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, - string? displayName = default, - int? topK = default, string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, float? temperature = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + int? topK = default, + float? topP = default, global::Google.Gemini.TuningTask? tuningTask = default, + string? displayName = default, string? description = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = 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 05e0e06..2da38a1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 d6d28d5..54e350f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs @@ -25,32 +25,32 @@ public partial interface IGeminiClient /// /// /// - /// - /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. - /// - /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. - /// /// /// 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. + /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Tuned model as a source for training a new model. /// - /// - /// Optional. A short description of this model. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuned model as a source for training a new model. + /// + /// Tuning tasks that create tuned models. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// + /// Optional. A short description of this model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -58,15 +58,15 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, - string? displayName = default, - int? topK = default, string? baseModel = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, float? temperature = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, + int? topK = default, + float? topP = default, global::Google.Gemini.TuningTask? tuningTask = default, + string? displayName = default, string? description = default, - float? topP = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = 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 10d0529..d7c71c9 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 @@ -22,12 +22,12 @@ public partial interface IGeminiClient /// Create a permission to a specific resource. /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -36,8 +36,8 @@ public partial interface IGeminiClient /// global::System.Threading.Tasks.Task TunedModelsPermissionsCreateAsync( string tunedModelsId, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 8cd2556..d7b4e42 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 @@ -28,12 +28,12 @@ public partial interface IGeminiClient /// /// /// - /// - /// Optional. Immutable. The type of the grantee. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -44,8 +44,8 @@ public partial interface IGeminiClient string tunedModelsId, string permissionsId, string? updateMask = default, - global::Google.Gemini.PermissionGranteeType? granteeType = default, string? emailAddress = default, + global::Google.Gemini.PermissionGranteeType? granteeType = 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 6450a16..2df064d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 81fd121..cff4431 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -22,51 +22,51 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// /// 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, - bool? store = default, - string? model = default, - global::Google.Gemini.Content? systemInstruction = default, global::System.Collections.Generic.IList? tools = default, - string? cachedContent = default, - global::System.Collections.Generic.IList? safetySettings = default, - global::Google.Gemini.GenerationConfig? generationConfig = default, global::System.Collections.Generic.IList? contents = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.GenerationConfig? generationConfig = default, global::Google.Gemini.ToolConfig? toolConfig = default, + global::System.Collections.Generic.IList? safetySettings = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::Google.Gemini.Content? systemInstruction = default, + string? model = default, + bool? store = default, + string? cachedContent = 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 239af2d..78df658 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs @@ -13,18 +13,6 @@ namespace Google.Gemini DefaultIgnoreCondition = global::System.Text.Json.Serialization.JsonIgnoreCondition.WhenWritingNull, Converters = new global::System.Type[] { - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), @@ -33,399 +21,411 @@ namespace Google.Gemini typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + 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.GenerateContentRequestServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), + 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.WebSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] [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.UrlContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRating))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] + [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.Operation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] + [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(global::Google.Gemini.RetrievalMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] + [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.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] - [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.InlinedEmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] - [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.SafetyRating))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] - [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.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.File))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFile))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] - [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.Interval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.GoogleMaps))] - [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.FunctionDeclaration))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.Permission))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclaration))] + [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.CreateFileRequest))] + [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.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.EmbedContentRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [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.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] - [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.GenerateContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] - [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.BatchEmbedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] - [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.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.FileData))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [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.Tool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] + [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.BatchGenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] - [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.RetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] - [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.TransferOwnershipResponse))] - [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.InlinedRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] + [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.ThinkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] + [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.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.LogprobsResult))] - [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.Image))] - [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.Part))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] - [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.FunctionCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListPermissionsResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] - [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.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.SchemaType), TypeInfoPropertyName = "SchemaType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] - [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.InlinedEmbedContentResponse))] - [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.Permission))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] - [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.ImportFileRequest))] - [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.TuningTask))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] - [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.EmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] - [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.ImageConfig))] - [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.FunctionCallingConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] [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.InputEmbedContentConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequests))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Document))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] - [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::Google.Gemini.Empty))] - [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.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.TopCandidates))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [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.GenerateContentRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] + [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.PrebuiltVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [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.Dataset))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] [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.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponseScheduling), TypeInfoPropertyName = "FunctionResponseScheduling2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCachedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListGeneratedFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListModelsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Model))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequest))] + [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::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCallingConfigMode), TypeInfoPropertyName = "FunctionCallingConfigMode2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListDocumentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.CountTokensRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [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.MultiSpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [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.CountTokensResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionGranteeType), TypeInfoPropertyName = "PermissionGranteeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PermissionRole), TypeInfoPropertyName = "PermissionRole2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [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 b8eacd7..9cb3851 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,327 +28,327 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.WebSearch? Type0 { get; set; } + public global::Google.Gemini.GroundingChunk? Type0 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type1 { get; set; } + public global::Google.Gemini.Image? Type1 { get; set; } /// /// /// - public string? Type2 { get; set; } + public global::Google.Gemini.Maps? Type2 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type3 { get; set; } + public global::Google.Gemini.Web? Type3 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type4 { get; set; } + public global::Google.Gemini.RetrievedContext? Type4 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type5 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type5 { get; set; } /// /// /// - public int? Type6 { get; set; } + public string? Type6 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type7 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type7 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type8 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type8 { get; set; } /// /// /// - public object? Type9 { get; set; } + public int? Type9 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type10 { get; set; } + public global::Google.Gemini.VideoMetadata? Type10 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type11 { get; set; } + public double? Type11 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type12 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type12 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type13 { get; set; } + public global::System.Collections.Generic.IList? Type13 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type14 { get; set; } + public global::Google.Gemini.UrlContext? Type14 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type15 { get; set; } + public global::Google.Gemini.BatchStats? Type15 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type16 { get; set; } + public global::Google.Gemini.GoogleSearch? Type16 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type17 { get; set; } + public global::Google.Gemini.Interval? Type17 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type18 { get; set; } + public global::Google.Gemini.SearchTypes? Type18 { get; set; } /// /// /// - public float? Type19 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type19 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type20 { get; set; } + public global::Google.Gemini.SafetyRating? Type20 { get; set; } /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type21 { get; set; } + public bool? Type21 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type22 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type22 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type23 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type23 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type24 { get; set; } + public global::Google.Gemini.Operation? Type24 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type25 { get; set; } + public object? Type25 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type26 { get; set; } + public global::Google.Gemini.Status? Type26 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type27 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type27 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type28 { get; set; } + public float? Type28 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type29 { get; set; } + public global::Google.Gemini.SafetySetting? Type29 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type30 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type30 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type31 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type31 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type32 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type32 { get; set; } /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type33 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type33 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type34 { get; set; } + public global::System.Collections.Generic.IList? Type34 { get; set; } /// /// /// - public bool? Type35 { get; set; } + public global::Google.Gemini.File? Type35 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type36 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type36 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type37 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type37 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type38 { get; set; } + public global::System.Collections.Generic.IList? Type38 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type39 { get; set; } + public global::System.Collections.Generic.IList? Type39 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type40 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type40 { get; set; } /// /// /// - public global::Google.Gemini.File? Type41 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type41 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type42 { get; set; } + public global::System.Collections.Generic.IList? Type42 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type43 { get; set; } + public global::Google.Gemini.UrlMetadata? Type43 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type44 { get; set; } + public global::Google.Gemini.GeneratedFile? Type44 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type45 { get; set; } + public global::Google.Gemini.GeneratedFileState? Type45 { get; set; } /// /// /// - public byte[]? Type46 { get; set; } + public global::Google.Gemini.Blob? Type46 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type47 { get; set; } + public byte[]? Type47 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type48 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type48 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type49 { get; set; } + public global::Google.Gemini.Candidate? Type49 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type50 { get; set; } + public global::System.Collections.Generic.IList? Type50 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type51 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type51 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type52 { get; set; } + public global::Google.Gemini.Content? Type52 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type53 { get; set; } + public global::System.Collections.Generic.IList? Type53 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type54 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type54 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type55 { get; set; } + public global::Google.Gemini.LogprobsResult? Type55 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type56 { get; set; } + public global::Google.Gemini.CitationMetadata? Type56 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type57 { get; set; } + public global::System.Collections.Generic.IList? Type57 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type58 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type58 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type59 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type59 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type60 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type60 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type61 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type61 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type62 { get; set; } + public global::Google.Gemini.Schema? Type62 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type63 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type63 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type64 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type64 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type65 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type65 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type66 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type66 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type67 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type67 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type68 { get; set; } + public global::System.Collections.Generic.IList? Type68 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type69 { get; set; } + public global::Google.Gemini.CustomMetadata? Type69 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type70 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type70 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type71 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type71 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type72 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type72 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type73 { get; set; } + public global::System.Collections.Generic.IList? Type73 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type74 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type74 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type75 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type75 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type76 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type76 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type77 { get; set; } + public global::Google.Gemini.ExecutableCode? Type77 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type78 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type78 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type79 { get; set; } + public global::Google.Gemini.CitationSource? Type79 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type80 { get; set; } + public global::Google.Gemini.UsageMetadata? Type80 { get; set; } /// /// /// @@ -360,179 +360,179 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.VideoMetadata? Type83 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type83 { get; set; } /// /// /// - public double? Type84 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type84 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type85 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type85 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type86 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type86 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type87 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type87 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type88 { get; set; } + public global::System.Collections.Generic.IList? Type88 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type89 { get; set; } + public global::Google.Gemini.Corpus? Type89 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type90 { get; set; } + public global::Google.Gemini.Tool? Type90 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type91 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type91 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type92 { get; set; } + public global::Google.Gemini.CodeExecution? Type92 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type93 { get; set; } + public global::Google.Gemini.ComputerUse? Type93 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type94 { get; set; } + public global::Google.Gemini.FileSearch? Type94 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type95 { get; set; } + public global::System.Collections.Generic.IList? Type95 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type96 { get; set; } + public global::Google.Gemini.GoogleMaps? Type96 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type97 { get; set; } + public global::System.Collections.Generic.IList? Type97 { get; set; } /// /// /// - public global::Google.Gemini.ContentEmbedding? Type98 { get; set; } + public global::Google.Gemini.McpServer? Type98 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type99 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type99 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type100 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type100 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type101 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type101 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type102 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type102 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type103 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type103 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type104 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type104 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type105 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type105 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type106 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type106 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type107 { get; set; } + public global::Google.Gemini.LatLng? Type107 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type108 { get; set; } + public global::Google.Gemini.TunedModelSource? Type108 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type109 { get; set; } + public global::Google.Gemini.InputConfig? Type109 { get; set; } /// /// /// - public global::Google.Gemini.Model? Type110 { get; set; } + public global::Google.Gemini.InlinedRequests? Type110 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type111 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type111 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type112 { get; set; } + public global::System.Collections.Generic.IList? Type112 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type113 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type113 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type114 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type114 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type115 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type115 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type116 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type116 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type117 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type117 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type118 { get; set; } + public global::Google.Gemini.StringList? Type118 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type119 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type119 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type120 { get; set; } + public global::System.Collections.Generic.IList? Type120 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type121 { get; set; } + public global::System.Collections.Generic.IList? Type121 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type122 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type122 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type123 { get; set; } + public global::System.Collections.Generic.IList? Type123 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type124 { get; set; } + public global::Google.Gemini.PromptFeedback? Type124 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type125 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? Type125 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type126 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type126 { get; set; } /// /// /// @@ -540,327 +540,327 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type128 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type128 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type129 { get; set; } + public global::System.Collections.Generic.IList? Type129 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type130 { get; set; } + public global::Google.Gemini.Permission? Type130 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type131 { get; set; } + public global::Google.Gemini.InlinedResponses? Type131 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type132 { get; set; } + public global::System.Collections.Generic.IList? Type132 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type133 { get; set; } + public global::Google.Gemini.InlinedResponse? Type133 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type134 { get; set; } + public global::Google.Gemini.ToolConfig? Type134 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type135 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type135 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type136 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type136 { get; set; } /// /// /// - public global::Google.Gemini.Part? Type137 { get; set; } + public global::Google.Gemini.CachedContent? Type137 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type138 { get; set; } + public global::System.Collections.Generic.IList? Type138 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type139 { get; set; } + public global::System.Collections.Generic.IList? Type139 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type140 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type140 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type141 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type141 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type142 { get; set; } + public global::System.Collections.Generic.IList? Type142 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type143 { get; set; } + public global::Google.Gemini.TunedModel? Type143 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type144 { get; set; } + public global::Google.Gemini.FileData? Type144 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type145 { get; set; } + public global::Google.Gemini.Document? Type145 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type146 { get; set; } + public global::Google.Gemini.DocumentState? Type146 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type147 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type147 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type148 { get; set; } + public global::System.Collections.Generic.IList? Type148 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type149 { get; set; } + public global::Google.Gemini.TopCandidates? Type149 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type150 { get; set; } + public global::System.Collections.Generic.IList? Type150 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type151 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type151 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type152 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type152 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type153 { get; set; } + public global::Google.Gemini.FunctionCall? Type153 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type154 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type154 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type155 { get; set; } + public global::System.Collections.Generic.IList? Type155 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type156 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type156 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type157 { get; set; } + public global::Google.Gemini.GenerationConfig? Type157 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type158 { get; set; } + public global::System.Collections.Generic.IList? Type158 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type159 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type159 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type160 { get; set; } + public global::Google.Gemini.ImageConfig? Type160 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type161 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type161 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type162 { get; set; } + public global::System.Collections.Generic.Dictionary? Type162 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type163 { get; set; } + public global::Google.Gemini.Part? Type163 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type164 { get; set; } + public global::Google.Gemini.ToolCall? Type164 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type165 { get; set; } + public global::Google.Gemini.FunctionResponse? Type165 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type166 { get; set; } + public global::Google.Gemini.ToolResponse? Type166 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type167 { get; set; } + public global::Google.Gemini.TuningTask? Type167 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type168 { get; set; } + public global::System.Collections.Generic.IList? Type168 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type169 { get; set; } + public global::Google.Gemini.Dataset? Type169 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type170 { get; set; } + public global::Google.Gemini.Hyperparameters? Type170 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type171 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type171 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type172 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type172 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type173 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type173 { get; set; } /// /// /// - public global::Google.Gemini.ReviewSnippet? Type174 { get; set; } + public global::System.Collections.Generic.IList? Type174 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type175 { get; set; } + public global::Google.Gemini.FileSearchStore? Type175 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type176 { get; set; } + public global::System.Collections.Generic.IList? Type176 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type177 { get; set; } + public global::System.Collections.Generic.IList? Type177 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type178 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type178 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type179 { get; set; } + public global::System.Collections.Generic.IList? Type179 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type180 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type180 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type181 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type181 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type182 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type182 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type183 { get; set; } + public global::Google.Gemini.SpeechConfig? Type183 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type184 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type184 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type185 { get; set; } + public global::System.Collections.Generic.IList? Type185 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type186 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type186 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type187 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type187 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type188 { get; set; } + public global::System.Collections.Generic.IList? Type188 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type189 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type189 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type190 { get; set; } + public global::Google.Gemini.FileState? Type190 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type191 { get; set; } + public global::Google.Gemini.FileSource? Type191 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type192 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type192 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type193 { get; set; } + public global::System.Collections.Generic.IList? Type193 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type194 { get; set; } + public global::Google.Gemini.Model? Type194 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type195 { get; set; } + public global::System.Collections.Generic.IList? Type195 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type196 { get; set; } + public global::Google.Gemini.InlinedRequest? Type196 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type197 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type197 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFileState? Type198 { get; set; } + public global::System.Collections.Generic.IList? Type198 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type199 { get; set; } + public global::System.Collections.Generic.IList? Type199 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type200 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type200 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type201 { get; set; } + public global::Google.Gemini.ImageSearch? Type201 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type202 { get; set; } + public global::Google.Gemini.WebSearch? Type202 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type203 { get; set; } + public global::Google.Gemini.VoiceConfig? Type203 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type204 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type204 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type205 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type205 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type206 { get; set; } + public global::Google.Gemini.Empty? Type206 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type207 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type207 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type208 { get; set; } + public global::System.Collections.Generic.IList? Type208 { get; set; } /// /// /// @@ -868,87 +868,87 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::System.Collections.Generic.IList? Type210 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type210 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type211 { get; set; } + public global::Google.Gemini.TuningExamples? Type211 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type212 { get; set; } + public global::System.Collections.Generic.IList? Type212 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type213 { get; set; } + public global::Google.Gemini.TuningExample? Type213 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type214 { get; set; } + public global::Google.Gemini.SchemaType? Type214 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type215 { get; set; } + public global::System.Collections.Generic.IList? Type215 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type216 { get; set; } + public global::System.Collections.Generic.Dictionary? Type216 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type217 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type217 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type218 { get; set; } + public global::Google.Gemini.ModelStatus? Type218 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type219 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type219 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type220 { get; set; } + public global::System.Collections.Generic.IList? Type220 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type221 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type221 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type222 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type222 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type223 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type223 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type224 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type224 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type225 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type225 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type226 { get; set; } + public global::System.Collections.Generic.IList? Type226 { get; set; } /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type227 { get; set; } + public global::Google.Gemini.TunedModelState? Type227 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type228 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type228 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type229 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type229 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type230 { get; set; } + public global::Google.Gemini.PermissionRole? Type230 { get; set; } /// /// /// @@ -956,20 +956,20 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.CountTokensRequest? Type232 { get; set; } + public global::System.Collections.Generic.IList? Type232 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType0 { get; set; } + public global::System.Collections.Generic.List? ListType0 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType1 { get; set; } + public global::System.Collections.Generic.List? ListType1 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType2 { get; set; } + public global::System.Collections.Generic.List? ListType2 { get; set; } /// /// /// @@ -977,27 +977,27 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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; } /// /// /// @@ -1005,138 +1005,138 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - 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; } } } \ 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 208866c..2d96e68 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AttributionSourceId.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class AttributionSourceId { - /// - /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("semanticRetrieverChunk")] - public global::Google.Gemini.SemanticRetrieverChunk? SemanticRetrieverChunk { get; set; } - /// /// Identifier for a part within a `GroundingPassage`. /// [global::System.Text.Json.Serialization.JsonPropertyName("groundingPassage")] public global::Google.Gemini.GroundingPassageId? GroundingPassage { get; set; } + /// + /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("semanticRetrieverChunk")] + public global::Google.Gemini.SemanticRetrieverChunk? SemanticRetrieverChunk { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class AttributionSourceId /// /// Initializes a new instance of the class. /// - /// - /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. - /// /// /// Identifier for a part within a `GroundingPassage`. /// + /// + /// Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AttributionSourceId( - global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk, - global::Google.Gemini.GroundingPassageId? groundingPassage) + global::Google.Gemini.GroundingPassageId? groundingPassage, + global::Google.Gemini.SemanticRetrieverChunk? semanticRetrieverChunk) { - this.SemanticRetrieverChunk = semanticRetrieverChunk; this.GroundingPassage = groundingPassage; + this.SemanticRetrieverChunk = semanticRetrieverChunk; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs index 340d130..d638ec9 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 @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class BatchStats { + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } + /// /// Output only. The number of requests that were successfully processed.
/// Included only in responses @@ -22,13 +29,6 @@ public sealed partial class BatchStats [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] public string? RequestCount { get; set; } - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } - /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses @@ -45,6 +45,10 @@ public sealed partial class BatchStats /// /// Initializes a new instance of the class. /// + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + /// /// /// Output only. The number of requests that were successfully processed.
/// Included only in responses @@ -53,10 +57,6 @@ public sealed partial class BatchStats /// Output only. The number of requests in the batch.
/// Included only in responses /// - /// - /// Output only. The number of requests that failed to be processed.
- /// Included only in responses - /// /// /// Output only. The number of requests that are still pending processing.
/// Included only in responses @@ -65,14 +65,14 @@ public sealed partial class BatchStats [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchStats( + string? failedRequestCount, string? successfulRequestCount, string? requestCount, - string? failedRequestCount, string? pendingRequestCount) { + this.FailedRequestCount = failedRequestCount; this.SuccessfulRequestCount = successfulRequestCount; this.RequestCount = requestCount; - this.FailedRequestCount = failedRequestCount; this.PendingRequestCount = pendingRequestCount; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs index 7dce698..8836a87 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini ///
public sealed partial class Blob { - /// - /// Raw bytes for media formats. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("data")] - public byte[]? Data { get; set; } - /// /// The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats). /// [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } + /// + /// Raw bytes for media formats. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("data")] + public byte[]? Data { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Blob /// /// Initializes a new instance of the class. /// - /// - /// Raw bytes for media formats. - /// /// /// The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats). /// + /// + /// Raw bytes for media formats. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Blob( - byte[]? data, - string? mimeType) + string? mimeType, + byte[]? data) { - this.Data = data; this.MimeType = mimeType; + this.Data = data; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs index 8fc2891..6ff9849 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,22 +9,17 @@ namespace Google.Gemini public sealed partial class CachedContent { /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } - - /// - /// Input only. New TTL for this resource, input only. + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] - public string? Ttl { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// /// Output only. When the cache entry was last updated in UTC time.
@@ -34,30 +29,29 @@ public sealed partial class CachedContent public string? UpdateTime { get; set; } /// - /// Output only. Creation time of the cache entry.
- /// Included only in responses + /// Optional. Input only. Immutable. The content to cache. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } /// - /// Metadata on the usage of the cached content. + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] + public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Output only. Creation time of the cache entry.
/// 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; } /// - /// Optional. Input only. Immutable. The content to cache. + /// Input only. New TTL for this resource, input only. /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("ttl")] + public string? Ttl { get; set; } /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. @@ -66,10 +60,10 @@ public sealed partial class CachedContent public string? ExpireTime { get; set; } /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { 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. @@ -78,10 +72,16 @@ public sealed partial class CachedContent public global::Google.Gemini.Content? SystemInstruction { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + + /// + /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -92,74 +92,74 @@ public sealed partial class CachedContent /// /// Initializes a new instance of the class. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// - /// - /// Input only. New TTL for this resource, input only. + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// /// /// Output only. When the cache entry was last updated in UTC time.
/// Included only in responses /// - /// - /// Output only. Creation time of the cache entry.
- /// Included only in responses + /// + /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Metadata on the usage of the cached content. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// + /// Output only. Creation time of the cache entry.
/// Included only in responses /// - /// - /// Optional. Input only. Immutable. The content to cache. + /// + /// Input only. New TTL for this resource, input only. /// /// /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// - /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` + /// + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// Metadata on the usage of the cached content. + /// + /// + /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( - global::Google.Gemini.ToolConfig? toolConfig, - string? ttl, - string? displayName, - string? updateTime, - string? createTime, - global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, string? name, + global::System.Collections.Generic.IList? tools, + string? updateTime, global::System.Collections.Generic.IList? contents, + global::Google.Gemini.ToolConfig? toolConfig, + string? createTime, + string? ttl, string? expireTime, - string? model, + string? displayName, global::Google.Gemini.Content? systemInstruction, - global::System.Collections.Generic.IList? tools) + global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, + string? model) { + this.Name = name; + this.Tools = tools; + this.UpdateTime = updateTime; + this.Contents = contents; this.ToolConfig = toolConfig; + this.CreateTime = createTime; this.Ttl = ttl; + this.ExpireTime = expireTime; this.DisplayName = displayName; - this.UpdateTime = updateTime; - this.CreateTime = createTime; + this.SystemInstruction = systemInstruction; this.UsageMetadata = usageMetadata; - this.Name = name; - this.Contents = contents; - this.ExpireTime = expireTime; this.Model = model; - this.SystemInstruction = systemInstruction; - this.Tools = tools; } /// 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 9bb18ff..59f0491 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,26 +9,24 @@ namespace Google.Gemini public sealed partial class Candidate { /// - /// Output only. Average log probability score of the candidate.
+ /// 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("avgLogprobs")] - public double? AvgLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] + public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("index")] - public int? Index { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("content")] + public global::Google.Gemini.Content? Content { get; set; } /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// Output only. Token count for this candidate.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishReason")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter))] - public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] + public int? TokenCount { get; set; } /// /// Metadata related to url context retrieval tool. @@ -37,11 +35,17 @@ public sealed partial class Candidate public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// 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. Average log probability score of the candidate.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("groundingAttributions")] - public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] + public double? AvgLogprobs { get; set; } /// /// List of ratings for the safety of a response candidate. There is at most one rating per category. @@ -50,23 +54,19 @@ public sealed partial class Candidate public global::System.Collections.Generic.IList? SafetyRatings { 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. Token count for this candidate.
+ /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] - public int? TokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishReason")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter))] + public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } /// - /// Logprobs Result + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] - public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("index")] + public int? Index { get; set; } /// /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
@@ -76,16 +76,16 @@ public sealed partial class Candidate public string? FinishMessage { get; set; } /// - /// Metadata returned to client when grounding is enabled. + /// Logprobs Result /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] - public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] + public global::Google.Gemini.LogprobsResult? LogprobsResult { 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. + /// 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -96,77 +96,77 @@ public sealed partial class Candidate /// /// Initializes a new instance of the class. /// - /// - /// Output only. Average log probability score of the candidate.
+ /// + /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
/// Included only in responses /// - /// - /// Output only. Index of the candidate in the list of response candidates.
- /// Included only in responses + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// + /// Output only. Token count for this candidate.
/// Included only in responses /// /// /// Metadata related to url context retrieval tool. /// - /// - /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
+ /// + /// Metadata returned to client when grounding is enabled. + /// + /// + /// Output only. Average log probability score of the candidate.
/// Included only in responses /// /// /// List of ratings for the safety of a response candidate. There is at most one rating per category. /// - /// - /// A collection of source attributions for a piece of content. - /// - /// - /// Output only. Token count for this candidate.
+ /// + /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
/// Included only in responses /// - /// - /// Logprobs Result + /// + /// Output only. Index of the candidate in the list of response candidates.
+ /// Included only in responses /// /// /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
/// Included only in responses /// - /// - /// Metadata returned to client when grounding is enabled. + /// + /// Logprobs Result /// - /// - /// 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. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( - double? avgLogprobs, - int? index, - global::Google.Gemini.CandidateFinishReason? finishReason, - global::Google.Gemini.UrlContextMetadata? urlContextMetadata, global::System.Collections.Generic.IList? groundingAttributions, - global::System.Collections.Generic.IList? safetyRatings, - global::Google.Gemini.CitationMetadata? citationMetadata, + global::Google.Gemini.Content? content, int? tokenCount, - global::Google.Gemini.LogprobsResult? logprobsResult, - string? finishMessage, + global::Google.Gemini.UrlContextMetadata? urlContextMetadata, global::Google.Gemini.GroundingMetadata? groundingMetadata, - global::Google.Gemini.Content? content) + double? avgLogprobs, + global::System.Collections.Generic.IList? safetyRatings, + global::Google.Gemini.CandidateFinishReason? finishReason, + int? index, + string? finishMessage, + global::Google.Gemini.LogprobsResult? logprobsResult, + global::Google.Gemini.CitationMetadata? citationMetadata) { - this.AvgLogprobs = avgLogprobs; - this.Index = index; - this.FinishReason = finishReason; - this.UrlContextMetadata = urlContextMetadata; this.GroundingAttributions = groundingAttributions; - this.SafetyRatings = safetyRatings; - this.CitationMetadata = citationMetadata; + this.Content = content; this.TokenCount = tokenCount; - this.LogprobsResult = logprobsResult; - this.FinishMessage = finishMessage; + this.UrlContextMetadata = urlContextMetadata; this.GroundingMetadata = groundingMetadata; - this.Content = content; + this.AvgLogprobs = avgLogprobs; + this.SafetyRatings = safetyRatings; + this.FinishReason = finishReason; + this.Index = index; + this.FinishMessage = finishMessage; + this.LogprobsResult = logprobsResult; + this.CitationMetadata = citationMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs index 229e50d..6d91af4 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,30 +8,30 @@ namespace Google.Gemini /// public sealed partial class CitationSource { - /// - /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] - public int? StartIndex { get; set; } - - /// - /// Optional. URI that is attributed as a source for a portion of the text. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// [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. End of the attributed segment, exclusive. /// [global::System.Text.Json.Serialization.JsonPropertyName("endIndex")] public int? EndIndex { get; set; } + /// + /// Optional. URI that is attributed as a source for a portion of the text. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class CitationSource /// /// Initializes a new instance of the class. /// - /// - /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. - /// - /// - /// Optional. URI that is attributed as a source for a portion of the text. - /// /// /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. /// + /// + /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. + /// /// /// Optional. End of the attributed segment, exclusive. /// + /// + /// Optional. URI that is attributed as a source for a portion of the text. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( - int? startIndex, - string? uri, string? license, - int? endIndex) + int? startIndex, + int? endIndex, + string? uri) { - this.StartIndex = startIndex; - this.Uri = uri; this.License = license; + this.StartIndex = startIndex; 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 a004072..590acbe 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. Contains stdout when code execution is successful, stderr or other description otherwise. /// - [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("output")] + public string? Output { get; set; } /// /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. @@ -22,10 +21,11 @@ public sealed partial class CodeExecutionResult public string? Id { get; set; } /// - /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. + /// Required. Outcome of the code execution. /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public string? Output { 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. 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. /// - /// - /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. + /// + /// Required. Outcome of the code execution. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( - global::Google.Gemini.CodeExecutionResultOutcome? outcome, + string? output, string? id, - string? output) + global::Google.Gemini.CodeExecutionResultOutcome? outcome) { - this.Outcome = outcome; - this.Id = id; this.Output = output; + this.Id = id; + this.Outcome = outcome; } /// 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 bc223dd..886d9de 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class Corpus { + /// + /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses @@ -15,12 +21,6 @@ public sealed partial class Corpus [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" - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } - /// /// Output only. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses @@ -44,13 +44,13 @@ public sealed partial class Corpus /// /// Initializes a new instance of the class. /// + /// + /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// /// /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses /// - /// - /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" - /// /// /// Output only. The Timestamp of when the `Corpus` was last updated.
/// Included only in responses @@ -63,13 +63,13 @@ public sealed partial class Corpus [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Corpus( - string? createTime, string? displayName, + string? createTime, string? updateTime, string? name) { - this.CreateTime = createTime; this.DisplayName = displayName; + this.CreateTime = createTime; this.UpdateTime = updateTime; 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 7f46bfc..2db32ed 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,11 +9,10 @@ namespace Google.Gemini public sealed partial class CountTokensResponse { /// - /// Output only. List of modalities that were processed in the cached content.
- /// Included only in responses + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] + public int? TotalTokens { get; set; } /// /// Number of tokens in the cached part of the prompt (the cached content). @@ -22,17 +21,18 @@ public sealed partial class CountTokensResponse public int? CachedContentTokenCount { get; set; } /// - /// Output only. List of modalities that were processed in the request input.
+ /// Output only. List of modalities that were processed in the cached content.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] - public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] + public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] - public int? TotalTokens { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] + public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -43,33 +43,33 @@ public sealed partial class CountTokensResponse /// /// Initializes a new instance of the class. /// - /// - /// Output only. List of modalities that were processed in the cached content.
- /// Included only in responses + /// + /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. /// /// /// Number of tokens in the cached part of the prompt (the cached content). /// + /// + /// 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 /// - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( - global::System.Collections.Generic.IList? cacheTokensDetails, + int? totalTokens, int? cachedContentTokenCount, - global::System.Collections.Generic.IList? promptTokensDetails, - int? totalTokens) + global::System.Collections.Generic.IList? cacheTokensDetails, + global::System.Collections.Generic.IList? promptTokensDetails) { - this.CacheTokensDetails = cacheTokensDetails; + this.TotalTokens = totalTokens; this.CachedContentTokenCount = cachedContentTokenCount; + this.CacheTokensDetails = cacheTokensDetails; this.PromptTokensDetails = promptTokensDetails; - this.TotalTokens = totalTokens; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs index 3c380a4..281ef6c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs @@ -14,18 +14,18 @@ public sealed partial class CustomLongRunningOperation [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. - /// - [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; } + /// + /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } + /// /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// @@ -33,10 +33,10 @@ public sealed partial class CustomLongRunningOperation public bool? Done { get; set; } /// - /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -50,33 +50,33 @@ 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}`. /// - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. - /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// + /// + /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// /// /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// - /// - /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( string? name, - object? metadata, global::Google.Gemini.Status? error, + object? response, bool? done, - object? response) + object? metadata) { this.Name = name; - this.Metadata = metadata; this.Error = error; - this.Done = done; this.Response = response; + this.Done = done; + this.Metadata = metadata; } /// 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 b2a2bbf..7daa08f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class CustomMetadata { + /// + /// The string value of the metadata to store. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] + public string? StringValue { get; set; } + /// /// The numeric value of the metadata to store. /// @@ -26,12 +32,6 @@ public sealed partial class CustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] public global::Google.Gemini.StringList? StringListValue { get; set; } - /// - /// The string value of the metadata to store. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] - public string? StringValue { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,6 +41,9 @@ public sealed partial class CustomMetadata /// /// Initializes a new instance of the class. /// + /// + /// The string value of the metadata to store. + /// /// /// The numeric value of the metadata to store. /// @@ -50,22 +53,19 @@ public sealed partial class CustomMetadata /// /// User provided string values assigned to a single metadata key. /// - /// - /// The string value of the metadata to store. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomMetadata( + string? stringValue, float? numericValue, string? key, - global::Google.Gemini.StringList? stringListValue, - string? stringValue) + global::Google.Gemini.StringList? stringListValue) { + this.StringValue = stringValue; this.NumericValue = numericValue; this.Key = key; this.StringListValue = stringListValue; - this.StringValue = stringValue; } /// 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 7f8a3d0..fbc461f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Document.g.cs @@ -9,10 +9,25 @@ namespace Google.Gemini public sealed partial class Document { /// - /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" + /// Output only. The size of raw bytes ingested into the Document.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } + + /// + /// Output only. The Timestamp of when the `Document` was created.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } + + /// + /// Output only. The mime type of the Document.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Output only. The Timestamp of when the `Document` was last updated.
@@ -21,6 +36,12 @@ public sealed partial class Document [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] public string? UpdateTime { get; set; } + /// + /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// Output only. Current state of the `Document`.
/// Included only in responses @@ -29,13 +50,6 @@ public sealed partial class Document [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 created.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } - /// /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` /// @@ -48,20 +62,6 @@ public sealed partial class Document [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// - /// Output only. The size of raw bytes ingested into the Document.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } - - /// - /// Output only. The mime type of the Document.
- /// Included only in responses - ///
- [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. /// - /// - /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" + /// + /// Output only. The size of raw bytes ingested into the Document.
+ /// Included only in responses + /// + /// + /// Output only. The Timestamp of when the `Document` was created.
+ /// Included only in responses + /// + /// + /// Output only. The mime type of the Document.
+ /// Included only in responses /// /// /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses /// + /// + /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" + /// /// /// Output only. Current state of the `Document`.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Document` was created.
- /// Included only in responses - /// /// /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` /// /// /// 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 mime type of the Document.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( - string? displayName, + string? sizeBytes, + string? createTime, + string? mimeType, string? updateTime, + string? displayName, global::Google.Gemini.DocumentState? state, - string? createTime, string? name, - global::System.Collections.Generic.IList? customMetadata, - string? sizeBytes, - string? mimeType) + global::System.Collections.Generic.IList? customMetadata) { - this.DisplayName = displayName; + this.SizeBytes = sizeBytes; + this.CreateTime = createTime; + this.MimeType = mimeType; this.UpdateTime = updateTime; + this.DisplayName = displayName; this.State = state; - this.CreateTime = createTime; this.Name = name; this.CustomMetadata = customMetadata; - this.SizeBytes = sizeBytes; - this.MimeType = mimeType; } /// 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 58ec30e..28b8167 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatch.g.cs @@ -14,6 +14,18 @@ public sealed partial class EmbedContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] public global::Google.Gemini.InputEmbedContentConfig? InputConfig { 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; } + + /// + /// Required. The user-defined name of this batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// @@ -28,10 +40,17 @@ public sealed partial class EmbedContentBatch public string? CreateTime { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } + + /// + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// /// Output only. The time at which the batch was last updated.
@@ -41,12 +60,10 @@ public sealed partial class EmbedContentBatch public string? UpdateTime { get; set; } /// - /// Output only. The state of the batch.
- /// Included only in responses + /// Stats about the batch. ///
- [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("batchStats")] + public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } /// /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
@@ -56,29 +73,12 @@ public sealed partial class EmbedContentBatch public string? Name { get; set; } /// - /// Output only. The time at which the batch processing completed.
+ /// Output only. The state of the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } - - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } - - /// - /// 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; } - - /// - /// Stats about the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.EmbedContentBatchStats? BatchStats { 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; } /// /// Additional properties that are not explicitly defined in the schema @@ -92,6 +92,12 @@ public sealed partial class EmbedContentBatch /// /// Configures the input to the batch request. /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Required. The user-defined name of this batch. + /// /// /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// @@ -99,61 +105,55 @@ public sealed partial class EmbedContentBatch /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// 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. + /// + /// + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses /// /// /// Output only. The time at which the batch was last updated.
/// Included only in responses /// - /// - /// Output only. The state of the batch.
- /// Included only in responses + /// + /// Stats about the batch. /// /// /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// - /// - /// Output only. The time at which the batch processing completed.
+ /// + /// 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. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Stats about the batch. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( global::Google.Gemini.InputEmbedContentConfig? inputConfig, + string? model, + string? displayName, global::Google.Gemini.EmbedContentBatchOutput? output, string? createTime, - string? displayName, + string? priority, + string? endTime, string? updateTime, - global::Google.Gemini.EmbedContentBatchState? state, + global::Google.Gemini.EmbedContentBatchStats? batchStats, string? name, - string? endTime, - string? priority, - string? model, - global::Google.Gemini.EmbedContentBatchStats? batchStats) + global::Google.Gemini.EmbedContentBatchState? state) { this.InputConfig = inputConfig; + this.Model = model; + this.DisplayName = displayName; this.Output = output; this.CreateTime = createTime; - this.DisplayName = displayName; - this.UpdateTime = updateTime; - this.State = state; - this.Name = name; - this.EndTime = endTime; this.Priority = priority; - this.Model = model; + this.EndTime = endTime; + this.UpdateTime = updateTime; this.BatchStats = batchStats; + this.Name = name; + this.State = state; } /// 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 c7ac9b5..973d484 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,6 +8,12 @@ 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 @@ -15,12 +21,6 @@ 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( - string? responsesFile, - global::Google.Gemini.InlinedEmbedContentResponses? inlinedResponses) + global::Google.Gemini.InlinedEmbedContentResponses? inlinedResponses, + string? responsesFile) { - this.ResponsesFile = responsesFile; this.InlinedResponses = inlinedResponses; + this.ResponsesFile = responsesFile; } /// 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 8701ce7..d90698b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs @@ -9,32 +9,32 @@ namespace Google.Gemini public sealed partial class EmbedContentBatchStats { /// - /// Output only. The number of requests in the batch.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] - public string? RequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests that were successfully processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] + public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that are still pending processing.
+ /// Output only. The number of requests in the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] - public string? PendingRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("requestCount")] + public string? RequestCount { get; set; } /// - /// Output only. The number of requests that were successfully processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] + public string? PendingRequestCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,35 +45,35 @@ public sealed partial class EmbedContentBatchStats /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of requests in the batch.
- /// Included only in responses - /// /// /// Output only. The number of requests that 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 were successfully processed.
/// Included only in responses /// + /// + /// Output only. The number of requests in the batch.
+ /// Included only in responses + /// + /// + /// Output only. The number of requests that are still pending processing.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchStats( - string? requestCount, string? failedRequestCount, - string? pendingRequestCount, - string? successfulRequestCount) + string? successfulRequestCount, + string? requestCount, + string? pendingRequestCount) { - this.RequestCount = requestCount; this.FailedRequestCount = failedRequestCount; - this.PendingRequestCount = pendingRequestCount; this.SuccessfulRequestCount = successfulRequestCount; + this.RequestCount = requestCount; + this.PendingRequestCount = pendingRequestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs index 757b8b6..a1a6903 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 @@ -9,10 +9,11 @@ namespace Google.Gemini public sealed partial class EmbedContentRequest { /// - /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] - public int? OutputDimensionality { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter))] + public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. @@ -21,10 +22,10 @@ public sealed partial class EmbedContentRequest public string? Title { get; set; } /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputDimensionality")] + public int? OutputDimensionality { get; set; } /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. @@ -33,11 +34,10 @@ public sealed partial class EmbedContentRequest public global::Google.Gemini.Content? Content { get; set; } /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// - [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter))] - public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -48,36 +48,36 @@ public sealed partial class EmbedContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). + /// + /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). /// /// /// Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// + /// Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Optional. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( - int? outputDimensionality, + global::Google.Gemini.EmbedContentRequestTaskType? taskType, string? title, - string? model, + int? outputDimensionality, global::Google.Gemini.Content? content, - global::Google.Gemini.EmbedContentRequestTaskType? taskType) + string? model) { - this.OutputDimensionality = outputDimensionality; + this.TaskType = taskType; this.Title = title; - this.Model = model; + this.OutputDimensionality = outputDimensionality; this.Content = content; - this.TaskType = taskType; + this.Model = model; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs index ab199b5..4f2c65f 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,18 +8,18 @@ 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. The code to be executed. /// [global::System.Text.Json.Serialization.JsonPropertyName("code")] public string? Code { get; set; } + /// + /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Required. Programming language of the `code`. /// @@ -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. The code to be executed. /// + /// + /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. + /// /// /// Required. Programming language of the `code`. /// @@ -49,12 +49,12 @@ public sealed partial class ExecutableCode [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ExecutableCode( - string? id, string? code, + string? id, global::Google.Gemini.ExecutableCodeLanguage? language) { - this.Id = id; this.Code = code; + this.Id = id; this.Language = language; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs index 41580b5..341f6d3 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs @@ -9,11 +9,30 @@ namespace Google.Gemini public sealed partial class File { /// - /// Output only. The timestamp of when the `File` was created.
+ /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + + /// + /// 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; } + + /// + /// Metadata for a video `File`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } + + /// + /// Output only. Processing state of the File.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] + public global::Google.Gemini.FileState? State { get; set; } /// /// Output only. The timestamp of when the `File` was last updated.
@@ -23,11 +42,11 @@ public sealed partial class File public string? UpdateTime { get; set; } /// - /// Output only. MIME type of the file.
+ /// Output only. The timestamp of when the `File` was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Output only. Size of the file in bytes.
@@ -36,6 +55,13 @@ public sealed partial class File [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] public string? SizeBytes { get; set; } + /// + /// Output only. The uri of the `File`.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } + /// /// Source of the File. /// @@ -44,36 +70,24 @@ public sealed partial class File public global::Google.Gemini.FileSource? Source { get; set; } /// - /// Metadata for a video `File`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - public global::Google.Gemini.VideoFileMetadata? VideoMetadata { get; set; } - - /// - /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("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). + /// 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; } /// - /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] + public string? ExpirationTime { get; set; } /// - /// Output only. Processing state of the File.
- /// Included only in responses + /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` ///
- [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("name")] + public string? Name { get; set; } /// /// Output only. SHA-256 hash of the uploaded bytes.
@@ -82,13 +96,6 @@ public sealed partial class File [global::System.Text.Json.Serialization.JsonPropertyName("sha256Hash")] public byte[]? Sha256Hash { get; set; } - /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] - public string? ExpirationTime { get; set; } - /// /// Output only. The download uri of the `File`.
/// Included only in responses @@ -96,13 +103,6 @@ public sealed partial class File [global::System.Text.Json.Serialization.JsonPropertyName("downloadUri")] public string? DownloadUri { get; set; } - /// - /// Output only. The uri of the `File`.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -112,90 +112,90 @@ public sealed partial class File /// /// Initializes a new instance of the class. /// - /// - /// Output only. The timestamp of when the `File` was created.
+ /// + /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + /// + /// Metadata for a video `File`. + /// + /// + /// Output only. Processing state of the File.
/// Included only in responses /// /// /// Output only. The timestamp of when the `File` was last updated.
/// Included only in responses /// - /// - /// Output only. MIME type of the file.
+ /// + /// Output only. The timestamp of when the `File` was created.
/// Included only in responses /// /// /// Output only. Size of the file in bytes.
/// Included only in responses /// + /// + /// Output only. The uri of the `File`.
+ /// Included only in responses + /// /// /// Source of the File. /// - /// - /// Metadata for a video `File`. + /// + /// Output only. MIME type of the file.
+ /// Included only in responses + /// + /// + /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// 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` /// - /// - /// 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). - /// - /// - /// 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.
- /// Included only in responses - /// /// /// Output only. SHA-256 hash of the uploaded bytes.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
- /// Included only in responses - /// /// /// Output only. The download uri of the `File`.
/// Included only in responses /// - /// - /// Output only. The uri of the `File`.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public File( - string? createTime, + string? displayName, + global::Google.Gemini.Status? error, + global::Google.Gemini.VideoFileMetadata? videoMetadata, + global::Google.Gemini.FileState? state, string? updateTime, - string? mimeType, + string? createTime, string? sizeBytes, + string? uri, global::Google.Gemini.FileSource? source, - global::Google.Gemini.VideoFileMetadata? videoMetadata, + string? mimeType, + string? expirationTime, string? name, - global::Google.Gemini.Status? error, - string? displayName, - global::Google.Gemini.FileState? state, byte[]? sha256Hash, - string? expirationTime, - string? downloadUri, - string? uri) + string? downloadUri) { - this.CreateTime = createTime; + this.DisplayName = displayName; + this.Error = error; + this.VideoMetadata = videoMetadata; + this.State = state; this.UpdateTime = updateTime; - this.MimeType = mimeType; + this.CreateTime = createTime; this.SizeBytes = sizeBytes; + this.Uri = uri; this.Source = source; - this.VideoMetadata = videoMetadata; + this.MimeType = mimeType; + this.ExpirationTime = expirationTime; this.Name = name; - this.Error = error; - this.DisplayName = displayName; - this.State = state; this.Sha256Hash = sha256Hash; - this.ExpirationTime = expirationTime; this.DownloadUri = downloadUri; - this.Uri = uri; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileData.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileData.g.cs index 6b60771..0f185b2 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileData.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileData.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class FileData { - /// - /// Required. URI. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileUri")] - public string? FileUri { get; set; } - /// /// Optional. The IANA standard MIME type of the source data. /// [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } + /// + /// Required. URI. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileUri")] + public string? FileUri { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class FileData /// /// Initializes a new instance of the class. /// - /// - /// Required. URI. - /// /// /// Optional. The IANA standard MIME type of the source data. /// + /// + /// Required. URI. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileData( - string? fileUri, - string? mimeType) + string? mimeType, + string? fileUri) { - this.FileUri = fileUri; this.MimeType = mimeType; + this.FileUri = fileUri; } /// 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 4f1999e..941bbd0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearch.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class FileSearch { - /// - /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. - /// - [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` /// @@ -26,6 +20,12 @@ public sealed partial class FileSearch [global::System.Text.Json.Serialization.JsonPropertyName("topK")] public int? TopK { get; set; } + /// + /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("metadataFilter")] + public string? MetadataFilter { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class FileSearch /// /// Initializes a new instance of the class. /// - /// - /// Optional. 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` /// /// /// Optional. The number of semantic retrieval chunks to retrieve. /// + /// + /// Optional. Metadata filter to apply to the semantic retrieval documents and chunks. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearch( - string? metadataFilter, global::System.Collections.Generic.IList? fileSearchStoreNames, - int? topK) + int? topK, + string? metadataFilter) { - this.MetadataFilter = metadataFilter; this.FileSearchStoreNames = fileSearchStoreNames; this.TopK = topK; + this.MetadataFilter = metadataFilter; } /// 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 7c056b9..9beebfd 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class FileSearchStore { + /// + /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } + /// /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses @@ -23,18 +30,18 @@ public sealed partial class FileSearchStore public string? SizeBytes { get; set; } /// - /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// 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("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
+ /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] - public string? FailedDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] + public string? ActiveDocumentsCount { 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" @@ -50,18 +57,11 @@ public sealed partial class FileSearchStore public string? UpdateTime { 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 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 @@ -72,6 +72,10 @@ public sealed partial class FileSearchStore /// /// Initializes a new instance of the class. /// + /// + /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// Included only in responses + /// /// /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses @@ -80,12 +84,12 @@ public sealed partial class FileSearchStore /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `FileSearchStore` was created.
+ /// + /// 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 number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses /// /// @@ -95,35 +99,31 @@ public sealed partial class FileSearchStore /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// 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 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? createTime, string? pendingDocumentsCount, string? sizeBytes, - string? createTime, - string? failedDocumentsCount, + string? name, + string? activeDocumentsCount, string? displayName, string? updateTime, - string? name, - string? activeDocumentsCount) + string? failedDocumentsCount) { + this.CreateTime = createTime; this.PendingDocumentsCount = pendingDocumentsCount; this.SizeBytes = sizeBytes; - this.CreateTime = createTime; - this.FailedDocumentsCount = failedDocumentsCount; - this.DisplayName = displayName; - this.UpdateTime = updateTime; this.Name = name; this.ActiveDocumentsCount = activeDocumentsCount; + this.DisplayName = displayName; + 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 e2ad38a..310f34c 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 4f2fd76..34bb1ab 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 f53f16a..3758a11 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs @@ -9,16 +9,10 @@ namespace Google.Gemini public sealed partial class FunctionDeclaration { /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - 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). + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] - public global::Google.Gemini.Schema? Parameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Required. A brief description of the function. @@ -33,17 +27,10 @@ public sealed partial class FunctionDeclaration public object? ParametersJsonSchema { get; set; } /// - /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] - public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } - - /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.Schema? Response { get; set; } /// /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. @@ -51,6 +38,19 @@ public sealed partial class FunctionDeclaration [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] public object? ResponseJsonSchema { get; set; } + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] + public global::Google.Gemini.Schema? Parameters { get; set; } + + /// + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] + public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -60,11 +60,8 @@ public sealed partial class FunctionDeclaration /// /// Initializes a new instance of the class. /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). - /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. /// /// /// Required. A brief description of the function. @@ -72,34 +69,37 @@ public sealed partial class FunctionDeclaration /// /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. /// - /// - /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. - /// - /// - /// Required. The name of the function. Must be a-z, A-Z, 0-9, or contain underscores, colons, dots, and dashes, with a maximum length of 128. + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// /// /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. /// + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( - global::Google.Gemini.Schema? response, - global::Google.Gemini.Schema? parameters, + string? name, string? description, object? parametersJsonSchema, - global::Google.Gemini.FunctionDeclarationBehavior? behavior, - string? name, - object? responseJsonSchema) + global::Google.Gemini.Schema? response, + object? responseJsonSchema, + global::Google.Gemini.Schema? parameters, + global::Google.Gemini.FunctionDeclarationBehavior? behavior) { - this.Response = response; - this.Parameters = parameters; + this.Name = name; this.Description = description; this.ParametersJsonSchema = parametersJsonSchema; - this.Behavior = behavior; - this.Name = name; + this.Response = response; this.ResponseJsonSchema = responseJsonSchema; + this.Parameters = parameters; + this.Behavior = behavior; } /// 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 78167ed..d41b524 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. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } - /// /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. /// @@ -26,6 +20,12 @@ public sealed partial class FunctionResponse [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } + /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// @@ -54,15 +54,15 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// - /// - /// 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. /// /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// + /// + /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. + /// /// /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. /// @@ -76,16 +76,16 @@ public sealed partial class FunctionResponse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( - string? id, object? response, string? name, + string? id, global::System.Collections.Generic.IList? parts, bool? willContinue, global::Google.Gemini.FunctionResponseScheduling? scheduling) { - this.Id = id; this.Response = response; this.Name = name; + this.Id = id; this.Parts = parts; this.WillContinue = willContinue; this.Scheduling = scheduling; diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs index d727aa3..68b61c6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponseBlob.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class FunctionResponseBlob { - /// - /// Raw bytes for media formats. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("data")] - public byte[]? Data { get; set; } - /// /// The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats). /// [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } + /// + /// Raw bytes for media formats. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("data")] + public byte[]? Data { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class FunctionResponseBlob /// /// Initializes a new instance of the class. /// - /// - /// Raw bytes for media formats. - /// /// /// The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats). /// + /// + /// Raw bytes for media formats. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponseBlob( - byte[]? data, - string? mimeType) + string? mimeType, + byte[]? data) { - this.Data = data; this.MimeType = mimeType; + this.Data = data; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs index 6c39973..4eda7cb 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,22 +9,28 @@ namespace Google.Gemini public sealed partial class GenerateContentBatch { /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } /// - /// Stats about the batch. + /// Configures the input to the batch request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] - public global::Google.Gemini.BatchStats? BatchStats { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] + public global::Google.Gemini.InputConfig? InputConfig { get; set; } + + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// Output only. The time at which the batch processing completed.
@@ -34,36 +40,24 @@ public sealed partial class GenerateContentBatch public string? EndTime { get; set; } /// - /// Configures the input to the batch request. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputConfig")] - public global::Google.Gemini.InputConfig? InputConfig { get; set; } - - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } - - /// - /// Output only. The time at which the batch was created.
+ /// Output only. The time at which the batch was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Required. The user-defined name of this batch. + /// Stats about the batch. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] + public global::Google.Gemini.BatchStats? BatchStats { get; set; } /// - /// Output only. The time at which the batch was last updated.
+ /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Output only. The state of the batch.
@@ -74,11 +68,17 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.GenerateContentBatchState? State { get; set; } /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Output only. The time at which the batch 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; } + + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -89,71 +89,71 @@ public sealed partial class GenerateContentBatch /// /// Initializes a new instance of the class. /// - /// - /// 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. + /// + /// + /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. + /// + /// + /// Configures the input to the batch request. /// /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - /// - /// Stats about the batch. - /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// - /// - /// Configures the input to the batch request. - /// - /// - /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. - /// - /// - /// Output only. The time at which the batch was created.
+ /// + /// Output only. The time at which the batch was last updated.
/// Included only in responses /// - /// - /// Required. The user-defined name of this batch. + /// + /// Stats about the batch. /// - /// - /// Output only. The time at which the batch was last updated.
+ /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses /// /// /// Output only. The state of the batch.
/// Included only in responses /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( - string? priority, + string? displayName, + global::Google.Gemini.GenerateContentBatchOutput? output, + global::Google.Gemini.InputConfig? inputConfig, string? model, - global::Google.Gemini.BatchStats? batchStats, string? endTime, - global::Google.Gemini.InputConfig? inputConfig, - global::Google.Gemini.GenerateContentBatchOutput? output, - string? createTime, - string? displayName, string? updateTime, + global::Google.Gemini.BatchStats? batchStats, + string? name, global::Google.Gemini.GenerateContentBatchState? state, - string? name) + string? createTime, + string? priority) { - this.Priority = priority; + this.DisplayName = displayName; + this.Output = output; + this.InputConfig = inputConfig; this.Model = model; - this.BatchStats = batchStats; this.EndTime = endTime; - this.InputConfig = inputConfig; - this.Output = output; - this.CreateTime = createTime; - this.DisplayName = displayName; this.UpdateTime = updateTime; - this.State = state; + this.BatchStats = batchStats; this.Name = name; + this.State = state; + this.CreateTime = createTime; + this.Priority = priority; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs index ca3508f..12a631b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GenerateContentBatchOutput { + /// + /// The responses to the requests in the batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] + public global::Google.Gemini.InlinedResponses? InlinedResponses { get; set; } + /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses @@ -15,12 +21,6 @@ public sealed partial class GenerateContentBatchOutput [global::System.Text.Json.Serialization.JsonPropertyName("responsesFile")] public string? ResponsesFile { get; set; } - /// - /// The responses to the requests in the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] - public global::Google.Gemini.InlinedResponses? InlinedResponses { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class GenerateContentBatchOutput /// /// Initializes a new instance of the class. /// + /// + /// The responses to the requests in the batch. + /// /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses /// - /// - /// The responses to the requests in the batch. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatchOutput( - string? responsesFile, - global::Google.Gemini.InlinedResponses? inlinedResponses) + global::Google.Gemini.InlinedResponses? inlinedResponses, + string? responsesFile) { - this.ResponsesFile = responsesFile; this.InlinedResponses = inlinedResponses; + this.ResponsesFile = responsesFile; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs index c602ac7..07faa01 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs @@ -9,34 +9,28 @@ namespace Google.Gemini public sealed partial class GenerateContentRequest { /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("store")] - public bool? Store { get; set; } - - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } /// - /// Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more. + /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] + public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContent")] - public string? CachedContent { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] + public global::Google.Gemini.ToolConfig? ToolConfig { 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. @@ -45,29 +39,35 @@ public sealed partial class GenerateContentRequest public global::System.Collections.Generic.IList? SafetySettings { get; set; } /// - /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. + /// Optional. The service tier of the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("generationConfig")] - public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter))] + public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { get; set; } /// - /// 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. + /// 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("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } /// - /// Optional. The service tier of the request. + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter))] - public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("store")] + public bool? Store { get; set; } + + /// + /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContent")] + public string? CachedContent { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -78,61 +78,61 @@ public sealed partial class GenerateContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. - /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// 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. /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` - /// - /// - /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. + /// + /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Required. The 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. + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// /// /// Optional. The service tier of the request. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// + /// 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}` /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentRequest( - bool? store, - string? model, - global::Google.Gemini.Content? systemInstruction, global::System.Collections.Generic.IList? tools, - string? cachedContent, - global::System.Collections.Generic.IList? safetySettings, - global::Google.Gemini.GenerationConfig? generationConfig, global::System.Collections.Generic.IList? contents, + global::Google.Gemini.GenerationConfig? generationConfig, + global::Google.Gemini.ToolConfig? toolConfig, + global::System.Collections.Generic.IList? safetySettings, global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, - global::Google.Gemini.ToolConfig? toolConfig) + global::Google.Gemini.Content? systemInstruction, + string? model, + bool? store, + string? cachedContent) { - this.Store = store; - this.Model = model; - this.SystemInstruction = systemInstruction; this.Tools = tools; - this.CachedContent = cachedContent; - this.SafetySettings = safetySettings; - this.GenerationConfig = generationConfig; this.Contents = contents; - this.ServiceTier = serviceTier; + this.GenerationConfig = generationConfig; this.ToolConfig = toolConfig; + this.SafetySettings = safetySettings; + this.ServiceTier = serviceTier; + this.SystemInstruction = systemInstruction; + this.Model = model; + this.Store = store; + this.CachedContent = cachedContent; } /// 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 70ca613..d0cb9b7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs @@ -8,24 +8,12 @@ namespace Google.Gemini /// public sealed partial class GenerateContentResponse { - /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] - public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } - /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } - /// - /// Metadata on the generation request's token usage. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } - /// /// Output only. The model version used to generate the response.
/// Included only in responses @@ -34,10 +22,10 @@ public sealed partial class GenerateContentResponse public string? ModelVersion { 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.
@@ -46,6 +34,18 @@ public sealed partial class GenerateContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("responseId")] public string? ResponseId { get; set; } + /// + /// Candidate responses from the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] + public global::System.Collections.Generic.IList? Candidates { get; set; } + + /// + /// Metadata on the generation request's token usage. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -55,43 +55,43 @@ public sealed partial class GenerateContentResponse /// /// Initializes a new instance of the class. /// - /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. - /// /// /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// - /// - /// Metadata on the generation request's token usage. - /// /// /// Output only. The model version used to generate the response.
/// Included only in responses /// - /// - /// Candidate responses from the model. + /// + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. /// /// /// Output only. response_id is used to identify each response.
/// Included only in responses /// + /// + /// Candidate responses from the model. + /// + /// + /// Metadata on the generation request's token usage. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentResponse( - global::Google.Gemini.ModelStatus? modelStatus, global::Google.Gemini.PromptFeedback? promptFeedback, - global::Google.Gemini.UsageMetadata? usageMetadata, string? modelVersion, + global::Google.Gemini.ModelStatus? modelStatus, + string? responseId, global::System.Collections.Generic.IList? candidates, - string? responseId) + global::Google.Gemini.UsageMetadata? usageMetadata) { - this.ModelStatus = modelStatus; this.PromptFeedback = promptFeedback; - this.UsageMetadata = usageMetadata; this.ModelVersion = modelVersion; - this.Candidates = candidates; + this.ModelStatus = modelStatus; this.ResponseId = responseId; + this.Candidates = candidates; + this.UsageMetadata = usageMetadata; } /// 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 1e5359b..f270d84 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GeneratedFile.g.cs @@ -20,12 +20,6 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// Output only. The state of the GeneratedFile.
/// Included only in responses @@ -34,6 +28,12 @@ public sealed partial class GeneratedFile [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter))] public global::Google.Gemini.GeneratedFileState? State { get; set; } + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -49,26 +49,26 @@ public sealed partial class GeneratedFile /// /// MIME type of the generatedFile. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// Output only. The state of the GeneratedFile.
/// Included only in responses /// + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GeneratedFile( string? name, string? mimeType, - global::Google.Gemini.Status? error, - global::Google.Gemini.GeneratedFileState? state) + global::Google.Gemini.GeneratedFileState? state, + global::Google.Gemini.Status? error) { this.Name = name; this.MimeType = mimeType; - this.Error = error; this.State = state; + this.Error = error; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs index c5aea10..51b532b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GenerationConfig { + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] + public global::Google.Gemini.Schema? ResponseSchema { get; set; } + /// /// Optional. Enables enhanced civic answers. It may not be available for all models. /// @@ -15,41 +21,40 @@ public sealed partial class GenerationConfig public bool? EnableEnhancedCivicAnswers { get; set; } /// - /// Optional. If specified, the media resolution specified will be used. + /// Config for speech generation and transcription. /// - [global::System.Text.Json.Serialization.JsonPropertyName("mediaResolution")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] - public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// Config for image generation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] - public global::Google.Gemini.Schema? ResponseSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] + public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } /// - /// Config for thinking features. + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("seed")] + public int? Seed { 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. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] + public string? ResponseMimeType { 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. An internal detail. Use `responseJsonSchema` rather than this field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { get; set; } /// - /// Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types. + /// Optional. 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("responseMimeType")] - public string? ResponseMimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] + public int? MaxOutputTokens { get; set; } /// /// Optional. If true, export the logprobs results in response. @@ -58,28 +63,29 @@ public sealed partial class GenerationConfig public bool? ResponseLogprobs { get; set; } /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// Optional. The 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("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// - /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// Optional. If specified, the media resolution specified will be used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mediaResolution")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter))] + public global::Google.Gemini.GenerationConfigMediaResolution? MediaResolution { get; set; } /// - /// Config for speech generation and transcription. + /// 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("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Config for image generation features. + /// 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("imageConfig")] - public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. @@ -87,12 +93,6 @@ public sealed partial class GenerationConfig [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] public float? PresencePenalty { get; set; } - /// - /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] - public float? FrequencyPenalty { get; set; } - /// /// Optional. The 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. /// @@ -100,34 +100,34 @@ public sealed partial class GenerationConfig public global::System.Collections.Generic.IList? ResponseModalities { 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. 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("maxOutputTokens")] - public int? MaxOutputTokens { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] + public int? Logprobs { get; set; } /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. + /// Config for thinking features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("seed")] - public int? Seed { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] + public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } /// - /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) + /// Optional. 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("candidateCount")] - public int? CandidateCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] + public float? FrequencyPenalty { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// - /// Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. + /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] - public int? Logprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidateCount")] + public int? CandidateCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -138,111 +138,111 @@ public sealed partial class GenerationConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. - /// - /// - /// Optional. If specified, the media resolution specified will be used. - /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - /// - /// Config for thinking features. + /// + /// Optional. Enables enhanced civic answers. It may not be available for all models. /// - /// - /// 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. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. + /// + /// Config for image generation features. + /// + /// + /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. /// /// /// 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. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// + /// 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. If true, export the logprobs results in response. /// - /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// + /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. /// - /// - /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// + /// Optional. If specified, the media resolution specified will be used. /// - /// - /// Config for speech generation and transcription. + /// + /// 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]. /// - /// - /// Config for image generation features. + /// + /// 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. 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. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. - /// /// /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// - /// - /// Optional. The maximum number of tokens to 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. 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. Seed used in decoding. If not set, the request uses a randomly generated seed. + /// + /// Config for thinking features. /// - /// - /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) + /// + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. /// - /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. + /// + /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - /// - /// Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. + /// + /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - bool? enableEnhancedCivicAnswers, - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, global::Google.Gemini.Schema? responseSchema, - global::Google.Gemini.ThinkingConfig? thinkingConfig, - int? topK, - global::System.Collections.Generic.IList? stopSequences, + bool? enableEnhancedCivicAnswers, + global::Google.Gemini.SpeechConfig? speechConfig, + global::Google.Gemini.ImageConfig? imageConfig, + int? seed, string? responseMimeType, + object? responseJsonSchema, + int? maxOutputTokens, bool? responseLogprobs, + global::System.Collections.Generic.IList? stopSequences, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, float? temperature, - float? topP, - global::Google.Gemini.SpeechConfig? speechConfig, - global::Google.Gemini.ImageConfig? imageConfig, + int? topK, float? presencePenalty, - float? frequencyPenalty, global::System.Collections.Generic.IList? responseModalities, - int? maxOutputTokens, - int? seed, - int? candidateCount, - object? responseJsonSchema, - int? logprobs) + int? logprobs, + global::Google.Gemini.ThinkingConfig? thinkingConfig, + float? frequencyPenalty, + float? topP, + int? candidateCount) { - this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; - this.MediaResolution = mediaResolution; this.ResponseSchema = responseSchema; - this.ThinkingConfig = thinkingConfig; - this.TopK = topK; - this.StopSequences = stopSequences; + this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; + this.SpeechConfig = speechConfig; + this.ImageConfig = imageConfig; + this.Seed = seed; this.ResponseMimeType = responseMimeType; + this.ResponseJsonSchema = responseJsonSchema; + this.MaxOutputTokens = maxOutputTokens; this.ResponseLogprobs = responseLogprobs; + this.StopSequences = stopSequences; + this.MediaResolution = mediaResolution; this.Temperature = temperature; - this.TopP = topP; - this.SpeechConfig = speechConfig; - this.ImageConfig = imageConfig; + this.TopK = topK; this.PresencePenalty = presencePenalty; - this.FrequencyPenalty = frequencyPenalty; this.ResponseModalities = responseModalities; - this.MaxOutputTokens = maxOutputTokens; - this.Seed = seed; - this.CandidateCount = candidateCount; - this.ResponseJsonSchema = responseJsonSchema; this.Logprobs = logprobs; + this.ThinkingConfig = thinkingConfig; + this.FrequencyPenalty = frequencyPenalty; + this.TopP = topP; + this.CandidateCount = candidateCount; } /// 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 d6183e5..49ae510 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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GoogleAiGenerativelanguageV1betaSegment { - /// - /// 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. /// @@ -32,6 +26,12 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment [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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,9 +41,6 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// Initializes a new instance of the class. /// - /// - /// 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. /// @@ -53,19 +50,22 @@ 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. /// + /// + /// End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaSegment( - int? endIndex, string? text, int? partIndex, - int? startIndex) + int? startIndex, + int? endIndex) { - this.EndIndex = endIndex; this.Text = text; this.PartIndex = partIndex; this.StartIndex = startIndex; + this.EndIndex = endIndex; } /// 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 3645446..bcc9b42 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 { - /// - /// 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; } + /// + /// 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; } + /// /// 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. /// - /// - /// 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. /// + /// + /// Different types of search that can be enabled on the GoogleSearch tool. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleSearch( - global::Google.Gemini.SearchTypes? searchTypes, - global::Google.Gemini.Interval? timeRangeFilter) + global::Google.Gemini.Interval? timeRangeFilter, + global::Google.Gemini.SearchTypes? searchTypes) { - this.SearchTypes = searchTypes; this.TimeRangeFilter = timeRangeFilter; + this.SearchTypes = searchTypes; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs index fadfe83..26223c8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingAttribution.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GroundingAttribution { - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { get; set; } - /// /// Identifier for the source contributing to this attribution. /// [global::System.Text.Json.Serialization.JsonPropertyName("sourceId")] public global::Google.Gemini.AttributionSourceId? SourceId { get; set; } + /// + /// 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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class GroundingAttribution /// /// Initializes a new instance of the class. /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// /// /// Identifier for the source contributing to this attribution. /// + /// + /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingAttribution( - global::Google.Gemini.Content? content, - global::Google.Gemini.AttributionSourceId? sourceId) + global::Google.Gemini.AttributionSourceId? sourceId, + global::Google.Gemini.Content? content) { - this.Content = content; this.SourceId = sourceId; + this.Content = content; } /// 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 2363445..d27561d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class GroundingChunk { /// - /// Chunk from the web. + /// Chunk from image search. /// - [global::System.Text.Json.Serialization.JsonPropertyName("web")] - public global::Google.Gemini.Web? Web { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("image")] + public global::Google.Gemini.Image? Image { get; set; } /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. @@ -21,10 +21,10 @@ public sealed partial class GroundingChunk public global::Google.Gemini.Maps? Maps { get; set; } /// - /// Chunk from image search. + /// Chunk from the web. /// - [global::System.Text.Json.Serialization.JsonPropertyName("image")] - public global::Google.Gemini.Image? Image { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("web")] + public global::Google.Gemini.Web? Web { get; set; } /// /// Chunk from context retrieved by the file search tool. @@ -41,14 +41,14 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// - /// - /// Chunk from the web. + /// + /// Chunk from image search. /// /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// - /// - /// Chunk from image search. + /// + /// Chunk from the web. /// /// /// Chunk from context retrieved by the file search tool. @@ -57,14 +57,14 @@ public sealed partial class GroundingChunk [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( - global::Google.Gemini.Web? web, - global::Google.Gemini.Maps? maps, global::Google.Gemini.Image? image, + global::Google.Gemini.Maps? maps, + global::Google.Gemini.Web? web, global::Google.Gemini.RetrievedContext? retrievedContext) { - this.Web = web; - this.Maps = maps; 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 ea178f0..52714bd 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,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GroundingChunkCustomMetadata { + /// + /// A list of string values. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] + public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } + /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// @@ -20,12 +26,6 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("key")] public string? Key { get; set; } - /// - /// A list of string values. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] - public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } - /// /// Optional. The string value of the metadata. /// @@ -41,15 +41,15 @@ public sealed partial class GroundingChunkCustomMetadata /// /// Initializes a new instance of the class. /// + /// + /// A list of string values. + /// /// /// Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used. /// /// /// The key of the metadata. /// - /// - /// A list of string values. - /// /// /// Optional. The string value of the metadata. /// @@ -57,14 +57,14 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( + global::Google.Gemini.GroundingChunkStringList? stringListValue, float? numericValue, string? key, - global::Google.Gemini.GroundingChunkStringList? stringListValue, string? stringValue) { + this.StringListValue = stringListValue; this.NumericValue = numericValue; this.Key = key; - this.StringListValue = stringListValue; this.StringValue = stringValue; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs index fc11141..5aa7af7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs @@ -9,22 +9,22 @@ namespace Google.Gemini public sealed partial class GroundingMetadata { /// - /// Google search entry point. + /// Metadata related to retrieval in the grounding flow. /// - [global::System.Text.Json.Serialization.JsonPropertyName("searchEntryPoint")] - public global::Google.Gemini.SearchEntryPoint? SearchEntryPoint { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] + public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } /// - /// Web search queries for the following-up web search. + /// Google search entry point. /// - [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] - public global::System.Collections.Generic.IList? WebSearchQueries { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("searchEntryPoint")] + public global::Google.Gemini.SearchEntryPoint? SearchEntryPoint { get; set; } /// - /// Image search queries used for grounding. + /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] - public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunks")] + public global::System.Collections.Generic.IList? GroundingChunks { get; set; } /// /// List of grounding support. @@ -33,22 +33,22 @@ public sealed partial class GroundingMetadata public global::System.Collections.Generic.IList? GroundingSupports { get; set; } /// - /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. + /// Web search queries for the following-up web search. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] - public string? GoogleMapsWidgetContextToken { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] + public global::System.Collections.Generic.IList? WebSearchQueries { get; set; } /// - /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. + /// Image search queries used for grounding. /// - [global::System.Text.Json.Serialization.JsonPropertyName("groundingChunks")] - public global::System.Collections.Generic.IList? GroundingChunks { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] + public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } /// - /// Metadata related to retrieval in the grounding flow. + /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] - public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] + public string? GoogleMapsWidgetContextToken { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -59,46 +59,46 @@ public sealed partial class GroundingMetadata /// /// Initializes a new instance of the class. /// + /// + /// Metadata related to retrieval in the grounding flow. + /// /// /// 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. + /// + /// + /// List of grounding support. + /// /// /// Web search queries for the following-up web search. /// /// /// Image search queries used for grounding. /// - /// - /// List of grounding support. - /// /// /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// - /// - /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. - /// - /// - /// Metadata related to retrieval in the grounding flow. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingMetadata( + global::Google.Gemini.RetrievalMetadata? retrievalMetadata, global::Google.Gemini.SearchEntryPoint? searchEntryPoint, + global::System.Collections.Generic.IList? groundingChunks, + global::System.Collections.Generic.IList? groundingSupports, global::System.Collections.Generic.IList? webSearchQueries, global::System.Collections.Generic.IList? imageSearchQueries, - global::System.Collections.Generic.IList? groundingSupports, - string? googleMapsWidgetContextToken, - global::System.Collections.Generic.IList? groundingChunks, - global::Google.Gemini.RetrievalMetadata? retrievalMetadata) + string? googleMapsWidgetContextToken) { + this.RetrievalMetadata = retrievalMetadata; this.SearchEntryPoint = searchEntryPoint; + this.GroundingChunks = groundingChunks; + this.GroundingSupports = groundingSupports; this.WebSearchQueries = webSearchQueries; this.ImageSearchQueries = imageSearchQueries; - this.GroundingSupports = groundingSupports; this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; - this.GroundingChunks = groundingChunks; - this.RetrievalMetadata = retrievalMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs index 29ecf6d..6d7ea67 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingPassageId.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class GroundingPassageId { /// - /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
+ /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("passageId")] - public string? PassageId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] + public int? PartIndex { get; set; } /// - /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
+ /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("partIndex")] - public int? PartIndex { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("passageId")] + public string? PassageId { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -31,23 +31,23 @@ public sealed partial class GroundingPassageId /// /// Initializes a new instance of the class. /// - /// - /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
- /// Included only in responses - /// /// /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
/// Included only in responses /// + /// + /// Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingPassageId( - string? passageId, - int? partIndex) + int? partIndex, + string? passageId) { - this.PassageId = passageId; this.PartIndex = partIndex; + this.PassageId = passageId; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs index 65cfa89..09b5305 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Hyperparameters.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Hyperparameters { - /// - /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("learningRate")] - public float? LearningRate { get; set; } - /// /// Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used. /// @@ -26,6 +20,12 @@ public sealed partial class Hyperparameters [global::System.Text.Json.Serialization.JsonPropertyName("batchSize")] public int? BatchSize { get; set; } + /// + /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("learningRate")] + public float? LearningRate { 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. /// @@ -41,15 +41,15 @@ public sealed partial class Hyperparameters /// /// Initializes a new instance of the class. /// - /// - /// Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples. - /// /// /// Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used. /// /// /// Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples. /// + /// + /// 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 number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used. /// @@ -57,14 +57,14 @@ public sealed partial class Hyperparameters [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Hyperparameters( - float? learningRate, float? learningRateMultiplier, int? batchSize, + float? learningRate, int? epochCount) { - this.LearningRate = learningRate; this.LearningRateMultiplier = learningRateMultiplier; this.BatchSize = batchSize; + this.LearningRate = learningRate; 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 b4add7f..c483dab 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class Image { /// - /// The title of the web page that the image is from. + /// The image asset URL. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageUri")] + public string? ImageUri { get; set; } /// /// The root domain of the web page that the image is from, e.g. "example.com". @@ -27,10 +27,10 @@ public sealed partial class Image public string? SourceUri { get; set; } /// - /// The image asset URL. + /// The title of the web page that the image is from. /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageUri")] - public string? ImageUri { 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 image asset URL. /// /// /// The root domain of the web page that the image is from, e.g. "example.com". @@ -50,22 +50,22 @@ public sealed partial class Image /// /// The web page URI for attribution. /// - /// - /// The image asset URL. + /// + /// 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? imageUri, string? domain, string? sourceUri, - string? imageUri) + string? title) { - this.Title = title; + this.ImageUri = imageUri; this.Domain = domain; this.SourceUri = sourceUri; - this.ImageUri = imageUri; + this.Title = title; } /// 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 99bdd63..53badde 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ImportFileRequest { - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] - public string? FileName { get; set; } - /// /// Custom metadata to be associated with the file. /// [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { get; set; } + /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -35,12 +35,12 @@ public sealed partial class ImportFileRequest /// /// Initializes a new instance of the class. /// - /// - /// Required. The name of the `File` to import. Example: `files/abc-123` - /// /// /// Custom metadata to be associated with the file. /// + /// + /// Required. The name of the `File` to import. Example: `files/abc-123` + /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -48,12 +48,12 @@ public sealed partial class ImportFileRequest [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( - string? fileName, global::System.Collections.Generic.IList? customMetadata, + string? fileName, global::Google.Gemini.ChunkingConfig? chunkingConfig) { - this.FileName = fileName; this.CustomMetadata = customMetadata; + this.FileName = fileName; this.ChunkingConfig = chunkingConfig; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs index c70f6aa..a3b4bba 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentRequest.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InlinedEmbedContentRequest { - /// - /// Request containing the `Content` for the model to embed. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("request")] - public global::Google.Gemini.EmbedContentRequest? Request { get; set; } - /// /// Optional. The metadata to be associated with the request. /// [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } + /// + /// Request containing the `Content` for the model to embed. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("request")] + public global::Google.Gemini.EmbedContentRequest? Request { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InlinedEmbedContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Request containing the `Content` for the model to embed. - /// /// /// Optional. The metadata to be associated with the request. /// + /// + /// Request containing the `Content` for the model to embed. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentRequest( - global::Google.Gemini.EmbedContentRequest? request, - object? metadata) + object? metadata, + global::Google.Gemini.EmbedContentRequest? request) { - this.Request = request; this.Metadata = metadata; + this.Request = request; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs index d67554e..4edfdb2 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 @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class InlinedResponse { - /// - /// Output only. The metadata associated with the request.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } - /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// @@ -27,6 +20,13 @@ public sealed partial class InlinedResponse [global::System.Text.Json.Serialization.JsonPropertyName("response")] public global::Google.Gemini.GenerateContentResponse? Response { get; set; } + /// + /// Output only. The metadata associated with the request.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,27 +36,27 @@ public sealed partial class InlinedResponse /// /// Initializes a new instance of the class. /// - /// - /// Output only. The metadata associated with the request.
- /// Included only in responses - /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`. /// + /// + /// Output only. The metadata associated with the request.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedResponse( - object? metadata, global::Google.Gemini.Status? error, - global::Google.Gemini.GenerateContentResponse? response) + global::Google.Gemini.GenerateContentResponse? response, + object? metadata) { - this.Metadata = metadata; this.Error = error; this.Response = response; + this.Metadata = metadata; } /// 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 0ba65b3..d5800e1 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. 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; } + /// + /// 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; } + /// /// 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. 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. /// + /// + /// Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Interval( - string? endTime, - string? startTime) + string? startTime, + string? endTime) { - this.EndTime = endTime; this.StartTime = startTime; + this.EndTime = endTime; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs index d8960e0..6b112b8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCachedContentsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListCachedContentsResponse { - /// - /// List of cached contents. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("cachedContents")] - public global::System.Collections.Generic.IList? CachedContents { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// List of cached contents. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("cachedContents")] + public global::System.Collections.Generic.IList? CachedContents { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListCachedContentsResponse /// /// Initializes a new instance of the class. /// - /// - /// List of cached contents. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages. /// + /// + /// List of cached contents. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCachedContentsResponse( - global::System.Collections.Generic.IList? cachedContents, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? cachedContents) { - this.CachedContents = cachedContents; this.NextPageToken = nextPageToken; + this.CachedContents = cachedContents; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs index 53b78dd..f5cb758 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 { - /// - /// 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; } + /// + /// 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 ListCorporaResponse /// /// 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 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCorporaResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? corpora) + global::System.Collections.Generic.IList? corpora, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.Corpora = corpora; + this.NextPageToken = nextPageToken; } /// 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 841ed88..b64b02e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFileSearchStoresResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListFileSearchStoresResponse { - /// - /// The returned rag_stores. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStores")] - public global::System.Collections.Generic.IList? FileSearchStores { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned rag_stores. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStores")] + public global::System.Collections.Generic.IList? FileSearchStores { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListFileSearchStoresResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned rag_stores. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned rag_stores. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFileSearchStoresResponse( - global::System.Collections.Generic.IList? fileSearchStores, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? fileSearchStores) { - this.FileSearchStores = fileSearchStores; this.NextPageToken = nextPageToken; + this.FileSearchStores = fileSearchStores; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs index 3136e0c..a2f8d43 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListOperationsResponse.g.cs @@ -14,18 +14,18 @@ public sealed partial class ListOperationsResponse [global::System.Text.Json.Serialization.JsonPropertyName("unreachable")] public global::System.Collections.Generic.IList? Unreachable { get; set; } - /// - /// The standard List next-page token. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] - public string? NextPageToken { get; set; } - /// /// A list of operations that matches the specified filter in the request. /// [global::System.Text.Json.Serialization.JsonPropertyName("operations")] public global::System.Collections.Generic.IList? Operations { get; set; } + /// + /// The standard List next-page token. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] + public string? NextPageToken { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ 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. /// - /// - /// The standard List next-page token. - /// /// /// A list of operations that matches the specified filter in the request. /// + /// + /// The standard List next-page token. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListOperationsResponse( global::System.Collections.Generic.IList? unreachable, - string? nextPageToken, - global::System.Collections.Generic.IList? operations) + global::System.Collections.Generic.IList? operations, + string? nextPageToken) { this.Unreachable = unreachable; - this.NextPageToken = nextPageToken; this.Operations = operations; + this.NextPageToken = nextPageToken; } /// 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 3b174b5..c530ffd 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 { - /// - /// 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; } + /// + /// 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 ListTunedModelsResponse /// /// Initializes a new instance of the class. /// - /// - /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. - /// /// /// The returned Models. /// + /// + /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListTunedModelsResponse( - string? nextPageToken, - global::System.Collections.Generic.IList? tunedModels) + global::System.Collections.Generic.IList? tunedModels, + string? nextPageToken) { - this.NextPageToken = nextPageToken; this.TunedModels = tunedModels; + this.NextPageToken = nextPageToken; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs index 5c9ddd1..0d7b895 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class LogprobsResultCandidate { - /// - /// The candidate’s token string value. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("token")] - public string? Token { get; set; } - /// /// The candidate's log probability. /// [global::System.Text.Json.Serialization.JsonPropertyName("logProbability")] public float? LogProbability { get; set; } + /// + /// The candidate’s token string value. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("token")] + public string? Token { get; set; } + /// /// The candidate’s token id value. /// @@ -35,12 +35,12 @@ public sealed partial class LogprobsResultCandidate /// /// Initializes a new instance of the class. /// - /// - /// The candidate’s token string value. - /// /// /// The candidate's log probability. /// + /// + /// The candidate’s token string value. + /// /// /// The candidate’s token id value. /// @@ -48,12 +48,12 @@ public sealed partial class LogprobsResultCandidate [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResultCandidate( - string? token, float? logProbability, + string? token, int? tokenId) { - this.Token = token; this.LogProbability = logProbability; + this.Token = token; this.TokenId = tokenId; } 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 d144af0..8bc2c87 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs @@ -9,10 +9,16 @@ namespace Google.Gemini public sealed partial class Model { /// - /// Maximum number of input tokens allowed for this model. + /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] - public int? InputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } /// /// 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. @@ -21,40 +27,40 @@ public sealed partial class Model public float? Temperature { get; set; } /// - /// A short description of the model. + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] + public string? BaseModelId { get; set; } /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// 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("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// Whether the model supports thinking. + /// A short description of the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] - public bool? Thinking { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// Maximum number of input tokens allowed for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("version")] - public string? Version { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] + public int? InputTokenLimit { get; set; } /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// Whether the model supports thinking. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] - public string? BaseModelId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] + public bool? Thinking { get; set; } /// - /// The maximum temperature this model can use. + /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] - public float? MaxTemperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] + public global::System.Collections.Generic.IList? SupportedGenerationMethods { 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. @@ -63,28 +69,22 @@ public sealed partial class Model 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; } - - /// - /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { get; set; } /// - /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] + public float? MaxTemperature { get; set; } /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. + /// Maximum number of output tokens available for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] - public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] + public int? OutputTokenLimit { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -95,76 +95,76 @@ public sealed partial class Model /// /// Initializes a new instance of the class. /// - /// - /// Maximum number of input tokens allowed for this model. + /// + /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` + /// + /// + /// 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. /// /// /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. /// + /// + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// + /// + /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. + /// /// /// A short description of the model. /// - /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// + /// Maximum number of input tokens allowed for this model. /// /// /// Whether the model supports thinking. /// + /// + /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. + /// + /// + /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. + /// /// /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - /// - /// 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. /// - /// - /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. - /// - /// - /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` - /// - /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( - int? inputTokenLimit, + string? name, + float? topP, float? temperature, + string? baseModelId, + int? topK, string? description, - float? topP, + int? inputTokenLimit, bool? thinking, + global::System.Collections.Generic.IList? supportedGenerationMethods, + string? displayName, string? version, - string? baseModelId, float? maxTemperature, - string? displayName, - int? outputTokenLimit, - int? topK, - string? name, - global::System.Collections.Generic.IList? supportedGenerationMethods) + int? outputTokenLimit) { - this.InputTokenLimit = inputTokenLimit; + this.Name = name; + this.TopP = topP; this.Temperature = temperature; + this.BaseModelId = baseModelId; + this.TopK = topK; this.Description = description; - this.TopP = topP; + this.InputTokenLimit = inputTokenLimit; this.Thinking = thinking; + this.SupportedGenerationMethods = supportedGenerationMethods; + this.DisplayName = displayName; this.Version = version; - this.BaseModelId = baseModelId; this.MaxTemperature = maxTemperature; - this.DisplayName = displayName; this.OutputTokenLimit = outputTokenLimit; - this.TopK = topK; - this.Name = name; - this.SupportedGenerationMethods = supportedGenerationMethods; } /// 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 fec1946..62f5027 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 @@ -20,18 +20,18 @@ public sealed partial class Operation [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// 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 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`. /// @@ -53,12 +53,12 @@ public sealed partial class Operation /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// + /// + /// The `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`. /// @@ -68,14 +68,14 @@ public sealed partial class Operation public Operation( object? metadata, string? name, - global::Google.Gemini.Status? error, bool? done, + global::Google.Gemini.Status? error, object? response) { this.Metadata = metadata; this.Name = name; - this.Error = error; this.Done = done; + this.Error = error; this.Response = response; } 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 0566406..fe278e0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs @@ -10,24 +10,18 @@ namespace Google.Gemini /// public sealed partial class Part { - /// - /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] - public object? PartMetadata { get; set; } - - /// - /// Inline text. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { 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. /// [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } + /// + /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] + public global::Google.Gemini.ToolCall? ToolCall { get; set; } + /// /// 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. /// @@ -40,6 +34,18 @@ public sealed partial class Part [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] public global::Google.Gemini.FileData? FileData { get; set; } + /// + /// Inline text. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } + + /// + /// Optional. Indicates if the part is thought from the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("thought")] + public bool? Thought { get; set; } + /// /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// @@ -53,22 +59,22 @@ public sealed partial class Part public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] - public global::Google.Gemini.ToolCall? ToolCall { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] + public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { 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`. + /// 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("toolResponse")] - public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("partMetadata")] + public object? PartMetadata { get; set; } /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// 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; } /// /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. @@ -78,16 +84,10 @@ public sealed partial class Part public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } /// - /// Optional. Indicates if the part is thought from the model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } - - /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// 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("thoughtSignature")] - public byte[]? ThoughtSignature { 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. /// - /// - /// 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. - /// /// /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. /// + /// + /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. + /// /// /// 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. /// + /// + /// Inline text. + /// + /// + /// Optional. Indicates if the part is thought from the model. + /// /// /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// /// /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// - /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// - /// - /// 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. /// - /// - /// Optional. Indicates if the part is thought from the model. + /// + /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. /// /// /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// + /// + /// 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( - object? partMetadata, - string? text, global::Google.Gemini.ExecutableCode? executableCode, + global::Google.Gemini.ToolCall? toolCall, global::Google.Gemini.FunctionResponse? functionResponse, global::Google.Gemini.FileData? fileData, + string? text, + bool? thought, global::Google.Gemini.Blob? inlineData, global::Google.Gemini.FunctionCall? functionCall, - global::Google.Gemini.ToolCall? toolCall, - global::Google.Gemini.ToolResponse? toolResponse, global::Google.Gemini.CodeExecutionResult? codeExecutionResult, - bool? thought, - byte[]? thoughtSignature) + object? partMetadata, + byte[]? thoughtSignature, + global::Google.Gemini.ToolResponse? toolResponse) { - this.PartMetadata = partMetadata; - this.Text = text; this.ExecutableCode = executableCode; + this.ToolCall = toolCall; this.FunctionResponse = functionResponse; this.FileData = fileData; + this.Text = text; + this.Thought = thought; this.InlineData = inlineData; this.FunctionCall = functionCall; - this.ToolCall = toolCall; - this.ToolResponse = toolResponse; this.CodeExecutionResult = codeExecutionResult; - this.Thought = thought; + this.PartMetadata = partMetadata; this.ThoughtSignature = thoughtSignature; + 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 9a41c01..eac5dd7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs @@ -15,6 +15,12 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] + public string? EmailAddress { get; set; } + /// /// Optional. Immutable. The type of the grantee. /// @@ -22,12 +28,6 @@ public sealed partial class Permission [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter))] public global::Google.Gemini.PermissionGranteeType? GranteeType { get; set; } - /// - /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("emailAddress")] - public string? EmailAddress { get; set; } - /// /// Required. The role granted by this permission. /// @@ -48,12 +48,12 @@ public sealed partial class Permission /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
/// Included only in responses /// - /// - /// Optional. Immutable. The 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. /// + /// + /// Optional. Immutable. The type of the grantee. + /// /// /// Required. The role granted by this permission. /// @@ -62,13 +62,13 @@ public sealed partial class Permission #endif public Permission( string? name, - global::Google.Gemini.PermissionGranteeType? granteeType, string? emailAddress, + global::Google.Gemini.PermissionGranteeType? granteeType, global::Google.Gemini.PermissionRole? role) { this.Name = name; - this.GranteeType = granteeType; this.EmailAddress = emailAddress; + this.GranteeType = granteeType; this.Role = role; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs index f7e526d..458cc7a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class PromptFeedback { - /// - /// Ratings for safety of the prompt. There is at most one rating per category. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } - /// /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. /// @@ -21,6 +15,12 @@ public sealed partial class PromptFeedback [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter))] public global::Google.Gemini.PromptFeedbackBlockReason? BlockReason { get; set; } + /// + /// Ratings for safety of the prompt. There is at most one rating per category. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class PromptFeedback /// /// Initializes a new instance of the class. /// - /// - /// Ratings for safety of the prompt. There is at most one rating per category. - /// /// /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. /// + /// + /// Ratings for safety of the prompt. There is at most one rating per category. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public PromptFeedback( - global::System.Collections.Generic.IList? safetyRatings, - global::Google.Gemini.PromptFeedbackBlockReason? blockReason) + global::Google.Gemini.PromptFeedbackBlockReason? blockReason, + global::System.Collections.Generic.IList? safetyRatings) { - this.SafetyRatings = safetyRatings; this.BlockReason = blockReason; + this.SafetyRatings = safetyRatings; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs index 72ed56f..0ff90ec 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 @@ -20,18 +20,18 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("title")] public string? Title { get; set; } - /// - /// Optional. Text of the chunk. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { 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` /// @@ -53,12 +53,12 @@ public sealed partial class RetrievedContext /// /// Optional. Title of the document. /// - /// - /// Optional. Text of the chunk. - /// /// /// Optional. User-provided metadata about the retrieved context. /// + /// + /// Optional. Text of the chunk. + /// /// /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` /// @@ -68,14 +68,14 @@ public sealed partial class RetrievedContext public RetrievedContext( string? uri, string? title, - string? text, global::System.Collections.Generic.IList? customMetadata, + string? text, string? fileSearchStore) { this.Uri = uri; this.Title = title; - this.Text = text; this.CustomMetadata = customMetadata; + this.Text = text; this.FileSearchStore = fileSearchStore; } 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 9317125..db35d02 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class ReviewSnippet { /// - /// Title of the review. + /// A link that corresponds to the user review on Google Maps. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] + public string? GoogleMapsUri { get; set; } /// /// The ID of the review snippet. @@ -21,10 +21,10 @@ public sealed partial class ReviewSnippet public string? ReviewId { get; set; } /// - /// A link that corresponds to the user review on Google Maps. + /// Title of the review. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsUri")] - public string? GoogleMapsUri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -35,26 +35,26 @@ public sealed partial class ReviewSnippet /// /// Initializes a new instance of the class. /// - /// - /// Title of the review. + /// + /// A link that corresponds to the user review on Google Maps. /// /// /// The ID of the review snippet. /// - /// - /// A link that corresponds to the user review on Google Maps. + /// + /// Title of the review. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ReviewSnippet( - string? title, + string? googleMapsUri, string? reviewId, - string? googleMapsUri) + string? title) { - this.Title = title; - this.ReviewId = reviewId; this.GoogleMapsUri = googleMapsUri; + this.ReviewId = reviewId; + this.Title = title; } /// 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 ee91d49..e676622 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs @@ -9,101 +9,101 @@ namespace Google.Gemini public sealed partial class Schema { /// - /// Optional. Required properties of Type.OBJECT. + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("type")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter))] + public global::Google.Gemini.SchemaType? Type { get; set; } /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// Optional. Required properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("format")] - public string? Format { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("required")] + public global::System.Collections.Generic.IList? Required { get; set; } /// - /// Optional. 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. 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("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] - public string? MinLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("items")] + public global::Google.Gemini.Schema? Items { get; set; } /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// Optional. Minimum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] - public double? Maximum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] + public string? MinProperties { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] - public double? Minimum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// - /// Optional. Indicates if the value may be null. + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] - public bool? Nullable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] + public global::System.Collections.Generic.IList? AnyOf { get; set; } /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("example")] - public object? Example { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] + public global::System.Collections.Generic.IList? PropertyOrdering { 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. Maximum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("items")] - public global::Google.Gemini.Schema? Items { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] + public string? MaxProperties { get; set; } /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// Optional. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] - public string? MaxItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// - /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("default")] - public object? Default { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { get; set; } /// - /// Optional. Maximum length of the Type.STRING + /// Optional. The title of the schema. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] - public string? MaxLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. + /// Optional. Example of the object. Will only populated when the object is the root. /// - [global::System.Text.Json.Serialization.JsonPropertyName("propertyOrdering")] - public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("example")] + public object? Example { get; set; } /// - /// Required. Data type. + /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - [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("minimum")] + public double? Minimum { get; set; } /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] - public string? MinProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("format")] + public string? Format { get; set; } /// - /// 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"]} /// - [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] - public string? Pattern { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { get; set; } /// /// Optional. Minimum number of the elements for Type.ARRAY. @@ -112,34 +112,34 @@ public sealed partial class Schema public string? MinItems { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] + public string? Pattern { get; set; } /// - /// Optional. Properties of Type.OBJECT. + /// Optional. Maximum length of the Type.STRING /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] + public string? MaxLength { get; set; } /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// Optional. Maximum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] - public string? MaxProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxItems")] + public string? MaxItems { get; set; } /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] - public global::System.Collections.Generic.IList? AnyOf { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] + public double? Maximum { get; set; } /// - /// Optional. The title of the schema. + /// Optional. Indicates if the value may be null. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] + public bool? Nullable { 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. /// + /// + /// Required. Data type. + /// /// /// Optional. Required properties of Type.OBJECT. /// - /// - /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. - /// - /// - /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} - /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER - /// - /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER - /// - /// - /// Optional. Indicates if the value may be null. - /// - /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// + /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. /// /// /// 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. Minimum number of the properties for Type.OBJECT. /// /// /// Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - /// - /// Optional. Maximum length of the Type.STRING + /// + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// /// /// 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. Maximum number of the properties for Type.OBJECT. /// - /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// + /// Optional. Properties of Type.OBJECT. /// - /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. + /// + /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING + /// + /// + /// Optional. The title of the schema. + /// + /// + /// Optional. Example of the object. Will only populated when the object is the root. + /// + /// + /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// + /// + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. + /// + /// + /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} /// /// /// Optional. Minimum 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. Properties of Type.OBJECT. + /// + /// Optional. Maximum length of the Type.STRING /// - /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// + /// Optional. Maximum number of the elements for Type.ARRAY. /// - /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - /// - /// Optional. The title of the schema. + /// + /// Optional. Indicates if the value may be null. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( + global::Google.Gemini.SchemaType? type, global::System.Collections.Generic.IList? required, - string? format, - global::System.Collections.Generic.IList? @enum, - string? minLength, - double? maximum, - double? minimum, - bool? nullable, - object? example, + string? description, global::Google.Gemini.Schema? items, - string? maxItems, + string? minProperties, object? @default, - string? maxLength, + global::System.Collections.Generic.IList? anyOf, global::System.Collections.Generic.IList? propertyOrdering, - global::Google.Gemini.SchemaType? type, - string? minProperties, - string? pattern, - string? minItems, - string? description, - global::System.Collections.Generic.Dictionary? properties, string? maxProperties, - global::System.Collections.Generic.IList? anyOf, - string? title) + global::System.Collections.Generic.Dictionary? properties, + string? minLength, + string? title, + object? example, + double? minimum, + string? format, + global::System.Collections.Generic.IList? @enum, + string? minItems, + string? pattern, + string? maxLength, + string? maxItems, + double? maximum, + bool? nullable) { + this.Type = type; this.Required = required; - this.Format = format; - this.Enum = @enum; - this.MinLength = minLength; - this.Maximum = maximum; - this.Minimum = minimum; - this.Nullable = nullable; - this.Example = example; + this.Description = description; this.Items = items; - this.MaxItems = maxItems; + this.MinProperties = minProperties; this.Default = @default; - this.MaxLength = maxLength; + this.AnyOf = anyOf; this.PropertyOrdering = propertyOrdering; - this.Type = type; - this.MinProperties = minProperties; - this.Pattern = pattern; - this.MinItems = minItems; - this.Description = description; - this.Properties = properties; this.MaxProperties = maxProperties; - this.AnyOf = anyOf; + this.Properties = properties; + this.MinLength = minLength; this.Title = title; + this.Example = example; + this.Minimum = minimum; + this.Format = format; + this.Enum = @enum; + this.MinItems = minItems; + this.Pattern = pattern; + this.MaxLength = maxLength; + this.MaxItems = maxItems; + this.Maximum = maximum; + this.Nullable = nullable; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs index c86475b..44773a7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SpeechConfig { - /// - /// Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] - public string? LanguageCode { get; set; } - /// /// The configuration for the multi-speaker setup. /// [global::System.Text.Json.Serialization.JsonPropertyName("multiSpeakerVoiceConfig")] public global::Google.Gemini.MultiSpeakerVoiceConfig? MultiSpeakerVoiceConfig { get; set; } + /// + /// Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] + public string? LanguageCode { get; set; } + /// /// The configuration for the voice to use. /// @@ -35,12 +35,12 @@ public sealed partial class SpeechConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`. - /// /// /// The configuration for the multi-speaker setup. /// + /// + /// Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`. + /// /// /// The configuration for the voice to use. /// @@ -48,12 +48,12 @@ public sealed partial class SpeechConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SpeechConfig( - string? languageCode, global::Google.Gemini.MultiSpeakerVoiceConfig? multiSpeakerVoiceConfig, + string? languageCode, global::Google.Gemini.VoiceConfig? voiceConfig) { - this.LanguageCode = languageCode; this.MultiSpeakerVoiceConfig = multiSpeakerVoiceConfig; + this.LanguageCode = languageCode; 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 7f09920..08b8748 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs @@ -14,18 +14,18 @@ public sealed partial class Status [global::System.Text.Json.Serialization.JsonPropertyName("code")] public int? Code { get; set; } - /// - /// A list of messages that carry the error details. There is a common set of message types for APIs to use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("details")] - public global::System.Collections.Generic.IList? Details { get; set; } - /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// [global::System.Text.Json.Serialization.JsonPropertyName("message")] public string? Message { get; set; } + /// + /// A list of messages that carry the error details. There is a common set of message types for APIs to use. + /// + [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 /// @@ -38,23 +38,23 @@ public sealed partial class Status /// /// 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. - /// /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// + /// + /// A list of messages that carry the error details. There is a common set of message types for APIs to use. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( int? code, - global::System.Collections.Generic.IList? details, - string? message) + string? message, + global::System.Collections.Generic.IList? details) { this.Code = code; - this.Details = details; 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 4ae8ae8..034d891 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,12 +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. /// @@ -26,6 +20,12 @@ public sealed partial class StreamableHttpTransport [global::System.Text.Json.Serialization.JsonPropertyName("url")] public string? Url { get; set; } + /// + /// Timeout for SSE read operations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] + public string? SseReadTimeout { get; set; } + /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// @@ -33,10 +33,10 @@ public sealed partial class StreamableHttpTransport public global::System.Collections.Generic.Dictionary? Headers { get; set; } /// - /// Timeout for SSE read operations. + /// HTTP timeout for regular operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] - public string? SseReadTimeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] + public string? Timeout { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -47,36 +47,36 @@ 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" /// + /// + /// Timeout for SSE read operations. + /// /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// - /// - /// Timeout for SSE read operations. + /// + /// HTTP timeout for regular operations. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public StreamableHttpTransport( - string? timeout, bool? terminateOnClose, string? url, + string? sseReadTimeout, global::System.Collections.Generic.Dictionary? headers, - string? sseReadTimeout) + string? timeout) { - this.Timeout = timeout; this.TerminateOnClose = terminateOnClose; this.Url = url; - this.Headers = headers; this.SseReadTimeout = sseReadTimeout; + this.Headers = headers; + this.Timeout = timeout; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs index 7319e77..5e903db 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class ThinkingConfig { - /// - /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingLevel")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter))] - public global::Google.Gemini.ThinkingConfigThinkingLevel? ThinkingLevel { get; set; } - /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// @@ -27,6 +20,13 @@ public sealed partial class ThinkingConfig [global::System.Text.Json.Serialization.JsonPropertyName("thinkingBudget")] public int? ThinkingBudget { get; set; } + /// + /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingLevel")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter))] + public global::Google.Gemini.ThinkingConfigThinkingLevel? ThinkingLevel { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ThinkingConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error. - /// /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// /// /// The number of thoughts tokens that the model should generate. /// + /// + /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ThinkingConfig( - global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel, bool? includeThoughts, - int? thinkingBudget) + int? thinkingBudget, + global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel) { - this.ThinkingLevel = thinkingLevel; this.IncludeThoughts = includeThoughts; this.ThinkingBudget = thinkingBudget; + this.ThinkingLevel = thinkingLevel; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs index eb1f4f8..2663513 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 @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Tool { - /// - /// Tool to support URL context retrieval. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] - public global::Google.Gemini.UrlContext? UrlContext { get; set; } - /// /// Tool to retrieve public web data for grounding, powered by Google. /// @@ -27,16 +21,10 @@ public sealed partial class Tool public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } /// - /// Optional. MCP Servers to connect to. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] - public global::System.Collections.Generic.IList? McpServers { get; set; } - - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] - public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] + public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } /// /// Computer Use tool type. @@ -44,6 +32,12 @@ public sealed partial class Tool [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } + /// + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] + public global::Google.Gemini.FileSearch? FileSearch { 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. /// @@ -51,16 +45,22 @@ public sealed partial class Tool public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } /// - /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] - public global::Google.Gemini.FileSearch? FileSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] + public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// Tool to support URL context retrieval. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] - public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContext")] + public global::Google.Gemini.UrlContext? UrlContext { get; set; } + + /// + /// Optional. MCP Servers to connect to. + /// + [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 support URL context retrieval. - /// /// /// Tool to retrieve public web data for grounding, powered by Google. /// /// /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. /// - /// - /// Optional. MCP Servers to connect to. - /// - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// /// /// Computer Use tool type. /// + /// + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// /// /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. /// - /// - /// 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. /// - /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// + /// Tool to support URL context retrieval. + /// + /// + /// Optional. MCP Servers to connect to. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Tool( - global::Google.Gemini.UrlContext? urlContext, global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, global::Google.Gemini.CodeExecution? codeExecution, - global::System.Collections.Generic.IList? mcpServers, - global::Google.Gemini.GoogleMaps? googleMaps, + global::Google.Gemini.GoogleSearch? googleSearch, global::Google.Gemini.ComputerUse? computerUse, - global::System.Collections.Generic.IList? functionDeclarations, global::Google.Gemini.FileSearch? fileSearch, - global::Google.Gemini.GoogleSearch? googleSearch) + global::System.Collections.Generic.IList? functionDeclarations, + global::Google.Gemini.GoogleMaps? googleMaps, + global::Google.Gemini.UrlContext? urlContext, + global::System.Collections.Generic.IList? mcpServers) { - this.UrlContext = urlContext; this.GoogleSearchRetrieval = googleSearchRetrieval; this.CodeExecution = codeExecution; - this.McpServers = mcpServers; - this.GoogleMaps = googleMaps; + this.GoogleSearch = googleSearch; this.ComputerUse = computerUse; - this.FunctionDeclarations = functionDeclarations; this.FileSearch = fileSearch; - this.GoogleSearch = googleSearch; + this.FunctionDeclarations = functionDeclarations; + this.GoogleMaps = googleMaps; + this.UrlContext = urlContext; + this.McpServers = mcpServers; } /// 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 c04b491..4fcef77 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,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class ToolCall { - /// - /// Required. The type of tool that was called. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter))] - public global::Google.Gemini.ToolCallToolType? ToolType { get; set; } - /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// @@ -27,6 +20,13 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } + /// + /// Required. The type of tool that was called. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("toolType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter))] + public global::Google.Gemini.ToolCallToolType? ToolType { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ToolCall /// /// Initializes a new instance of the class. /// - /// - /// Required. The type of tool that was called. - /// /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// /// /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. /// + /// + /// Required. The type of tool that was called. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolCall( - global::Google.Gemini.ToolCallToolType? toolType, object? args, - string? id) + string? id, + global::Google.Gemini.ToolCallToolType? toolType) { - this.ToolType = toolType; this.Args = args; this.Id = id; + this.ToolType = toolType; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolConfig.g.cs index ba65046..6357a63 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class ToolConfig { /// - /// Configuration for specifying function calling behavior. + /// Retrieval config. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionCallingConfig")] - public global::Google.Gemini.FunctionCallingConfig? FunctionCallingConfig { get; set; } + [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. @@ -21,10 +21,10 @@ public sealed partial class ToolConfig public bool? IncludeServerSideToolInvocations { get; set; } /// - /// Retrieval config. + /// Configuration for specifying function calling behavior. /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalConfig")] - public global::Google.Gemini.RetrievalConfig? RetrievalConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionCallingConfig")] + public global::Google.Gemini.FunctionCallingConfig? FunctionCallingConfig { 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. /// - /// - /// 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. /// - /// - /// Retrieval config. + /// + /// Configuration for specifying function calling behavior. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolConfig( - global::Google.Gemini.FunctionCallingConfig? functionCallingConfig, + global::Google.Gemini.RetrievalConfig? retrievalConfig, bool? includeServerSideToolInvocations, - global::Google.Gemini.RetrievalConfig? retrievalConfig) + global::Google.Gemini.FunctionCallingConfig? functionCallingConfig) { - this.FunctionCallingConfig = functionCallingConfig; - this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; this.RetrievalConfig = retrievalConfig; + this.IncludeServerSideToolInvocations = includeServerSideToolInvocations; + this.FunctionCallingConfig = functionCallingConfig; } /// 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 8a47cf0..21b7c61 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolResponse.g.cs @@ -14,12 +14,6 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } - /// - /// Optional. The tool response. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } - /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// @@ -27,6 +21,12 @@ public sealed partial class ToolResponse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter))] public global::Google.Gemini.ToolResponseToolType? ToolType { get; set; } + /// + /// Optional. The tool response. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ToolResponse /// /// Optional. The identifier of the tool call this response is for. /// - /// - /// Optional. The tool response. - /// /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// + /// + /// Optional. The tool response. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolResponse( string? id, - object? response, - global::Google.Gemini.ToolResponseToolType? toolType) + global::Google.Gemini.ToolResponseToolType? toolType, + object? response) { this.Id = id; - this.Response = response; this.ToolType = toolType; + this.Response = response; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs index eb5a146..b28242c 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,30 +9,34 @@ namespace Google.Gemini public sealed partial class TunedModel { /// - /// 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; } /// - /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// Optional. List of project numbers that have read access to the tuned model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] + public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } /// - /// Output only. The state of the tuned model.
- /// Included only in responses + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. ///
- [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("temperature")] + public float? Temperature { get; set; } /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// Tuned model as a source for training a new model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] - public string? BaseModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tunedModelSource")] + public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } + + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// /// Output only. The 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`
@@ -42,10 +46,10 @@ public sealed partial class TunedModel public string? Name { 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; } /// /// Tuning tasks that create tuned models. @@ -54,42 +58,38 @@ public sealed partial class TunedModel public global::Google.Gemini.TuningTask? TuningTask { get; set; } /// - /// Optional. A short description of this model. + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// 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 timestamp when this model was created.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("topP")] - public float? TopP { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Tuned model as a source for training a new model. + /// Optional. A short description of this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tunedModelSource")] - public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Output only. The timestamp when this model was updated.
+ /// Output only. The state of the tuned model.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { 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 created.
+ /// Output only. The timestamp when this model was updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } - - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("readerProjectNumbers")] - public global::System.Collections.Generic.IList? ReaderProjectNumbers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { 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. 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. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. List of project numbers that have read access to the tuned model. /// - /// - /// Output only. The state of the tuned model.
- /// Included only in responses + /// + /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// Tuned model as a source for training a new model. + /// + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
/// Included only in responses /// - /// - /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. + /// + /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// /// /// Tuning tasks that create tuned models. /// + /// + /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. + /// + /// + /// Output only. The timestamp when this model was created.
+ /// Included only in responses + /// /// /// Optional. A short description of this model. /// - /// - /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. - /// - /// - /// Tuned model as a source for training a new 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 /// - /// - /// Output only. The timestamp when this model was created.
- /// 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( - string? displayName, - int? topK, - global::Google.Gemini.TunedModelState? state, string? baseModel, - string? name, + global::System.Collections.Generic.IList? readerProjectNumbers, float? temperature, - global::Google.Gemini.TuningTask? tuningTask, - string? description, - float? topP, global::Google.Gemini.TunedModelSource? tunedModelSource, - string? updateTime, + int? topK, + string? name, + float? topP, + global::Google.Gemini.TuningTask? tuningTask, + string? displayName, string? createTime, - global::System.Collections.Generic.IList? readerProjectNumbers) + string? description, + global::Google.Gemini.TunedModelState? state, + string? updateTime) { - this.DisplayName = displayName; - this.TopK = topK; - this.State = state; this.BaseModel = baseModel; - this.Name = name; + this.ReaderProjectNumbers = readerProjectNumbers; this.Temperature = temperature; + this.TunedModelSource = tunedModelSource; + this.TopK = topK; + this.Name = name; + this.TopP = topP; this.TuningTask = tuningTask; + this.DisplayName = displayName; + this.CreateTime = createTime; this.Description = description; - this.TopP = topP; - this.TunedModelSource = tunedModelSource; + this.State = state; this.UpdateTime = updateTime; - this.CreateTime = createTime; - this.ReaderProjectNumbers = readerProjectNumbers; } /// 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 f35cdbc..dccf0ec 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 @@ -16,24 +16,18 @@ public sealed partial class TuningTask public string? StartTime { get; set; } /// - /// Output only. Metrics collected during tuning.
+ /// Output only. The timestamp when tuning this model completed.
/// Included only in responses ///
- [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 - /// - [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] - public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] + public string? CompleteTime { get; set; } /// - /// Output only. The timestamp when tuning this model completed.
+ /// Output only. Metrics collected during tuning.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] - public string? CompleteTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("snapshots")] + public global::System.Collections.Generic.IList? Snapshots { get; set; } /// /// Dataset for training or validation. @@ -41,6 +35,12 @@ public sealed partial class TuningTask [global::System.Text.Json.Serialization.JsonPropertyName("trainingData")] public global::Google.Gemini.Dataset? TrainingData { get; set; } + /// + /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + /// + [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] + public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -54,35 +54,35 @@ public sealed partial class TuningTask /// Output only. The timestamp when tuning this model started.
/// Included only in responses /// - /// - /// 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. The timestamp when tuning this model completed.
/// Included only in responses /// + /// + /// Output only. Metrics collected during tuning.
+ /// Included only in responses + /// /// /// Dataset for training or validation. /// + /// + /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( string? startTime, - global::System.Collections.Generic.IList? snapshots, - global::Google.Gemini.Hyperparameters? hyperparameters, string? completeTime, - global::Google.Gemini.Dataset? trainingData) + global::System.Collections.Generic.IList? snapshots, + global::Google.Gemini.Dataset? trainingData, + global::Google.Gemini.Hyperparameters? hyperparameters) { this.StartTime = startTime; - this.Snapshots = snapshots; - this.Hyperparameters = hyperparameters; this.CompleteTime = completeTime; + this.Snapshots = snapshots; this.TrainingData = trainingData; + this.Hyperparameters = hyperparameters; } /// 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 a80a207..7d2d27c 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,6 @@ namespace Google.Gemini /// public sealed partial class UploadToFileSearchStoreRequest { - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] - public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } - - /// - /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } - /// /// Optional. Display name of the created document. /// @@ -32,6 +20,18 @@ public sealed partial class UploadToFileSearchStoreRequest [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// + /// 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; } + + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// + [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] + public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class UploadToFileSearchStoreRequest /// /// Initializes a new instance of the class. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - /// - /// Optional. 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. /// + /// + /// Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content. + /// + /// + /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UploadToFileSearchStoreRequest( - global::Google.Gemini.ChunkingConfig? chunkingConfig, - string? mimeType, string? displayName, - global::System.Collections.Generic.IList? customMetadata) + global::System.Collections.Generic.IList? customMetadata, + string? mimeType, + global::Google.Gemini.ChunkingConfig? chunkingConfig) { - this.ChunkingConfig = chunkingConfig; - this.MimeType = mimeType; this.DisplayName = displayName; this.CustomMetadata = customMetadata; + this.MimeType = mimeType; + this.ChunkingConfig = chunkingConfig; } /// 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 d2fe110..961d09f 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 60f8622..f712857 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,12 +8,26 @@ namespace Google.Gemini /// public sealed partial class UsageMetadata { + /// + /// 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 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 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. Number of tokens of thoughts for thinking models.
/// Included only in responses @@ -27,20 +41,6 @@ public sealed partial class UsageMetadata [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] public int? PromptTokenCount { get; set; } - /// - /// Output only. Number of tokens present in tool-use prompt(s).
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] - public int? ToolUsePromptTokenCount { get; set; } - - /// - /// Output only. List of modalities that were processed for tool-use request inputs.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] - public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } - /// /// Total token count for the generation request (prompt + response candidates). /// @@ -48,31 +48,31 @@ public sealed partial class UsageMetadata public int? TotalTokenCount { get; set; } /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses + /// Total number of tokens across all the generated response candidates. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] - public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] + public int? CandidatesTokenCount { get; set; } /// - /// Output only. List of modalities that were returned in the response.
+ /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] - public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] + public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } /// - /// Total number of tokens across all the generated response candidates. + /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] - public int? CandidatesTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] + public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } /// - /// Output only. List of modalities of the cached content in the request input.
+ /// Output only. Number of tokens present in tool-use prompt(s).
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokenCount")] + public int? ToolUsePromptTokenCount { get; set; } /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -97,9 +97,17 @@ public sealed partial class UsageMetadata /// /// Initializes a new instance of the class. /// + /// + /// 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) /// + /// + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses + /// /// /// Output only. Number of tokens of thoughts for thinking models.
/// Included only in responses @@ -107,25 +115,9 @@ public sealed partial class UsageMetadata /// /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. /// - /// - /// Output only. Number of tokens present in tool-use prompt(s).
- /// Included only in responses - /// - /// - /// 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 + response candidates). /// - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - /// - /// - /// Output only. List of modalities that were returned in the response.
- /// Included only in responses - /// /// /// Total number of tokens across all the generated response candidates. /// @@ -133,6 +125,14 @@ public sealed partial class UsageMetadata /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses /// + /// + /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Included only in responses + /// + /// + /// Output only. Number of tokens present in tool-use prompt(s).
+ /// Included only in responses + /// /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
/// Included only in responses @@ -145,29 +145,29 @@ public sealed partial class UsageMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UsageMetadata( + global::System.Collections.Generic.IList? promptTokensDetails, int? cachedContentTokenCount, + global::System.Collections.Generic.IList? candidatesTokensDetails, int? thoughtsTokenCount, int? promptTokenCount, - int? toolUsePromptTokenCount, - global::System.Collections.Generic.IList? toolUsePromptTokensDetails, int? totalTokenCount, - global::System.Collections.Generic.IList? promptTokensDetails, - global::System.Collections.Generic.IList? candidatesTokensDetails, int? candidatesTokenCount, global::System.Collections.Generic.IList? cacheTokensDetails, + global::System.Collections.Generic.IList? toolUsePromptTokensDetails, + int? toolUsePromptTokenCount, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { + this.PromptTokensDetails = promptTokensDetails; this.CachedContentTokenCount = cachedContentTokenCount; + this.CandidatesTokensDetails = candidatesTokensDetails; this.ThoughtsTokenCount = thoughtsTokenCount; this.PromptTokenCount = promptTokenCount; - this.ToolUsePromptTokenCount = toolUsePromptTokenCount; - this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; this.TotalTokenCount = totalTokenCount; - this.PromptTokensDetails = promptTokensDetails; - this.CandidatesTokensDetails = candidatesTokensDetails; this.CandidatesTokenCount = candidatesTokenCount; this.CacheTokensDetails = cacheTokensDetails; + this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; + this.ToolUsePromptTokenCount = toolUsePromptTokenCount; 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 3719af7..96e74cc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs @@ -10,11 +10,11 @@ namespace Google.Gemini public sealed partial class VideoMetadata { /// - /// Optional. The start offset of the video. + /// Optional. The end offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public string? StartOffset { get; set; } + public string? EndOffset { get; set; } /// /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. @@ -24,11 +24,11 @@ public sealed partial class VideoMetadata public double? Fps { get; set; } /// - /// Optional. The end offset of the video. + /// Optional. The start offset of the video. /// - [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] + [global::System.Text.Json.Serialization.JsonPropertyName("startOffset")] [global::System.Obsolete("This property marked as deprecated.")] - public string? EndOffset { get; set; } + public string? StartOffset { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -39,26 +39,26 @@ public sealed partial class VideoMetadata /// /// Initializes a new instance of the class. /// - /// - /// Optional. The start offset of the video. + /// + /// Optional. The end offset of the video. /// /// /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. /// - /// - /// Optional. The end offset of the video. + /// + /// Optional. The start offset of the video. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public VideoMetadata( - string? startOffset, + string? endOffset, double? fps, - string? endOffset) + string? startOffset) { - this.StartOffset = startOffset; - this.Fps = fps; this.EndOffset = endOffset; + this.Fps = fps; + this.StartOffset = startOffset; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index 97b04cc..afbe94d 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,27 +11,15 @@ } ], "paths": { - "/dynamic/{dynamicId}:generateContent": { + "/files:register": { "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": "dynamicId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "schema": { - "type": "string", - "pattern": "^dynamic/[^/]+$" - } - } - ], + "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/GenerateContentRequest" + "$ref": "#/components/schemas/RegisterFilesRequest" } } } @@ -42,7 +30,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/RegisterFilesResponse" } } } @@ -50,43 +38,57 @@ } } }, - "/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", + "/files/{filesId}": { + "get": { + "description": "Gets the metadata for the given `File`.", + "operationId": "files.get", "parameters": [ { - "name": "dynamicId", + "name": "filesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The name of the `File` to get. Example: `files/abc-123`", "schema": { "type": "string", - "pattern": "^dynamic/[^/]+$" + "pattern": "^files/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/File" + } } } } - }, + } + }, + "delete": { + "description": "Deletes the `File`.", + "operationId": "files.delete", + "parameters": [ + { + "name": "filesId", + "in": "path", + "required": true, + "description": "Required. The name of the `File` to delete. Example: `files/abc-123`", + "schema": { + "type": "string", + "pattern": "^files/[^/]+$" + } + } + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -94,27 +96,26 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}": { - "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.delete", + "/files": { + "get": { + "description": "Lists the metadata for `File`s owned by the requesting project.", + "operationId": "files.list", "parameters": [ { - "name": "force", + "name": "pageSize", "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", "schema": { - "type": "boolean" + "type": "integer", + "format": "int32" } }, { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListFiles` call.", "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "type": "string" } } ], @@ -124,35 +125,32 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListFilesResponse" } } } } } }, - "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/[^/]+$" + "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/FileSearchStore" + "$ref": "#/components/schemas/CreateFileResponse" } } } @@ -160,16 +158,16 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { + "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", + "operationId": "media.uploadToFileSearchStore", "parameters": [ { "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", "pattern": "^fileSearchStores/[^/]+$" @@ -180,7 +178,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" } } } @@ -191,7 +189,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CustomLongRunningOperation" } } } @@ -199,15 +197,15 @@ } } }, - "/fileSearchStores": { + "/generatedFiles": { "get": { - "description": "Lists all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.list", + "description": "Lists the generated files owned by the requesting project.", + "operationId": "generatedFiles.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", + "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", "schema": { "type": "integer", "format": "int32" @@ -216,7 +214,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", + "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", "schema": { "type": "string" } @@ -228,32 +226,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" - } - } - } - } - } - }, - "post": { - "description": "Creates an empty `FileSearchStore`.", - "operationId": "fileSearchStores.create", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/FileSearchStore" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/ListGeneratedFilesResponse" } } } @@ -261,10 +234,10 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { + "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { "get": { "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "fileSearchStores.upload.operations.get", + "operationId": "generatedFiles.operations.get", "parameters": [ { "name": "operationsId", @@ -275,13 +248,13 @@ } }, { - "name": "fileSearchStoresId", + "name": "generatedFilesId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" } } ], @@ -299,46 +272,43 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents": { - "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + "/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": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "dynamicId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -346,81 +316,77 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.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": "fileSearchStoresId", + "name": "dynamicId", "in": "path", "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" - } - }, - { - "name": "force", - "in": "query", - "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", - "schema": { - "type": "boolean" - } - }, - { - "name": "documentsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", - "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "type": "string", + "pattern": "^dynamic/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.get", + } + }, + "/models/{modelsId}:embedContent": { + "post": { + "description": "Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding).", + "operationId": "models.embedContent", "parameters": [ { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "documentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/EmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -428,30 +394,31 @@ } } }, - "/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}:asyncBatchEmbedContent": { + "post": { + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "models.asyncBatchEmbedContent", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "fileSearchStoresId", + "name": "modelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", @@ -466,50 +433,66 @@ } } }, - "/files": { - "get": { - "description": "Lists the metadata for `File`s owned by the requesting project.", - "operationId": "files.list", + "/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": "pageSize", - "in": "query", - "description": "Optional. Maximum number of `File`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 100.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token from a previous `ListFiles` call.", + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchEmbedContentsRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFilesResponse" + "$ref": "#/components/schemas/BatchEmbedContentsResponse" } } } } } - }, + } + }, + "/models/{modelsId}:countTokens": { "post": { - "description": "Creates a `File`.", - "operationId": "media.upload", + "description": "Runs a model's tokenizer on input `Content` and returns the token count. Refer to the [tokens guide](https://ai.google.dev/gemini-api/docs/tokens) to learn more about tokens.", + "operationId": "models.countTokens", + "parameters": [ + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "schema": { + "type": "string", + "pattern": "^models/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileRequest" + "$ref": "#/components/schemas/CountTokensRequest" } } } @@ -520,7 +503,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CreateFileResponse" + "$ref": "#/components/schemas/CountTokensResponse" } } } @@ -528,47 +511,65 @@ } } }, - "/files/{filesId}": { - "delete": { - "description": "Deletes the `File`.", - "operationId": "files.delete", + "/models/{modelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "models.batchGenerateContent", "parameters": [ { - "name": "filesId", + "name": "modelsId", "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": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } } } - }, + } + }, + "/models": { "get": { - "description": "Gets the metadata for the given `File`.", - "operationId": "files.get", + "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", + "operationId": "models.list", "parameters": [ { - "name": "filesId", - "in": "path", - "required": true, - "description": "Required. The name of the `File` to get. Example: `files/abc-123`", + "name": "pageSize", + "in": "query", + "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", "schema": { - "type": "string", - "pattern": "^files/[^/]+$" + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", + "schema": { + "type": "string" } } ], @@ -578,7 +579,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/File" + "$ref": "#/components/schemas/ListModelsResponse" } } } @@ -586,26 +587,29 @@ } } }, - "/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" - } + "/models/{modelsId}": { + "get": { + "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", + "operationId": "models.get", + "parameters": [ + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "schema": { + "type": "string", + "pattern": "^models/[^/]+$" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/Model" } } } @@ -613,28 +617,19 @@ } } }, - "/cachedContents/{cachedContentsId}": { - "patch": { - "description": "Updates CachedContent resource (only expiration is updatable).", - "operationId": "cachedContents.patch", + "/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": "cachedContentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", - "schema": { - "type": "string", - "pattern": "^cachedContents/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "The list of fields to update.", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^models/[^/]+$" } } ], @@ -642,7 +637,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -653,53 +648,104 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "delete": { - "description": "Deletes CachedContent resource.", - "operationId": "cachedContents.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": "cachedContentsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, + } + }, + "/models/{modelsId}/operations": { "get": { - "description": "Reads CachedContent resource.", - "operationId": "cachedContents.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": "cachedContentsId", + "name": "filter", + "in": "query", + "description": "The standard list filter.", + "schema": { + "type": "string" + } + }, + { + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", + "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "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" } } ], @@ -709,7 +755,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/ListOperationsResponse" } } } @@ -717,15 +763,53 @@ } } }, - "/cachedContents": { + "/models/{modelsId}/operations/{operationsId}": { "get": { - "description": "Lists CachedContents.", - "operationId": "cachedContents.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": "operationsId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", + "schema": { + "type": "string", + "pattern": "^models/[^/]+/operations/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Operation" + } + } + } + } + } + } + }, + "/corpora": { + "get": { + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.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 `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" @@ -734,7 +818,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 `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" } @@ -746,7 +830,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" + "$ref": "#/components/schemas/ListCorporaResponse" } } } @@ -754,13 +838,13 @@ } }, "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", + "description": "Creates an empty `Corpus`.", + "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Corpus" } } } @@ -771,7 +855,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Corpus" } } } @@ -779,26 +863,19 @@ } } }, - "/models": { + "/corpora/{corporaId}": { "get": { - "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", - "operationId": "models.list", + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { - "type": "string" + "type": "string", + "pattern": "^corpora/[^/]+$" } } ], @@ -808,46 +885,43 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListModelsResponse" + "$ref": "#/components/schemas/Corpus" } } } } } - } - }, - "/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 a `Corpus`.", + "operationId": "corpora.delete", "parameters": [ { - "name": "modelsId", + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `Corpus` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Corpus` contains any `Document`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/CountTokensRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CountTokensResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -855,19 +929,36 @@ } } }, - "/models/{modelsId}": { + "/corpora/{corporaId}/permissions": { "get": { - "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", - "operationId": "models.get", + "description": "Lists permissions for the specific resource.", + "operationId": "corpora.permissions.list", "parameters": [ { - "name": "modelsId", + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -877,27 +968,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } } } - } - }, - "/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", + "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/[^/]+$" } } ], @@ -905,7 +994,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -916,7 +1005,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Permission" } } } @@ -924,58 +1013,72 @@ } } }, - "/models/{modelsId}:batchEmbedContents": { - "post": { - "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", - "operationId": "models.batchEmbedContents", + "/corpora/{corporaId}/permissions/{permissionsId}": { + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", "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/BatchEmbedContentsRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/models/{modelsId}:asyncBatchEmbedContent": { - "post": { - "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", - "operationId": "models.asyncBatchEmbedContent", + }, + "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" } } ], @@ -983,7 +1086,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -994,39 +1097,74 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/models/{modelsId}:batchGenerateContent": { - "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "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": "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/BatchGenerateContentRequest" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } } } } - }, + } + } + }, + "/corpora/{corporaId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "corpora.operations.get", + "parameters": [ + { + "name": "operationsId", + "in": "path", + "required": true, + "schema": { + "type": "string" + } + }, + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+/operations/[^/]+$" + } + } + ], "responses": { "200": { "description": "Successful response", @@ -1041,43 +1179,87 @@ } } }, - "/models/{modelsId}:streamGenerateContent": { + "/batches/{batchesId}:cancel": { "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "models.streamGenerateContent", + "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", + "operationId": "batches.cancel", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "The name of the operation resource to be cancelled.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } } } } - }, + } + } + }, + "/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", + "in": "path", + "required": true, + "description": "The name of the operation resource.", + "schema": { + "type": "string", + "pattern": "^batches/[^/]+$" + } + } + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } - }, - "text/event-stream": { + } + } + } + } + }, + "delete": { + "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.", + "operationId": "batches.delete", + "parameters": [ + { + "name": "batchesId", + "in": "path", + "required": true, + "description": "The name of the operation resource to be deleted.", + "schema": { + "type": "string", + "pattern": "^batches/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -1085,19 +1267,28 @@ } } }, - "/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", + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "modelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -1105,7 +1296,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -1116,7 +1307,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -1124,10 +1315,10 @@ } } }, - "/models/{modelsId}/operations": { + "/batches": { "get": { "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "models.operations.list", + "operationId": "batches.list", "parameters": [ { "name": "filter", @@ -1137,16 +1328,6 @@ "type": "string" } }, - { - "name": "modelsId", - "in": "path", - "required": true, - "description": "The name of the operation's parent resource.", - "schema": { - "type": "string", - "pattern": "^models/[^/]+$" - } - }, { "name": "pageSize", "in": "query", @@ -1187,53 +1368,36 @@ } } }, - "/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", + "/batches/{batchesId}:updateGenerateContentBatch": { + "patch": { + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", "parameters": [ { - "name": "operationsId", + "name": "batchesId", "in": "path", "required": true, + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { - "type": "string" - } + "type": "string", + "pattern": "^batches/[^/]+$" + } }, { - "name": "modelsId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", "schema": { "type": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "format": "google-fieldmask" } } ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" - } - } - } - } - } - } - }, - "/corpora": { - "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -1244,32 +1408,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentBatch" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}": { "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.list", + "description": "Gets information about a specific TunedModel.", + "operationId": "tunedModels.get", "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 model. Format: `tunedModels/my-model-id`", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1279,35 +1438,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" + "$ref": "#/components/schemas/TunedModel" } } } } } - } - }, - "/corpora/{corporaId}": { + }, "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + "description": "Deletes a tuned model.", + "operationId": "tunedModels.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", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1324,28 +1473,46 @@ } } }, - "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.get", + "patch": { + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", "parameters": [ { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "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": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TunedModel" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/TunedModel" } } } @@ -1353,30 +1520,29 @@ } } }, - "/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", + "/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": "operationsId", - "in": "path", - "required": true, + "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" } - }, - { - "name": "corporaId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", - "schema": { - "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" - } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TunedModel" + } + } + } + }, "responses": { "200": { "description": "Successful response", @@ -1389,17 +1555,23 @@ } } } - } - }, - "/corpora/{corporaId}/permissions": { + }, "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.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. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", + "description": "Optional. The maximum number of `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" @@ -1408,20 +1580,10 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", "schema": { "type": "string" } - }, - { - "name": "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": { @@ -1430,25 +1592,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}:generateContent": { "post": { - "description": "Create a permission to a specific resource.", - "operationId": "corpora.permissions.create", + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "tunedModels.generateContent", "parameters": [ { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1456,7 +1620,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1467,7 +1631,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1475,72 +1639,63 @@ } } }, - "/corpora/{corporaId}/permissions/{permissionsId}": { - "get": { - "description": "Gets information about a specific Permission.", - "operationId": "corpora.permissions.get", + "/tunedModels/{tunedModelsId}:streamGenerateContent": { + "post": { + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "tunedModels.streamGenerateContent", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, - "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 name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", + } + }, + "/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": "permissionsId", + "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" - } - }, - { - "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": "^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" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1548,7 +1703,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/TransferOwnershipRequest" } } } @@ -1559,43 +1714,46 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + } + }, + "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { + "post": { + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "tunedModels.asyncBatchEmbedContent", "parameters": [ { - "name": "permissionsId", - "in": "path", - "required": true, - "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 name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } @@ -1603,19 +1761,19 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { + "/tunedModels/{tunedModelsId}:batchGenerateContent": { "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 `GenerateContent` requests for batch processing.", + "operationId": "tunedModels.batchGenerateContent", "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/[^/]+$" } } ], @@ -1623,7 +1781,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -1634,7 +1792,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" + "$ref": "#/components/schemas/Operation" } } } @@ -1642,19 +1800,36 @@ } } }, - "/batches/{batchesId}:cancel": { - "post": { - "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", - "operationId": "batches.cancel", + "/tunedModels/{tunedModelsId}/permissions": { + "get": { + "description": "Lists permissions for the specific resource.", + "operationId": "tunedModels.permissions.list", "parameters": [ { - "name": "batchesId", + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListPermissions` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListPermissions` must match the call that provided the page token.", + "schema": { + "type": "string" + } + }, + { + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource to be cancelled.", + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1664,55 +1839,72 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } } } - } - }, - "/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", + }, + "post": { + "description": "Create a permission to a specific resource.", + "operationId": "tunedModels.permissions.create", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource to be deleted.", + "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Permission" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "batches.get", + "description": "Gets information about a specific Permission.", + "operationId": "tunedModels.permissions.get", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "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": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -1722,33 +1914,39 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/batches/{batchesId}:updateEmbedContentBatch": { + }, "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", + "description": "Updates the permission.", + "operationId": "tunedModels.permissions.patch", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "schema": { + "type": "string" + } + }, + { + "name": "permissionsId", + "in": "path", + "required": true, + "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } }, { "name": "updateMask", "in": "query", - "description": "Optional. The list of fields to update.", + "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", "schema": { "type": "string", "format": "google-fieldmask" @@ -1759,7 +1957,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Permission" } } } @@ -1770,55 +1968,43 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.delete", "parameters": [ { - "name": "batchesId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" + "type": "string" } }, { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", + "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", - "format": "google-fieldmask" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" + "$ref": "#/components/schemas/Empty" } } } @@ -1826,10 +2012,10 @@ } } }, - "/batches": { + "/tunedModels/{tunedModelsId}/operations": { "get": { "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "batches.list", + "operationId": "tunedModels.operations.list", "parameters": [ { "name": "filter", @@ -1839,6 +2025,16 @@ "type": "string" } }, + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "The name of the operation's parent resource.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + }, { "name": "pageSize", "in": "query", @@ -1879,43 +2075,37 @@ } } }, - "/tunedModels/{tunedModelsId}:streamGenerateContent": { - "post": { - "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", - "operationId": "tunedModels.streamGenerateContent", + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "tunedModels.operations.get", "parameters": [ { "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string" + } + }, + { + "name": "operationsId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^tunedModels/[^/]+/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" } } } @@ -1923,58 +2113,15 @@ } } }, - "/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", - "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" - } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/TunedModel" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" - } - } - } - } - } - }, + "/cachedContents": { "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.list", + "description": "Lists CachedContents.", + "operationId": "cachedContents.list", "parameters": [ - { - "name": "filter", - "in": "query", - "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", - "schema": { - "type": "string" - } - }, { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of cached contents to return. The service may return fewer than this value. If unspecified, some default (under maximum) number of items will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.", "schema": { "type": "integer", "format": "int32" @@ -1983,7 +2130,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `ListCachedContents` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListCachedContents` must match the call that provided the page token.", "schema": { "type": "string" } @@ -1995,35 +2142,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } } } - } - }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { + }, "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - } - ], + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2034,7 +2167,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2042,47 +2175,19 @@ } } }, - "/tunedModels/{tunedModelsId}": { - "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" - } - } - } - } - } - }, + "/cachedContents/{cachedContentsId}": { "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.get", + "description": "Reads CachedContent resource.", + "operationId": "cachedContents.get", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -2092,7 +2197,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2100,23 +2205,23 @@ } }, "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", + "description": "Updates CachedContent resource (only expiration is updatable).", + "operationId": "cachedContents.patch", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } }, { "name": "updateMask", "in": "query", - "description": "Optional. The list of fields to update.", + "description": "The list of fields to update.", "schema": { "type": "string", "format": "google-fieldmask" @@ -2127,7 +2232,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2138,35 +2243,51 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CachedContent" } } } } } - } - }, - "/tunedModels/{tunedModelsId}:generateContent": { - "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "tunedModels.generateContent", + }, + "delete": { + "description": "Deletes CachedContent resource.", + "operationId": "cachedContents.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } + } + } + } + } + } + }, + "/fileSearchStores": { + "post": { + "description": "Creates an empty `FileSearchStore`.", + "operationId": "fileSearchStores.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/FileSearchStore" } } } @@ -2177,46 +2298,42 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/FileSearchStore" } } } } } - } - }, - "/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": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" + "type": "integer", + "format": "int32" } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/TransferOwnershipRequest" - } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", + "schema": { + "type": "string" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipResponse" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } @@ -2224,129 +2341,55 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}": { + "get": { + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. The name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/FileSearchStore" } } } } } - } - }, - "/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", + }, + "delete": { + "description": "Deletes a `FileSearchStore`.", + "operationId": "fileSearchStores.delete", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "The name of the operation's parent resource.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "The standard list page token.", - "schema": { - "type": "string" - } - }, - { - "name": "returnPartialSuccess", + "name": "force", "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. 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" } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" - } - } - } - } - } - } - }, - "/tunedModels/{tunedModelsId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "tunedModels.operations.get", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } }, { - "name": "operationsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/operations/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2356,7 +2399,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } @@ -2364,19 +2407,19 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions": { + "/fileSearchStores/{fileSearchStoresId}:importFile": { "post": { - "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", + "description": "Imports a `File` from File Service to a `FileSearchStore`.", + "operationId": "fileSearchStores.importFile", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2384,7 +2427,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -2395,42 +2438,35 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.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": "fileSearchStores.upload.operations.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.", + "name": "operationsId", + "in": "path", + "required": true, "schema": { "type": "string" } }, { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } ], @@ -2440,7 +2476,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -2448,13 +2484,13 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { - "patch": { - "description": "Updates the permission.", - "operationId": "tunedModels.permissions.patch", + "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.operations.get", "parameters": [ { - "name": "tunedModelsId", + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -2462,67 +2498,60 @@ } }, { - "name": "permissionsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "description": "The name of the operation resource.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Permission" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "delete": { - "description": "Deletes the permission.", - "operationId": "tunedModels.permissions.delete", + } + }, + "/fileSearchStores/{fileSearchStoresId}/documents": { + "get": { + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", "parameters": [ { - "name": "tunedModelsId", - "in": "path", - "required": true, + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", "schema": { "type": "string" } }, { - "name": "permissionsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -2532,19 +2561,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListDocumentsResponse" } } } } } - }, + } + }, + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.get", "parameters": [ { - "name": "tunedModelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, "schema": { @@ -2552,13 +2583,13 @@ } }, { - "name": "permissionsId", + "name": "documentsId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], @@ -2568,34 +2599,41 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Document" } } } } } - } - }, - "/generatedFiles": { - "get": { - "description": "Lists the generated files owned by the requesting project.", - "operationId": "generatedFiles.list", + }, + "delete": { + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.delete", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", + "name": "fileSearchStoresId", + "in": "path", + "required": true, "schema": { - "type": "integer", - "format": "int32" + "type": "string" } }, { - "name": "pageToken", + "name": "force", "in": "query", - "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", + "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", "schema": { - "type": "string" + "type": "boolean" + } + }, + { + "name": "documentsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], @@ -2605,45 +2643,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListGeneratedFilesResponse" - } - } - } - } - } - } - }, - "/generatedFiles/{generatedFilesId}/operations/{operationsId}": { - "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "generatedFiles.operations.get", - "parameters": [ - { - "name": "operationsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "generatedFilesId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", - "schema": { - "type": "string", - "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } @@ -2654,309 +2654,171 @@ }, "components": { "schemas": { - "WebSearch": { - "properties": {}, - "description": "Standard web search for grounding and related configurations.", - "type": "object" - }, - "RetrievedContext": { - "description": "Chunk from context retrieved by the file search tool.", + "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", "properties": { - "uri": { - "description": "Optional. URI reference of the semantic retrieval document.", - "type": "string" - }, - "title": { - "description": "Optional. Title of the document.", - "type": "string" + "image": { + "$ref": "#/components/schemas/Image", + "description": "Optional. Grounding chunk from image search." }, - "text": { - "description": "Optional. Text of the chunk.", - "type": "string" + "maps": { + "description": "Optional. Grounding chunk from Google Maps.", + "$ref": "#/components/schemas/Maps" }, - "customMetadata": { - "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" - }, - "description": "Optional. User-provided metadata about the retrieved context.", - "type": "array" + "web": { + "description": "Grounding chunk from the web.", + "$ref": "#/components/schemas/Web" }, - "fileSearchStore": { - "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", - "type": "string" + "retrievedContext": { + "$ref": "#/components/schemas/RetrievedContext", + "description": "Optional. Grounding chunk from context retrieved by the file search tool." } } }, - "GroundingPassageId": { - "description": "Identifier for a part within a `GroundingPassage`.", + "ReviewSnippet": { "type": "object", "properties": { - "passageId": { - "readOnly": true, - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", + "googleMapsUri": { + "description": "A link that corresponds to the user review on Google Maps.", "type": "string" }, - "partIndex": { - "readOnly": true, + "reviewId": { + "description": "The ID of the review snippet.", + "type": "string" + }, + "title": { + "type": "string", + "description": "Title of the review." + } + }, + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps." + }, + "TransferOwnershipResponse": { + "type": "object", + "properties": {}, + "description": "Response from `TransferOwnership`." + }, + "WhiteSpaceConfig": { + "type": "object", + "properties": { + "maxTokensPerChunk": { + "format": "int32", + "description": "Maximum number of tokens per chunk. Tokens are defined as words for this chunking algorithm. Note: we are defining tokens as words split by whitespace as opposed to the output of a tokenizer. The context window of the latest gemini embedding model as of 2025-04-17 is currently 8192 tokens. We assume that the average word is 5 characters. Therefore, we set the upper limit to 2**9, which is 512 words, or 2560 tokens, assuming worst case a character per token. This is a conservative estimate meant to prevent context window overflow.", + "type": "integer" + }, + "maxOverlapTokens": { + "description": "Maximum number of overlapping tokens between two adjacent chunks.", "format": "int32", - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", "type": "integer" } - } + }, + "description": "Configuration for a white space chunking algorithm [white space delimited]." }, - "InlinedRequest": { - "description": "The request to be processed in the batch.", - "type": "object", + "VideoMetadata": { + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/GenerateContentRequest" + "endOffset": { + "type": "string", + "format": "google-duration", + "description": "Optional. The end offset of the video." }, - "metadata": { - "additionalProperties": { - "description": "Properties of the object." - }, - "description": "Optional. The metadata to be associated with the request.", - "type": "object" + "fps": { + "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" + }, + "startOffset": { + "type": "string", + "description": "Optional. The start offset of the video.", + "format": "google-duration" } - } + }, + "deprecated": true, + "type": "object" }, - "ListOperationsResponse": { - "description": "The response message for Operations.ListOperations.", + "GroundingChunkStringList": { "type": "object", "properties": { - "unreachable": { + "values": { + "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.", - "type": "array" - }, - "nextPageToken": { - "description": "The standard List next-page token.", - "type": "string" - }, - "operations": { - "items": { - "$ref": "#/components/schemas/Operation" - }, - "description": "A list of operations that matches the specified filter in the request.", - "type": "array" + "description": "The string values of the list." } - } + }, + "description": "A list of string values." }, - "SemanticRetrieverChunk": { + "UrlContext": { + "type": "object", + "properties": {}, + "description": "Tool to support URL context retrieval." + }, + "BatchStats": { + "type": "object", "properties": { - "source": { - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "failedRequestCount": { "type": "string", + "format": "int64", + "description": "Output only. The number of requests that failed to be processed.", "readOnly": true }, - "chunk": { - "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", - "type": "string", - "readOnly": true - } - }, - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", - "type": "object" - }, - "ToolResponse": { - "properties": { - "id": { - "description": "Optional. The identifier of the tool call this response is for.", + "successfulRequestCount": { + "format": "int64", + "description": "Output only. The number of requests that were successfully processed.", + "readOnly": true, "type": "string" }, - "response": { - "description": "Optional. The tool response.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "requestCount": { + "format": "int64", + "description": "Output only. The number of requests in the batch.", + "readOnly": true, + "type": "string" }, - "toolType": { - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ], - "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." - ], - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", + "pendingRequestCount": { + "format": "int64", + "description": "Output only. The number of requests that are still pending processing.", + "readOnly": true, "type": "string" } }, - "description": "The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`.", - "type": "object" + "description": "Stats about the batch." }, - "DynamicRetrievalConfig": { - "description": "Describes the options to customize dynamic retrieval.", + "GoogleSearch": { + "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "type": "object", "properties": { - "mode": { - "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" - ], - "description": "The mode of the predictor to be used in dynamic retrieval.", - "type": "string", - "x-enum-descriptions": [ - "Always trigger retrieval.", - "Run retrieval only when system decides it is necessary." - ] + "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" }, - "dynamicThreshold": { - "format": "float", - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", - "type": "number" + "searchTypes": { + "$ref": "#/components/schemas/SearchTypes", + "description": "Optional. The set of search types to enable. If not set, web search is enabled by default." } } }, - "GroundingMetadata": { - "description": "Metadata returned to client when grounding is enabled.", + "CachedContentUsageMetadata": { "type": "object", "properties": { - "searchEntryPoint": { - "description": "Optional. Google search entry for the following-up web searches.", - "$ref": "#/components/schemas/SearchEntryPoint" - }, - "webSearchQueries": { - "items": { - "type": "string" - }, - "description": "Web search queries for the following-up web search.", - "type": "array" - }, - "imageSearchQueries": { - "description": "Image search queries used for grounding.", - "type": "array", - "items": { - "type": "string" - } - }, - "groundingSupports": { - "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - }, - "description": "List of grounding support.", - "type": "array" - }, - "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" - }, - "groundingChunks": { - "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses.", - "type": "array", - "items": { - "$ref": "#/components/schemas/GroundingChunk" - } - }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" - } - } - }, - "FileSearch": { - "properties": { - "metadataFilter": { - "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", - "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" - } - }, - "topK": { - "format": "int32", - "description": "Optional. The number of semantic retrieval chunks to retrieve.", - "type": "integer" - } - }, - "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", - "type": "object" - }, - "FunctionCallingConfig": { - "properties": { - "mode": { - "enum": [ - "MODE_UNSPECIFIED", - "AUTO", - "ANY", - "NONE", - "VALIDATED" - ], - "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", - "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\"." - ] - }, - "allowedFunctionNames": { - "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names.", - "type": "array", - "items": { - "type": "string" - } - } - }, - "description": "Configuration for specifying function calling behavior.", - "type": "object" - }, - "InlinedEmbedContentRequest": { - "description": "The request to be processed in the batch.", - "type": "object", - "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/EmbedContentRequest" - }, - "metadata": { - "description": "Optional. The metadata to be associated with the request.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } - } - } - }, - "ChunkingConfig": { - "properties": { - "whiteSpaceConfig": { - "description": "White space chunking configuration.", - "$ref": "#/components/schemas/WhiteSpaceConfig" - } - }, - "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" - }, - "SafetyRating": { - "description": "Safety rating for a piece of content. The safety rating contains the category of harm and the harm probability level in that category for a piece of content. Content is classified for safety across a number of harm categories and the probability of the harm classification is included here.", - "type": "object", - "properties": { - "blocked": { - "description": "Was this content blocked because of this rating?", - "type": "boolean" + "totalTokenCount": { + "type": "integer", + "description": "Total number of tokens that the cached content consumes.", + "format": "int32" + } + }, + "description": "Metadata on the usage of the cached content." + }, + "SafetyRating": { + "type": "object", + "properties": { + "blocked": { + "type": "boolean", + "description": "Was this content blocked because of this rating?" }, "category": { + "type": "string", "enum": [ "HARM_CATEGORY_UNSPECIFIED", "HARM_CATEGORY_DEROGATORY", @@ -2971,20 +2833,7 @@ "HARM_CATEGORY_DANGEROUS_CONTENT", "HARM_CATEGORY_CIVIC_INTEGRITY" ], - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], + "description": "Required. The category for this rating.", "enumDeprecated": [ false, false, @@ -2999,8 +2848,20 @@ false, true ], - "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." + ] }, "probability": { "enum": [ @@ -3010,8 +2871,8 @@ "MEDIUM", "HIGH" ], - "description": "Required. The probability of harm for this content.", "type": "string", + "description": "Required. The probability of harm for this content.", "x-enum-descriptions": [ "Probability is unspecified.", "Content has a negligible chance of being unsafe.", @@ -3020,406 +2881,572 @@ "Content has a high chance of being unsafe." ] } - } + }, + "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." }, - "UrlContextMetadata": { - "description": "Metadata related to url context retrieval tool.", + "Operation": { + "description": "This resource represents a long-running operation that is the result of a network API call.", "type": "object", "properties": { - "urlMetadata": { - "description": "List of url context.", - "type": "array", - "items": { - "$ref": "#/components/schemas/UrlMetadata" + "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." } - } - } - }, - "File": { - "properties": { - "createTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. The timestamp of when the `File` was created.", - "type": "string" }, - "updateTime": { - "description": "Output only. The timestamp of when the `File` was last updated.", + "name": { "type": "string", - "readOnly": true, - "format": "google-datetime" + "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}`." }, - "mimeType": { - "description": "Output only. MIME type of the file.", - "type": "string", - "readOnly": true + "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" }, - "sizeBytes": { - "readOnly": true, - "format": "int64", - "description": "Output only. Size of the file in bytes.", - "type": "string" + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." }, - "source": { + "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" + } + } + }, + "RetrievalMetadata": { + "type": "object", + "properties": { + "googleSearchDynamicRetrievalScore": { + "type": "number", + "format": "float", + "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search." + } + }, + "description": "Metadata related to retrieval in the grounding flow." + }, + "SafetySetting": { + "type": "object", + "properties": { + "category": { + "type": "string", + "description": "Required. The category for this setting.", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ], "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." + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." ], - "description": "Source of the File.", - "type": "string", "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" + "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" ] }, - "videoMetadata": { - "description": "Output only. Metadata for a video.", - "$ref": "#/components/schemas/VideoFileMetadata", - "readOnly": true - }, - "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" - }, - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. Error status if File processing failed." - }, - "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": { - "description": "Output only. Processing state of the File.", + "threshold": { + "enum": [ + "HARM_BLOCK_THRESHOLD_UNSPECIFIED", + "BLOCK_LOW_AND_ABOVE", + "BLOCK_MEDIUM_AND_ABOVE", + "BLOCK_ONLY_HIGH", + "BLOCK_NONE", + "OFF" + ], "type": "string", - "readOnly": true, + "description": "Required. Controls the probability threshold at which harm is blocked.", "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "File is being processed and cannot be used for inference yet.", - "File is processed and available for inference.", - "File failed processing." - ], - "enum": [ - "STATE_UNSPECIFIED", - "PROCESSING", - "ACTIVE", - "FAILED" + "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." ] - }, - "sha256Hash": { - "description": "Output only. SHA-256 hash of the uploaded bytes.", - "type": "string", - "readOnly": true, - "format": "byte" - }, - "expirationTime": { - "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", - "type": "string", - "readOnly": true, - "format": "google-datetime" - }, - "downloadUri": { - "readOnly": true, - "description": "Output only. The download uri of the `File`.", - "type": "string" - }, - "uri": { - "readOnly": true, - "description": "Output only. The uri of the `File`.", - "type": "string" } }, - "description": "A file uploaded to the API. Next ID: 15", - "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." }, - "GoogleSearch": { + "GoogleAiGenerativelanguageV1betaSegment": { + "description": "Segment of the content.", + "type": "object", "properties": { - "searchTypes": { - "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", - "$ref": "#/components/schemas/SearchTypes" + "text": { + "type": "string", + "description": "The text corresponding to the segment from the response." }, - "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" + "partIndex": { + "type": "integer", + "format": "int32", + "description": "The index of a Part object within its parent Content object." + }, + "startIndex": { + "type": "integer", + "format": "int32", + "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero." + }, + "endIndex": { + "type": "integer", + "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", + "format": "int32" } - }, - "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "type": "object" + } }, - "TopCandidates": { - "description": "Candidates with top log probabilities at each decoding step.", + "RegisterFilesResponse": { + "description": "Response for `RegisterFiles`.", "type": "object", "properties": { - "candidates": { - "description": "Sorted by log probability in descending order.", + "files": { "type": "array", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - } + "$ref": "#/components/schemas/File" + }, + "description": "The registered files to be used when calling GenerateContent." } } }, - "Maps": { + "GroundingMetadata": { + "description": "Metadata returned to client when grounding is enabled.", + "type": "object", "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" - }, - "placeAnswerSources": { - "description": "Sources that provide answers about the features of a given place in Google Maps.", - "$ref": "#/components/schemas/PlaceAnswerSources" - }, - "uri": { - "description": "URI reference of the place.", - "type": "string" - }, - "title": { - "description": "Title of the place.", - "type": "string" + "retrievalMetadata": { + "$ref": "#/components/schemas/RetrievalMetadata", + "description": "Metadata related to retrieval in the grounding flow." }, - "text": { - "description": "Text description of the place answer.", - "type": "string" - } - }, - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", - "type": "object" - }, - "Tool": { - "properties": { - "urlContext": { - "description": "Optional. Tool to support URL context retrieval.", - "$ref": "#/components/schemas/UrlContext" + "searchEntryPoint": { + "$ref": "#/components/schemas/SearchEntryPoint", + "description": "Optional. Google search entry for the following-up web searches." }, - "googleSearchRetrieval": { - "description": "Optional. Retrieval tool that is powered by Google search.", - "$ref": "#/components/schemas/GoogleSearchRetrieval" + "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" }, - "codeExecution": { - "description": "Optional. Enables the model to execute code as part of generation.", - "$ref": "#/components/schemas/CodeExecution" + "groundingSupports": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" + }, + "description": "List of grounding support." }, - "mcpServers": { - "description": "Optional. MCP Servers to connect to.", + "webSearchQueries": { "type": "array", + "description": "Web search queries for the following-up web search.", "items": { - "$ref": "#/components/schemas/McpServer" + "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" - }, - "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" - }, - "functionDeclarations": { + "imageSearchQueries": { + "description": "Image search queries used for grounding.", "items": { - "$ref": "#/components/schemas/FunctionDeclaration" + "type": "string" }, - "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", "type": "array" }, - "fileSearch": { - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", - "$ref": "#/components/schemas/FileSearch" - }, - "googleSearch": { - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "$ref": "#/components/schemas/GoogleSearch" + "googleMapsWidgetContextToken": { + "type": "string", + "description": "Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled." } - }, - "description": "Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. Next ID: 16", - "type": "object" + } }, - "CitationMetadata": { + "UrlContextMetadata": { + "description": "Metadata related to url context retrieval tool.", + "type": "object", "properties": { - "citationSources": { - "description": "Citations to sources for a specific response.", + "urlMetadata": { "type": "array", "items": { - "$ref": "#/components/schemas/CitationSource" - } + "$ref": "#/components/schemas/UrlMetadata" + }, + "description": "List of url context." } - }, - "description": "A collection of source attributions for a piece of content.", - "type": "object" + } }, - "Permission": { - "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", + "GeneratedFile": { + "description": "A file generated on behalf of a user.", "type": "object", "properties": { "name": { - "readOnly": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", + "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", "type": "string" }, - "granteeType": { - "enum": [ - "GRANTEE_TYPE_UNSPECIFIED", - "USER", - "GROUP", - "EVERYONE" - ], - "description": "Optional. Immutable. The type of the grantee.", + "mimeType": { "type": "string", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "Represents a user. When set, you must provide email_address for the user.", - "Represents a group. When set, you must provide email_address for the group.", - "Represents access to everyone. No extra information is required." - ] - }, - "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" + "description": "MIME type of the generatedFile." }, - "role": { - "description": "Required. The role granted by this permission.", - "type": "string", + "state": { + "enum": [ + "STATE_UNSPECIFIED", + "GENERATING", + "GENERATED", + "FAILED" + ], + "description": "Output only. The state of the GeneratedFile.", "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." + "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": [ - "ROLE_UNSPECIFIED", - "OWNER", - "WRITER", - "READER" - ] + "type": "string", + "readOnly": true + }, + "error": { + "$ref": "#/components/schemas/Status", + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state." } } }, - "AsyncBatchEmbedContentRequest": { + "Blob": { + "type": "object", "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/EmbedContentBatch" - } - }, - "description": "Request for an `AsyncBatchEmbedContent` operation.", - "type": "object" - }, - "CodeExecutionResult": { + "mimeType": { + "description": "The IANA standard MIME type of the source data. Examples: - image/png - image/jpeg If an unsupported MIME type is provided, an error will be returned. For a complete list of supported types, see [Supported file formats](https://ai.google.dev/gemini-api/docs/prompting_with_media#supported_file_formats).", + "type": "string" + }, + "data": { + "type": "string", + "format": "byte", + "description": "Raw bytes for media formats." + } + }, + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field." + }, + "ChunkingConfig": { + "type": "object", "properties": { - "outcome": { + "whiteSpaceConfig": { + "$ref": "#/components/schemas/WhiteSpaceConfig", + "description": "White space chunking configuration." + } + }, + "description": "Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto" + }, + "Candidate": { + "type": "object", + "properties": { + "groundingAttributions": { + "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, + "type": "array" + }, + "content": { + "$ref": "#/components/schemas/Content", + "description": "Output only. Generated content returned from the model.", + "readOnly": true + }, + "tokenCount": { + "format": "int32", + "description": "Output only. Token count for this candidate.", + "readOnly": true, + "type": "integer" + }, + "urlContextMetadata": { + "$ref": "#/components/schemas/UrlContextMetadata", + "description": "Output only. Metadata related to url context retrieval tool.", + "readOnly": true + }, + "groundingMetadata": { + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", + "readOnly": true, + "$ref": "#/components/schemas/GroundingMetadata" + }, + "avgLogprobs": { + "description": "Output only. Average log probability score of the candidate.", + "readOnly": true, + "format": "double", + "type": "number" + }, + "safetyRatings": { + "description": "List of ratings for the safety of a response candidate. There is at most one rating per category.", + "items": { + "$ref": "#/components/schemas/SafetyRating" + }, + "type": "array" + }, + "finishReason": { "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" + "FINISH_REASON_UNSPECIFIED", + "STOP", + "MAX_TOKENS", + "SAFETY", + "RECITATION", + "LANGUAGE", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "SPII", + "MALFORMED_FUNCTION_CALL", + "IMAGE_SAFETY", + "IMAGE_PROHIBITED_CONTENT", + "IMAGE_OTHER", + "NO_IMAGE", + "IMAGE_RECITATION", + "UNEXPECTED_TOOL_CALL", + "TOO_MANY_TOOL_CALLS", + "MISSING_THOUGHT_SIGNATURE", + "MALFORMED_RESPONSE" ], + "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", "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." + "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." ], - "description": "Required. Outcome of the code execution.", - "type": "string" + "type": "string", + "readOnly": true }, - "id": { - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", - "type": "string" + "index": { + "description": "Output only. Index of the candidate in the list of response candidates.", + "readOnly": true, + "format": "int32", + "type": "integer" }, - "output": { - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", + "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" + }, + "logprobsResult": { + "$ref": "#/components/schemas/LogprobsResult", + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "readOnly": true + }, + "citationMetadata": { + "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data.", + "readOnly": true, + "$ref": "#/components/schemas/CitationMetadata" } }, - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", - "type": "object" + "description": "A response candidate generated from the model." }, - "CitationSource": { + "RetrievedContext": { + "type": "object", "properties": { - "startIndex": { - "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes.", - "type": "integer", - "format": "int32" - }, "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", - "type": "string" + "type": "string", + "description": "Optional. URI reference of the semantic retrieval document." }, - "license": { - "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", + "title": { + "description": "Optional. Title of the document.", "type": "string" }, - "endIndex": { - "format": "int32", - "description": "Optional. End of the attributed segment, exclusive.", - "type": "integer" + "customMetadata": { + "description": "Optional. User-provided metadata about the retrieved context.", + "items": { + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" + }, + "type": "array" + }, + "text": { + "type": "string", + "description": "Optional. Text of the chunk." + }, + "fileSearchStore": { + "type": "string", + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`" } }, - "description": "A citation to a source for a portion of a specific response.", - "type": "object" + "description": "Chunk from context retrieved by the file search tool." }, - "VideoFileMetadata": { + "CodeExecutionResult": { + "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", + "type": "object", "properties": { - "videoDuration": { - "format": "google-duration", - "description": "Duration of the video.", + "output": { + "type": "string", + "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise." + }, + "id": { + "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", + "type": "string" + }, + "outcome": { + "description": "Required. Outcome of the code execution.", + "x-enum-descriptions": [ + "Unspecified status. This value should not be used.", + "Code execution completed successfully. `output` contains the stdout, if any.", + "Code execution failed. `output` contains the stderr and stdout, if any.", + "Code execution ran for too long, and was cancelled. There may or may not be a partial `output` present." + ], + "enum": [ + "OUTCOME_UNSPECIFIED", + "OUTCOME_OK", + "OUTCOME_FAILED", + "OUTCOME_DEADLINE_EXCEEDED" + ], "type": "string" } - }, - "description": "Metadata for a video `File`.", - "type": "object" + } }, - "UrlMetadata": { + "FunctionDeclaration": { + "type": "object", "properties": { - "retrievedUrl": { - "description": "Retrieved url by the tool.", + "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" }, - "urlRetrievalStatus": { + "description": { + "type": "string", + "description": "Required. A brief description of the function." + }, + "parametersJsonSchema": { + "description": "Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { \"type\": \"object\", \"properties\": { \"name\": { \"type\": \"string\" }, \"age\": { \"type\": \"integer\" } }, \"additionalProperties\": false, \"required\": [\"name\", \"age\"], \"propertyOrdering\": [\"name\", \"age\"] } ``` This field is mutually exclusive with `parameters`." + }, + "response": { + "description": "Optional. Describes the output from this function in JSON Schema format. Reflects the Open API 3.03 Response Object. The Schema defines the type used for the response value of the function.", + "$ref": "#/components/schemas/Schema" + }, + "responseJsonSchema": { + "description": "Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`." + }, + "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" + }, + "behavior": { "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." + "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": "Status of the url retrieval.", + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", "type": "string", "enum": [ - "URL_RETRIEVAL_STATUS_UNSPECIFIED", - "URL_RETRIEVAL_STATUS_SUCCESS", - "URL_RETRIEVAL_STATUS_ERROR", - "URL_RETRIEVAL_STATUS_PAYWALL", - "URL_RETRIEVAL_STATUS_UNSAFE" + "UNSPECIFIED", + "BLOCKING", + "NON_BLOCKING" ] } }, - "description": "Context of the a single url retrieval.", - "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." }, - "EmbedContentRequest": { + "GroundingChunkCustomMetadata": { + "description": "User provided metadata about the GroundingFact.", + "type": "object", "properties": { - "outputDimensionality": { - "format": "int32", - "description": "Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`).", - "type": "integer" - }, - "title": { - "description": "Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval.", - "type": "string" + "stringListValue": { + "description": "Optional. A list of string values for the metadata.", + "$ref": "#/components/schemas/GroundingChunkStringList" }, - "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}`", + "numericValue": { + "type": "number", + "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", + "format": "float" + }, + "key": { + "type": "string", + "description": "The key of the metadata." + }, + "stringValue": { + "type": "string", + "description": "Optional. The string value of the metadata." + } + } + }, + "CreateFileRequest": { + "description": "Request for `CreateFile`.", + "type": "object", + "properties": { + "file": { + "description": "Optional. Metadata for the file to create.", + "$ref": "#/components/schemas/File" + } + } + }, + "FunctionResponsePart": { + "type": "object", + "properties": { + "inlineData": { + "$ref": "#/components/schemas/FunctionResponseBlob", + "description": "Inline media bytes." + } + }, + "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." + }, + "UploadToFileSearchStoreRequest": { + "type": "object", + "properties": { + "displayName": { + "description": "Optional. Display name of the created document.", "type": "string" }, - "content": { - "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", - "$ref": "#/components/schemas/Content" + "customMetadata": { + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Custom metadata to be associated with the data.", + "type": "array" + }, + "mimeType": { + "type": "string", + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content." }, + "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" + } + }, + "description": "Request for `UploadToFileSearchStore`." + }, + "EmbedContentRequest": { + "description": "Request containing the `Content` for the model to embed.", + "type": "object", + "properties": { "taskType": { "x-enum-descriptions": [ "Unset value, which will default to one of the other enum values.", @@ -3445,590 +3472,427 @@ "FACT_VERIFICATION", "CODE_RETRIEVAL_QUERY" ] - } - }, - "description": "Request containing the `Content` for the model to embed.", - "type": "object" - }, - "StringList": { - "description": "User provided string values assigned to a single metadata key.", - "type": "object", - "properties": { - "values": { - "items": { - "type": "string" - }, - "description": "The string values of the metadata to store.", - "type": "array" + }, + "title": { + "type": "string", + "description": "Optional. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval." + }, + "outputDimensionality": { + "format": "int32", + "description": "Optional. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`).", + "type": "integer" + }, + "content": { + "$ref": "#/components/schemas/Content", + "description": "Required. The content to embed. Only the `parts.text` fields will be counted." + }, + "model": { + "type": "string", + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`" } } }, - "ImageSearch": { - "properties": {}, - "description": "Image search for grounding and related configurations.", - "type": "object" - }, - "CountTokensResponse": { - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", + "ListOperationsResponse": { + "description": "The response message for Operations.ListOperations.", "type": "object", "properties": { - "cacheTokensDetails": { + "unreachable": { + "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "string" }, - "description": "Output only. List of modalities that were processed in the cached content.", - "type": "array", - "readOnly": true - }, - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content).", - "type": "integer", - "format": "int32" + "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." }, - "promptTokensDetails": { + "operations": { + "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/Operation" }, - "description": "Output only. List of modalities that were processed in the request input.", - "type": "array", - "readOnly": true + "description": "A list of operations that matches the specified filter in the request." }, - "totalTokens": { - "format": "int32", - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", - "type": "integer" + "nextPageToken": { + "type": "string", + "description": "The standard List next-page token." } } }, - "VideoMetadata": { + "VideoFileMetadata": { + "description": "Metadata for a video `File`.", + "type": "object", "properties": { - "startOffset": { + "videoDuration": { "format": "google-duration", - "description": "Optional. The start offset of the video.", + "description": "Duration of the video.", "type": "string" - }, - "fps": { - "format": "double", - "description": "Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0].", - "type": "number" - }, - "endOffset": { - "description": "Optional. The end offset of the video.", - "type": "string", - "format": "google-duration" } - }, - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", - "type": "object", - "deprecated": true + } }, - "BatchEmbedContentsRequest": { - "description": "Batch request to get embeddings from the model for a list of prompts.", + "InlinedEmbedContentResponse": { "type": "object", "properties": { - "requests": { - "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`.", - "type": "array", - "items": { - "$ref": "#/components/schemas/EmbedContentRequest" - } + "error": { + "$ref": "#/components/schemas/Status", + "description": "Output only. The error encountered while processing the request.", + "readOnly": true + }, + "response": { + "$ref": "#/components/schemas/EmbedContentResponse", + "description": "Output only. The response to the request.", + "readOnly": true + }, + "metadata": { + "description": "Output only. The metadata associated with the request.", + "readOnly": true, + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" } - } + }, + "description": "The response to a single request in the batch." }, - "EmbedContentBatchStats": { - "description": "Stats about the batch.", + "ExecutableCode": { "type": "object", "properties": { - "requestCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of requests in the batch.", - "type": "string" - }, - "failedRequestCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of requests that failed to be processed.", - "type": "string" + "code": { + "type": "string", + "description": "Required. The code to be executed." }, - "pendingRequestCount": { - "description": "Output only. The number of requests that are still pending processing.", + "id": { "type": "string", - "readOnly": true, - "format": "int64" + "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." }, - "successfulRequestCount": { - "description": "Output only. The number of requests that were successfully processed.", + "language": { + "enum": [ + "LANGUAGE_UNSPECIFIED", + "PYTHON" + ], "type": "string", - "readOnly": true, - "format": "int64" + "description": "Required. Programming language of the `code`.", + "x-enum-descriptions": [ + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." + ] } - } + }, + "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." }, - "CachedContentUsageMetadata": { - "description": "Metadata on the usage of the cached content.", + "CitationSource": { "type": "object", "properties": { - "totalTokenCount": { - "description": "Total number of tokens that the cached content consumes.", + "license": { + "type": "string", + "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations." + }, + "startIndex": { "type": "integer", - "format": "int32" - } - } - }, - "ListDocumentsResponse": { - "properties": { - "documents": { - "description": "The returned `Document`s.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Document" - } + "format": "int32", + "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes." }, - "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.", + "endIndex": { + "description": "Optional. End of the attributed segment, exclusive.", + "format": "int32", + "type": "integer" + }, + "uri": { + "description": "Optional. URI that is attributed as a source for a portion of the text.", "type": "string" } }, - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", - "type": "object" + "description": "A citation to a source for a portion of a specific response." }, - "GenerateContentBatchOutput": { - "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", + "UsageMetadata": { "type": "object", "properties": { - "responsesFile": { + "promptTokensDetails": { + "type": "array", + "description": "Output only. List of modalities that were processed in the request input.", "readOnly": true, - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", - "type": "string" + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } }, - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", - "$ref": "#/components/schemas/InlinedResponses", - "readOnly": true - } - } - }, - "GoogleSearchRetrieval": { - "properties": { - "dynamicRetrievalConfig": { - "description": "Specifies the dynamic retrieval configuration for the given source.", - "$ref": "#/components/schemas/DynamicRetrievalConfig" - } - }, - "description": "Tool to retrieve public web data for grounding, powered by Google.", - "type": "object" - }, - "InlinedRequests": { - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", - "type": "object", - "properties": { - "requests": { - "description": "Required. The requests to be processed in the batch.", - "type": "array", - "items": { - "$ref": "#/components/schemas/InlinedRequest" - } - } - } - }, - "BatchEmbedContentsResponse": { - "description": "The response to a `BatchEmbedContentsRequest`.", - "type": "object", - "properties": { - "embeddings": { - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", - "type": "array", + "cachedContentTokenCount": { + "type": "integer", + "description": "Number of tokens in the cached part of the prompt (the cached content)", + "format": "int32" + }, + "candidatesTokensDetails": { + "description": "Output only. List of modalities that were returned in the response.", + "readOnly": true, "items": { - "$ref": "#/components/schemas/ContentEmbedding" + "$ref": "#/components/schemas/ModalityTokenCount" }, - "readOnly": true + "type": "array" }, - "usageMetadata": { - "description": "Output only. The usage metadata for the request.", - "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata" - } - } - }, - "McpServer": { - "properties": { - "streamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses.", - "$ref": "#/components/schemas/StreamableHttpTransport" + "thoughtsTokenCount": { + "type": "integer", + "format": "int32", + "description": "Output only. Number of tokens of thoughts for thinking models.", + "readOnly": true }, - "name": { - "description": "The name of the MCPServer.", - "type": "string" - } - }, - "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 5", - "type": "object" - }, - "GoogleAiGenerativelanguageV1betaSegment": { - "description": "Segment of the content.", - "type": "object", - "properties": { - "endIndex": { + "promptTokenCount": { "format": "int32", - "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", + "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content.", "type": "integer" }, - "text": { - "description": "The text corresponding to the segment from the response.", - "type": "string" - }, - "partIndex": { + "totalTokenCount": { + "type": "integer", "format": "int32", - "description": "The index of a Part object within its parent Content object.", - "type": "integer" + "description": "Total token count for the generation request (prompt + response candidates)." }, - "startIndex": { + "candidatesTokenCount": { + "type": "integer", "format": "int32", - "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", - "type": "integer" - } - } - }, - "ContentEmbedding": { - "description": "A list of floats representing an embedding.", - "type": "object", - "properties": { - "values": { - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "description": "Total number of tokens across all the generated response candidates." + }, + "cacheTokensDetails": { "type": "array", "items": { - "type": "number", - "format": "float" - } + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities of the cached content in the request input.", + "readOnly": true }, - "shape": { - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", + "toolUsePromptTokensDetails": { + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed for tool-use request inputs.", + "readOnly": true, + "type": "array" + }, + "toolUsePromptTokenCount": { + "type": "integer", + "format": "int32", + "description": "Output only. Number of tokens present in tool-use prompt(s).", + "readOnly": true + }, + "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": { - "format": "int32", - "type": "integer" + "$ref": "#/components/schemas/ModalityTokenCount" } } - } + }, + "description": "Metadata on the generation request's token usage." }, - "ComputerUse": { - "description": "Computer Use tool type.", + "TransferOwnershipRequest": { + "description": "Request to transfer the ownership of the tuned model.", "type": "object", "properties": { - "environment": { - "enum": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER" - ], - "x-enum-descriptions": [ - "Defaults to browser.", - "Operates in a web browser." - ], - "description": "Required. The environment being operated.", + "emailAddress": { + "description": "Required. The email address of the user to whom the tuned model is being transferred to.", "type": "string" - }, - "excludedPredefinedFunctions": { - "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions.", - "type": "array", - "items": { - "type": "string" - } } } }, - "ListGeneratedFilesResponse": { - "description": "Response for `ListGeneratedFiles`.", + "EmbedContentResponse": { "type": "object", "properties": { - "generatedFiles": { - "items": { - "$ref": "#/components/schemas/GeneratedFile" - }, - "description": "The list of `GeneratedFile`s.", - "type": "array" + "embedding": { + "description": "Output only. The embedding generated from the input content.", + "readOnly": true, + "$ref": "#/components/schemas/ContentEmbedding" }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", - "type": "string" + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" } - } + }, + "description": "The response to an `EmbedContentRequest`." }, - "RetrievalMetadata": { + "TuningSnapshot": { + "type": "object", "properties": { - "googleSearchDynamicRetrievalScore": { + "epoch": { + "format": "int32", + "description": "Output only. The epoch this step was part of.", + "readOnly": true, + "type": "integer" + }, + "meanLoss": { "format": "float", - "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", + "description": "Output only. The mean loss of the training examples for this step.", + "readOnly": true, "type": "number" + }, + "computeTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp when this metric was computed.", + "readOnly": true + }, + "step": { + "type": "integer", + "description": "Output only. The tuning step.", + "readOnly": true, + "format": "int32" } }, - "description": "Metadata related to retrieval in the grounding flow.", - "type": "object" + "description": "Record for a single tuning step." }, - "ListModelsResponse": { + "ListCorporaResponse": { + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", + "type": "object", "properties": { - "models": { - "description": "The returned Models.", + "corpora": { "type": "array", + "description": "The returned corpora.", "items": { - "$ref": "#/components/schemas/Model" + "$ref": "#/components/schemas/Corpus" } }, "nextPageToken": { "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", "type": "string" } - }, - "description": "Response from `ListModel` containing a paginated list of Models.", - "type": "object" + } }, - "FileData": { - "description": "URI based data.", + "EmbeddingUsageMetadata": { + "description": "Metadata on the usage of the embedding request.", "type": "object", "properties": { - "fileUri": { - "description": "Required. URI.", - "type": "string" + "promptTokenCount": { + "description": "Output only. Number of tokens in the prompt.", + "readOnly": true, + "format": "int32", + "type": "integer" }, - "mimeType": { - "description": "Optional. The IANA standard MIME type of the source data.", - "type": "string" + "promptTokenDetails": { + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true } } }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { - "description": "Grounding support.", + "Tool": { "type": "object", "properties": { - "groundingChunkIndices": { - "items": { - "format": "int32", - "type": "integer" - }, - "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" + "googleSearchRetrieval": { + "$ref": "#/components/schemas/GoogleSearchRetrieval", + "description": "Optional. Retrieval tool that is powered by Google search." }, - "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" - } + "codeExecution": { + "description": "Optional. Enables the model to execute code as part of generation.", + "$ref": "#/components/schemas/CodeExecution" }, - "segment": { - "description": "Segment of the content this support belongs to.", - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" + "googleSearch": { + "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", + "$ref": "#/components/schemas/GoogleSearch" }, - "renderedParts": { - "readOnly": true, - "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.", + "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." + }, + "fileSearch": { + "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", + "$ref": "#/components/schemas/FileSearch" + }, + "functionDeclarations": { "type": "array", + "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn.", "items": { - "format": "int32", - "type": "integer" + "$ref": "#/components/schemas/FunctionDeclaration" } - } - } - }, - "EmbedContentBatchOutput": { - "properties": { - "responsesFile": { - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.", - "type": "string", - "readOnly": true - }, - "inlinedResponses": { - "$ref": "#/components/schemas/InlinedEmbedContentResponses", - "readOnly": true, - "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests." - } - }, - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", - "type": "object" - }, - "CustomMetadata": { - "properties": { - "numericValue": { - "format": "float", - "description": "The numeric value of the metadata to store.", - "type": "number" }, - "key": { - "description": "Required. The key of the metadata to store.", - "type": "string" - }, - "stringListValue": { - "description": "The StringList value of the metadata to store.", - "$ref": "#/components/schemas/StringList" + "googleMaps": { + "$ref": "#/components/schemas/GoogleMaps", + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query." }, - "stringValue": { - "description": "The string value of the metadata to store.", - "type": "string" - } - }, - "description": "User provided metadata stored as key-value pairs.", - "type": "object" - }, - "TuningExample": { - "properties": { - "textInput": { - "description": "Optional. Text model input.", - "type": "string" + "urlContext": { + "description": "Optional. Tool to support URL context retrieval.", + "$ref": "#/components/schemas/UrlContext" }, - "output": { - "description": "Required. The expected model output.", - "type": "string" - } - }, - "description": "A single example for tuning.", - "type": "object" - }, - "ListFileSearchStoresResponse": { - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", - "type": "object", - "properties": { - "fileSearchStores": { + "mcpServers": { "items": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/McpServer" }, - "description": "The returned rag_stores.", + "description": "Optional. MCP Servers to connect to.", "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": "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" }, - "RetrievalConfig": { - "description": "Retrieval config.", + "BatchGenerateContentRequest": { + "description": "Request for a `BatchGenerateContent` operation.", "type": "object", "properties": { - "latLng": { - "description": "Optional. The location of the user.", - "$ref": "#/components/schemas/LatLng" - }, - "languageCode": { - "description": "Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt).", - "type": "string" + "batch": { + "$ref": "#/components/schemas/GenerateContentBatch", + "description": "Required. The batch to create." } } }, - "InputConfig": { - "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/InlinedRequests" - } - }, - "description": "Configures the input to the batch request.", - "type": "object" - }, - "FunctionDeclaration": { - "properties": { - "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" - }, - "parameters": { - "description": "Optional. Describes the parameters to this function. Reflects the Open API 3.03 Parameter Object string Key: the name of the parameter. Parameter names are case sensitive. Schema Value: the Schema defining the type used for the parameter.", - "$ref": "#/components/schemas/Schema" - }, - "description": { - "description": "Required. A brief description of the function.", - "type": "string" - }, - "parametersJsonSchema": { - "description": "Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { \"type\": \"object\", \"properties\": { \"name\": { \"type\": \"string\" }, \"age\": { \"type\": \"integer\" } }, \"additionalProperties\": false, \"required\": [\"name\", \"age\"], \"propertyOrdering\": [\"name\", \"age\"] } ``` This field is mutually exclusive with `parameters`." - }, - "behavior": { - "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", - "type": "string", - "x-enum-descriptions": [ - "This value is unused.", - "If set, the system will wait to receive the function response before continuing the conversation.", - "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." - ], - "enum": [ - "UNSPECIFIED", - "BLOCKING", - "NON_BLOCKING" - ] - }, - "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" - }, - "responseJsonSchema": { - "description": "Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`." - } - }, - "description": "Structured representation of a function declaration as defined by the [OpenAPI 3.03 specification](https://spec.openapis.org/oas/v3.0.3). Included in this declaration are the function name and parameters. This FunctionDeclaration is a representation of a block of code that can be used as a `Tool` by the model and executed by the client.", - "type": "object" - }, - "TransferOwnershipResponse": { - "properties": {}, - "description": "Response from `TransferOwnership`.", - "type": "object" - }, - "GenerateContentBatch": { - "description": "A resource representing a batch of `GenerateContent` requests.", + "EmbedContentBatch": { + "description": "A resource representing a batch of `EmbedContent` requests.", "type": "object", "properties": { - "priority": { - "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0.", - "type": "string", - "format": "int64" + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputEmbedContentConfig" }, "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" - }, - "batchStats": { - "$ref": "#/components/schemas/BatchStats", - "readOnly": true, - "description": "Output only. Stats about the batch." - }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", "type": "string", - "readOnly": true, - "format": "google-datetime" + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputConfig" + "displayName": { + "type": "string", + "description": "Required. The user-defined name of this batch." }, "output": { + "description": "Output only. The output of the batch request.", "readOnly": true, - "$ref": "#/components/schemas/GenerateContentBatchOutput", - "description": "Output only. The output of the batch request." + "$ref": "#/components/schemas/EmbedContentBatchOutput" }, "createTime": { - "readOnly": true, "format": "google-datetime", "description": "Output only. The time at which the batch was created.", + "readOnly": true, "type": "string" }, - "displayName": { - "description": "Required. The user-defined name of this batch.", + "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" }, - "updateTime": { - "readOnly": true, + "endTime": { + "type": "string", "format": "google-datetime", + "description": "Output only. The time at which the batch processing completed.", + "readOnly": true + }, + "updateTime": { + "type": "string", "description": "Output only. The time at which the batch was last updated.", - "type": "string" + "readOnly": true, + "format": "google-datetime" + }, + "batchStats": { + "$ref": "#/components/schemas/EmbedContentBatchStats", + "description": "Output only. Stats about the batch.", + "readOnly": true + }, + "name": { + "type": "string", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "readOnly": true }, "state": { - "readOnly": true, - "description": "Output only. The state of the batch.", "type": "string", + "readOnly": true, "enum": [ "BATCH_STATE_UNSPECIFIED", "BATCH_STATE_PENDING", @@ -4046,332 +3910,270 @@ "The batch failed.", "The batch has been cancelled.", "The batch has expired." - ] - }, - "name": { - "readOnly": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "type": "string" + ], + "description": "Output only. The state of the batch." } } }, - "MultiSpeakerVoiceConfig": { - "description": "The configuration for the multi-speaker setup.", + "GroundingAttribution": { "type": "object", "properties": { - "speakerVoiceConfigs": { - "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" - }, - "description": "Required. All the enabled speaker voices.", - "type": "array" + "sourceId": { + "$ref": "#/components/schemas/AttributionSourceId", + "description": "Output only. Identifier for the source contributing to this attribution.", + "readOnly": true + }, + "content": { + "$ref": "#/components/schemas/Content", + "description": "Grounding source content that makes up this attribution." } - } + }, + "description": "Attribution for a source that contributed to an answer." }, - "LogprobsResult": { - "description": "Logprobs Result", + "LatLng": { + "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges.", "type": "object", "properties": { - "logProbabilitySum": { - "description": "Sum of log probabilities for all tokens.", - "type": "number", - "format": "float" - }, - "topCandidates": { - "description": "Length = total number of decoding steps.", - "type": "array", - "items": { - "$ref": "#/components/schemas/TopCandidates" - } + "latitude": { + "format": "double", + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", + "type": "number" }, - "chosenCandidates": { - "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - }, - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", - "type": "array" + "longitude": { + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", + "format": "double", + "type": "number" } } }, - "GroundingChunk": { + "TunedModelSource": { + "type": "object", "properties": { - "web": { - "description": "Grounding chunk from the web.", - "$ref": "#/components/schemas/Web" - }, - "maps": { - "description": "Optional. Grounding chunk from Google Maps.", - "$ref": "#/components/schemas/Maps" - }, - "image": { - "description": "Optional. Grounding chunk from image search.", - "$ref": "#/components/schemas/Image" + "tunedModel": { + "type": "string", + "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`" }, - "retrievedContext": { - "description": "Optional. Grounding chunk from context retrieved by the file search tool.", - "$ref": "#/components/schemas/RetrievedContext" + "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" } }, - "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": "Tuned model as a source for training a new model." }, - "SearchEntryPoint": { + "InputConfig": { + "description": "Configures the input to the batch request.", + "type": "object", "properties": { - "renderedContent": { - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", + "fileName": { + "description": "The name of the `File` containing the input requests.", "type": "string" }, - "sdkBlob": { - "format": "byte", - "description": "Optional. Base64 encoded JSON representing array of tuple.", - "type": "string" + "requests": { + "$ref": "#/components/schemas/InlinedRequests", + "description": "The requests to be processed in the batch." } - }, - "description": "Google search entry point.", - "type": "object" + } }, - "FunctionResponsePart": { - "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", + "ImportFileRequest": { "type": "object", "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/FunctionResponseBlob" + "customMetadata": { + "type": "array", + "description": "Custom metadata to be associated with the file.", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + } + }, + "fileName": { + "type": "string", + "description": "Required. The name of the `File` to import. Example: `files/abc-123`" + }, + "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." } - } + }, + "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`." }, - "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.", + "Status": { + "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", "type": "object", "properties": { - "mediaResolution": { - "description": "Optional. Media resolution for the input media.", - "$ref": "#/components/schemas/MediaResolution" - }, - "partMetadata": { - "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } + "code": { + "type": "integer", + "format": "int32", + "description": "The status code, which should be an enum value of google.rpc.Code." }, - "text": { - "description": "Inline text.", + "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" }, - "executableCode": { - "description": "Code generated by the model that is meant to be executed.", - "$ref": "#/components/schemas/ExecutableCode" - }, - "functionResponse": { - "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model.", - "$ref": "#/components/schemas/FunctionResponse" - }, - "fileData": { - "description": "URI based data.", - "$ref": "#/components/schemas/FileData" - }, - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/Blob" - }, - "functionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", - "$ref": "#/components/schemas/FunctionCall" - }, - "toolCall": { - "description": "Server-side tool call. This field is populated when the model predicts a tool invocation that should be executed on the server. The client is expected to echo this message back to the API.", - "$ref": "#/components/schemas/ToolCall" - }, - "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" - }, - "codeExecutionResult": { - "description": "Result of executing the `ExecutableCode`.", - "$ref": "#/components/schemas/CodeExecutionResult" - }, - "videoMetadata": { - "description": "Optional. Video metadata. The metadata should only be specified while the video data is presented in inline_data or file_data.", - "$ref": "#/components/schemas/VideoMetadata" - }, - "thought": { - "description": "Optional. Indicates if the part is thought from the model.", - "type": "boolean" - }, - "thoughtSignature": { - "format": "byte", - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests.", - "type": "string" + "details": { + "type": "array", + "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", + "items": { + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object" + } } } }, - "ModelStatus": { - "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable.", + "InputEmbedContentConfig": { "type": "object", "properties": { - "modelStage": { - "description": "The stage of the underlying model.", - "type": "string", - "enumDeprecated": [ - false, - true, - false, - false, - false, - false, - true, - false - ], + "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" + } + }, + "description": "Configures the input to the batch request." + }, + "DynamicRetrievalConfig": { + "type": "object", + "properties": { + "mode": { + "description": "The mode of the predictor to be used in dynamic retrieval.", "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." + "Always trigger retrieval.", + "Run retrieval only when system decides it is necessary." ], "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" - ] + "MODE_UNSPECIFIED", + "MODE_DYNAMIC" + ], + "type": "string" }, - "retirementTime": { - "description": "The time at which the model will be retired.", - "type": "string", - "format": "google-datetime" + "dynamicThreshold": { + "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", + "format": "float", + "type": "number" + } + }, + "description": "Describes the options to customize dynamic retrieval." + }, + "ThinkingConfig": { + "description": "Config for thinking features.", + "type": "object", + "properties": { + "includeThoughts": { + "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", + "type": "boolean" }, - "message": { - "description": "A message explaining the model status.", - "type": "string" + "thinkingBudget": { + "format": "int32", + "description": "The number of thoughts tokens that the model should generate.", + "type": "integer" + }, + "thinkingLevel": { + "enum": [ + "THINKING_LEVEL_UNSPECIFIED", + "MINIMAL", + "LOW", + "MEDIUM", + "HIGH" + ], + "type": "string", + "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", + "x-enum-descriptions": [ + "Default value.", + "Little to no thinking.", + "Low thinking level.", + "Medium thinking level.", + "High thinking level." + ] } } }, - "ListPermissionsResponse": { - "description": "Response from `ListPermissions` containing a paginated list of permissions.", + "StringList": { "type": "object", "properties": { - "permissions": { + "values": { "items": { - "$ref": "#/components/schemas/Permission" + "type": "string" }, - "description": "Returned permissions.", + "description": "The string values of the metadata to store.", "type": "array" + } + }, + "description": "User provided string values assigned to a single metadata key." + }, + "ListFilesResponse": { + "description": "Response for `ListFiles`.", + "type": "object", + "properties": { + "files": { + "type": "array", + "description": "The list of `File`s.", + "items": { + "$ref": "#/components/schemas/File" + } }, "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call." } } }, - "Model": { - "description": "Information about a Generative Language Model.", + "GoogleAiGenerativelanguageV1betaGroundingSupport": { "type": "object", "properties": { - "inputTokenLimit": { - "description": "Maximum number of input tokens allowed for this model.", - "type": "integer", - "format": "int32" - }, - "temperature": { - "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model.", - "type": "number", - "format": "float" + "groundingChunkIndices": { + "items": { + "type": "integer", + "format": "int32" + }, + "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order).", + "type": "array" }, - "description": { - "description": "A short description of the model.", - "type": "string" + "confidenceScores": { + "items": { + "type": "number", + "format": "float" + }, + "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices.", + "type": "array" }, - "topP": { - "format": "float", - "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", - "type": "number" + "segment": { + "description": "Segment of the content this support belongs to.", + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" }, - "thinking": { - "description": "Whether the model supports thinking.", - "type": "boolean" - }, - "version": { - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", - "type": "string" - }, - "baseModelId": { - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", - "type": "string" - }, - "maxTemperature": { - "description": "The maximum temperature this model can use.", - "type": "number", - "format": "float" - }, - "displayName": { - "description": "The human-readable name of the model. E.g. \"Gemini 1.5 Flash\". The name can be up to 128 characters long and can consist of any UTF-8 characters.", - "type": "string" - }, - "outputTokenLimit": { - "description": "Maximum number of output tokens available for this model.", - "type": "integer", - "format": "int32" - }, - "topK": { - "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter.", - "type": "integer", - "format": "int32" - }, - "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" - }, - "supportedGenerationMethods": { - "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`.", + "renderedParts": { "type": "array", "items": { - "type": "string" - } + "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 } - } + }, + "description": "Grounding support." }, - "FunctionResponseBlob": { - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", + "BatchEmbedContentsRequest": { "type": "object", "properties": { - "data": { - "description": "Raw bytes for media formats.", - "type": "string", - "format": "byte" - }, - "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" + "requests": { + "type": "array", + "items": { + "$ref": "#/components/schemas/EmbedContentRequest" + }, + "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`." } - } + }, + "description": "Batch request to get embeddings from the model for a list of prompts." }, "PromptFeedback": { + "type": "object", "properties": { - "safetyRatings": { - "description": "Ratings for safety of the prompt. There is at most one rating per category.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SafetyRating" - } - }, "blockReason": { - "enum": [ - "BLOCK_REASON_UNSPECIFIED", - "SAFETY", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "IMAGE_SAFETY" - ], + "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", "x-enum-descriptions": [ "Default value. This value is unused.", "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", @@ -4380,2221 +4182,2419 @@ "Prompt was blocked due to prohibited content.", "Candidates blocked due to unsafe image generation content." ], - "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", + "enum": [ + "BLOCK_REASON_UNSPECIFIED", + "SAFETY", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "IMAGE_SAFETY" + ], "type": "string" + }, + "safetyRatings": { + "items": { + "$ref": "#/components/schemas/SafetyRating" + }, + "description": "Ratings for safety of the prompt. There is at most one rating per category.", + "type": "array" } }, - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", - "type": "object" + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`." }, - "FunctionCall": { + "GenerateContentBatch": { + "description": "A resource representing a batch of `GenerateContent` requests.", + "type": "object", "properties": { - "name": { - "description": "Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128.", - "type": "string" + "displayName": { + "type": "string", + "description": "Required. The user-defined name of this batch." }, - "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`.", + "output": { + "$ref": "#/components/schemas/GenerateContentBatchOutput", + "description": "Output only. The output of the batch request.", + "readOnly": true + }, + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputConfig" + }, + "model": { + "type": "string", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + }, + "endTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The time at which the batch processing completed.", + "readOnly": true + }, + "updateTime": { + "format": "google-datetime", + "description": "Output only. The time at which the batch was last updated.", + "readOnly": true, "type": "string" }, - "args": { - "description": "Optional. The function parameters and values in JSON object format.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object." - } - } - }, - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", - "type": "object" - }, - "SafetySetting": { - "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked.", - "type": "object", - "properties": { - "category": { - "x-enum-descriptions": [ - "Category is unspecified.", - "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", - "**PaLM** - Content that is rude, disrespectful, or profane.", - "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", - "**PaLM** - Contains references to sexual acts or other lewd content.", - "**PaLM** - Promotes unchecked medical advice.", - "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", - "**Gemini** - Harassment content.", - "**Gemini** - Hate speech and content.", - "**Gemini** - Sexually explicit content.", - "**Gemini** - Dangerous content.", - "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." - ], - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "description": "Required. The category for this setting.", + "batchStats": { + "$ref": "#/components/schemas/BatchStats", + "description": "Output only. Stats about the batch.", + "readOnly": true + }, + "name": { "type": "string", - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", + "readOnly": true }, - "threshold": { + "state": { + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], "x-enum-descriptions": [ - "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." ], - "description": "Required. Controls the probability threshold at which harm is blocked.", + "description": "Output only. The state of the batch.", "type": "string", - "enum": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" - ] + "readOnly": true + }, + "createTime": { + "description": "Output only. The time at which the batch was created.", + "readOnly": true, + "format": "google-datetime", + "type": "string" + }, + "priority": { + "type": "string", + "format": "int64", + "description": "Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0." } } }, - "ListCorporaResponse": { + "ListPermissionsResponse": { + "description": "Response from `ListPermissions` containing a paginated list of permissions.", + "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" - }, - "corpora": { + "permissions": { + "description": "Returned permissions.", "items": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/Permission" }, - "description": "The returned corpora.", "type": "array" + }, + "nextPageToken": { + "type": "string", + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." } - }, - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", - "type": "object" + } }, - "LatLng": { - "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges.", + "InlinedResponses": { "type": "object", "properties": { - "latitude": { - "format": "double", - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", - "type": "number" + "inlinedResponses": { + "type": "array", + "description": "Output only. The responses to the requests in the batch.", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/InlinedResponse" + } + } + }, + "description": "The responses to the requests in the batch." + }, + "ToolConfig": { + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", + "type": "object", + "properties": { + "retrievalConfig": { + "$ref": "#/components/schemas/RetrievalConfig", + "description": "Optional. Retrieval config." }, - "longitude": { - "format": "double", - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", - "type": "number" + "includeServerSideToolInvocations": { + "description": "Optional. If true, the API response will include the server-side tool calls and responses within the `Content` message. This allows clients to observe the server's tool interactions.", + "type": "boolean" + }, + "functionCallingConfig": { + "description": "Optional. Function calling config.", + "$ref": "#/components/schemas/FunctionCallingConfig" } } }, - "Schema": { - "description": "The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema).", + "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", "properties": { - "required": { + "name": { + "type": "string", + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", + "readOnly": true + }, + "tools": { + "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", "items": { - "type": "string" + "$ref": "#/components/schemas/Tool" }, - "description": "Optional. Required properties of Type.OBJECT.", "type": "array" }, - "format": { - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", + "updateTime": { + "format": "google-datetime", + "description": "Output only. When the cache entry was last updated in UTC time.", + "readOnly": true, "type": "string" }, - "enum": { - "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}", - "type": "array", + "contents": { "items": { - "type": "string" - } - }, - "minLength": { - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", - "type": "string", - "format": "int64" - }, - "maximum": { - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", - "type": "number", - "format": "double" - }, - "minimum": { - "format": "double", - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "type": "number" - }, - "nullable": { - "description": "Optional. Indicates if the value may be null.", - "type": "boolean" - }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." + "$ref": "#/components/schemas/Content" + }, + "description": "Optional. Input only. Immutable. The content to cache.", + "type": "array" }, - "items": { - "description": "Optional. Schema of the elements of Type.ARRAY.", - "$ref": "#/components/schemas/Schema" + "toolConfig": { + "$ref": "#/components/schemas/ToolConfig", + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools." }, - "maxItems": { - "description": "Optional. Maximum number of the elements for Type.ARRAY.", + "createTime": { "type": "string", - "format": "int64" - }, - "default": { - "description": "Optional. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors." - }, - "maxLength": { - "format": "int64", - "description": "Optional. Maximum length of the Type.STRING", - "type": "string" - }, - "propertyOrdering": { - "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response.", - "type": "array", - "items": { - "type": "string" - } - }, - "type": { - "enum": [ - "TYPE_UNSPECIFIED", - "STRING", - "NUMBER", - "INTEGER", - "BOOLEAN", - "ARRAY", - "OBJECT", - "NULL" - ], - "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.", - "type": "string" + "description": "Output only. Creation time of the cache entry.", + "readOnly": true, + "format": "google-datetime" }, - "minProperties": { - "format": "int64", - "description": "Optional. Minimum number of the properties for Type.OBJECT.", + "ttl": { + "format": "google-duration", + "description": "Input only. New TTL for this resource, input only.", "type": "string" }, - "pattern": { - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", + "expireTime": { + "format": "google-datetime", + "description": "Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input.", "type": "string" }, - "minItems": { - "description": "Optional. Minimum number of the elements for Type.ARRAY.", + "displayName": { "type": "string", - "format": "int64" - }, - "description": { - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", - "type": "string" - }, - "properties": { - "description": "Optional. Properties of Type.OBJECT.", - "type": "object", - "additionalProperties": { - "$ref": "#/components/schemas/Schema" - } + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters." }, - "maxProperties": { - "format": "int64", - "description": "Optional. Maximum number of the properties for Type.OBJECT.", - "type": "string" + "systemInstruction": { + "$ref": "#/components/schemas/Content", + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." }, - "anyOf": { - "items": { - "$ref": "#/components/schemas/Schema" - }, - "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", - "type": "array" + "usageMetadata": { + "description": "Output only. Metadata on the usage of the cached content.", + "readOnly": true, + "$ref": "#/components/schemas/CachedContentUsageMetadata" }, - "title": { - "description": "Optional. The title of the schema.", + "model": { + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", "type": "string" } } }, - "InlinedResponse": { - "description": "The response to a single request in the batch.", + "Maps": { "type": "object", "properties": { - "metadata": { - "description": "Output only. The metadata associated with the request.", - "type": "object", - "readOnly": true, - "additionalProperties": { - "description": "Properties of the object." - } + "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" }, - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request." + "placeAnswerSources": { + "description": "Sources that provide answers about the features of a given place in Google Maps.", + "$ref": "#/components/schemas/PlaceAnswerSources" }, - "response": { - "$ref": "#/components/schemas/GenerateContentResponse", - "readOnly": true, - "description": "Output only. The response to the request." + "uri": { + "type": "string", + "description": "URI reference of the place." + }, + "title": { + "type": "string", + "description": "Title of the place." + }, + "text": { + "description": "Text description of the place answer.", + "type": "string" } - } + }, + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place." }, - "InlinedEmbedContentResponses": { + "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": {} + }, + "ListTunedModelsResponse": { + "type": "object", "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "type": "array", + "tunedModels": { "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" + "$ref": "#/components/schemas/TunedModel" }, - "readOnly": true + "description": "The returned Models.", + "type": "array" + }, + "nextPageToken": { + "type": "string", + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." } }, - "description": "The responses to the requests in the batch.", - "type": "object" + "description": "Response from `ListTunedModels` containing a paginated list of Models." }, - "SpeechConfig": { + "FileData": { + "description": "URI based data.", + "type": "object", "properties": { - "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`.", + "mimeType": { + "description": "Optional. The IANA standard MIME type of the source data.", "type": "string" }, - "multiSpeakerVoiceConfig": { - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" - }, - "voiceConfig": { - "description": "The configuration in case of single-voice output.", - "$ref": "#/components/schemas/VoiceConfig" + "fileUri": { + "type": "string", + "description": "Required. URI." } - }, - "description": "Config for speech generation and transcription.", - "type": "object" + } }, - "InlinedResponses": { - "description": "The responses to the requests in the batch.", + "Document": { + "description": "A `Document` is a collection of `Chunk`s.", "type": "object", "properties": { - "inlinedResponses": { - "description": "Output only. The responses to the requests in the batch.", - "type": "array", - "items": { - "$ref": "#/components/schemas/InlinedResponse" - }, - "readOnly": true - } - } - }, - "CodeExecution": { - "properties": {}, - "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", - "type": "object" - }, - "TuningExamples": { - "description": "A set of tuning examples. Can be training or validation data.", - "type": "object", - "properties": { - "examples": { - "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type.", + "sizeBytes": { + "type": "string", + "format": "int64", + "description": "Output only. The size of raw bytes ingested into the Document.", + "readOnly": true + }, + "createTime": { + "description": "Output only. The Timestamp of when the `Document` was created.", + "readOnly": true, + "format": "google-datetime", + "type": "string" + }, + "mimeType": { + "type": "string", + "description": "Output only. The mime type of the Document.", + "readOnly": true + }, + "updateTime": { + "description": "Output only. The Timestamp of when the `Document` was last updated.", + "readOnly": true, + "format": "google-datetime", + "type": "string" + }, + "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, + "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. Current state of the `Document`.", + "enum": [ + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" + ] + }, + "name": { + "type": "string", + "description": "Immutable. Identifier. The `Document` resource name. The ID (name excluding the \"fileSearchStores/*/documents/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c`" + }, + "customMetadata": { "type": "array", + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", "items": { - "$ref": "#/components/schemas/TuningExample" + "$ref": "#/components/schemas/CustomMetadata" } } } }, - "ModalityTokenCount": { - "description": "Represents token counting info for a single modality.", + "ComputerUse": { "type": "object", "properties": { - "modality": { - "description": "The modality associated with this token count.", + "environment": { + "enum": [ + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER" + ], "type": "string", + "description": "Required. The environment being operated.", "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." - ], - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "VIDEO", - "AUDIO", - "DOCUMENT" + "Defaults to browser.", + "Operates in a web browser." ] }, - "tokenCount": { - "format": "int32", - "description": "Number of tokens.", - "type": "integer" + "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": "Computer Use tool type." }, - "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`.", + "Image": { "type": "object", "properties": { - "modelStatus": { - "readOnly": true, - "$ref": "#/components/schemas/ModelStatus", - "description": "Output only. The current model status of this model." - }, - "promptFeedback": { - "description": "Returns the prompt's feedback related to the content filters.", - "$ref": "#/components/schemas/PromptFeedback" + "imageUri": { + "description": "The image asset URL.", + "type": "string" }, - "usageMetadata": { - "$ref": "#/components/schemas/UsageMetadata", - "readOnly": true, - "description": "Output only. Metadata on the generation requests' token usage." + "domain": { + "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", + "type": "string" }, - "modelVersion": { - "description": "Output only. The model version used to generate the response.", + "sourceUri": { "type": "string", - "readOnly": true - }, - "candidates": { - "items": { - "$ref": "#/components/schemas/Candidate" - }, - "description": "Candidate responses from the model.", - "type": "array" + "description": "The web page URI for attribution." }, - "responseId": { - "readOnly": true, - "description": "Output only. response_id is used to identify each response.", - "type": "string" + "title": { + "type": "string", + "description": "The title of the web page that the image is from." } - } + }, + "description": "Chunk from image search." }, - "ImportFileRequest": { - "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`.", + "LogprobsResult": { + "description": "Logprobs Result", "type": "object", "properties": { - "fileName": { - "description": "Required. The name of the `File` to import. Example: `files/abc-123`", - "type": "string" + "logProbabilitySum": { + "description": "Sum of log probabilities for all tokens.", + "format": "float", + "type": "number" }, - "customMetadata": { + "topCandidates": { + "type": "array", + "description": "Length = total number of decoding steps.", "items": { - "$ref": "#/components/schemas/CustomMetadata" + "$ref": "#/components/schemas/TopCandidates" + } + }, + "chosenCandidates": { + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" }, - "description": "Custom metadata to be associated with the file.", + "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", "type": "array" - }, - "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" } } }, - "ReviewSnippet": { + "CreateFileResponse": { + "type": "object", "properties": { - "title": { - "description": "Title of the review.", - "type": "string" - }, - "reviewId": { - "description": "The ID of the review snippet.", - "type": "string" - }, - "googleMapsUri": { - "description": "A link that corresponds to the user review on Google Maps.", - "type": "string" + "file": { + "description": "Metadata for the created file.", + "$ref": "#/components/schemas/File" } }, - "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", - "type": "object" + "description": "Response for `CreateFile`." }, - "TuningTask": { - "description": "Tuning tasks that create tuned models.", + "CustomMetadata": { "type": "object", "properties": { - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", - "type": "string", - "readOnly": true, - "format": "google-datetime" - }, - "snapshots": { - "items": { - "$ref": "#/components/schemas/TuningSnapshot" - }, - "description": "Output only. Metrics collected during tuning.", - "type": "array", - "readOnly": true + "stringValue": { + "description": "The string value of the metadata to store.", + "type": "string" }, - "hyperparameters": { - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", - "$ref": "#/components/schemas/Hyperparameters" + "numericValue": { + "type": "number", + "description": "The numeric value of the metadata to store.", + "format": "float" }, - "completeTime": { - "description": "Output only. The timestamp when tuning this model completed.", + "key": { "type": "string", - "readOnly": true, - "format": "google-datetime" + "description": "Required. The key of the metadata to store." }, - "trainingData": { - "description": "Required. Input only. Immutable. The model training data.", - "$ref": "#/components/schemas/Dataset" + "stringListValue": { + "description": "The StringList value of the metadata to store.", + "$ref": "#/components/schemas/StringList" } - } + }, + "description": "User provided metadata stored as key-value pairs." }, - "ToolConfig": { + "FunctionCall": { + "type": "object", "properties": { - "functionCallingConfig": { - "description": "Optional. Function calling config.", - "$ref": "#/components/schemas/FunctionCallingConfig" + "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" }, - "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" + "args": { + "description": "Optional. The function parameters and values in JSON object format.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" }, - "retrievalConfig": { - "description": "Optional. Retrieval config.", - "$ref": "#/components/schemas/RetrievalConfig" + "id": { + "description": "Optional. Unique identifier of the function call. If populated, the client to execute the `function_call` and return the response with the matching `id`.", + "type": "string" } }, - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", - "type": "object" + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values." }, - "ListFilesResponse": { - "description": "Response for `ListFiles`.", + "ListCachedContentsResponse": { + "description": "Response with CachedContents list.", "type": "object", "properties": { - "files": { + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.", + "type": "string" + }, + "cachedContents": { "items": { - "$ref": "#/components/schemas/File" + "$ref": "#/components/schemas/CachedContent" }, - "description": "The list of `File`s.", + "description": "List of cached contents.", "type": "array" - }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", - "type": "string" } } }, - "Dataset": { - "description": "Dataset for training or validation.", + "GenerateContentRequest": { "type": "object", "properties": { - "examples": { - "description": "Optional. Inline examples with simple input/output text.", - "$ref": "#/components/schemas/TuningExamples" - } - } - }, - "InlinedEmbedContentResponse": { - "properties": { - "error": { - "readOnly": true, - "$ref": "#/components/schemas/Status", - "description": "Output only. The error encountered while processing the request." - }, - "response": { - "description": "Output only. The response to the request.", - "readOnly": true, - "$ref": "#/components/schemas/EmbedContentResponse" - }, - "metadata": { - "description": "Output only. The metadata associated with the request.", - "type": "object", - "readOnly": true, - "additionalProperties": { - "description": "Properties of the object." + "tools": { + "type": "array", + "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more.", + "items": { + "$ref": "#/components/schemas/Tool" } - } - }, - "description": "The response to a single request in the batch.", - "type": "object" - }, - "CustomLongRunningOperation": { - "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" - }, - "metadata": { - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - }, - "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", - "type": "object" - }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - }, - "done": { - "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", - "type": "boolean" }, - "response": { - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." + "contents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" }, - "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", - "type": "object" - } - }, - "type": "object" - }, - "GroundingAttribution": { - "properties": { - "content": { - "description": "Grounding source content that makes up this attribution.", - "$ref": "#/components/schemas/Content" + "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request." }, - "sourceId": { - "$ref": "#/components/schemas/AttributionSourceId", - "readOnly": true, - "description": "Output only. Identifier for the source contributing to this attribution." - } - }, - "description": "Attribution for a source that contributed to an answer.", - "type": "object" - }, - "FileSearchStore": { - "description": "A `FileSearchStore` is a collection of `Document`s.", - "type": "object", - "properties": { - "pendingDocumentsCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", - "type": "string" + "generationConfig": { + "description": "Optional. Configuration options for model generation and outputs.", + "$ref": "#/components/schemas/GenerationConfig" }, - "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`.", - "type": "string", - "readOnly": true, - "format": "int64" + "toolConfig": { + "$ref": "#/components/schemas/ToolConfig", + "description": "Optional. Tool configuration for any `Tool` specified in the request. Refer to the [Function calling guide](https://ai.google.dev/gemini-api/docs/function-calling#function_calling_mode) for a usage example." }, - "createTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", - "type": "string" + "safetySettings": { + "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.", + "items": { + "$ref": "#/components/schemas/SafetySetting" + } }, - "failedDocumentsCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "serviceTier": { + "description": "Optional. The service tier of the request.", + "x-enum-descriptions": [ + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." + ], + "enum": [ + "unspecified", + "standard", + "flex", + "priority" + ], "type": "string" }, - "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" + "systemInstruction": { + "$ref": "#/components/schemas/Content", + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only." }, - "updateTime": { - "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "model": { "type": "string", - "readOnly": true, - "format": "google-datetime" + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." }, - "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.", - "type": "string", - "readOnly": true + "store": { + "type": "boolean", + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." }, - "activeDocumentsCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "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" } - } + }, + "description": "Request to generate a completion from the model." }, "ImageConfig": { - "description": "Config for image generation features.", "type": "object", "properties": { "imageSize": { - "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`.", - "type": "string" + "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" } - } + }, + "description": "Config for image generation features." }, - "Image": { + "SearchEntryPoint": { + "type": "object", "properties": { - "title": { - "description": "The title of the web page that the image is from.", - "type": "string" - }, - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", - "type": "string" - }, - "sourceUri": { - "description": "The web page URI for attribution.", + "renderedContent": { + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", "type": "string" }, - "imageUri": { - "description": "The image asset URL.", - "type": "string" + "sdkBlob": { + "type": "string", + "format": "byte", + "description": "Optional. Base64 encoded JSON representing array of tuple." } }, - "description": "Chunk from image search.", - "type": "object" + "description": "Google search entry point." }, - "PlaceAnswerSources": { + "TopCandidates": { + "description": "Candidates with top log probabilities at each decoding step.", + "type": "object", "properties": { - "reviewSnippets": { + "candidates": { "items": { - "$ref": "#/components/schemas/ReviewSnippet" + "$ref": "#/components/schemas/LogprobsResultCandidate" }, - "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", + "description": "Sorted by log probability in descending order.", "type": "array" } - }, - "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", - "type": "object" + } }, - "CachedContent": { + "StreamableHttpTransport": { + "type": "object", "properties": { - "toolConfig": { - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", - "$ref": "#/components/schemas/ToolConfig" + "terminateOnClose": { + "description": "Whether to close the client session when the transport closes.", + "type": "boolean" }, - "ttl": { - "description": "Input only. New TTL for this resource, input only.", + "url": { "type": "string", - "format": "google-duration" + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"" }, - "displayName": { - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", + "sseReadTimeout": { + "description": "Timeout for SSE read operations.", + "format": "google-duration", "type": "string" }, - "updateTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. When the cache entry was last updated in UTC time.", - "type": "string" + "headers": { + "type": "object", + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", + "additionalProperties": { + "type": "string" + } }, - "createTime": { - "description": "Output only. Creation time of the cache entry.", + "timeout": { "type": "string", - "readOnly": true, - "format": "google-datetime" + "description": "HTTP timeout for regular operations.", + "format": "google-duration" + } + }, + "description": "A transport that can stream HTTP requests and responses. Next ID: 6" + }, + "Part": { + "type": "object", + "properties": { + "executableCode": { + "$ref": "#/components/schemas/ExecutableCode", + "description": "Code generated by the model that is meant to be executed." }, - "usageMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/CachedContentUsageMetadata", - "description": "Output only. Metadata on the usage of the cached content." + "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" }, - "name": { - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", - "type": "string", - "readOnly": true + "functionResponse": { + "$ref": "#/components/schemas/FunctionResponse", + "description": "The result output of a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model." }, - "contents": { - "items": { - "$ref": "#/components/schemas/Content" - }, - "description": "Optional. Input only. Immutable. The content to cache.", - "type": "array" + "fileData": { + "$ref": "#/components/schemas/FileData", + "description": "URI based data." }, - "expireTime": { - "description": "Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input.", + "mediaResolution": { + "$ref": "#/components/schemas/MediaResolution", + "description": "Optional. Media resolution for the input media." + }, + "text": { "type": "string", - "format": "google-datetime" + "description": "Inline text." }, - "model": { - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", - "type": "string" + "thought": { + "description": "Optional. Indicates if the part is thought from the model.", + "type": "boolean" }, - "systemInstruction": { - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only.", - "$ref": "#/components/schemas/Content" + "inlineData": { + "description": "Inline media bytes.", + "$ref": "#/components/schemas/Blob" }, - "tools": { - "items": { - "$ref": "#/components/schemas/Tool" - }, - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", - "type": "array" + "functionCall": { + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", + "$ref": "#/components/schemas/FunctionCall" + }, + "codeExecutionResult": { + "description": "Result of executing the `ExecutableCode`.", + "$ref": "#/components/schemas/CodeExecutionResult" + }, + "partMetadata": { + "type": "object", + "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", + "additionalProperties": { + "description": "Properties of the object." + } + }, + "thoughtSignature": { + "type": "string", + "format": "byte", + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." + }, + "videoMetadata": { + "description": "Optional. Video metadata. The metadata should only be specified while the video data is presented in inline_data or file_data.", + "$ref": "#/components/schemas/VideoMetadata" + }, + "toolResponse": { + "$ref": "#/components/schemas/ToolResponse", + "description": "The output from a server-side `ToolCall` execution. This field is populated by the client with the results of executing the corresponding `ToolCall`." } }, - "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 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." }, - "Hyperparameters": { - "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", + "TuningTask": { + "description": "Tuning tasks that create tuned models.", "type": "object", "properties": { - "learningRate": { - "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples.", - "type": "number", - "format": "float" + "startTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp when tuning this model started.", + "readOnly": true }, - "learningRateMultiplier": { - "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used.", - "type": "number", - "format": "float" + "completeTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp when tuning this model completed.", + "readOnly": true }, - "batchSize": { - "format": "int32", - "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples.", - "type": "integer" + "snapshots": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TuningSnapshot" + }, + "description": "Output only. Metrics collected during tuning.", + "readOnly": true }, - "epochCount": { - "format": "int32", - "description": "Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used.", - "type": "integer" + "trainingData": { + "description": "Required. Input only. Immutable. The model training data.", + "$ref": "#/components/schemas/Dataset" + }, + "hyperparameters": { + "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", + "$ref": "#/components/schemas/Hyperparameters" } } }, - "AttributionSourceId": { + "ModalityTokenCount": { + "type": "object", "properties": { - "semanticRetrieverChunk": { - "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", - "$ref": "#/components/schemas/SemanticRetrieverChunk" + "modality": { + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "VIDEO", + "AUDIO", + "DOCUMENT" + ], + "type": "string", + "description": "The modality associated with this token count.", + "x-enum-descriptions": [ + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." + ] }, - "groundingPassage": { - "description": "Identifier for an inline passage.", - "$ref": "#/components/schemas/GroundingPassageId" + "tokenCount": { + "type": "integer", + "description": "Number of tokens.", + "format": "int32" } }, - "description": "Identifier for the source contributing to this attribution.", - "type": "object" + "description": "Represents token counting info for a single modality." }, - "LogprobsResultCandidate": { - "description": "Candidate for the logprobs token and score.", + "EmbedContentBatchOutput": { "type": "object", "properties": { - "token": { - "description": "The candidate\u2019s token string value.", - "type": "string" - }, - "logProbability": { - "description": "The candidate's log probability.", - "type": "number", - "format": "float" + "inlinedResponses": { + "$ref": "#/components/schemas/InlinedEmbedContentResponses", + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", + "readOnly": true }, - "tokenId": { - "format": "int32", - "description": "The candidate\u2019s token id value.", - "type": "integer" - } - } - }, - "RegisterFilesResponse": { - "description": "Response for `RegisterFiles`.", - "type": "object", - "properties": { - "files": { - "description": "The registered files to be used when calling GenerateContent.", - "type": "array", - "items": { - "$ref": "#/components/schemas/File" - } + "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 } - } + }, + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field." }, - "ListTunedModelsResponse": { - "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "ListFileSearchStoresResponse": { + "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", "type": "object", "properties": { "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" }, - "tunedModels": { - "description": "The returned Models.", - "type": "array", + "fileSearchStores": { + "description": "The returned rag_stores.", "items": { - "$ref": "#/components/schemas/TunedModel" - } + "$ref": "#/components/schemas/FileSearchStore" + }, + "type": "array" } } }, - "UrlContext": { - "description": "Tool to support URL context retrieval.", + "FileSearchStore": { "type": "object", - "properties": {} - }, - "InputEmbedContentConfig": { "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", + "createTime": { + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", + "readOnly": true, "type": "string" }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedEmbedContentRequests" - } - }, - "description": "Configures the input to the batch request.", - "type": "object" - }, - "GeneratedFile": { - "properties": { + "pendingDocumentsCount": { + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", + "readOnly": true, + "format": "int64" + }, + "sizeBytes": { + "type": "string", + "format": "int64", + "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 + }, "name": { - "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", + "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" }, - "mimeType": { - "description": "MIME type of the generatedFile.", + "activeDocumentsCount": { + "format": "int64", + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "readOnly": true, "type": "string" }, - "error": { - "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", - "$ref": "#/components/schemas/Status" - }, - "state": { - "readOnly": true, - "description": "Output only. The state of the GeneratedFile.", + "displayName": { "type": "string", - "enum": [ - "STATE_UNSPECIFIED", - "GENERATING", - "GENERATED", - "FAILED" - ], - "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": "A file generated on behalf of a user.", - "type": "object" - }, - "TunedModelSource": { - "properties": { - "tunedModel": { - "description": "Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model`", - "type": "string" + "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\"" }, - "baseModel": { + "updateTime": { + "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", "readOnly": true, - "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`", + "format": "google-datetime", "type": "string" - } - }, - "description": "Tuned model as a source for training a new model.", - "type": "object" - }, - "EmbedContentResponse": { - "properties": { - "embedding": { - "readOnly": true, - "$ref": "#/components/schemas/ContentEmbedding", - "description": "Output only. The embedding generated from the input content." }, - "usageMetadata": { - "description": "Output only. The usage metadata for the request.", + "failedDocumentsCount": { + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", "readOnly": true, - "$ref": "#/components/schemas/EmbeddingUsageMetadata" + "format": "int64", + "type": "string" } }, - "description": "The response to an `EmbedContentRequest`.", - "type": "object" + "description": "A `FileSearchStore` is a collection of `Document`s." }, - "CreateFileResponse": { - "description": "Response for `CreateFile`.", + "PlaceAnswerSources": { + "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", "type": "object", "properties": { - "file": { - "description": "Metadata for the created file.", - "$ref": "#/components/schemas/File" + "reviewSnippets": { + "items": { + "$ref": "#/components/schemas/ReviewSnippet" + }, + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", + "type": "array" } } }, - "ExecutableCode": { - "properties": { - "id": { - "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`.", - "type": "string" + "FunctionResponse": { + "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", + "type": "object", + "properties": { + "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.", + "additionalProperties": { + "description": "Properties of the object." + } }, - "code": { - "description": "Required. The code to be executed.", + "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" }, - "language": { - "description": "Required. Programming language of the `code`.", + "id": { "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." - ], + "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`." + }, + "parts": { + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionResponsePart" + }, + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types." + }, + "willContinue": { + "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" + }, + "scheduling": { "enum": [ - "LANGUAGE_UNSPECIFIED", - "PYTHON" + "SCHEDULING_UNSPECIFIED", + "SILENT", + "WHEN_IDLE", + "INTERRUPT" + ], + "type": "string", + "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." ] } + } + }, + "Content": { + "type": "object", + "properties": { + "parts": { + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", + "items": { + "$ref": "#/components/schemas/Part" + }, + "type": "array" + }, + "role": { + "type": "string", + "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset." + } }, - "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated.", - "type": "object" + "description": "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." }, - "Document": { - "description": "A `Document` is a collection of `Chunk`s.", + "ContentEmbedding": { "type": "object", "properties": { - "displayName": { - "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"", - "type": "string" + "values": { + "type": "array", + "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "items": { + "type": "number", + "format": "float" + } }, - "updateTime": { - "description": "Output only. The Timestamp of when the `Document` was last updated.", + "shape": { + "type": "array", + "items": { + "type": "integer", + "format": "int32" + }, + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048])." + } + }, + "description": "A list of floats representing an embedding." + }, + "Web": { + "description": "Chunk from the web.", + "type": "object", + "properties": { + "uri": { "type": "string", - "readOnly": true, - "format": "google-datetime" + "description": "Output only. URI reference of the chunk.", + "readOnly": true }, - "state": { - "readOnly": true, - "description": "Output only. Current state of the `Document`.", + "title": { + "type": "string", + "description": "Output only. Title of the chunk.", + "readOnly": true + } + } + }, + "ToolResponse": { + "type": "object", + "properties": { + "id": { "type": "string", + "description": "Optional. The identifier of the tool call this response is for." + }, + "toolType": { "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" ], + "type": "string", + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", "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." + "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." ] }, - "createTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Document` was created.", - "type": "string" + "response": { + "type": "object", + "description": "Optional. The tool response.", + "additionalProperties": { + "description": "Properties of the 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`." + }, + "McpServer": { + "type": "object", + "properties": { + "streamableHttpTransport": { + "description": "A transport that can stream HTTP requests and responses.", + "$ref": "#/components/schemas/StreamableHttpTransport" }, "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" - }, - "customMetadata": { - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", - "type": "array" - }, - "sizeBytes": { - "description": "Output only. The size of raw bytes ingested into the Document.", - "type": "string", - "readOnly": true, - "format": "int64" - }, - "mimeType": { - "readOnly": true, - "description": "Output only. The mime type of the Document.", + "description": "The name of the MCPServer.", "type": "string" } - } + }, + "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 5" }, - "StreamableHttpTransport": { + "CustomLongRunningOperation": { + "type": "object", "properties": { - "timeout": { - "format": "google-duration", - "description": "HTTP timeout for regular operations.", - "type": "string" - }, - "terminateOnClose": { - "description": "Whether to close the client session when the transport closes.", - "type": "boolean" + "name": { + "type": "string", + "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`." }, - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", - "type": "string" + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." }, - "headers": { - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", + "response": { "type": "object", + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", "additionalProperties": { - "type": "string" + "description": "Properties of the object. Contains field @type with type URL." } }, - "sseReadTimeout": { - "description": "Timeout for SSE read operations.", - "type": "string", - "format": "google-duration" + "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" + }, + "metadata": { + "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "type": "object" } - }, - "description": "A transport that can stream HTTP requests and responses. Next ID: 6", - "type": "object" + } }, - "ThinkingConfig": { + "UrlMetadata": { + "type": "object", "properties": { - "thinkingLevel": { - "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. If not specified, the default is HIGH. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", + "urlRetrievalStatus": { + "enum": [ + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" + ], "type": "string", + "description": "Status of the url retrieval.", "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" + "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." ] }, - "includeThoughts": { - "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", - "type": "boolean" - }, - "thinkingBudget": { - "format": "int32", - "description": "The number of thoughts tokens that the model should generate.", - "type": "integer" + "retrievedUrl": { + "type": "string", + "description": "Retrieved url by the tool." } }, - "description": "Config for thinking features.", - "type": "object" + "description": "Context of the a single url retrieval." }, - "EmbedContentBatch": { + "GenerationConfig": { + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "type": "object", "properties": { - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputEmbedContentConfig" + "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" }, - "output": { - "description": "Output only. The output of the batch request.", - "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchOutput" + "enableEnhancedCivicAnswers": { + "type": "boolean", + "description": "Optional. Enables enhanced civic answers. It may not be available for all models." }, - "createTime": { - "description": "Output only. The time at which the batch was created.", - "type": "string", - "readOnly": true, - "format": "google-datetime" + "speechConfig": { + "$ref": "#/components/schemas/SpeechConfig", + "description": "Optional. The speech generation config." }, - "displayName": { - "description": "Required. The user-defined name of this batch.", - "type": "string" + "imageConfig": { + "$ref": "#/components/schemas/ImageConfig", + "description": "Optional. Config for image generation. An error will be returned if this field is set for models that don't support these config options." }, - "updateTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. The time at which the batch was last updated.", + "seed": { + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "format": "int32", + "type": "integer" + }, + "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" }, - "state": { - "readOnly": true, - "description": "Output only. The state of the batch.", - "type": "string", - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" - ], - "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." - ] + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." }, - "name": { - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "type": "string", - "readOnly": true + "maxOutputTokens": { + "type": "integer", + "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function.", + "format": "int32" }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", - "type": "string", - "readOnly": true, - "format": "google-datetime" + "responseLogprobs": { + "type": "boolean", + "description": "Optional. If true, export the logprobs results in response." }, - "priority": { - "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.", - "type": "string" + "stopSequences": { + "type": "array", + "description": "Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response.", + "items": { + "type": "string" + } }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "mediaResolution": { + "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)." + ], + "description": "Optional. If specified, the media resolution specified will be used.", + "type": "string", + "enum": [ + "MEDIA_RESOLUTION_UNSPECIFIED", + "MEDIA_RESOLUTION_LOW", + "MEDIA_RESOLUTION_MEDIUM", + "MEDIA_RESOLUTION_HIGH" + ] }, - "batchStats": { - "description": "Output only. Stats about the batch.", - "readOnly": true, - "$ref": "#/components/schemas/EmbedContentBatchStats" - } - }, - "description": "A resource representing a batch of `EmbedContent` requests.", - "type": "object" - }, - "UploadToFileSearchStoreRequest": { - "properties": { - "chunkingConfig": { - "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", - "$ref": "#/components/schemas/ChunkingConfig" + "temperature": { + "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].", + "type": "number" }, - "mimeType": { - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", - "type": "string" + "topK": { + "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.", + "type": "integer" }, - "displayName": { - "description": "Optional. Display name of the created document.", - "type": "string" + "presencePenalty": { + "format": "float", + "description": "Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary.", + "type": "number" }, - "customMetadata": { + "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.", "items": { - "$ref": "#/components/schemas/CustomMetadata" + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "AUDIO", + "VIDEO" + ], + "type": "string", + "x-enum-descriptions": [ + "Default value.", + "Indicates the model should return text.", + "Indicates the model should return images.", + "Indicates the model should return audio.", + "Indicates the model should return video." + ] }, - "description": "Custom metadata to be associated with the data.", "type": "array" + }, + "logprobs": { + "type": "integer", + "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20].", + "format": "int32" + }, + "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" + }, + "frequencyPenalty": { + "type": "number", + "format": "float", + "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit." + }, + "topP": { + "type": "number", + "format": "float", + "description": "Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests." + }, + "candidateCount": { + "type": "integer", + "format": "int32", + "description": "Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family)" } - }, - "description": "Request for `UploadToFileSearchStore`.", - "type": "object" - }, - "Empty": { - "properties": {}, - "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", - "type": "object" + } }, - "InlinedEmbedContentRequests": { + "ListGeneratedFilesResponse": { + "type": "object", "properties": { - "requests": { + "generatedFiles": { "items": { - "$ref": "#/components/schemas/InlinedEmbedContentRequest" + "$ref": "#/components/schemas/GeneratedFile" }, - "description": "Required. The requests to be processed in the batch.", + "description": "The list of `GeneratedFile`s.", "type": "array" + }, + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." } }, - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", - "type": "object" + "description": "Response for `ListGeneratedFiles`." }, - "Operation": { - "description": "This resource represents a long-running operation that is the result of a network API call.", + "InlinedResponse": { "type": "object", "properties": { - "metadata": { - "description": "Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any.", - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } - }, - "name": { - "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`.", - "type": "string" - }, "error": { - "description": "The error result of the operation in case of failure or cancellation.", + "description": "Output only. The error encountered while processing the request.", + "readOnly": true, "$ref": "#/components/schemas/Status" }, - "done": { - "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", - "type": "boolean" - }, "response": { + "$ref": "#/components/schemas/GenerateContentResponse", + "description": "Output only. The response to the request.", + "readOnly": true + }, + "metadata": { + "description": "Output only. The metadata associated with the request.", + "readOnly": true, "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." + "description": "Properties of the 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`.", "type": "object" } - } - }, - "SpeakerVoiceConfig": { - "properties": { - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" - }, - "voiceConfig": { - "description": "Required. The configuration for the voice to use.", - "$ref": "#/components/schemas/VoiceConfig" - } }, - "description": "The configuration for a single speaker in a multi speaker setup.", - "type": "object" + "description": "The response to a single request in the batch." }, - "GenerateContentRequest": { + "File": { + "description": "A file uploaded to the API. Next ID: 15", + "type": "object", "properties": { - "store": { - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", - "type": "boolean" + "displayName": { + "type": "string", + "description": "Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: \"Welcome Image\"" }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "error": { + "description": "Output only. Error status if File processing failed.", + "readOnly": true, + "$ref": "#/components/schemas/Status" }, - "systemInstruction": { - "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", - "$ref": "#/components/schemas/Content" + "videoMetadata": { + "description": "Output only. Metadata for a video.", + "readOnly": true, + "$ref": "#/components/schemas/VideoFileMetadata" }, - "tools": { - "description": "Optional. A list of `Tools` the `Model` may use to generate the next response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the `Model`. Supported `Tool`s are `Function` and `code_execution`. Refer to the [Function calling](https://ai.google.dev/gemini-api/docs/function-calling) and the [Code execution](https://ai.google.dev/gemini-api/docs/code-execution) guides to learn more.", - "type": "array", - "items": { - "$ref": "#/components/schemas/Tool" - } - }, - "cachedContent": { - "description": "Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}`", + "state": { + "description": "Output only. Processing state of the File.", + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "File is being processed and cannot be used for inference yet.", + "File is processed and available for inference.", + "File failed processing." + ], + "enum": [ + "STATE_UNSPECIFIED", + "PROCESSING", + "ACTIVE", + "FAILED" + ], + "readOnly": true, "type": "string" }, - "safetySettings": { - "description": "Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications.", - "type": "array", - "items": { - "$ref": "#/components/schemas/SafetySetting" - } + "updateTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` was last updated.", + "readOnly": true }, - "generationConfig": { - "description": "Optional. Configuration options for model generation and outputs.", - "$ref": "#/components/schemas/GenerationConfig" + "createTime": { + "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` was created.", + "readOnly": true, + "type": "string" }, - "contents": { - "items": { - "$ref": "#/components/schemas/Content" - }, - "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request.", - "type": "array" + "sizeBytes": { + "format": "int64", + "description": "Output only. Size of the file in bytes.", + "readOnly": true, + "type": "string" }, - "serviceTier": { - "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ], + "uri": { + "description": "Output only. The uri of the `File`.", + "readOnly": true, + "type": "string" + }, + "source": { + "description": "Source of the File.", "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "Used if source is not specified.", + "Indicates the file is uploaded by the user.", + "Indicates the file is generated by Google.", + "Indicates the file is a registered, i.e. a Google Cloud Storage file." + ], + "enum": [ + "SOURCE_UNSPECIFIED", + "UPLOADED", + "GENERATED", + "REGISTERED" ], - "description": "Optional. The service tier of the request.", "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" + "mimeType": { + "type": "string", + "description": "Output only. MIME type of the file.", + "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": "google-datetime", + "type": "string" + }, + "name": { + "description": "Immutable. Identifier. The `File` resource name. The ID (name excluding the \"files/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456`", + "type": "string" + }, + "sha256Hash": { + "type": "string", + "description": "Output only. SHA-256 hash of the uploaded bytes.", + "readOnly": true, + "format": "byte" + }, + "downloadUri": { + "type": "string", + "description": "Output only. The download uri of the `File`.", + "readOnly": true } - }, - "description": "Request to generate a completion from the model.", - "type": "object" + } }, - "VoiceConfig": { + "ListModelsResponse": { + "type": "object", "properties": { - "prebuiltVoiceConfig": { - "description": "The configuration for the prebuilt voice to use.", - "$ref": "#/components/schemas/PrebuiltVoiceConfig" + "models": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Model" + }, + "description": "The returned Models." + }, + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", + "type": "string" } }, - "description": "The configuration for the voice to use.", - "type": "object" + "description": "Response from `ListModel` containing a paginated list of Models." }, - "PrebuiltVoiceConfig": { + "InlinedRequests": { + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", + "type": "object", "properties": { - "voiceName": { - "description": "The name of the preset voice to use.", - "type": "string" + "requests": { + "items": { + "$ref": "#/components/schemas/InlinedRequest" + }, + "description": "Required. The requests to be processed in the batch.", + "type": "array" } - }, - "description": "The configuration for the prebuilt speaker to use.", - "type": "object" + } }, - "WhiteSpaceConfig": { - "description": "Configuration for a white space chunking algorithm [white space delimited].", + "FileSearch": { "type": "object", "properties": { - "maxTokensPerChunk": { - "format": "int32", - "description": "Maximum number of tokens per chunk. Tokens are defined as words for this chunking algorithm. Note: we are defining tokens as words split by whitespace as opposed to the output of a tokenizer. The context window of the latest gemini embedding model as of 2025-04-17 is currently 8192 tokens. We assume that the average word is 5 characters. Therefore, we set the upper limit to 2**9, which is 512 words, or 2560 tokens, assuming worst case a character per token. This is a conservative estimate meant to prevent context window overflow.", - "type": "integer" + "fileSearchStoreNames": { + "items": { + "type": "string" + }, + "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", + "type": "array" }, - "maxOverlapTokens": { - "description": "Maximum number of overlapping tokens between two adjacent chunks.", + "topK": { "type": "integer", - "format": "int32" + "format": "int32", + "description": "Optional. The number of semantic retrieval chunks to retrieve." + }, + "metadataFilter": { + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", + "type": "string" } - } + }, + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API." }, - "EmbeddingUsageMetadata": { + "BatchEmbedContentsResponse": { + "description": "The response to a `BatchEmbedContentsRequest`.", + "type": "object", "properties": { - "promptTokenCount": { - "description": "Output only. Number of tokens in the prompt.", - "type": "integer", + "embeddings": { + "type": "array", + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", "readOnly": true, - "format": "int32" - }, - "promptTokenDetails": { "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were processed in the request input.", - "type": "array", + "$ref": "#/components/schemas/ContentEmbedding" + } + }, + "usageMetadata": { + "$ref": "#/components/schemas/EmbeddingUsageMetadata", + "description": "Output only. The usage metadata for the request.", "readOnly": true } - }, - "description": "Metadata on the usage of the embedding request.", - "type": "object" + } }, - "Interval": { + "InlinedEmbedContentResponses": { + "description": "The responses to the requests in the batch.", + "type": "object", "properties": { - "endTime": { - "format": "google-datetime", - "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end.", - "type": "string" - }, - "startTime": { - "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": "string" + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch.", + "readOnly": true, + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentResponse" + }, + "type": "array" } - }, - "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" + } }, - "TransferOwnershipRequest": { - "description": "Request to transfer the ownership of the tuned model.", + "ToolCall": { + "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`.", "type": "object", "properties": { - "emailAddress": { - "description": "Required. The email address of the user to whom the tuned model is being transferred to.", + "args": { + "type": "object", + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", + "additionalProperties": { + "description": "Properties of the object." + } + }, + "id": { + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", "type": "string" + }, + "toolType": { + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ], + "type": "string", + "description": "Required. The type of tool that was called.", + "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." + ] } } }, "SearchTypes": { - "description": "Different types of search that can be enabled on the GoogleSearch tool.", "type": "object", "properties": { "imageSearch": { - "description": "Optional. Enables image search. Image bytes are returned.", - "$ref": "#/components/schemas/ImageSearch" + "$ref": "#/components/schemas/ImageSearch", + "description": "Optional. Enables image search. Image bytes are returned." }, "webSearch": { "description": "Optional. Enables web search. Only text results are returned.", "$ref": "#/components/schemas/WebSearch" } - } + }, + "description": "Different types of search that can be enabled on the GoogleSearch tool." }, - "GroundingChunkStringList": { - "description": "A list of string values.", + "VoiceConfig": { "type": "object", "properties": { - "values": { - "items": { - "type": "string" - }, - "description": "The string values of the list.", - "type": "array" + "prebuiltVoiceConfig": { + "$ref": "#/components/schemas/PrebuiltVoiceConfig", + "description": "The configuration for the prebuilt voice to use." } - } + }, + "description": "The configuration for the voice to use." }, - "Content": { + "Hyperparameters": { + "type": "object", "properties": { - "parts": { - "items": { - "$ref": "#/components/schemas/Part" - }, - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", - "type": "array" + "learningRateMultiplier": { + "type": "number", + "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used.", + "format": "float" }, - "role": { - "description": "Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset.", - "type": "string" + "batchSize": { + "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples.", + "format": "int32", + "type": "integer" + }, + "learningRate": { + "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples.", + "format": "float", + "type": "number" + }, + "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" } }, - "description": "The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn.", - "type": "object" + "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance" }, - "CreateFileRequest": { + "FunctionResponseBlob": { + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", + "type": "object", "properties": { - "file": { - "description": "Optional. Metadata for the file to create.", - "$ref": "#/components/schemas/File" + "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)." + }, + "data": { + "type": "string", + "description": "Raw bytes for media formats.", + "format": "byte" } - }, - "description": "Request for `CreateFile`.", - "type": "object" + } }, - "Corpus": { - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "FunctionCallingConfig": { + "description": "Configuration for specifying function calling behavior.", "type": "object", "properties": { - "createTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Corpus` was created.", - "type": "string" - }, - "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" + "allowedFunctionNames": { + "type": "array", + "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names.", + "items": { + "type": "string" + } }, - "updateTime": { - "description": "Output only. The Timestamp of when the `Corpus` was last updated.", + "mode": { "type": "string", - "readOnly": true, - "format": "google-datetime" - }, - "name": { - "readOnly": true, - "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", - "type": "string" + "enum": [ + "MODE_UNSPECIFIED", + "AUTO", + "ANY", + "NONE", + "VALIDATED" + ], + "x-enum-descriptions": [ + "Unspecified function calling mode. This value should not be used.", + "Default model behavior, model decides to predict either a function call or a natural language response.", + "Model is constrained to always predicting a function call only. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\".", + "Model will not predict any function call. Model behavior is same as when not passing any function declarations.", + "Model decides to predict either a function call or a natural language response, but will validate function calls with constrained decoding. If \"allowed_function_names\" are set, the predicted function call will be limited to any one of \"allowed_function_names\", else the predicted function call will be any one of the provided \"function_declarations\"." + ], + "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO." } } }, - "GroundingChunkCustomMetadata": { + "Empty": { + "type": "object", + "properties": {}, + "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }" + }, + "LogprobsResultCandidate": { + "description": "Candidate for the logprobs token and score.", + "type": "object", "properties": { - "numericValue": { + "logProbability": { + "description": "The candidate's log probability.", "format": "float", - "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", "type": "number" }, - "key": { - "description": "The key of the metadata.", - "type": "string" - }, - "stringListValue": { - "description": "Optional. A list of string values for the metadata.", - "$ref": "#/components/schemas/GroundingChunkStringList" + "token": { + "type": "string", + "description": "The candidate\u2019s token string value." }, - "stringValue": { - "description": "Optional. The string value of the metadata.", - "type": "string" + "tokenId": { + "type": "integer", + "description": "The candidate\u2019s token id value.", + "format": "int32" } - }, - "description": "User provided metadata about the GroundingFact.", - "type": "object" + } }, - "Blob": { + "ListDocumentsResponse": { + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", + "type": "object", "properties": { - "data": { - "format": "byte", - "description": "Raw bytes for media formats.", - "type": "string" + "documents": { + "description": "The returned `Document`s.", + "items": { + "$ref": "#/components/schemas/Document" + }, + "type": "array" }, - "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).", + "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": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", - "type": "object" + } }, - "Web": { + "InlinedEmbedContentRequests": { + "type": "object", "properties": { - "uri": { - "readOnly": true, - "description": "Output only. URI reference of the chunk.", - "type": "string" - }, - "title": { - "readOnly": true, - "description": "Output only. Title of the chunk.", - "type": "string" + "requests": { + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentRequest" + }, + "description": "Required. The requests to be processed in the batch." } }, - "description": "Chunk from the web.", - "type": "object" + "description": "The requests to be processed in the batch if provided as part of the batch creation request." }, - "ToolCall": { - "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`.", + "TuningExamples": { + "description": "A set of tuning examples. Can be training or validation data.", "type": "object", "properties": { - "toolType": { - "description": "Required. The type of tool that was called.", - "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" - ] - }, - "args": { - "additionalProperties": { - "description": "Properties of the object." + "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" }, - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", - "type": "object" - }, - "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", - "type": "string" + "type": "array" } } }, - "BatchGenerateContentRequest": { - "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/GenerateContentBatch" - } - }, - "description": "Request for a `BatchGenerateContent` operation.", - "type": "object" - }, - "TuningSnapshot": { - "description": "Record for a single tuning step.", + "Interval": { "type": "object", "properties": { - "epoch": { - "description": "Output only. The epoch this step was part of.", - "type": "integer", - "readOnly": true, - "format": "int32" - }, - "meanLoss": { - "description": "Output only. The mean loss of the training examples for this step.", - "type": "number", - "readOnly": true, - "format": "float" - }, - "computeTime": { - "readOnly": true, + "startTime": { + "type": "string", "format": "google-datetime", - "description": "Output only. The timestamp when this metric was computed.", - "type": "string" + "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start." }, - "step": { - "readOnly": true, - "format": "int32", - "description": "Output only. The tuning step.", - "type": "integer" + "endTime": { + "type": "string", + "format": "google-datetime", + "description": "Optional. Exclusive end of the interval. If specified, a Timestamp matching this interval will have to be before the end." } - } + }, + "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." }, - "GenerationConfig": { + "Schema": { + "type": "object", "properties": { - "enableEnhancedCivicAnswers": { - "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", - "type": "boolean" - }, - "mediaResolution": { + "type": { "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" + "TYPE_UNSPECIFIED", + "STRING", + "NUMBER", + "INTEGER", + "BOOLEAN", + "ARRAY", + "OBJECT", + "NULL" ], - "description": "Optional. If specified, the media resolution specified will be used.", "type": "string", + "description": "Required. Data type.", "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)." + "Not specified, should not be used.", + "String type.", + "Number type.", + "Integer type.", + "Boolean type.", + "Array type.", + "Object type.", + "Null type." ] }, - "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.", + "required": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Optional. Required properties of Type.OBJECT." + }, + "description": { + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "type": "string" + }, + "items": { + "description": "Optional. Schema of the elements of Type.ARRAY.", "$ref": "#/components/schemas/Schema" }, - "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" + "minProperties": { + "description": "Optional. Minimum number of the properties for Type.OBJECT.", + "format": "int64", + "type": "string" }, - "topK": { - "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.", - "type": "integer" + "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." }, - "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.", + "anyOf": { "type": "array", + "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", "items": { - "type": "string" + "$ref": "#/components/schemas/Schema" } }, - "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" + "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.", + "items": { + "type": "string" + }, + "type": "array" }, - "responseLogprobs": { - "description": "Optional. If true, export the logprobs results in response.", - "type": "boolean" + "maxProperties": { + "type": "string", + "description": "Optional. Maximum number of the properties for Type.OBJECT.", + "format": "int64" }, - "temperature": { - "description": "Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0].", - "type": "number", - "format": "float" + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + }, + "type": "object" }, - "topP": { - "format": "float", - "description": "Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", - "type": "number" + "minLength": { + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "format": "int64", + "type": "string" }, - "speechConfig": { - "description": "Optional. The speech generation config.", - "$ref": "#/components/schemas/SpeechConfig" + "title": { + "description": "Optional. The title of the schema.", + "type": "string" }, - "imageConfig": { - "description": "Optional. Config for image generation. An error will be returned if this field is set for models that don't support these config options.", - "$ref": "#/components/schemas/ImageConfig" + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." }, - "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.", + "minimum": { "type": "number", - "format": "float" + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", + "format": "double" }, - "frequencyPenalty": { - "format": "float", - "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit.", - "type": "number" + "format": { + "type": "string", + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." }, - "responseModalities": { + "enum": { + "type": "array", "items": { - "x-enum-descriptions": [ - "Default value.", - "Indicates the model should return text.", - "Indicates the model should return images.", - "Indicates the model should return audio.", - "Indicates the model should return video." - ], - "type": "string", - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "AUDIO", - "VIDEO" - ] + "type": "string" }, - "description": "Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text.", - "type": "array" + "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}" }, - "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" + "minItems": { + "type": "string", + "format": "int64", + "description": "Optional. Minimum number of the elements for Type.ARRAY." }, - "seed": { - "format": "int32", - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", - "type": "integer" + "pattern": { + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", + "type": "string" }, - "candidateCount": { - "description": "Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family)", - "type": "integer", - "format": "int32" + "maxLength": { + "description": "Optional. Maximum length of the Type.STRING", + "format": "int64", + "type": "string" }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." + "maxItems": { + "description": "Optional. Maximum number of the elements for Type.ARRAY.", + "format": "int64", + "type": "string" }, - "logprobs": { - "description": "Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20].", - "type": "integer", - "format": "int32" + "maximum": { + "type": "number", + "format": "double", + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER" + }, + "nullable": { + "description": "Optional. Indicates if the value may be null.", + "type": "boolean" } }, - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", - "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)." }, - "Candidate": { - "description": "A response candidate generated from the model.", + "WebSearch": { + "type": "object", + "properties": {}, + "description": "Standard web search for grounding and related configurations." + }, + "CountTokensRequest": { "type": "object", "properties": { - "avgLogprobs": { - "description": "Output only. Average log probability score of the candidate.", - "type": "number", - "readOnly": true, - "format": "double" - }, - "index": { - "description": "Output only. Index of the candidate in the list of response candidates.", - "type": "integer", - "readOnly": true, - "format": "int32" + "contents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + }, + "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set." }, - "finishReason": { - "readOnly": true, - "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", - "type": "string", - "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" + "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`." + }, + "ModelStatus": { + "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable.", + "type": "object", + "properties": { + "modelStage": { + "description": "The stage of the underlying model.", + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false ], "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." - ] + "Unspecified model stage.", + "The underlying model is subject to lots of tunings.", + "Models in this stage are for experimental purposes only.", + "Models in this stage are more mature than experimental models.", + "Models in this stage are considered stable and ready for production use.", + "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", + "Models in this stage are deprecated. These models cannot be used.", + "Models in this stage are retired. These models cannot be used." + ], + "enum": [ + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" + ], + "type": "string" }, - "urlContextMetadata": { - "description": "Output only. Metadata related to url context retrieval tool.", - "readOnly": true, - "$ref": "#/components/schemas/UrlContextMetadata" + "retirementTime": { + "type": "string", + "format": "google-datetime", + "description": "The time at which the model will be retired." }, - "groundingAttributions": { - "readOnly": true, + "message": { + "description": "A message explaining the model status.", + "type": "string" + } + } + }, + "CitationMetadata": { + "type": "object", + "properties": { + "citationSources": { + "description": "Citations to sources for a specific response.", "items": { - "$ref": "#/components/schemas/GroundingAttribution" + "$ref": "#/components/schemas/CitationSource" }, - "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", "type": "array" + } + }, + "description": "A collection of source attributions for a piece of content." + }, + "AttributionSourceId": { + "type": "object", + "properties": { + "groundingPassage": { + "$ref": "#/components/schemas/GroundingPassageId", + "description": "Identifier for an inline passage." }, - "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" - } + "semanticRetrieverChunk": { + "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", + "$ref": "#/components/schemas/SemanticRetrieverChunk" + } + }, + "description": "Identifier for the source contributing to this attribution." + }, + "EmbedContentBatchStats": { + "type": "object", + "properties": { + "failedRequestCount": { + "type": "string", + "description": "Output only. The number of requests that failed to be processed.", + "readOnly": true, + "format": "int64" }, - "citationMetadata": { + "successfulRequestCount": { + "format": "int64", + "description": "Output only. The number of requests that were successfully processed.", "readOnly": true, - "$ref": "#/components/schemas/CitationMetadata", - "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data." + "type": "string" }, - "tokenCount": { - "description": "Output only. Token count for this candidate.", - "type": "integer", + "requestCount": { + "type": "string", + "format": "int64", + "description": "Output only. The number of requests in the batch.", + "readOnly": true + }, + "pendingRequestCount": { + "type": "string", + "description": "Output only. The number of requests that are still pending processing.", "readOnly": true, - "format": "int32" + "format": "int64" + } + }, + "description": "Stats about the batch." + }, + "SpeechConfig": { + "type": "object", + "properties": { + "multiSpeakerVoiceConfig": { + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig", + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field." }, - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "languageCode": { + "type": "string", + "description": "Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`." + }, + "voiceConfig": { + "$ref": "#/components/schemas/VoiceConfig", + "description": "The configuration in case of single-voice output." + } + }, + "description": "Config for speech generation and transcription." + }, + "GoogleMaps": { + "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", + "type": "object", + "properties": { + "enableWidget": { + "type": "boolean", + "description": "Optional. Whether to return a widget context token in the GroundingMetadata of the response. Developers can use the widget context token to render a Google Maps widget with geospatial context related to the places that the model references in the response." + } + } + }, + "TuningExample": { + "type": "object", + "properties": { + "textInput": { + "description": "Optional. Text model input.", + "type": "string" + }, + "output": { + "description": "Required. The expected model output.", + "type": "string" + } + }, + "description": "A single example for tuning." + }, + "Dataset": { + "description": "Dataset for training or validation.", + "type": "object", + "properties": { + "examples": { + "description": "Optional. Inline examples with simple input/output text.", + "$ref": "#/components/schemas/TuningExamples" + } + } + }, + "AsyncBatchEmbedContentRequest": { + "type": "object", + "properties": { + "batch": { + "$ref": "#/components/schemas/EmbedContentBatch", + "description": "Required. The batch to create." + } + }, + "description": "Request for an `AsyncBatchEmbedContent` operation." + }, + "Corpus": { + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "type": "object", + "properties": { + "displayName": { + "description": "Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"", + "type": "string" + }, + "createTime": { + "description": "Output only. The Timestamp of when the `Corpus` was created.", "readOnly": true, - "$ref": "#/components/schemas/LogprobsResult" + "format": "google-datetime", + "type": "string" }, - "finishMessage": { - "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.", + "updateTime": { "type": "string", + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `Corpus` was last updated.", "readOnly": true }, - "groundingMetadata": { - "readOnly": true, - "$ref": "#/components/schemas/GroundingMetadata", - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls." - }, - "content": { - "description": "Output only. Generated content returned from the model.", - "readOnly": true, - "$ref": "#/components/schemas/Content" + "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 } } }, - "FunctionResponse": { + "SpeakerVoiceConfig": { + "type": "object", "properties": { - "id": { - "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`.", + "speaker": { + "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", "type": "string" }, - "response": { + "voiceConfig": { + "$ref": "#/components/schemas/VoiceConfig", + "description": "Required. The configuration for the voice to use." + } + }, + "description": "The configuration for a single speaker in a multi speaker setup." + }, + "ImageSearch": { + "description": "Image search for grounding and related configurations.", + "type": "object", + "properties": {} + }, + "PrebuiltVoiceConfig": { + "description": "The configuration for the prebuilt speaker to use.", + "type": "object", + "properties": { + "voiceName": { + "description": "The name of the preset voice to use.", + "type": "string" + } + } + }, + "InlinedEmbedContentRequest": { + "type": "object", + "properties": { + "metadata": { + "description": "Optional. The metadata to be associated with the request.", "additionalProperties": { "description": "Properties of the object." }, - "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model.", "type": "object" }, - "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" - }, - "parts": { - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", - "type": "array", - "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - } - }, - "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" - }, - "scheduling": { - "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" - ], - "x-enum-descriptions": [ - "This value is unused.", - "Only add the result to the conversation context, do not interrupt or trigger generation.", - "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", - "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." - ], - "description": "Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE.", - "type": "string" + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/EmbedContentRequest" } }, - "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", - "type": "object" + "description": "The request to be processed in the batch." }, - "GoogleMaps": { + "GoogleSearchRetrieval": { + "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" + "dynamicRetrievalConfig": { + "$ref": "#/components/schemas/DynamicRetrievalConfig", + "description": "Specifies the dynamic retrieval configuration for the given source." } }, - "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", - "type": "object" + "description": "Tool to retrieve public web data for grounding, powered by Google." }, - "UsageMetadata": { - "description": "Metadata on the generation request's token usage.", + "GenerateContentResponse": { "type": "object", "properties": { - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content)", - "type": "integer", - "format": "int32" - }, - "thoughtsTokenCount": { - "readOnly": true, - "format": "int32", - "description": "Output only. Number of tokens of thoughts for thinking models.", - "type": "integer" + "promptFeedback": { + "$ref": "#/components/schemas/PromptFeedback", + "description": "Returns the prompt's feedback related to the content filters." }, - "promptTokenCount": { - "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content.", - "type": "integer", - "format": "int32" + "modelVersion": { + "type": "string", + "description": "Output only. The model version used to generate the response.", + "readOnly": true }, - "toolUsePromptTokenCount": { + "modelStatus": { + "description": "Output only. The current model status of this model.", "readOnly": true, - "format": "int32", - "description": "Output only. Number of tokens present in tool-use prompt(s).", - "type": "integer" + "$ref": "#/components/schemas/ModelStatus" }, - "toolUsePromptTokensDetails": { + "responseId": { + "description": "Output only. response_id is used to identify each response.", "readOnly": true, + "type": "string" + }, + "candidates": { + "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/Candidate" }, - "description": "Output only. List of modalities that were processed for tool-use request inputs.", - "type": "array" + "description": "Candidate responses from the model." }, - "totalTokenCount": { - "description": "Total token count for the generation request (prompt + response candidates).", - "type": "integer", - "format": "int32" + "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`." + }, + "TunedModel": { + "type": "object", + "properties": { + "baseModel": { + "type": "string", + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`" }, - "promptTokensDetails": { - "readOnly": true, + "readerProjectNumbers": { + "description": "Optional. List of project numbers that have read access to the tuned model.", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "type": "string", + "format": "int64" }, - "description": "Output only. List of modalities that were processed in the request input.", "type": "array" }, - "candidatesTokensDetails": { + "temperature": { + "type": "number", + "format": "float", + "description": "Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model." + }, + "tunedModelSource": { + "$ref": "#/components/schemas/TunedModelSource", + "description": "Optional. TunedModel to use as the starting point for training the new model." + }, + "topK": { + "format": "int32", + "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model.", + "type": "integer" + }, + "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 + }, + "topP": { + "type": "number", + "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" + }, + "tuningTask": { + "$ref": "#/components/schemas/TuningTask", + "description": "Required. The tuning task that creates the tuned model." + }, + "displayName": { + "type": "string", + "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces." + }, + "createTime": { + "type": "string", + "description": "Output only. The timestamp when this model was created.", "readOnly": true, - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "description": "Output only. List of modalities that were returned in the response.", - "type": "array" + "format": "google-datetime" }, - "candidatesTokenCount": { - "description": "Total number of tokens across all the generated response candidates.", - "type": "integer", - "format": "int32" + "description": { + "description": "Optional. A short description of this model.", + "type": "string" }, - "cacheTokensDetails": { + "state": { + "type": "string", "readOnly": true, - "description": "Output only. List of modalities of the cached content in the request input.", - "type": "array", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" + ], + "x-enum-descriptions": [ + "The default value. This value is unused.", + "The model is being created.", + "The model is ready to be used.", + "The model failed to be created." + ], + "description": "Output only. The state of the tuned model." }, - "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", + "updateTime": { + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp when this model was updated.", "readOnly": true + } + }, + "description": "A fine-tuned model created using ModelService.CreateTunedModel." + }, + "SemanticRetrieverChunk": { + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", + "type": "object", + "properties": { + "source": { + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "readOnly": true, + "type": "string" }, - "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", + "chunk": { + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", "readOnly": true, - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } + "type": "string" } } }, - "ListCachedContentsResponse": { - "description": "Response with CachedContents list.", + "GenerateContentBatchOutput": { "type": "object", "properties": { - "cachedContents": { - "description": "List of cached contents.", - "type": "array", - "items": { - "$ref": "#/components/schemas/CachedContent" - } + "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 }, - "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" + "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 } - } + }, + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field." }, - "TunedModel": { - "description": "A fine-tuned model created using ModelService.CreateTunedModel.", + "Model": { "type": "object", "properties": { - "displayName": { - "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces.", + "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" }, + "topP": { + "format": "float", + "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", + "type": "number" + }, + "temperature": { + "type": "number", + "format": "float", + "description": "Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model." + }, + "baseModelId": { + "type": "string", + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`" + }, "topK": { "format": "int32", - "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model.", + "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter.", "type": "integer" }, - "state": { - "readOnly": true, - "description": "Output only. The state of the tuned model.", + "description": { "type": "string", - "enum": [ - "STATE_UNSPECIFIED", - "CREATING", - "ACTIVE", - "FAILED" - ], - "x-enum-descriptions": [ - "The default value. This value is unused.", - "The model is being created.", - "The model is ready to be used.", - "The model failed to be created." - ] + "description": "A short description of the model." }, - "baseModel": { - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", - "type": "string" + "inputTokenLimit": { + "type": "integer", + "description": "Maximum number of input tokens allowed for this model.", + "format": "int32" }, - "name": { - "readOnly": true, - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", - "type": "string" + "thinking": { + "description": "Whether the model supports thinking.", + "type": "boolean" }, - "temperature": { - "description": "Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model.", - "type": "number", - "format": "float" + "supportedGenerationMethods": { + "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`.", + "type": "array" }, - "tuningTask": { - "description": "Required. The tuning task that creates the tuned model.", - "$ref": "#/components/schemas/TuningTask" + "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." }, - "description": { - "description": "Optional. A short description of this model.", - "type": "string" + "version": { + "type": "string", + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)" }, - "topP": { - "format": "float", - "description": "Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model.", - "type": "number" + "maxTemperature": { + "type": "number", + "description": "The maximum temperature this model can use.", + "format": "float" }, - "tunedModelSource": { - "description": "Optional. TunedModel to use as the starting point for training the new model.", - "$ref": "#/components/schemas/TunedModelSource" + "outputTokenLimit": { + "description": "Maximum number of output tokens available for this model.", + "format": "int32", + "type": "integer" + } + }, + "description": "Information about a Generative Language Model." + }, + "GroundingPassageId": { + "description": "Identifier for a part within a `GroundingPassage`.", + "type": "object", + "properties": { + "partIndex": { + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", + "readOnly": true, + "format": "int32", + "type": "integer" }, - "updateTime": { - "description": "Output only. The timestamp when this model was updated.", + "passageId": { "type": "string", - "readOnly": true, - "format": "google-datetime" + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`.", + "readOnly": true + } + } + }, + "RetrievalConfig": { + "type": "object", + "properties": { + "latLng": { + "$ref": "#/components/schemas/LatLng", + "description": "Optional. The location of the user." }, - "createTime": { - "readOnly": true, - "format": "google-datetime", - "description": "Output only. The timestamp when this model was created.", - "type": "string" + "languageCode": { + "type": "string", + "description": "Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt)." + } + }, + "description": "Retrieval config." + }, + "InlinedRequest": { + "type": "object", + "properties": { + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/GenerateContentRequest" }, - "readerProjectNumbers": { - "items": { - "format": "int64", - "type": "string" + "metadata": { + "description": "Optional. The metadata to be associated with the request.", + "additionalProperties": { + "description": "Properties of the object." }, - "description": "Optional. List of project numbers that have read access to the tuned model.", - "type": "array" + "type": "object" } - } + }, + "description": "The request to be processed in the batch." }, - "Status": { - "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", + "CountTokensResponse": { "type": "object", "properties": { - "code": { + "totalTokens": { + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", "format": "int32", - "description": "The status code, which should be an enum value of google.rpc.Code.", "type": "integer" }, - "details": { + "cachedContentTokenCount": { + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content).", + "type": "integer" + }, + "cacheTokensDetails": { "items": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } + "$ref": "#/components/schemas/ModalityTokenCount" }, - "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", + "description": "Output only. List of modalities that were processed in the cached content.", + "readOnly": true, "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" - } - } - }, - "RegisterFilesRequest": { - "properties": { - "uris": { + "promptTokensDetails": { + "type": "array", "items": { - "type": "string" + "$ref": "#/components/schemas/ModalityTokenCount" }, - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", - "type": "array" + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true } }, - "description": "Request for `RegisterFiles`.", - "type": "object" + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`." }, - "BatchStats": { - "description": "Stats about the batch.", + "Permission": { + "description": "Permission resource grants user, group or the rest of the world access to the PaLM API resource (e.g. a tuned model, corpus). A role is a collection of permitted operations that allows users to perform specific actions on PaLM API resources. To make them available to users, groups, or service accounts, you assign roles. When you assign a role, you grant permissions that the role contains. There are three concentric roles. Each role is a superset of the previous role's permitted operations: - reader can use the resource (e.g. tuned model, corpus) for inference - writer has reader's permissions and additionally can edit and share - owner has writer's permissions and additionally can delete", "type": "object", "properties": { - "successfulRequestCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of requests that were successfully processed.", - "type": "string" - }, - "requestCount": { - "readOnly": true, - "format": "int64", - "description": "Output only. The number of requests in the batch.", - "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 }, - "failedRequestCount": { - "description": "Output only. The number of requests that failed to be processed.", + "emailAddress": { "type": "string", - "readOnly": true, - "format": "int64" + "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." }, - "pendingRequestCount": { - "description": "Output only. The number of requests that are still pending processing.", + "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." + ], + "enum": [ + "GRANTEE_TYPE_UNSPECIFIED", + "USER", + "GROUP", + "EVERYONE" + ], + "type": "string" + }, + "role": { + "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." + ], + "description": "Required. The role granted by this permission.", "type": "string", - "readOnly": true, - "format": "int64" + "enum": [ + "ROLE_UNSPECIFIED", + "OWNER", + "WRITER", + "READER" + ] } } }, - "CountTokensRequest": { + "RegisterFilesRequest": { + "description": "Request for `RegisterFiles`.", + "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.", + "uris": { "type": "array", "items": { - "$ref": "#/components/schemas/Content" - } - }, - "generateContentRequest": { - "description": "Optional. The overall input given to the `Model`. This includes the prompt as well as other model steering information like [system instructions](https://ai.google.dev/gemini-api/docs/system-instructions), and/or function declarations for [function calling](https://ai.google.dev/gemini-api/docs/function-calling). `Model`s/`Content`s and `generate_content_request`s are mutually exclusive. You can either send `Model` + `Content`s or a `generate_content_request`, but never both.", - "$ref": "#/components/schemas/GenerateContentRequest" + "type": "string" + }, + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/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`.", - "type": "object" + } + }, + "MultiSpeakerVoiceConfig": { + "description": "The configuration for the multi-speaker setup.", + "type": "object", + "properties": { + "speakerVoiceConfigs": { + "description": "Required. All the enabled speaker voices.", + "items": { + "$ref": "#/components/schemas/SpeakerVoiceConfig" + }, + "type": "array" + } + } } } }