From 49c20f039d0c60f0687bf737e743adaa92fa75c9 Mon Sep 17 00:00:00 2001 From: "github-actions[bot]" Date: Thu, 25 Jun 2026 22:19:52 +0000 Subject: [PATCH] feat: Updated OpenAPI spec --- ...Client.BatchesUpdateEmbedContentBatch.g.cs | 16 +- ...ent.BatchesUpdateGenerateContentBatch.g.cs | 16 +- ...ini.GeminiClient.CachedContentsCreate.g.cs | 50 +- ...mini.GeminiClient.CachedContentsPatch.g.cs | 50 +- ...GeminiClient.CorporaPermissionsCreate.g.cs | 10 +- ....GeminiClient.CorporaPermissionsPatch.g.cs | 10 +- ...i.GeminiClient.DynamicGenerateContent.g.cs | 52 +- ...niClient.DynamicStreamGenerateContent.g.cs | 52 +- ....DynamicStreamGenerateContentAsStream.g.cs | 52 +- ...i.GeminiClient.FileSearchStoresCreate.g.cs | 10 +- ...miniClient.FileSearchStoresImportFile.g.cs | 10 +- ...niClient.MediaUploadToFileSearchStore.g.cs | 10 +- ...emini.GeminiClient.ModelsEmbedContent.g.cs | 16 +- ...ni.GeminiClient.ModelsGenerateContent.g.cs | 52 +- ...iniClient.ModelsStreamGenerateContent.g.cs | 52 +- ...t.ModelsStreamGenerateContentAsStream.g.cs | 52 +- ...Gemini.GeminiClient.TunedModelsCreate.g.cs | 44 +- ...miniClient.TunedModelsGenerateContent.g.cs | 52 +- ....Gemini.GeminiClient.TunedModelsPatch.g.cs | 44 +- ...niClient.TunedModelsPermissionsCreate.g.cs | 10 +- ...iniClient.TunedModelsPermissionsPatch.g.cs | 10 +- ...ient.TunedModelsStreamGenerateContent.g.cs | 52 +- ...edModelsStreamGenerateContentAsStream.g.cs | 52 +- ...Client.BatchesUpdateEmbedContentBatch.g.cs | 12 +- ...ent.BatchesUpdateGenerateContentBatch.g.cs | 12 +- ...ni.IGeminiClient.CachedContentsCreate.g.cs | 40 +- ...ini.IGeminiClient.CachedContentsPatch.g.cs | 40 +- ...GeminiClient.CorporaPermissionsCreate.g.cs | 8 +- ...IGeminiClient.CorporaPermissionsPatch.g.cs | 8 +- ....IGeminiClient.DynamicGenerateContent.g.cs | 40 +- ...niClient.DynamicStreamGenerateContent.g.cs | 40 +- ....DynamicStreamGenerateContentAsStream.g.cs | 40 +- ....IGeminiClient.FileSearchStoresCreate.g.cs | 8 +- ...miniClient.FileSearchStoresImportFile.g.cs | 8 +- ...niClient.MediaUploadToFileSearchStore.g.cs | 8 +- ...mini.IGeminiClient.ModelsEmbedContent.g.cs | 12 +- ...i.IGeminiClient.ModelsGenerateContent.g.cs | 40 +- ...iniClient.ModelsStreamGenerateContent.g.cs | 40 +- ...t.ModelsStreamGenerateContentAsStream.g.cs | 40 +- ...emini.IGeminiClient.TunedModelsCreate.g.cs | 34 +- ...miniClient.TunedModelsGenerateContent.g.cs | 40 +- ...Gemini.IGeminiClient.TunedModelsPatch.g.cs | 34 +- ...niClient.TunedModelsPermissionsCreate.g.cs | 8 +- ...iniClient.TunedModelsPermissionsPatch.g.cs | 8 +- ...ient.TunedModelsStreamGenerateContent.g.cs | 40 +- ...edModelsStreamGenerateContentAsStream.g.cs | 40 +- .../Google.Gemini.JsonSerializerContext.g.cs | 648 +- ...gle.Gemini.JsonSerializerContextTypes.g.cs | 588 +- ...gle.Gemini.Models.AudioResponseFormat.g.cs | 40 +- .../Google.Gemini.Models.BatchStats.g.cs | 40 +- .../Generated/Google.Gemini.Models.Blob.g.cs | 24 +- .../Google.Gemini.Models.CachedContent.g.cs | 154 +- .../Google.Gemini.Models.Candidate.g.cs | 142 +- .../Google.Gemini.Models.CitationSource.g.cs | 24 +- ...gle.Gemini.Models.CodeExecutionResult.g.cs | 24 +- .../Google.Gemini.Models.ComputerUse.g.cs | 28 +- .../Google.Gemini.Models.Content.g.cs | 24 +- ...Google.Gemini.Models.ContentEmbedding.g.cs | 24 +- .../Google.Gemini.Models.Corpus.g.cs | 26 +- ...gle.Gemini.Models.CountTokensResponse.g.cs | 48 +- ...ini.Models.CustomLongRunningOperation.g.cs | 38 +- .../Google.Gemini.Models.CustomMetadata.g.cs | 46 +- .../Google.Gemini.Models.Document.g.cs | 86 +- ...oogle.Gemini.Models.EmbedContentBatch.g.cs | 124 +- ....Gemini.Models.EmbedContentBatchStats.g.cs | 26 +- ...ogle.Gemini.Models.EmbedContentConfig.g.cs | 44 +- ...gle.Gemini.Models.EmbedContentRequest.g.cs | 50 +- ...le.Gemini.Models.EmbedContentResponse.g.cs | 24 +- ....Gemini.Models.EmbeddingUsageMetadata.g.cs | 26 +- .../Google.Gemini.Models.ExecutableCode.g.cs | 24 +- .../Generated/Google.Gemini.Models.File.g.cs | 150 +- .../Google.Gemini.Models.FileData.g.cs | 24 +- .../Google.Gemini.Models.FileSearchStore.g.cs | 98 +- .../Google.Gemini.Models.FunctionCall.g.cs | 24 +- ...gle.Gemini.Models.FunctionDeclaration.g.cs | 62 +- ...Google.Gemini.Models.FunctionResponse.g.cs | 58 +- ...le.Gemini.Models.FunctionResponseBlob.g.cs | 24 +- ...le.Gemini.Models.GenerateContentBatch.g.cs | 108 +- ...ini.Models.GenerateContentBatchOutput.g.cs | 24 +- ....Gemini.Models.GenerateContentRequest.g.cs | 102 +- ...Gemini.Models.GenerateContentResponse.g.cs | 58 +- ...Google.Gemini.Models.GenerationConfig.g.cs | 260 +- ...erativelanguageV1betaGroundingSupport.g.cs | 24 +- ...ogleAiGenerativelanguageV1betaSegment.g.cs | 24 +- .../Google.Gemini.Models.GoogleSearch.g.cs | 24 +- .../Google.Gemini.Models.GroundingChunk.g.cs | 22 +- ...i.Models.GroundingChunkCustomMetadata.g.cs | 24 +- ...oogle.Gemini.Models.GroundingMetadata.g.cs | 72 +- ...ogle.Gemini.Models.GroundingPassageId.g.cs | 26 +- .../Generated/Google.Gemini.Models.Image.g.cs | 22 +- ...gle.Gemini.Models.ImageResponseFormat.g.cs | 24 +- ...oogle.Gemini.Models.ImportFileRequest.g.cs | 24 +- ...ni.Models.InlinedEmbedContentResponse.g.cs | 24 +- .../Google.Gemini.Models.InlinedResponse.g.cs | 22 +- .../Google.Gemini.Models.InputConfig.g.cs | 24 +- .../Google.Gemini.Models.Interval.g.cs | 24 +- .../Google.Gemini.Models.LatLng.g.cs | 24 +- ...gle.Gemini.Models.ListCorporaResponse.g.cs | 24 +- ...e.Gemini.Models.ListDocumentsResponse.g.cs | 24 +- ...oogle.Gemini.Models.ListFilesResponse.g.cs | 24 +- ...Gemini.Models.ListTunedModelsResponse.g.cs | 24 +- ...Gemini.Models.LogprobsResultCandidate.g.cs | 24 +- .../Generated/Google.Gemini.Models.Maps.g.cs | 46 +- .../Google.Gemini.Models.McpServer.g.cs | 24 +- .../Generated/Google.Gemini.Models.Model.g.cs | 142 +- .../Google.Gemini.Models.ModelStatus.g.cs | 24 +- .../Google.Gemini.Models.Operation.g.cs | 36 +- .../Generated/Google.Gemini.Models.Part.g.cs | 150 +- .../Google.Gemini.Models.Permission.g.cs | 42 +- .../Google.Gemini.Models.PromptFeedback.g.cs | 24 +- ...le.Gemini.Models.ResponseFormatConfig.g.cs | 22 +- .../Google.Gemini.Models.RetrievalConfig.g.cs | 24 +- ...Google.Gemini.Models.RetrievedContext.g.cs | 60 +- .../Google.Gemini.Models.ReviewSnippet.g.cs | 28 +- .../Google.Gemini.Models.SafetySetting.g.cs | 26 +- .../Google.Gemini.Models.Schema.g.cs | 264 +- .../Google.Gemini.Models.SearchTypes.g.cs | 24 +- ....Gemini.Models.SemanticRetrieverChunk.g.cs | 26 +- ...ogle.Gemini.Models.SpeakerVoiceConfig.g.cs | 24 +- .../Google.Gemini.Models.SpeechConfig.g.cs | 24 +- .../Google.Gemini.Models.Status.g.cs | 24 +- ...Gemini.Models.StreamableHttpTransport.g.cs | 46 +- ...ogle.Gemini.Models.TextResponseFormat.g.cs | 24 +- .../Google.Gemini.Models.ThinkingConfig.g.cs | 26 +- .../Generated/Google.Gemini.Models.Tool.g.cs | 88 +- .../Google.Gemini.Models.ToolCall.g.cs | 24 +- .../Google.Gemini.Models.ToolResponse.g.cs | 28 +- ...oogle.Gemini.Models.TranslationConfig.g.cs | 24 +- .../Google.Gemini.Models.TunedModel.g.cs | 148 +- ...Google.Gemini.Models.TunedModelSource.g.cs | 24 +- .../Google.Gemini.Models.TuningSnapshot.g.cs | 50 +- .../Google.Gemini.Models.TuningTask.g.cs | 46 +- ...Models.UploadToFileSearchStoreRequest.g.cs | 24 +- .../Google.Gemini.Models.UrlMetadata.g.cs | 24 +- .../Google.Gemini.Models.UsageMetadata.g.cs | 136 +- .../Google.Gemini.Models.VideoMetadata.g.cs | 26 +- src/libs/Google.Gemini/openapi.json | 8452 ++++++++--------- 137 files changed, 7718 insertions(+), 7718 deletions(-) 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 f4016144..2d4153da 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateEmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.BatchesUpdateEmbedContentBatch.g.cs @@ -451,14 +451,14 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// Configures the input to the batch request. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// /// /// Required. The user-defined name of this batch. @@ -473,9 +473,9 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( string batchesId, string? updateMask = default, string? model = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, - global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, string? priority = default, + global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, string? displayName = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, @@ -484,9 +484,9 @@ partial void ProcessBatchesUpdateEmbedContentBatchResponseContent( var __request = new global::Google.Gemini.EmbedContentBatch { Model = model, - Output = output, - InputConfig = inputConfig, Priority = priority, + InputConfig = inputConfig, + Output = output, DisplayName = displayName, 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 e94cbd91..0085769f 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 @@ -457,14 +457,14 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// Configures the input to the batch request. /// - /// - /// 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}`. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -475,9 +475,9 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( string? displayName = default, global::Google.Gemini.BatchStats? batchStats = default, global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? model = default, - global::Google.Gemini.InputConfig? inputConfig = default, string? priority = default, + global::Google.Gemini.InputConfig? inputConfig = default, + string? model = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { @@ -486,9 +486,9 @@ partial void ProcessBatchesUpdateGenerateContentBatchResponseContent( DisplayName = displayName, BatchStats = batchStats, Output = output, - Model = model, - InputConfig = inputConfig, Priority = priority, + InputConfig = inputConfig, + Model = model, }; 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 77b69a37..7b8ea312 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsCreate.g.cs @@ -425,6 +425,21 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Creates CachedContent resource. /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Input only. New TTL for this resource, input only. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// 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. /// @@ -434,51 +449,36 @@ partial void ProcessCachedContentsCreateResponseContent( /// /// Metadata on the usage of the cached content. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsCreateAsync( + string? expireTime = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + string? ttl = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, string? displayName = default, global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? ttl = default, - string? expireTime = default, global::System.Collections.Generic.IList? contents = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { + ExpireTime = expireTime, + ToolConfig = toolConfig, + Ttl = ttl, + Tools = tools, + Model = model, DisplayName = displayName, SystemInstruction = systemInstruction, UsageMetadata = usageMetadata, - Ttl = ttl, - ExpireTime = expireTime, Contents = contents, - Model = model, - Tools = tools, - ToolConfig = toolConfig, }; 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 8c31d2e3..35a8dd03 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CachedContentsPatch.g.cs @@ -448,6 +448,21 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Input only. New TTL for this resource, input only. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// 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. /// @@ -457,53 +472,38 @@ partial void ProcessCachedContentsPatchResponseContent( /// /// Metadata on the usage of the cached content. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, + string? expireTime = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + string? ttl = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, string? displayName = default, global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? ttl = default, - string? expireTime = default, global::System.Collections.Generic.IList? contents = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.CachedContent { + ExpireTime = expireTime, + ToolConfig = toolConfig, + Ttl = ttl, + Tools = tools, + Model = model, DisplayName = displayName, SystemInstruction = systemInstruction, UsageMetadata = usageMetadata, - Ttl = ttl, - ExpireTime = expireTime, Contents = contents, - Model = model, - Tools = tools, - ToolConfig = toolConfig, }; return await CachedContentsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs index fe472747..5e53cccf 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsCreate.g.cs @@ -438,28 +438,28 @@ partial void ProcessCorporaPermissionsCreateResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task CorporaPermissionsCreateAsync( string corporaId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await CorporaPermissionsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs index 1d67f6ca..ed2f0c85 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.CorporaPermissionsPatch.g.cs @@ -461,12 +461,12 @@ partial void ProcessCorporaPermissionsPatchResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -475,16 +475,16 @@ partial void ProcessCorporaPermissionsPatchResponseContent( string corporaId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await CorporaPermissionsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs index cbbf25c9..1f8a0c60 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicGenerateContent.g.cs @@ -435,17 +435,14 @@ partial void ProcessDynamicGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -453,48 +450,51 @@ partial void ProcessDynamicGenerateContentResponseContent( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 860a2c6a..b3036690 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContent.g.cs @@ -435,17 +435,14 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -453,48 +450,51 @@ partial void ProcessDynamicStreamGenerateContentResponseContent( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 92dd5084..0efbed3c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -376,17 +376,14 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -394,48 +391,51 @@ partial void ProcessDynamicStreamGenerateContentAsStreamResponse( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + CachedContent = cachedContent, }; var __enumerable = DynamicStreamGenerateContentAsStreamAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs index 7dac3545..9f8368aa 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresCreate.g.cs @@ -425,25 +425,25 @@ partial void ProcessFileSearchStoresCreateResponseContent( /// /// Creates an empty `FileSearchStore`. /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. - /// /// /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task FileSearchStoresCreateAsync( - string? embeddingModel = default, string? displayName = default, + string? embeddingModel = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.FileSearchStore { - EmbeddingModel = embeddingModel, DisplayName = displayName, + EmbeddingModel = embeddingModel, }; return await FileSearchStoresCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs index 84aaacd5..945fb3d5 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.FileSearchStoresImportFile.g.cs @@ -435,31 +435,31 @@ partial void ProcessFileSearchStoresImportFileResponseContent( /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Custom metadata to be associated with the file. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, - global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? fileName = default, + global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.ImportFileRequest { - CustomMetadata = customMetadata, ChunkingConfig = chunkingConfig, FileName = fileName, + CustomMetadata = customMetadata, }; return await FileSearchStoresImportFileAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs index 94a4e2f0..a013d49f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.MediaUploadToFileSearchStore.g.cs @@ -435,6 +435,9 @@ 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. /// @@ -444,27 +447,24 @@ partial void ProcessMediaUploadToFileSearchStoreResponseContent( /// /// Custom metadata to be associated with the data. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// 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, - 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, - 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 160bbf91..c4e0cb91 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsEmbedContent.g.cs @@ -437,31 +437,31 @@ partial void ProcessModelsEmbedContentResponseContent( /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// Configurations for the EmbedContent request. + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// + /// Configurations for the EmbedContent request. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, - global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, - global::Google.Gemini.Content? content = default, string? model = default, + global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.EmbedContentRequest { - EmbedContentConfig = embedContentConfig, - Content = content, Model = model, + Content = content, + EmbedContentConfig = embedContentConfig, }; return await ModelsEmbedContentAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs index b43b8d4a..4c1df37c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsGenerateContent.g.cs @@ -435,17 +435,14 @@ partial void ProcessModelsGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -453,48 +450,51 @@ partial void ProcessModelsGenerateContentResponseContent( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 bec5b9d4..5d99b791 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContent.g.cs @@ -435,17 +435,14 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -453,48 +450,51 @@ partial void ProcessModelsStreamGenerateContentResponseContent( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 9eb2e4f5..83f9a00e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -376,17 +376,14 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -394,48 +391,51 @@ partial void ProcessModelsStreamGenerateContentAsStreamResponse( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 6395a087..8bb84c8c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsCreate.g.cs @@ -438,61 +438,61 @@ partial void ProcessTunedModelsCreateResponseContent( /// Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222 /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Optional. 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. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// /// Optional. A short description of this model. /// - /// - /// Tuned model as a source for training a new model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, + string? baseModel = default, string? displayName = default, - int? topK = default, + global::Google.Gemini.TuningTask? tuningTask = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, string? description = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? topP = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? baseModel = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, + int? topK = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { + BaseModel = baseModel, DisplayName = displayName, - TopK = topK, + TuningTask = tuningTask, + ReaderProjectNumbers = readerProjectNumbers, Description = description, - TunedModelSource = tunedModelSource, TopP = topP, - ReaderProjectNumbers = readerProjectNumbers, - BaseModel = baseModel, + TunedModelSource = tunedModelSource, Temperature = temperature, - TuningTask = tuningTask, + TopK = topK, }; 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 91eb84a1..2ec7ba52 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsGenerateContent.g.cs @@ -435,17 +435,14 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -453,48 +450,51 @@ partial void ProcessTunedModelsGenerateContentResponseContent( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 c644bc8a..60403eca 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPatch.g.cs @@ -448,32 +448,32 @@ partial void ProcessTunedModelsPatchResponseContent( /// /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. 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. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// /// Optional. A short description of this model. /// - /// - /// Tuned model as a source for training a new model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -481,29 +481,29 @@ partial void ProcessTunedModelsPatchResponseContent( public async global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, + string? baseModel = default, string? displayName = default, - int? topK = default, + global::Google.Gemini.TuningTask? tuningTask = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, string? description = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? topP = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? baseModel = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, + int? topK = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.TunedModel { + BaseModel = baseModel, DisplayName = displayName, - TopK = topK, + TuningTask = tuningTask, + ReaderProjectNumbers = readerProjectNumbers, Description = description, - TunedModelSource = tunedModelSource, TopP = topP, - ReaderProjectNumbers = readerProjectNumbers, - BaseModel = baseModel, + TunedModelSource = tunedModelSource, Temperature = temperature, - TuningTask = tuningTask, + TopK = topK, }; return await TunedModelsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs index afe70489..9e0209cf 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsCreate.g.cs @@ -438,28 +438,28 @@ partial void ProcessTunedModelsPermissionsCreateResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// public async global::System.Threading.Tasks.Task TunedModelsPermissionsCreateAsync( string tunedModelsId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await TunedModelsPermissionsCreateAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs index 6e969712..2e627ccb 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsPermissionsPatch.g.cs @@ -461,12 +461,12 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -475,16 +475,16 @@ partial void ProcessTunedModelsPermissionsPatchResponseContent( string permissionsId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.Permission { GranteeType = granteeType, - Role = role, EmailAddress = emailAddress, + Role = role, }; return await TunedModelsPermissionsPatchAsync( diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs index fc403c23..a00dbc5c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContent.g.cs @@ -435,17 +435,14 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -453,48 +450,51 @@ partial void ProcessTunedModelsStreamGenerateContentResponseContent( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = default, + string? cachedContent = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default) { var __request = new global::Google.Gemini.GenerateContentRequest { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 638f692a..924ee492 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.GeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -376,17 +376,14 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -394,48 +391,51 @@ partial void ProcessTunedModelsStreamGenerateContentAsStreamResponse( /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 { - SystemInstruction = systemInstruction, - CachedContent = cachedContent, + ToolConfig = toolConfig, GenerationConfig = generationConfig, - ServiceTier = serviceTier, + Store = store, Model = model, SafetySettings = safetySettings, - Contents = contents, Tools = tools, - ToolConfig = toolConfig, - Store = store, + ServiceTier = serviceTier, + Contents = contents, + SystemInstruction = systemInstruction, + 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 676cc0f4..f1fac3b1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.BatchesUpdateEmbedContentBatch.g.cs @@ -44,14 +44,14 @@ public partial interface IGeminiClient /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// Configures the input to the batch request. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// /// /// Required. The user-defined name of this batch. @@ -66,9 +66,9 @@ public partial interface IGeminiClient string batchesId, string? updateMask = default, string? model = default, - global::Google.Gemini.EmbedContentBatchOutput? output = default, - global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, string? priority = default, + global::Google.Gemini.InputEmbedContentConfig? inputConfig = default, + global::Google.Gemini.EmbedContentBatchOutput? output = default, string? displayName = default, global::Google.Gemini.EmbedContentBatchStats? batchStats = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = 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 f72b7fb6..28feb689 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 @@ -50,14 +50,14 @@ public partial interface IGeminiClient /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// Configures the input to the batch request. /// - /// - /// 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}`. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -68,9 +68,9 @@ public partial interface IGeminiClient string? displayName = default, global::Google.Gemini.BatchStats? batchStats = default, global::Google.Gemini.GenerateContentBatchOutput? output = default, - string? model = default, - global::Google.Gemini.InputConfig? inputConfig = default, string? priority = default, + global::Google.Gemini.InputConfig? inputConfig = 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.CachedContentsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs index 8959451f..79cb847b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsCreate.g.cs @@ -31,6 +31,21 @@ public partial interface IGeminiClient /// /// Creates CachedContent resource. /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Input only. New TTL for this resource, input only. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// 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. /// @@ -40,37 +55,22 @@ public partial interface IGeminiClient /// /// Metadata on the usage of the cached content. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsCreateAsync( + string? expireTime = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + string? ttl = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, string? displayName = default, global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? ttl = default, - string? expireTime = default, global::System.Collections.Generic.IList? contents = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = 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 6d2e35b9..bfd3490d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CachedContentsPatch.g.cs @@ -41,6 +41,21 @@ public partial interface IGeminiClient /// /// /// + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// + /// Input only. New TTL for this resource, input only. + /// + /// + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response + /// + /// + /// 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. /// @@ -50,39 +65,24 @@ public partial interface IGeminiClient /// /// Metadata on the usage of the cached content. /// - /// - /// Input only. New TTL for this resource, input only. - /// - /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. - /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. - /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CachedContentsPatchAsync( string cachedContentsId, string? updateMask = default, + string? expireTime = default, + global::Google.Gemini.ToolConfig? toolConfig = default, + string? ttl = default, + global::System.Collections.Generic.IList? tools = default, + string? model = default, string? displayName = default, global::Google.Gemini.Content? systemInstruction = default, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata = default, - string? ttl = default, - string? expireTime = default, global::System.Collections.Generic.IList? contents = default, - string? model = default, - global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs index 8736c8ac..742c7e66 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsCreate.g.cs @@ -39,20 +39,20 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task CorporaPermissionsCreateAsync( string corporaId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs index 674f1dfe..b57a43d0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.CorporaPermissionsPatch.g.cs @@ -49,12 +49,12 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -63,8 +63,8 @@ public partial interface IGeminiClient string corporaId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs index dd2a52c6..96e2bc79 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicGenerateContent.g.cs @@ -36,17 +36,14 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -54,33 +51,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 ded596e1..e2a4afba 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContent.g.cs @@ -36,17 +36,14 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -54,33 +51,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 1ec9c2ea..1f27c6da 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.DynamicStreamGenerateContentAsStream.g.cs @@ -22,17 +22,14 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -40,33 +37,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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.FileSearchStoresCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs index 456dc9c7..9edab07f 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresCreate.g.cs @@ -31,18 +31,18 @@ public partial interface IGeminiClient /// /// Creates an empty `FileSearchStore`. /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. - /// /// /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task FileSearchStoresCreateAsync( - string? embeddingModel = default, string? displayName = default, + string? embeddingModel = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs index e0b568c2..44182be1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.FileSearchStoresImportFile.g.cs @@ -36,23 +36,23 @@ public partial interface IGeminiClient /// Imports a `File` from File Service to a `FileSearchStore`. /// /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Custom metadata to be associated with the file. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task FileSearchStoresImportFileAsync( string fileSearchStoresId, - global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.ChunkingConfig? chunkingConfig = default, string? fileName = default, + global::System.Collections.Generic.IList? customMetadata = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs index eb56a9b7..b3f64a78 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.MediaUploadToFileSearchStore.g.cs @@ -36,6 +36,9 @@ 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. /// @@ -45,18 +48,15 @@ public partial interface IGeminiClient /// /// Custom metadata to be associated with the data. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// /// 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, - 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 4b94ecba..2f5b194e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsEmbedContent.g.cs @@ -38,23 +38,23 @@ public partial interface IGeminiClient /// Generates a text embedding vector from the input `Content` using the specified [Gemini Embedding model](https://ai.google.dev/gemini-api/docs/models/gemini#text-embedding). /// /// - /// - /// Configurations for the EmbedContent request. + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// + /// Configurations for the EmbedContent request. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task ModelsEmbedContentAsync( string modelsId, - global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, - global::Google.Gemini.Content? content = default, string? model = default, + global::Google.Gemini.Content? content = default, + global::Google.Gemini.EmbedContentConfig? embedContentConfig = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs index 8798ae86..bed598a7 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsGenerateContent.g.cs @@ -36,17 +36,14 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -54,33 +51,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 abbbabeb..42e44c01 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContent.g.cs @@ -36,17 +36,14 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -54,33 +51,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 bd2401c0..cf975f1d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.ModelsStreamGenerateContentAsStream.g.cs @@ -22,17 +22,14 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -40,33 +37,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 215583d0..c1b09019 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsCreate.g.cs @@ -36,47 +36,47 @@ public partial interface IGeminiClient /// Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222 /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Optional. 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. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// /// Optional. A short description of this model. /// - /// - /// Tuned model as a source for training a new model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsCreateAsync( string? tunedModelId = default, + string? baseModel = default, string? displayName = default, - int? topK = default, + global::Google.Gemini.TuningTask? tuningTask = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, string? description = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? topP = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? baseModel = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, + int? topK = 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 21b75d7c..ec0cecfe 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsGenerateContent.g.cs @@ -36,17 +36,14 @@ public partial interface IGeminiClient /// Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -54,33 +51,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 3201c325..8fa1fbcd 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPatch.g.cs @@ -41,32 +41,32 @@ public partial interface IGeminiClient /// /// /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. 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. + /// + /// Tuning tasks that create tuned models. + /// + /// + /// Optional. List of project numbers that have read access to the tuned model. /// /// /// Optional. A short description of this model. /// - /// - /// Tuned model as a source for training a new model. - /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. - /// - /// - /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + /// Tuned model as a source for training a new model. /// /// /// Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with @@ -74,15 +74,15 @@ public partial interface IGeminiClient global::System.Threading.Tasks.Task TunedModelsPatchAsync( string tunedModelsId, string? updateMask = default, + string? baseModel = default, string? displayName = default, - int? topK = default, + global::Google.Gemini.TuningTask? tuningTask = default, + global::System.Collections.Generic.IList? readerProjectNumbers = default, string? description = default, - global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? topP = default, - global::System.Collections.Generic.IList? readerProjectNumbers = default, - string? baseModel = default, + global::Google.Gemini.TunedModelSource? tunedModelSource = default, float? temperature = default, - global::Google.Gemini.TuningTask? tuningTask = default, + int? topK = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs index 5c5f33eb..6d247e33 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsCreate.g.cs @@ -39,20 +39,20 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// global::System.Threading.Tasks.Task TunedModelsPermissionsCreateAsync( string tunedModelsId, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs index 9e3910e8..065efa6e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsPermissionsPatch.g.cs @@ -49,12 +49,12 @@ public partial interface IGeminiClient /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// + /// + /// Required. The role granted by this permission. + /// /// Per-request overrides such as headers, query parameters, timeout, retries, and response buffering. /// The token to cancel the operation with /// @@ -63,8 +63,8 @@ public partial interface IGeminiClient string permissionsId, string? updateMask = default, global::Google.Gemini.PermissionGranteeType? granteeType = default, - global::Google.Gemini.PermissionRole? role = default, string? emailAddress = default, + global::Google.Gemini.PermissionRole? role = default, global::Google.Gemini.AutoSDKRequestOptions? requestOptions = default, global::System.Threading.CancellationToken cancellationToken = default); } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs index 7222c266..6e3e597d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContent.g.cs @@ -36,17 +36,14 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -54,33 +51,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 fdd4665a..9ff6f0f4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.IGeminiClient.TunedModelsStreamGenerateContentAsStream.g.cs @@ -22,17 +22,14 @@ public partial interface IGeminiClient /// Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`. /// /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -40,33 +37,36 @@ public partial interface IGeminiClient /// /// 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. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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, - global::Google.Gemini.Content? systemInstruction = default, - string? cachedContent = default, + global::Google.Gemini.ToolConfig? toolConfig = default, global::Google.Gemini.GenerationConfig? generationConfig = default, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + bool? store = default, string? model = default, global::System.Collections.Generic.IList? safetySettings = default, - global::System.Collections.Generic.IList? contents = default, global::System.Collections.Generic.IList? tools = default, - global::Google.Gemini.ToolConfig? toolConfig = default, - bool? store = default, + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier = default, + global::System.Collections.Generic.IList? contents = default, + global::Google.Gemini.Content? systemInstruction = 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 cd04f52c..bbc7f194 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContext.g.cs @@ -13,118 +13,118 @@ namespace Google.Gemini DefaultIgnoreCondition = global::System.Text.Json.Serialization.JsonIgnoreCondition.WhenWritingNull, Converters = new global::System.Type[] { - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter), typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter), typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigResponseModalitieNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerationConfigMediaResolutionNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionCallingConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SchemaTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter), - typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DynamicRetrievalConfigModeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.TunedModelStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.FileSourceNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.CandidateFinishReasonNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter), typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioJsonConverter), typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatAspectRatioNullableJsonConverter), @@ -133,17 +133,13 @@ namespace Google.Gemini typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatImageSizeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.SafetyRatingCategoryNullableJsonConverter), - - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.SafetyRatingProbabilityNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), typeof(global::Google.Gemini.JsonConverters.PermissionGranteeTypeJsonConverter), @@ -153,337 +149,341 @@ namespace Google.Gemini typeof(global::Google.Gemini.JsonConverters.PermissionRoleNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseEnvironmentNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ComputerUseDisabledSafetyPolicieNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.DocumentStateNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityJsonConverter), - typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ModalityTokenCountModalityNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolResponseToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter), - typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.UsageMetadataServiceTierNullableJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter), - typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeNullableJsonConverter), + typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierNullableJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateJsonConverter), + + typeof(global::Google.Gemini.JsonConverters.GeneratedFileStateNullableJsonConverter), 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.SearchEntryPoint))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(string))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] - [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.CustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ChunkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Content))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCode))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] [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.GenerationConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(bool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeechConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(byte[]))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Blob))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(int))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatMimeType), TypeInfoPropertyName = "AudioResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatDelivery), TypeInfoPropertyName = "AudioResponseFormatDelivery2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(float))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningSnapshot))] + [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.SpeechConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.MultiSpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchGenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseDisabledSafetyPolicie), TypeInfoPropertyName = "ComputerUseDisabledSafetyPolicie2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] + [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.WhiteSpaceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchEntryPoint))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(object))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Schema))] [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.Schema))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ResponseFormatConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleMaps))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.MultiSpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListOperationsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Operation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchOutput))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedResponses))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerationConfigMediaResolution), TypeInfoPropertyName = "GenerationConfigMediaResolution2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TranslationConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Image))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SemanticRetrieverChunk))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WhiteSpaceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Hyperparameters))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListFilesResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatDelivery), TypeInfoPropertyName = "AudioResponseFormatDelivery2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AudioResponseFormatMimeType), TypeInfoPropertyName = "AudioResponseFormatMimeType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] - [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.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.Blob))] - [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.ExecutableCode))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [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.GoogleAiGenerativelanguageV1betaGroundingSupport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkCustomMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] + [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.Content))] + [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.StreamableHttpTransport))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(double))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SchemaType), TypeInfoPropertyName = "SchemaType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequests))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRating))] + [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::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListDocumentsResponse))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Document))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Status))] - [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.FunctionResponseBlob))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InputEmbedContentConfig))] + [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.InlinedEmbedContentRequests))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCachedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.ImageResponseFormat))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResultCandidate))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TopCandidates))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] + [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.UrlMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclaration))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.File))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetyRating))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentConfigTaskType), TypeInfoPropertyName = "EmbedContentConfigTaskType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileData))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ContentEmbedding))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] + [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.GenerateContentResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentRequestTaskType), TypeInfoPropertyName = "EmbedContentRequestTaskType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LatLng))] [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.GroundingChunkCustomMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingChunkStringList))] - [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.FunctionResponsePart))] - [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.CustomLongRunningOperation))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SafetySettingCategory), TypeInfoPropertyName = "SafetySettingCategory2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatus))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Candidate))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SpeakerVoiceConfig))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormat))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormat))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfig))] - [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.InputConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedRequests))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DynamicRetrievalConfigMode), TypeInfoPropertyName = "DynamicRetrievalConfigMode2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.McpServer))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StreamableHttpTransport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningTask))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] - [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.GroundingMetadata))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] [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.FileSource), TypeInfoPropertyName = "FileSource2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.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.InlinedRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Interval))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ReviewSnippet))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Part))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCall))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResult))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievalMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecution))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AsyncBatchEmbedContentRequest))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedback))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.WebSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationSource))] - [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::Google.Gemini.Image))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Web))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContext))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UploadToFileSearchStoreRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContentUsageMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.StringList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadata))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlMetadataUrlRetrievalStatus), TypeInfoPropertyName = "UrlMetadataUrlRetrievalStatus2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModel))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelState), TypeInfoPropertyName = "TunedModelState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TunedModelSource))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.SearchTypes))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.LatLng))] - [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.VoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PrebuiltVoiceConfig))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatch))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentBatchState), TypeInfoPropertyName = "GenerateContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.VideoFileMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileState), TypeInfoPropertyName = "FileState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSource), TypeInfoPropertyName = "FileSource2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.ListCachedContentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CachedContent))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExample))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CreateFileResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RetrievedContext))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Maps))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Dataset))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TuningExamples))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PlaceAnswerSources))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.LogprobsResult))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CandidateFinishReason), TypeInfoPropertyName = "CandidateFinishReason2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingAttribution))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CitationMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UrlContextMetadata))] + [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.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.BatchGenerateContentRequest))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TransferOwnershipResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatDelivery), TypeInfoPropertyName = "ImageResponseFormatDelivery2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchStats))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatMimeType), TypeInfoPropertyName = "ImageResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatDelivery), TypeInfoPropertyName = "ImageResponseFormatDelivery2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatAspectRatio), TypeInfoPropertyName = "ImageResponseFormatAspectRatio2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImageResponseFormatImageSize), TypeInfoPropertyName = "ImageResponseFormatImageSize2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.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.FunctionDeclaration))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FunctionDeclarationBehavior), TypeInfoPropertyName = "FunctionDeclarationBehavior2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] [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.EmbedContentBatchStats))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbedContentBatchState), TypeInfoPropertyName = "EmbedContentBatchState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseEnvironment), TypeInfoPropertyName = "ComputerUseEnvironment2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ComputerUseDisabledSafetyPolicie), TypeInfoPropertyName = "ComputerUseDisabledSafetyPolicie2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.PromptFeedbackBlockReason), TypeInfoPropertyName = "PromptFeedbackBlockReason2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolResponseToolType), TypeInfoPropertyName = "ToolResponseToolType2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ToolCallToolType), TypeInfoPropertyName = "ToolCallToolType2")] [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.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearch))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListPermissionsResponse))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CodeExecutionResultOutcome), TypeInfoPropertyName = "CodeExecutionResultOutcome2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.BatchEmbedContentsResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.EmbeddingUsageMetadata))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GoogleSearchRetrieval))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModelStatusModelStage), TypeInfoPropertyName = "ModelStatusModelStage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GroundingPassageId))] + [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.InlinedRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.TextResponseFormatMimeType), TypeInfoPropertyName = "TextResponseFormatMimeType2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.InlinedEmbedContentResponses))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Empty))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.Dictionary))] + [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.FileSearch))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.DocumentState), TypeInfoPropertyName = "DocumentState2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCount))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ModalityTokenCountModality), TypeInfoPropertyName = "ModalityTokenCountModality2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ListCorporaResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Corpus))] + [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.ThinkingConfigThinkingLevel), TypeInfoPropertyName = "ThinkingConfigThinkingLevel2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.AttributionSourceId))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.Tool))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ExecutableCodeLanguage), TypeInfoPropertyName = "ExecutableCodeLanguage2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::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.TransferOwnershipRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.UsageMetadataServiceTier), TypeInfoPropertyName = "UsageMetadataServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CustomLongRunningOperation))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.ImportFileRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.CountTokensResponse))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GenerateContentRequestServiceTier), TypeInfoPropertyName = "GenerateContentRequestServiceTier2")] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.IList))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.RegisterFilesRequest))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::Google.Gemini.GeneratedFileState), TypeInfoPropertyName = "GeneratedFileState2")] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] - [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [global::System.Text.Json.Serialization.JsonSerializable(typeof(global::System.Collections.Generic.List))] + [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 f069dfdd..34eea284 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.JsonSerializerContextTypes.g.cs @@ -28,63 +28,63 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::Google.Gemini.SearchEntryPoint? Type0 { get; set; } + public global::Google.Gemini.UploadToFileSearchStoreRequest? Type0 { get; set; } /// /// /// - public string? Type1 { get; set; } + public global::Google.Gemini.ChunkingConfig? Type1 { get; set; } /// /// /// - public byte[]? Type2 { get; set; } + public string? Type2 { get; set; } /// /// /// - public global::Google.Gemini.ImageSearch? Type3 { get; set; } + public global::System.Collections.Generic.IList? Type3 { get; set; } /// /// /// - public global::Google.Gemini.ImportFileRequest? Type4 { get; set; } + public global::Google.Gemini.CustomMetadata? Type4 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type5 { get; set; } + public global::Google.Gemini.ListOperationsResponse? Type5 { get; set; } /// /// /// - public global::Google.Gemini.CustomMetadata? Type6 { get; set; } + public global::System.Collections.Generic.IList? Type6 { get; set; } /// /// /// - public global::Google.Gemini.ChunkingConfig? Type7 { get; set; } + public global::Google.Gemini.Operation? Type7 { get; set; } /// /// /// - public global::Google.Gemini.GroundingAttribution? Type8 { get; set; } + public global::System.Collections.Generic.IList? Type8 { get; set; } /// /// /// - public global::Google.Gemini.Content? Type9 { get; set; } + public global::Google.Gemini.Part? Type9 { get; set; } /// /// /// - public global::Google.Gemini.AttributionSourceId? Type10 { get; set; } + public object? Type10 { get; set; } /// /// /// - public global::Google.Gemini.VideoMetadata? Type11 { get; set; } + public global::Google.Gemini.ExecutableCode? Type11 { get; set; } /// /// /// - public double? Type12 { get; set; } + public global::Google.Gemini.ToolResponse? Type12 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfig? Type13 { get; set; } + public global::Google.Gemini.FileData? Type13 { get; set; } /// /// /// - public float? Type14 { get; set; } + public global::Google.Gemini.VideoMetadata? Type14 { get; set; } /// /// /// @@ -92,939 +92,939 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::System.Collections.Generic.IList? Type16 { get; set; } + public global::Google.Gemini.CodeExecutionResult? Type16 { get; set; } /// /// /// - public global::Google.Gemini.SpeechConfig? Type17 { get; set; } + public byte[]? Type17 { get; set; } /// /// /// - public int? Type18 { get; set; } + public global::Google.Gemini.FunctionResponse? Type18 { get; set; } /// /// /// - public global::Google.Gemini.ImageConfig? Type19 { get; set; } + public global::Google.Gemini.ToolCall? Type19 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfig? Type20 { get; set; } + public global::Google.Gemini.FunctionCall? Type20 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigMediaResolution? Type21 { get; set; } + public global::Google.Gemini.Blob? Type21 { get; set; } /// /// /// - public global::Google.Gemini.TranslationConfig? Type22 { get; set; } + public global::Google.Gemini.CachedContentUsageMetadata? Type22 { get; set; } /// /// /// - public object? Type23 { get; set; } + public int? Type23 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type24 { get; set; } + public global::Google.Gemini.AudioResponseFormat? Type24 { get; set; } /// /// /// - public global::Google.Gemini.GenerationConfigResponseModalitie? Type25 { get; set; } + public global::Google.Gemini.AudioResponseFormatMimeType? Type25 { get; set; } /// /// /// - public global::Google.Gemini.Schema? Type26 { get; set; } + public global::Google.Gemini.AudioResponseFormatDelivery? Type26 { get; set; } /// /// /// - public global::Google.Gemini.ResponseFormatConfig? Type27 { get; set; } + public global::Google.Gemini.GenerateContentBatchOutput? Type27 { get; set; } /// /// /// - public global::Google.Gemini.GoogleMaps? Type28 { get; set; } + public global::Google.Gemini.InlinedResponses? Type28 { get; set; } /// /// /// - public global::Google.Gemini.MultiSpeakerVoiceConfig? Type29 { get; set; } + public float? Type29 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type30 { get; set; } + public global::Google.Gemini.StringList? Type30 { get; set; } /// /// /// - public global::Google.Gemini.SpeakerVoiceConfig? Type31 { get; set; } + public global::Google.Gemini.SearchTypes? Type31 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponses? Type32 { get; set; } + public global::Google.Gemini.WebSearch? Type32 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type33 { get; set; } + public global::Google.Gemini.ImageSearch? Type33 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentResponse? Type34 { get; set; } + public global::Google.Gemini.TunedModel? Type34 { get; set; } /// /// /// - public global::Google.Gemini.ListOperationsResponse? Type35 { get; set; } + public global::Google.Gemini.TunedModelState? Type35 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type36 { get; set; } + public global::Google.Gemini.TuningTask? Type36 { get; set; } /// /// /// - public global::Google.Gemini.Operation? Type37 { get; set; } + public global::Google.Gemini.TunedModelSource? Type37 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchOutput? Type38 { get; set; } + public global::Google.Gemini.GoogleMaps? Type38 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponses? Type39 { get; set; } + public global::Google.Gemini.TuningSnapshot? Type39 { get; set; } /// /// /// - public global::Google.Gemini.SemanticRetrieverChunk? Type40 { get; set; } + public global::Google.Gemini.VoiceConfig? Type40 { get; set; } /// /// /// - public global::Google.Gemini.WhiteSpaceConfig? Type41 { get; set; } + public global::Google.Gemini.PrebuiltVoiceConfig? Type41 { get; set; } /// /// /// - public global::Google.Gemini.Hyperparameters? Type42 { get; set; } + public global::Google.Gemini.SpeechConfig? Type42 { get; set; } /// /// /// - public global::Google.Gemini.ListFilesResponse? Type43 { get; set; } + public global::Google.Gemini.MultiSpeakerVoiceConfig? Type43 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type44 { get; set; } + public global::Google.Gemini.BatchEmbedContentsRequest? Type44 { get; set; } /// /// /// - public global::Google.Gemini.File? Type45 { get; set; } + public global::System.Collections.Generic.IList? Type45 { get; set; } /// /// /// - public global::Google.Gemini.VideoFileMetadata? Type46 { get; set; } + public global::Google.Gemini.EmbedContentRequest? Type46 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormat? Type47 { get; set; } + public global::Google.Gemini.BatchGenerateContentRequest? Type47 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatDelivery? Type48 { get; set; } + public global::Google.Gemini.GenerateContentBatch? Type48 { get; set; } /// /// /// - public global::Google.Gemini.AudioResponseFormatMimeType? Type49 { get; set; } + public global::Google.Gemini.Hyperparameters? Type49 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormat? Type50 { get; set; } + public global::Google.Gemini.ComputerUse? Type50 { get; set; } /// /// /// - public global::Google.Gemini.TextResponseFormatMimeType? Type51 { get; set; } + public global::System.Collections.Generic.IList? Type51 { get; set; } /// /// /// - public global::Google.Gemini.ListCorporaResponse? Type52 { get; set; } + public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type52 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type53 { get; set; } + public global::Google.Gemini.ComputerUseEnvironment? Type53 { get; set; } /// /// /// - public global::Google.Gemini.Corpus? Type54 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponse? Type54 { get; set; } /// /// /// - public global::Google.Gemini.ListModelsResponse? Type55 { get; set; } + public global::Google.Gemini.Status? Type55 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type56 { get; set; } + public global::Google.Gemini.EmbedContentResponse? Type56 { get; set; } /// /// /// - public global::Google.Gemini.Model? Type57 { get; set; } + public global::Google.Gemini.ListFileSearchStoresResponse? Type57 { get; set; } /// /// /// - public global::Google.Gemini.Blob? Type58 { get; set; } + public global::System.Collections.Generic.IList? Type58 { get; set; } /// /// /// - public global::Google.Gemini.Maps? Type59 { get; set; } + public global::Google.Gemini.FileSearchStore? Type59 { get; set; } /// /// /// - public global::Google.Gemini.PlaceAnswerSources? Type60 { get; set; } + public global::Google.Gemini.WhiteSpaceConfig? Type60 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCode? Type61 { get; set; } + public global::Google.Gemini.CodeExecutionResultOutcome? Type61 { get; set; } /// /// /// - public global::Google.Gemini.ExecutableCodeLanguage? Type62 { get; set; } + public global::Google.Gemini.EmbedContentConfig? Type62 { get; set; } /// /// /// - public global::Google.Gemini.ListDocumentsResponse? Type63 { get; set; } + public global::Google.Gemini.EmbedContentConfigTaskType? Type63 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type64 { get; set; } + public global::Google.Gemini.SearchEntryPoint? Type64 { get; set; } /// /// /// - public global::Google.Gemini.Document? Type65 { get; set; } + public global::Google.Gemini.Web? Type65 { get; set; } /// /// /// - public global::Google.Gemini.Status? Type66 { get; set; } + public global::Google.Gemini.ImageConfig? Type66 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfig? Type67 { get; set; } + public global::Google.Gemini.GenerationConfig? Type67 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCallingConfigMode? Type68 { get; set; } + public global::Google.Gemini.Schema? Type68 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseBlob? Type69 { get; set; } + public global::System.Collections.Generic.IList? Type69 { get; set; } /// /// /// - public global::Google.Gemini.InputEmbedContentConfig? Type70 { get; set; } + public global::Google.Gemini.GenerationConfigResponseModalitie? Type70 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequests? Type71 { get; set; } + public global::Google.Gemini.ResponseFormatConfig? Type71 { get; set; } /// /// /// - public global::Google.Gemini.ListCachedContentsResponse? Type72 { get; set; } + public global::Google.Gemini.GenerationConfigMediaResolution? Type72 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type73 { get; set; } + public global::Google.Gemini.TranslationConfig? Type73 { get; set; } /// /// /// - public global::Google.Gemini.CachedContent? Type74 { get; set; } + public global::Google.Gemini.ThinkingConfig? Type74 { get; set; } /// /// /// - public global::Google.Gemini.ListGeneratedFilesResponse? Type75 { get; set; } + public global::Google.Gemini.CitationSource? Type75 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type76 { get; set; } + public global::Google.Gemini.Image? Type76 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFile? Type77 { get; set; } + public global::Google.Gemini.SemanticRetrieverChunk? Type77 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormat? Type78 { get; set; } + public global::Google.Gemini.FunctionResponsePart? Type78 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResult? Type79 { get; set; } + public global::Google.Gemini.FunctionResponseBlob? Type79 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type80 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type80 { get; set; } /// /// /// - public global::Google.Gemini.LogprobsResultCandidate? Type81 { get; set; } + public global::System.Collections.Generic.IList? Type81 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type82 { get; set; } + public global::System.Collections.Generic.IList? Type82 { get; set; } /// /// /// - public global::Google.Gemini.TopCandidates? Type83 { get; set; } + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type83 { get; set; } /// /// /// - public global::Google.Gemini.Candidate? Type84 { get; set; } + public global::Google.Gemini.GroundingChunkCustomMetadata? Type84 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type85 { get; set; } + public global::Google.Gemini.GroundingChunkStringList? Type85 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRating? Type86 { get; set; } + public global::Google.Gemini.ContentEmbedding? Type86 { get; set; } /// /// /// - public global::Google.Gemini.UrlContextMetadata? Type87 { get; set; } + public global::Google.Gemini.FunctionCallingConfig? Type87 { get; set; } /// /// /// - public global::Google.Gemini.CandidateFinishReason? Type88 { get; set; } + public global::Google.Gemini.FunctionCallingConfigMode? Type88 { get; set; } /// /// /// - public global::Google.Gemini.CitationMetadata? Type89 { get; set; } + public global::Google.Gemini.Content? Type89 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type90 { get; set; } + public global::System.Collections.Generic.IList? Type90 { get; set; } /// /// /// - public global::Google.Gemini.GroundingMetadata? Type91 { get; set; } + public global::Google.Gemini.McpServer? Type91 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecution? Type92 { get; set; } + public global::Google.Gemini.StreamableHttpTransport? Type92 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfig? Type93 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequest? Type93 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentConfigTaskType? Type94 { get; set; } + public double? Type94 { get; set; } /// /// /// - public global::Google.Gemini.FileData? Type95 { get; set; } + public global::System.Collections.Generic.Dictionary? Type95 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsResponse? Type96 { get; set; } + public global::Google.Gemini.SchemaType? 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.InputConfig? Type98 { get; set; } /// /// /// - public global::Google.Gemini.EmbeddingUsageMetadata? Type99 { get; set; } + public global::Google.Gemini.InlinedRequests? Type99 { get; set; } /// /// /// - public global::Google.Gemini.SafetySetting? Type100 { get; set; } + public global::System.Collections.Generic.Dictionary? Type100 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingCategory? Type101 { get; set; } + public global::Google.Gemini.SafetyRating? Type101 { get; set; } /// /// /// - public global::Google.Gemini.SafetySettingThreshold? Type102 { get; set; } + public global::Google.Gemini.SafetyRatingCategory? Type102 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkCustomMetadata? Type103 { get; set; } + public global::Google.Gemini.SafetyRatingProbability? Type103 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunkStringList? Type104 { get; set; } + public global::System.Collections.Generic.IList? Type104 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequest? Type105 { get; set; } + public global::Google.Gemini.ListDocumentsResponse? Type105 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentRequestTaskType? Type106 { get; set; } + public global::System.Collections.Generic.IList? Type106 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponsePart? Type107 { get; set; } + public global::Google.Gemini.Document? Type107 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type108 { get; set; } + public global::System.Collections.Generic.IList? Type108 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type109 { get; set; } + public global::Google.Gemini.InlinedResponse? Type109 { get; set; } /// /// /// - public global::Google.Gemini.CustomLongRunningOperation? Type110 { get; set; } + public global::Google.Gemini.InlinedEmbedContentRequests? Type110 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequest? Type111 { get; set; } + public global::System.Collections.Generic.IList? Type111 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentRequestServiceTier? Type112 { get; set; } + public global::System.Collections.Generic.IList? Type112 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type113 { get; set; } + public global::Google.Gemini.FunctionResponseScheduling? Type113 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type114 { get; set; } + public global::Google.Gemini.UrlMetadata? Type114 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type115 { get; set; } + public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type115 { get; set; } /// /// /// - public global::Google.Gemini.Tool? Type116 { get; set; } + public global::Google.Gemini.FunctionDeclaration? Type116 { get; set; } /// /// /// - public global::Google.Gemini.ToolConfig? Type117 { get; set; } + public global::Google.Gemini.FunctionDeclarationBehavior? Type117 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearchRetrieval? Type118 { get; set; } + public global::Google.Gemini.ToolConfig? Type118 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfig? Type119 { get; set; } + public global::Google.Gemini.RetrievalConfig? Type119 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type120 { get; set; } + public global::Google.Gemini.CreateFileRequest? Type120 { get; set; } /// /// /// - public global::Google.Gemini.InlinedResponse? Type121 { get; set; } + public global::Google.Gemini.File? Type121 { get; set; } /// /// /// - public global::Google.Gemini.InputConfig? Type122 { get; set; } + public global::Google.Gemini.PromptFeedback? Type122 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequests? Type123 { get; set; } + public global::System.Collections.Generic.IList? Type123 { get; set; } /// /// /// - public global::Google.Gemini.DynamicRetrievalConfigMode? Type124 { get; set; } + public global::Google.Gemini.PromptFeedbackBlockReason? Type124 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipRequest? Type125 { get; set; } + public global::Google.Gemini.Interval? Type125 { get; set; } /// /// /// - public global::Google.Gemini.McpServer? Type126 { get; set; } + public global::Google.Gemini.ListModelsResponse? Type126 { get; set; } /// /// /// - public global::Google.Gemini.StreamableHttpTransport? Type127 { get; set; } + public global::System.Collections.Generic.IList? Type127 { get; set; } /// /// /// - public global::Google.Gemini.TuningTask? Type128 { get; set; } + public global::Google.Gemini.Model? Type128 { get; set; } /// /// /// - public global::Google.Gemini.Dataset? Type129 { get; set; } + public global::Google.Gemini.GenerateContentResponse? Type129 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type130 { get; set; } + public global::Google.Gemini.EmbedContentRequestTaskType? Type130 { get; set; } /// /// /// - public global::Google.Gemini.TuningSnapshot? Type131 { get; set; } + public global::Google.Gemini.UrlContext? Type131 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type132 { get; set; } + public global::Google.Gemini.ReviewSnippet? Type132 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaGroundingSupport? Type133 { get; set; } + public global::Google.Gemini.BatchStats? Type133 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalMetadata? Type134 { get; set; } + public global::Google.Gemini.LatLng? Type134 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type135 { get; set; } + public global::Google.Gemini.SafetySetting? Type135 { get; set; } /// /// /// - public global::Google.Gemini.GroundingChunk? Type136 { get; set; } + public global::Google.Gemini.SafetySettingThreshold? Type136 { get; set; } /// /// /// - public global::Google.Gemini.FileSource? Type137 { get; set; } + public global::Google.Gemini.SafetySettingCategory? Type137 { get; set; } /// /// /// - public global::Google.Gemini.FileState? Type138 { get; set; } + public global::Google.Gemini.ModelStatus? Type138 { get; set; } /// /// /// - public global::Google.Gemini.SchemaType? Type139 { get; set; } + public global::System.Collections.Generic.IList? Type139 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type140 { get; set; } + public global::Google.Gemini.Candidate? Type140 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type141 { get; set; } + public global::Google.Gemini.UsageMetadata? Type141 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatus? Type142 { get; set; } + public global::Google.Gemini.SpeakerVoiceConfig? Type142 { get; set; } /// /// /// - public global::Google.Gemini.ModelStatusModelStage? Type143 { get; set; } + public global::Google.Gemini.TransferOwnershipResponse? Type143 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type144 { get; set; } + public global::Google.Gemini.ImageResponseFormat? Type144 { get; set; } /// /// /// - public global::Google.Gemini.InlinedRequest? Type145 { get; set; } + public global::Google.Gemini.TextResponseFormat? Type145 { get; set; } /// /// /// - public global::Google.Gemini.Interval? Type146 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfig? Type146 { get; set; } /// /// /// - public global::Google.Gemini.RetrievalConfig? Type147 { get; set; } + public global::Google.Gemini.DynamicRetrievalConfigMode? Type147 { get; set; } /// /// /// - public global::Google.Gemini.FunctionCall? Type148 { get; set; } + public global::Google.Gemini.GroundingMetadata? Type148 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesRequest? Type149 { get; set; } + public global::System.Collections.Generic.IList? Type149 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type150 { get; set; } + public global::System.Collections.Generic.IList? Type150 { get; set; } /// /// /// - public global::Google.Gemini.ReviewSnippet? Type151 { get; set; } + public global::Google.Gemini.GroundingChunk? Type151 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensRequest? Type152 { get; set; } + public global::Google.Gemini.RetrievalMetadata? Type152 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileResponse? Type153 { get; set; } + public global::Google.Gemini.CodeExecution? Type153 { get; set; } /// /// /// - public global::Google.Gemini.TuningExample? Type154 { get; set; } + public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type154 { get; set; } /// /// /// - public global::Google.Gemini.GroundingPassageId? Type155 { get; set; } + public global::Google.Gemini.EmbedContentBatch? Type155 { get; set; } /// /// /// - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Type156 { get; set; } + public global::Google.Gemini.GenerateContentBatchState? Type156 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type157 { get; set; } + public global::Google.Gemini.VideoFileMetadata? Type157 { get; set; } /// /// /// - public global::Google.Gemini.Part? Type158 { get; set; } + public global::Google.Gemini.FileState? Type158 { get; set; } /// /// /// - public global::Google.Gemini.ToolCall? Type159 { get; set; } + public global::Google.Gemini.FileSource? Type159 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResult? Type160 { get; set; } + public global::Google.Gemini.TopCandidates? Type160 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponse? Type161 { get; set; } + public global::System.Collections.Generic.IList? Type161 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponse? Type162 { get; set; } + public global::Google.Gemini.LogprobsResultCandidate? Type162 { get; set; } /// /// /// - public global::Google.Gemini.AsyncBatchEmbedContentRequest? Type163 { get; set; } + public global::Google.Gemini.ListCachedContentsResponse? Type163 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatch? Type164 { get; set; } + public global::System.Collections.Generic.IList? Type164 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentResponse? Type165 { get; set; } + public global::Google.Gemini.CachedContent? Type165 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type166 { get; set; } + public global::Google.Gemini.GoogleSearch? Type166 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadata? Type167 { get; set; } + public global::Google.Gemini.TuningExample? Type167 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedback? Type168 { get; set; } + public global::Google.Gemini.CreateFileResponse? Type168 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCount? Type169 { get; set; } + public global::Google.Gemini.RetrievedContext? Type169 { get; set; } /// /// /// - public global::Google.Gemini.ModalityTokenCountModality? Type170 { get; set; } + public global::Google.Gemini.Maps? Type170 { get; set; } /// /// /// - public global::Google.Gemini.WebSearch? Type171 { get; set; } + public global::Google.Gemini.Dataset? Type171 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type172 { get; set; } + public global::Google.Gemini.TuningExamples? Type172 { get; set; } /// /// /// - public global::Google.Gemini.CitationSource? Type173 { get; set; } + public global::Google.Gemini.PlaceAnswerSources? Type173 { get; set; } /// /// /// - public global::Google.Gemini.InlinedEmbedContentRequest? Type174 { get; set; } + public global::System.Collections.Generic.IList? Type174 { get; set; } /// /// /// - public global::Google.Gemini.TuningExamples? Type175 { get; set; } + public global::Google.Gemini.LogprobsResult? Type175 { get; set; } /// /// /// - public global::Google.Gemini.Image? Type176 { get; set; } + public global::Google.Gemini.CandidateFinishReason? Type176 { get; set; } /// /// /// - public global::Google.Gemini.RetrievedContext? Type177 { get; set; } + public global::System.Collections.Generic.IList? Type177 { get; set; } /// /// /// - public global::Google.Gemini.Web? Type178 { get; set; } + public global::Google.Gemini.GroundingAttribution? Type178 { get; set; } /// /// /// - public global::Google.Gemini.BatchStats? Type179 { get; set; } + public global::Google.Gemini.CitationMetadata? Type179 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type180 { get; set; } + public global::Google.Gemini.UrlContextMetadata? Type180 { get; set; } /// /// /// - public global::Google.Gemini.ThinkingConfigThinkingLevel? Type181 { get; set; } + public global::Google.Gemini.InputEmbedContentConfig? Type181 { get; set; } /// /// /// - public global::Google.Gemini.UrlContext? Type182 { get; set; } + public global::Google.Gemini.EmbedContentBatchOutput? Type182 { get; set; } /// /// /// - public global::Google.Gemini.UploadToFileSearchStoreRequest? Type183 { get; set; } + public global::Google.Gemini.EmbedContentBatchState? Type183 { get; set; } /// /// /// - public global::Google.Gemini.DocumentState? Type184 { get; set; } + public global::Google.Gemini.EmbedContentBatchStats? Type184 { get; set; } /// /// /// - public global::Google.Gemini.CachedContentUsageMetadata? Type185 { get; set; } + public global::System.Collections.Generic.IList? Type185 { get; set; } /// /// /// - public global::Google.Gemini.StringList? Type186 { get; set; } + public global::Google.Gemini.ImageResponseFormatMimeType? Type186 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type187 { get; set; } + public global::Google.Gemini.ImageResponseFormatDelivery? Type187 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadata? Type188 { get; set; } + public global::Google.Gemini.ImageResponseFormatAspectRatio? Type188 { get; set; } /// /// /// - public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? Type189 { get; set; } + public global::Google.Gemini.ImageResponseFormatImageSize? Type189 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type190 { get; set; } + public global::Google.Gemini.ToolCallToolType? Type190 { get; set; } /// /// /// - public global::Google.Gemini.UsageMetadataServiceTier? Type191 { get; set; } + public global::Google.Gemini.ToolResponseToolType? Type191 { get; set; } /// /// /// - public global::Google.Gemini.TunedModel? Type192 { get; set; } + public global::Google.Gemini.Permission? Type192 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelState? Type193 { get; set; } + public global::Google.Gemini.PermissionGranteeType? Type193 { get; set; } /// /// /// - public global::Google.Gemini.TunedModelSource? Type194 { get; set; } + public global::Google.Gemini.PermissionRole? Type194 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type195 { get; set; } + public global::Google.Gemini.ListTunedModelsResponse? Type195 { get; set; } /// /// /// - public global::Google.Gemini.SearchTypes? Type196 { get; set; } + public global::System.Collections.Generic.IList? Type196 { get; set; } /// /// /// - public global::Google.Gemini.FunctionResponseScheduling? Type197 { get; set; } + public global::System.Collections.Generic.IList? Type197 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type198 { get; set; } + public global::System.Collections.Generic.IList? Type198 { get; set; } /// /// /// - public global::Google.Gemini.LatLng? Type199 { get; set; } + public global::Google.Gemini.BatchEmbedContentsResponse? Type199 { get; set; } /// /// /// - public global::Google.Gemini.BatchEmbedContentsRequest? Type200 { get; set; } + public global::System.Collections.Generic.IList? Type200 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type201 { get; set; } + public global::Google.Gemini.EmbeddingUsageMetadata? Type201 { get; set; } /// /// /// - public global::Google.Gemini.VoiceConfig? Type202 { get; set; } + public global::Google.Gemini.GoogleSearchRetrieval? Type202 { get; set; } /// /// /// - public global::Google.Gemini.PrebuiltVoiceConfig? Type203 { get; set; } + public global::Google.Gemini.ModelStatusModelStage? Type203 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatch? Type204 { get; set; } + public global::Google.Gemini.GroundingPassageId? Type204 { get; set; } /// /// /// - public global::Google.Gemini.GenerateContentBatchState? Type205 { get; set; } + public global::Google.Gemini.ListGeneratedFilesResponse? Type205 { get; set; } /// /// /// - public global::Google.Gemini.CreateFileRequest? Type206 { get; set; } + public global::System.Collections.Generic.IList? Type206 { get; set; } /// /// /// - public global::Google.Gemini.RegisterFilesResponse? Type207 { get; set; } + public global::Google.Gemini.GeneratedFile? Type207 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchOutput? Type208 { get; set; } + public global::Google.Gemini.InlinedRequest? Type208 { get; set; } /// /// /// - public global::Google.Gemini.ListFileSearchStoresResponse? Type209 { get; set; } + public global::Google.Gemini.GenerateContentRequest? Type209 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type210 { get; set; } + public global::Google.Gemini.TextResponseFormatMimeType? Type210 { get; set; } /// /// /// - public global::Google.Gemini.FileSearchStore? Type211 { get; set; } + public global::Google.Gemini.InlinedEmbedContentResponses? Type211 { get; set; } /// /// /// - public global::Google.Gemini.BatchGenerateContentRequest? Type212 { get; set; } + public global::Google.Gemini.Empty? Type212 { get; set; } /// /// /// - public global::Google.Gemini.TransferOwnershipResponse? Type213 { get; set; } + public global::Google.Gemini.ListFilesResponse? Type213 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentResponse? Type214 { get; set; } + public global::System.Collections.Generic.IList? Type214 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatDelivery? Type215 { get; set; } + public global::System.Collections.Generic.IList? Type215 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatMimeType? Type216 { get; set; } + public global::Google.Gemini.FileSearch? Type216 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatAspectRatio? Type217 { get; set; } + public global::Google.Gemini.DocumentState? Type217 { get; set; } /// /// /// - public global::Google.Gemini.ImageResponseFormatImageSize? Type218 { get; set; } + public global::Google.Gemini.ModalityTokenCount? Type218 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingCategory? Type219 { get; set; } + public global::Google.Gemini.ModalityTokenCountModality? Type219 { get; set; } /// /// /// - public global::Google.Gemini.SafetyRatingProbability? Type220 { get; set; } + public global::Google.Gemini.RegisterFilesResponse? Type220 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclaration? Type221 { get; set; } + public global::Google.Gemini.ListCorporaResponse? Type221 { get; set; } /// /// /// - public global::Google.Gemini.FunctionDeclarationBehavior? Type222 { get; set; } + public global::System.Collections.Generic.IList? Type222 { get; set; } /// /// /// - public global::Google.Gemini.FileSearch? Type223 { get; set; } + public global::Google.Gemini.Corpus? Type223 { get; set; } /// /// /// - public global::Google.Gemini.Permission? Type224 { get; set; } + public global::Google.Gemini.ListPermissionsResponse? Type224 { get; set; } /// /// /// - public global::Google.Gemini.PermissionGranteeType? Type225 { get; set; } + public global::System.Collections.Generic.IList? Type225 { get; set; } /// /// /// - public global::Google.Gemini.PermissionRole? Type226 { get; set; } + public global::Google.Gemini.ThinkingConfigThinkingLevel? Type226 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchStats? Type227 { get; set; } + public global::Google.Gemini.AttributionSourceId? Type227 { get; set; } /// /// /// - public global::Google.Gemini.EmbedContentBatchState? Type228 { get; set; } + public global::Google.Gemini.Tool? Type228 { get; set; } /// /// /// - public global::Google.Gemini.CountTokensResponse? Type229 { get; set; } + public global::System.Collections.Generic.IList? Type229 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUse? Type230 { get; set; } + public global::System.Collections.Generic.IList? Type230 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseEnvironment? Type231 { get; set; } + public global::Google.Gemini.CountTokensRequest? Type231 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type232 { get; set; } + public global::System.Collections.Generic.IList? Type232 { get; set; } /// /// /// - public global::Google.Gemini.ComputerUseDisabledSafetyPolicie? Type233 { get; set; } + public global::Google.Gemini.ExecutableCodeLanguage? Type233 { get; set; } /// /// /// - public global::Google.Gemini.PromptFeedbackBlockReason? Type234 { get; set; } + public global::System.Collections.Generic.IList? Type234 { get; set; } /// /// /// - public global::Google.Gemini.ToolResponseToolType? Type235 { get; set; } + public global::System.Collections.Generic.IList? Type235 { get; set; } /// /// /// - public global::Google.Gemini.ToolCallToolType? Type236 { get; set; } + public global::Google.Gemini.TransferOwnershipRequest? Type236 { get; set; } /// /// /// - public global::Google.Gemini.ListTunedModelsResponse? Type237 { get; set; } + public global::System.Collections.Generic.IList? Type237 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type238 { get; set; } + public global::System.Collections.Generic.IList? Type238 { get; set; } /// /// /// - public global::Google.Gemini.GeneratedFileState? Type239 { get; set; } + public global::System.Collections.Generic.IList? Type239 { get; set; } /// /// /// - public global::Google.Gemini.GoogleSearch? Type240 { get; set; } + public global::System.Collections.Generic.IList? Type240 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type241 { get; set; } + public global::Google.Gemini.UsageMetadataServiceTier? Type241 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type242 { get; set; } + public global::Google.Gemini.CustomLongRunningOperation? Type242 { get; set; } /// /// /// - public global::Google.Gemini.ListPermissionsResponse? Type243 { get; set; } + public global::Google.Gemini.ImportFileRequest? Type243 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type244 { get; set; } + public global::Google.Gemini.CountTokensResponse? Type244 { get; set; } /// /// /// - public global::Google.Gemini.CodeExecutionResultOutcome? Type245 { get; set; } + public global::System.Collections.Generic.IList? Type245 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type246 { get; set; } + public global::Google.Gemini.GenerateContentRequestServiceTier? Type246 { get; set; } /// /// /// - public global::System.Collections.Generic.IList? Type247 { get; set; } + public global::System.Collections.Generic.IList? Type247 { get; set; } /// /// /// - public global::Google.Gemini.Empty? Type248 { get; set; } + public global::Google.Gemini.RegisterFilesRequest? Type248 { get; set; } /// /// /// - public global::System.Collections.Generic.Dictionary? Type249 { get; set; } + public global::Google.Gemini.GeneratedFileState? Type249 { get; set; } /// /// @@ -1033,182 +1033,182 @@ public sealed partial class JsonSerializerContextTypes /// /// /// - public global::System.Collections.Generic.List? ListType1 { get; set; } + public global::System.Collections.Generic.List? ListType1 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType2 { get; set; } + public global::System.Collections.Generic.List? ListType2 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType3 { get; set; } + public global::System.Collections.Generic.List? ListType3 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType4 { get; set; } + public global::System.Collections.Generic.List? ListType4 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType5 { get; set; } + public global::System.Collections.Generic.List? ListType5 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType6 { get; set; } + public global::System.Collections.Generic.List? ListType6 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType7 { get; set; } + public global::System.Collections.Generic.List? ListType7 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType8 { get; set; } + public global::System.Collections.Generic.List? ListType8 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType9 { get; set; } + public global::System.Collections.Generic.List? ListType9 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType10 { get; set; } + public global::System.Collections.Generic.List? ListType10 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType11 { get; set; } + public global::System.Collections.Generic.List? ListType11 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType12 { get; set; } + public global::System.Collections.Generic.List? ListType12 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType13 { get; set; } + public global::System.Collections.Generic.List? ListType13 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType14 { get; set; } + public global::System.Collections.Generic.List? ListType14 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType15 { get; set; } + public global::System.Collections.Generic.List? ListType15 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType16 { get; set; } + public global::System.Collections.Generic.List? ListType16 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType17 { get; set; } + public global::System.Collections.Generic.List? ListType17 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType18 { get; set; } + public global::System.Collections.Generic.List? ListType18 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType19 { get; set; } + public global::System.Collections.Generic.List? ListType19 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType20 { get; set; } + public global::System.Collections.Generic.List? ListType20 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType21 { get; set; } + public global::System.Collections.Generic.List? ListType21 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType22 { get; set; } + public global::System.Collections.Generic.List? ListType22 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType23 { get; set; } + public global::System.Collections.Generic.List? ListType23 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType24 { get; set; } + public global::System.Collections.Generic.List? ListType24 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType25 { get; set; } + public global::System.Collections.Generic.List? ListType25 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType26 { get; set; } + public global::System.Collections.Generic.List? ListType26 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType27 { get; set; } + public global::System.Collections.Generic.List? ListType27 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType28 { get; set; } + public global::System.Collections.Generic.List? ListType28 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType29 { get; set; } + public global::System.Collections.Generic.List? ListType29 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType30 { get; set; } + public global::System.Collections.Generic.List? ListType30 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType31 { get; set; } + public global::System.Collections.Generic.List? ListType31 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType32 { get; set; } + public global::System.Collections.Generic.List? ListType32 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType33 { get; set; } + public global::System.Collections.Generic.List? ListType33 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType34 { get; set; } + public global::System.Collections.Generic.List? ListType34 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType35 { get; set; } + public global::System.Collections.Generic.List? ListType35 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType36 { get; set; } + public global::System.Collections.Generic.List? ListType36 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType37 { get; set; } + public global::System.Collections.Generic.List? ListType37 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType38 { get; set; } + public global::System.Collections.Generic.List? ListType38 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType39 { get; set; } + public global::System.Collections.Generic.List? ListType39 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType40 { get; set; } + public global::System.Collections.Generic.List? ListType40 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType41 { get; set; } + public global::System.Collections.Generic.List? ListType41 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType42 { get; set; } + public global::System.Collections.Generic.List? ListType42 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType43 { get; set; } + public global::System.Collections.Generic.List? ListType43 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType44 { get; set; } + public global::System.Collections.Generic.List? ListType44 { get; set; } /// /// /// - public global::System.Collections.Generic.List? ListType45 { get; set; } + public global::System.Collections.Generic.List? ListType45 { get; set; } } } \ No newline at end of file diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs index ec74f8c3..fa9a4271 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.AudioResponseFormat.g.cs @@ -9,10 +9,11 @@ namespace Google.Gemini public sealed partial class AudioResponseFormat { /// - /// Optional. Sample rate in Hz. + /// Optional. The MIME type of the audio output. /// - [global::System.Text.Json.Serialization.JsonPropertyName("sampleRate")] - public int? SampleRate { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter))] + public global::Google.Gemini.AudioResponseFormatMimeType? MimeType { get; set; } /// /// Optional. The delivery mode for the audio output. @@ -21,19 +22,18 @@ public sealed partial class AudioResponseFormat [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatDeliveryJsonConverter))] public global::Google.Gemini.AudioResponseFormatDelivery? Delivery { get; set; } - /// - /// Optional. The MIME type of the audio output. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.AudioResponseFormatMimeTypeJsonConverter))] - public global::Google.Gemini.AudioResponseFormatMimeType? MimeType { get; set; } - /// /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). /// [global::System.Text.Json.Serialization.JsonPropertyName("bitRate")] public int? BitRate { get; set; } + /// + /// Optional. Sample rate in Hz. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sampleRate")] + public int? SampleRate { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -43,31 +43,31 @@ public sealed partial class AudioResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. Sample rate in Hz. + /// + /// Optional. The MIME type of the audio output. /// /// /// Optional. The delivery mode for the audio output. /// - /// - /// Optional. The MIME type of the audio output. - /// /// /// Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus). /// + /// + /// Optional. Sample rate in Hz. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public AudioResponseFormat( - int? sampleRate, - global::Google.Gemini.AudioResponseFormatDelivery? delivery, global::Google.Gemini.AudioResponseFormatMimeType? mimeType, - int? bitRate) + global::Google.Gemini.AudioResponseFormatDelivery? delivery, + int? bitRate, + int? sampleRate) { - this.SampleRate = sampleRate; - this.Delivery = delivery; this.MimeType = mimeType; + this.Delivery = delivery; this.BitRate = bitRate; + this.SampleRate = sampleRate; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs index 6b4d1340..25c98c30 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.BatchStats.g.cs @@ -9,11 +9,11 @@ namespace Google.Gemini public sealed partial class BatchStats { /// - /// Output only. The number of requests that were successfully processed.
+ /// Output only. The number of requests that are still pending processing.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] + public string? PendingRequestCount { get; set; } /// /// Output only. The number of requests in the batch.
@@ -23,18 +23,18 @@ public sealed partial class BatchStats public string? RequestCount { get; set; } /// - /// Output only. The number of requests that failed to be processed.
+ /// Output only. The number of requests that were successfully processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] - public string? FailedRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] + public string? SuccessfulRequestCount { get; set; } /// - /// Output only. The number of requests that are still pending processing.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("pendingRequestCount")] - public string? PendingRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,35 +45,35 @@ public sealed partial class BatchStats /// /// Initializes a new instance of the class. /// - /// - /// Output only. The number of requests that were successfully processed.
+ /// + /// Output only. The number of requests that are still pending processing.
/// Included only in responses /// /// /// Output only. The number of requests in the batch.
/// Included only in responses /// - /// - /// 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 /// - /// - /// Output only. The number of requests that are still pending processing.
+ /// + /// Output only. The number of requests that failed to be processed.
/// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public BatchStats( - string? successfulRequestCount, + string? pendingRequestCount, string? requestCount, - string? failedRequestCount, - string? pendingRequestCount) + string? successfulRequestCount, + string? failedRequestCount) { - this.SuccessfulRequestCount = successfulRequestCount; + this.PendingRequestCount = pendingRequestCount; this.RequestCount = requestCount; + this.SuccessfulRequestCount = successfulRequestCount; 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 2f59c767..17a76eb9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Blob.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class Blob { - /// - /// Raw bytes for media formats. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("data")] - public byte[]? Data { get; set; } - /// /// The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). // /// [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] public string? MimeType { get; set; } + /// + /// Raw bytes for media formats. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("data")] + public byte[]? Data { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Blob /// /// Initializes a new instance of the class. /// - /// - /// Raw bytes for media formats. - /// /// /// The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). // /// + /// + /// Raw bytes for media formats. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Blob( - byte[]? data, - string? mimeType) + string? mimeType, + byte[]? data) { - this.Data = data; this.MimeType = mimeType; + this.Data = data; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CachedContent.g.cs index 614d2c91..bec71ef6 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,17 +9,10 @@ namespace Google.Gemini public sealed partial class CachedContent { /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } - - /// - /// Output only. Creation time of the cache entry.
- /// Included only in responses + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] + public string? ExpireTime { get; set; } /// /// Output only. When the cache entry was last updated in UTC time.
@@ -29,16 +22,10 @@ public sealed partial class CachedContent public string? UpdateTime { get; set; } /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } - - /// - /// 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; } /// /// Input only. New TTL for this resource, input only. @@ -47,41 +34,54 @@ public sealed partial class CachedContent public string? Ttl { get; set; } /// - /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. + /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// - [global::System.Text.Json.Serialization.JsonPropertyName("expireTime")] - public string? ExpireTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tools")] + public global::System.Collections.Generic.IList? Tools { get; set; } /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
- /// Included only in responses + /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// - /// Optional. Input only. Immutable. The content to cache. + /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. /// - [global::System.Text.Json.Serialization.JsonPropertyName("contents")] - public global::System.Collections.Generic.IList? Contents { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + 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 + /// Output only. Creation time of the cache entry.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tools")] - public global::System.Collections.Generic.IList? Tools { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// Metadata on the usage of the cached content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] + public global::Google.Gemini.CachedContentUsageMetadata? UsageMetadata { get; set; } + + /// + /// Optional. Input only. Immutable. The content to cache. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } + + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { 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. /// - /// - /// Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters. - /// - /// - /// Output only. Creation time of the cache entry.
- /// Included only in responses + /// + /// Timestamp in UTC of when this resource is considered expired. This is *always* provided on output, regardless of what was sent on input. /// /// /// Output only. When the cache entry was last updated in UTC time.
/// Included only in responses /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Metadata on the usage of the cached content. + /// + /// 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. Input only. Immutable. A list of `Tools` the model may use to generate the next response /// - /// - /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// + /// 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. + /// + /// + /// Output only. Creation time of the cache entry.
/// Included only in responses /// + /// + /// Metadata on the usage of the cached content. + /// /// /// Optional. Input only. Immutable. The content to cache. /// - /// - /// Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}` - /// - /// - /// Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response - /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`
+ /// Included only in responses /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CachedContent( - string? displayName, - string? createTime, + string? expireTime, string? updateTime, + global::Google.Gemini.ToolConfig? toolConfig, + string? ttl, + global::System.Collections.Generic.IList? tools, + string? model, + string? displayName, global::Google.Gemini.Content? systemInstruction, + string? createTime, global::Google.Gemini.CachedContentUsageMetadata? usageMetadata, - string? ttl, - string? expireTime, - string? name, global::System.Collections.Generic.IList? contents, - string? model, - global::System.Collections.Generic.IList? tools, - global::Google.Gemini.ToolConfig? toolConfig) + string? name) { - this.DisplayName = displayName; - this.CreateTime = createTime; + this.ExpireTime = expireTime; this.UpdateTime = updateTime; + this.ToolConfig = toolConfig; + this.Ttl = ttl; + this.Tools = tools; + this.Model = model; + this.DisplayName = displayName; this.SystemInstruction = systemInstruction; + this.CreateTime = createTime; this.UsageMetadata = usageMetadata; - this.Ttl = ttl; - this.ExpireTime = expireTime; - this.Name = name; this.Contents = contents; - this.Model = model; - this.Tools = tools; - this.ToolConfig = toolConfig; + this.Name = name; } /// 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 421940c9..1c2a2f78 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,16 +9,17 @@ namespace Google.Gemini public sealed partial class Candidate { /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. + /// Output only. Average log probability score of the candidate.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] + public double? AvgLogprobs { get; set; } /// - /// Metadata related to url context retrieval tool. + /// Logprobs Result /// - [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] - public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] + public global::Google.Gemini.LogprobsResult? LogprobsResult { get; set; } /// /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
@@ -29,30 +30,17 @@ public sealed partial class Candidate public global::Google.Gemini.CandidateFinishReason? FinishReason { get; set; } /// - /// Logprobs Result - /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobsResult")] - public global::Google.Gemini.LogprobsResult? LogprobsResult { 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. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] - public int? TokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] + public string? FinishMessage { get; set; } /// - /// Output only. Average log probability score of the candidate.
- /// Included only in responses + /// Metadata returned to client when grounding is enabled. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("avgLogprobs")] - public double? AvgLogprobs { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("groundingMetadata")] + public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } /// /// Output only. Index of the candidate in the list of response candidates.
@@ -69,23 +57,35 @@ public sealed partial class Candidate public global::System.Collections.Generic.IList? GroundingAttributions { get; set; } /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// List of ratings for the safety of a response candidate. There is at most one rating per category. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + + /// + /// 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.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("finishMessage")] - public string? FinishMessage { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tokenCount")] + public int? TokenCount { get; set; } /// - /// 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 related to url context retrieval tool. /// - [global::System.Text.Json.Serialization.JsonPropertyName("content")] - public global::Google.Gemini.Content? Content { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("urlContextMetadata")] + public global::Google.Gemini.UrlContextMetadata? UrlContextMetadata { get; set; } /// - /// Metadata returned to client when grounding is enabled. + /// 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("groundingMetadata")] - public global::Google.Gemini.GroundingMetadata? GroundingMetadata { get; set; } + [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 @@ -96,30 +96,24 @@ public sealed partial class Candidate /// /// Initializes a new instance of the class. /// - /// - /// List of ratings for the safety of a response candidate. There is at most one rating per category. - /// - /// - /// Metadata related to url context retrieval tool. - /// - /// - /// Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.
+ /// + /// Output only. Average log probability score of the candidate.
/// Included only in responses /// /// /// Logprobs Result /// - /// - /// 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 /// - /// - /// Output only. Average log probability score of the candidate.
+ /// + /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
/// Included only in responses /// + /// + /// Metadata returned to client when grounding is enabled. + /// /// /// Output only. Index of the candidate in the list of response candidates.
/// Included only in responses @@ -128,45 +122,51 @@ public sealed partial class Candidate /// Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.
/// Included only in responses /// - /// - /// Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set.
+ /// + /// 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.
/// Included only in responses /// + /// + /// Metadata related to url context retrieval tool. + /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Metadata returned to client when grounding is enabled. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Candidate( - global::System.Collections.Generic.IList? safetyRatings, - global::Google.Gemini.UrlContextMetadata? urlContextMetadata, - global::Google.Gemini.CandidateFinishReason? finishReason, - global::Google.Gemini.LogprobsResult? logprobsResult, - global::Google.Gemini.CitationMetadata? citationMetadata, - int? tokenCount, double? avgLogprobs, + global::Google.Gemini.LogprobsResult? logprobsResult, + global::Google.Gemini.CandidateFinishReason? finishReason, + string? finishMessage, + global::Google.Gemini.GroundingMetadata? groundingMetadata, int? index, global::System.Collections.Generic.IList? groundingAttributions, - string? finishMessage, - global::Google.Gemini.Content? content, - global::Google.Gemini.GroundingMetadata? groundingMetadata) + global::System.Collections.Generic.IList? safetyRatings, + global::Google.Gemini.CitationMetadata? citationMetadata, + int? tokenCount, + global::Google.Gemini.UrlContextMetadata? urlContextMetadata, + global::Google.Gemini.Content? content) { - this.SafetyRatings = safetyRatings; - this.UrlContextMetadata = urlContextMetadata; - this.FinishReason = finishReason; - this.LogprobsResult = logprobsResult; - this.CitationMetadata = citationMetadata; - this.TokenCount = tokenCount; this.AvgLogprobs = avgLogprobs; + this.LogprobsResult = logprobsResult; + this.FinishReason = finishReason; + this.FinishMessage = finishMessage; + this.GroundingMetadata = groundingMetadata; this.Index = index; this.GroundingAttributions = groundingAttributions; - this.FinishMessage = finishMessage; + this.SafetyRatings = safetyRatings; + this.CitationMetadata = citationMetadata; + this.TokenCount = tokenCount; + this.UrlContextMetadata = urlContextMetadata; this.Content = content; - this.GroundingMetadata = groundingMetadata; } /// 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 4f2ac466..c06cc88c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CitationSource.g.cs @@ -14,6 +14,12 @@ public sealed partial class CitationSource [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] public int? StartIndex { get; set; } + /// + /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("license")] + public string? License { get; set; } + /// /// Optional. End of the attributed segment, exclusive. /// @@ -26,12 +32,6 @@ public sealed partial class CitationSource [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; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -44,28 +44,28 @@ public sealed partial class CitationSource /// /// Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes. /// + /// + /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. + /// /// /// Optional. End of the attributed segment, exclusive. /// /// /// Optional. URI that is attributed as a source for a portion of the text. /// - /// - /// Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CitationSource( int? startIndex, + string? license, int? endIndex, - string? uri, - string? license) + string? uri) { this.StartIndex = startIndex; + this.License = license; this.EndIndex = endIndex; this.Uri = uri; - this.License = license; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs index a1771d2d..11556e1a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CodeExecutionResult.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class CodeExecutionResult { - /// - /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public string? Output { get; set; } - /// /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// @@ -27,6 +21,12 @@ public sealed partial class CodeExecutionResult [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.CodeExecutionResultOutcomeJsonConverter))] public global::Google.Gemini.CodeExecutionResultOutcome? Outcome { get; set; } + /// + /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public string? Output { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class CodeExecutionResult /// /// Initializes a new instance of the class. /// - /// - /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. - /// /// /// Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id. /// /// /// Required. Outcome of the code execution. /// + /// + /// Optional. Contains stdout when code execution is successful, stderr or other description otherwise. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CodeExecutionResult( - string? output, string? id, - global::Google.Gemini.CodeExecutionResultOutcome? outcome) + global::Google.Gemini.CodeExecutionResultOutcome? outcome, + string? output) { - this.Output = output; this.Id = id; this.Outcome = outcome; + this.Output = output; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs index 6e234610..908b858b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ComputerUse.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class ComputerUse { /// - /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. + /// Optional. Disabled safety policies for computer use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("excludedPredefinedFunctions")] - public global::System.Collections.Generic.IList? ExcludedPredefinedFunctions { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("disabledSafetyPolicies")] + public global::System.Collections.Generic.IList? DisabledSafetyPolicies { get; set; } /// /// Optional. Whether enable the prompt injection detection check on computer-use request. @@ -28,10 +28,10 @@ public sealed partial class ComputerUse public global::Google.Gemini.ComputerUseEnvironment? Environment { get; set; } /// - /// Optional. Disabled safety policies for computer use. + /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. /// - [global::System.Text.Json.Serialization.JsonPropertyName("disabledSafetyPolicies")] - public global::System.Collections.Generic.IList? DisabledSafetyPolicies { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("excludedPredefinedFunctions")] + public global::System.Collections.Generic.IList? ExcludedPredefinedFunctions { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -42,8 +42,8 @@ public sealed partial class ComputerUse /// /// Initializes a new instance of the class. /// - /// - /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. + /// + /// Optional. Disabled safety policies for computer use. /// /// /// Optional. Whether enable the prompt injection detection check on computer-use request. @@ -51,22 +51,22 @@ public sealed partial class ComputerUse /// /// Required. The environment being operated. /// - /// - /// Optional. Disabled safety policies for computer use. + /// + /// Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ComputerUse( - global::System.Collections.Generic.IList? excludedPredefinedFunctions, + global::System.Collections.Generic.IList? disabledSafetyPolicies, bool? enablePromptInjectionDetection, global::Google.Gemini.ComputerUseEnvironment? environment, - global::System.Collections.Generic.IList? disabledSafetyPolicies) + global::System.Collections.Generic.IList? excludedPredefinedFunctions) { - this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; + this.DisabledSafetyPolicies = disabledSafetyPolicies; this.EnablePromptInjectionDetection = enablePromptInjectionDetection; this.Environment = environment; - this.DisabledSafetyPolicies = disabledSafetyPolicies; + this.ExcludedPredefinedFunctions = excludedPredefinedFunctions; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs index db1b7f3e..c53213b9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Content.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class Content { - /// - /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("parts")] - public global::System.Collections.Generic.IList? Parts { get; set; } - /// /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. /// [global::System.Text.Json.Serialization.JsonPropertyName("role")] public string? Role { get; set; } + /// + /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("parts")] + public global::System.Collections.Generic.IList? Parts { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class Content /// /// Initializes a new instance of the class. /// - /// - /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. - /// /// /// Optional. The producer of the content. Must be either 'user' or 'model'. Useful to set for multi-turn conversations, otherwise can be left blank or unset. /// + /// + /// Ordered `Parts` that constitute a single message. Parts may have different MIME types. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Content( - global::System.Collections.Generic.IList? parts, - string? role) + string? role, + global::System.Collections.Generic.IList? parts) { - this.Parts = parts; this.Role = role; + this.Parts = parts; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs index 941fe884..2381f72d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ContentEmbedding.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ContentEmbedding { - /// - /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("shape")] - public global::System.Collections.Generic.IList? Shape { get; set; } - /// /// The embedding values. This is for 3P users only and will not be populated for 1P calls. /// [global::System.Text.Json.Serialization.JsonPropertyName("values")] public global::System.Collections.Generic.IList? Values { get; set; } + /// + /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("shape")] + public global::System.Collections.Generic.IList? Shape { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ContentEmbedding /// /// Initializes a new instance of the class. /// - /// - /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). - /// /// /// The embedding values. This is for 3P users only and will not be populated for 1P calls. /// + /// + /// This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ContentEmbedding( - global::System.Collections.Generic.IList? shape, - global::System.Collections.Generic.IList? values) + global::System.Collections.Generic.IList? values, + global::System.Collections.Generic.IList? shape) { - this.Shape = shape; this.Values = values; + this.Shape = shape; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Corpus.g.cs index 803c44e9..f1218b51 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,13 @@ namespace Google.Gemini /// public sealed partial class Corpus { + /// + /// Output only. The Timestamp of when the `Corpus` was last updated.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } + /// /// 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" /// @@ -21,13 +28,6 @@ public sealed partial class Corpus [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] public string? CreateTime { get; set; } - /// - /// Output only. The Timestamp of when the `Corpus` was last updated.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } - /// /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
/// Included only in responses @@ -44,6 +44,10 @@ public sealed partial class Corpus /// /// Initializes a new instance of the class. /// + /// + /// Output only. The Timestamp of when the `Corpus` was last updated.
+ /// Included only in responses + /// /// /// Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// @@ -51,10 +55,6 @@ public sealed partial class Corpus /// Output only. The Timestamp of when the `Corpus` was created.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Corpus` was last updated.
- /// Included only in responses - /// /// /// Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the "corpora/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`
/// Included only in responses @@ -63,14 +63,14 @@ public sealed partial class Corpus [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Corpus( + string? updateTime, string? displayName, string? createTime, - string? updateTime, string? name) { + this.UpdateTime = updateTime; 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 b4caf241..249717c8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CountTokensResponse.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class CountTokensResponse { - /// - /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] - public int? TotalTokens { get; set; } - /// /// Number of tokens in the cached part of the prompt (the cached content). /// @@ -21,18 +15,24 @@ 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; } /// - /// Output only. List of modalities that were processed in the cached content.
+ /// The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("totalTokens")] + public int? TotalTokens { get; set; } + + /// + /// Output only. List of modalities that were processed in the request input.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] - public global::System.Collections.Generic.IList? CacheTokensDetails { 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. /// - /// - /// 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 request input.
- /// Included only in responses - /// /// /// 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. + /// + /// + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CountTokensResponse( - int? totalTokens, int? cachedContentTokenCount, - global::System.Collections.Generic.IList? promptTokensDetails, - global::System.Collections.Generic.IList? cacheTokensDetails) + global::System.Collections.Generic.IList? cacheTokensDetails, + int? totalTokens, + global::System.Collections.Generic.IList? promptTokensDetails) { - this.TotalTokens = totalTokens; this.CachedContentTokenCount = cachedContentTokenCount; - this.PromptTokensDetails = promptTokensDetails; this.CacheTokensDetails = cacheTokensDetails; + this.TotalTokens = totalTokens; + this.PromptTokensDetails = promptTokensDetails; } /// 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 fbc3255f..09709a63 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomLongRunningOperation.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class CustomLongRunningOperation { /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// - [global::System.Text.Json.Serialization.JsonPropertyName("done")] - public bool? Done { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. @@ -20,12 +20,6 @@ public sealed partial class CustomLongRunningOperation [global::System.Text.Json.Serialization.JsonPropertyName("response")] public object? Response { get; set; } - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } - /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// @@ -38,6 +32,12 @@ public sealed partial class CustomLongRunningOperation [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("done")] + public bool? Done { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -47,36 +47,36 @@ public sealed partial class CustomLongRunningOperation /// /// Initializes a new instance of the class. /// - /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// /// /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// + /// + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomLongRunningOperation( - bool? done, - object? response, global::Google.Gemini.Status? error, + object? response, object? metadata, - string? name) + string? name, + bool? done) { - this.Done = done; - this.Response = response; this.Error = error; + this.Response = response; this.Metadata = metadata; this.Name = name; + this.Done = done; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.CustomMetadata.g.cs index 058d263c..1ff420e8 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,30 +8,30 @@ namespace Google.Gemini /// public sealed partial class CustomMetadata { - /// - /// Required. The key of the metadata to store. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("key")] - public string? Key { get; set; } - - /// - /// User provided string values assigned to a single metadata key. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] - public global::Google.Gemini.StringList? StringListValue { get; set; } - /// /// The numeric value of the metadata to store. /// [global::System.Text.Json.Serialization.JsonPropertyName("numericValue")] public float? NumericValue { get; set; } + /// + /// Required. The key of the metadata to store. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("key")] + public string? Key { get; set; } + /// /// The string value of the metadata to store. /// [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] public string? StringValue { get; set; } + /// + /// User provided string values assigned to a single metadata key. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] + public global::Google.Gemini.StringList? StringListValue { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,31 +41,31 @@ public sealed partial class CustomMetadata /// /// Initializes a new instance of the class. /// - /// - /// Required. The key of the metadata to store. - /// - /// - /// User provided string values assigned to a single metadata key. - /// /// /// The numeric value of the metadata to store. /// + /// + /// Required. The key of the metadata to store. + /// /// /// The string value of the metadata to store. /// + /// + /// User provided string values assigned to a single metadata key. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public CustomMetadata( - string? key, - global::Google.Gemini.StringList? stringListValue, float? numericValue, - string? stringValue) + string? key, + string? stringValue, + global::Google.Gemini.StringList? stringListValue) { - this.Key = key; - this.StringListValue = stringListValue; this.NumericValue = numericValue; + this.Key = key; this.StringValue = stringValue; + this.StringListValue = stringListValue; } /// 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 55f4df6d..600b57eb 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,19 +9,17 @@ namespace Google.Gemini public sealed partial class Document { /// - /// Output only. Current state of the `Document`.
- /// Included only in responses + /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] - public global::Google.Gemini.DocumentState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Output only. The mime type of the Document.
+ /// Output only. The Timestamp of when the `Document` 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. The Timestamp of when the `Document` was last updated.
@@ -31,11 +29,12 @@ public sealed partial class Document public string? UpdateTime { get; set; } /// - /// Output only. The Timestamp of when the `Document` was created.
+ /// Output only. Current state of the `Document`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.DocumentStateJsonConverter))] + public global::Google.Gemini.DocumentState? State { get; set; } /// /// Output only. The size of raw bytes ingested into the Document.
@@ -45,16 +44,11 @@ public sealed partial class Document public string? SizeBytes { 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; } - - /// - /// 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 mime type of the Document.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` @@ -62,6 +56,12 @@ public sealed partial class Document [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -71,56 +71,56 @@ public sealed partial class Document /// /// Initializes a new instance of the class. /// - /// - /// Output only. Current state of the `Document`.
- /// Included only in responses + /// + /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" /// - /// - /// Output only. The mime type of the Document.
+ /// + /// Output only. The Timestamp of when the `Document` was created.
/// Included only in responses /// /// /// Output only. The Timestamp of when the `Document` was last updated.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `Document` was created.
+ /// + /// Output only. Current state of the `Document`.
/// Included only in responses /// /// /// Output only. The size of raw bytes ingested into the Document.
/// Included only in responses /// - /// - /// Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: "Semantic Retriever Documentation" - /// - /// - /// 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 mime type of the Document.
+ /// Included only in responses /// /// /// Immutable. Identifier. The `Document` resource name. The ID (name excluding the "fileSearchStores/*/documents/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/{file_search_store_id}/documents/my-awesome-doc-123a456b789c` /// + /// + /// Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Document( - global::Google.Gemini.DocumentState? state, - string? mimeType, - string? updateTime, + string? displayName, string? createTime, + string? updateTime, + global::Google.Gemini.DocumentState? state, string? sizeBytes, - string? displayName, - global::System.Collections.Generic.IList? customMetadata, - string? name) + string? mimeType, + string? name, + global::System.Collections.Generic.IList? customMetadata) { - this.State = state; - this.MimeType = mimeType; - this.UpdateTime = updateTime; + this.DisplayName = displayName; this.CreateTime = createTime; + this.UpdateTime = updateTime; + this.State = state; this.SizeBytes = sizeBytes; - this.DisplayName = displayName; - this.CustomMetadata = customMetadata; + this.MimeType = mimeType; this.Name = name; + this.CustomMetadata = customMetadata; } /// 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 30aa56b6..72db6626 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 @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class EmbedContentBatch { - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// @@ -22,10 +15,17 @@ public sealed partial class EmbedContentBatch public string? Model { get; set; } /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("output")] - public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } + + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// /// Configures the input to the batch request. @@ -34,10 +34,24 @@ public sealed partial class EmbedContentBatch public global::Google.Gemini.InputEmbedContentConfig? InputConfig { get; set; } /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } + + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("output")] + public global::Google.Gemini.EmbedContentBatchOutput? Output { get; set; } /// /// Required. The user-defined name of this batch. @@ -53,18 +67,12 @@ public sealed partial class EmbedContentBatch public string? CreateTime { get; set; } /// - /// Output only. The time at which the batch was last updated.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } - - /// - /// Output only. The time at which the batch processing completed.
+ /// Output only. The state of the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] + public global::Google.Gemini.EmbedContentBatchState? State { get; set; } /// /// Stats about the batch. @@ -72,14 +80,6 @@ public sealed partial class EmbedContentBatch [global::System.Text.Json.Serialization.JsonPropertyName("batchStats")] public global::Google.Gemini.EmbedContentBatchStats? BatchStats { get; set; } - /// - /// Output only. The state of the batch.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentBatchStateJsonConverter))] - public global::Google.Gemini.EmbedContentBatchState? State { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -89,21 +89,29 @@ public sealed partial class EmbedContentBatch /// /// Initializes a new instance of the class. /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses - /// /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - /// - /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. + /// + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses + /// + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. /// /// /// Configures the input to the batch request. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// Output only. The time at which the batch processing completed.
+ /// Included only in responses + /// + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses + /// + /// + /// The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field. /// /// /// Required. The user-defined name of this batch. @@ -112,48 +120,40 @@ public sealed partial class EmbedContentBatch /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// Output only. The time at which the batch was last updated.
- /// Included only in responses - /// - /// - /// Output only. The time at which the batch processing completed.
+ /// + /// Output only. The state of the batch.
/// Included only in responses /// /// /// Stats about the batch. /// - /// - /// Output only. The state of the batch.
- /// Included only in responses - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatch( - string? name, string? model, - global::Google.Gemini.EmbedContentBatchOutput? output, - global::Google.Gemini.InputEmbedContentConfig? inputConfig, + string? updateTime, string? priority, + global::Google.Gemini.InputEmbedContentConfig? inputConfig, + string? endTime, + string? name, + global::Google.Gemini.EmbedContentBatchOutput? output, string? displayName, string? createTime, - string? updateTime, - string? endTime, - global::Google.Gemini.EmbedContentBatchStats? batchStats, - global::Google.Gemini.EmbedContentBatchState? state) + global::Google.Gemini.EmbedContentBatchState? state, + global::Google.Gemini.EmbedContentBatchStats? batchStats) { - this.Name = name; this.Model = model; - this.Output = output; - this.InputConfig = inputConfig; + this.UpdateTime = updateTime; this.Priority = priority; + this.InputConfig = inputConfig; + this.EndTime = endTime; + this.Name = name; + this.Output = output; this.DisplayName = displayName; this.CreateTime = createTime; - this.UpdateTime = updateTime; - this.EndTime = endTime; - this.BatchStats = batchStats; this.State = state; + this.BatchStats = batchStats; } /// 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 e8bb48ac..2cce5225 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentBatchStats.g.cs @@ -23,18 +23,18 @@ public sealed partial class EmbedContentBatchStats public string? RequestCount { 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 were successfully processed.
+ /// Output only. The number of requests that failed to be processed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("successfulRequestCount")] - public string? SuccessfulRequestCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("failedRequestCount")] + public string? FailedRequestCount { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -53,27 +53,27 @@ public sealed partial class EmbedContentBatchStats /// Output only. The number of requests 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 were successfully processed.
/// Included only in responses /// + /// + /// Output only. The number of requests that failed to be processed.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentBatchStats( string? pendingRequestCount, string? requestCount, - string? failedRequestCount, - string? successfulRequestCount) + string? successfulRequestCount, + string? failedRequestCount) { this.PendingRequestCount = pendingRequestCount; this.RequestCount = requestCount; - this.FailedRequestCount = failedRequestCount; this.SuccessfulRequestCount = successfulRequestCount; + this.FailedRequestCount = failedRequestCount; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs index 9798e98d..6a64911e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentConfig.g.cs @@ -15,10 +15,10 @@ public sealed partial class EmbedContentConfig public int? OutputDimensionality { get; set; } /// - /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. + /// Optional. Whether to enable OCR for document content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] - public bool? AutoTruncate { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] + public bool? DocumentOcr { get; set; } /// /// Optional. Whether to extract audio from video content. @@ -27,10 +27,11 @@ public sealed partial class EmbedContentConfig public bool? AudioTrackExtraction { get; set; } /// - /// Optional. Whether to enable OCR for document content. + /// Optional. The task type of the embedding. /// - [global::System.Text.Json.Serialization.JsonPropertyName("documentOcr")] - public bool? DocumentOcr { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter))] + public global::Google.Gemini.EmbedContentConfigTaskType? TaskType { get; set; } /// /// Optional. The title for the text. @@ -39,11 +40,10 @@ public sealed partial class EmbedContentConfig public string? Title { get; set; } /// - /// Optional. The task type of the embedding. + /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. /// - [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentConfigTaskTypeJsonConverter))] - public global::Google.Gemini.EmbedContentConfigTaskType? TaskType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("autoTruncate")] + public bool? AutoTruncate { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -57,38 +57,38 @@ public sealed partial class EmbedContentConfig /// /// Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. /// - /// - /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. + /// + /// Optional. Whether to enable OCR for document content. /// /// /// Optional. Whether to extract audio from video content. /// - /// - /// Optional. Whether to enable OCR for document content. + /// + /// Optional. The task type of the embedding. /// /// /// Optional. The title for the text. /// - /// - /// Optional. The task type of the embedding. + /// + /// Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentConfig( int? outputDimensionality, - bool? autoTruncate, - bool? audioTrackExtraction, bool? documentOcr, + bool? audioTrackExtraction, + global::Google.Gemini.EmbedContentConfigTaskType? taskType, string? title, - global::Google.Gemini.EmbedContentConfigTaskType? taskType) + bool? autoTruncate) { this.OutputDimensionality = outputDimensionality; - this.AutoTruncate = autoTruncate; - this.AudioTrackExtraction = audioTrackExtraction; this.DocumentOcr = documentOcr; - this.Title = title; + this.AudioTrackExtraction = audioTrackExtraction; this.TaskType = taskType; + this.Title = title; + this.AutoTruncate = autoTruncate; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs index 4ca12c35..16881bed 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentRequest.g.cs @@ -10,14 +10,6 @@ namespace Google.Gemini /// public sealed partial class EmbedContentRequest { - /// - /// Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter))] - [global::System.Obsolete("This property marked as deprecated.")] - public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } - /// /// Optional. Deprecated: Please use EmbedContentConfig.title instead. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval. /// @@ -26,10 +18,10 @@ public sealed partial class EmbedContentRequest public string? Title { get; set; } /// - /// Configurations for the EmbedContent request. + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// - [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] - public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. @@ -37,12 +29,6 @@ public sealed partial class EmbedContentRequest [global::System.Text.Json.Serialization.JsonPropertyName("content")] public global::Google.Gemini.Content? Content { get; set; } - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } - /// /// Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`). /// @@ -50,6 +36,20 @@ public sealed partial class EmbedContentRequest [global::System.Obsolete("This property marked as deprecated.")] public int? OutputDimensionality { get; set; } + /// + /// Configurations for the EmbedContent request. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("embedContentConfig")] + public global::Google.Gemini.EmbedContentConfig? EmbedContentConfig { get; set; } + + /// + /// Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("taskType")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.EmbedContentRequestTaskTypeJsonConverter))] + [global::System.Obsolete("This property marked as deprecated.")] + public global::Google.Gemini.EmbedContentRequestTaskType? TaskType { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -59,26 +59,26 @@ public sealed partial class EmbedContentRequest /// /// Initializes a new instance of the class. /// - /// - /// Configurations for the EmbedContent request. + /// + /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` /// /// /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. /// - /// - /// Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}` + /// + /// Configurations for the EmbedContent request. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentRequest( - global::Google.Gemini.EmbedContentConfig? embedContentConfig, + string? model, global::Google.Gemini.Content? content, - string? model) + global::Google.Gemini.EmbedContentConfig? embedContentConfig) { - this.EmbedContentConfig = embedContentConfig; - this.Content = content; this.Model = model; + this.Content = content; + this.EmbedContentConfig = embedContentConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs index 6b1b3f35..ced79a0c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbedContentResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class EmbedContentResponse { - /// - /// A list of floats representing an embedding. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("embedding")] - public global::Google.Gemini.ContentEmbedding? Embedding { get; set; } - /// /// Metadata on the usage of the embedding request. /// [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] public global::Google.Gemini.EmbeddingUsageMetadata? UsageMetadata { get; set; } + /// + /// A list of floats representing an embedding. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("embedding")] + public global::Google.Gemini.ContentEmbedding? Embedding { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class EmbedContentResponse /// /// Initializes a new instance of the class. /// - /// - /// A list of floats representing an embedding. - /// /// /// Metadata on the usage of the embedding request. /// + /// + /// A list of floats representing an embedding. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbedContentResponse( - global::Google.Gemini.ContentEmbedding? embedding, - global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata) + global::Google.Gemini.EmbeddingUsageMetadata? usageMetadata, + global::Google.Gemini.ContentEmbedding? embedding) { - this.Embedding = embedding; this.UsageMetadata = usageMetadata; + this.Embedding = embedding; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs index ecd1c5d4..20f3b809 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.EmbeddingUsageMetadata.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class EmbeddingUsageMetadata { /// - /// Output only. List of modalities that were processed in the request input.
+ /// Output only. Number of tokens in the prompt.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenDetails")] - public global::System.Collections.Generic.IList? PromptTokenDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } /// - /// Output only. Number of tokens in the prompt.
+ /// Output only. List of modalities that were processed in the request input.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenDetails")] + public global::System.Collections.Generic.IList? PromptTokenDetails { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -31,23 +31,23 @@ public sealed partial class EmbeddingUsageMetadata /// /// Initializes a new instance of the class. /// - /// - /// Output only. List of modalities that were processed in the request input.
- /// Included only in responses - /// /// /// Output only. Number of tokens in the prompt.
/// Included only in responses /// + /// + /// Output only. List of modalities that were processed in the request input.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public EmbeddingUsageMetadata( - global::System.Collections.Generic.IList? promptTokenDetails, - int? promptTokenCount) + int? promptTokenCount, + global::System.Collections.Generic.IList? promptTokenDetails) { - this.PromptTokenDetails = promptTokenDetails; this.PromptTokenCount = promptTokenCount; + this.PromptTokenDetails = promptTokenDetails; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs index 358665ad..9af6f777 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ExecutableCode.g.cs @@ -14,6 +14,12 @@ public sealed partial class ExecutableCode [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } + /// + /// Required. The code to be executed. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("code")] + public string? Code { get; set; } + /// /// Required. Programming language of the `code`. /// @@ -21,12 +27,6 @@ public sealed partial class ExecutableCode [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ExecutableCodeLanguageJsonConverter))] public global::Google.Gemini.ExecutableCodeLanguage? Language { get; set; } - /// - /// Required. The code to be executed. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("code")] - public string? Code { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ExecutableCode /// /// Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`. /// - /// - /// Required. Programming language of the `code`. - /// /// /// Required. The code to be executed. /// + /// + /// Required. Programming language of the `code`. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ExecutableCode( string? id, - global::Google.Gemini.ExecutableCodeLanguage? language, - string? code) + string? code, + global::Google.Gemini.ExecutableCodeLanguage? language) { this.Id = id; - this.Language = language; this.Code = code; + this.Language = language; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.File.g.cs index 36f9285a..5a2df3f2 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,18 +9,18 @@ namespace Google.Gemini public sealed partial class File { /// - /// Output only. Size of the file in bytes.
+ /// Output only. MIME type of the file.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { get; set; } /// - /// Output only. The timestamp of when the `File` was last updated.
+ /// Output only. Size of the file in bytes.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// /// Output only. SHA-256 hash of the uploaded bytes.
@@ -36,72 +36,72 @@ public sealed partial class File 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` + /// 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("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Output only. The download uri of the `File`.
+ /// Output only. Processing state of the File.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("downloadUri")] - public string? DownloadUri { 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; } /// - /// Source of the File. + /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// - [global::System.Text.Json.Serialization.JsonPropertyName("source")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] - public global::Google.Gemini.FileSource? Source { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("error")] + public global::Google.Gemini.Status? Error { get; set; } /// - /// Output only. The uri of the `File`.
+ /// Output only. The download uri of the `File`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("downloadUri")] + public string? DownloadUri { get; set; } /// - /// Output only. The timestamp of when the `File` was created.
- /// 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("createTime")] - public string? CreateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// - /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" + /// Output only. The timestamp of when the `File` was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). + /// Source of the File. /// - [global::System.Text.Json.Serialization.JsonPropertyName("error")] - public global::Google.Gemini.Status? Error { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("source")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileSourceJsonConverter))] + public global::Google.Gemini.FileSource? Source { get; set; } /// - /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
+ /// Output only. The timestamp of when the `File` was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] - public string? ExpirationTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// - /// Output only. Processing state of the File.
+ /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FileStateJsonConverter))] - public global::Google.Gemini.FileState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("expirationTime")] + public string? ExpirationTime { get; set; } /// - /// Output only. MIME type of the file.
+ /// Output only. The uri of the `File`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] - public string? MimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -112,12 +112,12 @@ public sealed partial class File /// /// Initializes a new instance of the class. /// - /// - /// Output only. Size of the file in bytes.
+ /// + /// Output only. MIME type of the file.
/// Included only in responses /// - /// - /// Output only. The timestamp of when the `File` was last updated.
+ /// + /// Output only. Size of the file in bytes.
/// Included only in responses /// /// @@ -127,75 +127,75 @@ public sealed partial class File /// /// Metadata for a video `File`. /// - /// - /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` + /// + /// 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 + /// + /// + /// 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 download uri of the `File`.
/// Included only in responses /// - /// - /// Source of the File. + /// + /// Immutable. Identifier. The `File` resource name. The ID (name excluding the "files/" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be generated. Example: `files/123-456` /// - /// - /// Output only. The uri of the `File`.
+ /// + /// Output only. The timestamp of when the `File` was last updated.
/// Included only in responses /// + /// + /// Source of the File. + /// /// /// Output only. The timestamp of when the `File` was created.
/// Included only in responses /// - /// - /// Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: "Welcome Image" - /// - /// - /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). - /// /// /// Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.
/// Included only in responses /// - /// - /// Output only. Processing state of the File.
- /// Included only in responses - /// - /// - /// Output only. MIME type of the file.
+ /// + /// 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? mimeType, string? sizeBytes, - string? updateTime, byte[]? sha256Hash, global::Google.Gemini.VideoFileMetadata? videoMetadata, - string? name, + string? displayName, + global::Google.Gemini.FileState? state, + global::Google.Gemini.Status? error, string? downloadUri, + string? name, + string? updateTime, global::Google.Gemini.FileSource? source, - string? uri, string? createTime, - string? displayName, - global::Google.Gemini.Status? error, string? expirationTime, - global::Google.Gemini.FileState? state, - string? mimeType) + string? uri) { + this.MimeType = mimeType; this.SizeBytes = sizeBytes; - this.UpdateTime = updateTime; this.Sha256Hash = sha256Hash; this.VideoMetadata = videoMetadata; - this.Name = name; + this.DisplayName = displayName; + this.State = state; + this.Error = error; this.DownloadUri = downloadUri; + this.Name = name; + this.UpdateTime = updateTime; this.Source = source; - this.Uri = uri; this.CreateTime = createTime; - this.DisplayName = displayName; - this.Error = error; this.ExpirationTime = expirationTime; - this.State = state; - this.MimeType = mimeType; + 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 b879641a..fc8fdc8c 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 { - /// - /// 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; } + /// + /// Optional. The IANA standard MIME type of the source data. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("mimeType")] + public string? MimeType { 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. /// - /// - /// Optional. The IANA standard MIME type of the source data. - /// /// /// Required. URI. /// + /// + /// Optional. The IANA standard MIME type of the source data. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileData( - string? mimeType, - string? fileUri) + string? fileUri, + string? mimeType) { - this.MimeType = mimeType; this.FileUri = fileUri; + this.MimeType = mimeType; } /// 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 a53ade4e..774925ae 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FileSearchStore.g.cs @@ -9,25 +9,25 @@ namespace Google.Gemini public sealed partial class FileSearchStore { /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
+ /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. The 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; } /// - /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
+ /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("failedDocumentsCount")] - public string? FailedDocumentsCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] + public string? SizeBytes { get; set; } /// /// Output only. The number of documents in the `FileSearchStore` that are being processed.
@@ -37,10 +37,10 @@ public sealed partial class FileSearchStore public string? PendingDocumentsCount { get; set; } /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// - [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] - public string? EmbeddingModel { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
@@ -50,24 +50,24 @@ public sealed partial class FileSearchStore public string? CreateTime { get; set; } /// - /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("activeDocumentsCount")] + public string? ActiveDocumentsCount { get; set; } /// - /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
- /// Included only in responses + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("sizeBytes")] - public string? SizeBytes { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("embeddingModel")] + public string? EmbeddingModel { get; set; } /// - /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// Output only. 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("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -78,63 +78,63 @@ public sealed partial class FileSearchStore /// /// Initializes a new instance of the class. /// - /// - /// Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the "fileSearchStores/" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.
- /// Included only in responses - /// - /// - /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
+ /// + /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
/// Included only in responses /// /// /// Output only. The number of documents in the `FileSearchStore` that have failed processing.
/// Included only in responses /// + /// + /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
+ /// Included only in responses + /// /// /// Output only. The number of documents in the `FileSearchStore` that are being processed.
/// Included only in responses /// - /// - /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. + /// + /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" /// /// /// Output only. The Timestamp of when the `FileSearchStore` was created.
/// Included only in responses /// - /// - /// Output only. The Timestamp of when the `FileSearchStore` was last updated.
+ /// + /// Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.
/// Included only in responses /// - /// - /// Output only. The size of raw bytes ingested into the `FileSearchStore`. This is the total size of all the documents in the `FileSearchStore`.
- /// Included only in responses + /// + /// Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used. /// - /// - /// Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: "Docs on Semantic Retriever" + /// + /// 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 /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FileSearchStore( - string? name, - string? activeDocumentsCount, + string? updateTime, string? failedDocumentsCount, + string? sizeBytes, string? pendingDocumentsCount, - string? embeddingModel, + string? displayName, string? createTime, - string? updateTime, - string? sizeBytes, - string? displayName) + string? activeDocumentsCount, + string? embeddingModel, + string? name) { - this.Name = name; - this.ActiveDocumentsCount = activeDocumentsCount; - this.FailedDocumentsCount = failedDocumentsCount; - this.PendingDocumentsCount = pendingDocumentsCount; - this.EmbeddingModel = embeddingModel; - this.CreateTime = createTime; this.UpdateTime = updateTime; + this.FailedDocumentsCount = failedDocumentsCount; this.SizeBytes = sizeBytes; + this.PendingDocumentsCount = pendingDocumentsCount; this.DisplayName = displayName; + this.CreateTime = createTime; + this.ActiveDocumentsCount = activeDocumentsCount; + this.EmbeddingModel = embeddingModel; + this.Name = name; } /// 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 245e16c4..ca8d29af 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("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; } - /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// Optional. The function parameters and values in JSON object format. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("args")] + public object? Args { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -38,23 +38,23 @@ public sealed partial class FunctionCall /// /// 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. - /// /// /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. /// + /// + /// Optional. The function parameters and values in JSON object format. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionCall( string? id, - object? args, - string? name) + string? name, + object? args) { this.Id = id; - this.Args = args; this.Name = name; + this.Args = args; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs index 8645fd22..00298529 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionDeclaration.g.cs @@ -9,16 +9,17 @@ namespace Google.Gemini public sealed partial class FunctionDeclaration { /// - /// Required. A brief description of the function. + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] + public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } /// - /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] - public object? ParametersJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] + public global::Google.Gemini.Schema? Parameters { 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. @@ -27,23 +28,22 @@ public sealed partial class FunctionDeclaration public string? Name { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// Required. A brief description of the function. /// - [global::System.Text.Json.Serialization.JsonPropertyName("parameters")] - public global::Google.Gemini.Schema? Parameters { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. + /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] - public object? ResponseJsonSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("parametersJsonSchema")] + public object? ParametersJsonSchema { get; set; } /// - /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. + /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("behavior")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionDeclarationBehaviorJsonConverter))] - public global::Google.Gemini.FunctionDeclarationBehavior? Behavior { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("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). @@ -60,24 +60,24 @@ public sealed partial class FunctionDeclaration /// /// Initializes a new instance of the class. /// - /// - /// Required. A brief description of the function. + /// + /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. /// - /// - /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. + /// + /// 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. /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// Required. A brief description of the function. + /// + /// + /// Optional. Describes the parameters to the function in JSON Schema format. The schema must describe an object where the properties are the parameters to the function. For example: ``` { "type": "object", "properties": { "name": { "type": "string" }, "age": { "type": "integer" } }, "additionalProperties": false, "required": ["name", "age"], "propertyOrdering": ["name", "age"] } ``` This field is mutually exclusive with `parameters`. /// /// /// Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`. /// - /// - /// Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method. - /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// @@ -85,20 +85,20 @@ public sealed partial class FunctionDeclaration [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionDeclaration( + global::Google.Gemini.FunctionDeclarationBehavior? behavior, + global::Google.Gemini.Schema? parameters, + string? name, string? description, object? parametersJsonSchema, - string? name, - global::Google.Gemini.Schema? parameters, object? responseJsonSchema, - global::Google.Gemini.FunctionDeclarationBehavior? behavior, global::Google.Gemini.Schema? response) { + this.Behavior = behavior; + this.Parameters = parameters; + this.Name = name; this.Description = description; this.ParametersJsonSchema = parametersJsonSchema; - this.Name = name; - this.Parameters = parameters; this.ResponseJsonSchema = responseJsonSchema; - this.Behavior = behavior; this.Response = response; } 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 e1096458..b9cae405 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.FunctionResponse.g.cs @@ -8,6 +8,18 @@ namespace Google.Gemini /// public sealed partial class FunctionResponse { + /// + /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("parts")] + public global::System.Collections.Generic.IList? Parts { get; set; } + + /// + /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + /// /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. /// @@ -21,12 +33,6 @@ public sealed partial class FunctionResponse [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.FunctionResponseSchedulingJsonConverter))] public global::Google.Gemini.FunctionResponseScheduling? Scheduling { get; set; } - /// - /// Optional. 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. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. /// @@ -34,16 +40,10 @@ public sealed partial class FunctionResponse public object? Response { get; set; } /// - /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - - /// - /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. + /// 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("parts")] - public global::System.Collections.Generic.IList? Parts { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -54,41 +54,41 @@ public sealed partial class FunctionResponse /// /// Initializes a new instance of the class. /// + /// + /// Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. + /// + /// + /// Required. The name of the function to call. Must be a-z, A-Z, 0-9, or contain underscores and dashes, with a maximum length of 128. + /// /// /// Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`. /// /// /// Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE. /// - /// - /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. - /// /// /// Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. "output", "result", etc. In particular, if the function call failed to execute, the response can have an "error" key to return error details to the model. Multimedia can be included by using a subobject containing a single "$ref" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal. /// - /// - /// 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. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types. + /// + /// Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public FunctionResponse( + global::System.Collections.Generic.IList? parts, + string? name, bool? willContinue, global::Google.Gemini.FunctionResponseScheduling? scheduling, - string? id, object? response, - string? name, - global::System.Collections.Generic.IList? parts) + string? id) { + this.Parts = parts; + this.Name = name; this.WillContinue = willContinue; this.Scheduling = scheduling; - this.Id = id; this.Response = response; - this.Name = name; - this.Parts = parts; + this.Id = id; } /// 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 de617a0d..16da0f84 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 c326aa0e..7b04ad95 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatch.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GenerateContentBatch { + /// + /// Required. The user-defined name of this batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } + /// /// Output only. The time at which the batch was created.
/// Included only in responses @@ -16,17 +22,12 @@ public sealed partial class GenerateContentBatch public string? CreateTime { get; set; } /// - /// Output only. The time at which the batch was last updated.
+ /// Output only. The state of the batch.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } - - /// - /// Required. The user-defined name of this batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("state")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter))] + public global::Google.Gemini.GenerateContentBatchState? State { get; set; } /// /// Stats about the batch. @@ -35,19 +36,18 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.BatchStats? BatchStats { get; set; } /// - /// Output only. The state of the batch.
+ /// Output only. The time at which the batch processing completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("state")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentBatchStateJsonConverter))] - public global::Google.Gemini.GenerateContentBatchState? State { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] + public string? EndTime { get; set; } /// - /// Output only. The time at which the batch processing completed.
+ /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("endTime")] - public string? EndTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. @@ -56,17 +56,17 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.GenerateContentBatchOutput? Output { get; set; } /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. + /// Output only. The time at which the batch was last updated.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("model")] - public string? Model { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] + public string? UpdateTime { get; set; } /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
- /// Included only in responses + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("priority")] + public string? Priority { get; set; } /// /// Configures the input to the batch request. @@ -75,10 +75,10 @@ public sealed partial class GenerateContentBatch public global::Google.Gemini.InputConfig? InputConfig { get; set; } /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("priority")] - public string? Priority { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("model")] + public string? Model { get; set; } /// /// 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. /// + /// + /// Required. The user-defined name of this batch. + /// /// /// Output only. The time at which the batch was created.
/// Included only in responses /// - /// - /// Output only. The time at which the batch was last updated.
+ /// + /// Output only. The state of the batch.
/// Included only in responses /// - /// - /// Required. The user-defined name of this batch. - /// /// /// Stats about the batch. /// - /// - /// Output only. The state of the batch.
- /// Included only in responses - /// /// /// Output only. The time at which the batch processing completed.
/// Included only in responses /// + /// + /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// Included only in responses + /// /// /// The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field. /// - /// - /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. - /// - /// - /// Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.
+ /// + /// Output only. The time at which the batch was last updated.
/// Included only in responses /// + /// + /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// /// /// Configures the input to the batch request. /// - /// - /// Optional. The priority of the batch. Batches with a higher priority value will be processed before batches with a lower priority value. Negative values are allowed. Default is 0. + /// + /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatch( - string? createTime, - string? updateTime, string? displayName, - global::Google.Gemini.BatchStats? batchStats, + string? createTime, global::Google.Gemini.GenerateContentBatchState? state, + global::Google.Gemini.BatchStats? batchStats, string? endTime, - global::Google.Gemini.GenerateContentBatchOutput? output, - string? model, string? name, + global::Google.Gemini.GenerateContentBatchOutput? output, + string? updateTime, + string? priority, global::Google.Gemini.InputConfig? inputConfig, - string? priority) + string? model) { - this.CreateTime = createTime; - this.UpdateTime = updateTime; this.DisplayName = displayName; - this.BatchStats = batchStats; + this.CreateTime = createTime; this.State = state; + this.BatchStats = batchStats; this.EndTime = endTime; - this.Output = output; - this.Model = model; this.Name = name; - this.InputConfig = inputConfig; + this.Output = output; + this.UpdateTime = updateTime; this.Priority = priority; + this.InputConfig = inputConfig; + this.Model = model; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs index c34eb311..bb020165 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentBatchOutput.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GenerateContentBatchOutput { - /// - /// The responses to the requests in the batch. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] - public global::Google.Gemini.InlinedResponses? InlinedResponses { get; set; } - /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses @@ -21,6 +15,12 @@ public sealed partial class GenerateContentBatchOutput [global::System.Text.Json.Serialization.JsonPropertyName("responsesFile")] public string? ResponsesFile { get; set; } + /// + /// The responses to the requests in the batch. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inlinedResponses")] + public global::Google.Gemini.InlinedResponses? InlinedResponses { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class GenerateContentBatchOutput /// /// Initializes a new instance of the class. /// - /// - /// The responses to the requests in the batch. - /// /// /// Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests.
/// Included only in responses /// + /// + /// The responses to the requests in the batch. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerateContentBatchOutput( - global::Google.Gemini.InlinedResponses? inlinedResponses, - string? responsesFile) + string? responsesFile, + global::Google.Gemini.InlinedResponses? inlinedResponses) { - this.InlinedResponses = inlinedResponses; this.ResponsesFile = responsesFile; + this.InlinedResponses = inlinedResponses; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs index c0a47595..2e772a66 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentRequest.g.cs @@ -9,16 +9,10 @@ namespace Google.Gemini public sealed partial class GenerateContentRequest { /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] - public global::Google.Gemini.Content? SystemInstruction { get; set; } - - /// - /// Optional. 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; } /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. @@ -27,11 +21,10 @@ public sealed partial class GenerateContentRequest public global::Google.Gemini.GenerationConfig? GenerationConfig { get; set; } /// - /// Optional. The service tier of the request. + /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. /// - [global::System.Text.Json.Serialization.JsonPropertyName("serviceTier")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.GenerateContentRequestServiceTierJsonConverter))] - public global::Google.Gemini.GenerateContentRequestServiceTier? ServiceTier { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("store")] + public bool? Store { get; set; } /// /// Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`. @@ -45,12 +38,6 @@ public sealed partial class GenerateContentRequest [global::System.Text.Json.Serialization.JsonPropertyName("safetySettings")] public global::System.Collections.Generic.IList? SafetySettings { 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. - /// - [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. /// @@ -58,16 +45,29 @@ public sealed partial class GenerateContentRequest public global::System.Collections.Generic.IList? Tools { get; set; } /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// Optional. The service tier of the request. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolConfig")] - public global::Google.Gemini.ToolConfig? ToolConfig { 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; } /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// 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("store")] - public bool? Store { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("contents")] + public global::System.Collections.Generic.IList? Contents { get; set; } + + /// + /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("systemInstruction")] + public global::Google.Gemini.Content? SystemInstruction { get; set; } + + /// + /// 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,17 +78,14 @@ public sealed partial class GenerateContentRequest /// /// Initializes a new instance of the class. /// - /// - /// The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn. - /// - /// - /// Optional. The name of the content [cached](https://ai.google.dev/gemini-api/docs/caching) to use as context to serve the prediction. Format: `cachedContents/{cachedContent}` + /// + /// The Tool configuration containing parameters for specifying `Tool` use in the request. /// /// /// Configuration options for model generation and outputs. Not all parameters are configurable for every model. /// - /// - /// Optional. The service tier of the request. + /// + /// 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}`. @@ -96,43 +93,46 @@ public sealed partial class GenerateContentRequest /// /// Optional. A list of unique `SafetySetting` instances for blocking unsafe content. This will be enforced on the `GenerateContentRequest.contents` and `GenerateContentResponse.candidates`. There should not be more than one setting for each `SafetyCategory` type. The API will block any contents and responses that fail to meet the thresholds set by these settings. This list overrides the default settings for each `SafetyCategory` specified in the safety_settings. If there is no `SafetySetting` for a given `SafetyCategory` provided in the list, the API will use the default safety setting for that category. Harm categories HARM_CATEGORY_HATE_SPEECH, HARM_CATEGORY_SEXUALLY_EXPLICIT, HARM_CATEGORY_DANGEROUS_CONTENT, HARM_CATEGORY_HARASSMENT, HARM_CATEGORY_CIVIC_INTEGRITY are supported. Refer to the [guide](https://ai.google.dev/gemini-api/docs/safety-settings) for detailed information on available safety settings. Also refer to the [Safety guidance](https://ai.google.dev/gemini-api/docs/safety-guidance) to learn how to incorporate safety considerations in your AI applications. /// - /// - /// Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request. - /// /// /// 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. /// - /// - /// The Tool configuration containing parameters for specifying `Tool` use in the request. + /// + /// Optional. The service tier of the request. /// - /// - /// Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config. + /// + /// 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. + /// + /// + /// 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( - global::Google.Gemini.Content? systemInstruction, - string? cachedContent, + global::Google.Gemini.ToolConfig? toolConfig, global::Google.Gemini.GenerationConfig? generationConfig, - global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, + bool? store, string? model, global::System.Collections.Generic.IList? safetySettings, - global::System.Collections.Generic.IList? contents, global::System.Collections.Generic.IList? tools, - global::Google.Gemini.ToolConfig? toolConfig, - bool? store) + global::Google.Gemini.GenerateContentRequestServiceTier? serviceTier, + global::System.Collections.Generic.IList? contents, + global::Google.Gemini.Content? systemInstruction, + string? cachedContent) { - this.SystemInstruction = systemInstruction; - this.CachedContent = cachedContent; + this.ToolConfig = toolConfig; this.GenerationConfig = generationConfig; - this.ServiceTier = serviceTier; + this.Store = store; this.Model = model; this.SafetySettings = safetySettings; - this.Contents = contents; this.Tools = tools; - this.ToolConfig = toolConfig; - this.Store = store; + this.ServiceTier = serviceTier; + this.Contents = contents; + this.SystemInstruction = systemInstruction; + 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 5e1a92fc..f928c125 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerateContentResponse.g.cs @@ -9,22 +9,16 @@ namespace Google.Gemini public sealed partial class GenerateContentResponse { /// - /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] - public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } - - /// - /// Candidate responses from the model. + /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] - public global::System.Collections.Generic.IList? Candidates { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] + public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } /// - /// Metadata on the generation request's token usage. + /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. /// - [global::System.Text.Json.Serialization.JsonPropertyName("usageMetadata")] - public global::Google.Gemini.UsageMetadata? UsageMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("modelStatus")] + public global::Google.Gemini.ModelStatus? ModelStatus { get; set; } /// /// Output only. The model version used to generate the response.
@@ -41,10 +35,16 @@ public sealed partial class GenerateContentResponse public string? ResponseId { get; set; } /// - /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. + /// Candidate responses from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("promptFeedback")] - public global::Google.Gemini.PromptFeedback? PromptFeedback { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidates")] + public global::System.Collections.Generic.IList? Candidates { get; set; } + + /// + /// Metadata on the generation request's token usage. + /// + [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,15 +55,12 @@ public sealed partial class GenerateContentResponse /// /// Initializes a new instance of the class. /// + /// + /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. + /// /// /// The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable. /// - /// - /// Candidate responses from the model. - /// - /// - /// Metadata on the generation request's token usage. - /// /// /// Output only. The model version used to generate the response.
/// Included only in responses @@ -72,26 +69,29 @@ public sealed partial class GenerateContentResponse /// Output only. response_id is used to identify each response.
/// Included only in responses /// - /// - /// A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`. + /// + /// 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.PromptFeedback? promptFeedback, global::Google.Gemini.ModelStatus? modelStatus, - global::System.Collections.Generic.IList? candidates, - global::Google.Gemini.UsageMetadata? usageMetadata, string? modelVersion, string? responseId, - global::Google.Gemini.PromptFeedback? promptFeedback) + global::System.Collections.Generic.IList? candidates, + global::Google.Gemini.UsageMetadata? usageMetadata) { + this.PromptFeedback = promptFeedback; this.ModelStatus = modelStatus; - this.Candidates = candidates; - this.UsageMetadata = usageMetadata; this.ModelVersion = modelVersion; this.ResponseId = responseId; - this.PromptFeedback = promptFeedback; + this.Candidates = candidates; + this.UsageMetadata = usageMetadata; } /// 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 94c2ec2d..78ab4e89 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GenerationConfig.g.cs @@ -9,28 +9,34 @@ namespace Google.Gemini public sealed partial class GenerationConfig { /// - /// 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 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("frequencyPenalty")] - public float? FrequencyPenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("stopSequences")] + public global::System.Collections.Generic.IList? StopSequences { get; set; } /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// 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("enableEnhancedCivicAnswers")] - public bool? EnableEnhancedCivicAnswers { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxOutputTokens")] + public int? MaxOutputTokens { 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. + /// 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("stopSequences")] - public global::System.Collections.Generic.IList? StopSequences { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] + public global::Google.Gemini.Schema? ResponseSchema { get; set; } /// - /// Config for speech generation and transcription. + /// 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("speechConfig")] - public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topP")] + public float? TopP { get; set; } + + /// + /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] + public global::System.Collections.Generic.IList? ResponseModalities { 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) @@ -39,59 +45,59 @@ public sealed partial class GenerationConfig public int? CandidateCount { 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. 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("topP")] - public float? TopP { 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. 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. 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. + /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. /// - [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] - public float? PresencePenalty { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] + public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } /// - /// Config for thinking features. + /// Optional. Enables enhanced civic answers. It may not be available for all models. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] - public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enableEnhancedCivicAnswers")] + public bool? EnableEnhancedCivicAnswers { get; set; } /// - /// Optional. If specified, the media resolution specified will be used. + /// 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("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("responseMimeType")] + public string? ResponseMimeType { get; set; } /// - /// Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. + /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. /// - [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("responseJsonSchema")] + public object? ResponseJsonSchema { 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. If specified, the media resolution specified will be used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("logprobs")] - public int? Logprobs { 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 translation features. + /// Config for speech generation and transcription. /// - [global::System.Text.Json.Serialization.JsonPropertyName("translationConfig")] - public global::Google.Gemini.TranslationConfig? TranslationConfig { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("speechConfig")] + public global::Google.Gemini.SpeechConfig? SpeechConfig { get; set; } /// /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. @@ -100,28 +106,22 @@ public sealed partial class GenerationConfig public int? Seed { get; set; } /// - /// Optional. An internal detail. Use `responseJsonSchema` rather than this field. - /// - [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. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseMimeType")] - public string? ResponseMimeType { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("frequencyPenalty")] + public float? FrequencyPenalty { get; set; } /// - /// 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. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseModalities")] - public global::System.Collections.Generic.IList? ResponseModalities { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("presencePenalty")] + public float? PresencePenalty { get; set; } /// - /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// Config for image generation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("imageConfig")] + public global::Google.Gemini.ImageConfig? ImageConfig { get; set; } /// /// Optional. If true, export the logprobs results in response. @@ -130,16 +130,16 @@ public sealed partial class GenerationConfig public bool? ResponseLogprobs { 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 translation features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseSchema")] - public global::Google.Gemini.Schema? ResponseSchema { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("translationConfig")] + public global::Google.Gemini.TranslationConfig? TranslationConfig { get; set; } /// - /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. + /// Config for thinking features. /// - [global::System.Text.Json.Serialization.JsonPropertyName("responseFormat")] - public global::Google.Gemini.ResponseFormatConfig? ResponseFormat { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingConfig")] + public global::Google.Gemini.ThinkingConfig? ThinkingConfig { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,121 +150,121 @@ public sealed partial class GenerationConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. - /// - /// - /// Optional. Enables enhanced civic answers. It may not be available for all models. - /// /// /// Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response. /// - /// - /// Config for speech generation and transcription. + /// + /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. /// - /// - /// Optional. Number of generated responses to return. If unset, this will default to 1. Please note that this doesn't work for previous generation models (Gemini 1.0 family) + /// + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// /// /// Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. /// - /// - /// Config for image generation features. - /// - /// - /// Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function. - /// - /// - /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. - /// - /// - /// Config for thinking features. + /// + /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. /// - /// - /// Optional. If specified, the media resolution specified will be used. + /// + /// 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. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0]. /// + /// + /// Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests. + /// /// /// Optional. Only valid if response_logprobs=True. This sets the number of top logprobs, including the chosen candidate, to return at each decoding step in the Candidate.logprobs_result. The number must be in the range of [0, 20]. /// - /// - /// Config for translation features. + /// + /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. /// - /// - /// Optional. Seed used in decoding. If not set, the request uses a randomly generated seed. + /// + /// Optional. Enables enhanced civic answers. It may not be available for all models. + /// + /// + /// 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. 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. If specified, the media resolution specified will be used. /// - /// - /// Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text. + /// + /// Config for speech generation and transcription. /// - /// - /// Optional. 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. Seed used in decoding. If not set, the request uses a randomly generated seed. + /// + /// + /// Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit. + /// + /// + /// Optional. Presence penalty applied to the next token's logprobs if the token has already been seen in the response. This penalty is binary on/off and not dependant on the number of times the token is used (after the first). Use frequency_penalty for a penalty that increases with each use. A positive penalty will discourage the use of tokens that have already been used in the response, increasing the vocabulary. A negative penalty will encourage the use of tokens that have already been used in the response, decreasing the vocabulary. + /// + /// + /// Config for image generation features. /// /// /// Optional. If true, export the logprobs results in response. /// - /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// + /// Config for translation features. /// - /// - /// Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality. + /// + /// Config for thinking features. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GenerationConfig( - float? frequencyPenalty, - bool? enableEnhancedCivicAnswers, global::System.Collections.Generic.IList? stopSequences, - global::Google.Gemini.SpeechConfig? speechConfig, - int? candidateCount, - float? topP, - global::Google.Gemini.ImageConfig? imageConfig, int? maxOutputTokens, - float? presencePenalty, - global::Google.Gemini.ThinkingConfig? thinkingConfig, - global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + global::Google.Gemini.Schema? responseSchema, + float? topP, + global::System.Collections.Generic.IList? responseModalities, + int? candidateCount, float? temperature, + int? topK, int? logprobs, - global::Google.Gemini.TranslationConfig? translationConfig, - int? seed, - object? responseJsonSchema, + global::Google.Gemini.ResponseFormatConfig? responseFormat, + bool? enableEnhancedCivicAnswers, string? responseMimeType, - global::System.Collections.Generic.IList? responseModalities, - int? topK, + object? responseJsonSchema, + global::Google.Gemini.GenerationConfigMediaResolution? mediaResolution, + global::Google.Gemini.SpeechConfig? speechConfig, + int? seed, + float? frequencyPenalty, + float? presencePenalty, + global::Google.Gemini.ImageConfig? imageConfig, bool? responseLogprobs, - global::Google.Gemini.Schema? responseSchema, - global::Google.Gemini.ResponseFormatConfig? responseFormat) + global::Google.Gemini.TranslationConfig? translationConfig, + global::Google.Gemini.ThinkingConfig? thinkingConfig) { - this.FrequencyPenalty = frequencyPenalty; - this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; this.StopSequences = stopSequences; - this.SpeechConfig = speechConfig; - this.CandidateCount = candidateCount; - this.TopP = topP; - this.ImageConfig = imageConfig; this.MaxOutputTokens = maxOutputTokens; - this.PresencePenalty = presencePenalty; - this.ThinkingConfig = thinkingConfig; - this.MediaResolution = mediaResolution; + this.ResponseSchema = responseSchema; + this.TopP = topP; + this.ResponseModalities = responseModalities; + this.CandidateCount = candidateCount; this.Temperature = temperature; + this.TopK = topK; this.Logprobs = logprobs; - this.TranslationConfig = translationConfig; - this.Seed = seed; - this.ResponseJsonSchema = responseJsonSchema; + this.ResponseFormat = responseFormat; + this.EnableEnhancedCivicAnswers = enableEnhancedCivicAnswers; this.ResponseMimeType = responseMimeType; - this.ResponseModalities = responseModalities; - this.TopK = topK; + this.ResponseJsonSchema = responseJsonSchema; + this.MediaResolution = mediaResolution; + this.SpeechConfig = speechConfig; + this.Seed = seed; + this.FrequencyPenalty = frequencyPenalty; + this.PresencePenalty = presencePenalty; + this.ImageConfig = imageConfig; this.ResponseLogprobs = responseLogprobs; - this.ResponseSchema = responseSchema; - this.ResponseFormat = responseFormat; + this.TranslationConfig = translationConfig; + this.ThinkingConfig = thinkingConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs index 73704ede..da37cfc2 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaGroundingSupport.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport { - /// - /// Segment of the content. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("segment")] - public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Segment { get; set; } - /// /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). /// @@ -33,6 +27,12 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport [global::System.Text.Json.Serialization.JsonPropertyName("renderedParts")] public global::System.Collections.Generic.IList? RenderedParts { get; set; } + /// + /// Segment of the content. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("segment")] + public global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? Segment { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -42,9 +42,6 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// /// Initializes a new instance of the class. /// - /// - /// Segment of the content. - /// /// /// Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order). /// @@ -55,19 +52,22 @@ public sealed partial class GoogleAiGenerativelanguageV1betaGroundingSupport /// Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.
/// Included only in responses /// + /// + /// Segment of the content. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaGroundingSupport( - global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? segment, global::System.Collections.Generic.IList? groundingChunkIndices, global::System.Collections.Generic.IList? confidenceScores, - global::System.Collections.Generic.IList? renderedParts) + global::System.Collections.Generic.IList? renderedParts, + global::Google.Gemini.GoogleAiGenerativelanguageV1betaSegment? segment) { - this.Segment = segment; this.GroundingChunkIndices = groundingChunkIndices; this.ConfidenceScores = confidenceScores; this.RenderedParts = renderedParts; + this.Segment = segment; } /// 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 eb519ebe..dec5fe8c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleAiGenerativelanguageV1betaSegment.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class GoogleAiGenerativelanguageV1betaSegment { - /// - /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] - public int? StartIndex { get; set; } - /// /// The index of a Part object within its parent Content object. /// @@ -32,6 +26,12 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment [global::System.Text.Json.Serialization.JsonPropertyName("text")] public string? Text { get; set; } + /// + /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("startIndex")] + public int? StartIndex { get; set; } + /// /// 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. /// - /// - /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. - /// /// /// The index of a Part object within its parent Content object. /// @@ -53,19 +50,22 @@ public sealed partial class GoogleAiGenerativelanguageV1betaSegment /// /// The text corresponding to the segment from the response. /// + /// + /// Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleAiGenerativelanguageV1betaSegment( - int? startIndex, int? partIndex, int? endIndex, - string? text) + string? text, + int? startIndex) { - this.StartIndex = startIndex; this.PartIndex = partIndex; this.EndIndex = endIndex; this.Text = text; + this.StartIndex = startIndex; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs index 72c07004..74828ec0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GoogleSearch.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class GoogleSearch { - /// - /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeRangeFilter")] - public global::Google.Gemini.Interval? TimeRangeFilter { get; set; } - /// /// Different types of search that can be enabled on the GoogleSearch tool. /// [global::System.Text.Json.Serialization.JsonPropertyName("searchTypes")] public global::Google.Gemini.SearchTypes? SearchTypes { get; set; } + /// + /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("timeRangeFilter")] + public global::Google.Gemini.Interval? TimeRangeFilter { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class GoogleSearch /// /// Initializes a new instance of the class. /// - /// - /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. - /// /// /// Different types of search that can be enabled on the GoogleSearch tool. /// + /// + /// Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GoogleSearch( - global::Google.Gemini.Interval? timeRangeFilter, - global::Google.Gemini.SearchTypes? searchTypes) + global::Google.Gemini.SearchTypes? searchTypes, + global::Google.Gemini.Interval? timeRangeFilter) { - this.TimeRangeFilter = timeRangeFilter; this.SearchTypes = searchTypes; + this.TimeRangeFilter = timeRangeFilter; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs index 50f41a7b..13e510e2 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunk.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GroundingChunk { + /// + /// Chunk from the web. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("web")] + public global::Google.Gemini.Web? Web { get; set; } + /// /// Chunk from image search. /// @@ -20,12 +26,6 @@ public sealed partial class GroundingChunk [global::System.Text.Json.Serialization.JsonPropertyName("retrievedContext")] public global::Google.Gemini.RetrievedContext? RetrievedContext { get; set; } - /// - /// Chunk from the web. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("web")] - public global::Google.Gemini.Web? Web { get; set; } - /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// @@ -41,15 +41,15 @@ public sealed partial class GroundingChunk /// /// Initializes a new instance of the class. /// + /// + /// Chunk from the web. + /// /// /// Chunk from image search. /// /// /// Chunk from context retrieved by the file search tool. /// - /// - /// Chunk from the web. - /// /// /// A grounding chunk from Google Maps. A Maps chunk corresponds to a single place. /// @@ -57,14 +57,14 @@ public sealed partial class GroundingChunk [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunk( + global::Google.Gemini.Web? web, global::Google.Gemini.Image? image, global::Google.Gemini.RetrievedContext? retrievedContext, - global::Google.Gemini.Web? web, global::Google.Gemini.Maps? maps) { + this.Web = web; this.Image = image; this.RetrievedContext = retrievedContext; - this.Web = web; this.Maps = maps; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs index 6de11c0e..b10a2039 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingChunkCustomMetadata.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class GroundingChunkCustomMetadata { - /// - /// 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. /// @@ -32,6 +26,12 @@ public sealed partial class GroundingChunkCustomMetadata [global::System.Text.Json.Serialization.JsonPropertyName("stringValue")] public string? StringValue { get; set; } + /// + /// A list of string values. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("stringListValue")] + public global::Google.Gemini.GroundingChunkStringList? StringListValue { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,9 +41,6 @@ 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. /// @@ -53,19 +50,22 @@ public sealed partial class GroundingChunkCustomMetadata /// /// Optional. The string value of the metadata. /// + /// + /// A list of string values. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingChunkCustomMetadata( - global::Google.Gemini.GroundingChunkStringList? stringListValue, float? numericValue, string? key, - string? stringValue) + string? stringValue, + global::Google.Gemini.GroundingChunkStringList? stringListValue) { - this.StringListValue = stringListValue; this.NumericValue = numericValue; this.Key = key; this.StringValue = stringValue; + this.StringListValue = stringListValue; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs index 7ddfa1e7..bd5df9d9 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.GroundingMetadata.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class GroundingMetadata { + /// + /// Web search queries for the following-up web search. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] + public global::System.Collections.Generic.IList? WebSearchQueries { get; set; } + /// /// Google search entry point. /// @@ -21,22 +27,10 @@ public sealed partial class GroundingMetadata public global::System.Collections.Generic.IList? GroundingSupports { get; set; } /// - /// Image search queries used for grounding. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] - public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } - - /// - /// Metadata related to retrieval in the grounding flow. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] - public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } - - /// - /// Web search queries for the following-up web search. + /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// - [global::System.Text.Json.Serialization.JsonPropertyName("webSearchQueries")] - public global::System.Collections.Generic.IList? WebSearchQueries { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] + public string? GoogleMapsWidgetContextToken { get; set; } /// /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. @@ -45,10 +39,16 @@ public sealed partial class GroundingMetadata public global::System.Collections.Generic.IList? GroundingChunks { get; set; } /// - /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. + /// Metadata related to retrieval in the grounding flow. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMapsWidgetContextToken")] - public string? GoogleMapsWidgetContextToken { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("retrievalMetadata")] + public global::Google.Gemini.RetrievalMetadata? RetrievalMetadata { get; set; } + + /// + /// Image search queries used for grounding. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("imageSearchQueries")] + public global::System.Collections.Generic.IList? ImageSearchQueries { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -59,46 +59,46 @@ public sealed partial class GroundingMetadata /// /// Initializes a new instance of the class. /// + /// + /// Web search queries for the following-up web search. + /// /// /// Google search entry point. /// /// /// List of grounding support. /// - /// - /// Image search queries used for grounding. - /// - /// - /// Metadata related to retrieval in the grounding flow. - /// - /// - /// Web search queries for the following-up web search. + /// + /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. /// /// /// List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses. /// - /// - /// Optional. Resource name of the Google Maps widget context token that can be used with the PlacesContextElement widget in order to render contextual data. Only populated in the case that grounding with Google Maps is enabled. + /// + /// Metadata related to retrieval in the grounding flow. + /// + /// + /// Image search queries used for grounding. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingMetadata( + global::System.Collections.Generic.IList? webSearchQueries, global::Google.Gemini.SearchEntryPoint? searchEntryPoint, global::System.Collections.Generic.IList? groundingSupports, - global::System.Collections.Generic.IList? imageSearchQueries, - global::Google.Gemini.RetrievalMetadata? retrievalMetadata, - global::System.Collections.Generic.IList? webSearchQueries, + string? googleMapsWidgetContextToken, global::System.Collections.Generic.IList? groundingChunks, - string? googleMapsWidgetContextToken) + global::Google.Gemini.RetrievalMetadata? retrievalMetadata, + global::System.Collections.Generic.IList? imageSearchQueries) { + this.WebSearchQueries = webSearchQueries; this.SearchEntryPoint = searchEntryPoint; this.GroundingSupports = groundingSupports; - this.ImageSearchQueries = imageSearchQueries; - this.RetrievalMetadata = retrievalMetadata; - this.WebSearchQueries = webSearchQueries; - this.GroundingChunks = groundingChunks; this.GoogleMapsWidgetContextToken = googleMapsWidgetContextToken; + this.GroundingChunks = groundingChunks; + this.RetrievalMetadata = retrievalMetadata; + this.ImageSearchQueries = imageSearchQueries; } /// 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 c11ba70e..90cec864 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. 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; } /// - /// 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; } /// /// 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. 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 /// + /// + /// Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public GroundingPassageId( - int? partIndex, - string? passageId) + string? passageId, + int? partIndex) { - this.PartIndex = partIndex; this.PassageId = passageId; + this.PartIndex = partIndex; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Image.g.cs index c92b6eea..6d709df6 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 @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Image { - /// - /// The web page URI for attribution. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] - public string? SourceUri { get; set; } - /// /// The title of the web page that the image is from. /// @@ -26,6 +20,12 @@ public sealed partial class Image [global::System.Text.Json.Serialization.JsonPropertyName("imageUri")] public string? ImageUri { get; set; } + /// + /// The web page URI for attribution. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("sourceUri")] + public string? SourceUri { get; set; } + /// /// The root domain of the web page that the image is from, e.g. "example.com". /// @@ -41,15 +41,15 @@ public sealed partial class Image /// /// Initializes a new instance of the class. /// - /// - /// The web page URI for attribution. - /// /// /// The title of the web page that the image is from. /// /// /// The image asset URL. /// + /// + /// The web page URI for attribution. + /// /// /// The root domain of the web page that the image is from, e.g. "example.com". /// @@ -57,14 +57,14 @@ public sealed partial class Image [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Image( - string? sourceUri, string? title, string? imageUri, + string? sourceUri, string? domain) { - this.SourceUri = sourceUri; this.Title = title; this.ImageUri = imageUri; + this.SourceUri = sourceUri; this.Domain = domain; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs index 7dba850b..7f21751e 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImageResponseFormat.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini ///
public sealed partial class ImageResponseFormat { - /// - /// Optional. The delivery mode for the image output. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter))] - public global::Google.Gemini.ImageResponseFormatDelivery? Delivery { get; set; } - /// /// Optional. The MIME type of the image output. /// @@ -22,6 +15,13 @@ public sealed partial class ImageResponseFormat [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatMimeTypeJsonConverter))] public global::Google.Gemini.ImageResponseFormatMimeType? MimeType { get; set; } + /// + /// Optional. The delivery mode for the image output. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("delivery")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ImageResponseFormatDeliveryJsonConverter))] + public global::Google.Gemini.ImageResponseFormatDelivery? Delivery { get; set; } + /// /// Optional. The aspect ratio for the image output. /// @@ -45,12 +45,12 @@ public sealed partial class ImageResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. The delivery mode for the image output. - /// /// /// Optional. The MIME type of the image output. /// + /// + /// Optional. The delivery mode for the image output. + /// /// /// Optional. The aspect ratio for the image output. /// @@ -61,13 +61,13 @@ public sealed partial class ImageResponseFormat [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImageResponseFormat( - global::Google.Gemini.ImageResponseFormatDelivery? delivery, global::Google.Gemini.ImageResponseFormatMimeType? mimeType, + global::Google.Gemini.ImageResponseFormatDelivery? delivery, global::Google.Gemini.ImageResponseFormatAspectRatio? aspectRatio, global::Google.Gemini.ImageResponseFormatImageSize? imageSize) { - this.Delivery = delivery; this.MimeType = mimeType; + this.Delivery = delivery; this.AspectRatio = aspectRatio; this.ImageSize = imageSize; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs index 4f2df00f..99504f17 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ImportFileRequest.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini ///
public sealed partial class ImportFileRequest { - /// - /// Custom metadata to be associated with the file. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] - public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// @@ -26,6 +20,12 @@ public sealed partial class ImportFileRequest [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] public string? FileName { get; set; } + /// + /// Custom metadata to be associated with the file. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] + public global::System.Collections.Generic.IList? CustomMetadata { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class ImportFileRequest /// /// Initializes a new instance of the class. /// - /// - /// Custom metadata to be associated with the file. - /// /// /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto /// /// /// Required. The name of the `File` to import. Example: `files/abc-123` /// + /// + /// Custom metadata to be associated with the file. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ImportFileRequest( - global::System.Collections.Generic.IList? customMetadata, global::Google.Gemini.ChunkingConfig? chunkingConfig, - string? fileName) + string? fileName, + global::System.Collections.Generic.IList? customMetadata) { - this.CustomMetadata = customMetadata; this.ChunkingConfig = chunkingConfig; this.FileName = fileName; + this.CustomMetadata = customMetadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs index 21763257..c4006720 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedEmbedContentResponse.g.cs @@ -14,6 +14,12 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("error")] public global::Google.Gemini.Status? Error { get; set; } + /// + /// The response to an `EmbedContentRequest`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.EmbedContentResponse? Response { get; set; } + /// /// Output only. The metadata associated with the request.
/// Included only in responses @@ -21,12 +27,6 @@ public sealed partial class InlinedEmbedContentResponse [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] public object? Metadata { get; set; } - /// - /// The response to an `EmbedContentRequest`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public global::Google.Gemini.EmbedContentResponse? Response { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,24 +39,24 @@ public sealed partial class InlinedEmbedContentResponse /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// + /// + /// The response to an `EmbedContentRequest`. + /// /// /// Output only. The metadata associated with the request.
/// Included only in responses /// - /// - /// The response to an `EmbedContentRequest`. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedEmbedContentResponse( global::Google.Gemini.Status? error, - object? metadata, - global::Google.Gemini.EmbedContentResponse? response) + global::Google.Gemini.EmbedContentResponse? response, + object? metadata) { this.Error = error; - this.Metadata = metadata; this.Response = response; + this.Metadata = metadata; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InlinedResponse.g.cs index 85a0a538..f3ca3ee4 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,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class InlinedResponse { - /// - /// Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public global::Google.Gemini.GenerateContentResponse? Response { get; set; } - /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// [global::System.Text.Json.Serialization.JsonPropertyName("error")] public global::Google.Gemini.Status? Error { get; set; } + /// + /// Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public global::Google.Gemini.GenerateContentResponse? Response { get; set; } + /// /// Output only. The metadata associated with the request.
/// Included only in responses @@ -36,12 +36,12 @@ public sealed partial class InlinedResponse /// /// Initializes a new instance of the class. /// - /// - /// Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`. - /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). /// + /// + /// 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 @@ -50,12 +50,12 @@ public sealed partial class InlinedResponse [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InlinedResponse( - global::Google.Gemini.GenerateContentResponse? response, global::Google.Gemini.Status? error, + global::Google.Gemini.GenerateContentResponse? response, object? metadata) { - this.Response = response; this.Error = error; + this.Response = response; this.Metadata = metadata; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs index 3d0f91ff..736a29fe 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.InputConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini ///
public sealed partial class InputConfig { - /// - /// The name of the `File` containing the input requests. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] - public string? FileName { get; set; } - /// /// The requests to be processed in the batch if provided as part of the batch creation request. /// [global::System.Text.Json.Serialization.JsonPropertyName("requests")] public global::Google.Gemini.InlinedRequests? Requests { get; set; } + /// + /// The name of the `File` containing the input requests. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("fileName")] + public string? FileName { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class InputConfig /// /// Initializes a new instance of the class. /// - /// - /// The name of the `File` containing the input requests. - /// /// /// The requests to be processed in the batch if provided as part of the batch creation request. /// + /// + /// The name of the `File` containing the input requests. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public InputConfig( - string? fileName, - global::Google.Gemini.InlinedRequests? requests) + global::Google.Gemini.InlinedRequests? requests, + string? fileName) { - this.FileName = fileName; this.Requests = requests; + this.FileName = fileName; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Interval.g.cs index afe10fd0..5ce34e69 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.LatLng.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs index 9a1d2d1e..8c9f6ab6 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LatLng.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class LatLng { - /// - /// The longitude in degrees. It must be in the range [-180.0, +180.0]. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("longitude")] - public double? Longitude { get; set; } - /// /// The latitude in degrees. It must be in the range [-90.0, +90.0]. /// [global::System.Text.Json.Serialization.JsonPropertyName("latitude")] public double? Latitude { get; set; } + /// + /// The longitude in degrees. It must be in the range [-180.0, +180.0]. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("longitude")] + public double? Longitude { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class LatLng /// /// Initializes a new instance of the class. /// - /// - /// The longitude in degrees. It must be in the range [-180.0, +180.0]. - /// /// /// The latitude in degrees. It must be in the range [-90.0, +90.0]. /// + /// + /// The longitude in degrees. It must be in the range [-180.0, +180.0]. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LatLng( - double? longitude, - double? latitude) + double? latitude, + double? longitude) { - this.Longitude = longitude; this.Latitude = latitude; + this.Longitude = longitude; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs index 6a5dbdc2..7bff6270 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListCorporaResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListCorporaResponse { - /// - /// The returned corpora. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("corpora")] - public global::System.Collections.Generic.IList? Corpora { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned corpora. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("corpora")] + public global::System.Collections.Generic.IList? Corpora { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListCorporaResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned corpora. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned corpora. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListCorporaResponse( - global::System.Collections.Generic.IList? corpora, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? corpora) { - this.Corpora = corpora; this.NextPageToken = nextPageToken; + this.Corpora = corpora; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs index ba11d1ec..305a1062 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListDocumentsResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListDocumentsResponse { - /// - /// The returned `Document`s. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("documents")] - public global::System.Collections.Generic.IList? Documents { get; set; } - /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The returned `Document`s. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("documents")] + public global::System.Collections.Generic.IList? Documents { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListDocumentsResponse /// /// Initializes a new instance of the class. /// - /// - /// The returned `Document`s. - /// /// /// A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages. /// + /// + /// The returned `Document`s. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListDocumentsResponse( - global::System.Collections.Generic.IList? documents, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? documents) { - this.Documents = documents; this.NextPageToken = nextPageToken; + this.Documents = documents; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs index 31720695..56d16d70 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListFilesResponse.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ListFilesResponse { - /// - /// The list of `File`s. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("files")] - public global::System.Collections.Generic.IList? Files { get; set; } - /// /// A token that can be sent as a `page_token` into a subsequent `ListFiles` call. /// [global::System.Text.Json.Serialization.JsonPropertyName("nextPageToken")] public string? NextPageToken { get; set; } + /// + /// The list of `File`s. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("files")] + public global::System.Collections.Generic.IList? Files { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class ListFilesResponse /// /// Initializes a new instance of the class. /// - /// - /// The list of `File`s. - /// /// /// A token that can be sent as a `page_token` into a subsequent `ListFiles` call. /// + /// + /// The list of `File`s. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ListFilesResponse( - global::System.Collections.Generic.IList? files, - string? nextPageToken) + string? nextPageToken, + global::System.Collections.Generic.IList? files) { - this.Files = files; this.NextPageToken = nextPageToken; + this.Files = files; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListTunedModelsResponse.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ListTunedModelsResponse.g.cs index 3c572fa7..920b8335 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 6ae18c56..6154061d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.LogprobsResultCandidate.g.cs @@ -8,12 +8,6 @@ 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 token id value. /// @@ -26,6 +20,12 @@ public sealed partial class LogprobsResultCandidate [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; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class LogprobsResultCandidate /// /// Initializes a new instance of the class. /// - /// - /// The candidate’s token string value. - /// /// /// The candidate’s token id value. /// /// /// The candidate's log probability. /// + /// + /// The candidate’s token string value. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public LogprobsResultCandidate( - string? token, int? tokenId, - float? logProbability) + float? logProbability, + string? token) { - this.Token = token; this.TokenId = tokenId; this.LogProbability = logProbability; + this.Token = token; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs index 34e729a5..df04fa7c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Maps.g.cs @@ -8,12 +8,24 @@ namespace Google.Gemini /// public sealed partial class Maps { + /// + /// Title of the place. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } + /// /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// [global::System.Text.Json.Serialization.JsonPropertyName("placeId")] public string? PlaceId { get; set; } + /// + /// Text description of the place answer. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } + /// /// URI reference of the place. /// @@ -26,18 +38,6 @@ public sealed partial class Maps [global::System.Text.Json.Serialization.JsonPropertyName("placeAnswerSources")] public global::Google.Gemini.PlaceAnswerSources? PlaceAnswerSources { get; set; } - /// - /// Title of the place. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } - - /// - /// Text description of the place answer. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -47,36 +47,36 @@ public sealed partial class Maps /// /// Initializes a new instance of the class. /// + /// + /// Title of the place. + /// /// /// The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place. /// + /// + /// Text description of the place answer. + /// /// /// URI reference of the place. /// /// /// Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: "does Bar Foo have Wifi" or "is Foo Bar wheelchair accessible?"). Currently we only support review snippets as sources. /// - /// - /// Title of the place. - /// - /// - /// Text description of the place answer. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Maps( + string? title, string? placeId, + string? text, string? uri, - global::Google.Gemini.PlaceAnswerSources? placeAnswerSources, - string? title, - string? text) + global::Google.Gemini.PlaceAnswerSources? placeAnswerSources) { + this.Title = title; this.PlaceId = placeId; + this.Text = text; this.Uri = uri; this.PlaceAnswerSources = placeAnswerSources; - this.Title = title; - this.Text = text; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs index c294428e..197f4054 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.McpServer.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class McpServer { - /// - /// A transport that can stream HTTP requests and responses. Next ID: 6 - /// - [global::System.Text.Json.Serialization.JsonPropertyName("streamableHttpTransport")] - public global::Google.Gemini.StreamableHttpTransport? StreamableHttpTransport { get; set; } - /// /// The name of the MCPServer. /// [global::System.Text.Json.Serialization.JsonPropertyName("name")] public string? Name { get; set; } + /// + /// A transport that can stream HTTP requests and responses. Next ID: 6 + /// + [global::System.Text.Json.Serialization.JsonPropertyName("streamableHttpTransport")] + public global::Google.Gemini.StreamableHttpTransport? StreamableHttpTransport { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class McpServer /// /// Initializes a new instance of the class. /// - /// - /// A transport that can stream HTTP requests and responses. Next ID: 6 - /// /// /// The name of the MCPServer. /// + /// + /// A transport that can stream HTTP requests and responses. Next ID: 6 + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public McpServer( - global::Google.Gemini.StreamableHttpTransport? streamableHttpTransport, - string? name) + string? name, + global::Google.Gemini.StreamableHttpTransport? streamableHttpTransport) { - this.StreamableHttpTransport = streamableHttpTransport; this.Name = name; + this.StreamableHttpTransport = streamableHttpTransport; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Model.g.cs index 42283fe3..048fc7ff 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,22 +9,22 @@ namespace Google.Gemini public sealed partial class Model { /// - /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. + /// Maximum number of output tokens available for this model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] - public string? DisplayName { get; set; } + [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. + /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("displayName")] + public string? DisplayName { get; set; } /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// 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("baseModelId")] - public string? BaseModelId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } /// /// A short description of the model. @@ -33,22 +33,22 @@ public sealed partial class Model public string? Description { get; set; } /// - /// Maximum number of output tokens available for this model. + /// Whether the model supports thinking. /// - [global::System.Text.Json.Serialization.JsonPropertyName("outputTokenLimit")] - public int? OutputTokenLimit { 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; } /// - /// 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; } /// /// 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. @@ -57,34 +57,34 @@ public sealed partial class Model public float? TopP { get; set; } /// - /// Maximum number of input tokens allowed for this model. + /// The maximum temperature this model can use. /// - [global::System.Text.Json.Serialization.JsonPropertyName("inputTokenLimit")] - public int? InputTokenLimit { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxTemperature")] + public float? MaxTemperature { 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` + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// - [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("version")] + public string? Version { get; set; } /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. + /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("supportedGenerationMethods")] - public global::System.Collections.Generic.IList? SupportedGenerationMethods { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] + public float? Temperature { get; set; } /// - /// Whether the model supports thinking. + /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinking")] - public bool? Thinking { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { get; set; } /// - /// 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` /// - [global::System.Text.Json.Serialization.JsonPropertyName("temperature")] - public float? Temperature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("baseModelId")] + public string? BaseModelId { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -95,76 +95,76 @@ public sealed partial class Model /// /// Initializes a new instance of the class. /// + /// + /// Maximum number of output tokens available for this model. + /// /// /// The human-readable name of the model. E.g. "Gemini 1.5 Flash". The name can be up to 128 characters long and can consist of any UTF-8 characters. /// - /// - /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. - /// - /// - /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// + /// Required. The resource name of the `Model`. Refer to [Model variants](https://ai.google.dev/gemini-api/docs/models/gemini#model-variations) for all allowed values. Format: `models/{model}` with a `{model}` naming convention of: * "{base_model_id}-{version}" Examples: * `models/gemini-1.5-flash-001` /// /// /// A short description of the model. /// - /// - /// Maximum number of output tokens available for this model. - /// - /// - /// The maximum temperature this model can use. - /// - /// - /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) + /// + /// Whether the model supports thinking. /// - /// - /// For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model. + /// + /// 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 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. /// - /// - /// The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`. + /// + /// The maximum temperature this model can use. /// - /// - /// Whether the model supports thinking. + /// + /// Required. The version number of the model. This represents the major version (`1.0` or `1.5`) /// /// /// Controls the randomness of the output. Values can range over `[0.0,max_temperature]`, inclusive. A higher value will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be used by the backend while making the call to the model. /// + /// + /// For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter. + /// + /// + /// Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash` + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Model( + int? outputTokenLimit, string? displayName, - int? topK, - string? baseModelId, + string? name, string? description, - int? outputTokenLimit, + bool? thinking, + global::System.Collections.Generic.IList? supportedGenerationMethods, + int? inputTokenLimit, + float? topP, float? maxTemperature, string? version, - float? topP, - int? inputTokenLimit, - string? name, - global::System.Collections.Generic.IList? supportedGenerationMethods, - bool? thinking, - float? temperature) + float? temperature, + int? topK, + string? baseModelId) { + this.OutputTokenLimit = outputTokenLimit; this.DisplayName = displayName; - this.TopK = topK; - this.BaseModelId = baseModelId; + this.Name = name; this.Description = description; - this.OutputTokenLimit = outputTokenLimit; + this.Thinking = thinking; + this.SupportedGenerationMethods = supportedGenerationMethods; + this.InputTokenLimit = inputTokenLimit; + this.TopP = topP; this.MaxTemperature = maxTemperature; this.Version = version; - this.TopP = topP; - this.InputTokenLimit = inputTokenLimit; - this.Name = name; - this.SupportedGenerationMethods = supportedGenerationMethods; - this.Thinking = thinking; this.Temperature = temperature; + this.TopK = topK; + this.BaseModelId = baseModelId; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs index 75612d76..e5ba4a30 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ModelStatus.g.cs @@ -15,18 +15,18 @@ public sealed partial class ModelStatus [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ModelStatusModelStageJsonConverter))] public global::Google.Gemini.ModelStatusModelStage? ModelStage { get; set; } - /// - /// The time at which the model will be retired. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retirementTime")] - public string? RetirementTime { get; set; } - /// /// A message explaining the model status. /// [global::System.Text.Json.Serialization.JsonPropertyName("message")] public string? Message { get; set; } + /// + /// The time at which the model will be retired. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retirementTime")] + public string? RetirementTime { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ModelStatus /// /// The stage of the underlying model. /// - /// - /// The time at which the model will be retired. - /// /// /// A message explaining the model status. /// + /// + /// The time at which the model will be retired. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ModelStatus( global::Google.Gemini.ModelStatusModelStage? modelStage, - string? retirementTime, - string? message) + string? message, + string? retirementTime) { this.ModelStage = modelStage; - this.RetirementTime = retirementTime; this.Message = message; + this.RetirementTime = retirementTime; } /// 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 5153de7e..be129cef 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Operation.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Operation.g.cs @@ -9,16 +9,16 @@ namespace Google.Gemini public sealed partial class Operation { /// - /// The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`. + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] + public object? Metadata { get; set; } /// - /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. + /// 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("done")] - public bool? Done { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("response")] + public object? Response { get; set; } /// /// The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. @@ -27,10 +27,10 @@ public sealed partial class Operation 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. + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// - [global::System.Text.Json.Serialization.JsonPropertyName("metadata")] - public object? Metadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("done")] + public bool? Done { get; set; } /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). @@ -47,17 +47,17 @@ public sealed partial class Operation /// /// Initializes a new instance of the class. /// + /// + /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// /// /// 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 server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`. /// - /// - /// Service-specific metadata associated with the operation. It typically contains progress information and common metadata such as create time. Some services might not provide such metadata. Any method that returns a long-running operation should document the metadata type, if any. + /// + /// If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available. /// /// /// The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors). @@ -66,16 +66,16 @@ public sealed partial class Operation [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Operation( + object? metadata, object? response, - bool? done, string? name, - object? metadata, + bool? done, global::Google.Gemini.Status? error) { + this.Metadata = metadata; this.Response = response; - this.Done = done; this.Name = name; - this.Metadata = metadata; + this.Done = done; this.Error = error; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Part.g.cs index caeb9a19..61d270fa 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,12 +10,6 @@ namespace Google.Gemini /// public sealed partial class Part { - /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] - public global::Google.Gemini.ToolCall? ToolCall { get; set; } - /// /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. /// @@ -23,71 +17,77 @@ public sealed partial class Part public object? PartMetadata { get; set; } /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// 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("codeExecutionResult")] - public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] + public global::Google.Gemini.ExecutableCode? ExecutableCode { 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. + /// 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("functionResponse")] - public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] + public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } /// - /// Optional. Indicates if the part is thought from the model. + /// URI based data. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thought")] - public bool? Thought { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] + public global::Google.Gemini.FileData? FileData { get; set; } /// - /// Inline text. + /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] + [global::System.Obsolete("This property marked as deprecated.")] + public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } /// - /// URI based data. + /// Optional. Indicates if the part is thought from the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileData")] - public global::Google.Gemini.FileData? FileData { get; set; } + [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. + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. /// - [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] - public global::Google.Gemini.Blob? InlineData { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("codeExecutionResult")] + public global::Google.Gemini.CodeExecutionResult? CodeExecutionResult { 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. + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. /// - [global::System.Text.Json.Serialization.JsonPropertyName("executableCode")] - public global::Google.Gemini.ExecutableCode? ExecutableCode { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] + public byte[]? ThoughtSignature { get; set; } /// - /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. + /// Inline text. /// - [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] - public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { 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`. + /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. /// - [global::System.Text.Json.Serialization.JsonPropertyName("toolResponse")] - public global::Google.Gemini.ToolResponse? ToolResponse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionResponse")] + public global::Google.Gemini.FunctionResponse? FunctionResponse { get; set; } /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. /// - [global::System.Text.Json.Serialization.JsonPropertyName("thoughtSignature")] - public byte[]? ThoughtSignature { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("toolCall")] + public global::Google.Gemini.ToolCall? ToolCall { get; set; } /// - /// Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content. + /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// - [global::System.Text.Json.Serialization.JsonPropertyName("videoMetadata")] - [global::System.Obsolete("This property marked as deprecated.")] - public global::Google.Gemini.VideoMetadata? VideoMetadata { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("functionCall")] + public global::Google.Gemini.FunctionCall? FunctionCall { get; set; } + + /// + /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("inlineData")] + public global::Google.Gemini.Blob? InlineData { get; set; } /// /// 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. /// - /// - /// A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`. - /// /// /// Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams. /// - /// - /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// + /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. /// - /// - /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. + /// + /// 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`. + /// + /// + /// URI based data. /// /// /// Optional. Indicates if the part is thought from the model. /// + /// + /// Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used. + /// + /// + /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// /// /// Inline text. /// - /// - /// URI based data. - /// - /// - /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. + /// + /// The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction. /// - /// - /// Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated. + /// + /// 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`. /// /// /// A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values. /// - /// - /// The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`. - /// - /// - /// Optional. An opaque signature for the thought so it can be reused in subsequent requests. + /// + /// Raw media bytes. Text should not be sent as raw bytes, use the 'text' field. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Part( - global::Google.Gemini.ToolCall? toolCall, object? partMetadata, - global::Google.Gemini.CodeExecutionResult? codeExecutionResult, - global::Google.Gemini.FunctionResponse? functionResponse, + global::Google.Gemini.ExecutableCode? executableCode, + global::Google.Gemini.ToolResponse? toolResponse, + global::Google.Gemini.FileData? fileData, bool? thought, + global::Google.Gemini.CodeExecutionResult? codeExecutionResult, + byte[]? thoughtSignature, string? text, - global::Google.Gemini.FileData? fileData, - global::Google.Gemini.Blob? inlineData, - global::Google.Gemini.ExecutableCode? executableCode, + global::Google.Gemini.FunctionResponse? functionResponse, + global::Google.Gemini.ToolCall? toolCall, global::Google.Gemini.FunctionCall? functionCall, - global::Google.Gemini.ToolResponse? toolResponse, - byte[]? thoughtSignature) + global::Google.Gemini.Blob? inlineData) { - this.ToolCall = toolCall; this.PartMetadata = partMetadata; - this.CodeExecutionResult = codeExecutionResult; - this.FunctionResponse = functionResponse; - this.Thought = thought; - this.Text = text; - this.FileData = fileData; - this.InlineData = inlineData; this.ExecutableCode = executableCode; - this.FunctionCall = functionCall; this.ToolResponse = toolResponse; + this.FileData = fileData; + this.Thought = thought; + this.CodeExecutionResult = codeExecutionResult; this.ThoughtSignature = thoughtSignature; + this.Text = text; + this.FunctionResponse = functionResponse; + this.ToolCall = toolCall; + this.FunctionCall = functionCall; + this.InlineData = inlineData; } /// 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 e162b999..5f77323b 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Permission.g.cs @@ -8,6 +8,13 @@ namespace Google.Gemini /// public sealed partial class Permission { + /// + /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
+ /// Included only in responses + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("name")] + public string? Name { get; set; } + /// /// Optional. Immutable. The type of the grantee. /// @@ -15,13 +22,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; } - /// - /// Required. The role granted by this permission. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("role")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] - public global::Google.Gemini.PermissionRole? Role { get; set; } - /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// @@ -29,11 +29,11 @@ public sealed partial class Permission public string? EmailAddress { get; set; } /// - /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
- /// Included only in responses + /// Required. The role granted by this permission. ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("role")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PermissionRoleJsonConverter))] + public global::Google.Gemini.PermissionRole? Role { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -44,32 +44,32 @@ public sealed partial class Permission /// /// Initializes a new instance of the class. /// + /// + /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
+ /// Included only in responses + /// /// /// Optional. Immutable. The type of the grantee. /// - /// - /// Required. The role granted by this permission. - /// /// /// Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE. /// - /// - /// Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.
- /// Included only in responses + /// + /// Required. The role granted by this permission. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Permission( + string? name, global::Google.Gemini.PermissionGranteeType? granteeType, - global::Google.Gemini.PermissionRole? role, string? emailAddress, - string? name) + global::Google.Gemini.PermissionRole? role) { + this.Name = name; this.GranteeType = granteeType; - this.Role = role; this.EmailAddress = emailAddress; - this.Name = name; + 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 08e93e4a..fccaca72 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.PromptFeedback.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class PromptFeedback { + /// + /// Ratings for safety of the prompt. There is at most one rating per category. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] + public global::System.Collections.Generic.IList? SafetyRatings { get; set; } + /// /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. /// @@ -15,12 +21,6 @@ public sealed partial class PromptFeedback [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.PromptFeedbackBlockReasonJsonConverter))] public global::Google.Gemini.PromptFeedbackBlockReason? BlockReason { get; set; } - /// - /// Ratings for safety of the prompt. There is at most one rating per category. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("safetyRatings")] - public global::System.Collections.Generic.IList? SafetyRatings { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class PromptFeedback /// /// Initializes a new instance of the class. /// - /// - /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. - /// /// /// Ratings for safety of the prompt. There is at most one rating per category. /// + /// + /// Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public PromptFeedback( - global::Google.Gemini.PromptFeedbackBlockReason? blockReason, - global::System.Collections.Generic.IList? safetyRatings) + global::System.Collections.Generic.IList? safetyRatings, + global::Google.Gemini.PromptFeedbackBlockReason? blockReason) { - this.BlockReason = blockReason; this.SafetyRatings = safetyRatings; + this.BlockReason = blockReason; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs index b12ae35b..fafacf58 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ResponseFormatConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class ResponseFormatConfig { - /// - /// Configuration for image output format. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("image")] - public global::Google.Gemini.ImageResponseFormat? Image { get; set; } - /// /// Configuration for audio output format. /// [global::System.Text.Json.Serialization.JsonPropertyName("audio")] public global::Google.Gemini.AudioResponseFormat? Audio { get; set; } + /// + /// Configuration for image output format. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("image")] + public global::Google.Gemini.ImageResponseFormat? Image { get; set; } + /// /// Configuration for text output format. /// @@ -35,12 +35,12 @@ public sealed partial class ResponseFormatConfig /// /// Initializes a new instance of the class. /// - /// - /// Configuration for image output format. - /// /// /// Configuration for audio output format. /// + /// + /// Configuration for image output format. + /// /// /// Configuration for text output format. /// @@ -48,12 +48,12 @@ public sealed partial class ResponseFormatConfig [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ResponseFormatConfig( - global::Google.Gemini.ImageResponseFormat? image, global::Google.Gemini.AudioResponseFormat? audio, + global::Google.Gemini.ImageResponseFormat? image, global::Google.Gemini.TextResponseFormat? text) { - this.Image = image; this.Audio = audio; + this.Image = image; this.Text = text; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs index 587cc51b..10e07f1c 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievalConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini ///
public sealed partial class RetrievalConfig { - /// - /// Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] - public string? LanguageCode { get; set; } - /// /// An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges. /// [global::System.Text.Json.Serialization.JsonPropertyName("latLng")] public global::Google.Gemini.LatLng? LatLng { get; set; } + /// + /// Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] + public string? LanguageCode { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class RetrievalConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt). - /// /// /// An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges. /// + /// + /// Optional. The language code of the user. Language code for content. Use language tags defined by [BCP47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievalConfig( - string? languageCode, - global::Google.Gemini.LatLng? latLng) + global::Google.Gemini.LatLng? latLng, + string? languageCode) { - this.LanguageCode = languageCode; this.LatLng = latLng; + this.LanguageCode = languageCode; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs index 2fd88162..83712a80 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.RetrievedContext.g.cs @@ -9,16 +9,16 @@ namespace Google.Gemini public sealed partial class RetrievedContext { /// - /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` + /// Optional. Text of the chunk. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStore")] - public string? FileSearchStore { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("text")] + public string? Text { get; set; } /// - /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} + /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` /// - [global::System.Text.Json.Serialization.JsonPropertyName("mediaId")] - public string? MediaId { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearchStore")] + public string? FileSearchStore { get; set; } /// /// Optional. Title of the document. @@ -27,10 +27,16 @@ public sealed partial class RetrievedContext public string? Title { get; set; } /// - /// Optional. Text of the chunk. + /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} /// - [global::System.Text.Json.Serialization.JsonPropertyName("text")] - public string? Text { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("mediaId")] + public string? MediaId { get; set; } + + /// + /// Optional. URI reference of the semantic retrieval document. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("uri")] + public string? Uri { get; set; } /// /// Optional. User-provided metadata about the retrieved context. @@ -44,12 +50,6 @@ public sealed partial class RetrievedContext [global::System.Text.Json.Serialization.JsonPropertyName("pageNumber")] public int? PageNumber { get; set; } - /// - /// Optional. URI reference of the semantic retrieval document. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("uri")] - public string? Uri { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -59,17 +59,20 @@ public sealed partial class RetrievedContext /// /// Initializes a new instance of the class. /// + /// + /// Optional. Text of the chunk. + /// /// /// Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123` /// - /// - /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} - /// /// /// Optional. Title of the document. /// - /// - /// Optional. Text of the chunk. + /// + /// Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id} + /// + /// + /// Optional. URI reference of the semantic retrieval document. /// /// /// Optional. User-provided metadata about the retrieved context. @@ -77,28 +80,25 @@ public sealed partial class RetrievedContext /// /// Optional. Page number of the retrieved context, if applicable. /// - /// - /// Optional. URI reference of the semantic retrieval document. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public RetrievedContext( + string? text, string? fileSearchStore, - string? mediaId, string? title, - string? text, + string? mediaId, + string? uri, global::System.Collections.Generic.IList? customMetadata, - int? pageNumber, - string? uri) + int? pageNumber) { + this.Text = text; this.FileSearchStore = fileSearchStore; - this.MediaId = mediaId; this.Title = title; - this.Text = text; + this.MediaId = mediaId; + this.Uri = uri; this.CustomMetadata = customMetadata; this.PageNumber = pageNumber; - this.Uri = uri; } /// 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 8c5f9176..19c4fb32 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ReviewSnippet.g.cs @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class ReviewSnippet { /// - /// Title of the review. + /// The ID of the review snippet. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("reviewId")] + public string? ReviewId { get; set; } /// /// A link that corresponds to the user review on Google Maps. @@ -21,10 +21,10 @@ public sealed partial class ReviewSnippet public string? GoogleMapsUri { get; set; } /// - /// The ID of the review snippet. + /// Title of the review. /// - [global::System.Text.Json.Serialization.JsonPropertyName("reviewId")] - public string? ReviewId { 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. + /// + /// The ID of the review snippet. /// /// /// A link that corresponds to the user review on Google Maps. /// - /// - /// The ID of the review snippet. + /// + /// Title of the review. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ReviewSnippet( - string? title, + string? reviewId, string? googleMapsUri, - string? reviewId) + string? title) { - this.Title = title; - this.GoogleMapsUri = googleMapsUri; this.ReviewId = reviewId; + this.GoogleMapsUri = googleMapsUri; + this.Title = title; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs index 1c981d0c..8a3dac69 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SafetySetting.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class SafetySetting { - /// - /// Required. The category for this setting. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("category")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter))] - public global::Google.Gemini.SafetySettingCategory? Category { get; set; } - /// /// Required. Controls the probability threshold at which harm is blocked. /// @@ -22,6 +15,13 @@ public sealed partial class SafetySetting [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetySettingThresholdJsonConverter))] public global::Google.Gemini.SafetySettingThreshold? Threshold { get; set; } + /// + /// Required. The category for this setting. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("category")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SafetySettingCategoryJsonConverter))] + public global::Google.Gemini.SafetySettingCategory? Category { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -31,21 +31,21 @@ public sealed partial class SafetySetting /// /// Initializes a new instance of the class. /// - /// - /// Required. The category for this setting. - /// /// /// Required. Controls the probability threshold at which harm is blocked. /// + /// + /// Required. The category for this setting. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SafetySetting( - global::Google.Gemini.SafetySettingCategory? category, - global::Google.Gemini.SafetySettingThreshold? threshold) + global::Google.Gemini.SafetySettingThreshold? threshold, + global::Google.Gemini.SafetySettingCategory? category) { - this.Category = category; this.Threshold = threshold; + this.Category = category; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Schema.g.cs index b29a0753..d3f50c25 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,53 +9,40 @@ namespace Google.Gemini public sealed partial class Schema { /// - /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING - /// - [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] - public string? MinLength { get; set; } - - /// - /// Optional. Minimum number of the properties for Type.OBJECT. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] - public string? MinProperties { get; set; } - - /// - /// Optional. Indicates if the value may be null. + /// 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("nullable")] - public bool? Nullable { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("enum")] + public global::System.Collections.Generic.IList? Enum { get; set; } /// - /// Optional. Example of the object. Will only populated when the object is the root. + /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("example")] - public object? Example { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] + public double? Maximum { get; set; } /// - /// 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 /// - [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] - public string? Pattern { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minLength")] + public string? MinLength { get; set; } /// - /// Required. Data type. + /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. /// - [global::System.Text.Json.Serialization.JsonPropertyName("type")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.SchemaTypeJsonConverter))] - public global::Google.Gemini.SchemaType? Type { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("description")] + public string? Description { get; set; } /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// Optional. Minimum number of the elements for Type.ARRAY. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maximum")] - public double? Maximum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] + public string? MinItems { get; set; } /// - /// Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER + /// Optional. Properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] - public double? Minimum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("properties")] + public global::System.Collections.Generic.Dictionary? Properties { get; set; } /// /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. @@ -63,6 +50,12 @@ public sealed partial class Schema [global::System.Text.Json.Serialization.JsonPropertyName("format")] public string? Format { get; set; } + /// + /// Optional. Indicates if the value may be null. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("nullable")] + public bool? Nullable { get; set; } + /// /// Optional. Maximum number of the elements for Type.ARRAY. /// @@ -70,10 +63,11 @@ public sealed partial class Schema public string? MaxItems { get; set; } /// - /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). + /// Required. Data type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("items")] - public global::Google.Gemini.Schema? Items { 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 order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. @@ -82,64 +76,70 @@ public sealed partial class Schema public global::System.Collections.Generic.IList? PropertyOrdering { get; set; } /// - /// Optional. The title of the schema. + /// Optional. Required properties of Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("title")] - public string? Title { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("required")] + public global::System.Collections.Generic.IList? Required { get; set; } /// - /// Optional. Minimum number of the elements for Type.ARRAY. + /// Optional. Maximum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("minItems")] - public string? MinItems { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] + public string? MaxProperties { 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 INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER /// - [global::System.Text.Json.Serialization.JsonPropertyName("default")] - public object? Default { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minimum")] + public double? Minimum { 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. Pattern of the Type.STRING to restrict a string to a regular expression. /// - [global::System.Text.Json.Serialization.JsonPropertyName("enum")] - public global::System.Collections.Generic.IList? Enum { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("pattern")] + public string? Pattern { get; set; } /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// Optional. The title of the schema. /// - [global::System.Text.Json.Serialization.JsonPropertyName("description")] - public string? Description { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("title")] + public string? Title { get; set; } /// - /// Optional. Required properties of Type.OBJECT. + /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - [global::System.Text.Json.Serialization.JsonPropertyName("required")] - public global::System.Collections.Generic.IList? Required { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("items")] + public global::Google.Gemini.Schema? Items { get; set; } /// - /// Optional. Maximum length of the Type.STRING + /// Optional. The value should be validated against any (one or more) of the subschemas in the list. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] - public string? MaxLength { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] + public global::System.Collections.Generic.IList? AnyOf { get; set; } /// - /// Optional. Properties of 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. /// - [global::System.Text.Json.Serialization.JsonPropertyName("properties")] - public global::System.Collections.Generic.Dictionary? Properties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("default")] + public object? Default { get; set; } /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. + /// Optional. Minimum number of the properties for Type.OBJECT. /// - [global::System.Text.Json.Serialization.JsonPropertyName("anyOf")] - public global::System.Collections.Generic.IList? AnyOf { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("minProperties")] + public string? MinProperties { get; set; } /// - /// Optional. Maximum number of the properties for Type.OBJECT. + /// Optional. Example of the object. Will only populated when the object is the root. /// - [global::System.Text.Json.Serialization.JsonPropertyName("maxProperties")] - public string? MaxProperties { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("example")] + public object? Example { get; set; } + + /// + /// Optional. Maximum length of the Type.STRING + /// + [global::System.Text.Json.Serialization.JsonPropertyName("maxLength")] + public string? MaxLength { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -150,121 +150,121 @@ public sealed partial class Schema /// /// Initializes a new instance of the class. /// + /// + /// Optional. 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. Maximum value of the Type.INTEGER and Type.NUMBER + /// /// /// Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING /// - /// - /// Optional. Minimum number of the properties for Type.OBJECT. + /// + /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// + /// Optional. Minimum number of the elements for Type.ARRAY. + /// + /// + /// Optional. Properties of Type.OBJECT. + /// + /// + /// Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality. /// /// /// Optional. Indicates if the value may be null. /// - /// - /// Optional. Example of the object. Will only populated when the object is the root. - /// - /// - /// Optional. Pattern of the Type.STRING to restrict a string to a regular expression. + /// + /// Optional. Maximum number of the elements for Type.ARRAY. /// /// /// Required. Data type. /// - /// - /// Optional. Maximum value of the Type.INTEGER and Type.NUMBER + /// + /// Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response. + /// + /// + /// Optional. Required properties of Type.OBJECT. + /// + /// + /// Optional. Maximum number of the properties for Type.OBJECT. /// /// /// 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. Pattern of the Type.STRING to restrict a string to a regular expression. /// - /// - /// Optional. Maximum number of the elements for Type.ARRAY. + /// + /// Optional. The title of the schema. /// /// /// The `Schema` object allows the definition of input and output data types. These types can be objects, but also primitives and arrays. Represents a select subset of an [OpenAPI 3.0 schema object](https://spec.openapis.org/oas/v3.0.3#schema). /// - /// - /// Optional. 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. The title of the schema. - /// - /// - /// Optional. Minimum 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. Default value of the field. Per JSON Schema, this field is intended for documentation generators and doesn't affect validation. Thus it's included here and ignored so that developers who send schemas with a `default` field don't get unknown-field errors. /// - /// - /// Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:["EAST", NORTH", "SOUTH", "WEST"]} - /// - /// - /// Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown. + /// + /// Optional. Minimum number of the properties for Type.OBJECT. /// - /// - /// Optional. Required properties of Type.OBJECT. + /// + /// Optional. Example of the object. Will only populated when the object is the root. /// /// /// Optional. Maximum length of the Type.STRING /// - /// - /// Optional. Properties of Type.OBJECT. - /// - /// - /// Optional. The value should be validated against any (one or more) of the subschemas in the list. - /// - /// - /// Optional. Maximum number of the properties for Type.OBJECT. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Schema( - string? minLength, - string? minProperties, - bool? nullable, - object? example, - string? pattern, - global::Google.Gemini.SchemaType? type, + global::System.Collections.Generic.IList? @enum, double? maximum, - double? minimum, + string? minLength, + string? description, + string? minItems, + global::System.Collections.Generic.Dictionary? properties, string? format, + bool? nullable, string? maxItems, - global::Google.Gemini.Schema? items, + global::Google.Gemini.SchemaType? type, global::System.Collections.Generic.IList? propertyOrdering, - string? title, - string? minItems, - object? @default, - global::System.Collections.Generic.IList? @enum, - string? description, global::System.Collections.Generic.IList? required, - string? maxLength, - global::System.Collections.Generic.Dictionary? properties, + string? maxProperties, + double? minimum, + string? pattern, + string? title, + global::Google.Gemini.Schema? items, global::System.Collections.Generic.IList? anyOf, - string? maxProperties) + object? @default, + string? minProperties, + object? example, + string? maxLength) { - this.MinLength = minLength; - this.MinProperties = minProperties; - this.Nullable = nullable; - this.Example = example; - this.Pattern = pattern; - this.Type = type; + this.Enum = @enum; this.Maximum = maximum; - this.Minimum = minimum; + this.MinLength = minLength; + this.Description = description; + this.MinItems = minItems; + this.Properties = properties; this.Format = format; + this.Nullable = nullable; this.MaxItems = maxItems; - this.Items = items; + this.Type = type; this.PropertyOrdering = propertyOrdering; + this.Required = required; + this.MaxProperties = maxProperties; + this.Minimum = minimum; + this.Pattern = pattern; this.Title = title; - this.MinItems = minItems; + this.Items = items; + this.AnyOf = anyOf; this.Default = @default; - this.Enum = @enum; - this.Description = description; - this.Required = required; + this.MinProperties = minProperties; + this.Example = example; this.MaxLength = maxLength; - this.Properties = properties; - this.AnyOf = anyOf; - this.MaxProperties = maxProperties; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs index 51762010..f9bd1b66 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SearchTypes.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SearchTypes { - /// - /// Image search for grounding and related configurations. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("imageSearch")] - public global::Google.Gemini.ImageSearch? ImageSearch { get; set; } - /// /// Standard web search for grounding and related configurations. /// [global::System.Text.Json.Serialization.JsonPropertyName("webSearch")] public global::Google.Gemini.WebSearch? WebSearch { get; set; } + /// + /// Image search for grounding and related configurations. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("imageSearch")] + public global::Google.Gemini.ImageSearch? ImageSearch { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class SearchTypes /// /// Initializes a new instance of the class. /// - /// - /// Image search for grounding and related configurations. - /// /// /// Standard web search for grounding and related configurations. /// + /// + /// Image search for grounding and related configurations. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SearchTypes( - global::Google.Gemini.ImageSearch? imageSearch, - global::Google.Gemini.WebSearch? webSearch) + global::Google.Gemini.WebSearch? webSearch, + global::Google.Gemini.ImageSearch? imageSearch) { - this.ImageSearch = imageSearch; this.WebSearch = webSearch; + this.ImageSearch = imageSearch; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SemanticRetrieverChunk.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SemanticRetrieverChunk.g.cs index 8890bdf2..db03bec1 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SemanticRetrieverChunk.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SemanticRetrieverChunk.g.cs @@ -9,18 +9,18 @@ namespace Google.Gemini public sealed partial class SemanticRetrieverChunk { /// - /// Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`
+ /// Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("chunk")] - public string? Chunk { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("source")] + public string? Source { get; set; } /// - /// Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`
+ /// Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("source")] - public string? Source { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("chunk")] + public string? Chunk { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -31,23 +31,23 @@ public sealed partial class SemanticRetrieverChunk /// /// Initializes a new instance of the class. /// - /// - /// Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`
- /// Included only in responses - /// /// /// Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`
/// Included only in responses /// + /// + /// Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SemanticRetrieverChunk( - string? chunk, - string? source) + string? source, + string? chunk) { - this.Chunk = chunk; this.Source = source; + this.Chunk = chunk; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs index f9754c22..0a6833b4 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeakerVoiceConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class SpeakerVoiceConfig { - /// - /// The configuration for the voice to use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] - public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } - /// /// Required. The name of the speaker to use. Should be the same as in the prompt. /// [global::System.Text.Json.Serialization.JsonPropertyName("speaker")] public string? Speaker { get; set; } + /// + /// The configuration for the voice to use. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] + public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class SpeakerVoiceConfig /// /// Initializes a new instance of the class. /// - /// - /// The configuration for the voice to use. - /// /// /// Required. The name of the speaker to use. Should be the same as in the prompt. /// + /// + /// The configuration for the voice to use. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SpeakerVoiceConfig( - global::Google.Gemini.VoiceConfig? voiceConfig, - string? speaker) + string? speaker, + global::Google.Gemini.VoiceConfig? voiceConfig) { - this.VoiceConfig = voiceConfig; this.Speaker = speaker; + this.VoiceConfig = voiceConfig; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.SpeechConfig.g.cs index 4d41ca9d..2cdf8fc7 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,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class SpeechConfig { - /// - /// The configuration for the voice to use. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] - public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } - /// /// The configuration for the multi-speaker setup. /// @@ -26,6 +20,12 @@ public sealed partial class SpeechConfig [global::System.Text.Json.Serialization.JsonPropertyName("languageCode")] public string? LanguageCode { get; set; } + /// + /// The configuration for the voice to use. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("voiceConfig")] + public global::Google.Gemini.VoiceConfig? VoiceConfig { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class SpeechConfig /// /// Initializes a new instance of the class. /// - /// - /// The configuration for the voice to use. - /// /// /// 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. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public SpeechConfig( - global::Google.Gemini.VoiceConfig? voiceConfig, global::Google.Gemini.MultiSpeakerVoiceConfig? multiSpeakerVoiceConfig, - string? languageCode) + string? languageCode, + global::Google.Gemini.VoiceConfig? voiceConfig) { - this.VoiceConfig = voiceConfig; 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 d40cd9d8..d1de5ffc 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Status.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class Status { - /// - /// The status code, which should be an enum value of google.rpc.Code. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("code")] - public int? Code { get; set; } - /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// @@ -26,6 +20,12 @@ public sealed partial class Status [global::System.Text.Json.Serialization.JsonPropertyName("details")] public global::System.Collections.Generic.IList? Details { get; set; } + /// + /// The status code, which should be an enum value of google.rpc.Code. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("code")] + public int? Code { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -35,26 +35,26 @@ public sealed partial class Status /// /// Initializes a new instance of the class. /// - /// - /// The status code, which should be an enum value of google.rpc.Code. - /// /// /// A developer-facing error message, which should be in English. Any user-facing error message should be localized and sent in the google.rpc.Status.details field, or localized by the client. /// /// /// A list of messages that carry the error details. There is a common set of message types for APIs to use. /// + /// + /// The status code, which should be an enum value of google.rpc.Code. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public Status( - int? code, string? message, - global::System.Collections.Generic.IList? details) + global::System.Collections.Generic.IList? details, + int? code) { - this.Code = code; this.Message = message; this.Details = details; + this.Code = code; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.StreamableHttpTransport.g.cs index fbc0b542..ef4984af 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,6 +8,12 @@ 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. /// @@ -15,16 +21,16 @@ public sealed partial class StreamableHttpTransport public bool? TerminateOnClose { get; set; } /// - /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" + /// Timeout for SSE read operations. /// - [global::System.Text.Json.Serialization.JsonPropertyName("url")] - public string? Url { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] + public string? SseReadTimeout { get; set; } /// - /// HTTP timeout for regular operations. + /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// - [global::System.Text.Json.Serialization.JsonPropertyName("timeout")] - public string? Timeout { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("url")] + public string? Url { get; set; } /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. @@ -32,12 +38,6 @@ public sealed partial class StreamableHttpTransport [global::System.Text.Json.Serialization.JsonPropertyName("headers")] public global::System.Collections.Generic.Dictionary? Headers { get; set; } - /// - /// Timeout for SSE read operations. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("sseReadTimeout")] - public string? SseReadTimeout { 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. /// + /// + /// Timeout for SSE read operations. + /// /// /// The full URL for the MCPServer endpoint. Example: "https://api.example.com/mcp" /// - /// - /// HTTP timeout for regular operations. - /// /// /// Optional: Fields for authentication headers, timeouts, etc., if needed. /// - /// - /// Timeout for SSE read operations. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public StreamableHttpTransport( + string? timeout, bool? terminateOnClose, + string? sseReadTimeout, string? url, - string? timeout, - global::System.Collections.Generic.Dictionary? headers, - string? sseReadTimeout) + global::System.Collections.Generic.Dictionary? headers) { + this.Timeout = timeout; this.TerminateOnClose = terminateOnClose; + this.SseReadTimeout = sseReadTimeout; this.Url = url; - this.Timeout = timeout; this.Headers = headers; - this.SseReadTimeout = sseReadTimeout; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TextResponseFormat.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TextResponseFormat.g.cs index e98438a9..d13926d0 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TextResponseFormat.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TextResponseFormat.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class TextResponseFormat { - /// - /// Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("schema")] - public object? Schema { get; set; } - /// /// Optional. The MIME type of the text output. /// @@ -21,6 +15,12 @@ public sealed partial class TextResponseFormat [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.TextResponseFormatMimeTypeJsonConverter))] public global::Google.Gemini.TextResponseFormatMimeType? MimeType { get; set; } + /// + /// Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("schema")] + public object? Schema { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class TextResponseFormat /// /// Initializes a new instance of the class. /// - /// - /// Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON. - /// /// /// Optional. The MIME type of the text output. /// + /// + /// Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TextResponseFormat( - object? schema, - global::Google.Gemini.TextResponseFormatMimeType? mimeType) + global::Google.Gemini.TextResponseFormatMimeType? mimeType, + object? schema) { - this.Schema = schema; this.MimeType = mimeType; + this.Schema = schema; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs index 6470d5f7..f6546f19 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ThinkingConfig.g.cs @@ -8,13 +8,6 @@ namespace Google.Gemini /// public sealed partial class ThinkingConfig { - /// - /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("thinkingLevel")] - [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter))] - public global::Google.Gemini.ThinkingConfigThinkingLevel? ThinkingLevel { get; set; } - /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// @@ -27,6 +20,13 @@ public sealed partial class ThinkingConfig [global::System.Text.Json.Serialization.JsonPropertyName("thinkingBudget")] public int? ThinkingBudget { get; set; } + /// + /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("thinkingLevel")] + [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ThinkingConfigThinkingLevelJsonConverter))] + public global::Google.Gemini.ThinkingConfigThinkingLevel? ThinkingLevel { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -36,26 +36,26 @@ public sealed partial class ThinkingConfig /// /// Initializes a new instance of the class. /// - /// - /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error. - /// /// /// Indicates whether to include thoughts in the response. If true, thoughts are returned only when available. /// /// /// The number of thoughts tokens that the model should generate. /// + /// + /// Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ThinkingConfig( - global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel, bool? includeThoughts, - int? thinkingBudget) + int? thinkingBudget, + global::Google.Gemini.ThinkingConfigThinkingLevel? thinkingLevel) { - this.ThinkingLevel = thinkingLevel; this.IncludeThoughts = includeThoughts; this.ThinkingBudget = thinkingBudget; + this.ThinkingLevel = thinkingLevel; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs index 683f8e58..7c14be97 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.Tool.g.cs @@ -9,22 +9,22 @@ namespace Google.Gemini public sealed partial class Tool { /// - /// Tool to retrieve public web data for grounding, powered by Google. + /// The GoogleMaps Tool that provides geospatial context for the user's query. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] - public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] + public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. + /// Tool to retrieve public web data for grounding, powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] - public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearchRetrieval")] + public global::Google.Gemini.GoogleSearchRetrieval? GoogleSearchRetrieval { get; set; } /// - /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// Computer Use tool type. /// - [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] - public global::Google.Gemini.FileSearch? FileSearch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] + public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } /// /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. @@ -32,12 +32,6 @@ public sealed partial class Tool [global::System.Text.Json.Serialization.JsonPropertyName("functionDeclarations")] public global::System.Collections.Generic.IList? FunctionDeclarations { get; set; } - /// - /// Optional. MCP Servers to connect to. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("mcpServers")] - public global::System.Collections.Generic.IList? McpServers { get; set; } - /// /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. /// @@ -45,16 +39,16 @@ public sealed partial class Tool public global::Google.Gemini.CodeExecution? CodeExecution { get; set; } /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// - [global::System.Text.Json.Serialization.JsonPropertyName("googleMaps")] - public global::Google.Gemini.GoogleMaps? GoogleMaps { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("fileSearch")] + public global::Google.Gemini.FileSearch? FileSearch { get; set; } /// - /// Computer Use tool type. + /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. /// - [global::System.Text.Json.Serialization.JsonPropertyName("computerUse")] - public global::Google.Gemini.ComputerUse? ComputerUse { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("googleSearch")] + public global::Google.Gemini.GoogleSearch? GoogleSearch { get; set; } /// /// Tool to support URL context retrieval. @@ -62,6 +56,12 @@ public sealed partial class Tool [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. /// + /// + /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// /// /// Tool to retrieve public web data for grounding, powered by Google. /// - /// - /// GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google. - /// - /// - /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. + /// + /// Computer Use tool type. /// /// /// Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role "function" generation context for the next model turn. /// - /// - /// Optional. MCP Servers to connect to. - /// /// /// Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool. /// - /// - /// The GoogleMaps Tool that provides geospatial context for the user's query. + /// + /// The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API. /// - /// - /// Computer Use tool type. + /// + /// 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.GoogleMaps? googleMaps, global::Google.Gemini.GoogleSearchRetrieval? googleSearchRetrieval, - global::Google.Gemini.GoogleSearch? googleSearch, - global::Google.Gemini.FileSearch? fileSearch, + global::Google.Gemini.ComputerUse? computerUse, global::System.Collections.Generic.IList? functionDeclarations, - global::System.Collections.Generic.IList? mcpServers, global::Google.Gemini.CodeExecution? codeExecution, - global::Google.Gemini.GoogleMaps? googleMaps, - global::Google.Gemini.ComputerUse? computerUse, - global::Google.Gemini.UrlContext? urlContext) + global::Google.Gemini.FileSearch? fileSearch, + global::Google.Gemini.GoogleSearch? googleSearch, + global::Google.Gemini.UrlContext? urlContext, + global::System.Collections.Generic.IList? mcpServers) { + this.GoogleMaps = googleMaps; this.GoogleSearchRetrieval = googleSearchRetrieval; - this.GoogleSearch = googleSearch; - this.FileSearch = fileSearch; + this.ComputerUse = computerUse; this.FunctionDeclarations = functionDeclarations; - this.McpServers = mcpServers; this.CodeExecution = codeExecution; - this.GoogleMaps = googleMaps; - this.ComputerUse = computerUse; + this.FileSearch = fileSearch; + this.GoogleSearch = googleSearch; 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 5cbd66dc..b0e4cb95 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.ToolCall.g.cs @@ -14,6 +14,12 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonPropertyName("id")] public string? Id { get; set; } + /// + /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} + /// + [global::System.Text.Json.Serialization.JsonPropertyName("args")] + public object? Args { get; set; } + /// /// Required. The type of tool that was called. /// @@ -21,12 +27,6 @@ public sealed partial class ToolCall [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.ToolCallToolTypeJsonConverter))] public global::Google.Gemini.ToolCallToolType? ToolType { get; set; } - /// - /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} - /// - [global::System.Text.Json.Serialization.JsonPropertyName("args")] - public object? Args { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,23 +39,23 @@ public sealed partial class ToolCall /// /// Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`. /// - /// - /// Required. The type of tool that was called. - /// /// /// Optional. The tool call arguments. Example: {"arg1" : "value1", "arg2" : "value2" , ...} /// + /// + /// Required. The type of tool that was called. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolCall( string? id, - global::Google.Gemini.ToolCallToolType? toolType, - object? args) + object? args, + global::Google.Gemini.ToolCallToolType? toolType) { this.Id = id; - this.ToolType = toolType; this.Args = args; + this.ToolType = toolType; } /// 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 3cf6fa00..faa08bd8 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 @@ -9,10 +9,10 @@ namespace Google.Gemini public sealed partial class ToolResponse { /// - /// Optional. The identifier of the tool call this response is for. + /// Optional. The tool response. /// - [global::System.Text.Json.Serialization.JsonPropertyName("id")] - public string? Id { get; set; } + [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`. @@ -22,10 +22,10 @@ public sealed partial class ToolResponse public global::Google.Gemini.ToolResponseToolType? ToolType { get; set; } /// - /// Optional. The tool response. + /// Optional. The identifier of the tool call this response is for. /// - [global::System.Text.Json.Serialization.JsonPropertyName("response")] - public object? Response { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("id")] + public string? Id { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -36,26 +36,26 @@ public sealed partial class ToolResponse /// /// Initializes a new instance of the class. /// - /// - /// Optional. The identifier of the tool call this response is for. + /// + /// Optional. The tool response. /// /// /// Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`. /// - /// - /// Optional. The tool response. + /// + /// Optional. The identifier of the tool call this response is for. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public ToolResponse( - string? id, + object? response, global::Google.Gemini.ToolResponseToolType? toolType, - object? response) + string? id) { - this.Id = id; - this.ToolType = toolType; this.Response = response; + this.ToolType = toolType; + this.Id = id; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs index 5586af7c..9487be42 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TranslationConfig.g.cs @@ -8,18 +8,18 @@ namespace Google.Gemini /// public sealed partial class TranslationConfig { - /// - /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). - /// - [global::System.Text.Json.Serialization.JsonPropertyName("targetLanguageCode")] - public string? TargetLanguageCode { get; set; } - /// /// Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language. /// [global::System.Text.Json.Serialization.JsonPropertyName("echoTargetLanguage")] public bool? EchoTargetLanguage { get; set; } + /// + /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). + /// + [global::System.Text.Json.Serialization.JsonPropertyName("targetLanguageCode")] + public string? TargetLanguageCode { get; set; } + /// /// Additional properties that are not explicitly defined in the schema /// @@ -29,21 +29,21 @@ public sealed partial class TranslationConfig /// /// Initializes a new instance of the class. /// - /// - /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). - /// /// /// Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language. /// + /// + /// Required. The target language for translation. Supported values are BCP-47 language codes (e.g. "en", "es", "fr"). + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TranslationConfig( - string? targetLanguageCode, - bool? echoTargetLanguage) + bool? echoTargetLanguage, + string? targetLanguageCode) { - this.TargetLanguageCode = targetLanguageCode; this.EchoTargetLanguage = echoTargetLanguage; + this.TargetLanguageCode = targetLanguageCode; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs index b56a446c..ab5777da 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModel.g.cs @@ -9,11 +9,18 @@ namespace Google.Gemini public sealed partial class TunedModel { /// - /// Output only. The timestamp when this model was created.
+ /// Output only. The state of the tuned model.
/// 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.TunedModelStateJsonConverter))] + public global::Google.Gemini.TunedModelState? State { get; set; } + + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] + public string? BaseModel { get; set; } /// /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. @@ -22,18 +29,23 @@ public sealed partial class TunedModel public string? DisplayName { 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. + /// Tuning tasks that create tuned models. /// - [global::System.Text.Json.Serialization.JsonPropertyName("topK")] - public int? TopK { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] + public global::Google.Gemini.TuningTask? TuningTask { get; set; } /// - /// Output only. The state of the tuned model.
+ /// 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; } + + /// + /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("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("name")] + public string? Name { get; set; } /// /// Optional. A short description of this model. @@ -42,17 +54,11 @@ public sealed partial class TunedModel public string? Description { get; set; } /// - /// Tuned model as a source for training a new model. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("tunedModelSource")] - public global::Google.Gemini.TunedModelSource? TunedModelSource { get; set; } - - /// - /// Output only. The timestamp when this model was updated.
+ /// Output only. The timestamp when this model was created.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("updateTime")] - public string? UpdateTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("createTime")] + public string? CreateTime { get; set; } /// /// Optional. 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. @@ -61,16 +67,17 @@ public sealed partial class TunedModel public float? TopP { get; set; } /// - /// Optional. List of project numbers that have read access to the tuned model. + /// Output only. The timestamp when this model was updated.
+ /// Included only in responses ///
- [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; } /// - /// 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. 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. @@ -79,17 +86,10 @@ public sealed partial class TunedModel public float? Temperature { get; set; } /// - /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("name")] - public string? Name { get; set; } - - /// - /// Tuning tasks that create tuned models. + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// - [global::System.Text.Json.Serialization.JsonPropertyName("tuningTask")] - public global::Google.Gemini.TuningTask? TuningTask { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("topK")] + public int? TopK { 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. /// - /// - /// Output only. The timestamp when this model was created.
+ /// + /// Output only. The state of the tuned model.
/// Included only in responses /// + /// + /// Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001` + /// /// /// Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces. /// - /// - /// Optional. 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. + /// + /// Tuning tasks that create tuned models. /// - /// - /// Output only. The state of the tuned model.
+ /// + /// Optional. List of project numbers that have read access to the tuned 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. A short description of this model. /// - /// - /// Tuned model as a source for training a new model. - /// - /// - /// Output only. The timestamp when this model was updated.
+ /// + /// Output only. The timestamp when this model was created.
/// Included only in responses /// /// /// Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Optional. List of project numbers that have read access to the tuned model. + /// + /// Output only. The timestamp when this model was updated.
+ /// Included only in responses /// - /// - /// 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. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model. /// - /// - /// Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`
- /// Included only in responses - /// - /// - /// Tuning tasks that create tuned models. + /// + /// Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model. /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModel( - string? createTime, - string? displayName, - int? topK, global::Google.Gemini.TunedModelState? state, + string? baseModel, + string? displayName, + global::Google.Gemini.TuningTask? tuningTask, + global::System.Collections.Generic.IList? readerProjectNumbers, + string? name, string? description, - global::Google.Gemini.TunedModelSource? tunedModelSource, - string? updateTime, + string? createTime, float? topP, - global::System.Collections.Generic.IList? readerProjectNumbers, - string? baseModel, + string? updateTime, + global::Google.Gemini.TunedModelSource? tunedModelSource, float? temperature, - string? name, - global::Google.Gemini.TuningTask? tuningTask) + int? topK) { - this.CreateTime = createTime; - this.DisplayName = displayName; - this.TopK = topK; this.State = state; + this.BaseModel = baseModel; + this.DisplayName = displayName; + this.TuningTask = tuningTask; + this.ReaderProjectNumbers = readerProjectNumbers; + this.Name = name; this.Description = description; - this.TunedModelSource = tunedModelSource; - this.UpdateTime = updateTime; + this.CreateTime = createTime; this.TopP = topP; - this.ReaderProjectNumbers = readerProjectNumbers; - this.BaseModel = baseModel; + this.UpdateTime = updateTime; + this.TunedModelSource = tunedModelSource; this.Temperature = temperature; - this.Name = name; - this.TuningTask = tuningTask; + this.TopK = topK; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModelSource.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModelSource.g.cs index ceaaa53f..bafee2ce 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModelSource.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TunedModelSource.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class TunedModelSource { + /// + /// Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model` + /// + [global::System.Text.Json.Serialization.JsonPropertyName("tunedModel")] + public string? TunedModel { get; set; } + /// /// Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`
/// Included only in responses @@ -15,12 +21,6 @@ public sealed partial class TunedModelSource [global::System.Text.Json.Serialization.JsonPropertyName("baseModel")] public string? BaseModel { get; set; } - /// - /// Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model` - /// - [global::System.Text.Json.Serialization.JsonPropertyName("tunedModel")] - public string? TunedModel { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,22 +30,22 @@ public sealed partial class TunedModelSource /// /// Initializes a new instance of the class. /// + /// + /// Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model` + /// /// /// Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`
/// Included only in responses /// - /// - /// Immutable. The name of the `TunedModel` to use as the starting point for training the new model. Example: `tunedModels/my-tuned-model` - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TunedModelSource( - string? baseModel, - string? tunedModel) + string? tunedModel, + string? baseModel) { - this.BaseModel = baseModel; this.TunedModel = tunedModel; + this.BaseModel = baseModel; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs index ebe79083..40a6ce78 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningSnapshot.g.cs @@ -9,32 +9,32 @@ namespace Google.Gemini public sealed partial class TuningSnapshot { /// - /// Output only. The epoch this step was part of.
+ /// Output only. The tuning step.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] - public int? Epoch { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("step")] + public int? Step { get; set; } /// - /// Output only. The timestamp when this metric was computed.
+ /// Output only. The mean loss of the training examples for this step.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] - public string? ComputeTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("meanLoss")] + public float? MeanLoss { get; set; } /// - /// Output only. The tuning step.
+ /// Output only. The timestamp when this metric was computed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("step")] - public int? Step { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("computeTime")] + public string? ComputeTime { get; set; } /// - /// Output only. The mean loss of the training examples for this step.
+ /// Output only. The epoch this step was part of.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("meanLoss")] - public float? MeanLoss { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("epoch")] + public int? Epoch { get; set; } /// /// Additional properties that are not explicitly defined in the schema @@ -45,14 +45,6 @@ public sealed partial class TuningSnapshot /// /// Initializes a new instance of the class. /// - /// - /// Output only. The epoch this step was part of.
- /// Included only in responses - /// - /// - /// Output only. The timestamp when this metric was computed.
- /// Included only in responses - /// /// /// Output only. The tuning step.
/// Included only in responses @@ -61,19 +53,27 @@ public sealed partial class TuningSnapshot /// Output only. The mean loss of the training examples for this step.
/// Included only in responses /// + /// + /// Output only. The timestamp when this metric was computed.
+ /// Included only in responses + /// + /// + /// Output only. The epoch this step was part of.
+ /// Included only in responses + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningSnapshot( - int? epoch, - string? computeTime, int? step, - float? meanLoss) + float? meanLoss, + string? computeTime, + int? epoch) { - this.Epoch = epoch; - this.ComputeTime = computeTime; this.Step = step; this.MeanLoss = meanLoss; + this.ComputeTime = computeTime; + this.Epoch = epoch; } /// 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 1f5fcead..1145ab1d 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.TuningTask.g.cs @@ -8,12 +8,6 @@ namespace Google.Gemini /// public sealed partial class TuningTask { - /// - /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance - /// - [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] - public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } - /// /// Dataset for training or validation. /// @@ -21,18 +15,24 @@ public sealed partial class TuningTask public global::Google.Gemini.Dataset? TrainingData { get; set; } /// - /// Output only. The timestamp when tuning this model started.
+ /// Output only. The timestamp when tuning this model completed.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] - public string? StartTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] + public string? CompleteTime { get; set; } /// - /// Output only. The timestamp when tuning this model completed.
+ /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("hyperparameters")] + public global::Google.Gemini.Hyperparameters? Hyperparameters { get; set; } + + /// + /// Output only. The timestamp when tuning this model started.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("completeTime")] - public string? CompleteTime { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("startTime")] + public string? StartTime { get; set; } /// /// Output only. Metrics collected during tuning.
@@ -50,20 +50,20 @@ public sealed partial class TuningTask /// /// Initializes a new instance of the class. /// - /// - /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance - /// /// /// Dataset for training or validation. /// - /// - /// Output only. The timestamp when tuning this model started.
- /// Included only in responses - /// /// /// Output only. The timestamp when tuning this model completed.
/// Included only in responses /// + /// + /// Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance + /// + /// + /// Output only. The timestamp when tuning this model started.
+ /// Included only in responses + /// /// /// Output only. Metrics collected during tuning.
/// Included only in responses @@ -72,16 +72,16 @@ public sealed partial class TuningTask [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public TuningTask( - global::Google.Gemini.Hyperparameters? hyperparameters, global::Google.Gemini.Dataset? trainingData, - string? startTime, string? completeTime, + global::Google.Gemini.Hyperparameters? hyperparameters, + string? startTime, global::System.Collections.Generic.IList? snapshots) { - this.Hyperparameters = hyperparameters; this.TrainingData = trainingData; - this.StartTime = startTime; this.CompleteTime = completeTime; + this.Hyperparameters = hyperparameters; + this.StartTime = startTime; this.Snapshots = snapshots; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UploadToFileSearchStoreRequest.g.cs index 67bad8c3..505bd78e 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,6 +8,12 @@ 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. /// @@ -26,12 +32,6 @@ public sealed partial class UploadToFileSearchStoreRequest [global::System.Text.Json.Serialization.JsonPropertyName("customMetadata")] public global::System.Collections.Generic.IList? CustomMetadata { get; set; } - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// - [global::System.Text.Json.Serialization.JsonPropertyName("chunkingConfig")] - public global::Google.Gemini.ChunkingConfig? ChunkingConfig { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -41,6 +41,9 @@ 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. /// @@ -50,22 +53,19 @@ public sealed partial class UploadToFileSearchStoreRequest /// /// Custom metadata to be associated with the data. /// - /// - /// Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto - /// #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::Google.Gemini.ChunkingConfig? chunkingConfig) + global::System.Collections.Generic.IList? customMetadata) { + this.ChunkingConfig = chunkingConfig; this.MimeType = mimeType; this.DisplayName = displayName; this.CustomMetadata = customMetadata; - 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 8be9fd58..92ed5e03 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UrlMetadata.g.cs @@ -8,6 +8,12 @@ namespace Google.Gemini /// public sealed partial class UrlMetadata { + /// + /// Retrieved url by the tool. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("retrievedUrl")] + public string? RetrievedUrl { get; set; } + /// /// Status of the url retrieval. /// @@ -15,12 +21,6 @@ public sealed partial class UrlMetadata [global::System.Text.Json.Serialization.JsonConverter(typeof(global::Google.Gemini.JsonConverters.UrlMetadataUrlRetrievalStatusJsonConverter))] public global::Google.Gemini.UrlMetadataUrlRetrievalStatus? UrlRetrievalStatus { get; set; } - /// - /// Retrieved url by the tool. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("retrievedUrl")] - public string? RetrievedUrl { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -30,21 +30,21 @@ public sealed partial class UrlMetadata /// /// Initializes a new instance of the class. /// - /// - /// Status of the url retrieval. - /// /// /// Retrieved url by the tool. /// + /// + /// Status of the url retrieval. + /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UrlMetadata( - global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus, - string? retrievedUrl) + string? retrievedUrl, + global::Google.Gemini.UrlMetadataUrlRetrievalStatus? urlRetrievalStatus) { - this.UrlRetrievalStatus = urlRetrievalStatus; this.RetrievedUrl = retrievedUrl; + this.UrlRetrievalStatus = urlRetrievalStatus; } /// diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs index 89d1c755..180c12a8 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.UsageMetadata.g.cs @@ -9,11 +9,17 @@ namespace Google.Gemini public sealed partial class UsageMetadata { /// - /// Output only. List of modalities that were processed in the request input.
+ /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] + public int? PromptTokenCount { get; set; } + + /// + /// Output only. List of modalities that were processed for tool-use request inputs.
/// 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("toolUsePromptTokensDetails")] + public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } /// /// Output only. List of modalities of the cached content in the request input.
@@ -22,12 +28,6 @@ public sealed partial class UsageMetadata [global::System.Text.Json.Serialization.JsonPropertyName("cacheTokensDetails")] public global::System.Collections.Generic.IList? CacheTokensDetails { get; set; } - /// - /// Total number of tokens across all the generated response candidates. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] - public int? CandidatesTokenCount { get; set; } - /// /// Output only. Service tier of the request.
/// Included only in responses @@ -37,24 +37,16 @@ public sealed partial class UsageMetadata public global::Google.Gemini.UsageMetadataServiceTier? ServiceTier { get; set; } /// - /// Output only. Number of tokens of thoughts for thinking models.
- /// Included only in responses - ///
- [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] - public int? ThoughtsTokenCount { get; set; } - - /// - /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + /// Number of tokens in the cached part of the prompt (the cached content) /// - [global::System.Text.Json.Serialization.JsonPropertyName("promptTokenCount")] - public int? PromptTokenCount { get; set; } + [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 + /// Total token count for the generation request (prompt + thoughts + response candidates). ///
- [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] - public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] + public int? TotalTokenCount { get; set; } /// /// Output only. Number of tokens present in tool-use prompt(s).
@@ -64,23 +56,31 @@ public sealed partial class UsageMetadata public int? ToolUsePromptTokenCount { get; set; } /// - /// Output only. List of modalities that were processed for tool-use request inputs.
+ /// Total number of tokens across all the generated response candidates. + ///
+ [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokenCount")] + public int? CandidatesTokenCount { get; set; } + + /// + /// Output only. List of modalities that were processed in the request input.
/// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("toolUsePromptTokensDetails")] - public global::System.Collections.Generic.IList? ToolUsePromptTokensDetails { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("promptTokensDetails")] + public global::System.Collections.Generic.IList? PromptTokensDetails { get; set; } /// - /// Total token count for the generation request (prompt + thoughts + response candidates). + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("totalTokenCount")] - public int? TotalTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("candidatesTokensDetails")] + public global::System.Collections.Generic.IList? CandidatesTokensDetails { get; set; } /// - /// Number of tokens in the cached part of the prompt (the cached content) + /// Output only. Number of tokens of thoughts for thinking models.
+ /// Included only in responses ///
- [global::System.Text.Json.Serialization.JsonPropertyName("cachedContentTokenCount")] - public int? CachedContentTokenCount { get; set; } + [global::System.Text.Json.Serialization.JsonPropertyName("thoughtsTokenCount")] + public int? ThoughtsTokenCount { get; set; } /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -105,45 +105,45 @@ public sealed partial class UsageMetadata /// /// Initializes a new instance of the class. /// - /// - /// Output only. List of modalities that were processed in the request input.
+ /// + /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + /// + /// + /// Output only. List of modalities that were processed for tool-use request inputs.
/// Included only in responses /// /// /// Output only. List of modalities of the cached content in the request input.
/// Included only in responses /// - /// - /// Total number of tokens across all the generated response candidates. - /// /// /// Output only. Service tier of the request.
/// Included only in responses /// - /// - /// Output only. Number of tokens of thoughts for thinking models.
- /// Included only in responses - /// - /// - /// Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content. + /// + /// 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 + /// + /// Total token count for the generation request (prompt + thoughts + response candidates). /// /// /// 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.
+ /// + /// Total number of tokens across all the generated response candidates. + /// + /// + /// Output only. List of modalities that were processed in the request input.
/// Included only in responses /// - /// - /// Total token count for the generation request (prompt + thoughts + response candidates). + /// + /// Output only. List of modalities that were returned in the response.
+ /// Included only in responses /// - /// - /// Number of tokens in the cached part of the prompt (the cached content) + /// + /// Output only. Number of tokens of thoughts for thinking models.
+ /// Included only in responses /// /// /// Output only. Number of tokens in the response. Used by Gemini 3.1+ Live API models instead of candidatesTokenCount.
@@ -157,31 +157,31 @@ public sealed partial class UsageMetadata [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public UsageMetadata( - global::System.Collections.Generic.IList? promptTokensDetails, - global::System.Collections.Generic.IList? cacheTokensDetails, - int? candidatesTokenCount, - global::Google.Gemini.UsageMetadataServiceTier? serviceTier, - int? thoughtsTokenCount, int? promptTokenCount, - global::System.Collections.Generic.IList? candidatesTokensDetails, - int? toolUsePromptTokenCount, global::System.Collections.Generic.IList? toolUsePromptTokensDetails, - int? totalTokenCount, + global::System.Collections.Generic.IList? cacheTokensDetails, + global::Google.Gemini.UsageMetadataServiceTier? serviceTier, int? cachedContentTokenCount, + int? totalTokenCount, + int? toolUsePromptTokenCount, + int? candidatesTokenCount, + global::System.Collections.Generic.IList? promptTokensDetails, + global::System.Collections.Generic.IList? candidatesTokensDetails, + int? thoughtsTokenCount, int? responseTokenCount, global::System.Collections.Generic.IList? responseTokensDetails) { - this.PromptTokensDetails = promptTokensDetails; - this.CacheTokensDetails = cacheTokensDetails; - this.CandidatesTokenCount = candidatesTokenCount; - this.ServiceTier = serviceTier; - this.ThoughtsTokenCount = thoughtsTokenCount; this.PromptTokenCount = promptTokenCount; - this.CandidatesTokensDetails = candidatesTokensDetails; - this.ToolUsePromptTokenCount = toolUsePromptTokenCount; this.ToolUsePromptTokensDetails = toolUsePromptTokensDetails; - this.TotalTokenCount = totalTokenCount; + this.CacheTokensDetails = cacheTokensDetails; + this.ServiceTier = serviceTier; this.CachedContentTokenCount = cachedContentTokenCount; + this.TotalTokenCount = totalTokenCount; + this.ToolUsePromptTokenCount = toolUsePromptTokenCount; + this.CandidatesTokenCount = candidatesTokenCount; + this.PromptTokensDetails = promptTokensDetails; + this.CandidatesTokensDetails = candidatesTokensDetails; + this.ThoughtsTokenCount = thoughtsTokenCount; this.ResponseTokenCount = responseTokenCount; this.ResponseTokensDetails = responseTokensDetails; } diff --git a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs index 681e8195..9220677a 100644 --- a/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs +++ b/src/libs/Google.Gemini/Generated/Google.Gemini.Models.VideoMetadata.g.cs @@ -9,6 +9,13 @@ namespace Google.Gemini [global::System.Obsolete("This model marked as deprecated.")] public sealed partial class VideoMetadata { + /// + /// Optional. The end offset of the video. + /// + [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] + [global::System.Obsolete("This property marked as deprecated.")] + 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]. /// @@ -23,13 +30,6 @@ public sealed partial class VideoMetadata [global::System.Obsolete("This property marked as deprecated.")] public string? StartOffset { get; set; } - /// - /// Optional. The end offset of the video. - /// - [global::System.Text.Json.Serialization.JsonPropertyName("endOffset")] - [global::System.Obsolete("This property marked as deprecated.")] - public string? EndOffset { get; set; } - /// /// Additional properties that are not explicitly defined in the schema /// @@ -39,26 +39,26 @@ public sealed partial class VideoMetadata /// /// Initializes a new instance of the class. /// + /// + /// Optional. The end offset of the video. + /// /// /// Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0]. /// /// /// Optional. The start offset of the video. /// - /// - /// Optional. The end offset of the video. - /// #if NET7_0_OR_GREATER [global::System.Diagnostics.CodeAnalysis.SetsRequiredMembers] #endif public VideoMetadata( + string? endOffset, double? fps, - string? startOffset, - string? endOffset) + string? startOffset) { + this.EndOffset = endOffset; this.Fps = fps; this.StartOffset = startOffset; - this.EndOffset = endOffset; } /// diff --git a/src/libs/Google.Gemini/openapi.json b/src/libs/Google.Gemini/openapi.json index cb60b2bf..f34ad0f3 100644 --- a/src/libs/Google.Gemini/openapi.json +++ b/src/libs/Google.Gemini/openapi.json @@ -11,66 +11,15 @@ } ], "paths": { - "/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": "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/[^/]+$" - } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - } - } - } - } - } - }, - "/dynamic/{dynamicId}:streamGenerateContent": { + "/files:register": { "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": "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" } } } @@ -81,12 +30,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/RegisterFilesResponse" } } } @@ -214,54 +158,55 @@ } } }, - "/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" - } + "/corpora/{corporaId}": { + "get": { + "description": "Gets information about a specific `Corpus`.", + "operationId": "corpora.get", + "parameters": [ + { + "name": "corporaId", + "in": "path", + "required": true, + "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "schema": { + "type": "string", + "pattern": "^corpora/[^/]+$" } } - }, + ], "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/RegisterFilesResponse" + "$ref": "#/components/schemas/Corpus" } } } } } - } - }, - "/fileSearchStores/{fileSearchStoresId}": { + }, "delete": { - "description": "Deletes a `FileSearchStore`.", - "operationId": "fileSearchStores.delete", + "description": "Deletes a `Corpus`.", + "operationId": "corpora.delete", "parameters": [ { "name": "force", "in": "query", - "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "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": "fileSearchStoresId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The resource name of the `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The resource name of the `Corpus`. Example: `corpora/my-corpus-123`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -277,45 +222,42 @@ } } } - }, - "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/[^/]+$" + } + }, + "/corpora": { + "post": { + "description": "Creates an empty `Corpus`.", + "operationId": "corpora.create", + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Corpus" + } } } - ], + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Corpus" } } } } } - } - }, - "/fileSearchStores": { + }, "get": { - "description": "Lists all `FileSearchStores` owned by the user.", - "operationId": "fileSearchStores.list", + "description": "Lists all `Corpora` owned by the user.", + "operationId": "corpora.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", + "description": "Optional. The maximum number of `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" @@ -324,7 +266,7 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListFileSearchStores` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListFileSearchStores` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `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" } @@ -336,32 +278,45 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListFileSearchStoresResponse" + "$ref": "#/components/schemas/ListCorporaResponse" } } } } } - }, - "post": { - "description": "Creates an empty `FileSearchStore`.", - "operationId": "fileSearchStores.create", - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/FileSearchStore" - } + } + }, + "/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", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Operation" } } } @@ -369,19 +324,36 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:importFile": { - "post": { - "description": "Imports a `File` from File Service to a `FileSearchStore`.", - "operationId": "fileSearchStores.importFile", + "/corpora/{corporaId}/permissions/{permissionsId}": { + "patch": { + "description": "Updates the permission.", + "operationId": "corpora.permissions.patch", "parameters": [ { - "name": "fileSearchStoresId", + "name": "permissionsId", "in": "path", "required": true, - "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string" + } + }, + { + "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": "^fileSearchStores/[^/]+$" + "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" } } ], @@ -389,7 +361,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ImportFileRequest" + "$ref": "#/components/schemas/Permission" } } } @@ -400,21 +372,19 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/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", + "description": "Gets information about a specific Permission.", + "operationId": "corpora.permissions.get", "parameters": [ { - "name": "operationsId", + "name": "permissionsId", "in": "path", "required": true, "schema": { @@ -422,13 +392,13 @@ } }, { - "name": "fileSearchStoresId", + "name": "corporaId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -438,44 +408,33 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Permission" } } } } } - } - }, - "/fileSearchStores/{fileSearchStoresId}/documents": { - "get": { - "description": "Lists all `Document`s in a `Corpus`.", - "operationId": "fileSearchStores.documents.list", + }, + "delete": { + "description": "Deletes the permission.", + "operationId": "corpora.permissions.delete", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", + "name": "permissionsId", + "in": "path", + "required": true, "schema": { "type": "string" } }, { - "name": "fileSearchStoresId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^corpora/[^/]+/permissions/[^/]+$" } } ], @@ -485,7 +444,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListDocumentsResponse" + "$ref": "#/components/schemas/Empty" } } } @@ -493,71 +452,73 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { - "get": { - "description": "Gets information about a specific `Document`.", - "operationId": "fileSearchStores.documents.get", + "/corpora/{corporaId}/permissions": { + "post": { + "description": "Create a permission to a specific resource.", + "operationId": "corpora.permissions.create", "parameters": [ { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "documentsId", + "name": "corporaId", "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 parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Permission" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Document" + "$ref": "#/components/schemas/Permission" } } } } } }, - "delete": { - "description": "Deletes a `Document`.", - "operationId": "fileSearchStores.documents.delete", + "get": { + "description": "Lists permissions for the specific resource.", + "operationId": "corpora.permissions.list", "parameters": [ { - "name": "fileSearchStoresId", - "in": "path", - "required": true, + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", "schema": { - "type": "string" + "type": "integer", + "format": "int32" } }, { - "name": "force", + "name": "pageToken", "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.", + "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": "boolean" + "type": "string" } }, { - "name": "documentsId", + "name": "corporaId", "in": "path", "required": true, - "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + "pattern": "^corpora/[^/]+$" } } ], @@ -567,7 +528,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/ListPermissionsResponse" } } } @@ -575,27 +536,34 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { + "/tunedModels": { "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "fileSearchStores.upload.operations.get", + "description": "Lists created tuned models.", + "operationId": "tunedModels.list", "parameters": [ { - "name": "operationsId", - "in": "path", - "required": true, + "name": "filter", + "in": "query", + "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", "schema": { "type": "string" } }, { - "name": "fileSearchStoresId", - "in": "path", - "required": true, - "description": "The name of the operation resource.", + "name": "pageSize", + "in": "query", + "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", "schema": { - "type": "string", - "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", + "schema": { + "type": "string" } } ], @@ -605,36 +573,23 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/ListTunedModelsResponse" } } } } } - } - }, - "/cachedContents/{cachedContentsId}": { - "patch": { - "description": "Updates CachedContent resource (only expiration is updatable).", - "operationId": "cachedContents.patch", + }, + "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": "cachedContentsId", - "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", + "name": "tunedModelId", "in": "query", - "description": "The list of fields to update.", + "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", - "format": "google-fieldmask" + "type": "string" } } ], @@ -642,7 +597,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } @@ -653,25 +608,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/Operation" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}": { "get": { - "description": "Reads CachedContent resource.", - "operationId": "cachedContents.get", + "description": "Gets information about a specific TunedModel.", + "operationId": "tunedModels.get", "parameters": [ { - "name": "cachedContentsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -681,7 +638,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } @@ -689,17 +646,17 @@ } }, "delete": { - "description": "Deletes CachedContent resource.", - "operationId": "cachedContents.delete", + "description": "Deletes a tuned model.", + "operationId": "tunedModels.delete", "parameters": [ { - "name": "cachedContentsId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", + "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^cachedContents/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -715,17 +672,36 @@ } } } - } - }, - "/cachedContents": { - "post": { - "description": "Creates CachedContent resource.", - "operationId": "cachedContents.create", + }, + "patch": { + "description": "Updates a tuned model.", + "operationId": "tunedModels.patch", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } @@ -736,42 +712,46 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CachedContent" + "$ref": "#/components/schemas/TunedModel" } } } } } - }, - "get": { - "description": "Lists CachedContents.", - "operationId": "cachedContents.list", + } + }, + "/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": "pageSize", - "in": "query", - "description": "Optional. The maximum number of cached contents to return. The service may return fewer than this value. If unspecified, some default (under maximum) number of items will be returned. The maximum value is 1000; values above 1000 will be coerced to 1000.", - "schema": { - "type": "integer", - "format": "int32" - } - }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token, received from a previous `ListCachedContents` call. Provide this to retrieve the subsequent page. When paginating, all other parameters provided to `ListCachedContents` must match the call that provided the page token.", + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCachedContentsResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -779,65 +759,77 @@ } } }, - "/corpora/{corporaId}": { - "get": { - "description": "Gets information about a specific `Corpus`.", - "operationId": "corpora.get", + "/tunedModels/{tunedModelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "tunedModels.batchGenerateContent", "parameters": [ { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, - "description": "Required. The name of the `Corpus`. Example: `corpora/my-corpus-123`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "delete": { - "description": "Deletes a `Corpus`.", - "operationId": "corpora.delete", + } + }, + "/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": "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 tuned model to transfer ownership. Format: `tunedModels/my-model-id`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/TransferOwnershipRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/TransferOwnershipResponse" } } } @@ -845,50 +837,66 @@ } } }, - "/corpora": { - "get": { - "description": "Lists all `Corpora` owned by the user.", - "operationId": "corpora.list", + "/tunedModels/{tunedModelsId}:generateContent": { + "post": { + "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", + "operationId": "tunedModels.generateContent", "parameters": [ { - "name": "pageSize", - "in": "query", - "description": "Optional. 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 name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { - "type": "string" + "type": "string", + "pattern": "^tunedModels/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListCorporaResponse" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, + } + }, + "/tunedModels/{tunedModelsId}:streamGenerateContent": { "post": { - "description": "Creates an empty `Corpus`.", - "operationId": "corpora.create", + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "tunedModels.streamGenerateContent", + "parameters": [ + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + } + ], "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -899,7 +907,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Corpus" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -907,13 +920,76 @@ } } }, - "/corpora/{corporaId}/operations/{operationsId}": { + "/tunedModels/{tunedModelsId}/operations": { + "get": { + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "tunedModels.operations.list", + "parameters": [ + { + "name": "filter", + "in": "query", + "description": "The standard list filter.", + "schema": { + "type": "string" + } + }, + { + "name": "tunedModelsId", + "in": "path", + "required": true, + "description": "The name of the operation's parent resource.", + "schema": { + "type": "string", + "pattern": "^tunedModels/[^/]+$" + } + }, + { + "name": "pageSize", + "in": "query", + "description": "The standard list page size.", + "schema": { + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "The standard list page token.", + "schema": { + "type": "string" + } + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListOperationsResponse" + } + } + } + } + } + } + }, + "/tunedModels/{tunedModelsId}/operations/{operationsId}": { "get": { "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "corpora.operations.get", + "operationId": "tunedModels.operations.get", "parameters": [ { - "name": "operationsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -921,13 +997,13 @@ } }, { - "name": "corporaId", + "name": "operationsId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/operations/[^/]+$" + "pattern": "^tunedModels/[^/]+/operations/[^/]+$" } } ], @@ -945,19 +1021,19 @@ } } }, - "/corpora/{corporaId}/permissions": { + "/tunedModels/{tunedModelsId}/permissions": { "post": { "description": "Create a permission to a specific resource.", - "operationId": "corpora.permissions.create", + "operationId": "tunedModels.permissions.create", "parameters": [ { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -985,7 +1061,7 @@ }, "get": { "description": "Lists permissions for the specific resource.", - "operationId": "corpora.permissions.list", + "operationId": "tunedModels.permissions.list", "parameters": [ { "name": "pageSize", @@ -1005,13 +1081,13 @@ } }, { - "name": "corporaId", + "name": "tunedModelsId", "in": "path", "required": true, "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+$" + "pattern": "^tunedModels/[^/]+$" } } ], @@ -1029,13 +1105,13 @@ } } }, - "/corpora/{corporaId}/permissions/{permissionsId}": { + "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { "patch": { "description": "Updates the permission.", - "operationId": "corpora.permissions.patch", + "operationId": "tunedModels.permissions.patch", "parameters": [ { - "name": "permissionsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1043,13 +1119,13 @@ } }, { - "name": "corporaId", + "name": "permissionsId", "in": "path", "required": true, "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } }, { @@ -1084,12 +1160,12 @@ } } }, - "delete": { - "description": "Deletes the permission.", - "operationId": "corpora.permissions.delete", + "get": { + "description": "Gets information about a specific Permission.", + "operationId": "tunedModels.permissions.get", "parameters": [ { - "name": "permissionsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1097,13 +1173,13 @@ } }, { - "name": "corporaId", + "name": "permissionsId", "in": "path", "required": true, "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -1113,19 +1189,19 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Permission" } } } } } }, - "get": { - "description": "Gets information about a specific Permission.", - "operationId": "corpora.permissions.get", + "delete": { + "description": "Deletes the permission.", + "operationId": "tunedModels.permissions.delete", "parameters": [ { - "name": "permissionsId", + "name": "tunedModelsId", "in": "path", "required": true, "schema": { @@ -1133,13 +1209,13 @@ } }, { - "name": "corporaId", + "name": "permissionsId", "in": "path", "required": true, "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", "schema": { "type": "string", - "pattern": "^corpora/[^/]+/permissions/[^/]+$" + "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" } } ], @@ -1149,7 +1225,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/Empty" } } } @@ -1157,27 +1233,15 @@ } } }, - "/models/{modelsId}:batchGenerateContent": { + "/fileSearchStores": { "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "models.batchGenerateContent", - "parameters": [ - { - "name": "modelsId", - "in": "path", - "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "schema": { - "type": "string", - "pattern": "^models/[^/]+$" - } - } - ], + "description": "Creates an empty `FileSearchStore`.", + "operationId": "fileSearchStores.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/FileSearchStore" } } } @@ -1188,53 +1252,21 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" - } - } - } - } - } - } - }, - "/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/Model" + "$ref": "#/components/schemas/FileSearchStore" } } } } } - } - }, - "/models": { + }, "get": { - "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", - "operationId": "models.list", + "description": "Lists all `FileSearchStores` owned by the user.", + "operationId": "fileSearchStores.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "The maximum number of `Models` to return (per page). If unspecified, 50 models will be returned per page. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "Optional. The maximum number of `FileSearchStores` to return (per page). The service may return fewer `FileSearchStores`. If unspecified, at most 10 `FileSearchStores` will be returned. The maximum size limit is 20 `FileSearchStores` per page.", "schema": { "type": "integer", "format": "int32" @@ -1243,7 +1275,7 @@ { "name": "pageToken", "in": "query", - "description": "A page token, received from a previous `ListModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListModels` must match the call that provided the page token.", + "description": "Optional. A page token, received from a previous `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" } @@ -1255,7 +1287,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListModelsResponse" + "$ref": "#/components/schemas/ListFileSearchStoresResponse" } } } @@ -1263,77 +1295,65 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}": { + "get": { + "description": "Gets information about a specific `FileSearchStore`.", + "operationId": "fileSearchStores.get", "parameters": [ { - "name": "modelsId", + "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": "^models/[^/]+$" + "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" } } } } } - } - }, - "/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 `FileSearchStore`.", + "operationId": "fileSearchStores.delete", "parameters": [ { - "name": "modelsId", + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Document`s and objects related to this `FileSearchStore` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `FileSearchStore` contains any `Document`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The 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 `FileSearchStore`. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], - "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" } } } @@ -1341,19 +1361,19 @@ } } }, - "/models/{modelsId}:generateContent": { + "/fileSearchStores/{fileSearchStoresId}:importFile": { "post": { - "description": "Generates a model response given an input `GenerateContentRequest`. Refer to the [text generation guide](https://ai.google.dev/gemini-api/docs/text-generation) for detailed usage information. Input capabilities differ between models, including tuned models. Refer to the [model guide](https://ai.google.dev/gemini-api/docs/models/gemini) and [tuning guide](https://ai.google.dev/gemini-api/docs/model-tuning) for details.", - "operationId": "models.generateContent", + "description": "Imports a `File` from File Service to a `FileSearchStore`.", + "operationId": "fileSearchStores.importFile", "parameters": [ { - "name": "modelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Required. Immutable. The name of the `FileSearchStore` to import the file into. Example: `fileSearchStores/my-file-search-store-123`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^fileSearchStores/[^/]+$" } } ], @@ -1361,7 +1381,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/ImportFileRequest" } } } @@ -1372,7 +1392,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1380,38 +1400,37 @@ } } }, - "/models/{modelsId}:batchEmbedContents": { - "post": { - "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", - "operationId": "models.batchEmbedContents", + "/fileSearchStores/{fileSearchStoresId}/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.operations.get", "parameters": [ { - "name": "modelsId", + "name": "operationsId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "schema": { + "type": "string" + } + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchEmbedContentsResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1419,38 +1438,37 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}/upload/operations/{operationsId}": { + "get": { + "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", + "operationId": "fileSearchStores.upload.operations.get", "parameters": [ { - "name": "modelsId", + "name": "operationsId", "in": "path", "required": true, - "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "schema": { + "type": "string" + } + }, + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/upload/operations/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/EmbedContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/EmbedContentResponse" + "$ref": "#/components/schemas/Operation" } } } @@ -1458,77 +1476,97 @@ } } }, - "/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", + "/fileSearchStores/{fileSearchStoresId}/documents/{documentsId}": { + "get": { + "description": "Gets information about a specific `Document`.", + "operationId": "fileSearchStores.documents.get", "parameters": [ { - "name": "modelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string" + } + }, + { + "name": "documentsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Document` to retrieve. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", "schema": { "type": "string", - "pattern": "^models/[^/]+$" + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" } } ], - "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/Document" } } } } } - } - }, - "/models/{modelsId}/operations": { - "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "models.operations.list", + }, + "delete": { + "description": "Deletes a `Document`.", + "operationId": "fileSearchStores.documents.delete", "parameters": [ { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "modelsId", + "name": "fileSearchStoresId", "in": "path", "required": true, - "description": "The name of the operation's parent resource.", "schema": { - "type": "string", - "pattern": "^models/[^/]+$" + "type": "string" } }, + { + "name": "force", + "in": "query", + "description": "Optional. If set to true, any `Chunk`s and objects related to this `Document` will also be deleted. If false (the default), a `FAILED_PRECONDITION` error will be returned if `Document` contains any `Chunk`s.", + "schema": { + "type": "boolean" + } + }, + { + "name": "documentsId", + "in": "path", + "required": true, + "description": "Required. The resource name of the `Document` to delete. Example: `fileSearchStores/my-file-search-store-123/documents/the-doc-abc`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+/documents/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Empty" + } + } + } + } + } + } + }, + "/fileSearchStores/{fileSearchStoresId}/documents": { + "get": { + "description": "Lists all `Document`s in a `Corpus`.", + "operationId": "fileSearchStores.documents.list", + "parameters": [ { "name": "pageSize", "in": "query", - "description": "The standard list page size.", + "description": "Optional. The maximum number of `Document`s to return (per page). The service may return fewer `Document`s. If unspecified, at most 10 `Document`s will be returned. The maximum size limit is 20 `Document`s per page.", "schema": { "type": "integer", "format": "int32" @@ -1537,17 +1575,95 @@ { "name": "pageToken", "in": "query", - "description": "The standard list page token.", + "description": "Optional. A page token, received from a previous `ListDocuments` call. Provide the `next_page_token` returned in the response as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListDocuments` must match the call that provided the page token.", "schema": { "type": "string" } }, { - "name": "returnPartialSuccess", + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. The name of the `FileSearchStore` containing `Document`s. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListDocumentsResponse" + } + } + } + } + } + } + }, + "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { + "post": { + "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", + "operationId": "media.uploadToFileSearchStore", + "parameters": [ + { + "name": "fileSearchStoresId", + "in": "path", + "required": true, + "description": "Required. Immutable. The name of the `FileSearchStore` to upload the file into. Example: `fileSearchStores/my-file-search-store-123`", + "schema": { + "type": "string", + "pattern": "^fileSearchStores/[^/]+$" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CustomLongRunningOperation" + } + } + } + } + } + } + }, + "/generatedFiles": { + "get": { + "description": "Lists the generated files owned by the requesting project.", + "operationId": "generatedFiles.list", + "parameters": [ + { + "name": "pageSize", "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. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", "schema": { - "type": "boolean" + "type": "integer", + "format": "int32" + } + }, + { + "name": "pageToken", + "in": "query", + "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", + "schema": { + "type": "string" } } ], @@ -1557,7 +1673,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" + "$ref": "#/components/schemas/ListGeneratedFilesResponse" } } } @@ -1565,10 +1681,10 @@ } } }, - "/models/{modelsId}/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": "models.operations.get", + "operationId": "generatedFiles.operations.get", "parameters": [ { "name": "operationsId", @@ -1579,13 +1695,13 @@ } }, { - "name": "modelsId", + "name": "generatedFilesId", "in": "path", "required": true, "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^models/[^/]+/operations/[^/]+$" + "pattern": "^generatedFiles/[^/]+/operations/[^/]+$" } } ], @@ -1603,19 +1719,19 @@ } } }, - "/tunedModels/{tunedModelsId}": { - "delete": { - "description": "Deletes a tuned model.", - "operationId": "tunedModels.delete", + "/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": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -1625,25 +1741,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } } } }, - "get": { - "description": "Gets information about a specific TunedModel.", - "operationId": "tunedModels.get", + "delete": { + "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.", + "operationId": "batches.delete", "parameters": [ { - "name": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The resource name of the model. Format: `tunedModels/my-model-id`", + "description": "The name of the operation resource to be deleted.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], @@ -1653,25 +1769,27 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/Empty" } } } } } - }, + } + }, + "/batches/{batchesId}:updateGenerateContentBatch": { "patch": { - "description": "Updates a tuned model.", - "operationId": "tunedModels.patch", + "description": "Updates a batch of GenerateContent requests for batch processing.", + "operationId": "batches.updateGenerateContentBatch", "parameters": [ { - "name": "tunedModelsId", + "name": "batchesId", "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. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" } }, { @@ -1688,7 +1806,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -1699,7 +1817,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/GenerateContentBatch" } } } @@ -1707,19 +1825,28 @@ } } }, - "/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", + "/batches/{batchesId}:updateEmbedContentBatch": { + "patch": { + "description": "Updates a batch of EmbedContent requests for batch processing.", + "operationId": "batches.updateEmbedContentBatch", "parameters": [ { - "name": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "Optional. The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -1727,7 +1854,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentRequest" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -1738,12 +1865,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" - } - }, - "text/event-stream": { - "schema": { - "$ref": "#/components/schemas/GenerateContentResponse" + "$ref": "#/components/schemas/EmbedContentBatch" } } } @@ -1751,38 +1873,29 @@ } } }, - "/tunedModels/{tunedModelsId}:asyncBatchEmbedContent": { + "/batches/{batchesId}:cancel": { "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", + "description": "Starts asynchronous cancellation on a long-running operation. The server makes a best effort to cancel the operation, but success is not guaranteed. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`. Clients can use Operations.GetOperation or other methods to check whether the cancellation succeeded or whether the operation completed despite cancellation. On successful cancellation, the operation is not deleted; instead, it becomes an operation with an Operation.error value with a google.rpc.Status.code of `1`, corresponding to `Code.CANCELLED`.", + "operationId": "batches.cancel", "parameters": [ { - "name": "tunedModelsId", + "name": "batchesId", "in": "path", "required": true, - "description": "Required. The 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": "^tunedModels/[^/]+$" + "pattern": "^batches/[^/]+$" } } ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" - } - } - } - }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/Empty" } } } @@ -1790,15 +1903,15 @@ } } }, - "/tunedModels": { + "/batches": { "get": { - "description": "Lists created tuned models.", - "operationId": "tunedModels.list", + "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", + "operationId": "batches.list", "parameters": [ { "name": "filter", "in": "query", - "description": "Optional. A filter is a full text search over the tuned model's description and display name. By default, results will not include tuned models shared with everyone. Additional operators: - owner:me - writers:me - readers:me - readers:everyone Examples: \"owner:me\" returns all tuned models to which caller has owner role \"readers:me\" returns all tuned models to which caller has reader role \"readers:everyone\" returns all tuned models that are shared with everyone", + "description": "The standard list filter.", "schema": { "type": "string" } @@ -1806,7 +1919,7 @@ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `TunedModels` to return (per page). The service may return fewer tuned models. If unspecified, at most 10 tuned models will be returned. This method returns at most 1000 models per page, even if you pass a larger page_size.", + "description": "The standard list page size.", "schema": { "type": "integer", "format": "int32" @@ -1815,35 +1928,47 @@ { "name": "pageToken", "in": "query", - "description": "Optional. A page token, received from a previous `ListTunedModels` call. Provide the `page_token` returned by one request as an argument to the next request to retrieve the next page. When paginating, all other parameters provided to `ListTunedModels` must match the call that provided the page token.", + "description": "The standard list page token.", "schema": { "type": "string" } - } - ], - "responses": { - "200": { - "description": "Successful response", + }, + { + "name": "returnPartialSuccess", + "in": "query", + "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", + "schema": { + "type": "boolean" + } + } + ], + "responses": { + "200": { + "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListTunedModelsResponse" + "$ref": "#/components/schemas/ListOperationsResponse" } } } } } - }, + } + }, + "/models/{modelsId}:countTokens": { "post": { - "description": "Creates a tuned model. Check intermediate tuning progress (if any) through the [google.longrunning.Operations] service. Access status and results through the Operations service. Example: GET /v1/tunedModels/az2mb0bpw6i/operations/000-111-222", - "operationId": "tunedModels.create", + "description": "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": "tunedModelId", - "in": "query", - "description": "Optional. The unique id for the tuned model if specified. This value should be up to 40 characters, the first character must be a letter, the last could be a letter or a number. The id must match the regular expression: `[a-z]([a-z0-9-]{0,38}[a-z0-9])?`.", + "name": "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/[^/]+$" } } ], @@ -1851,7 +1976,85 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TunedModel" + "$ref": "#/components/schemas/CountTokensRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/CountTokensResponse" + } + } + } + } + } + } + }, + "/models/{modelsId}:batchEmbedContents": { + "post": { + "description": "Generates multiple embedding vectors from the input `Content` which consists of a batch of strings represented as `EmbedContentRequest` objects.", + "operationId": "models.batchEmbedContents", + "parameters": [ + { + "name": "modelsId", + "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/BatchEmbedContentsRequest" + } + } + } + }, + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchEmbedContentsResponse" + } + } + } + } + } + } + }, + "/models/{modelsId}:batchGenerateContent": { + "post": { + "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", + "operationId": "models.batchGenerateContent", + "parameters": [ + { + "name": "modelsId", + "in": "path", + "required": true, + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "schema": { + "type": "string", + "pattern": "^models/[^/]+$" + } + } + ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/BatchGenerateContentRequest" } } } @@ -1870,19 +2073,56 @@ } } }, - "/tunedModels/{tunedModelsId}:transferOwnership": { + "/models": { + "get": { + "description": "Lists the [`Model`s](https://ai.google.dev/gemini-api/docs/models/gemini) available through the Gemini API.", + "operationId": "models.list", + "parameters": [ + { + "name": "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.", + "schema": { + "type": "string" + } + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/ListModelsResponse" + } + } + } + } + } + } + }, + "/models/{modelsId}:embedContent": { "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", + "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": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name of the tuned model to transfer ownership. Format: `tunedModels/my-model-id`", + "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": "^tunedModels/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1890,7 +2130,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipRequest" + "$ref": "#/components/schemas/EmbedContentRequest" } } } @@ -1901,7 +2141,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/TransferOwnershipResponse" + "$ref": "#/components/schemas/EmbedContentResponse" } } } @@ -1909,19 +2149,19 @@ } } }, - "/tunedModels/{tunedModelsId}:generateContent": { + "/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": "tunedModels.generateContent", + "operationId": "models.generateContent", "parameters": [ { - "name": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1948,19 +2188,19 @@ } } }, - "/tunedModels/{tunedModelsId}:batchGenerateContent": { + "/models/{modelsId}:streamGenerateContent": { "post": { - "description": "Enqueues a batch of `GenerateContent` requests for batch processing.", - "operationId": "tunedModels.batchGenerateContent", + "description": "Generates a [streamed response](https://ai.google.dev/gemini-api/docs/text-generation?lang=python#generate-a-text-stream) from the model given an input `GenerateContentRequest`.", + "operationId": "models.streamGenerateContent", "parameters": [ { - "name": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^models/[^/]+$" } } ], @@ -1968,7 +2208,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/BatchGenerateContentRequest" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -1979,7 +2219,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -1987,30 +2232,61 @@ } } }, - "/tunedModels/{tunedModelsId}/operations/{operationsId}": { + "/models/{modelsId}": { "get": { - "description": "Gets the latest state of a long-running operation. Clients can use this method to poll the operation result at intervals as recommended by the API service.", - "operationId": "tunedModels.operations.get", + "description": "Gets information about a specific `Model` such as its version number, token limits, [parameters](https://ai.google.dev/gemini-api/docs/models/generative-models#model-parameters) and other metadata. Refer to the [Gemini models guide](https://ai.google.dev/gemini-api/docs/models/gemini) for detailed model information.", + "operationId": "models.get", "parameters": [ { - "name": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, + "description": "Required. The resource name of the model. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", "schema": { - "type": "string" + "type": "string", + "pattern": "^models/[^/]+$" } - }, + } + ], + "responses": { + "200": { + "description": "Successful response", + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/Model" + } + } + } + } + } + } + }, + "/models/{modelsId}:asyncBatchEmbedContent": { + "post": { + "description": "Enqueues a batch of `EmbedContent` requests for batch processing. We have a `BatchEmbedContents` handler in `GenerativeService`, but it was synchronized. So we name this one to be `Async` to avoid confusion.", + "operationId": "models.asyncBatchEmbedContent", + "parameters": [ { - "name": "operationsId", + "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": "^tunedModels/[^/]+/operations/[^/]+$" + "pattern": "^models/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/AsyncBatchEmbedContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", @@ -2025,10 +2301,10 @@ } } }, - "/tunedModels/{tunedModelsId}/operations": { + "/models/{modelsId}/operations": { "get": { "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "tunedModels.operations.list", + "operationId": "models.operations.list", "parameters": [ { "name": "filter", @@ -2039,13 +2315,13 @@ } }, { - "name": "tunedModelsId", + "name": "modelsId", "in": "path", "required": true, "description": "The name of the operation's parent resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+$" + "pattern": "^models/[^/]+$" } }, { @@ -2088,13 +2364,13 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions/{permissionsId}": { - "delete": { - "description": "Deletes the permission.", - "operationId": "tunedModels.permissions.delete", - "parameters": [ - { - "name": "tunedModelsId", + "/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", + "parameters": [ + { + "name": "operationsId", "in": "path", "required": true, "schema": { @@ -2102,13 +2378,13 @@ } }, { - "name": "permissionsId", + "name": "modelsId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "The name of the operation resource.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^models/[^/]+/operations/[^/]+$" } } ], @@ -2118,78 +2394,66 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/Operation" } } } } } - }, - "get": { - "description": "Gets information about a specific Permission.", - "operationId": "tunedModels.permissions.get", + } + }, + "/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": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "permissionsId", + "name": "dynamicId", "in": "path", "required": true, - "description": "Required. The resource name of the permission. Formats: `tunedModels/{tuned_model}/permissions/{permission}` `corpora/{corpus}/permissions/{permission}`", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" + "pattern": "^dynamic/[^/]+$" } } ], + "requestBody": { + "content": { + "application/json": { + "schema": { + "$ref": "#/components/schemas/GenerateContentRequest" + } + } + } + }, "responses": { "200": { "description": "Successful response", "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" } } } } } - }, - "patch": { - "description": "Updates the permission.", - "operationId": "tunedModels.permissions.patch", + } + }, + "/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": "tunedModelsId", - "in": "path", - "required": true, - "schema": { - "type": "string" - } - }, - { - "name": "permissionsId", + "name": "dynamicId", "in": "path", "required": true, - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only.", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+/permissions/[^/]+$" - } - }, - { - "name": "updateMask", - "in": "query", - "description": "Required. The list of fields to update. Accepted ones: - role (`Permission.role` field)", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", "schema": { "type": "string", - "format": "google-fieldmask" + "pattern": "^dynamic/[^/]+$" } } ], @@ -2197,7 +2461,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentRequest" } } } @@ -2208,7 +2472,12 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/GenerateContentResponse" + } + }, + "text/event-stream": { + "schema": { + "$ref": "#/components/schemas/GenerateContentResponse" } } } @@ -2216,15 +2485,15 @@ } } }, - "/tunedModels/{tunedModelsId}/permissions": { + "/cachedContents": { "get": { - "description": "Lists permissions for the specific resource.", - "operationId": "tunedModels.permissions.list", + "description": "Lists CachedContents.", + "operationId": "cachedContents.list", "parameters": [ { "name": "pageSize", "in": "query", - "description": "Optional. The maximum number of `Permission`s to return (per page). The service may return fewer permissions. If unspecified, at most 10 permissions will be returned. This method returns at most 1000 permissions per page, even if you pass larger page_size.", + "description": "Optional. 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" @@ -2233,20 +2502,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 `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" } - }, - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The parent resource of the permissions. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } } ], "responses": { @@ -2255,7 +2514,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/ListPermissionsResponse" + "$ref": "#/components/schemas/ListCachedContentsResponse" } } } @@ -2263,25 +2522,13 @@ } }, "post": { - "description": "Create a permission to a specific resource.", - "operationId": "tunedModels.permissions.create", - "parameters": [ - { - "name": "tunedModelsId", - "in": "path", - "required": true, - "description": "Required. The parent resource of the `Permission`. Formats: `tunedModels/{tuned_model}` `corpora/{corpus}`", - "schema": { - "type": "string", - "pattern": "^tunedModels/[^/]+$" - } - } - ], + "description": "Creates CachedContent resource.", + "operationId": "cachedContents.create", "requestBody": { "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2292,7 +2539,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2300,19 +2547,28 @@ } } }, - "/fileSearchStores/{fileSearchStoresId}:uploadToFileSearchStore": { - "post": { - "description": "Uploads data to a FileSearchStore, preprocesses and chunks before storing it in a FileSearchStore Document.", - "operationId": "media.uploadToFileSearchStore", + "/cachedContents/{cachedContentsId}": { + "patch": { + "description": "Updates CachedContent resource (only expiration is updatable).", + "operationId": "cachedContents.patch", "parameters": [ { - "name": "fileSearchStoresId", + "name": "cachedContentsId", "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": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^fileSearchStores/[^/]+$" + "pattern": "^cachedContents/[^/]+$" + } + }, + { + "name": "updateMask", + "in": "query", + "description": "The list of fields to update.", + "schema": { + "type": "string", + "format": "google-fieldmask" } } ], @@ -2320,7 +2576,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/UploadToFileSearchStoreRequest" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2331,37 +2587,7 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/CustomLongRunningOperation" - } - } - } - } - } - } - }, - "/batches/{batchesId}": { - "delete": { - "description": "Deletes a long-running operation. This method indicates that the client is no longer interested in the operation result. It does not cancel the operation. If the server doesn't support this method, it returns `google.rpc.Code.UNIMPLEMENTED`.", - "operationId": "batches.delete", - "parameters": [ - { - "name": "batchesId", - "in": "path", - "required": true, - "description": "The name of the operation resource to be deleted.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/Empty" + "$ref": "#/components/schemas/CachedContent" } } } @@ -2369,17 +2595,17 @@ } }, "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": "Reads CachedContent resource.", + "operationId": "cachedContents.get", "parameters": [ { - "name": "batchesId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "The name of the operation resource.", + "description": "Required. The resource name referring to the content cache entry. Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -2389,27 +2615,25 @@ "content": { "application/json": { "schema": { - "$ref": "#/components/schemas/Operation" + "$ref": "#/components/schemas/CachedContent" } } } } } - } - }, - "/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", + }, + "delete": { + "description": "Deletes CachedContent resource.", + "operationId": "cachedContents.delete", "parameters": [ { - "name": "batchesId", + "name": "cachedContentsId", "in": "path", "required": true, - "description": "The name of the operation resource to be cancelled.", + "description": "Required. The resource name referring to the content cache entry Format: `cachedContents/{id}`", "schema": { "type": "string", - "pattern": "^batches/[^/]+$" + "pattern": "^cachedContents/[^/]+$" } } ], @@ -2426,4505 +2650,4281 @@ } } } - }, - "/batches/{batchesId}:updateEmbedContentBatch": { - "patch": { - "description": "Updates a batch of EmbedContent requests for batch processing.", - "operationId": "batches.updateEmbedContentBatch", - "parameters": [ - { - "name": "batchesId", - "in": "path", - "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } + } + }, + "components": { + "schemas": { + "UploadToFileSearchStoreRequest": { + "description": "Request for `UploadToFileSearchStore`.", + "type": "object", + "properties": { + "chunkingConfig": { + "description": "Optional. Config for telling the service how to chunk the data. If not provided, the service will use default parameters.", + "$ref": "#/components/schemas/ChunkingConfig" }, - { - "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/EmbedContentBatch" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/EmbedContentBatch" - } - } - } - } - } - } - }, - "/batches": { - "get": { - "description": "Lists operations that match the specified filter in the request. If the server doesn't support this method, it returns `UNIMPLEMENTED`.", - "operationId": "batches.list", - "parameters": [ - { - "name": "filter", - "in": "query", - "description": "The standard list filter.", - "schema": { - "type": "string" - } - }, - { - "name": "pageSize", - "in": "query", - "description": "The standard list page size.", - "schema": { - "type": "integer", - "format": "int32" - } + "mimeType": { + "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", + "type": "string" }, - { - "name": "pageToken", - "in": "query", - "description": "The standard list page token.", - "schema": { - "type": "string" - } + "displayName": { + "type": "string", + "description": "Optional. Display name of the created document." }, - { - "name": "returnPartialSuccess", - "in": "query", - "description": "When set to `true`, operations that are reachable are returned as normal, and those that are unreachable are returned in the ListOperationsResponse.unreachable field. This can only be `true` when reading across collections. For example, when `parent` is set to `\"projects/example/locations/-\"`. This field is not supported by default and will result in an `UNIMPLEMENTED` error if set unless explicitly documented otherwise in service or product specific documentation.", - "schema": { - "type": "boolean" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/ListOperationsResponse" - } - } + "customMetadata": { + "description": "Custom metadata to be associated with the data.", + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" } } } - } - }, - "/batches/{batchesId}:updateGenerateContentBatch": { - "patch": { - "description": "Updates a batch of GenerateContent requests for batch processing.", - "operationId": "batches.updateGenerateContentBatch", - "parameters": [ - { - "name": "batchesId", - "in": "path", - "required": true, - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`.", - "schema": { - "type": "string", - "pattern": "^batches/[^/]+$" - } + }, + "ListOperationsResponse": { + "description": "The response message for Operations.ListOperations.", + "type": "object", + "properties": { + "operations": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Operation" + }, + "description": "A list of operations that matches the specified filter in the request." }, - { - "name": "updateMask", - "in": "query", - "description": "Optional. The list of fields to update.", - "schema": { - "type": "string", - "format": "google-fieldmask" - } - } - ], - "requestBody": { - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" - } - } - } - }, - "responses": { - "200": { - "description": "Successful response", - "content": { - "application/json": { - "schema": { - "$ref": "#/components/schemas/GenerateContentBatch" - } - } - } - } - } - } - }, - "/generatedFiles": { - "get": { - "description": "Lists the generated files owned by the requesting project.", - "operationId": "generatedFiles.list", - "parameters": [ - { - "name": "pageSize", - "in": "query", - "description": "Optional. Maximum number of `GeneratedFile`s to return per page. If unspecified, defaults to 10. Maximum `page_size` is 50.", - "schema": { - "type": "integer", - "format": "int32" - } + "nextPageToken": { + "type": "string", + "description": "The standard List next-page token." }, - { - "name": "pageToken", - "in": "query", - "description": "Optional. A page token from a previous `ListGeneratedFiles` call.", - "schema": { - "type": "string" - } - } - ], - "responses": { - "200": { - "description": "Successful response", - "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": { + "unreachable": { + "type": "array", + "items": { "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" - } - } - } + }, + "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." } } - } - } - }, - "components": { - "schemas": { - "SearchEntryPoint": { - "description": "Google search entry point.", + }, + "Part": { + "type": "object", "properties": { - "renderedContent": { - "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", - "type": "string" + "partMetadata": { + "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" }, - "sdkBlob": { - "description": "Optional. Base64 encoded JSON representing array of tuple.", + "executableCode": { + "$ref": "#/components/schemas/ExecutableCode", + "description": "Code generated by the model that is meant to be executed." + }, + "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" + }, + "fileData": { + "$ref": "#/components/schemas/FileData", + "description": "URI based data." + }, + "videoMetadata": { + "$ref": "#/components/schemas/VideoMetadata", + "description": "Optional. Video metadata. The metadata should only be specified while the video data is presented in inline_data or file_data." + }, + "thought": { + "description": "Optional. Indicates if the part is thought from the model.", + "type": "boolean" + }, + "codeExecutionResult": { + "description": "Result of executing the `ExecutableCode`.", + "$ref": "#/components/schemas/CodeExecutionResult" + }, + "thoughtSignature": { "type": "string", - "format": "byte" + "format": "byte", + "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." + }, + "mediaResolution": { + "$ref": "#/components/schemas/MediaResolution", + "description": "Optional. Media resolution for the input media." + }, + "text": { + "description": "Inline text.", + "type": "string" + }, + "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" + }, + "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" + }, + "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" + }, + "inlineData": { + "$ref": "#/components/schemas/Blob", + "description": "Inline media bytes." } }, - "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." }, - "ImageSearch": { - "description": "Image search for grounding and related configurations.", - "properties": {}, - "type": "object" + "CachedContentUsageMetadata": { + "description": "Metadata on the usage of the cached content.", + "type": "object", + "properties": { + "totalTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total number of tokens that the cached content consumes." + } + } }, - "ImportFileRequest": { + "AudioResponseFormat": { "type": "object", - "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`.", "properties": { - "customMetadata": { - "description": "Custom metadata to be associated with the file.", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - }, - "type": "array" + "mimeType": { + "type": "string", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "MP3 audio format.", + "OGG Opus audio format.", + "Raw PCM (L16) audio format.", + "WAV audio format.", + "A-law audio format.", + "Mu-law audio format." + ], + "description": "Optional. The MIME type of the audio output.", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "AUDIO_MP3", + "AUDIO_OGG_OPUS", + "AUDIO_L16", + "AUDIO_WAV", + "AUDIO_ALAW", + "AUDIO_MULAW" + ] }, - "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" + "delivery": { + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Audio data is returned inline in the response.", + "Audio data is returned as a URI." + ], + "type": "string", + "description": "Optional. The delivery mode for the audio output.", + "enum": [ + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" + ] }, - "fileName": { - "description": "Required. The name of the `File` to import. Example: `files/abc-123`", - "type": "string" + "bitRate": { + "format": "int32", + "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus).", + "type": "integer" + }, + "sampleRate": { + "description": "Optional. Sample rate in Hz.", + "format": "int32", + "type": "integer" } - } + }, + "description": "Configuration for audio output format." }, - "GroundingAttribution": { - "description": "Attribution for a source that contributed to an answer.", + "GenerateContentBatchOutput": { + "type": "object", "properties": { - "content": { - "description": "Grounding source content that makes up this attribution.", - "$ref": "#/components/schemas/Content" + "responsesFile": { + "readOnly": true, + "type": "string", + "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." }, - "sourceId": { + "inlinedResponses": { "readOnly": true, - "description": "Output only. Identifier for the source contributing to this attribution.", - "$ref": "#/components/schemas/AttributionSourceId" + "$ref": "#/components/schemas/InlinedResponses", + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests." } }, - "type": "object" + "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field." }, - "VideoMetadata": { - "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content.", - "deprecated": true, + "CustomMetadata": { + "description": "User provided metadata stored as key-value pairs.", "type": "object", "properties": { - "fps": { - "description": "Optional. The frame rate of the video sent to the model. If not specified, the default value will be 1.0. The fps range is (0.0, 24.0].", - "type": "number", - "format": "double" + "numericValue": { + "description": "The numeric value of the metadata to store.", + "format": "float", + "type": "number" }, - "startOffset": { - "description": "Optional. The start offset of the video.", + "key": { "type": "string", - "format": "google-duration" + "description": "Required. The key of the metadata to store." }, - "endOffset": { - "description": "Optional. The end offset of the video.", - "type": "string", - "format": "google-duration" + "stringValue": { + "description": "The string value of the metadata to store.", + "type": "string" + }, + "stringListValue": { + "$ref": "#/components/schemas/StringList", + "description": "The StringList value of the metadata to store." + } + } + }, + "SearchTypes": { + "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "type": "object", + "properties": { + "webSearch": { + "$ref": "#/components/schemas/WebSearch", + "description": "Optional. Enables web search. Only text results are returned." + }, + "imageSearch": { + "description": "Optional. Enables image search. Image bytes are returned.", + "$ref": "#/components/schemas/ImageSearch" } } }, - "GenerationConfig": { + "TunedModel": { "type": "object", - "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", "properties": { - "frequencyPenalty": { - "description": "Optional. Frequency penalty applied to the next token's logprobs, multiplied by the number of times each token has been seen in the respponse so far. A positive penalty will discourage the use of tokens that have already been used, proportional to the number of times the token has been used: The more a token is used, the more difficult it is for the model to use that token again increasing the vocabulary of responses. Caution: A _negative_ penalty will encourage the model to reuse tokens proportional to the number of times the token has been used. Small negative values will reduce the vocabulary of a response. Larger negative values will cause the model to start repeating a common token until it hits the max_output_tokens limit.", - "type": "number", - "format": "float" + "state": { + "description": "Output only. The state of the tuned model.", + "enum": [ + "STATE_UNSPECIFIED", + "CREATING", + "ACTIVE", + "FAILED" + ], + "readOnly": true, + "type": "string", + "x-enum-descriptions": [ + "The default value. This value is unused.", + "The model is being created.", + "The model is ready to be used.", + "The model failed to be created." + ] }, - "enableEnhancedCivicAnswers": { - "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", - "type": "boolean" + "baseModel": { + "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", + "type": "string" }, - "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.", - "items": { - "type": "string" - }, - "type": "array" + "displayName": { + "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces.", + "type": "string" }, - "speechConfig": { - "description": "Optional. The speech generation config.", - "$ref": "#/components/schemas/SpeechConfig" + "tuningTask": { + "description": "Required. The tuning task that creates the tuned model.", + "$ref": "#/components/schemas/TuningTask" }, - "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" + "readerProjectNumbers": { + "type": "array", + "items": { + "type": "string", + "format": "int64" + }, + "description": "Optional. List of project numbers that have read access to the tuned model." }, - "topP": { - "description": "Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", - "type": "number", - "format": "float" + "name": { + "readOnly": true, + "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`" }, - "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" + "description": { + "description": "Optional. A short description of this model.", + "type": "string" }, - "maxOutputTokens": { - "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function.", - "type": "integer", - "format": "int32" + "createTime": { + "readOnly": true, + "type": "string", + "format": "google-datetime", + "description": "Output only. The timestamp when this model was created." }, - "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.", + "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" }, - "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" - }, - "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)." - ], + "updateTime": { + "readOnly": true, "type": "string", - "enum": [ - "MEDIA_RESOLUTION_UNSPECIFIED", - "MEDIA_RESOLUTION_LOW", - "MEDIA_RESOLUTION_MEDIUM", - "MEDIA_RESOLUTION_HIGH" - ], - "description": "Optional. If specified, the media resolution specified will be used." + "description": "Output only. The timestamp when this model was updated.", + "format": "google-datetime" + }, + "tunedModelSource": { + "description": "Optional. TunedModel to use as the starting point for training the new model.", + "$ref": "#/components/schemas/TunedModelSource" }, "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", + "description": "Optional. Controls the randomness of the output. Values can range over `[0.0,1.0]`, inclusive. A value closer to `1.0` will produce responses that are more varied, while a value closer to `0.0` will typically result in less surprising responses from the model. This value specifies default to be the one used by the base model while creating the model.", "format": "float" }, - "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" - }, - "translationConfig": { - "description": "Optional. Config for translation.", - "$ref": "#/components/schemas/TranslationConfig" - }, - "seed": { - "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", - "type": "integer", - "format": "int32" - }, - "responseJsonSchema": { - "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." - }, - "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" - }, - "responseModalities": { - "type": "array", - "description": "Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text.", - "items": { - "x-enum-descriptions": [ - "Default value.", - "Indicates the model should return text.", - "Indicates the model should return images.", - "Indicates the model should return audio.", - "Indicates the model should return video." - ], - "type": "string", - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "AUDIO", - "VIDEO" - ] - } - }, "topK": { - "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", "type": "integer", + "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model.", "format": "int32" - }, - "responseLogprobs": { - "description": "Optional. If true, export the logprobs results in response.", - "type": "boolean" - }, - "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" - }, - "responseFormat": { - "description": "Optional. Configuration for the response output format. Allows specifying output configuration per modality (text, audio, image) in a flat structure.", - "$ref": "#/components/schemas/ResponseFormatConfig" } - } + }, + "description": "A fine-tuned model created using ModelService.CreateTunedModel." }, "GoogleMaps": { - "type": "object", "description": "The GoogleMaps Tool that provides geospatial context for the user's query.", - "properties": { - "enableWidget": { - "description": "Optional. Whether to return a widget context token in the GroundingMetadata of the response. Developers can use the widget context token to render a Google Maps widget with geospatial context related to the places that the model references in the response.", - "type": "boolean" - } - } - }, - "MultiSpeakerVoiceConfig": { "type": "object", - "description": "The configuration for the multi-speaker setup.", "properties": { - "speakerVoiceConfigs": { - "description": "Required. All the enabled speaker voices.", - "items": { - "$ref": "#/components/schemas/SpeakerVoiceConfig" - }, - "type": "array" + "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." } } }, - "InlinedEmbedContentResponses": { + "TuningSnapshot": { + "description": "Record for a single tuning step.", "type": "object", - "description": "The responses to the requests in the batch.", "properties": { - "inlinedResponses": { + "step": { + "format": "int32", + "description": "Output only. The tuning step.", "readOnly": true, - "type": "array", - "description": "Output only. The responses to the requests in the batch.", - "items": { - "$ref": "#/components/schemas/InlinedEmbedContentResponse" - } - } - } - }, - "ListOperationsResponse": { - "description": "The response message for Operations.ListOperations.", - "properties": { - "operations": { - "type": "array", - "description": "A list of operations that matches the specified filter in the request.", - "items": { - "$ref": "#/components/schemas/Operation" - } + "type": "integer" }, - "nextPageToken": { - "description": "The standard List next-page token.", - "type": "string" + "meanLoss": { + "readOnly": true, + "type": "number", + "description": "Output only. The mean loss of the training examples for this step.", + "format": "float" }, - "unreachable": { - "description": "Unordered list. Unreachable resources. Populated when the request sets `ListOperationsRequest.return_partial_success` and reads across collections. For example, when attempting to list all resources across all supported locations.", - "items": { - "type": "string" - }, - "type": "array" - } - }, - "type": "object" - }, - "GenerateContentBatchOutput": { - "type": "object", - "description": "The output of a batch request. This is returned in the `BatchGenerateContentResponse` or the `GenerateContentBatch.output` field.", - "properties": { - "inlinedResponses": { + "computeTime": { + "description": "Output only. The timestamp when this metric was computed.", + "format": "google-datetime", "readOnly": true, - "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", - "$ref": "#/components/schemas/InlinedResponses" + "type": "string" }, - "responsesFile": { + "epoch": { "readOnly": true, - "type": "string", - "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `GenerateContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." + "type": "integer", + "format": "int32", + "description": "Output only. The epoch this step was part of." } } }, - "TranslationConfig": { - "description": "Config for translation features.", + "VoiceConfig": { + "type": "object", "properties": { - "targetLanguageCode": { - "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\").", - "type": "string" - }, - "echoTargetLanguage": { - "description": "Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language.", - "type": "boolean" + "prebuiltVoiceConfig": { + "description": "The configuration for the prebuilt voice to use.", + "$ref": "#/components/schemas/PrebuiltVoiceConfig" } }, - "type": "object" + "description": "The configuration for the voice to use." }, - "SemanticRetrieverChunk": { - "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", + "SpeechConfig": { + "description": "Config for speech generation and transcription.", + "type": "object", "properties": { - "chunk": { - "readOnly": true, - "type": "string", - "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`" + "multiSpeakerVoiceConfig": { + "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", + "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" }, - "source": { - "readOnly": true, + "languageCode": { "type": "string", - "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`" + "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": { + "description": "The configuration in case of single-voice output.", + "$ref": "#/components/schemas/VoiceConfig" + } + } + }, + "BatchEmbedContentsRequest": { + "description": "Batch request to get embeddings from the model for a list of prompts.", + "type": "object", + "properties": { + "requests": { + "type": "array", + "items": { + "$ref": "#/components/schemas/EmbedContentRequest" + }, + "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`." } - }, - "type": "object" + } }, - "WhiteSpaceConfig": { - "description": "Configuration for a white space chunking algorithm [white space delimited].", + "BatchGenerateContentRequest": { + "type": "object", "properties": { - "maxTokensPerChunk": { - "type": "integer", - "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." - }, - "maxOverlapTokens": { - "description": "Maximum number of overlapping tokens between two adjacent chunks.", - "type": "integer", - "format": "int32" + "batch": { + "$ref": "#/components/schemas/GenerateContentBatch", + "description": "Required. The batch to create." } }, - "type": "object" + "description": "Request for a `BatchGenerateContent` operation." }, "Hyperparameters": { "type": "object", - "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance", "properties": { "batchSize": { "type": "integer", - "format": "int32", - "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples." + "description": "Immutable. The batch size hyperparameter for tuning. If not set, a default of 4 or 16 will be used based on the number of training examples.", + "format": "int32" }, "learningRate": { - "type": "number", "format": "float", - "description": "Optional. Immutable. The learning rate hyperparameter for tuning. If not set, a default of 0.001 or 0.0002 will be calculated based on the number of training examples." + "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" }, "learningRateMultiplier": { + "format": "float", "description": "Optional. Immutable. The learning rate multiplier is used to calculate a final learning_rate based on the default (recommended) value. Actual learning rate := learning_rate_multiplier * default learning rate Default learning rate is dependent on base model and dataset size. If not set, a default of 1.0 will be used.", - "type": "number", - "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.", "type": "integer", + "description": "Immutable. The number of training epochs. An epoch is one pass through the training data. If not set, a default of 5 will be used.", "format": "int32" } - } + }, + "description": "Hyperparameters controlling the tuning process. Read more at https://ai.google.dev/docs/model_tuning_guidance" }, - "ListFilesResponse": { + "ComputerUse": { "type": "object", - "description": "Response for `ListFiles`.", "properties": { - "files": { + "disabledSafetyPolicies": { + "description": "Optional. Disabled safety policies for computer use.", "type": "array", - "description": "The list of `File`s.", "items": { - "$ref": "#/components/schemas/File" + "enum": [ + "SAFETY_POLICY_UNSPECIFIED", + "FINANCIAL_TRANSACTIONS", + "SENSITIVE_DATA_MODIFICATION", + "COMMUNICATION_TOOL", + "ACCOUNT_CREATION", + "DATA_MODIFICATION", + "USER_CONSENT_MANAGEMENT", + "LEGAL_TERMS_AND_AGREEMENTS" + ], + "x-enum-descriptions": [ + "Unspecified safety policy.", + "Safety policy for financial transactions.", + "Safety policy for sensitive data modification.", + "Safety policy for communication tools (e.g. Gmail, Chat, Meet).", + "Safety policy for account creation.", + "Safety policy for data modification.", + "Safety policy for user consent management.", + "Safety policy for legal terms and agreements." + ], + "type": "string" } }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call.", - "type": "string" - } - } - }, - "VideoFileMetadata": { - "type": "object", - "description": "Metadata for a video `File`.", - "properties": { - "videoDuration": { - "type": "string", - "format": "google-duration", - "description": "Duration of the video." - } - } - }, - "AudioResponseFormat": { - "description": "Configuration for audio output format.", - "properties": { - "sampleRate": { - "description": "Optional. Sample rate in Hz.", - "type": "integer", - "format": "int32" + "enablePromptInjectionDetection": { + "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", + "type": "boolean" }, - "delivery": { + "environment": { "x-enum-descriptions": [ - "Default value. This value is unused.", - "Audio data is returned inline in the response.", - "Audio data is returned as a URI." - ], - "type": "string", - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" + "Defaults to browser.", + "Operates in a web browser.", + "Operates in a mobile environment.", + "Operates in a desktop environment." ], - "description": "Optional. The delivery mode for the audio output." - }, - "mimeType": { "type": "string", + "description": "Required. The environment being operated.", "enum": [ - "MIME_TYPE_UNSPECIFIED", - "AUDIO_MP3", - "AUDIO_OGG_OPUS", - "AUDIO_L16", - "AUDIO_WAV", - "AUDIO_ALAW", - "AUDIO_MULAW" - ], - "x-enum-descriptions": [ - "Default value. This value is unused.", - "MP3 audio format.", - "OGG Opus audio format.", - "Raw PCM (L16) audio format.", - "WAV audio format.", - "A-law audio format.", - "Mu-law audio format." - ], - "description": "Optional. The MIME type of the audio output." + "ENVIRONMENT_UNSPECIFIED", + "ENVIRONMENT_BROWSER", + "ENVIRONMENT_MOBILE", + "ENVIRONMENT_DESKTOP" + ] }, - "bitRate": { - "type": "integer", - "format": "int32", - "description": "Optional. Bit rate in bits per second (bps). Only applicable for compressed formats (MP3, Opus)." + "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." } }, - "type": "object" + "description": "Computer Use tool type." }, - "TextResponseFormat": { - "description": "Configuration for text output format.", + "InlinedEmbedContentResponse": { + "description": "The response to a single request in the batch.", + "type": "object", "properties": { - "schema": { - "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." + "error": { + "description": "Output only. The error encountered while processing the request.", + "readOnly": true, + "$ref": "#/components/schemas/Status" }, - "mimeType": { - "x-enum-descriptions": [ - "Default value. This value is unused.", - "JSON output format.", - "Plain text output format." - ], - "type": "string", - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "APPLICATION_JSON", - "TEXT_PLAIN" - ], - "description": "Optional. The MIME type of the text output." + "response": { + "description": "Output only. The response to the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentResponse" + }, + "metadata": { + "readOnly": true, + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Output only. The metadata associated with the request." } - }, - "type": "object" + } }, - "ListCorporaResponse": { - "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", + "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": { - "corpora": { - "description": "The returned corpora.", + "fileSearchStores": { + "description": "The returned rag_stores.", + "type": "array", "items": { - "$ref": "#/components/schemas/Corpus" - }, - "type": "array" + "$ref": "#/components/schemas/FileSearchStore" + } }, "nextPageToken": { "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", "type": "string" } - }, - "type": "object" + } }, - "ListModelsResponse": { + "ChunkingConfig": { "type": "object", - "description": "Response from `ListModel` containing a paginated list of Models.", "properties": { - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" - }, - "models": { - "type": "array", - "description": "The returned Models.", - "items": { - "$ref": "#/components/schemas/Model" - } + "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" }, - "Blob": { - "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", + "CodeExecutionResult": { + "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", + "type": "object", "properties": { - "data": { - "description": "Raw bytes for media formats.", + "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": { + "x-enum-descriptions": [ + "Unspecified status. This value should not be used.", + "Code execution completed successfully. `output` contains the stdout, if any.", + "Code execution failed. `output` contains the stderr and stdout, if any.", + "Code execution ran for too long, and was cancelled. There may or may not be a partial `output` present." + ], "type": "string", - "format": "byte" + "description": "Required. Outcome of the code execution.", + "enum": [ + "OUTCOME_UNSPECIFIED", + "OUTCOME_OK", + "OUTCOME_FAILED", + "OUTCOME_DEADLINE_EXCEEDED" + ] }, - "mimeType": { - "description": "The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). //", + "output": { + "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", "type": "string" } - }, - "type": "object" + } }, - "Maps": { + "EmbedContentConfig": { "type": "object", - "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", "properties": { - "placeId": { - "description": "The ID of the place, in `places/{place_id}` format. A user can use this ID to look up that place.", - "type": "string" + "outputDimensionality": { + "type": "integer", + "format": "int32", + "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end." }, - "uri": { - "description": "URI reference of the place.", + "documentOcr": { + "type": "boolean", + "description": "Optional. Whether to enable OCR for document content." + }, + "audioTrackExtraction": { + "description": "Optional. Whether to extract audio from video content.", + "type": "boolean" + }, + "taskType": { + "description": "Optional. The task type of the embedding.", + "enum": [ + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ], + "x-enum-descriptions": [ + "Unset value, which will default to one of the other enum values.", + "Specifies the given text is a query in a search/retrieval setting.", + "Specifies the given text is a document from the corpus being searched.", + "Specifies the given text will be used for STS.", + "Specifies that the given text will be classified.", + "Specifies that the embeddings will be used for clustering.", + "Specifies that the given text will be used for question answering.", + "Specifies that the given text will be used for fact verification.", + "Specifies that the given text will be used for code retrieval." + ], "type": "string" }, - "placeAnswerSources": { - "description": "Sources that provide answers about the features of a given place in Google Maps.", - "$ref": "#/components/schemas/PlaceAnswerSources" - }, "title": { - "description": "Title of the place.", - "type": "string" + "type": "string", + "description": "Optional. The title for the text." }, - "text": { - "description": "Text description of the place answer.", - "type": "string" + "autoTruncate": { + "type": "boolean", + "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length." } - } + }, + "description": "Configurations for the EmbedContent request." }, - "ExecutableCode": { + "SearchEntryPoint": { + "description": "Google search entry point.", "type": "object", - "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated.", "properties": { - "id": { - "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`.", + "renderedContent": { + "description": "Optional. Web content snippet that can be embedded in a web page or an app webview.", "type": "string" }, - "language": { - "description": "Required. Programming language of the `code`.", - "type": "string", - "enum": [ - "LANGUAGE_UNSPECIFIED", - "PYTHON" - ], - "x-enum-descriptions": [ - "Unspecified language. This value should not be used.", - "Python >= 3.10, with numpy and simpy available. Python is the default language." - ] - }, - "code": { - "description": "Required. The code to be executed.", + "sdkBlob": { + "description": "Optional. Base64 encoded JSON representing array of tuple.", + "format": "byte", "type": "string" } } }, - "ListDocumentsResponse": { - "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`.", + "Web": { + "type": "object", "properties": { - "documents": { - "type": "array", - "description": "The returned `Document`s.", - "items": { - "$ref": "#/components/schemas/Document" - } + "uri": { + "readOnly": true, + "type": "string", + "description": "Output only. URI reference of the chunk." }, - "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" + "title": { + "readOnly": true, + "type": "string", + "description": "Output only. Title of the chunk." } }, - "type": "object" + "description": "Chunk from the web." }, - "ChunkingConfig": { + "ImageConfig": { + "description": "Config for image generation features.", "type": "object", - "description": "Parameters for telling the service how to chunk the file. inspired by google3/cloud/ai/platform/extension/lib/retrieval/config/chunker_config.proto", "properties": { - "whiteSpaceConfig": { - "description": "White space chunking configuration.", - "$ref": "#/components/schemas/WhiteSpaceConfig" + "aspectRatio": { + "type": "string", + "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided." + }, + "imageSize": { + "type": "string", + "description": "Optional. Specifies the size of generated images. Supported values are `512`, `1K`, `2K`, `4K`. If not specified, the model will use default value `1K`." } } }, - "Operation": { - "description": "This resource represents a long-running operation that is the result of a network API call.", + "GenerationConfig": { + "description": "Configuration options for model generation and outputs. Not all parameters are configurable for every model.", + "type": "object", "properties": { - "response": { - "type": "object", - "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." + "stopSequences": { + "description": "Optional. The set of character sequences (up to 5) that will stop output generation. If specified, the API will stop at the first appearance of a `stop_sequence`. The stop sequence will not be included as part of the response.", + "type": "array", + "items": { + "type": "string" } }, - "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.", + "maxOutputTokens": { + "description": "Optional. The maximum number of tokens to include in a response candidate. Note: The default value varies by model, see the `Model.output_token_limit` attribute of the `Model` returned from the `getModel` function.", + "format": "int32", + "type": "integer" + }, + "responseSchema": { + "$ref": "#/components/schemas/Schema", + "description": "Optional. Output schema of the generated candidate text. Schemas must be a subset of the [OpenAPI schema](https://spec.openapis.org/oas/v3.0.3#schema) and can be objects, primitives or arrays. If set, a compatible `response_mime_type` must also be set. Compatible MIME types: `application/json`: Schema for JSON response. Refer to the [JSON text generation guide](https://ai.google.dev/gemini-api/docs/json-mode) for more details." + }, + "topP": { + "description": "Optional. The maximum cumulative probability of tokens to consider when sampling. The model uses combined Top-k and Top-p (nucleus) sampling. Tokens are sorted based on their assigned probabilities so that only the most likely tokens are considered. Top-k sampling directly limits the maximum number of tokens to consider, while Nucleus sampling limits the number of tokens based on the cumulative probability. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests.", + "format": "float", + "type": "number" + }, + "responseModalities": { + "description": "Optional. The requested modalities of the response. Represents the set of modalities that the model can return, and should be expected in the response. This is an exact match to the modalities of the response. A model may have multiple combinations of supported modalities. If the requested modalities do not match any of the supported combinations, an error will be returned. An empty list is equivalent to requesting only text.", + "type": "array", + "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" + ] + } + }, + "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)" + }, + "temperature": { + "type": "number", + "description": "Optional. Controls the randomness of the output. Note: The default value varies by model, see the `Model.temperature` attribute of the `Model` returned from the `getModel` function. Values can range from [0.0, 2.0].", + "format": "float" + }, + "topK": { + "type": "integer", + "format": "int32", + "description": "Optional. The maximum number of tokens to consider when sampling. Gemini models use Top-p (nucleus) sampling or a combination of Top-k and nucleus sampling. Top-k sampling considers the set of `top_k` most probable tokens. Models running with nucleus sampling don't allow top_k setting. Note: The default value varies by `Model` and is specified by the`Model.top_p` attribute returned from the `getModel` function. An empty `top_k` attribute indicates that the model doesn't apply top-k sampling and doesn't allow setting `top_k` on requests." + }, + "logprobs": { + "type": "integer", + "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" + }, + "responseFormat": { + "$ref": "#/components/schemas/ResponseFormatConfig", + "description": "Optional. Configuration for the response output format. Allows specifying output configuration per modality (text, audio, image) in a flat structure." + }, + "enableEnhancedCivicAnswers": { + "description": "Optional. Enables enhanced civic answers. It may not be available for all models.", "type": "boolean" }, - "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" + "responseMimeType": { + "type": "string", + "description": "Optional. MIME type of the generated candidate text. Supported MIME types are: `text/plain`: (default) Text output. `application/json`: JSON response in the response candidates. `text/x.enum`: ENUM as a string response in the response candidates. Refer to the [docs](https://ai.google.dev/gemini-api/docs/prompting_with_media#plain_text_formats) for a list of all supported text MIME types." }, - "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" + "responseJsonSchema": { + "description": "Optional. An internal detail. Use `responseJsonSchema` rather than this field." }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" - } - }, - "type": "object" - }, - "FunctionCallingConfig": { - "type": "object", - "description": "Configuration for specifying function calling behavior.", - "properties": { - "mode": { - "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", + "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)." + ], "type": "string", + "description": "Optional. If specified, the media resolution specified will be used.", "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\"." + "MEDIA_RESOLUTION_UNSPECIFIED", + "MEDIA_RESOLUTION_LOW", + "MEDIA_RESOLUTION_MEDIUM", + "MEDIA_RESOLUTION_HIGH" ] }, - "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.", - "items": { - "type": "string" - }, - "type": "array" + "speechConfig": { + "$ref": "#/components/schemas/SpeechConfig", + "description": "Optional. The speech generation config." + }, + "seed": { + "format": "int32", + "description": "Optional. Seed used in decoding. If not set, the request uses a randomly generated seed.", + "type": "integer" + }, + "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" + }, + "presencePenalty": { + "type": "number", + "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." + }, + "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." + }, + "responseLogprobs": { + "type": "boolean", + "description": "Optional. If true, export the logprobs results in response." + }, + "translationConfig": { + "description": "Optional. Config for translation.", + "$ref": "#/components/schemas/TranslationConfig" + }, + "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" } } }, - "FunctionResponseBlob": { - "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", + "CitationSource": { + "description": "A citation to a source for a portion of a specific response.", + "type": "object", "properties": { - "data": { - "description": "Raw bytes for media formats.", + "startIndex": { + "type": "integer", + "description": "Optional. Start of segment of the response that is attributed to this source. Index indicates the start of the segment, measured in bytes.", + "format": "int32" + }, + "license": { "type": "string", - "format": "byte" + "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations." }, - "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" - } - }, - "type": "object" - }, - "InputEmbedContentConfig": { - "type": "object", - "description": "Configures the input to the batch request.", - "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", - "type": "string" + "endIndex": { + "description": "Optional. End of the attributed segment, exclusive.", + "format": "int32", + "type": "integer" }, - "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedEmbedContentRequests" + "uri": { + "type": "string", + "description": "Optional. URI that is attributed as a source for a portion of the text." } } }, - "ListCachedContentsResponse": { + "Image": { + "description": "Chunk from image search.", "type": "object", - "description": "Response with CachedContents list.", - "properties": { - "cachedContents": { - "type": "array", - "description": "List of cached contents.", - "items": { - "$ref": "#/components/schemas/CachedContent" - } + "properties": { + "title": { + "description": "The title of the web page that the image is from.", + "type": "string" }, - "nextPageToken": { - "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no subsequent pages.", + "imageUri": { + "description": "The image asset URL.", "type": "string" + }, + "sourceUri": { + "type": "string", + "description": "The web page URI for attribution." + }, + "domain": { + "type": "string", + "description": "The root domain of the web page that the image is from, e.g. \"example.com\"." } } }, - "ListGeneratedFilesResponse": { + "SemanticRetrieverChunk": { + "description": "Identifier for a `Chunk` retrieved via Semantic Retriever specified in the `GenerateAnswerRequest` using `SemanticRetrieverConfig`.", "type": "object", - "description": "Response for `ListGeneratedFiles`.", "properties": { - "generatedFiles": { - "description": "The list of `GeneratedFile`s.", - "items": { - "$ref": "#/components/schemas/GeneratedFile" - }, - "type": "array" + "source": { + "description": "Output only. Name of the source matching the request's `SemanticRetrieverConfig.source`. Example: `corpora/123` or `corpora/123/documents/abc`", + "readOnly": true, + "type": "string" }, - "nextPageToken": { - "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call.", + "chunk": { + "description": "Output only. Name of the `Chunk` containing the attributed text. Example: `corpora/123/documents/abc/chunks/xyz`", + "readOnly": true, "type": "string" } } }, - "ResponseFormatConfig": { - "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality.", + "FunctionResponsePart": { + "type": "object", "properties": { - "image": { - "description": "Optional. Image output format configuration.", - "$ref": "#/components/schemas/ImageResponseFormat" - }, - "audio": { - "description": "Optional. Audio output format configuration.", - "$ref": "#/components/schemas/AudioResponseFormat" - }, - "text": { - "description": "Optional. Text output format configuration.", - "$ref": "#/components/schemas/TextResponseFormat" + "inlineData": { + "$ref": "#/components/schemas/FunctionResponseBlob", + "description": "Inline media bytes." } }, - "type": "object" + "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes." }, - "LogprobsResult": { - "description": "Logprobs Result", + "GoogleAiGenerativelanguageV1betaGroundingSupport": { + "type": "object", "properties": { - "chosenCandidates": { + "groundingChunkIndices": { + "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order).", "type": "array", - "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates.", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" + "type": "integer", + "format": "int32" } }, - "logProbabilitySum": { - "description": "Sum of log probabilities for all tokens.", - "type": "number", - "format": "float" + "confidenceScores": { + "type": "array", + "items": { + "type": "number", + "format": "float" + }, + "description": "Optional. Confidence score of the support references. Ranges from 0 to 1. 1 is the most confident. This list must have the same size as the grounding_chunk_indices." }, - "topCandidates": { + "renderedParts": { + "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", + "readOnly": true, "type": "array", - "description": "Length = total number of decoding steps.", "items": { - "$ref": "#/components/schemas/TopCandidates" + "type": "integer", + "format": "int32" } + }, + "segment": { + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment", + "description": "Segment of the content this support belongs to." } }, - "type": "object" + "description": "Grounding support." }, - "Candidate": { - "description": "A response candidate generated from the model.", + "GroundingChunkCustomMetadata": { + "type": "object", "properties": { - "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" - }, - "urlContextMetadata": { - "readOnly": true, - "description": "Output only. Metadata related to url context retrieval tool.", - "$ref": "#/components/schemas/UrlContextMetadata" - }, - "finishReason": { - "readOnly": true, - "enum": [ - "FINISH_REASON_UNSPECIFIED", - "STOP", - "MAX_TOKENS", - "SAFETY", - "RECITATION", - "LANGUAGE", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "SPII", - "MALFORMED_FUNCTION_CALL", - "IMAGE_SAFETY", - "IMAGE_PROHIBITED_CONTENT", - "IMAGE_OTHER", - "NO_IMAGE", - "IMAGE_RECITATION", - "UNEXPECTED_TOOL_CALL", - "TOO_MANY_TOOL_CALLS", - "MISSING_THOUGHT_SIGNATURE", - "MALFORMED_RESPONSE", - "ESCALATION" - ], - "type": "string", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Natural stop point of the model or provided stop sequence.", - "The maximum number of tokens as specified in the request was reached.", - "The response candidate content was flagged for safety reasons.", - "The response candidate content was flagged for recitation reasons.", - "The response candidate content was flagged for using an unsupported language.", - "Unknown reason.", - "Token generation stopped because the content contains forbidden terms.", - "Token generation stopped for potentially containing prohibited content.", - "Token generation stopped because the content potentially contains Sensitive Personally Identifiable Information (SPII).", - "The function call generated by the model is invalid.", - "Token generation stopped because generated images contain safety violations.", - "Image generation stopped because generated images has other prohibited content.", - "Image generation stopped because of other miscellaneous issue.", - "The model was expected to generate an image, but none was generated.", - "Image generation stopped due to recitation.", - "Model generated a tool call but no tools were enabled in the request.", - "Model called too many tools consecutively, thus the system exited execution.", - "Request has at least one thought signature missing.", - "Finished due to malformed response.", - "Request was filtered by an escalation rule." - ], - "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens." - }, - "logprobsResult": { - "description": "Output only. Log-likelihood scores for the response tokens and top tokens", - "$ref": "#/components/schemas/LogprobsResult", - "readOnly": true - }, - "citationMetadata": { - "readOnly": true, - "description": "Output only. Citation information for model-generated candidate. This field may be populated with recitation information for any text included in the `content`. These are passages that are \"recited\" from copyrighted material in the foundational LLM's training data.", - "$ref": "#/components/schemas/CitationMetadata" - }, - "tokenCount": { - "description": "Output only. Token count for this candidate.", - "readOnly": true, - "type": "integer", - "format": "int32" - }, - "avgLogprobs": { - "description": "Output only. Average log probability score of the candidate.", - "readOnly": true, + "numericValue": { "type": "number", - "format": "double" - }, - "index": { - "description": "Output only. Index of the candidate in the list of response candidates.", - "readOnly": true, - "type": "integer", - "format": "int32" - }, - "groundingAttributions": { - "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", - "items": { - "$ref": "#/components/schemas/GroundingAttribution" - }, - "readOnly": true, - "type": "array" + "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", + "format": "float" }, - "finishMessage": { - "readOnly": true, + "key": { "type": "string", - "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." + "description": "The key of the metadata." }, - "content": { - "readOnly": true, - "description": "Output only. Generated content returned from the model.", - "$ref": "#/components/schemas/Content" + "stringValue": { + "type": "string", + "description": "Optional. The string value of the metadata." }, - "groundingMetadata": { - "readOnly": true, - "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls.", - "$ref": "#/components/schemas/GroundingMetadata" + "stringListValue": { + "description": "Optional. A list of string values for the metadata.", + "$ref": "#/components/schemas/GroundingChunkStringList" } }, - "type": "object" + "description": "User provided metadata about the GroundingFact." }, - "CodeExecution": { + "ContentEmbedding": { "type": "object", - "description": "Tool that executes code generated by the model, and automatically returns the result to the model. See also `ExecutableCode` and `CodeExecutionResult` which are only generated when using this tool.", - "properties": {} + "properties": { + "values": { + "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", + "type": "array", + "items": { + "type": "number", + "format": "float" + } + }, + "shape": { + "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", + "type": "array", + "items": { + "type": "integer", + "format": "int32" + } + } + }, + "description": "A list of floats representing an embedding." }, - "EmbedContentConfig": { + "FunctionCallingConfig": { + "description": "Configuration for specifying function calling behavior.", "type": "object", - "description": "Configurations for the EmbedContent request.", "properties": { - "outputDimensionality": { - "type": "integer", - "format": "int32", - "description": "Optional. Reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end." - }, - "autoTruncate": { - "description": "Optional. Whether to silently truncate the input content if it's longer than the maximum sequence length.", - "type": "boolean" - }, - "audioTrackExtraction": { - "description": "Optional. Whether to extract audio from video content.", - "type": "boolean" - }, - "documentOcr": { - "description": "Optional. Whether to enable OCR for document content.", - "type": "boolean" - }, - "title": { - "description": "Optional. The title for the text.", - "type": "string" - }, - "taskType": { + "mode": { "x-enum-descriptions": [ - "Unset value, which will default to one of the other enum values.", - "Specifies the given text is a query in a search/retrieval setting.", - "Specifies the given text is a document from the corpus being searched.", - "Specifies the given text will be used for STS.", - "Specifies that the given text will be classified.", - "Specifies that the embeddings will be used for clustering.", - "Specifies that the given text will be used for question answering.", - "Specifies that the given text will be used for fact verification.", - "Specifies that the given text will be used for code retrieval." + "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\"." ], "type": "string", + "description": "Optional. Specifies the mode in which function calling should execute. If unspecified, the default value will be set to AUTO.", "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" - ], - "description": "Optional. The task type of the embedding." + "MODE_UNSPECIFIED", + "AUTO", + "ANY", + "NONE", + "VALIDATED" + ] + }, + "allowedFunctionNames": { + "description": "Optional. A set of function names that, when provided, limits the functions the model will call. This should only be set when the Mode is ANY or VALIDATED. Function names should match [FunctionDeclaration.name]. When set, model will predict a function call from only allowed function names.", + "type": "array", + "items": { + "type": "string" + } } } }, - "FileData": { + "GroundingChunkStringList": { + "description": "A list of string values.", "type": "object", - "description": "URI based data.", "properties": { - "mimeType": { - "description": "Optional. The IANA standard MIME type of the source data.", - "type": "string" - }, - "fileUri": { - "description": "Required. URI.", - "type": "string" + "values": { + "type": "array", + "items": { + "type": "string" + }, + "description": "The string values of the list." } } }, - "BatchEmbedContentsResponse": { + "Content": { "type": "object", - "description": "The response to a `BatchEmbedContentsRequest`.", "properties": { - "embeddings": { - "description": "Output only. The embeddings for each request, in the same order as provided in the batch request.", - "items": { - "$ref": "#/components/schemas/ContentEmbedding" - }, - "readOnly": true, - "type": "array" + "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" }, - "usageMetadata": { - "readOnly": true, - "description": "Output only. The usage metadata for the request.", - "$ref": "#/components/schemas/EmbeddingUsageMetadata" + "parts": { + "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Part" + } } - } + }, + "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." }, - "SafetySetting": { + "McpServer": { + "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 6", "type": "object", - "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked.", "properties": { - "category": { - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ], - "description": "Required. The category for this setting.", + "name": { "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." - ] + "description": "The name of the MCPServer." }, - "threshold": { - "x-enum-descriptions": [ - "Threshold is unspecified.", - "Content with NEGLIGIBLE will be allowed.", - "Content with NEGLIGIBLE and LOW will be allowed.", - "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", - "All content will be allowed.", - "Turn off the safety filter." - ], - "type": "string", - "enum": [ - "HARM_BLOCK_THRESHOLD_UNSPECIFIED", - "BLOCK_LOW_AND_ABOVE", - "BLOCK_MEDIUM_AND_ABOVE", - "BLOCK_ONLY_HIGH", - "BLOCK_NONE", - "OFF" - ], - "description": "Required. Controls the probability threshold at which harm is blocked." + "streamableHttpTransport": { + "$ref": "#/components/schemas/StreamableHttpTransport", + "description": "A transport that can stream HTTP requests and responses." } } }, - "Corpus": { - "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "InlinedEmbedContentRequest": { + "description": "The request to be processed in the batch.", + "type": "object", "properties": { - "displayName": { - "description": "Optional. The human-readable display name for the `Corpus`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"", - "type": "string" - }, - "createTime": { - "description": "Output only. The Timestamp of when the `Corpus` was created.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "updateTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Corpus` was last updated." + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/EmbedContentRequest" }, - "name": { - "description": "Output only. Immutable. Identifier. The `Corpus` resource name. The ID (name excluding the \"corpora/\" prefix) can contain up to 40 characters that are lowercase alphanumeric or dashes (-). The ID cannot start or end with a dash. If the name is empty on create, a unique name will be derived from `display_name` along with a 12 character random suffix. Example: `corpora/my-awesome-corpora-123a456b789c`", - "readOnly": true, - "type": "string" + "metadata": { + "description": "Optional. The metadata to be associated with the request.", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" } - }, - "type": "object" + } }, - "GroundingChunkCustomMetadata": { - "description": "User provided metadata about the GroundingFact.", + "Schema": { + "type": "object", "properties": { - "stringListValue": { - "description": "Optional. A list of string values for the metadata.", - "$ref": "#/components/schemas/GroundingChunkStringList" + "enum": { + "description": "Optional. Possible values of the element of Type.STRING with enum format. For example we can define an Enum Direction as : {type:STRING, format:enum, enum:[\"EAST\", NORTH\", \"SOUTH\", \"WEST\"]}", + "type": "array", + "items": { + "type": "string" + } }, - "numericValue": { - "description": "Optional. The numeric value of the metadata. The expected range for this value depends on the specific `key` used.", - "type": "number", - "format": "float" + "maximum": { + "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER", + "format": "double", + "type": "number" }, - "key": { - "description": "The key of the metadata.", + "minLength": { + "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "format": "int64", "type": "string" }, - "stringValue": { - "description": "Optional. The string value of the metadata.", + "description": { + "type": "string", + "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown." + }, + "minItems": { + "description": "Optional. Minimum number of the elements for Type.ARRAY.", + "format": "int64", "type": "string" - } - }, - "type": "object" - }, - "EmbedContentRequest": { - "description": "Request containing the `Content` for the model to embed.", - "properties": { - "taskType": { + }, + "properties": { + "description": "Optional. Properties of Type.OBJECT.", + "additionalProperties": { + "$ref": "#/components/schemas/Schema" + }, + "type": "object" + }, + "format": { + "type": "string", + "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality." + }, + "nullable": { + "description": "Optional. Indicates if the value may be null.", + "type": "boolean" + }, + "maxItems": { + "type": "string", + "description": "Optional. Maximum number of the elements for Type.ARRAY.", + "format": "int64" + }, + "type": { "type": "string", - "deprecated": true, "x-enum-descriptions": [ - "Unset value, which will default to one of the other enum values.", - "Specifies the given text is a query in a search/retrieval setting.", - "Specifies the given text is a document from the corpus being searched.", - "Specifies the given text will be used for STS.", - "Specifies that the given text will be classified.", - "Specifies that the embeddings will be used for clustering.", - "Specifies that the given text will be used for question answering.", - "Specifies that the given text will be used for fact verification.", - "Specifies that the given text will be used for code retrieval." + "Not specified, should not be used.", + "String type.", + "Number type.", + "Integer type.", + "Boolean type.", + "Array type.", + "Object type.", + "Null type." ], - "description": "Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`).", + "description": "Required. Data type.", "enum": [ - "TASK_TYPE_UNSPECIFIED", - "RETRIEVAL_QUERY", - "RETRIEVAL_DOCUMENT", - "SEMANTIC_SIMILARITY", - "CLASSIFICATION", - "CLUSTERING", - "QUESTION_ANSWERING", - "FACT_VERIFICATION", - "CODE_RETRIEVAL_QUERY" + "TYPE_UNSPECIFIED", + "STRING", + "NUMBER", + "INTEGER", + "BOOLEAN", + "ARRAY", + "OBJECT", + "NULL" ] }, + "propertyOrdering": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response." + }, + "required": { + "description": "Optional. Required properties of Type.OBJECT.", + "type": "array", + "items": { + "type": "string" + } + }, + "maxProperties": { + "description": "Optional. Maximum number of the properties for Type.OBJECT.", + "format": "int64", + "type": "string" + }, + "minimum": { + "format": "double", + "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", + "type": "number" + }, + "pattern": { + "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", + "type": "string" + }, "title": { - "description": "Optional. Deprecated: Please use EmbedContentConfig.title instead. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval.", - "deprecated": true, + "description": "Optional. The title of the schema.", "type": "string" }, - "embedContentConfig": { - "description": "Optional. Configuration for the EmbedContent request.", - "$ref": "#/components/schemas/EmbedContentConfig" + "items": { + "description": "Optional. Schema of the elements of Type.ARRAY.", + "$ref": "#/components/schemas/Schema" }, - "content": { - "description": "Required. The content to embed. Only the `parts.text` fields will be counted.", - "$ref": "#/components/schemas/Content" + "anyOf": { + "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Schema" + } }, - "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}`", + "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." + }, + "minProperties": { + "description": "Optional. Minimum number of the properties for Type.OBJECT.", + "format": "int64", "type": "string" }, - "outputDimensionality": { - "deprecated": true, - "type": "integer", - "format": "int32", - "description": "Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`)." + "example": { + "description": "Optional. Example of the object. Will only populated when the object is the root." + }, + "maxLength": { + "type": "string", + "format": "int64", + "description": "Optional. Maximum length of the Type.STRING" } }, - "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)." }, - "FunctionResponsePart": { + "InputConfig": { + "description": "Configures the input to the batch request.", "type": "object", - "description": "A datatype containing media that is part of a `FunctionResponse` message. A `FunctionResponsePart` consists of data which has an associated datatype. A `FunctionResponsePart` can only contain one of the accepted types in `FunctionResponsePart.data`. A `FunctionResponsePart` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", "properties": { - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/FunctionResponseBlob" + "requests": { + "$ref": "#/components/schemas/InlinedRequests", + "description": "The requests to be processed in the batch." + }, + "fileName": { + "description": "The name of the `File` containing the input requests.", + "type": "string" } } }, - "ContentEmbedding": { + "StreamableHttpTransport": { + "description": "A transport that can stream HTTP requests and responses. Next ID: 6", "type": "object", - "description": "A list of floats representing an embedding.", "properties": { - "shape": { - "type": "array", - "description": "This field stores the soft tokens tensor frame shape (e.g. [1, 1, 256, 2048]).", - "items": { - "type": "integer", - "format": "int32" - } + "timeout": { + "type": "string", + "format": "google-duration", + "description": "HTTP timeout for regular operations." }, - "values": { - "description": "The embedding values. This is for 3P users only and will not be populated for 1P calls.", - "items": { - "type": "number", - "format": "float" + "terminateOnClose": { + "type": "boolean", + "description": "Whether to close the client session when the transport closes." + }, + "sseReadTimeout": { + "type": "string", + "description": "Timeout for SSE read operations.", + "format": "google-duration" + }, + "url": { + "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", + "type": "string" + }, + "headers": { + "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", + "additionalProperties": { + "type": "string" }, - "type": "array" + "type": "object" } } }, - "CustomLongRunningOperation": { + "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": { - "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" + "category": { + "description": "Required. The category for this rating.", + "enum": [ + "HARM_CATEGORY_UNSPECIFIED", + "HARM_CATEGORY_DEROGATORY", + "HARM_CATEGORY_TOXICITY", + "HARM_CATEGORY_VIOLENCE", + "HARM_CATEGORY_SEXUAL", + "HARM_CATEGORY_MEDICAL", + "HARM_CATEGORY_DANGEROUS", + "HARM_CATEGORY_HARASSMENT", + "HARM_CATEGORY_HATE_SPEECH", + "HARM_CATEGORY_SEXUALLY_EXPLICIT", + "HARM_CATEGORY_DANGEROUS_CONTENT", + "HARM_CATEGORY_CIVIC_INTEGRITY" + ], + "x-enum-descriptions": [ + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "type": "string", + "enumDeprecated": [ + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + false, + true + ] }, - "response": { - "type": "object", - "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } + "probability": { + "x-enum-descriptions": [ + "Probability is unspecified.", + "Content has a negligible chance of being unsafe.", + "Content has a low chance of being unsafe.", + "Content has a medium chance of being unsafe.", + "Content has a high chance of being unsafe." + ], + "type": "string", + "description": "Required. The probability of harm for this content.", + "enum": [ + "HARM_PROBABILITY_UNSPECIFIED", + "NEGLIGIBLE", + "LOW", + "MEDIUM", + "HIGH" + ] }, - "error": { - "description": "The error result of the operation in case of failure or cancellation.", - "$ref": "#/components/schemas/Status" + "blocked": { + "type": "boolean", + "description": "Was this content blocked because of this rating?" + } + } + }, + "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": { + "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" }, - "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." + "details": { + "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", + "type": "array", + "items": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + } } }, - "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}`.", + "code": { + "format": "int32", + "description": "The status code, which should be an enum value of google.rpc.Code.", + "type": "integer" + } + } + }, + "ListDocumentsResponse": { + "type": "object", + "properties": { + "nextPageToken": { + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", "type": "string" + }, + "documents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Document" + }, + "description": "The returned `Document`s." } }, - "type": "object" + "description": "Response from `ListDocuments` containing a paginated list of `Document`s. The `Document`s are sorted by ascending `document.create_time`." }, - "GenerateContentRequest": { - "description": "Request to generate a completion from the model.", + "FileSearchStore": { + "description": "A `FileSearchStore` is a collection of `Document`s.", + "type": "object", "properties": { - "systemInstruction": { - "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", - "$ref": "#/components/schemas/Content" - }, - "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}`", + "updateTime": { + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", + "readOnly": true, "type": "string" }, - "generationConfig": { - "description": "Optional. Configuration options for model generation and outputs.", - "$ref": "#/components/schemas/GenerationConfig" - }, - "serviceTier": { - "type": "string", - "enum": [ - "unspecified", - "standard", - "flex", - "priority" - ], - "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." - ], - "description": "Optional. The service tier of the request." + "failedDocumentsCount": { + "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", + "format": "int64", + "readOnly": true, + "type": "string" }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "sizeBytes": { + "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, "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.", - "items": { - "$ref": "#/components/schemas/SafetySetting" - }, - "type": "array" + "pendingDocumentsCount": { + "format": "int64", + "description": "Output only. The number of documents in the `FileSearchStore` that are being processed.", + "readOnly": true, + "type": "string" }, - "contents": { - "type": "array", - "description": "Required. The content of the current conversation with the model. For single-turn queries, this is a single instance. For multi-turn queries like [chat](https://ai.google.dev/gemini-api/docs/text-generation#chat), this is a repeated field that contains the conversation history and the latest request.", - "items": { - "$ref": "#/components/schemas/Content" - } + "displayName": { + "type": "string", + "description": "Optional. The human-readable display name for the `FileSearchStore`. The display name must be no more than 512 characters in length, including spaces. Example: \"Docs on Semantic Retriever\"" }, - "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" - } + "createTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The Timestamp of when the `FileSearchStore` was created.", + "format": "google-datetime" }, - "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" + "activeDocumentsCount": { + "readOnly": true, + "type": "string", + "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", + "format": "int64" }, - "store": { - "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config.", - "type": "boolean" - } - }, - "type": "object" - }, - "GoogleSearchRetrieval": { - "description": "Tool to retrieve public web data for grounding, powered by Google.", - "properties": { - "dynamicRetrievalConfig": { - "description": "Specifies the dynamic retrieval configuration for the given source.", - "$ref": "#/components/schemas/DynamicRetrievalConfig" + "embeddingModel": { + "description": "Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used.", + "type": "string" + }, + "name": { + "description": "Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the \"fileSearchStores/\" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.", + "readOnly": true, + "type": "string" } - }, - "type": "object" + } }, "InlinedResponses": { "type": "object", - "description": "The responses to the requests in the batch.", "properties": { "inlinedResponses": { "readOnly": true, "type": "array", - "description": "Output only. The responses to the requests in the batch.", "items": { "$ref": "#/components/schemas/InlinedResponse" - } + }, + "description": "Output only. The responses to the requests in the batch." } - } + }, + "description": "The responses to the requests in the batch." }, - "InputConfig": { + "InlinedEmbedContentRequests": { + "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "type": "object", - "description": "Configures the input to the batch request.", "properties": { - "fileName": { - "description": "The name of the `File` containing the input requests.", - "type": "string" - }, "requests": { - "description": "The requests to be processed in the batch.", - "$ref": "#/components/schemas/InlinedRequests" + "description": "Required. The requests to be processed in the batch.", + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentRequest" + } } } }, - "DynamicRetrievalConfig": { + "FunctionResponse": { "type": "object", - "description": "Describes the options to customize dynamic retrieval.", "properties": { - "dynamicThreshold": { - "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", - "type": "number", - "format": "float" + "parts": { + "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionResponsePart" + } }, - "mode": { - "description": "The mode of the predictor to be used in dynamic retrieval.", + "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" + }, + "willContinue": { + "type": "boolean", + "description": "Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`." + }, + "scheduling": { + "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.", + "enum": [ + "SCHEDULING_UNSPECIFIED", + "SILENT", + "WHEN_IDLE", + "INTERRUPT" + ], "x-enum-descriptions": [ - "Always trigger retrieval.", - "Run retrieval only when system decides it is necessary." + "This value is unused.", + "Only add the result to the conversation context, do not interrupt or trigger generation.", + "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", + "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." ], + "type": "string" + }, + "response": { + "type": "object", + "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model. Multimedia can be included by using a subobject containing a single \"$ref\" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal.", + "additionalProperties": { + "description": "Properties of the object." + } + }, + "id": { "type": "string", - "enum": [ - "MODE_UNSPECIFIED", - "MODE_DYNAMIC" - ] + "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`." } - } + }, + "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." }, - "TransferOwnershipRequest": { + "UrlMetadata": { "type": "object", - "description": "Request to transfer the ownership of the tuned model.", "properties": { - "emailAddress": { - "description": "Required. The email address of the user to whom the tuned model is being transferred to.", + "retrievedUrl": { + "description": "Retrieved url by the tool.", "type": "string" + }, + "urlRetrievalStatus": { + "type": "string", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Url retrieval is successful.", + "Url retrieval is failed due to error.", + "Url retrieval is failed because the content is behind paywall.", + "Url retrieval is failed because the content is unsafe." + ], + "description": "Status of the url retrieval.", + "enum": [ + "URL_RETRIEVAL_STATUS_UNSPECIFIED", + "URL_RETRIEVAL_STATUS_SUCCESS", + "URL_RETRIEVAL_STATUS_ERROR", + "URL_RETRIEVAL_STATUS_PAYWALL", + "URL_RETRIEVAL_STATUS_UNSAFE" + ] } - } + }, + "description": "Context of the a single url retrieval." }, - "McpServer": { + "FunctionDeclaration": { "type": "object", - "description": "A MCPServer is a server that can be called by the model to perform actions. It is a server that implements the MCP protocol. Next ID: 6", "properties": { - "streamableHttpTransport": { - "description": "A transport that can stream HTTP requests and responses.", - "$ref": "#/components/schemas/StreamableHttpTransport" + "behavior": { + "type": "string", + "x-enum-descriptions": [ + "This value is unused.", + "If set, the system will wait to receive the function response before continuing the conversation.", + "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." + ], + "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", + "enum": [ + "UNSPECIFIED", + "BLOCKING", + "NON_BLOCKING" + ] + }, + "parameters": { + "$ref": "#/components/schemas/Schema", + "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." }, "name": { - "description": "The name of the MCPServer.", + "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" - } - } - }, - "TuningTask": { - "type": "object", - "description": "Tuning tasks that create tuned models.", - "properties": { - "hyperparameters": { - "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", - "$ref": "#/components/schemas/Hyperparameters" - }, - "trainingData": { - "description": "Required. Input only. Immutable. The model training data.", - "$ref": "#/components/schemas/Dataset" }, - "startTime": { - "description": "Output only. The timestamp when tuning this model started.", - "readOnly": true, + "description": { "type": "string", - "format": "google-datetime" + "description": "Required. A brief description of the function." }, - "completeTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp when tuning this model completed." + "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`." }, - "snapshots": { - "description": "Output only. Metrics collected during tuning.", - "items": { - "$ref": "#/components/schemas/TuningSnapshot" - }, - "readOnly": true, - "type": "array" + "responseJsonSchema": { + "description": "Optional. Describes the output from this function in JSON Schema format. The value specified by the schema is the response value of the function. This field is mutually exclusive with `response`." + }, + "response": { + "description": "Optional. Describes the output from this function in JSON Schema format. Reflects the Open API 3.03 Response Object. The Schema defines the type used for the response value of the function.", + "$ref": "#/components/schemas/Schema" } - } + }, + "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." }, - "TuningSnapshot": { - "description": "Record for a single tuning step.", + "ToolConfig": { + "type": "object", "properties": { - "epoch": { - "description": "Output only. The epoch this step was part of.", - "readOnly": true, - "type": "integer", - "format": "int32" - }, - "computeTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp when this metric was computed." + "retrievalConfig": { + "$ref": "#/components/schemas/RetrievalConfig", + "description": "Optional. Retrieval config." }, - "step": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. The tuning step." + "functionCallingConfig": { + "$ref": "#/components/schemas/FunctionCallingConfig", + "description": "Optional. Function calling config." }, - "meanLoss": { - "readOnly": true, - "type": "number", - "format": "float", - "description": "Output only. The mean loss of the training examples for this step." + "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" } }, - "type": "object" + "description": "The Tool configuration containing parameters for specifying `Tool` use in the request." }, - "GroundingMetadata": { + "CreateFileRequest": { "type": "object", - "description": "Metadata returned to client when grounding is enabled.", "properties": { - "searchEntryPoint": { - "description": "Optional. Google search entry for the following-up web searches.", - "$ref": "#/components/schemas/SearchEntryPoint" - }, - "groundingSupports": { - "type": "array", - "description": "List of grounding support.", - "items": { - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" - } - }, - "imageSearchQueries": { - "description": "Image search queries used for grounding.", - "items": { - "type": "string" - }, - "type": "array" - }, - "retrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "$ref": "#/components/schemas/RetrievalMetadata" - }, - "webSearchQueries": { - "type": "array", - "description": "Web search queries for the following-up web search.", - "items": { - "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.", + "file": { + "description": "Optional. Metadata for the file to create.", + "$ref": "#/components/schemas/File" + } + }, + "description": "Request for `CreateFile`." + }, + "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/GroundingChunk" - }, - "type": "array" + "$ref": "#/components/schemas/SafetyRating" + } }, - "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.", + "blockReason": { + "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" + ], + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", + "Prompt was blocked due to unknown reasons.", + "Prompt was blocked due to the terms which are included from the terminology blocklist.", + "Prompt was blocked due to prohibited content.", + "Candidates blocked due to unsafe image generation content." + ], "type": "string" } - } + }, + "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`." }, - "File": { - "description": "A file uploaded to the API. Next ID: 15", + "Interval": { + "type": "object", "properties": { - "sizeBytes": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. Size of the file in bytes." - }, - "updateTime": { - "description": "Output only. The timestamp of when the `File` was last updated.", - "readOnly": true, + "startTime": { "type": "string", + "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start.", "format": "google-datetime" }, - "sha256Hash": { - "description": "Output only. SHA-256 hash of the uploaded bytes.", - "readOnly": true, - "type": "string", - "format": "byte" - }, - "videoMetadata": { - "readOnly": true, - "description": "Output only. Metadata for a video.", - "$ref": "#/components/schemas/VideoFileMetadata" - }, - "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" - }, - "downloadUri": { - "description": "Output only. The download uri of the `File`.", - "readOnly": true, - "type": "string" - }, - "source": { - "description": "Source of the File.", - "type": "string", - "enum": [ - "SOURCE_UNSPECIFIED", - "UPLOADED", - "GENERATED", - "REGISTERED" - ], - "x-enum-descriptions": [ - "Used if source is not specified.", - "Indicates the file is uploaded by the user.", - "Indicates the file is generated by Google.", - "Indicates the file is a registered, i.e. a Google Cloud Storage file." - ] - }, - "uri": { - "readOnly": true, - "type": "string", - "description": "Output only. The uri of the `File`." - }, - "createTime": { - "readOnly": true, + "endTime": { "type": "string", "format": "google-datetime", - "description": "Output only. The timestamp of when the `File` was created." - }, - "displayName": { - "description": "Optional. The human-readable display name for the `File`. The display name must be no more than 512 characters in length, including spaces. Example: \"Welcome Image\"", - "type": "string" + "description": "Optional. 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." + }, + "ListModelsResponse": { + "type": "object", + "properties": { + "nextPageToken": { + "type": "string", + "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages." }, + "models": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Model" + }, + "description": "The returned Models." + } + }, + "description": "Response from `ListModel` containing a paginated list of Models." + }, + "InlinedResponse": { + "description": "The response to a single request in the batch.", + "type": "object", + "properties": { "error": { - "description": "Output only. Error status if File processing failed.", + "readOnly": true, "$ref": "#/components/schemas/Status", - "readOnly": true + "description": "Output only. The error encountered while processing the request." }, - "expirationTime": { + "response": { + "description": "Output only. The response to the request.", "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire." + "$ref": "#/components/schemas/GenerateContentResponse" }, - "state": { + "metadata": { "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "PROCESSING", - "ACTIVE", - "FAILED" - ], - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "File is being processed and cannot be used for inference yet.", - "File is processed and available for inference.", - "File failed processing." - ], - "type": "string", - "description": "Output only. Processing state of the File." + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Output only. The metadata associated with the request." + } + } + }, + "TranslationConfig": { + "type": "object", + "properties": { + "echoTargetLanguage": { + "description": "Optional. If true, the model will generate audio when the target language is spoken, essentially it will parrot the input. If false, we will not produce audio for the target language.", + "type": "boolean" }, - "mimeType": { - "readOnly": true, + "targetLanguageCode": { "type": "string", - "description": "Output only. MIME type of the file." + "description": "Required. The target language for translation. Supported values are BCP-47 language codes (e.g. \"en\", \"es\", \"fr\")." } }, - "type": "object" + "description": "Config for translation features." }, - "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).", + "EmbedContentRequest": { + "type": "object", "properties": { - "minLength": { - "description": "Optional. SCHEMA FIELDS FOR TYPE STRING Minimum length of the Type.STRING", + "title": { "type": "string", - "format": "int64" + "description": "Optional. Deprecated: Please use EmbedContentConfig.title instead. An optional title for the text. Only applicable when TaskType is `RETRIEVAL_DOCUMENT`. Note: Specifying a `title` for `RETRIEVAL_DOCUMENT` provides better quality embeddings for retrieval.", + "deprecated": true }, - "minProperties": { - "type": "string", - "format": "int64", - "description": "Optional. Minimum number of the properties for Type.OBJECT." + "model": { + "description": "Required. The model's resource name. This serves as an ID for the Model to use. This name should match a model name returned by the `ListModels` method. Format: `models/{model}`", + "type": "string" }, - "nullable": { - "description": "Optional. Indicates if the value may be null.", - "type": "boolean" + "content": { + "$ref": "#/components/schemas/Content", + "description": "Required. The content to embed. Only the `parts.text` fields will be counted." }, - "example": { - "description": "Optional. Example of the object. Will only populated when the object is the root." + "outputDimensionality": { + "type": "integer", + "description": "Optional. Deprecated: Please use EmbedContentConfig.output_dimensionality instead. Optional reduced dimension for the output embedding. If set, excessive values in the output embedding are truncated from the end. Supported by newer models since 2024 only. You cannot set this value if using the earlier model (`models/embedding-001`).", + "deprecated": true, + "format": "int32" }, - "pattern": { - "description": "Optional. Pattern of the Type.STRING to restrict a string to a regular expression.", - "type": "string" + "embedContentConfig": { + "$ref": "#/components/schemas/EmbedContentConfig", + "description": "Optional. Configuration for the EmbedContent request." }, - "type": { + "taskType": { + "deprecated": true, "x-enum-descriptions": [ - "Not specified, should not be used.", - "String type.", - "Number type.", - "Integer type.", - "Boolean type.", - "Array type.", - "Object type.", - "Null type." + "Unset value, which will default to one of the other enum values.", + "Specifies the given text is a query in a search/retrieval setting.", + "Specifies the given text is a document from the corpus being searched.", + "Specifies the given text will be used for STS.", + "Specifies that the given text will be classified.", + "Specifies that the embeddings will be used for clustering.", + "Specifies that the given text will be used for question answering.", + "Specifies that the given text will be used for fact verification.", + "Specifies that the given text will be used for code retrieval." ], "type": "string", + "description": "Optional. Deprecated: Please use EmbedContentConfig.task_type instead. Optional task type for which the embeddings will be used. Not supported on earlier models (`models/embedding-001`).", "enum": [ - "TYPE_UNSPECIFIED", - "STRING", - "NUMBER", - "INTEGER", - "BOOLEAN", - "ARRAY", - "OBJECT", - "NULL" - ], - "description": "Required. Data type." - }, - "maximum": { - "type": "number", - "format": "double", - "description": "Optional. Maximum value of the Type.INTEGER and Type.NUMBER" - }, - "minimum": { - "description": "Optional. SCHEMA FIELDS FOR TYPE INTEGER and NUMBER Minimum value of the Type.INTEGER and Type.NUMBER", - "type": "number", - "format": "double" - }, - "format": { - "description": "Optional. The format of the data. Any value is allowed, but most do not trigger any special functionality.", - "type": "string" - }, - "maxItems": { + "TASK_TYPE_UNSPECIFIED", + "RETRIEVAL_QUERY", + "RETRIEVAL_DOCUMENT", + "SEMANTIC_SIMILARITY", + "CLASSIFICATION", + "CLUSTERING", + "QUESTION_ANSWERING", + "FACT_VERIFICATION", + "CODE_RETRIEVAL_QUERY" + ] + } + }, + "description": "Request containing the `Content` for the model to embed." + }, + "UrlContext": { + "description": "Tool to support URL context retrieval.", + "type": "object", + "properties": {} + }, + "ReviewSnippet": { + "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", + "type": "object", + "properties": { + "reviewId": { "type": "string", - "format": "int64", - "description": "Optional. Maximum number of the elements for Type.ARRAY." - }, - "items": { - "description": "Optional. Schema of the elements of Type.ARRAY.", - "$ref": "#/components/schemas/Schema" + "description": "The ID of the review snippet." }, - "propertyOrdering": { - "type": "array", - "description": "Optional. The order of the properties. Not a standard field in open api spec. Used to determine the order of the properties in the response.", - "items": { - "type": "string" - } + "googleMapsUri": { + "type": "string", + "description": "A link that corresponds to the user review on Google Maps." }, "title": { - "description": "Optional. The title of the schema.", + "type": "string", + "description": "Title of the review." + } + } + }, + "BatchStats": { + "type": "object", + "properties": { + "pendingRequestCount": { + "format": "int64", + "description": "Output only. The number of requests that are still pending processing.", + "readOnly": true, "type": "string" }, - "minItems": { - "type": "string", + "requestCount": { + "description": "Output only. The number of requests in the batch.", "format": "int64", - "description": "Optional. Minimum number of the elements for Type.ARRAY." - }, - "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." + "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\"]}", - "items": { - "type": "string" - }, - "type": "array" + "successfulRequestCount": { + "readOnly": true, + "type": "string", + "description": "Output only. The number of requests that were successfully processed.", + "format": "int64" }, - "description": { - "description": "Optional. A brief description of the parameter. This could contain examples of use. Parameter description may be formatted as Markdown.", + "failedRequestCount": { + "description": "Output only. The number of requests that failed to be processed.", + "format": "int64", + "readOnly": true, + "type": "string" + } + }, + "description": "Stats about the batch." + }, + "FunctionCall": { + "type": "object", + "properties": { + "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" }, - "required": { - "type": "array", - "description": "Optional. Required properties of Type.OBJECT.", - "items": { - "type": "string" - } - }, - "maxLength": { - "description": "Optional. Maximum length of the Type.STRING", + "name": { "type": "string", - "format": "int64" + "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." }, - "properties": { - "type": "object", - "description": "Optional. Properties of Type.OBJECT.", + "args": { + "description": "Optional. The function parameters and values in JSON object format.", "additionalProperties": { - "$ref": "#/components/schemas/Schema" - } - }, - "anyOf": { - "description": "Optional. The value should be validated against any (one or more) of the subschemas in the list.", - "items": { - "$ref": "#/components/schemas/Schema" + "description": "Properties of the object." }, - "type": "array" + "type": "object" + } + }, + "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values." + }, + "LatLng": { + "type": "object", + "properties": { + "latitude": { + "description": "The latitude in degrees. It must be in the range [-90.0, +90.0].", + "format": "double", + "type": "number" }, - "maxProperties": { - "type": "string", - "format": "int64", - "description": "Optional. Maximum number of the properties for Type.OBJECT." + "longitude": { + "type": "number", + "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", + "format": "double" } }, - "type": "object" + "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges." }, - "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.", + "SafetySetting": { + "type": "object", "properties": { - "modelStage": { - "enum": [ - "MODEL_STAGE_UNSPECIFIED", - "UNSTABLE_EXPERIMENTAL", - "EXPERIMENTAL", - "PREVIEW", - "STABLE", - "LEGACY", - "DEPRECATED", - "RETIRED" + "threshold": { + "type": "string", + "x-enum-descriptions": [ + "Threshold is unspecified.", + "Content with NEGLIGIBLE will be allowed.", + "Content with NEGLIGIBLE and LOW will be allowed.", + "Content with NEGLIGIBLE, LOW, and MEDIUM will be allowed.", + "All content will be allowed.", + "Turn off the safety filter." ], + "description": "Required. Controls the probability threshold at which harm is blocked.", + "enum": [ + "HARM_BLOCK_THRESHOLD_UNSPECIFIED", + "BLOCK_LOW_AND_ABOVE", + "BLOCK_MEDIUM_AND_ABOVE", + "BLOCK_ONLY_HIGH", + "BLOCK_NONE", + "OFF" + ] + }, + "category": { "enumDeprecated": [ false, - true, false, false, false, false, - true, - false + false, + false, + false, + false, + false, + false, + true ], - "description": "The stage of the underlying model.", - "type": "string", "x-enum-descriptions": [ - "Unspecified model stage.", - "The underlying model is subject to lots of tunings.", - "Models in this stage are for experimental purposes only.", - "Models in this stage are more mature than experimental models.", - "Models in this stage are considered stable and ready for production use.", - "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", - "Models in this stage are deprecated. These models cannot be used.", - "Models in this stage are retired. These models cannot be used." + "Category is unspecified.", + "**PaLM** - Negative or harmful comments targeting identity and/or protected attribute.", + "**PaLM** - Content that is rude, disrespectful, or profane.", + "**PaLM** - Describes scenarios depicting violence against an individual or group, or general descriptions of gore.", + "**PaLM** - Contains references to sexual acts or other lewd content.", + "**PaLM** - Promotes unchecked medical advice.", + "**PaLM** - Dangerous content that promotes, facilitates, or encourages harmful acts.", + "**Gemini** - Harassment content.", + "**Gemini** - Hate speech and content.", + "**Gemini** - Sexually explicit content.", + "**Gemini** - Dangerous content.", + "**Gemini** - Content that may be used to harm civic integrity. DEPRECATED: use enable_enhanced_civic_answers instead." + ], + "type": "string", + "description": "Required. The category for this setting.", + "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" ] - }, - "retirementTime": { + } + }, + "description": "Safety setting, affecting the safety-blocking behavior. Passing a safety setting for a category changes the allowed probability that content is blocked." + }, + "Blob": { + "description": "Raw media bytes. Text should not be sent as raw bytes, use the 'text' field.", + "type": "object", + "properties": { + "mimeType": { "type": "string", - "format": "google-datetime", - "description": "The time at which the model will be retired." + "description": "The IANA standard MIME type of the source data. Examples of supported types: - Images: image/png, image/jpeg, image/jpg, image/webp, image/heic, image/heif, image/gif, image/avif - Audio: audio/*, video/audio/s16le, video/audio/wav - Video: video/* - Text: text/plain, text/html, text/css, text/javascript, text/x-typescript, text/csv, text/markdown, text/x-python, text/xml, text/rtf, video/text/timestamp - Applications: application/x-javascript, application/x-typescript, application/x-python-code, application/json, application/x-ipynb+json, application/rtf, application/pdf For additional context, see [Supported file formats](https://ai.google.dev/gemini-api/docs/file-input-methods#supported-content-types). //" }, - "message": { - "description": "A message explaining the model status.", + "data": { + "description": "Raw bytes for media formats.", + "format": "byte", "type": "string" } - }, - "type": "object" + } }, - "InlinedRequests": { - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", + "GenerateContentResponse": { + "type": "object", "properties": { - "requests": { + "promptFeedback": { + "$ref": "#/components/schemas/PromptFeedback", + "description": "Returns the prompt's feedback related to the content filters." + }, + "modelStatus": { + "readOnly": true, + "$ref": "#/components/schemas/ModelStatus", + "description": "Output only. The current model status of this model." + }, + "modelVersion": { + "description": "Output only. The model version used to generate the response.", + "readOnly": true, + "type": "string" + }, + "responseId": { + "description": "Output only. response_id is used to identify each response.", + "readOnly": true, + "type": "string" + }, + "candidates": { "type": "array", - "description": "Required. The requests to be processed in the batch.", "items": { - "$ref": "#/components/schemas/InlinedRequest" - } + "$ref": "#/components/schemas/Candidate" + }, + "description": "Candidate responses from the model." + }, + "usageMetadata": { + "description": "Output only. Metadata on the generation requests' token usage.", + "readOnly": true, + "$ref": "#/components/schemas/UsageMetadata" } }, - "type": "object" + "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`." }, - "Interval": { + "SpeakerVoiceConfig": { "type": "object", - "description": "Represents a time interval, encoded as a Timestamp start (inclusive) and a Timestamp end (exclusive). The start must be less than or equal to the end. When the start equals the end, the interval is empty (matches no time). When both start and end are unspecified, the interval matches any time.", "properties": { - "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." + "speaker": { + "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", + "type": "string" }, - "startTime": { - "type": "string", - "format": "google-datetime", - "description": "Optional. Inclusive start of the interval. If specified, a Timestamp matching this interval will have to be the same or after the start." + "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." + }, + "TransferOwnershipResponse": { + "type": "object", + "properties": {}, + "description": "Response from `TransferOwnership`." + }, + "ResponseFormatConfig": { + "description": "Configuration for the response output format. This is a flat object where each optional sub-field configures a specific output modality.", + "type": "object", + "properties": { + "audio": { + "$ref": "#/components/schemas/AudioResponseFormat", + "description": "Optional. Audio output format configuration." + }, + "image": { + "description": "Optional. Image output format configuration.", + "$ref": "#/components/schemas/ImageResponseFormat" + }, + "text": { + "description": "Optional. Text output format configuration.", + "$ref": "#/components/schemas/TextResponseFormat" } } }, - "ImageConfig": { + "DynamicRetrievalConfig": { + "description": "Describes the options to customize dynamic retrieval.", "type": "object", - "description": "Config for image generation features.", "properties": { - "aspectRatio": { - "description": "Optional. The aspect ratio of the image to generate. Supported aspect ratios: `1:1`, `1:4`, `4:1`, `1:8`, `8:1`, `2:3`, `3:2`, `3:4`, `4:3`, `4:5`, `5:4`, `9:16`, `16:9`, or `21:9`. If not specified, the model will choose a default aspect ratio based on any reference images provided.", - "type": "string" + "dynamicThreshold": { + "format": "float", + "description": "The threshold to be used in dynamic retrieval. If not set, a system default value is used.", + "type": "number" }, - "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`.", + "mode": { + "description": "The mode of the predictor to be used in dynamic retrieval.", + "enum": [ + "MODE_UNSPECIFIED", + "MODE_DYNAMIC" + ], + "x-enum-descriptions": [ + "Always trigger retrieval.", + "Run retrieval only when system decides it is necessary." + ], "type": "string" } } }, - "ToolConfig": { + "Operation": { + "description": "This resource represents a long-running operation that is the result of a network API call.", "type": "object", - "description": "The Tool configuration containing parameters for specifying `Tool` use in the request.", - "properties": { - "retrievalConfig": { - "description": "Optional. Retrieval config.", - "$ref": "#/components/schemas/RetrievalConfig" - }, - "functionCallingConfig": { - "description": "Optional. Function calling config.", - "$ref": "#/components/schemas/FunctionCallingConfig" - }, - "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" - } - } - }, - "FunctionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", "properties": { - "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" + "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" }, - "args": { - "description": "Optional. The function parameters and values in JSON object format.", + "response": { "additionalProperties": { - "description": "Properties of the object." + "description": "Properties of the object. Contains field @type with type URL." }, + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`.", "type": "object" }, "name": { - "description": "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" - } - }, - "type": "object" - }, - "RegisterFilesRequest": { - "description": "Request for `RegisterFiles`.", - "properties": { - "uris": { - "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`.", - "items": { - "type": "string" - }, - "type": "array" + "type": "string", + "description": "The server-assigned name, which is only unique within the same service that originally returns it. If you use the default HTTP mapping, the `name` should be a resource name ending with `operations/{unique_id}`." + }, + "done": { + "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available.", + "type": "boolean" + }, + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." } - }, - "type": "object" + } }, - "PlaceAnswerSources": { + "GroundingMetadata": { + "description": "Metadata returned to client when grounding is enabled.", "type": "object", - "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", "properties": { - "reviewSnippets": { + "webSearchQueries": { + "description": "Web search queries for the following-up web search.", "type": "array", - "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps.", "items": { - "$ref": "#/components/schemas/ReviewSnippet" + "type": "string" } - } - } - }, - "CountTokensRequest": { - "description": "Counts the number of tokens in the `prompt` sent to a model. Models may tokenize text differently, so each model may return a different `token_count`.", - "properties": { - "contents": { + }, + "searchEntryPoint": { + "$ref": "#/components/schemas/SearchEntryPoint", + "description": "Optional. Google search entry for the following-up web searches." + }, + "groundingSupports": { + "description": "List of grounding support.", "type": "array", - "description": "Optional. The input given to the model as a prompt. This field is ignored when `generate_content_request` is set.", "items": { - "$ref": "#/components/schemas/Content" + "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaGroundingSupport" } }, - "generateContentRequest": { - "description": "Optional. The overall input given to the `Model`. This includes the prompt as well as other model steering information like [system instructions](https://ai.google.dev/gemini-api/docs/system-instructions), and/or function declarations for [function calling](https://ai.google.dev/gemini-api/docs/function-calling). `Model`s/`Content`s and `generate_content_request`s are mutually exclusive. You can either send `Model` + `Content`s or a `generate_content_request`, but never both.", - "$ref": "#/components/schemas/GenerateContentRequest" - } - }, - "type": "object" - }, - "InlinedRequest": { - "type": "object", - "description": "The request to be processed in the batch.", - "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/GenerateContentRequest" + "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." }, - "metadata": { - "type": "object", - "description": "Optional. The metadata to be associated with the request.", - "additionalProperties": { - "description": "Properties of the object." + "groundingChunks": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingChunk" + }, + "description": "List of supporting references retrieved from specified grounding source. When streaming, this only contains the grounding chunks that have not been included in the grounding metadata of previous responses." + }, + "retrievalMetadata": { + "$ref": "#/components/schemas/RetrievalMetadata", + "description": "Metadata related to retrieval in the grounding flow." + }, + "imageSearchQueries": { + "description": "Image search queries used for grounding.", + "type": "array", + "items": { + "type": "string" } } } }, - "CreateFileResponse": { + "CodeExecution": { + "type": "object", + "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." + }, + "AsyncBatchEmbedContentRequest": { + "description": "Request for an `AsyncBatchEmbedContent` operation.", "type": "object", - "description": "Response for `CreateFile`.", "properties": { - "file": { - "description": "Metadata for the created file.", - "$ref": "#/components/schemas/File" + "batch": { + "$ref": "#/components/schemas/EmbedContentBatch", + "description": "Required. The batch to create." } } }, - "TuningExample": { + "GenerateContentBatch": { + "description": "A resource representing a batch of `GenerateContent` requests.", "type": "object", - "description": "A single example for tuning.", "properties": { - "textInput": { - "description": "Optional. Text model input.", + "displayName": { + "type": "string", + "description": "Required. The user-defined name of this batch." + }, + "createTime": { + "description": "Output only. The time at which the batch was created.", + "format": "google-datetime", + "readOnly": true, "type": "string" }, - "output": { - "description": "Required. The expected model output.", + "state": { + "description": "Output only. The state of the batch.", + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ], + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], + "readOnly": true, "type": "string" - } - } - }, - "GroundingPassageId": { - "description": "Identifier for a part within a `GroundingPassage`.", - "properties": { - "partIndex": { + }, + "batchStats": { + "description": "Output only. Stats about the batch.", "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`." + "$ref": "#/components/schemas/BatchStats" }, - "passageId": { + "endTime": { + "description": "Output only. The time at which the batch processing completed.", + "format": "google-datetime", + "readOnly": true, + "type": "string" + }, + "name": { "readOnly": true, "type": "string", - "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`." - } - }, - "type": "object" - }, - "GoogleAiGenerativelanguageV1betaSegment": { - "description": "Segment of the content.", - "properties": { - "startIndex": { - "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", - "type": "integer", - "format": "int32" + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." }, - "partIndex": { - "description": "The index of a Part object within its parent Content object.", - "type": "integer", - "format": "int32" + "output": { + "readOnly": true, + "$ref": "#/components/schemas/GenerateContentBatchOutput", + "description": "Output only. The output of the batch request." }, - "endIndex": { - "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", - "type": "integer", - "format": "int32" + "updateTime": { + "readOnly": true, + "type": "string", + "format": "google-datetime", + "description": "Output only. The time at which the batch was last updated." }, - "text": { - "description": "The text corresponding to the segment from the response.", - "type": "string" - } - }, - "type": "object" - }, - "Status": { - "description": "The `Status` type defines a logical error model that is suitable for different programming environments, including REST APIs and RPC APIs. It is used by [gRPC](https://github.com/grpc). Each `Status` message contains three pieces of data: error code, error message, and error details. You can find out more about this error model and how to work with it in the [API Design Guide](https://cloud.google.com/apis/design/errors).", - "properties": { - "code": { - "type": "integer", - "format": "int32", - "description": "The status code, which should be an enum value of google.rpc.Code." + "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." }, - "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" + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputConfig" }, - "details": { - "description": "A list of messages that carry the error details. There is a common set of message types for APIs to use.", - "items": { - "type": "object", - "additionalProperties": { - "description": "Properties of the object. Contains field @type with type URL." - } - }, - "type": "array" + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" } - }, - "type": "object" + } }, - "Part": { - "type": "object", - "description": "A datatype containing media that is part of a multi-part `Content` message. A `Part` consists of data which has an associated datatype. A `Part` can only contain one of the accepted types in `Part.data`. A `Part` must have a fixed IANA MIME type identifying the type and subtype of the media if the `inline_data` field is filled with raw bytes.", - "properties": { - "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" - }, - "partMetadata": { - "description": "Custom metadata associated with the Part. Agents using genai.Part as content representation may need to keep track of the additional information. For example it can be name of a file/source from which the Part originates or a way to multiplex multiple Part streams.", - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" - }, - "codeExecutionResult": { - "description": "Result of executing the `ExecutableCode`.", - "$ref": "#/components/schemas/CodeExecutionResult" - }, - "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" + "File": { + "description": "A file uploaded to the API. Next ID: 15", + "type": "object", + "properties": { + "mimeType": { + "readOnly": true, + "type": "string", + "description": "Output only. MIME type of the file." }, - "thought": { - "description": "Optional. Indicates if the part is thought from the model.", - "type": "boolean" + "sizeBytes": { + "readOnly": true, + "type": "string", + "description": "Output only. Size of the file in bytes.", + "format": "int64" }, - "text": { - "description": "Inline text.", + "sha256Hash": { + "description": "Output only. SHA-256 hash of the uploaded bytes.", + "format": "byte", + "readOnly": true, "type": "string" }, - "fileData": { - "description": "URI based data.", - "$ref": "#/components/schemas/FileData" - }, - "inlineData": { - "description": "Inline media bytes.", - "$ref": "#/components/schemas/Blob" + "videoMetadata": { + "readOnly": true, + "$ref": "#/components/schemas/VideoFileMetadata", + "description": "Output only. Metadata for a video." }, - "mediaResolution": { - "description": "Optional. Media resolution for the input media.", - "$ref": "#/components/schemas/MediaResolution" + "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" }, - "executableCode": { - "description": "Code generated by the model that is meant to be executed.", - "$ref": "#/components/schemas/ExecutableCode" + "state": { + "description": "Output only. Processing state of the File.", + "enum": [ + "STATE_UNSPECIFIED", + "PROCESSING", + "ACTIVE", + "FAILED" + ], + "x-enum-descriptions": [ + "The default value. This value is used if the state is omitted.", + "File is being processed and cannot be used for inference yet.", + "File is processed and available for inference.", + "File failed processing." + ], + "readOnly": true, + "type": "string" }, - "functionCall": { - "description": "A predicted `FunctionCall` returned from the model that contains a string representing the `FunctionDeclaration.name` with the arguments and their values.", - "$ref": "#/components/schemas/FunctionCall" + "error": { + "readOnly": true, + "$ref": "#/components/schemas/Status", + "description": "Output only. Error status if File processing failed." }, - "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" + "downloadUri": { + "description": "Output only. The download uri of the `File`.", + "readOnly": true, + "type": "string" }, - "thoughtSignature": { + "name": { "type": "string", - "format": "byte", - "description": "Optional. An opaque signature for the thought so it can be reused in subsequent requests." + "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`" }, - "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" - } - } - }, - "AsyncBatchEmbedContentRequest": { - "description": "Request for an `AsyncBatchEmbedContent` operation.", - "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/EmbedContentBatch" - } - }, - "type": "object" - }, - "GenerateContentResponse": { - "description": "Response from the model supporting multiple candidate responses. Safety ratings and content filtering are reported for both prompt in `GenerateContentResponse.prompt_feedback` and for each candidate in `finish_reason` and in `safety_ratings`. The API: - Returns either all requested candidates or none of them - Returns no candidates at all only if there was something wrong with the prompt (check `prompt_feedback`) - Reports feedback on each candidate in `finish_reason` and `safety_ratings`.", - "properties": { - "modelStatus": { + "updateTime": { + "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` was last updated.", "readOnly": true, - "description": "Output only. The current model status of this model.", - "$ref": "#/components/schemas/ModelStatus" + "type": "string" }, - "candidates": { - "description": "Candidate responses from the model.", - "items": { - "$ref": "#/components/schemas/Candidate" - }, - "type": "array" + "source": { + "description": "Source of the File.", + "enum": [ + "SOURCE_UNSPECIFIED", + "UPLOADED", + "GENERATED", + "REGISTERED" + ], + "type": "string", + "x-enum-descriptions": [ + "Used if source is not specified.", + "Indicates the file is uploaded by the user.", + "Indicates the file is generated by Google.", + "Indicates the file is a registered, i.e. a Google Cloud Storage file." + ] }, - "usageMetadata": { + "createTime": { + "format": "google-datetime", + "description": "Output only. The timestamp of when the `File` was created.", "readOnly": true, - "description": "Output only. Metadata on the generation requests' token usage.", - "$ref": "#/components/schemas/UsageMetadata" + "type": "string" }, - "modelVersion": { - "description": "Output only. The model version used to generate the response.", + "expirationTime": { + "description": "Output only. The timestamp of when the `File` will be deleted. Only set if the `File` is scheduled to expire.", + "format": "google-datetime", "readOnly": true, "type": "string" }, - "responseId": { + "uri": { "readOnly": true, "type": "string", - "description": "Output only. response_id is used to identify each response." - }, - "promptFeedback": { - "description": "Returns the prompt's feedback related to the content filters.", - "$ref": "#/components/schemas/PromptFeedback" - } - }, - "type": "object" - }, - "AttributionSourceId": { - "type": "object", - "description": "Identifier for the source contributing to this attribution.", - "properties": { - "groundingPassage": { - "description": "Identifier for an inline passage.", - "$ref": "#/components/schemas/GroundingPassageId" - }, - "semanticRetrieverChunk": { - "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", - "$ref": "#/components/schemas/SemanticRetrieverChunk" + "description": "Output only. The uri of the `File`." } } }, - "ModalityTokenCount": { - "description": "Represents token counting info for a single modality.", + "TopCandidates": { + "type": "object", "properties": { - "tokenCount": { - "description": "Number of tokens.", - "type": "integer", - "format": "int32" - }, - "modality": { - "x-enum-descriptions": [ - "Unspecified modality.", - "Plain text.", - "Image.", - "Video.", - "Audio.", - "Document, e.g. PDF." - ], - "type": "string", - "enum": [ - "MODALITY_UNSPECIFIED", - "TEXT", - "IMAGE", - "VIDEO", - "AUDIO", - "DOCUMENT" - ], - "description": "The modality associated with this token count." + "candidates": { + "description": "Sorted by log probability in descending order.", + "type": "array", + "items": { + "$ref": "#/components/schemas/LogprobsResultCandidate" + } } }, - "type": "object" - }, - "WebSearch": { - "description": "Standard web search for grounding and related configurations.", - "properties": {}, - "type": "object" + "description": "Candidates with top log probabilities at each decoding step." }, - "CitationMetadata": { - "description": "A collection of source attributions for a piece of content.", + "ListCachedContentsResponse": { + "type": "object", "properties": { - "citationSources": { - "description": "Citations to sources for a specific response.", + "cachedContents": { + "type": "array", "items": { - "$ref": "#/components/schemas/CitationSource" + "$ref": "#/components/schemas/CachedContent" }, - "type": "array" + "description": "List of cached contents." + }, + "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 subsequent pages." } }, - "type": "object" + "description": "Response with CachedContents list." }, - "InlinedEmbedContentRequest": { - "description": "The request to be processed in the batch.", + "LogprobsResultCandidate": { + "type": "object", "properties": { - "request": { - "description": "Required. The request to be processed in the batch.", - "$ref": "#/components/schemas/EmbedContentRequest" + "tokenId": { + "format": "int32", + "description": "The candidate\u2019s token id value.", + "type": "integer" }, - "metadata": { - "type": "object", - "description": "Optional. The metadata to be associated with the request.", - "additionalProperties": { - "description": "Properties of the object." - } + "logProbability": { + "description": "The candidate's log probability.", + "format": "float", + "type": "number" + }, + "token": { + "description": "The candidate\u2019s token string value.", + "type": "string" } }, - "type": "object" + "description": "Candidate for the logprobs token and score." }, - "Dataset": { + "GoogleSearch": { + "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "type": "object", - "description": "Dataset for training or validation.", "properties": { - "examples": { - "description": "Optional. Inline examples with simple input/output text.", - "$ref": "#/components/schemas/TuningExamples" + "searchTypes": { + "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", + "$ref": "#/components/schemas/SearchTypes" + }, + "timeRangeFilter": { + "$ref": "#/components/schemas/Interval", + "description": "Optional. Filter search results to a specific time range. If customers set a start time, they must set an end time (and vice versa)." } } }, - "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.", + "TuningExample": { + "type": "object", "properties": { - "image": { - "description": "Optional. Grounding chunk from image search.", - "$ref": "#/components/schemas/Image" - }, - "retrievedContext": { - "description": "Optional. Grounding chunk from context retrieved by the file search tool.", - "$ref": "#/components/schemas/RetrievedContext" - }, - "web": { - "description": "Grounding chunk from the web.", - "$ref": "#/components/schemas/Web" + "textInput": { + "type": "string", + "description": "Optional. Text model input." }, - "maps": { - "description": "Optional. Grounding chunk from Google Maps.", - "$ref": "#/components/schemas/Maps" + "output": { + "type": "string", + "description": "Required. The expected model output." } }, - "type": "object" + "description": "A single example for tuning." }, - "BatchStats": { + "VideoMetadata": { "type": "object", - "description": "Stats about the batch.", + "deprecated": true, "properties": { - "successfulRequestCount": { - "readOnly": true, + "endOffset": { "type": "string", - "format": "int64", - "description": "Output only. The number of requests that were successfully processed." + "format": "google-duration", + "description": "Optional. The end offset of the video." }, - "requestCount": { - "description": "Output only. The number of requests in the batch.", - "readOnly": true, + "fps": { + "type": "number", + "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]." + }, + "startOffset": { "type": "string", - "format": "int64" + "format": "google-duration", + "description": "Optional. The start offset of the video." + } + }, + "description": "Deprecated: Use `GenerateContentRequest.processing_options` instead. Metadata describes the input video content." + }, + "CreateFileResponse": { + "type": "object", + "properties": { + "file": { + "$ref": "#/components/schemas/File", + "description": "Metadata for the created file." + } + }, + "description": "Response for `CreateFile`." + }, + "GroundingChunk": { + "type": "object", + "properties": { + "web": { + "$ref": "#/components/schemas/Web", + "description": "Grounding chunk from the web." + }, + "image": { + "description": "Optional. Grounding chunk from image search.", + "$ref": "#/components/schemas/Image" }, - "failedRequestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that failed to be processed." + "retrievedContext": { + "$ref": "#/components/schemas/RetrievedContext", + "description": "Optional. Grounding chunk from context retrieved by the file search tool." }, - "pendingRequestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that are still pending processing." + "maps": { + "$ref": "#/components/schemas/Maps", + "description": "Optional. Grounding chunk from Google Maps." } - } + }, + "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." }, - "Content": { + "Dataset": { "type": "object", - "description": "The base structured datatype containing multi-part content of a message. A `Content` includes a `role` field designating the producer of the `Content` and a `parts` field containing multi-part data that contains the content of the message turn.", "properties": { - "parts": { + "examples": { + "description": "Optional. Inline examples with simple input/output text.", + "$ref": "#/components/schemas/TuningExamples" + } + }, + "description": "Dataset for training or validation." + }, + "PlaceAnswerSources": { + "description": "Collection of sources that provide answers about the features of a given place in Google Maps. Each PlaceAnswerSources message corresponds to a specific place in Google Maps. The Google Maps tool used these sources in order to answer questions about features of the place (e.g: \"does Bar Foo have Wifi\" or \"is Foo Bar wheelchair accessible?\"). Currently we only support review snippets as sources.", + "type": "object", + "properties": { + "reviewSnippets": { "type": "array", - "description": "Ordered `Parts` that constitute a single message. Parts may have different MIME types.", "items": { - "$ref": "#/components/schemas/Part" - } - }, - "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" + "$ref": "#/components/schemas/ReviewSnippet" + }, + "description": "Snippets of reviews that are used to generate answers about the features of a given place in Google Maps." } } }, - "InlinedResponse": { + "WhiteSpaceConfig": { "type": "object", - "description": "The response to a single request in the batch.", "properties": { - "response": { - "description": "Output only. The response to the request.", - "$ref": "#/components/schemas/GenerateContentResponse", - "readOnly": true - }, - "error": { - "description": "Output only. The error encountered while processing the request.", - "$ref": "#/components/schemas/Status", - "readOnly": true + "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" }, - "metadata": { - "readOnly": true, - "type": "object", - "description": "Output only. The metadata associated with the request.", - "additionalProperties": { - "description": "Properties of the object." - } + "maxOverlapTokens": { + "type": "integer", + "description": "Maximum number of overlapping tokens between two adjacent chunks.", + "format": "int32" } - } + }, + "description": "Configuration for a white space chunking algorithm [white space delimited]." }, - "ThinkingConfig": { + "Candidate": { "type": "object", - "description": "Config for thinking features.", "properties": { - "thinkingLevel": { + "avgLogprobs": { + "readOnly": true, + "type": "number", + "format": "double", + "description": "Output only. Average log probability score of the candidate." + }, + "logprobsResult": { + "description": "Output only. Log-likelihood scores for the response tokens and top tokens", + "readOnly": true, + "$ref": "#/components/schemas/LogprobsResult" + }, + "finishReason": { + "readOnly": true, "type": "string", - "enum": [ - "THINKING_LEVEL_UNSPECIFIED", - "MINIMAL", - "LOW", - "MEDIUM", - "HIGH" - ], "x-enum-descriptions": [ - "Default value.", - "Little to no thinking.", - "Low thinking level.", - "Medium thinking level.", - "High thinking level." + "Default value. This value is unused.", + "Natural stop point of the model or provided stop sequence.", + "The maximum number of tokens as specified in the request was reached.", + "The response candidate content was flagged for safety reasons.", + "The response candidate content was flagged for recitation reasons.", + "The response candidate content was flagged for using an unsupported language.", + "Unknown reason.", + "Token generation stopped because the content contains forbidden terms.", + "Token generation stopped for potentially containing prohibited content.", + "Token generation stopped because the content potentially contains Sensitive Personally Identifiable Information (SPII).", + "The function call generated by the model is invalid.", + "Token generation stopped because generated images contain safety violations.", + "Image generation stopped because generated images has other prohibited content.", + "Image generation stopped because of other miscellaneous issue.", + "The model was expected to generate an image, but none was generated.", + "Image generation stopped due to recitation.", + "Model generated a tool call but no tools were enabled in the request.", + "Model called too many tools consecutively, thus the system exited execution.", + "Request has at least one thought signature missing.", + "Finished due to malformed response.", + "Request was filtered by an escalation rule." ], - "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error." + "description": "Optional. Output only. The reason why the model stopped generating tokens. If empty, the model has not stopped generating tokens.", + "enum": [ + "FINISH_REASON_UNSPECIFIED", + "STOP", + "MAX_TOKENS", + "SAFETY", + "RECITATION", + "LANGUAGE", + "OTHER", + "BLOCKLIST", + "PROHIBITED_CONTENT", + "SPII", + "MALFORMED_FUNCTION_CALL", + "IMAGE_SAFETY", + "IMAGE_PROHIBITED_CONTENT", + "IMAGE_OTHER", + "NO_IMAGE", + "IMAGE_RECITATION", + "UNEXPECTED_TOOL_CALL", + "TOO_MANY_TOOL_CALLS", + "MISSING_THOUGHT_SIGNATURE", + "MALFORMED_RESPONSE", + "ESCALATION" + ] }, - "includeThoughts": { - "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", - "type": "boolean" + "finishMessage": { + "readOnly": true, + "type": "string", + "description": "Optional. Output only. Details the reason why the model stopped generating tokens. This is populated only when `finish_reason` is set." }, - "thinkingBudget": { - "description": "The number of thoughts tokens that the model should generate.", + "groundingMetadata": { + "readOnly": true, + "$ref": "#/components/schemas/GroundingMetadata", + "description": "Output only. Grounding metadata for the candidate. This field is populated for `GenerateContent` calls." + }, + "index": { + "readOnly": true, "type": "integer", + "description": "Output only. Index of the candidate in the list of response candidates.", "format": "int32" - } - } - }, - "UrlContext": { - "description": "Tool to support URL context retrieval.", - "properties": {}, - "type": "object" - }, - "UploadToFileSearchStoreRequest": { - "description": "Request for `UploadToFileSearchStore`.", - "properties": { - "mimeType": { - "description": "Optional. MIME type of the data. If not provided, it will be inferred from the uploaded content.", - "type": "string" }, - "displayName": { - "description": "Optional. Display name of the created document.", - "type": "string" + "groundingAttributions": { + "description": "Output only. Attribution information for sources that contributed to a grounded answer. This field is populated for `GenerateAnswer` calls.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/GroundingAttribution" + } }, - "customMetadata": { - "description": "Custom metadata to be associated with the data.", + "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/CustomMetadata" - }, - "type": "array" + "$ref": "#/components/schemas/SafetyRating" + } }, - "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" + "citationMetadata": { + "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." + }, + "tokenCount": { + "format": "int32", + "description": "Output only. Token count for this candidate.", + "readOnly": true, + "type": "integer" + }, + "urlContextMetadata": { + "description": "Output only. Metadata related to url context retrieval tool.", + "readOnly": true, + "$ref": "#/components/schemas/UrlContextMetadata" + }, + "content": { + "description": "Output only. Generated content returned from the model.", + "readOnly": true, + "$ref": "#/components/schemas/Content" } }, - "type": "object" + "description": "A response candidate generated from the model." }, - "Document": { + "EmbedContentBatch": { "type": "object", - "description": "A `Document` is a collection of `Chunk`s.", "properties": { - "state": { - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", - "All `Chunks` of the `Document` is processed and available for querying.", - "Some `Chunks` of the `Document` failed processing." - ], - "type": "string", - "description": "Output only. Current state of the `Document`.", - "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "STATE_PENDING", - "STATE_ACTIVE", - "STATE_FAILED" - ] - }, - "mimeType": { - "readOnly": true, - "type": "string", - "description": "Output only. The mime type of the Document." + "model": { + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", + "type": "string" }, "updateTime": { - "description": "Output only. The Timestamp of when the `Document` was last updated.", + "format": "google-datetime", + "description": "Output only. The time at which the batch was last updated.", "readOnly": true, + "type": "string" + }, + "priority": { "type": "string", - "format": "google-datetime" + "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." }, - "createTime": { + "inputConfig": { + "description": "Required. Input configuration of the instances on which batch processing are performed.", + "$ref": "#/components/schemas/InputEmbedContentConfig" + }, + "endTime": { "readOnly": true, "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `Document` was created." + "description": "Output only. The time at which the batch processing completed.", + "format": "google-datetime" }, - "sizeBytes": { - "description": "Output only. The size of raw bytes ingested into the Document.", + "name": { "readOnly": true, "type": "string", - "format": "int64" - }, - "displayName": { - "description": "Optional. The human-readable display name for the `Document`. The display name must be no more than 512 characters in length, including spaces. Example: \"Semantic Retriever Documentation\"", - "type": "string" - }, - "customMetadata": { - "type": "array", - "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`.", - "items": { - "$ref": "#/components/schemas/CustomMetadata" - } + "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." + }, + "output": { + "description": "Output only. The output of the batch request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchOutput" }, - "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" - } - } - }, - "CachedContent": { - "description": "Content that has been preprocessed and can be used in subsequent request to GenerativeService. Cached content can be only used with model it was created for.", - "properties": { "displayName": { - "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", - "type": "string" + "type": "string", + "description": "Required. The user-defined name of this batch." }, "createTime": { - "readOnly": true, - "type": "string", + "description": "Output only. The time at which the batch was created.", "format": "google-datetime", - "description": "Output only. Creation time of the cache entry." + "readOnly": true, + "type": "string" }, - "updateTime": { - "description": "Output only. When the cache entry was last updated in UTC time.", + "state": { + "x-enum-descriptions": [ + "The batch state is unspecified.", + "The service is preparing to run the batch.", + "The batch is in progress.", + "The batch completed successfully.", + "The batch failed.", + "The batch has been cancelled.", + "The batch has expired." + ], "readOnly": true, "type": "string", - "format": "google-datetime" + "description": "Output only. The state of the batch.", + "enum": [ + "BATCH_STATE_UNSPECIFIED", + "BATCH_STATE_PENDING", + "BATCH_STATE_RUNNING", + "BATCH_STATE_SUCCEEDED", + "BATCH_STATE_FAILED", + "BATCH_STATE_CANCELLED", + "BATCH_STATE_EXPIRED" + ] }, - "systemInstruction": { - "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only.", - "$ref": "#/components/schemas/Content" + "batchStats": { + "description": "Output only. Stats about the batch.", + "readOnly": true, + "$ref": "#/components/schemas/EmbedContentBatchStats" + } + }, + "description": "A resource representing a batch of `EmbedContent` requests." + }, + "RetrievedContext": { + "type": "object", + "properties": { + "text": { + "description": "Optional. Text of the chunk.", + "type": "string" }, - "usageMetadata": { - "description": "Output only. Metadata on the usage of the cached content.", - "$ref": "#/components/schemas/CachedContentUsageMetadata", - "readOnly": true + "fileSearchStore": { + "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", + "type": "string" }, - "ttl": { + "title": { "type": "string", - "format": "google-duration", - "description": "Input only. New TTL for this resource, input only." + "description": "Optional. Title of the document." }, - "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.", + "mediaId": { "type": "string", - "format": "google-datetime" + "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}" }, - "name": { - "readOnly": true, + "uri": { "type": "string", - "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`" + "description": "Optional. URI reference of the semantic retrieval document." }, - "contents": { + "customMetadata": { + "description": "Optional. User-provided metadata about the retrieved context.", "type": "array", - "description": "Optional. Input only. Immutable. The content to cache.", "items": { - "$ref": "#/components/schemas/Content" + "$ref": "#/components/schemas/GroundingChunkCustomMetadata" } }, - "model": { - "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`", - "type": "string" - }, - "tools": { - "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response", - "items": { - "$ref": "#/components/schemas/Tool" - }, - "type": "array" - }, - "toolConfig": { - "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools.", - "$ref": "#/components/schemas/ToolConfig" + "pageNumber": { + "description": "Optional. Page number of the retrieved context, if applicable.", + "format": "int32", + "type": "integer" } }, - "type": "object" + "description": "Chunk from context retrieved by the file search tool." }, - "GroundingChunkStringList": { - "description": "A list of string values.", + "PrebuiltVoiceConfig": { + "type": "object", "properties": { - "values": { - "type": "array", - "description": "The string values of the list.", - "items": { - "type": "string" - } + "voiceName": { + "type": "string", + "description": "The name of the preset voice to use." } }, - "type": "object" + "description": "The configuration for the prebuilt speaker to use." + }, + "FileData": { + "description": "URI based data.", + "type": "object", + "properties": { + "fileUri": { + "description": "Required. URI.", + "type": "string" + }, + "mimeType": { + "description": "Optional. The IANA standard MIME type of the source data.", + "type": "string" + } + } }, "StringList": { - "description": "User provided string values assigned to a single metadata key.", + "type": "object", "properties": { "values": { "description": "The string values of the metadata to store.", + "type": "array", "items": { "type": "string" - }, - "type": "array" + } } }, - "type": "object" + "description": "User provided string values assigned to a single metadata key." }, - "RetrievedContext": { + "ImageResponseFormat": { + "description": "Configuration for image output format.", "type": "object", - "description": "Chunk from context retrieved by the file search tool.", "properties": { - "fileSearchStore": { - "description": "Optional. Name of the `FileSearchStore` containing the document. Example: `fileSearchStores/123`", - "type": "string" - }, - "mediaId": { - "description": "Optional. The media blob resource name for multimodal file search results. Format: fileSearchStores/{file_search_store_id}/media/{blob_id}", - "type": "string" + "mimeType": { + "x-enum-descriptions": [ + "Default value. This value is unused.", + "JPEG image format." + ], + "type": "string", + "description": "Optional. The MIME type of the image output.", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "IMAGE_JPEG" + ] }, - "title": { - "description": "Optional. Title of the document.", - "type": "string" + "delivery": { + "type": "string", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "Image data is returned inline in the response.", + "Image data is returned as a URI." + ], + "description": "Optional. The delivery mode for the image output.", + "enum": [ + "DELIVERY_UNSPECIFIED", + "INLINE", + "URI" + ] }, - "text": { - "description": "Optional. Text of the chunk.", + "aspectRatio": { + "description": "Optional. The aspect ratio for the image output.", + "enum": [ + "ASPECT_RATIO_UNSPECIFIED", + "ASPECT_RATIO_ONE_BY_ONE", + "ASPECT_RATIO_TWO_BY_THREE", + "ASPECT_RATIO_THREE_BY_TWO", + "ASPECT_RATIO_THREE_BY_FOUR", + "ASPECT_RATIO_FOUR_BY_THREE", + "ASPECT_RATIO_FOUR_BY_FIVE", + "ASPECT_RATIO_FIVE_BY_FOUR", + "ASPECT_RATIO_NINE_BY_SIXTEEN", + "ASPECT_RATIO_SIXTEEN_BY_NINE", + "ASPECT_RATIO_TWENTY_ONE_BY_NINE", + "ASPECT_RATIO_ONE_BY_EIGHT", + "ASPECT_RATIO_EIGHT_BY_ONE", + "ASPECT_RATIO_ONE_BY_FOUR", + "ASPECT_RATIO_FOUR_BY_ONE" + ], + "x-enum-descriptions": [ + "Default value. This value is unused.", + "1:1 aspect ratio.", + "2:3 aspect ratio.", + "3:2 aspect ratio.", + "3:4 aspect ratio.", + "4:3 aspect ratio.", + "4:5 aspect ratio.", + "5:4 aspect ratio.", + "9:16 aspect ratio.", + "16:9 aspect ratio.", + "21:9 aspect ratio.", + "1:8 aspect ratio.", + "8:1 aspect ratio.", + "1:4 aspect ratio.", + "4:1 aspect ratio." + ], "type": "string" }, - "customMetadata": { - "type": "array", - "description": "Optional. User-provided metadata about the retrieved context.", - "items": { - "$ref": "#/components/schemas/GroundingChunkCustomMetadata" - } - }, - "pageNumber": { - "description": "Optional. Page number of the retrieved context, if applicable.", - "type": "integer", - "format": "int32" - }, - "uri": { - "description": "Optional. URI reference of the semantic retrieval document.", - "type": "string" + "imageSize": { + "x-enum-descriptions": [ + "Default value. This value is unused.", + "512px image size.", + "1K image size.", + "2K image size.", + "4K image size." + ], + "type": "string", + "description": "Optional. The size of the image output.", + "enum": [ + "IMAGE_SIZE_UNSPECIFIED", + "IMAGE_SIZE_FIVE_TWELVE", + "IMAGE_SIZE_ONE_K", + "IMAGE_SIZE_TWO_K", + "IMAGE_SIZE_FOUR_K" + ] } } }, - "CustomMetadata": { - "description": "User provided metadata stored as key-value pairs.", + "ToolCall": { + "type": "object", "properties": { - "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" + "id": { + "type": "string", + "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`." }, - "numericValue": { - "description": "The numeric value of the metadata to store.", - "type": "number", - "format": "float" + "args": { + "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", + "additionalProperties": { + "description": "Properties of the object." + }, + "type": "object" }, - "stringValue": { - "description": "The string value of the metadata to store.", + "toolType": { + "description": "Required. The type of tool that was called.", + "enum": [ + "TOOL_TYPE_UNSPECIFIED", + "GOOGLE_SEARCH_WEB", + "GOOGLE_SEARCH_IMAGE", + "URL_CONTEXT", + "GOOGLE_MAPS", + "FILE_SEARCH" + ], + "x-enum-descriptions": [ + "Unspecified tool type.", + "Google search tool, maps to Tool.google_search.search_types.web_search.", + "Image search tool, maps to Tool.google_search.search_types.image_search.", + "URL context tool, maps to Tool.url_context.", + "Google maps tool, maps to Tool.google_maps.", + "File search tool, maps to Tool.file_search." + ], "type": "string" } }, - "type": "object" + "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`." }, - "UrlMetadata": { - "description": "Context of the a single url retrieval.", + "ToolResponse": { + "type": "object", "properties": { - "urlRetrievalStatus": { - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Url retrieval is successful.", - "Url retrieval is failed due to error.", - "Url retrieval is failed because the content is behind paywall.", - "Url retrieval is failed because the content is unsafe." - ], - "type": "string", + "response": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object." + }, + "description": "Optional. The tool response." + }, + "toolType": { + "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`.", "enum": [ - "URL_RETRIEVAL_STATUS_UNSPECIFIED", - "URL_RETRIEVAL_STATUS_SUCCESS", - "URL_RETRIEVAL_STATUS_ERROR", - "URL_RETRIEVAL_STATUS_PAYWALL", - "URL_RETRIEVAL_STATUS_UNSAFE" + "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": "Status of the url retrieval." - }, - "retrievedUrl": { - "description": "Retrieved url by the tool.", "type": "string" + }, + "id": { + "type": "string", + "description": "Optional. The identifier of the tool call this response is for." } }, - "type": "object" + "description": "The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`." }, - "UsageMetadata": { + "VideoFileMetadata": { "type": "object", - "description": "Metadata on the generation request's token usage.", "properties": { - "promptTokensDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" - }, - "cacheTokensDetails": { + "videoDuration": { + "type": "string", + "format": "google-duration", + "description": "Duration of the video." + } + }, + "description": "Metadata for a video `File`." + }, + "Permission": { + "type": "object", + "properties": { + "name": { "readOnly": true, - "type": "array", - "description": "Output only. List of modalities of the cached content in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } - }, - "candidatesTokenCount": { - "type": "integer", - "format": "int32", - "description": "Total number of tokens across all the generated response candidates." + "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." }, - "serviceTier": { + "granteeType": { + "description": "Optional. Immutable. The type of the grantee.", + "enum": [ + "GRANTEE_TYPE_UNSPECIFIED", + "USER", + "GROUP", + "EVERYONE" + ], "x-enum-descriptions": [ - "Default service tier, which is standard.", - "Standard service tier.", - "Flex service tier.", - "Priority service tier." + "The default value. This value is unused.", + "Represents a user. When set, you must provide email_address for the user.", + "Represents a group. When set, you must provide email_address for the group.", + "Represents access to everyone. No extra information is required." ], + "type": "string" + }, + "emailAddress": { "type": "string", - "description": "Output only. Service tier of the request.", - "readOnly": true, + "description": "Optional. Immutable. The email address of the user of group which this permission refers. Field is not set when permission's grantee type is EVERYONE." + }, + "role": { + "description": "Required. The role granted by this permission.", "enum": [ - "unspecified", - "standard", - "flex", - "priority" + "ROLE_UNSPECIFIED", + "OWNER", + "WRITER", + "READER" + ], + "type": "string", + "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." ] - }, - "thoughtsTokenCount": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. Number of tokens of thoughts for thinking models." - }, - "promptTokenCount": { - "type": "integer", - "format": "int32", - "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content." - }, - "candidatesTokensDetails": { - "description": "Output only. List of modalities that were returned in the response.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" - }, - "toolUsePromptTokenCount": { - "readOnly": true, - "type": "integer", - "format": "int32", - "description": "Output only. Number of tokens present in tool-use prompt(s)." - }, - "toolUsePromptTokensDetails": { - "description": "Output only. List of modalities that were processed for tool-use request inputs.", + } + }, + "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" + }, + "ListTunedModelsResponse": { + "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "type": "object", + "properties": { + "tunedModels": { + "type": "array", "items": { - "$ref": "#/components/schemas/ModalityTokenCount" + "$ref": "#/components/schemas/TunedModel" }, - "readOnly": true, - "type": "array" - }, - "totalTokenCount": { - "type": "integer", - "format": "int32", - "description": "Total token count for the generation request (prompt + thoughts + response candidates)." - }, - "cachedContentTokenCount": { - "type": "integer", - "format": "int32", - "description": "Number of tokens in the cached part of the prompt (the cached content)" - }, - "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 + "description": "The returned Models." }, - "responseTokensDetails": { - "description": "Output only. List of modalities returned in the response with per-modality token counts. Used by Gemini 3.1+ Live API models instead of candidatesTokensDetails.", - "type": "array", - "readOnly": true, - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - } + "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" } } }, - "TunedModel": { - "description": "A fine-tuned model created using ModelService.CreateTunedModel.", + "Maps": { + "description": "A grounding chunk from Google Maps. A Maps chunk corresponds to a single place.", + "type": "object", "properties": { - "createTime": { - "description": "Output only. The timestamp when this model was created.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "displayName": { - "description": "Optional. The name to display for this model in user interfaces. The display name must be up to 40 characters including spaces.", + "title": { + "description": "Title of the place.", "type": "string" }, - "topK": { - "type": "integer", - "format": "int32", - "description": "Optional. For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. This value specifies default to be the one used by the base model while creating the model." - }, - "state": { - "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "CREATING", - "ACTIVE", - "FAILED" - ], - "description": "Output only. The state of the tuned model.", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "The model is being created.", - "The model is ready to be used.", - "The model failed to be created." - ], + "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" }, - "description": { - "description": "Optional. A short description of this model.", + "text": { + "description": "Text description of the place answer.", "type": "string" }, - "tunedModelSource": { - "description": "Optional. TunedModel to use as the starting point for training the new model.", - "$ref": "#/components/schemas/TunedModelSource" - }, - "updateTime": { - "readOnly": true, + "uri": { "type": "string", - "format": "google-datetime", - "description": "Output only. The timestamp when this model was updated." - }, - "topP": { - "description": "Optional. For Nucleus sampling. Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be the one used by the base model while creating the model.", - "type": "number", - "format": "float" + "description": "URI reference of the place." }, - "readerProjectNumbers": { - "type": "array", - "description": "Optional. List of project numbers that have read access to the tuned model.", - "items": { - "type": "string", - "format": "int64" - } + "placeAnswerSources": { + "$ref": "#/components/schemas/PlaceAnswerSources", + "description": "Sources that provide answers about the features of a given place in Google Maps." + } + } + }, + "TuningTask": { + "description": "Tuning tasks that create tuned models.", + "type": "object", + "properties": { + "trainingData": { + "description": "Required. Input only. Immutable. The model training data.", + "$ref": "#/components/schemas/Dataset" }, - "baseModel": { - "description": "Immutable. The name of the `Model` to tune. Example: `models/gemini-1.5-flash-001`", - "type": "string" + "completeTime": { + "readOnly": true, + "type": "string", + "description": "Output only. The timestamp when tuning this model completed.", + "format": "google-datetime" }, - "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" + "hyperparameters": { + "description": "Immutable. Hyperparameters controlling the tuning process. If not provided, default values will be used.", + "$ref": "#/components/schemas/Hyperparameters" }, - "name": { - "description": "Output only. The tuned model name. A unique name will be generated on create. Example: `tunedModels/az2mb0bpw6i` If display_name is set on create, the id portion of the name will be set by concatenating the words of the display_name with hyphens and adding a random portion for uniqueness. Example: * display_name = `Sentence Translator` * name = `tunedModels/sentence-translator-u3b7m`", + "startTime": { "readOnly": true, - "type": "string" + "type": "string", + "description": "Output only. The timestamp when tuning this model started.", + "format": "google-datetime" }, - "tuningTask": { - "description": "Required. The tuning task that creates the tuned model.", - "$ref": "#/components/schemas/TuningTask" + "snapshots": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/TuningSnapshot" + }, + "description": "Output only. Metrics collected during tuning." } - }, - "type": "object" + } }, - "TuningExamples": { - "description": "A set of tuning examples. Can be training or validation data.", + "UrlContextMetadata": { + "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.", + "urlMetadata": { + "type": "array", "items": { - "$ref": "#/components/schemas/TuningExample" + "$ref": "#/components/schemas/UrlMetadata" }, - "type": "array" + "description": "List of url context." } }, - "type": "object" + "description": "Metadata related to url context retrieval tool." }, - "Web": { + "WebSearch": { + "description": "Standard web search for grounding and related configurations.", + "type": "object", + "properties": {} + }, + "BatchEmbedContentsResponse": { "type": "object", - "description": "Chunk from the web.", "properties": { - "uri": { + "embeddings": { "readOnly": true, - "type": "string", - "description": "Output only. URI reference of the chunk." + "type": "array", + "items": { + "$ref": "#/components/schemas/ContentEmbedding" + }, + "description": "Output only. The embeddings for each request, in the same order as provided in the batch request." }, - "title": { - "description": "Output only. Title of the chunk.", + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" + } + }, + "description": "The response to a `BatchEmbedContentsRequest`." + }, + "FunctionResponseBlob": { + "description": "Raw media bytes for function response. Text should not be sent as raw bytes, use the 'FunctionResponse.response' field.", + "type": "object", + "properties": { + "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": { + "format": "byte", + "description": "Raw bytes for media formats.", "type": "string" } } }, - "SearchTypes": { - "description": "Different types of search that can be enabled on the GoogleSearch tool.", + "GoogleSearchRetrieval": { + "description": "Tool to retrieve public web data for grounding, powered by Google.", + "type": "object", "properties": { - "imageSearch": { - "description": "Optional. Enables image search. Image bytes are returned.", - "$ref": "#/components/schemas/ImageSearch" - }, - "webSearch": { - "description": "Optional. Enables web search. Only text results are returned.", - "$ref": "#/components/schemas/WebSearch" + "dynamicRetrievalConfig": { + "description": "Specifies the dynamic retrieval configuration for the given source.", + "$ref": "#/components/schemas/DynamicRetrievalConfig" } - }, - "type": "object" + } }, - "ReviewSnippet": { - "description": "Encapsulates a snippet of a user review that answers a question about the features of a specific place in Google Maps.", + "ImageSearch": { + "description": "Image search for grounding and related configurations.", + "type": "object", + "properties": {} + }, + "ModelStatus": { + "description": "The status of the underlying model. This is used to indicate the stage of the underlying model and the retirement time if applicable.", + "type": "object", "properties": { - "title": { - "description": "Title of the review.", - "type": "string" + "modelStage": { + "description": "The stage of the underlying model.", + "enum": [ + "MODEL_STAGE_UNSPECIFIED", + "UNSTABLE_EXPERIMENTAL", + "EXPERIMENTAL", + "PREVIEW", + "STABLE", + "LEGACY", + "DEPRECATED", + "RETIRED" + ], + "enumDeprecated": [ + false, + true, + false, + false, + false, + false, + true, + false + ], + "type": "string", + "x-enum-descriptions": [ + "Unspecified model stage.", + "The underlying model is subject to lots of tunings.", + "Models in this stage are for experimental purposes only.", + "Models in this stage are more mature than experimental models.", + "Models in this stage are considered stable and ready for production use.", + "If the model is on this stage, it means that this model is on the path to deprecation in near future. Only existing customers can use this model.", + "Models in this stage are deprecated. These models cannot be used.", + "Models in this stage are retired. These models cannot be used." + ] }, - "googleMapsUri": { - "description": "A link that corresponds to the user review on Google Maps.", + "message": { + "description": "A message explaining the model status.", "type": "string" }, - "reviewId": { - "description": "The ID of the review snippet.", + "retirementTime": { + "format": "google-datetime", + "description": "The time at which the model will be retired.", "type": "string" } - }, - "type": "object" + } }, - "FunctionResponse": { + "GroundingPassageId": { + "description": "Identifier for a part within a `GroundingPassage`.", "type": "object", - "description": "The result output from a `FunctionCall` that contains a string representing the `FunctionDeclaration.name` and a structured JSON object containing any output from the function is used as context to the model. This should contain the result of a`FunctionCall` made based on model prediction.", "properties": { - "willContinue": { - "description": "Optional. Signals that function call continues, and more responses will be returned, turning the function call into a generator. Is only applicable to NON_BLOCKING function calls, is ignored otherwise. If set to false, future responses will not be considered. It is allowed to return empty `response` with `will_continue=False` to signal that the function call is finished. This may still trigger the model generation. To avoid triggering the generation and finish the function call, additionally set `scheduling` to `SILENT`.", - "type": "boolean" - }, - "scheduling": { - "description": "Optional. Specifies how the response should be scheduled in the conversation. Only applicable to NON_BLOCKING function calls, is ignored otherwise. Defaults to WHEN_IDLE.", + "passageId": { + "readOnly": true, "type": "string", - "enum": [ - "SCHEDULING_UNSPECIFIED", - "SILENT", - "WHEN_IDLE", - "INTERRUPT" - ], - "x-enum-descriptions": [ - "This value is unused.", - "Only add the result to the conversation context, do not interrupt or trigger generation.", - "Add the result to the conversation context, and prompt to generate output without interrupting ongoing generation.", - "Add the result to the conversation context, interrupt ongoing generation and prompt to generate output." - ] + "description": "Output only. ID of the passage matching the `GenerateAnswerRequest`'s `GroundingPassage.id`." }, - "id": { - "description": "Optional. The identifier of the function call this response is for. Populated by the client to match the corresponding function call `id`.", - "type": "string" + "partIndex": { + "format": "int32", + "description": "Output only. Index of the part within the `GenerateAnswerRequest`'s `GroundingPassage.content`.", + "readOnly": true, + "type": "integer" + } + } + }, + "ListGeneratedFilesResponse": { + "description": "Response for `ListGeneratedFiles`.", + "type": "object", + "properties": { + "generatedFiles": { + "type": "array", + "items": { + "$ref": "#/components/schemas/GeneratedFile" + }, + "description": "The list of `GeneratedFile`s." }, - "response": { + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListGeneratedFiles` call." + } + } + }, + "InlinedRequest": { + "type": "object", + "properties": { + "request": { + "description": "Required. The request to be processed in the batch.", + "$ref": "#/components/schemas/GenerateContentRequest" + }, + "metadata": { "type": "object", - "description": "Required. The function response in JSON object format. Callers can use any keys of their choice that fit the function's syntax to return the function output, e.g. \"output\", \"result\", etc. In particular, if the function call failed to execute, the response can have an \"error\" key to return error details to the model. Multimedia can be included by using a subobject containing a single \"$ref\" key whose value is the `inline_data.display_name` of a `FunctionResponsePart` holding the multimedia. See https://ai.google.dev/gemini-api/docs/function-calling#multimodal.", "additionalProperties": { "description": "Properties of the object." - } - }, - "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" + }, + "description": "Optional. The metadata to be associated with the request." + } + }, + "description": "The request to be processed in the batch." + }, + "TextResponseFormat": { + "description": "Configuration for text output format.", + "type": "object", + "properties": { + "mimeType": { + "description": "Optional. The MIME type of the text output.", + "enum": [ + "MIME_TYPE_UNSPECIFIED", + "APPLICATION_JSON", + "TEXT_PLAIN" + ], + "type": "string", + "x-enum-descriptions": [ + "Default value. This value is unused.", + "JSON output format.", + "Plain text output format." + ] }, - "parts": { - "type": "array", - "description": "Optional. Ordered `Parts` that constitute a function response. Parts may have different IANA MIME types.", - "items": { - "$ref": "#/components/schemas/FunctionResponsePart" - } + "schema": { + "description": "Optional. The JSON schema that the output should conform to. Only applicable when mime_type is APPLICATION_JSON." } } }, "RetrievalConfig": { "type": "object", - "description": "Retrieval config.", "properties": { + "latLng": { + "$ref": "#/components/schemas/LatLng", + "description": "Optional. The location of the user." + }, "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" + "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." + }, + "EmbedContentBatchOutput": { + "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", + "type": "object", + "properties": { + "responsesFile": { + "readOnly": true, + "type": "string", + "description": "Output only. The file ID of the file containing the responses. The file will be a JSONL file with a single response per line. The responses will be `EmbedContentResponse` messages formatted as JSON. The responses will be written in the same order as the input requests." }, - "latLng": { - "description": "Optional. The location of the user.", - "$ref": "#/components/schemas/LatLng" + "inlinedResponses": { + "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", + "readOnly": true, + "$ref": "#/components/schemas/InlinedEmbedContentResponses" + } + } + }, + "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); }" + }, + "ListFilesResponse": { + "description": "Response for `ListFiles`.", + "type": "object", + "properties": { + "nextPageToken": { + "type": "string", + "description": "A token that can be sent as a `page_token` into a subsequent `ListFiles` call." + }, + "files": { + "type": "array", + "items": { + "$ref": "#/components/schemas/File" + }, + "description": "The list of `File`s." } } }, - "BatchEmbedContentsRequest": { + "MultiSpeakerVoiceConfig": { "type": "object", - "description": "Batch request to get embeddings from the model for a list of prompts.", "properties": { - "requests": { + "speakerVoiceConfigs": { + "description": "Required. All the enabled speaker voices.", "type": "array", - "description": "Required. Embed requests for the batch. The model in each of these requests must match the model specified `BatchEmbedContentsRequest.model`.", "items": { - "$ref": "#/components/schemas/EmbedContentRequest" + "$ref": "#/components/schemas/SpeakerVoiceConfig" } } - } + }, + "description": "The configuration for the multi-speaker setup." }, - "CitationSource": { + "FileSearch": { + "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", "type": "object", - "description": "A citation to a source for a portion of a specific response.", "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" - }, - "endIndex": { - "description": "Optional. End of the attributed segment, exclusive.", - "type": "integer", - "format": "int32" + "fileSearchStoreNames": { + "type": "array", + "items": { + "type": "string" + }, + "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`" }, - "uri": { - "description": "Optional. URI that is attributed as a source for a portion of the text.", + "metadataFilter": { + "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", "type": "string" }, - "license": { - "description": "Optional. License for the GitHub project that is attributed as a source for segment. License info is required for code citations.", - "type": "string" + "topK": { + "description": "Optional. The number of semantic retrieval chunks to retrieve.", + "format": "int32", + "type": "integer" } } }, - "EmbeddingUsageMetadata": { - "description": "Metadata on the usage of the embedding request.", + "TunedModelSource": { + "description": "Tuned model as a source for training a new model.", + "type": "object", "properties": { - "promptTokenDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" + "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" }, - "promptTokenCount": { - "description": "Output only. Number of tokens in the prompt.", + "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": "integer", - "format": "int32" - } - }, - "type": "object" - }, - "VoiceConfig": { - "description": "The configuration for the voice to use.", - "properties": { - "prebuiltVoiceConfig": { - "description": "The configuration for the prebuilt voice to use.", - "$ref": "#/components/schemas/PrebuiltVoiceConfig" - } - }, - "type": "object" - }, - "SpeechConfig": { - "description": "Config for speech generation and transcription.", - "properties": { - "voiceConfig": { - "description": "The configuration in case of single-voice output.", - "$ref": "#/components/schemas/VoiceConfig" - }, - "multiSpeakerVoiceConfig": { - "description": "Optional. The configuration for the multi-speaker setup. It is mutually exclusive with the voice_config field.", - "$ref": "#/components/schemas/MultiSpeakerVoiceConfig" - }, - "languageCode": { - "description": "Optional. The IETF [BCP-47](https://www.rfc-editor.org/rfc/bcp/bcp47.txt) language code that the user configured the app to use. Used for speech recognition and synthesis. Valid values are: `de-DE`, `en-AU`, `en-GB`, `en-IN`, `en-US`, `es-US`, `fr-FR`, `hi-IN`, `pt-BR`, `ar-XA`, `es-ES`, `fr-CA`, `id-ID`, `it-IT`, `ja-JP`, `tr-TR`, `vi-VN`, `bn-IN`, `gu-IN`, `kn-IN`, `ml-IN`, `mr-IN`, `ta-IN`, `te-IN`, `nl-NL`, `ko-KR`, `cmn-CN`, `pl-PL`, `ru-RU`, and `th-TH`.", "type": "string" } - }, - "type": "object" + } }, - "GenerateContentBatch": { - "description": "A resource representing a batch of `GenerateContent` requests.", + "Document": { + "description": "A `Document` is a collection of `Chunk`s.", + "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" + }, "createTime": { - "description": "Output only. The time at which the batch was created.", + "description": "Output only. The Timestamp of when the `Document` was created.", + "format": "google-datetime", "readOnly": true, - "type": "string", - "format": "google-datetime" + "type": "string" }, "updateTime": { "readOnly": true, "type": "string", "format": "google-datetime", - "description": "Output only. The time at which the batch was last updated." - }, - "displayName": { - "description": "Required. The user-defined name of this batch.", - "type": "string" - }, - "batchStats": { - "readOnly": true, - "description": "Output only. Stats about the batch.", - "$ref": "#/components/schemas/BatchStats" + "description": "Output only. The Timestamp of when the `Document` was last updated." }, "state": { - "type": "string", "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." + "The default value. This value is used if the state is omitted.", + "Some `Chunks` of the `Document` are being processed (embedding and vector storage).", + "All `Chunks` of the `Document` is processed and available for querying.", + "Some `Chunks` of the `Document` failed processing." ], - "description": "Output only. The state of the batch.", "readOnly": true, + "type": "string", + "description": "Output only. Current state of the `Document`.", "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" + "STATE_UNSPECIFIED", + "STATE_PENDING", + "STATE_ACTIVE", + "STATE_FAILED" ] }, - "endTime": { - "description": "Output only. The time at which the batch processing completed.", + "sizeBytes": { "readOnly": true, "type": "string", - "format": "google-datetime" + "format": "int64", + "description": "Output only. The size of raw bytes ingested into the Document." }, - "output": { + "mimeType": { "readOnly": true, - "description": "Output only. The output of the batch request.", - "$ref": "#/components/schemas/GenerateContentBatchOutput" - }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "type": "string", + "description": "Output only. The mime type of the Document." }, "name": { - "readOnly": true, "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." - }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputConfig" + "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`" }, - "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." - } - }, - "type": "object" - }, - "PrebuiltVoiceConfig": { - "description": "The configuration for the prebuilt speaker to use.", - "properties": { - "voiceName": { - "description": "The name of the preset voice to use.", - "type": "string" + "customMetadata": { + "type": "array", + "items": { + "$ref": "#/components/schemas/CustomMetadata" + }, + "description": "Optional. User provided custom metadata stored as key-value pairs used for querying. A `Document` can have a maximum of 20 `CustomMetadata`." } - }, - "type": "object" + } }, - "CreateFileRequest": { + "ModalityTokenCount": { + "description": "Represents token counting info for a single modality.", "type": "object", - "description": "Request for `CreateFile`.", "properties": { - "file": { - "description": "Optional. Metadata for the file to create.", - "$ref": "#/components/schemas/File" + "tokenCount": { + "type": "integer", + "description": "Number of tokens.", + "format": "int32" + }, + "modality": { + "description": "The modality associated with this token count.", + "enum": [ + "MODALITY_UNSPECIFIED", + "TEXT", + "IMAGE", + "VIDEO", + "AUDIO", + "DOCUMENT" + ], + "x-enum-descriptions": [ + "Unspecified modality.", + "Plain text.", + "Image.", + "Video.", + "Audio.", + "Document, e.g. PDF." + ], + "type": "string" } } }, "RegisterFilesResponse": { - "description": "Response for `RegisterFiles`.", + "type": "object", "properties": { "files": { "type": "array", - "description": "The registered files to be used when calling GenerateContent.", "items": { "$ref": "#/components/schemas/File" - } + }, + "description": "The registered files to be used when calling GenerateContent." } }, - "type": "object" + "description": "Response for `RegisterFiles`." }, - "Image": { + "ListCorporaResponse": { + "description": "Response from `ListCorpora` containing a paginated list of `Corpora`. The results are sorted by ascending `corpus.create_time`.", "type": "object", - "description": "Chunk from image search.", "properties": { - "sourceUri": { - "description": "The web page URI for attribution.", - "type": "string" - }, - "title": { - "description": "The title of the web page that the image is from.", - "type": "string" - }, - "imageUri": { - "description": "The image asset URL.", + "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" }, - "domain": { - "description": "The root domain of the web page that the image is from, e.g. \"example.com\".", - "type": "string" + "corpora": { + "description": "The returned corpora.", + "type": "array", + "items": { + "$ref": "#/components/schemas/Corpus" + } } } }, - "EmbedContentBatchOutput": { + "ListPermissionsResponse": { "type": "object", - "description": "The output of a batch request. This is returned in the `AsyncBatchEmbedContentResponse` or the `EmbedContentBatch.output` field.", - "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.", - "readOnly": true, - "type": "string" - }, - "inlinedResponses": { - "readOnly": true, - "description": "Output only. The responses to the requests in the batch. Returned when the batch was built using inlined requests. The responses will be in the same order as the input requests.", - "$ref": "#/components/schemas/InlinedEmbedContentResponses" - } - } - }, - "ListFileSearchStoresResponse": { - "description": "Response from `ListFileSearchStores` containing a paginated list of `FileSearchStores`. The results are sorted by ascending `file_search_store.create_time`.", "properties": { - "fileSearchStores": { - "description": "The returned rag_stores.", + "permissions": { + "type": "array", "items": { - "$ref": "#/components/schemas/FileSearchStore" + "$ref": "#/components/schemas/Permission" }, - "type": "array" + "description": "Returned permissions." }, "nextPageToken": { "description": "A token, which can be sent as `page_token` to retrieve the next page. If this field is omitted, there are no more pages.", - "type": "string" - } - }, - "type": "object" - }, - "BatchGenerateContentRequest": { - "description": "Request for a `BatchGenerateContent` operation.", - "properties": { - "batch": { - "description": "Required. The batch to create.", - "$ref": "#/components/schemas/GenerateContentBatch" + "type": "string" } }, - "type": "object" + "description": "Response from `ListPermissions` containing a paginated list of permissions." }, - "LogprobsResultCandidate": { + "ThinkingConfig": { "type": "object", - "description": "Candidate for the logprobs token and score.", "properties": { - "token": { - "description": "The candidate\u2019s token string value.", - "type": "string" + "includeThoughts": { + "description": "Indicates whether to include thoughts in the response. If true, thoughts are returned only when available.", + "type": "boolean" }, - "tokenId": { - "description": "The candidate\u2019s token id value.", + "thinkingBudget": { "type": "integer", + "description": "The number of thoughts tokens that the model should generate.", "format": "int32" }, - "logProbability": { - "description": "The candidate's log probability.", - "type": "number", - "format": "float" + "thinkingLevel": { + "description": "Optional. Controls the maximum depth of the model's internal reasoning process before it produces a response. The default value is model-dependent. Refer to the [Thinking levels guide](https://ai.google.dev/gemini-api/docs/thinking#thinking-levels) for more details. Recommended for Gemini 3 or later models. Use with earlier models results in an error.", + "enum": [ + "THINKING_LEVEL_UNSPECIFIED", + "MINIMAL", + "LOW", + "MEDIUM", + "HIGH" + ], + "x-enum-descriptions": [ + "Default value.", + "Little to no thinking.", + "Low thinking level.", + "Medium thinking level.", + "High thinking level." + ], + "type": "string" } - } - }, - "TransferOwnershipResponse": { - "description": "Response from `TransferOwnership`.", - "properties": {}, - "type": "object" + }, + "description": "Config for thinking features." }, - "InlinedEmbedContentResponse": { + "AttributionSourceId": { "type": "object", - "description": "The response to a single request in the batch.", "properties": { - "error": { - "description": "Output only. The error encountered while processing the request.", - "$ref": "#/components/schemas/Status", - "readOnly": true - }, - "metadata": { - "description": "Output only. The metadata associated with the request.", - "additionalProperties": { - "description": "Properties of the object." - }, - "readOnly": true, - "type": "object" + "groundingPassage": { + "$ref": "#/components/schemas/GroundingPassageId", + "description": "Identifier for an inline passage." }, - "response": { - "readOnly": true, - "description": "Output only. The response to the request.", - "$ref": "#/components/schemas/EmbedContentResponse" + "semanticRetrieverChunk": { + "description": "Identifier for a `Chunk` fetched via Semantic Retriever.", + "$ref": "#/components/schemas/SemanticRetrieverChunk" } - } + }, + "description": "Identifier for the source contributing to this attribution." }, - "LatLng": { + "Tool": { + "description": "Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. Next ID: 16", "type": "object", - "description": "An object that represents a latitude/longitude pair. This is expressed as a pair of doubles to represent degrees latitude and degrees longitude. Unless specified otherwise, this object must conform to the WGS84 standard. Values must be within normalized ranges.", "properties": { - "longitude": { - "description": "The longitude in degrees. It must be in the range [-180.0, +180.0].", - "type": "number", - "format": "double" + "googleMaps": { + "description": "Optional. Tool that allows grounding the model's response with geospatial context related to the user's query.", + "$ref": "#/components/schemas/GoogleMaps" }, - "latitude": { - "type": "number", - "format": "double", - "description": "The latitude in degrees. It must be in the range [-90.0, +90.0]." - } - } - }, - "ImageResponseFormat": { - "type": "object", - "description": "Configuration for image output format.", - "properties": { - "delivery": { - "description": "Optional. The delivery mode for the image output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Image data is returned inline in the response.", - "Image data is returned as a URI." - ], - "type": "string", - "enum": [ - "DELIVERY_UNSPECIFIED", - "INLINE", - "URI" - ] + "googleSearchRetrieval": { + "description": "Optional. Retrieval tool that is powered by Google search.", + "$ref": "#/components/schemas/GoogleSearchRetrieval" }, - "mimeType": { - "description": "Optional. The MIME type of the image output.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "JPEG image format." - ], - "type": "string", - "enum": [ - "MIME_TYPE_UNSPECIFIED", - "IMAGE_JPEG" - ] + "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." }, - "aspectRatio": { - "description": "Optional. The aspect ratio for the image output.", - "type": "string", - "enum": [ - "ASPECT_RATIO_UNSPECIFIED", - "ASPECT_RATIO_ONE_BY_ONE", - "ASPECT_RATIO_TWO_BY_THREE", - "ASPECT_RATIO_THREE_BY_TWO", - "ASPECT_RATIO_THREE_BY_FOUR", - "ASPECT_RATIO_FOUR_BY_THREE", - "ASPECT_RATIO_FOUR_BY_FIVE", - "ASPECT_RATIO_FIVE_BY_FOUR", - "ASPECT_RATIO_NINE_BY_SIXTEEN", - "ASPECT_RATIO_SIXTEEN_BY_NINE", - "ASPECT_RATIO_TWENTY_ONE_BY_NINE", - "ASPECT_RATIO_ONE_BY_EIGHT", - "ASPECT_RATIO_EIGHT_BY_ONE", - "ASPECT_RATIO_ONE_BY_FOUR", - "ASPECT_RATIO_FOUR_BY_ONE" - ], - "x-enum-descriptions": [ - "Default value. This value is unused.", - "1:1 aspect ratio.", - "2:3 aspect ratio.", - "3:2 aspect ratio.", - "3:4 aspect ratio.", - "4:3 aspect ratio.", - "4:5 aspect ratio.", - "5:4 aspect ratio.", - "9:16 aspect ratio.", - "16:9 aspect ratio.", - "21:9 aspect ratio.", - "1:8 aspect ratio.", - "8:1 aspect ratio.", - "1:4 aspect ratio.", - "4:1 aspect ratio." - ] + "functionDeclarations": { + "type": "array", + "items": { + "$ref": "#/components/schemas/FunctionDeclaration" + }, + "description": "Optional. A list of `FunctionDeclarations` available to the model that can be used for function calling. The model or system does not execute the function. Instead the defined function may be returned as a FunctionCall with arguments to the client side for execution. The model may decide to call a subset of these functions by populating FunctionCall in the response. The next conversation turn may contain a FunctionResponse with the Content.role \"function\" generation context for the next model turn." }, - "imageSize": { - "type": "string", - "enum": [ - "IMAGE_SIZE_UNSPECIFIED", - "IMAGE_SIZE_FIVE_TWELVE", - "IMAGE_SIZE_ONE_K", - "IMAGE_SIZE_TWO_K", - "IMAGE_SIZE_FOUR_K" - ], - "x-enum-descriptions": [ - "Default value. This value is unused.", - "512px image size.", - "1K image size.", - "2K image size.", - "4K image size." - ], - "description": "Optional. The size of the image output." + "codeExecution": { + "description": "Optional. Enables the model to execute code as part of generation.", + "$ref": "#/components/schemas/CodeExecution" + }, + "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" + }, + "urlContext": { + "description": "Optional. Tool to support URL context retrieval.", + "$ref": "#/components/schemas/UrlContext" + }, + "mcpServers": { + "description": "Optional. MCP Servers to connect to.", + "type": "array", + "items": { + "$ref": "#/components/schemas/McpServer" + } } } - }, - "SafetyRating": { - "description": "Safety rating for a piece of content. The safety rating contains the category of harm and the harm probability level in that category for a piece of content. Content is classified for safety across a number of harm categories and the probability of the harm classification is included here.", - "properties": { - "category": { - "description": "Required. The category for this rating.", - "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." - ], - "enum": [ - "HARM_CATEGORY_UNSPECIFIED", - "HARM_CATEGORY_DEROGATORY", - "HARM_CATEGORY_TOXICITY", - "HARM_CATEGORY_VIOLENCE", - "HARM_CATEGORY_SEXUAL", - "HARM_CATEGORY_MEDICAL", - "HARM_CATEGORY_DANGEROUS", - "HARM_CATEGORY_HARASSMENT", - "HARM_CATEGORY_HATE_SPEECH", - "HARM_CATEGORY_SEXUALLY_EXPLICIT", - "HARM_CATEGORY_DANGEROUS_CONTENT", - "HARM_CATEGORY_CIVIC_INTEGRITY" - ], - "enumDeprecated": [ - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - false, - true - ] - }, - "probability": { - "x-enum-descriptions": [ - "Probability is unspecified.", - "Content has a negligible chance of being unsafe.", - "Content has a low chance of being unsafe.", - "Content has a medium chance of being unsafe.", - "Content has a high chance of being unsafe." - ], - "type": "string", - "enum": [ - "HARM_PROBABILITY_UNSPECIFIED", - "NEGLIGIBLE", - "LOW", - "MEDIUM", - "HIGH" - ], - "description": "Required. The probability of harm for this content." + }, + "CountTokensRequest": { + "type": "object", + "properties": { + "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." }, - "blocked": { - "description": "Was this content blocked because of this rating?", - "type": "boolean" + "generateContentRequest": { + "description": "Optional. The overall input given to the `Model`. This includes the prompt as well as other model steering information like [system instructions](https://ai.google.dev/gemini-api/docs/system-instructions), and/or function declarations for [function calling](https://ai.google.dev/gemini-api/docs/function-calling). `Model`s/`Content`s and `generate_content_request`s are mutually exclusive. You can either send `Model` + `Content`s or a `generate_content_request`, but never both.", + "$ref": "#/components/schemas/GenerateContentRequest" } }, - "type": "object" + "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`." }, - "FunctionDeclaration": { + "ExecutableCode": { + "description": "Code generated by the model that is meant to be executed, and the result returned to the model. Only generated when using the `CodeExecution` tool, in which the code will be automatically executed, and a corresponding `CodeExecutionResult` will also be generated.", "type": "object", - "description": "Structured representation of a function declaration as defined by the [OpenAPI 3.03 specification](https://spec.openapis.org/oas/v3.0.3). Included in this declaration are the function name and parameters. This FunctionDeclaration is a representation of a block of code that can be used as a `Tool` by the model and executed by the client.", "properties": { - "description": { - "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`." - }, - "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" - }, - "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" + "id": { + "type": "string", + "description": "Optional. Unique identifier of the `ExecutableCode` part. The server returns the `CodeExecutionResult` with the matching `id`." }, - "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`." + "code": { + "type": "string", + "description": "Required. The code to be executed." }, - "behavior": { - "description": "Optional. Specifies the function Behavior. Currently only supported by the BidiGenerateContent method.", + "language": { + "x-enum-descriptions": [ + "Unspecified language. This value should not be used.", + "Python >= 3.10, with numpy and simpy available. Python is the default language." + ], "type": "string", + "description": "Required. Programming language of the `code`.", "enum": [ - "UNSPECIFIED", - "BLOCKING", - "NON_BLOCKING" - ], - "x-enum-descriptions": [ - "This value is unused.", - "If set, the system will wait to receive the function response before continuing the conversation.", - "If set, the system will not wait to receive the function response. Instead, it will attempt to handle function responses as they become available while maintaining the conversation between the user and the model." + "LANGUAGE_UNSPECIFIED", + "PYTHON" ] - }, - "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" } } }, - "Model": { + "TuningExamples": { "type": "object", - "description": "Information about a Generative Language Model.", "properties": { - "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.", + "examples": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TuningExample" + }, + "description": "The examples. Example input can be for text or discuss, but all examples in a set must be of the same type." + } + }, + "description": "A set of tuning examples. Can be training or validation data." + }, + "InlinedEmbedContentResponses": { + "description": "The responses to the requests in the batch.", + "type": "object", + "properties": { + "inlinedResponses": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/InlinedEmbedContentResponse" + }, + "description": "Output only. The responses to the requests in the batch." + } + } + }, + "InputEmbedContentConfig": { + "type": "object", + "properties": { + "fileName": { + "description": "The name of the `File` containing the input requests.", "type": "string" }, - "topK": { - "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter.", + "requests": { + "description": "The requests to be processed in the batch.", + "$ref": "#/components/schemas/InlinedEmbedContentRequests" + } + }, + "description": "Configures the input to the batch request." + }, + "Model": { + "description": "Information about a Generative Language Model.", + "type": "object", + "properties": { + "outputTokenLimit": { "type": "integer", + "description": "Maximum number of output tokens available for this model.", "format": "int32" }, - "baseModelId": { - "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "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" }, + "name": { + "type": "string", + "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`" + }, "description": { - "description": "A short description of the model.", - "type": "string" + "type": "string", + "description": "A short description of the model." }, - "outputTokenLimit": { + "thinking": { + "type": "boolean", + "description": "Whether the model supports thinking." + }, + "supportedGenerationMethods": { + "type": "array", + "items": { + "type": "string" + }, + "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`." + }, + "inputTokenLimit": { "type": "integer", "format": "int32", - "description": "Maximum number of output tokens available for this model." + "description": "Maximum number of input tokens allowed for this model." }, - "maxTemperature": { - "description": "The maximum temperature this model can use.", + "topP": { "type": "number", + "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model.", "format": "float" }, - "version": { - "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)", - "type": "string" - }, - "topP": { + "maxTemperature": { "type": "number", "format": "float", - "description": "For [Nucleus sampling](https://ai.google.dev/gemini-api/docs/prompting-strategies#top-p). Nucleus sampling considers the smallest set of tokens whose probability sum is at least `top_p`. This value specifies default to be used by the backend while making the call to the model." - }, - "inputTokenLimit": { - "description": "Maximum number of input tokens allowed for this model.", - "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": { - "type": "array", - "description": "The model's supported generation methods. The corresponding API method names are defined as Pascal case strings, such as `generateMessage` and `generateContent`.", - "items": { - "type": "string" - } + "description": "The maximum temperature this model can use." }, - "thinking": { - "description": "Whether the model supports thinking.", - "type": "boolean" + "version": { + "type": "string", + "description": "Required. The version number of the model. This represents the major version (`1.0` or `1.5`)" }, "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." + "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" + }, + "topK": { + "description": "For Top-k sampling. Top-k sampling considers the set of `top_k` most probable tokens. This value specifies default to be used by the backend while making the call to the model. If empty, indicates the model doesn't use top-k sampling, and `top_k` isn't allowed as a generation parameter.", + "format": "int32", + "type": "integer" + }, + "baseModelId": { + "description": "Required. The name of the base model, pass this to the generation request. Examples: * `gemini-1.5-flash`", + "type": "string" } } }, - "TunedModelSource": { - "description": "Tuned model as a source for training a new model.", + "TransferOwnershipRequest": { + "description": "Request to transfer the ownership of the tuned model.", + "type": "object", "properties": { - "baseModel": { - "readOnly": true, + "emailAddress": { "type": "string", - "description": "Output only. The name of the base `Model` this `TunedModel` was tuned from. Example: `models/gemini-1.5-flash-001`" - }, - "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": "Required. The email address of the user to whom the tuned model is being transferred to." } - }, - "type": "object" + } }, - "FileSearch": { - "description": "The FileSearch tool that retrieves knowledge from Semantic Retrieval corpora. Files are imported to Semantic Retrieval corpora using the ImportFile API.", + "CitationMetadata": { + "type": "object", "properties": { - "fileSearchStoreNames": { - "description": "Required. The names of the file_search_stores to retrieve from. Example: `fileSearchStores/my-file-search-store-123`", + "citationSources": { + "description": "Citations to sources for a specific response.", + "type": "array", "items": { - "type": "string" - }, - "type": "array" - }, - "metadataFilter": { - "description": "Optional. Metadata filter to apply to the semantic retrieval documents and chunks.", - "type": "string" - }, - "topK": { - "description": "Optional. The number of semantic retrieval chunks to retrieve.", - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/CitationSource" + } } }, - "type": "object" + "description": "A collection of source attributions for a piece of content." }, - "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", + "CachedContent": { + "type": "object", "properties": { - "granteeType": { - "x-enum-descriptions": [ - "The default value. This value is unused.", - "Represents a user. When set, you must provide email_address for the user.", - "Represents a group. When set, you must provide email_address for the group.", - "Represents access to everyone. No extra information is required." - ], - "type": "string", - "enum": [ - "GRANTEE_TYPE_UNSPECIFIED", - "USER", - "GROUP", - "EVERYONE" - ], - "description": "Optional. Immutable. The type of the grantee." - }, - "role": { - "description": "Required. The role granted by this permission.", - "x-enum-descriptions": [ - "The default value. This value is unused.", - "Owner can use, update, share and delete the resource.", - "Writer can use, update and share the resource.", - "Reader can use the resource." - ], + "expireTime": { "type": "string", - "enum": [ - "ROLE_UNSPECIFIED", - "OWNER", - "WRITER", - "READER" - ] - }, - "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" + "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." }, - "name": { - "readOnly": true, - "type": "string", - "description": "Output only. Identifier. The permission name. A unique name will be generated on create. Examples: tunedModels/{tuned_model}/permissions/{permission} corpora/{corpus}/permissions/{permission} Output only." - } - }, - "type": "object" - }, - "EmbedContentBatch": { - "description": "A resource representing a batch of `EmbedContent` requests.", - "properties": { - "name": { + "updateTime": { "readOnly": true, "type": "string", - "description": "Output only. Identifier. Resource name of the batch. Format: `batches/{batch_id}`." + "description": "Output only. When the cache entry was last updated in UTC time.", + "format": "google-datetime" }, - "model": { - "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`.", - "type": "string" + "toolConfig": { + "$ref": "#/components/schemas/ToolConfig", + "description": "Optional. Input only. Immutable. Tool config. This config is shared for all tools." }, - "output": { - "description": "Output only. The output of the batch request.", - "$ref": "#/components/schemas/EmbedContentBatchOutput", - "readOnly": true + "ttl": { + "type": "string", + "description": "Input only. New TTL for this resource, input only.", + "format": "google-duration" }, - "inputConfig": { - "description": "Required. Input configuration of the instances on which batch processing are performed.", - "$ref": "#/components/schemas/InputEmbedContentConfig" + "tools": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Tool" + }, + "description": "Optional. Input only. Immutable. A list of `Tools` the model may use to generate the next response" }, - "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.", + "model": { "type": "string", - "format": "int64" + "description": "Required. Immutable. The name of the `Model` to use for cached content Format: `models/{model}`" }, "displayName": { - "description": "Required. The user-defined name of this batch.", + "description": "Optional. Immutable. The user-generated meaningful display name of the cached content. Maximum 128 Unicode characters.", "type": "string" }, - "createTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The time at which the batch was created." + "systemInstruction": { + "$ref": "#/components/schemas/Content", + "description": "Optional. Input only. Immutable. Developer set system instruction. Currently text only." }, - "updateTime": { - "description": "Output only. The time at which the batch was last updated.", + "createTime": { "readOnly": true, "type": "string", + "description": "Output only. Creation time of the cache entry.", "format": "google-datetime" }, - "endTime": { + "usageMetadata": { "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The time at which the batch processing completed." + "$ref": "#/components/schemas/CachedContentUsageMetadata", + "description": "Output only. Metadata on the usage of the cached content." }, - "batchStats": { - "description": "Output only. Stats about the batch.", - "$ref": "#/components/schemas/EmbedContentBatchStats", - "readOnly": true + "contents": { + "type": "array", + "items": { + "$ref": "#/components/schemas/Content" + }, + "description": "Optional. Input only. Immutable. The content to cache." }, - "state": { + "name": { "readOnly": true, - "enum": [ - "BATCH_STATE_UNSPECIFIED", - "BATCH_STATE_PENDING", - "BATCH_STATE_RUNNING", - "BATCH_STATE_SUCCEEDED", - "BATCH_STATE_FAILED", - "BATCH_STATE_CANCELLED", - "BATCH_STATE_EXPIRED" - ], - "description": "Output only. The state of the batch.", "type": "string", - "x-enum-descriptions": [ - "The batch state is unspecified.", - "The service is preparing to run the batch.", - "The batch is in progress.", - "The batch completed successfully.", - "The batch failed.", - "The batch has been cancelled.", - "The batch has expired." - ] + "description": "Output only. Identifier. The resource name referring to the cached content. Format: `cachedContents/{id}`" } }, - "type": "object" + "description": "Content that has been preprocessed and can be used in subsequent request to GenerativeService. Cached content can be only used with model it was created for." }, - "CountTokensResponse": { - "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`.", + "GroundingAttribution": { + "type": "object", "properties": { - "totalTokens": { - "type": "integer", - "format": "int32", - "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative." - }, - "cachedContentTokenCount": { - "description": "Number of tokens in the cached part of the prompt (the cached content).", - "type": "integer", - "format": "int32" - }, - "promptTokensDetails": { - "description": "Output only. List of modalities that were processed in the request input.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, - "readOnly": true, - "type": "array" + "content": { + "description": "Grounding source content that makes up this attribution.", + "$ref": "#/components/schemas/Content" }, - "cacheTokensDetails": { - "description": "Output only. List of modalities that were processed in the cached content.", - "items": { - "$ref": "#/components/schemas/ModalityTokenCount" - }, + "sourceId": { + "description": "Output only. Identifier for the source contributing to this attribution.", "readOnly": true, - "type": "array" + "$ref": "#/components/schemas/AttributionSourceId" } }, - "type": "object" + "description": "Attribution for a source that contributed to an answer." }, - "ComputerUse": { + "RetrievalMetadata": { + "description": "Metadata related to retrieval in the grounding flow.", "type": "object", - "description": "Computer Use tool type.", "properties": { - "excludedPredefinedFunctions": { - "description": "Optional. By default, predefined functions are included in the final model call. Some of them can be explicitly excluded from being automatically included. This can serve two purposes: 1. Using a more restricted / different action space. 2. Improving the definitions / instructions of predefined functions.", - "items": { - "type": "string" - }, - "type": "array" - }, - "enablePromptInjectionDetection": { - "description": "Optional. Whether enable the prompt injection detection check on computer-use request.", - "type": "boolean" - }, - "environment": { - "description": "Required. The environment being operated.", - "x-enum-descriptions": [ - "Defaults to browser.", - "Operates in a web browser.", - "Operates in a mobile environment.", - "Operates in a desktop environment." - ], - "type": "string", - "enum": [ - "ENVIRONMENT_UNSPECIFIED", - "ENVIRONMENT_BROWSER", - "ENVIRONMENT_MOBILE", - "ENVIRONMENT_DESKTOP" - ] - }, - "disabledSafetyPolicies": { - "type": "array", - "description": "Optional. Disabled safety policies for computer use.", - "items": { - "type": "string", - "enum": [ - "SAFETY_POLICY_UNSPECIFIED", - "FINANCIAL_TRANSACTIONS", - "SENSITIVE_DATA_MODIFICATION", - "COMMUNICATION_TOOL", - "ACCOUNT_CREATION", - "DATA_MODIFICATION", - "USER_CONSENT_MANAGEMENT", - "LEGAL_TERMS_AND_AGREEMENTS" - ], - "x-enum-descriptions": [ - "Unspecified safety policy.", - "Safety policy for financial transactions.", - "Safety policy for sensitive data modification.", - "Safety policy for communication tools (e.g. Gmail, Chat, Meet).", - "Safety policy for account creation.", - "Safety policy for data modification.", - "Safety policy for user consent management.", - "Safety policy for legal terms and agreements." - ] - } + "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." } } }, - "PromptFeedback": { + "InlinedRequests": { "type": "object", - "description": "A set of the feedback metadata the prompt specified in `GenerateContentRequest.content`.", "properties": { - "blockReason": { - "description": "Optional. If set, the prompt was blocked and no candidates are returned. Rephrase the prompt.", - "x-enum-descriptions": [ - "Default value. This value is unused.", - "Prompt was blocked due to safety reasons. Inspect `safety_ratings` to understand which safety category blocked it.", - "Prompt was blocked due to unknown reasons.", - "Prompt was blocked due to the terms which are included from the terminology blocklist.", - "Prompt was blocked due to prohibited content.", - "Candidates blocked due to unsafe image generation content." - ], - "type": "string", - "enum": [ - "BLOCK_REASON_UNSPECIFIED", - "SAFETY", - "OTHER", - "BLOCKLIST", - "PROHIBITED_CONTENT", - "IMAGE_SAFETY" - ] - }, - "safetyRatings": { + "requests": { "type": "array", - "description": "Ratings for safety of the prompt. There is at most one rating per category.", "items": { - "$ref": "#/components/schemas/SafetyRating" - } + "$ref": "#/components/schemas/InlinedRequest" + }, + "description": "Required. The requests to be processed in the batch." } - } + }, + "description": "The requests to be processed in the batch if provided as part of the batch creation request." }, - "ToolResponse": { + "UsageMetadata": { + "description": "Metadata on the generation request's token usage.", "type": "object", - "description": "The output from a server-side `ToolCall` execution. This message contains the results of a tool invocation that was initiated by a `ToolCall` from the model. The client should pass this `ToolResponse` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolCall`.", "properties": { - "id": { - "description": "Optional. The identifier of the tool call this response is for.", - "type": "string" - }, - "toolType": { - "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." - ], - "type": "string", - "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ], - "description": "Required. The type of tool that was called, matching the `tool_type` in the corresponding `ToolCall`." + "promptTokenCount": { + "description": "Number of tokens in the prompt. When `cached_content` is set, this is still the total effective prompt size meaning this includes the number of tokens in the cached content.", + "format": "int32", + "type": "integer" }, - "response": { - "type": "object", - "description": "Optional. The tool response.", - "additionalProperties": { - "description": "Properties of the object." - } - } - } - }, - "SpeakerVoiceConfig": { - "description": "The configuration for a single speaker in a multi speaker setup.", - "properties": { - "voiceConfig": { - "description": "Required. The configuration for the voice to use.", - "$ref": "#/components/schemas/VoiceConfig" + "toolUsePromptTokensDetails": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities that were processed for tool-use request inputs." }, - "speaker": { - "description": "Required. The name of the speaker to use. Should be the same as in the prompt.", - "type": "string" - } - }, - "type": "object" - }, - "ToolCall": { - "type": "object", - "description": "A predicted server-side `ToolCall` returned from the model. This message contains information about a tool that the model wants to invoke. The client is NOT expected to execute this `ToolCall`. Instead, the client should pass this `ToolCall` back to the API in a subsequent turn within a `Content` message, along with the corresponding `ToolResponse`.", - "properties": { - "id": { - "description": "Optional. Unique identifier of the tool call. The server returns the tool response with the matching `id`.", - "type": "string" + "cacheTokensDetails": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + }, + "description": "Output only. List of modalities of the cached content in the request input." }, - "toolType": { + "serviceTier": { + "readOnly": true, + "type": "string", "x-enum-descriptions": [ - "Unspecified tool type.", - "Google search tool, maps to Tool.google_search.search_types.web_search.", - "Image search tool, maps to Tool.google_search.search_types.image_search.", - "URL context tool, maps to Tool.url_context.", - "Google maps tool, maps to Tool.google_maps.", - "File search tool, maps to Tool.file_search." + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." ], - "type": "string", + "description": "Output only. Service tier of the request.", "enum": [ - "TOOL_TYPE_UNSPECIFIED", - "GOOGLE_SEARCH_WEB", - "GOOGLE_SEARCH_IMAGE", - "URL_CONTEXT", - "GOOGLE_MAPS", - "FILE_SEARCH" - ], - "description": "Required. The type of tool that was called." + "unspecified", + "standard", + "flex", + "priority" + ] + }, + "cachedContentTokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content)" }, - "args": { - "description": "Optional. The tool call arguments. Example: {\"arg1\" : \"value1\", \"arg2\" : \"value2\" , ...}", - "additionalProperties": { - "description": "Properties of the object." - }, - "type": "object" - } - } - }, - "CachedContentUsageMetadata": { - "description": "Metadata on the usage of the cached content.", - "properties": { "totalTokenCount": { + "description": "Total token count for the generation request (prompt + thoughts + response candidates).", + "format": "int32", + "type": "integer" + }, + "toolUsePromptTokenCount": { + "description": "Output only. Number of tokens present in tool-use prompt(s).", + "format": "int32", + "readOnly": true, + "type": "integer" + }, + "candidatesTokenCount": { + "type": "integer", + "format": "int32", + "description": "Total number of tokens across all the generated response candidates." + }, + "promptTokensDetails": { + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "candidatesTokensDetails": { + "description": "Output only. List of modalities that were returned in the response.", + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "thoughtsTokenCount": { + "format": "int32", + "description": "Output only. Number of tokens of thoughts for thinking models.", + "readOnly": true, + "type": "integer" + }, + "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", - "description": "Total number of tokens that the cached content consumes." - } - }, - "type": "object" - }, - "EmbedContentResponse": { - "description": "The response to an `EmbedContentRequest`.", - "properties": { - "embedding": { - "description": "Output only. The embedding generated from the input content.", - "$ref": "#/components/schemas/ContentEmbedding", "readOnly": true }, - "usageMetadata": { + "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, - "description": "Output only. The usage metadata for the request.", - "$ref": "#/components/schemas/EmbeddingUsageMetadata" + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" + } } - }, - "type": "object" + } }, - "ListTunedModelsResponse": { - "description": "Response from `ListTunedModels` containing a paginated list of Models.", + "EmbeddingUsageMetadata": { + "description": "Metadata on the usage of the embedding request.", + "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" + "promptTokenCount": { + "readOnly": true, + "type": "integer", + "description": "Output only. Number of tokens in the prompt.", + "format": "int32" }, - "tunedModels": { - "description": "The returned Models.", + "promptTokenDetails": { + "description": "Output only. List of modalities that were processed in the request input.", + "readOnly": true, + "type": "array", "items": { - "$ref": "#/components/schemas/TunedModel" - }, - "type": "array" - } - }, - "type": "object" - }, - "RetrievalMetadata": { - "description": "Metadata related to retrieval in the grounding flow.", - "properties": { - "googleSearchDynamicRetrievalScore": { - "description": "Optional. Score indicating how likely information from google search could help answer the prompt. The score is in the range [0, 1], where 0 is the least likely and 1 is the most likely. This score is only populated when google search grounding and dynamic retrieval is enabled. It will be compared to the threshold to determine whether to trigger google search.", - "type": "number", - "format": "float" + "$ref": "#/components/schemas/ModalityTokenCount" + } } - }, - "type": "object" + } }, - "GeneratedFile": { + "CustomLongRunningOperation": { "type": "object", - "description": "A file generated on behalf of a user.", "properties": { - "name": { - "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", - "type": "string" + "error": { + "$ref": "#/components/schemas/Status", + "description": "The error result of the operation in case of failure or cancellation." }, - "mimeType": { - "description": "MIME type of the generatedFile.", - "type": "string" + "response": { + "type": "object", + "additionalProperties": { + "description": "Properties of the object. Contains field @type with type URL." + }, + "description": "The normal, successful response of the operation. If the original method returns no data on success, such as `Delete`, the response is `google.protobuf.Empty`. If the original method is standard `Get`/`Create`/`Update`, the response should be the resource. For other methods, the response should have the type `XxxResponse`, where `Xxx` is the original method name. For example, if the original method name is `TakeSnapshot()`, the inferred response type is `TakeSnapshotResponse`." }, - "state": { - "readOnly": true, - "enum": [ - "STATE_UNSPECIFIED", - "GENERATING", - "GENERATED", - "FAILED" - ], - "description": "Output only. The state of the GeneratedFile.", - "x-enum-descriptions": [ - "The default value. This value is used if the state is omitted.", - "Being generated.", - "Generated and is ready for download.", - "Failed to generate the GeneratedFile." - ], + "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." + } + }, + "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": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", - "$ref": "#/components/schemas/Status" + "done": { + "type": "boolean", + "description": "If the value is `false`, it means the operation is still in progress. If `true`, the operation is completed, and either `error` or `response` is available." } } }, - "EmbedContentBatchStats": { - "description": "Stats about the batch.", + "Corpus": { + "description": "A `Corpus` is a collection of `Document`s. A project can create up to 10 corpora.", + "type": "object", "properties": { - "pendingRequestCount": { + "updateTime": { "readOnly": true, "type": "string", - "format": "int64", - "description": "Output only. The number of requests that are still pending processing." + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `Corpus` was last updated." }, - "requestCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests in the batch." + "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" }, - "failedRequestCount": { + "createTime": { + "format": "google-datetime", + "description": "Output only. The Timestamp of when the `Corpus` was created.", "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of requests that failed to be processed." + "type": "string" }, - "successfulRequestCount": { + "name": { "readOnly": true, "type": "string", - "format": "int64", - "description": "Output only. The number of requests that were successfully processed." + "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": "object" + } }, - "Tool": { + "ImportFileRequest": { "type": "object", - "description": "Tool details that the model may use to generate response. A `Tool` is a piece of code that enables the system to interact with external systems to perform an action, or set of actions, outside of knowledge and scope of the model. Next ID: 16", "properties": { - "googleSearchRetrieval": { - "description": "Optional. Retrieval tool that is powered by Google search.", - "$ref": "#/components/schemas/GoogleSearchRetrieval" - }, - "googleSearch": { - "description": "Optional. GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", - "$ref": "#/components/schemas/GoogleSearch" - }, - "fileSearch": { - "description": "Optional. FileSearch tool type. Tool to retrieve knowledge from Semantic Retrieval corpora.", - "$ref": "#/components/schemas/FileSearch" + "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." }, - "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": { - "$ref": "#/components/schemas/FunctionDeclaration" - } + "fileName": { + "type": "string", + "description": "Required. The name of the `File` to import. Example: `files/abc-123`" }, - "mcpServers": { + "customMetadata": { + "description": "Custom metadata to be associated with the file.", "type": "array", - "description": "Optional. MCP Servers to connect to.", "items": { - "$ref": "#/components/schemas/McpServer" + "$ref": "#/components/schemas/CustomMetadata" } - }, - "codeExecution": { - "description": "Optional. Enables the model to execute code as part of generation.", - "$ref": "#/components/schemas/CodeExecution" - }, - "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" - }, - "urlContext": { - "description": "Optional. Tool to support URL context retrieval.", - "$ref": "#/components/schemas/UrlContext" } - } + }, + "description": "Request for `ImportFile` to import a File API file with a `FileSearchStore`." }, - "GoogleSearch": { + "EmbedContentResponse": { "type": "object", - "description": "GoogleSearch tool type. Tool to support Google Search in Model. Powered by Google.", "properties": { - "timeRangeFilter": { - "description": "Optional. Filter search results to a specific time range. If customers set a start time, they must set an end time (and vice versa).", - "$ref": "#/components/schemas/Interval" + "usageMetadata": { + "description": "Output only. The usage metadata for the request.", + "readOnly": true, + "$ref": "#/components/schemas/EmbeddingUsageMetadata" }, - "searchTypes": { - "description": "Optional. The set of search types to enable. If not set, web search is enabled by default.", - "$ref": "#/components/schemas/SearchTypes" + "embedding": { + "readOnly": true, + "$ref": "#/components/schemas/ContentEmbedding", + "description": "Output only. The embedding generated from the input content." } - } + }, + "description": "The response to an `EmbedContentRequest`." }, - "ListPermissionsResponse": { + "CountTokensResponse": { "type": "object", - "description": "Response from `ListPermissions` containing a paginated list of permissions.", "properties": { - "permissions": { - "description": "Returned permissions.", + "cachedContentTokenCount": { + "type": "integer", + "format": "int32", + "description": "Number of tokens in the cached part of the prompt (the cached content)." + }, + "cacheTokensDetails": { + "description": "Output only. List of modalities that were processed in the cached content.", + "readOnly": true, + "type": "array", "items": { - "$ref": "#/components/schemas/Permission" + "$ref": "#/components/schemas/ModalityTokenCount" + } + }, + "totalTokens": { + "type": "integer", + "description": "The number of tokens that the `Model` tokenizes the `prompt` into. Always non-negative.", + "format": "int32" + }, + "promptTokensDetails": { + "readOnly": true, + "type": "array", + "items": { + "$ref": "#/components/schemas/ModalityTokenCount" }, - "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": "Output only. List of modalities that were processed in the request input." } - } + }, + "description": "A response from `CountTokens`. It returns the model's `token_count` for the `prompt`." }, - "CodeExecutionResult": { - "description": "Result of executing the `ExecutableCode`. Generated only when the `CodeExecution` tool is used.", + "EmbedContentBatchStats": { + "type": "object", "properties": { - "output": { - "description": "Optional. Contains stdout when code execution is successful, stderr or other description otherwise.", - "type": "string" + "pendingRequestCount": { + "readOnly": true, + "type": "string", + "description": "Output only. The number of requests that are still pending processing.", + "format": "int64" }, - "id": { - "description": "Optional. The identifier of the `ExecutableCode` part this result is for. Only populated if the corresponding `ExecutableCode` has an id.", + "requestCount": { + "readOnly": true, + "type": "string", + "format": "int64", + "description": "Output only. The number of requests in the batch." + }, + "successfulRequestCount": { + "format": "int64", + "description": "Output only. The number of requests that were successfully processed.", + "readOnly": true, "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." - ], - "type": "string", - "enum": [ - "OUTCOME_UNSPECIFIED", - "OUTCOME_OK", - "OUTCOME_FAILED", - "OUTCOME_DEADLINE_EXCEEDED" - ] + "failedRequestCount": { + "description": "Output only. The number of requests that failed to be processed.", + "format": "int64", + "readOnly": true, + "type": "string" } }, - "type": "object" + "description": "Stats about the batch." }, - "GoogleAiGenerativelanguageV1betaGroundingSupport": { + "GenerateContentRequest": { + "description": "Request to generate a completion from the model.", "type": "object", - "description": "Grounding support.", "properties": { - "segment": { - "description": "Segment of the content this support belongs to.", - "$ref": "#/components/schemas/GoogleAiGenerativelanguageV1betaSegment" + "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" }, - "groundingChunkIndices": { - "description": "Optional. A list of indices (into 'grounding_chunk' in `response.candidate.grounding_metadata`) specifying the citations associated with the claim. For instance [1,3,4] means that grounding_chunk[1], grounding_chunk[3], grounding_chunk[4] are the retrieved content attributed to the claim. If the response is streaming, the grounding_chunk_indices refer to the indices across all responses. It is the client's responsibility to accumulate the grounding chunks from all responses (while maintaining the same order).", + "generationConfig": { + "description": "Optional. Configuration options for model generation and outputs.", + "$ref": "#/components/schemas/GenerationConfig" + }, + "store": { + "type": "boolean", + "description": "Optional. Configures the logging behavior for a given request. If set, it takes precedence over the project-level logging config." + }, + "model": { + "type": "string", + "description": "Required. The name of the `Model` to use for generating the completion. Format: `models/{model}`." + }, + "safetySettings": { + "type": "array", "items": { - "type": "integer", - "format": "int32" + "$ref": "#/components/schemas/SafetySetting" }, - "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." }, - "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.", + "tools": { + "type": "array", "items": { - "type": "number", - "format": "float" + "$ref": "#/components/schemas/Tool" }, - "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." }, - "renderedParts": { - "readOnly": true, + "serviceTier": { + "x-enum-descriptions": [ + "Default service tier, which is standard.", + "Standard service tier.", + "Flex service tier.", + "Priority service tier." + ], + "type": "string", + "description": "Optional. The service tier of the request.", + "enum": [ + "unspecified", + "standard", + "flex", + "priority" + ] + }, + "contents": { "type": "array", - "description": "Output only. Indices into the `parts` field of the candidate's content. These indices specify which rendered parts are associated with this support source.", "items": { - "type": "integer", - "format": "int32" - } + "$ref": "#/components/schemas/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." + }, + "systemInstruction": { + "description": "Optional. Developer set [system instruction(s)](https://ai.google.dev/gemini-api/docs/system-instructions). Currently, text only.", + "$ref": "#/components/schemas/Content" + }, + "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" } } }, - "UrlContextMetadata": { + "GoogleAiGenerativelanguageV1betaSegment": { "type": "object", - "description": "Metadata related to url context retrieval tool.", "properties": { - "urlMetadata": { - "description": "List of url context.", - "items": { - "$ref": "#/components/schemas/UrlMetadata" - }, - "type": "array" + "partIndex": { + "description": "The index of a Part object within its parent Content object.", + "format": "int32", + "type": "integer" + }, + "endIndex": { + "description": "End index in the given Part, measured in bytes. Offset from the start of the Part, exclusive, starting at zero.", + "format": "int32", + "type": "integer" + }, + "text": { + "description": "The text corresponding to the segment from the response.", + "type": "string" + }, + "startIndex": { + "description": "Start index in the given Part, measured in bytes. Offset from the start of the Part, inclusive, starting at zero.", + "format": "int32", + "type": "integer" } - } + }, + "description": "Segment of the content." }, - "InlinedEmbedContentRequests": { + "LogprobsResult": { + "description": "Logprobs Result", "type": "object", - "description": "The requests to be processed in the batch if provided as part of the batch creation request.", "properties": { - "requests": { + "chosenCandidates": { "type": "array", - "description": "Required. The requests to be processed in the batch.", "items": { - "$ref": "#/components/schemas/InlinedEmbedContentRequest" - } + "$ref": "#/components/schemas/LogprobsResultCandidate" + }, + "description": "Length = total number of decoding steps. The chosen candidates may or may not be in top_candidates." + }, + "logProbabilitySum": { + "type": "number", + "format": "float", + "description": "Sum of log probabilities for all tokens." + }, + "topCandidates": { + "type": "array", + "items": { + "$ref": "#/components/schemas/TopCandidates" + }, + "description": "Length = total number of decoding steps." } } }, - "Empty": { + "RegisterFilesRequest": { "type": "object", - "description": "A generic empty message that you can re-use to avoid defining duplicated empty messages in your APIs. A typical example is to use it as the request or the response type of an API method. For instance: service Foo { rpc Bar(google.protobuf.Empty) returns (google.protobuf.Empty); }", - "properties": {} - }, - "TopCandidates": { - "description": "Candidates with top log probabilities at each decoding step.", "properties": { - "candidates": { + "uris": { "type": "array", - "description": "Sorted by log probability in descending order.", "items": { - "$ref": "#/components/schemas/LogprobsResultCandidate" - } + "type": "string" + }, + "description": "Required. The Google Cloud Storage URIs to register. Example: `gs://bucket/object`." } }, - "type": "object" + "description": "Request for `RegisterFiles`." }, - "FileSearchStore": { - "description": "A `FileSearchStore` is a collection of `Document`s.", + "GeneratedFile": { + "type": "object", "properties": { "name": { - "description": "Output only. Immutable. Identifier. The `FileSearchStore` resource name. It is an ID (name excluding the \"fileSearchStores/\" prefix) that can contain up to 40 characters that are lowercase alphanumeric or dashes (-). It is output only. The unique name will be derived from `display_name` along with a 12 character random suffix. Example: `fileSearchStores/my-awesome-file-search-store-123a456b789c` If `display_name` is not provided, the name will be randomly generated.", - "readOnly": true, + "description": "Identifier. The name of the generated file. Example: `generatedFiles/abc-123`", "type": "string" }, - "activeDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that are active and ready for retrieval.", - "readOnly": true, - "type": "string", - "format": "int64" - }, - "failedDocumentsCount": { - "description": "Output only. The number of documents in the `FileSearchStore` that have failed processing.", - "readOnly": true, - "type": "string", - "format": "int64" - }, - "pendingDocumentsCount": { - "readOnly": true, - "type": "string", - "format": "int64", - "description": "Output only. The number of documents in the `FileSearchStore` that are being processed." - }, - "embeddingModel": { - "description": "Optional. The embedding model to use for the `FileSearchStore`. The model's resource name. This serves as an ID for the Model to use. Format: `models/{model}`. If not specified, the default embedding model will be used.", + "mimeType": { + "description": "MIME type of the generatedFile.", "type": "string" }, - "createTime": { - "readOnly": true, - "type": "string", - "format": "google-datetime", - "description": "Output only. The Timestamp of when the `FileSearchStore` was created." - }, - "updateTime": { - "description": "Output only. The Timestamp of when the `FileSearchStore` was last updated.", - "readOnly": true, - "type": "string", - "format": "google-datetime" - }, - "sizeBytes": { + "state": { + "description": "Output only. The state of the GeneratedFile.", + "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." + ], "readOnly": true, - "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`." - }, - "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" - } - }, - "type": "object" - }, - "StreamableHttpTransport": { - "type": "object", - "description": "A transport that can stream HTTP requests and responses. Next ID: 6", - "properties": { - "terminateOnClose": { - "description": "Whether to close the client session when the transport closes.", - "type": "boolean" - }, - "url": { - "description": "The full URL for the MCPServer endpoint. Example: \"https://api.example.com/mcp\"", "type": "string" }, - "timeout": { - "type": "string", - "format": "google-duration", - "description": "HTTP timeout for regular operations." - }, - "headers": { - "type": "object", - "description": "Optional: Fields for authentication headers, timeouts, etc., if needed.", - "additionalProperties": { - "type": "string" - } - }, - "sseReadTimeout": { - "description": "Timeout for SSE read operations.", - "type": "string", - "format": "google-duration" + "error": { + "description": "Error details if the GeneratedFile ends up in the STATE_FAILED state.", + "$ref": "#/components/schemas/Status" } - } + }, + "description": "A file generated on behalf of a user." } } }