summaryrefslogtreecommitdiff
path: root/third_party/googleapis/google/logging/v2/logging_config.proto
diff options
context:
space:
mode:
Diffstat (limited to 'third_party/googleapis/google/logging/v2/logging_config.proto')
-rw-r--r--third_party/googleapis/google/logging/v2/logging_config.proto1957
1 files changed, 1957 insertions, 0 deletions
diff --git a/third_party/googleapis/google/logging/v2/logging_config.proto b/third_party/googleapis/google/logging/v2/logging_config.proto
new file mode 100644
index 0000000..ef00240
--- /dev/null
+++ b/third_party/googleapis/google/logging/v2/logging_config.proto
@@ -0,0 +1,1957 @@
+// Copyright 2022 Google LLC
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+syntax = "proto3";
+
+package google.logging.v2;
+
+import "google/api/annotations.proto";
+import "google/api/client.proto";
+import "google/api/field_behavior.proto";
+import "google/api/resource.proto";
+import "google/longrunning/operations.proto";
+import "google/protobuf/empty.proto";
+import "google/protobuf/field_mask.proto";
+import "google/protobuf/timestamp.proto";
+
+option cc_enable_arenas = true;
+option csharp_namespace = "Google.Cloud.Logging.V2";
+option go_package = "google.golang.org/genproto/googleapis/logging/v2;logging";
+option java_multiple_files = true;
+option java_outer_classname = "LoggingConfigProto";
+option java_package = "com.google.logging.v2";
+option php_namespace = "Google\\Cloud\\Logging\\V2";
+option ruby_package = "Google::Cloud::Logging::V2";
+option (google.api.resource_definition) = {
+ type: "logging.googleapis.com/OrganizationLocation"
+ pattern: "organizations/{organization}/locations/{location}"
+};
+option (google.api.resource_definition) = {
+ type: "logging.googleapis.com/FolderLocation"
+ pattern: "folders/{folder}/locations/{location}"
+};
+option (google.api.resource_definition) = {
+ type: "logging.googleapis.com/BillingAccountLocation"
+ pattern: "billingAccounts/{billing_account}/locations/{location}"
+};
+
+// Service for configuring sinks used to route log entries.
+service ConfigServiceV2 {
+ option (google.api.default_host) = "logging.googleapis.com";
+ option (google.api.oauth_scopes) =
+ "https://www.googleapis.com/auth/cloud-platform,"
+ "https://www.googleapis.com/auth/cloud-platform.read-only,"
+ "https://www.googleapis.com/auth/logging.admin,"
+ "https://www.googleapis.com/auth/logging.read";
+
+ // Lists log buckets.
+ rpc ListBuckets(ListBucketsRequest) returns (ListBucketsResponse) {
+ option (google.api.http) = {
+ get: "/v2/{parent=*/*/locations/*}/buckets"
+ additional_bindings {
+ get: "/v2/{parent=projects/*/locations/*}/buckets"
+ }
+ additional_bindings {
+ get: "/v2/{parent=organizations/*/locations/*}/buckets"
+ }
+ additional_bindings {
+ get: "/v2/{parent=folders/*/locations/*}/buckets"
+ }
+ additional_bindings {
+ get: "/v2/{parent=billingAccounts/*/locations/*}/buckets"
+ }
+ };
+ option (google.api.method_signature) = "parent";
+ }
+
+ // Gets a log bucket.
+ rpc GetBucket(GetBucketRequest) returns (LogBucket) {
+ option (google.api.http) = {
+ get: "/v2/{name=*/*/locations/*/buckets/*}"
+ additional_bindings {
+ get: "/v2/{name=projects/*/locations/*/buckets/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=organizations/*/locations/*/buckets/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=folders/*/locations/*/buckets/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=billingAccounts/*/buckets/*}"
+ }
+ };
+ }
+
+ // Creates a log bucket that can be used to store log entries. After a bucket
+ // has been created, the bucket's location cannot be changed.
+ rpc CreateBucket(CreateBucketRequest) returns (LogBucket) {
+ option (google.api.http) = {
+ post: "/v2/{parent=*/*/locations/*}/buckets"
+ body: "bucket"
+ additional_bindings {
+ post: "/v2/{parent=projects/*/locations/*}/buckets"
+ body: "bucket"
+ }
+ additional_bindings {
+ post: "/v2/{parent=organizations/*/locations/*}/buckets"
+ body: "bucket"
+ }
+ additional_bindings {
+ post: "/v2/{parent=folders/*/locations/*}/buckets"
+ body: "bucket"
+ }
+ additional_bindings {
+ post: "/v2/{parent=billingAccounts/*/locations/*}/buckets"
+ body: "bucket"
+ }
+ };
+ }
+
+ // Updates a log bucket. This method replaces the following fields in the
+ // existing bucket with values from the new bucket: `retention_period`
+ //
+ // If the retention period is decreased and the bucket is locked,
+ // `FAILED_PRECONDITION` will be returned.
+ //
+ // If the bucket has a `lifecycle_state` of `DELETE_REQUESTED`, then
+ // `FAILED_PRECONDITION` will be returned.
+ //
+ // After a bucket has been created, the bucket's location cannot be changed.
+ rpc UpdateBucket(UpdateBucketRequest) returns (LogBucket) {
+ option (google.api.http) = {
+ patch: "/v2/{name=*/*/locations/*/buckets/*}"
+ body: "bucket"
+ additional_bindings {
+ patch: "/v2/{name=projects/*/locations/*/buckets/*}"
+ body: "bucket"
+ }
+ additional_bindings {
+ patch: "/v2/{name=organizations/*/locations/*/buckets/*}"
+ body: "bucket"
+ }
+ additional_bindings {
+ patch: "/v2/{name=folders/*/locations/*/buckets/*}"
+ body: "bucket"
+ }
+ additional_bindings {
+ patch: "/v2/{name=billingAccounts/*/locations/*/buckets/*}"
+ body: "bucket"
+ }
+ };
+ }
+
+ // Deletes a log bucket.
+ //
+ // Changes the bucket's `lifecycle_state` to the `DELETE_REQUESTED` state.
+ // After 7 days, the bucket will be purged and all log entries in the bucket
+ // will be permanently deleted.
+ rpc DeleteBucket(DeleteBucketRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = {
+ delete: "/v2/{name=*/*/locations/*/buckets/*}"
+ additional_bindings {
+ delete: "/v2/{name=projects/*/locations/*/buckets/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=organizations/*/locations/*/buckets/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=folders/*/locations/*/buckets/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=billingAccounts/*/locations/*/buckets/*}"
+ }
+ };
+ }
+
+ // Undeletes a log bucket. A bucket that has been deleted can be undeleted
+ // within the grace period of 7 days.
+ rpc UndeleteBucket(UndeleteBucketRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = {
+ post: "/v2/{name=*/*/locations/*/buckets/*}:undelete"
+ body: "*"
+ additional_bindings {
+ post: "/v2/{name=projects/*/locations/*/buckets/*}:undelete"
+ body: "*"
+ }
+ additional_bindings {
+ post: "/v2/{name=organizations/*/locations/*/buckets/*}:undelete"
+ body: "*"
+ }
+ additional_bindings {
+ post: "/v2/{name=folders/*/locations/*/buckets/*}:undelete"
+ body: "*"
+ }
+ additional_bindings {
+ post: "/v2/{name=billingAccounts/*/locations/*/buckets/*}:undelete"
+ body: "*"
+ }
+ };
+ }
+
+ // Lists views on a log bucket.
+ rpc ListViews(ListViewsRequest) returns (ListViewsResponse) {
+ option (google.api.http) = {
+ get: "/v2/{parent=*/*/locations/*/buckets/*}/views"
+ additional_bindings {
+ get: "/v2/{parent=projects/*/locations/*/buckets/*}/views"
+ }
+ additional_bindings {
+ get: "/v2/{parent=organizations/*/locations/*/buckets/*}/views"
+ }
+ additional_bindings {
+ get: "/v2/{parent=folders/*/locations/*/buckets/*}/views"
+ }
+ additional_bindings {
+ get: "/v2/{parent=billingAccounts/*/locations/*/buckets/*}/views"
+ }
+ };
+ option (google.api.method_signature) = "parent";
+ }
+
+ // Gets a view on a log bucket..
+ rpc GetView(GetViewRequest) returns (LogView) {
+ option (google.api.http) = {
+ get: "/v2/{name=*/*/locations/*/buckets/*/views/*}"
+ additional_bindings {
+ get: "/v2/{name=projects/*/locations/*/buckets/*/views/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=organizations/*/locations/*/buckets/*/views/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=folders/*/locations/*/buckets/*/views/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=billingAccounts/*/buckets/*/views/*}"
+ }
+ };
+ }
+
+ // Creates a view over log entries in a log bucket. A bucket may contain a
+ // maximum of 30 views.
+ rpc CreateView(CreateViewRequest) returns (LogView) {
+ option (google.api.http) = {
+ post: "/v2/{parent=*/*/locations/*/buckets/*}/views"
+ body: "view"
+ additional_bindings {
+ post: "/v2/{parent=projects/*/locations/*/buckets/*}/views"
+ body: "view"
+ }
+ additional_bindings {
+ post: "/v2/{parent=organizations/*/locations/*/buckets/*}/views"
+ body: "view"
+ }
+ additional_bindings {
+ post: "/v2/{parent=folders/*/locations/*/buckets/*}/views"
+ body: "view"
+ }
+ additional_bindings {
+ post: "/v2/{parent=billingAccounts/*/locations/*/buckets/*}/views"
+ body: "view"
+ }
+ };
+ }
+
+ // Updates a view on a log bucket. This method replaces the following fields
+ // in the existing view with values from the new view: `filter`.
+ // If an `UNAVAILABLE` error is returned, this indicates that system is not in
+ // a state where it can update the view. If this occurs, please try again in a
+ // few minutes.
+ rpc UpdateView(UpdateViewRequest) returns (LogView) {
+ option (google.api.http) = {
+ patch: "/v2/{name=*/*/locations/*/buckets/*/views/*}"
+ body: "view"
+ additional_bindings {
+ patch: "/v2/{name=projects/*/locations/*/buckets/*/views/*}"
+ body: "view"
+ }
+ additional_bindings {
+ patch: "/v2/{name=organizations/*/locations/*/buckets/*/views/*}"
+ body: "view"
+ }
+ additional_bindings {
+ patch: "/v2/{name=folders/*/locations/*/buckets/*/views/*}"
+ body: "view"
+ }
+ additional_bindings {
+ patch: "/v2/{name=billingAccounts/*/locations/*/buckets/*/views/*}"
+ body: "view"
+ }
+ };
+ }
+
+ // Deletes a view on a log bucket.
+ // If an `UNAVAILABLE` error is returned, this indicates that system is not in
+ // a state where it can delete the view. If this occurs, please try again in a
+ // few minutes.
+ rpc DeleteView(DeleteViewRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = {
+ delete: "/v2/{name=*/*/locations/*/buckets/*/views/*}"
+ additional_bindings {
+ delete: "/v2/{name=projects/*/locations/*/buckets/*/views/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=organizations/*/locations/*/buckets/*/views/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=folders/*/locations/*/buckets/*/views/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=billingAccounts/*/locations/*/buckets/*/views/*}"
+ }
+ };
+ }
+
+ // Lists sinks.
+ rpc ListSinks(ListSinksRequest) returns (ListSinksResponse) {
+ option (google.api.http) = {
+ get: "/v2/{parent=*/*}/sinks"
+ additional_bindings {
+ get: "/v2/{parent=projects/*}/sinks"
+ }
+ additional_bindings {
+ get: "/v2/{parent=organizations/*}/sinks"
+ }
+ additional_bindings {
+ get: "/v2/{parent=folders/*}/sinks"
+ }
+ additional_bindings {
+ get: "/v2/{parent=billingAccounts/*}/sinks"
+ }
+ };
+ option (google.api.method_signature) = "parent";
+ }
+
+ // Gets a sink.
+ rpc GetSink(GetSinkRequest) returns (LogSink) {
+ option (google.api.http) = {
+ get: "/v2/{sink_name=*/*/sinks/*}"
+ additional_bindings {
+ get: "/v2/{sink_name=projects/*/sinks/*}"
+ }
+ additional_bindings {
+ get: "/v2/{sink_name=organizations/*/sinks/*}"
+ }
+ additional_bindings {
+ get: "/v2/{sink_name=folders/*/sinks/*}"
+ }
+ additional_bindings {
+ get: "/v2/{sink_name=billingAccounts/*/sinks/*}"
+ }
+ };
+ option (google.api.method_signature) = "sink_name";
+ }
+
+ // Creates a sink that exports specified log entries to a destination. The
+ // export of newly-ingested log entries begins immediately, unless the sink's
+ // `writer_identity` is not permitted to write to the destination. A sink can
+ // export log entries only from the resource owning the sink.
+ rpc CreateSink(CreateSinkRequest) returns (LogSink) {
+ option (google.api.http) = {
+ post: "/v2/{parent=*/*}/sinks"
+ body: "sink"
+ additional_bindings {
+ post: "/v2/{parent=projects/*}/sinks"
+ body: "sink"
+ }
+ additional_bindings {
+ post: "/v2/{parent=organizations/*}/sinks"
+ body: "sink"
+ }
+ additional_bindings {
+ post: "/v2/{parent=folders/*}/sinks"
+ body: "sink"
+ }
+ additional_bindings {
+ post: "/v2/{parent=billingAccounts/*}/sinks"
+ body: "sink"
+ }
+ };
+ option (google.api.method_signature) = "parent,sink";
+ }
+
+ // Updates a sink. This method replaces the following fields in the existing
+ // sink with values from the new sink: `destination`, and `filter`.
+ //
+ // The updated sink might also have a new `writer_identity`; see the
+ // `unique_writer_identity` field.
+ rpc UpdateSink(UpdateSinkRequest) returns (LogSink) {
+ option (google.api.http) = {
+ put: "/v2/{sink_name=*/*/sinks/*}"
+ body: "sink"
+ additional_bindings {
+ put: "/v2/{sink_name=projects/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ put: "/v2/{sink_name=organizations/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ put: "/v2/{sink_name=folders/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ put: "/v2/{sink_name=billingAccounts/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ patch: "/v2/{sink_name=projects/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ patch: "/v2/{sink_name=organizations/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ patch: "/v2/{sink_name=folders/*/sinks/*}"
+ body: "sink"
+ }
+ additional_bindings {
+ patch: "/v2/{sink_name=billingAccounts/*/sinks/*}"
+ body: "sink"
+ }
+ };
+ option (google.api.method_signature) = "sink_name,sink,update_mask";
+ option (google.api.method_signature) = "sink_name,sink";
+ }
+
+ // Deletes a sink. If the sink has a unique `writer_identity`, then that
+ // service account is also deleted.
+ rpc DeleteSink(DeleteSinkRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = {
+ delete: "/v2/{sink_name=*/*/sinks/*}"
+ additional_bindings {
+ delete: "/v2/{sink_name=projects/*/sinks/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{sink_name=organizations/*/sinks/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{sink_name=folders/*/sinks/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{sink_name=billingAccounts/*/sinks/*}"
+ }
+ };
+ option (google.api.method_signature) = "sink_name";
+ }
+
+ // Lists all the exclusions on the _Default sink in a parent resource.
+ rpc ListExclusions(ListExclusionsRequest) returns (ListExclusionsResponse) {
+ option (google.api.http) = {
+ get: "/v2/{parent=*/*}/exclusions"
+ additional_bindings {
+ get: "/v2/{parent=projects/*}/exclusions"
+ }
+ additional_bindings {
+ get: "/v2/{parent=organizations/*}/exclusions"
+ }
+ additional_bindings {
+ get: "/v2/{parent=folders/*}/exclusions"
+ }
+ additional_bindings {
+ get: "/v2/{parent=billingAccounts/*}/exclusions"
+ }
+ };
+ option (google.api.method_signature) = "parent";
+ }
+
+ // Gets the description of an exclusion in the _Default sink.
+ rpc GetExclusion(GetExclusionRequest) returns (LogExclusion) {
+ option (google.api.http) = {
+ get: "/v2/{name=*/*/exclusions/*}"
+ additional_bindings {
+ get: "/v2/{name=projects/*/exclusions/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=organizations/*/exclusions/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=folders/*/exclusions/*}"
+ }
+ additional_bindings {
+ get: "/v2/{name=billingAccounts/*/exclusions/*}"
+ }
+ };
+ option (google.api.method_signature) = "name";
+ }
+
+ // Creates a new exclusion in the _Default sink in a specified parent
+ // resource. Only log entries belonging to that resource can be excluded. You
+ // can have up to 10 exclusions in a resource.
+ rpc CreateExclusion(CreateExclusionRequest) returns (LogExclusion) {
+ option (google.api.http) = {
+ post: "/v2/{parent=*/*}/exclusions"
+ body: "exclusion"
+ additional_bindings {
+ post: "/v2/{parent=projects/*}/exclusions"
+ body: "exclusion"
+ }
+ additional_bindings {
+ post: "/v2/{parent=organizations/*}/exclusions"
+ body: "exclusion"
+ }
+ additional_bindings {
+ post: "/v2/{parent=folders/*}/exclusions"
+ body: "exclusion"
+ }
+ additional_bindings {
+ post: "/v2/{parent=billingAccounts/*}/exclusions"
+ body: "exclusion"
+ }
+ };
+ option (google.api.method_signature) = "parent,exclusion";
+ }
+
+ // Changes one or more properties of an existing exclusion in the _Default
+ // sink.
+ rpc UpdateExclusion(UpdateExclusionRequest) returns (LogExclusion) {
+ option (google.api.http) = {
+ patch: "/v2/{name=*/*/exclusions/*}"
+ body: "exclusion"
+ additional_bindings {
+ patch: "/v2/{name=projects/*/exclusions/*}"
+ body: "exclusion"
+ }
+ additional_bindings {
+ patch: "/v2/{name=organizations/*/exclusions/*}"
+ body: "exclusion"
+ }
+ additional_bindings {
+ patch: "/v2/{name=folders/*/exclusions/*}"
+ body: "exclusion"
+ }
+ additional_bindings {
+ patch: "/v2/{name=billingAccounts/*/exclusions/*}"
+ body: "exclusion"
+ }
+ };
+ option (google.api.method_signature) = "name,exclusion,update_mask";
+ }
+
+ // Deletes an exclusion in the _Default sink.
+ rpc DeleteExclusion(DeleteExclusionRequest) returns (google.protobuf.Empty) {
+ option (google.api.http) = {
+ delete: "/v2/{name=*/*/exclusions/*}"
+ additional_bindings {
+ delete: "/v2/{name=projects/*/exclusions/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=organizations/*/exclusions/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=folders/*/exclusions/*}"
+ }
+ additional_bindings {
+ delete: "/v2/{name=billingAccounts/*/exclusions/*}"
+ }
+ };
+ option (google.api.method_signature) = "name";
+ }
+
+ // Gets the Logging CMEK settings for the given resource.
+ //
+ // Note: CMEK for the Log Router can be configured for Google Cloud projects,
+ // folders, organizations and billing accounts. Once configured for an
+ // organization, it applies to all projects and folders in the Google Cloud
+ // organization.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ rpc GetCmekSettings(GetCmekSettingsRequest) returns (CmekSettings) {
+ option (google.api.http) = {
+ get: "/v2/{name=*/*}/cmekSettings"
+ additional_bindings {
+ get: "/v2/{name=projects/*}/cmekSettings"
+ }
+ additional_bindings {
+ get: "/v2/{name=organizations/*}/cmekSettings"
+ }
+ additional_bindings {
+ get: "/v2/{name=folders/*}/cmekSettings"
+ }
+ additional_bindings {
+ get: "/v2/{name=billingAccounts/*}/cmekSettings"
+ }
+ };
+ }
+
+ // Updates the Log Router CMEK settings for the given resource.
+ //
+ // Note: CMEK for the Log Router can currently only be configured for Google
+ // Cloud organizations. Once configured, it applies to all projects and
+ // folders in the Google Cloud organization.
+ //
+ // [UpdateCmekSettings][google.logging.v2.ConfigServiceV2.UpdateCmekSettings]
+ // will fail if 1) `kms_key_name` is invalid, or 2) the associated service
+ // account does not have the required
+ // `roles/cloudkms.cryptoKeyEncrypterDecrypter` role assigned for the key, or
+ // 3) access to the key is disabled.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ rpc UpdateCmekSettings(UpdateCmekSettingsRequest) returns (CmekSettings) {
+ option (google.api.http) = {
+ patch: "/v2/{name=*/*}/cmekSettings"
+ body: "cmek_settings"
+ additional_bindings {
+ patch: "/v2/{name=organizations/*}/cmekSettings"
+ body: "cmek_settings"
+ }
+ };
+ }
+
+ // Gets the Log Router settings for the given resource.
+ //
+ // Note: Settings for the Log Router can be get for Google Cloud projects,
+ // folders, organizations and billing accounts. Currently it can only be
+ // configured for organizations. Once configured for an organization, it
+ // applies to all projects and folders in the Google Cloud organization.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ rpc GetSettings(GetSettingsRequest) returns (Settings) {
+ option (google.api.http) = {
+ get: "/v2/{name=*/*}/settings"
+ additional_bindings {
+ get: "/v2/{name=projects/*}/settings"
+ }
+ additional_bindings {
+ get: "/v2/{name=organizations/*}/settings"
+ }
+ additional_bindings {
+ get: "/v2/{name=folders/*}/settings"
+ }
+ additional_bindings {
+ get: "/v2/{name=billingAccounts/*}/settings"
+ }
+ };
+ option (google.api.method_signature) = "name";
+ }
+
+ // Updates the Log Router settings for the given resource.
+ //
+ // Note: Settings for the Log Router can currently only be configured for
+ // Google Cloud organizations. Once configured, it applies to all projects and
+ // folders in the Google Cloud organization.
+ //
+ // [UpdateSettings][google.logging.v2.ConfigServiceV2.UpdateSettings]
+ // will fail if 1) `kms_key_name` is invalid, or 2) the associated service
+ // account does not have the required
+ // `roles/cloudkms.cryptoKeyEncrypterDecrypter` role assigned for the key, or
+ // 3) access to the key is disabled. 4) `location_id` is not supported by
+ // Logging. 5) `location_id` violate OrgPolicy.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ rpc UpdateSettings(UpdateSettingsRequest) returns (Settings) {
+ option (google.api.http) = {
+ patch: "/v2/{name=*/*}/settings"
+ body: "settings"
+ additional_bindings {
+ patch: "/v2/{name=organizations/*}/settings"
+ body: "settings"
+ }
+ additional_bindings {
+ patch: "/v2/{name=folders/*}/settings"
+ body: "settings"
+ }
+ };
+ option (google.api.method_signature) = "settings,update_mask";
+ }
+
+ // Copies a set of log entries from a log bucket to a Cloud Storage bucket.
+ rpc CopyLogEntries(CopyLogEntriesRequest) returns (google.longrunning.Operation) {
+ option (google.api.http) = {
+ post: "/v2/entries:copy"
+ body: "*"
+ };
+ option (google.longrunning.operation_info) = {
+ response_type: "CopyLogEntriesResponse"
+ metadata_type: "CopyLogEntriesMetadata"
+ };
+ }
+}
+
+// Describes a repository in which log entries are stored.
+message LogBucket {
+ option (google.api.resource) = {
+ type: "logging.googleapis.com/LogBucket"
+ pattern: "projects/{project}/locations/{location}/buckets/{bucket}"
+ pattern: "organizations/{organization}/locations/{location}/buckets/{bucket}"
+ pattern: "folders/{folder}/locations/{location}/buckets/{bucket}"
+ pattern: "billingAccounts/{billing_account}/locations/{location}/buckets/{bucket}"
+ };
+
+ // Output only. The resource name of the bucket.
+ //
+ // For example:
+ //
+ // `projects/my-project/locations/global/buckets/my-bucket`
+ //
+ // For a list of supported locations, see [Supported
+ // Regions](https://cloud.google.com/logging/docs/region-support)
+ //
+ // For the location of `global` it is unspecified where log entries are
+ // actually stored.
+ //
+ // After a bucket has been created, the location cannot be changed.
+ string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Describes this bucket.
+ string description = 3;
+
+ // Output only. The creation timestamp of the bucket. This is not set for any of the
+ // default buckets.
+ google.protobuf.Timestamp create_time = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Output only. The last update timestamp of the bucket.
+ google.protobuf.Timestamp update_time = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Logs will be retained by default for this amount of time, after which they
+ // will automatically be deleted. The minimum retention period is 1 day. If
+ // this value is set to zero at bucket creation time, the default time of 30
+ // days will be used.
+ int32 retention_days = 11;
+
+ // Whether the bucket is locked.
+ //
+ // The retention period on a locked bucket cannot be changed. Locked buckets
+ // may only be deleted if they are empty.
+ bool locked = 9;
+
+ // Output only. The bucket lifecycle state.
+ LifecycleState lifecycle_state = 12 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Log entry field paths that are denied access in this bucket.
+ //
+ // The following fields and their children are eligible: `textPayload`,
+ // `jsonPayload`, `protoPayload`, `httpRequest`, `labels`, `sourceLocation`.
+ //
+ // Restricting a repeated field will restrict all values. Adding a parent will
+ // block all child fields. (e.g. `foo.bar` will block `foo.bar.baz`)
+ repeated string restricted_fields = 15;
+
+ // The CMEK settings of the log bucket. If present, new log entries written to
+ // this log bucket are encrypted using the CMEK key provided in this
+ // configuration. If a log bucket has CMEK settings, the CMEK settings cannot
+ // be disabled later by updating the log bucket. Changing the KMS key is
+ // allowed.
+ CmekSettings cmek_settings = 19;
+}
+
+// Describes a view over log entries in a bucket.
+message LogView {
+ option (google.api.resource) = {
+ type: "logging.googleapis.com/LogView"
+ pattern: "projects/{project}/locations/{location}/buckets/{bucket}/views/{view}"
+ pattern: "organizations/{organization}/locations/{location}/buckets/{bucket}/views/{view}"
+ pattern: "folders/{folder}/locations/{location}/buckets/{bucket}/views/{view}"
+ pattern: "billingAccounts/{billing_account}/locations/{location}/buckets/{bucket}/views/{view}"
+ };
+
+ // The resource name of the view.
+ //
+ // For example:
+ //
+ // `projects/my-project/locations/global/buckets/my-bucket/views/my-view`
+ string name = 1;
+
+ // Describes this view.
+ string description = 3;
+
+ // Output only. The creation timestamp of the view.
+ google.protobuf.Timestamp create_time = 4 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Output only. The last update timestamp of the view.
+ google.protobuf.Timestamp update_time = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Filter that restricts which log entries in a bucket are visible in this
+ // view.
+ //
+ // Filters are restricted to be a logical AND of ==/!= of any of the
+ // following:
+ //
+ // - originating project/folder/organization/billing account.
+ // - resource type
+ // - log id
+ //
+ // For example:
+ //
+ // SOURCE("projects/myproject") AND resource.type = "gce_instance"
+ // AND LOG_ID("stdout")
+ string filter = 7;
+}
+
+// Describes a sink used to export log entries to one of the following
+// destinations in any project: a Cloud Storage bucket, a BigQuery dataset, a
+// Pub/Sub topic or a Cloud Logging log bucket. A logs filter controls which log
+// entries are exported. The sink must be created within a project,
+// organization, billing account, or folder.
+message LogSink {
+ option (google.api.resource) = {
+ type: "logging.googleapis.com/LogSink"
+ pattern: "projects/{project}/sinks/{sink}"
+ pattern: "organizations/{organization}/sinks/{sink}"
+ pattern: "folders/{folder}/sinks/{sink}"
+ pattern: "billingAccounts/{billing_account}/sinks/{sink}"
+ };
+
+ // Deprecated. This is unused.
+ enum VersionFormat {
+ // An unspecified format version that will default to V2.
+ VERSION_FORMAT_UNSPECIFIED = 0;
+
+ // `LogEntry` version 2 format.
+ V2 = 1;
+
+ // `LogEntry` version 1 format.
+ V1 = 2;
+ }
+
+ // Required. The client-assigned sink identifier, unique within the project.
+ //
+ // For example: `"my-syslog-errors-to-pubsub"`. Sink identifiers are limited
+ // to 100 characters and can include only the following characters: upper and
+ // lower-case alphanumeric characters, underscores, hyphens, and periods.
+ // First character has to be alphanumeric.
+ string name = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The export destination:
+ //
+ // "storage.googleapis.com/[GCS_BUCKET]"
+ // "bigquery.googleapis.com/projects/[PROJECT_ID]/datasets/[DATASET]"
+ // "pubsub.googleapis.com/projects/[PROJECT_ID]/topics/[TOPIC_ID]"
+ //
+ // The sink's `writer_identity`, set when the sink is created, must have
+ // permission to write to the destination or else the log entries are not
+ // exported. For more information, see
+ // [Exporting Logs with
+ // Sinks](https://cloud.google.com/logging/docs/api/tasks/exporting-logs).
+ string destination = 3 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "*"
+ }
+ ];
+
+ // Optional. An [advanced logs
+ // filter](https://cloud.google.com/logging/docs/view/advanced-queries). The
+ // only exported log entries are those that are in the resource owning the
+ // sink and that match the filter.
+ //
+ // For example:
+ //
+ // `logName="projects/[PROJECT_ID]/logs/[LOG_ID]" AND severity>=ERROR`
+ string filter = 5 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. A description of this sink.
+ //
+ // The maximum length of the description is 8000 characters.
+ string description = 18 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. If set to true, then this sink is disabled and it does not export any log
+ // entries.
+ bool disabled = 19 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. Log entries that match any of these exclusion filters will not be exported.
+ //
+ // If a log entry is matched by both `filter` and one of `exclusion_filters`
+ // it will not be exported.
+ repeated LogExclusion exclusions = 16 [(google.api.field_behavior) = OPTIONAL];
+
+ // Deprecated. This field is unused.
+ VersionFormat output_version_format = 6 [deprecated = true];
+
+ // Output only. An IAM identity—a service account or group—under which Cloud
+ // Logging writes the exported log entries to the sink's destination. This
+ // field is set by
+ // [sinks.create][google.logging.v2.ConfigServiceV2.CreateSink] and
+ // [sinks.update][google.logging.v2.ConfigServiceV2.UpdateSink] based on the
+ // value of `unique_writer_identity` in those methods.
+ //
+ // Until you grant this identity write-access to the destination, log entry
+ // exports from this sink will fail. For more information, see [Granting
+ // Access for a
+ // Resource](https://cloud.google.com/iam/docs/granting-roles-to-service-accounts#granting_access_to_a_service_account_for_a_resource).
+ // Consult the destination service's documentation to determine the
+ // appropriate IAM roles to assign to the identity.
+ //
+ // Sinks that have a destination that is a log bucket in the same project as
+ // the sink do not have a writer_identity and no additional permissions are
+ // required.
+ string writer_identity = 8 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Optional. This field applies only to sinks owned by organizations and folders. If the
+ // field is false, the default, only the logs owned by the sink's parent
+ // resource are available for export. If the field is true, then log entries
+ // from all the projects, folders, and billing accounts contained in the
+ // sink's parent resource are also available for export. Whether a particular
+ // log entry from the children is exported depends on the sink's filter
+ // expression.
+ //
+ // For example, if this field is true, then the filter
+ // `resource.type=gce_instance` would export all Compute Engine VM instance
+ // log entries from all projects in the sink's parent.
+ //
+ // To only export entries from certain child projects, filter on the project
+ // part of the log name:
+ //
+ // logName:("projects/test-project1/" OR "projects/test-project2/") AND
+ // resource.type=gce_instance
+ bool include_children = 9 [(google.api.field_behavior) = OPTIONAL];
+
+ // Destination dependent options.
+ oneof options {
+ // Optional. Options that affect sinks exporting data to BigQuery.
+ BigQueryOptions bigquery_options = 12 [(google.api.field_behavior) = OPTIONAL];
+ }
+
+ // Output only. The creation timestamp of the sink.
+ //
+ // This field may not be present for older sinks.
+ google.protobuf.Timestamp create_time = 13 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Output only. The last update timestamp of the sink.
+ //
+ // This field may not be present for older sinks.
+ google.protobuf.Timestamp update_time = 14 [(google.api.field_behavior) = OUTPUT_ONLY];
+}
+
+// Options that change functionality of a sink exporting data to BigQuery.
+message BigQueryOptions {
+ // Optional. Whether to use [BigQuery's partition
+ // tables](https://cloud.google.com/bigquery/docs/partitioned-tables). By
+ // default, Cloud Logging creates dated tables based on the log entries'
+ // timestamps, e.g. syslog_20170523. With partitioned tables the date suffix
+ // is no longer present and [special query
+ // syntax](https://cloud.google.com/bigquery/docs/querying-partitioned-tables)
+ // has to be used instead. In both cases, tables are sharded based on UTC
+ // timezone.
+ bool use_partitioned_tables = 1 [(google.api.field_behavior) = OPTIONAL];
+
+ // Output only. True if new timestamp column based partitioning is in use, false if legacy
+ // ingestion-time partitioning is in use.
+ //
+ // All new sinks will have this field set true and will use timestamp column
+ // based partitioning. If use_partitioned_tables is false, this value has no
+ // meaning and will be false. Legacy sinks using partitioned tables will have
+ // this field set to false.
+ bool uses_timestamp_column_partitioning = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
+}
+
+// The parameters to `ListBuckets`.
+message ListBucketsRequest {
+ // Required. The parent resource whose buckets are to be listed:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]"
+ // "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]"
+ // "folders/[FOLDER_ID]/locations/[LOCATION_ID]"
+ //
+ // Note: The locations portion of the resource must be specified, but
+ // supplying the character `-` in place of [LOCATION_ID] will return all
+ // buckets.
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "logging.googleapis.com/LogBucket"
+ }
+ ];
+
+ // Optional. If present, then retrieve the next batch of results from the preceding call
+ // to this method. `pageToken` must be the value of `nextPageToken` from the
+ // previous response. The values of other method parameters should be
+ // identical to those in the previous call.
+ string page_token = 2 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. The maximum number of results to return from this request. Non-positive
+ // values are ignored. The presence of `nextPageToken` in the response
+ // indicates that more results might be available.
+ int32 page_size = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// The response from ListBuckets.
+message ListBucketsResponse {
+ // A list of buckets.
+ repeated LogBucket buckets = 1;
+
+ // If there might be more results than appear in this response, then
+ // `nextPageToken` is included. To get the next set of results, call the same
+ // method again using the value of `nextPageToken` as `pageToken`.
+ string next_page_token = 2;
+}
+
+// The parameters to `CreateBucket`.
+message CreateBucketRequest {
+ // Required. The resource in which to create the log bucket:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global"`
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "logging.googleapis.com/LogBucket"
+ }
+ ];
+
+ // Required. A client-assigned identifier such as `"my-bucket"`. Identifiers are limited
+ // to 100 characters and can include only letters, digits, underscores,
+ // hyphens, and periods.
+ string bucket_id = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The new bucket. The region specified in the new bucket must be compliant
+ // with any Location Restriction Org Policy. The name field in the bucket is
+ // ignored.
+ LogBucket bucket = 3 [(google.api.field_behavior) = REQUIRED];
+}
+
+// The parameters to `UpdateBucket`.
+message UpdateBucketRequest {
+ // Required. The full resource name of the bucket to update.
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogBucket"
+ }
+ ];
+
+ // Required. The updated bucket.
+ LogBucket bucket = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. Field mask that specifies the fields in `bucket` that need an update. A
+ // bucket field will be overwritten if, and only if, it is in the update mask.
+ // `name` and output only fields cannot be updated.
+ //
+ // For a detailed `FieldMask` definition, see:
+ // https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#google.protobuf.FieldMask
+ //
+ // For example: `updateMask=retention_days`
+ google.protobuf.FieldMask update_mask = 4 [(google.api.field_behavior) = REQUIRED];
+}
+
+// The parameters to `GetBucket`.
+message GetBucketRequest {
+ // Required. The resource name of the bucket:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogBucket"
+ }
+ ];
+}
+
+// The parameters to `DeleteBucket`.
+message DeleteBucketRequest {
+ // Required. The full resource name of the bucket to delete.
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogBucket"
+ }
+ ];
+}
+
+// The parameters to `UndeleteBucket`.
+message UndeleteBucketRequest {
+ // Required. The full resource name of the bucket to undelete.
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "organizations/[ORGANIZATION_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ // "folders/[FOLDER_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogBucket"
+ }
+ ];
+}
+
+// The parameters to `ListViews`.
+message ListViewsRequest {
+ // Required. The bucket whose views are to be listed:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"
+ string parent = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. If present, then retrieve the next batch of results from the preceding call
+ // to this method. `pageToken` must be the value of `nextPageToken` from the
+ // previous response. The values of other method parameters should be
+ // identical to those in the previous call.
+ string page_token = 2 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. The maximum number of results to return from this request.
+ //
+ // Non-positive values are ignored. The presence of `nextPageToken` in the
+ // response indicates that more results might be available.
+ int32 page_size = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// The response from ListViews.
+message ListViewsResponse {
+ // A list of views.
+ repeated LogView views = 1;
+
+ // If there might be more results than appear in this response, then
+ // `nextPageToken` is included. To get the next set of results, call the same
+ // method again using the value of `nextPageToken` as `pageToken`.
+ string next_page_token = 2;
+}
+
+// The parameters to `CreateView`.
+message CreateViewRequest {
+ // Required. The bucket in which to create the view
+ //
+ // `"projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]"`
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket"`
+ string parent = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The id to use for this view.
+ string view_id = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The new view.
+ LogView view = 3 [(google.api.field_behavior) = REQUIRED];
+}
+
+// The parameters to `UpdateView`.
+message UpdateViewRequest {
+ // Required. The full resource name of the view to update
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]/views/[VIEW_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket/views/my-view"`
+ string name = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The updated view.
+ LogView view = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. Field mask that specifies the fields in `view` that need
+ // an update. A field will be overwritten if, and only if, it is
+ // in the update mask. `name` and output only fields cannot be updated.
+ //
+ // For a detailed `FieldMask` definition, see
+ // https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#google.protobuf.FieldMask
+ //
+ // For example: `updateMask=filter`
+ google.protobuf.FieldMask update_mask = 4 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// The parameters to `GetView`.
+message GetViewRequest {
+ // Required. The resource name of the policy:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]/views/[VIEW_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket/views/my-view"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogView"
+ }
+ ];
+}
+
+// The parameters to `DeleteView`.
+message DeleteViewRequest {
+ // Required. The full resource name of the view to delete:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION_ID]/buckets/[BUCKET_ID]/views/[VIEW_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-bucket/views/my-view"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogView"
+ }
+ ];
+}
+
+// The parameters to `ListSinks`.
+message ListSinksRequest {
+ // Required. The parent resource whose sinks are to be listed:
+ //
+ // "projects/[PROJECT_ID]"
+ // "organizations/[ORGANIZATION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]"
+ // "folders/[FOLDER_ID]"
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "logging.googleapis.com/LogSink"
+ }
+ ];
+
+ // Optional. If present, then retrieve the next batch of results from the
+ // preceding call to this method. `pageToken` must be the value of
+ // `nextPageToken` from the previous response. The values of other method
+ // parameters should be identical to those in the previous call.
+ string page_token = 2 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. The maximum number of results to return from this request.
+ // Non-positive values are ignored. The presence of `nextPageToken` in the
+ // response indicates that more results might be available.
+ int32 page_size = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// Result returned from `ListSinks`.
+message ListSinksResponse {
+ // A list of sinks.
+ repeated LogSink sinks = 1;
+
+ // If there might be more results than appear in this response, then
+ // `nextPageToken` is included. To get the next set of results, call the same
+ // method again using the value of `nextPageToken` as `pageToken`.
+ string next_page_token = 2;
+}
+
+// The parameters to `GetSink`.
+message GetSinkRequest {
+ // Required. The resource name of the sink:
+ //
+ // "projects/[PROJECT_ID]/sinks/[SINK_ID]"
+ // "organizations/[ORGANIZATION_ID]/sinks/[SINK_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/sinks/[SINK_ID]"
+ // "folders/[FOLDER_ID]/sinks/[SINK_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/sinks/my-sink"`
+ string sink_name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogSink"
+ }
+ ];
+}
+
+// The parameters to `CreateSink`.
+message CreateSinkRequest {
+ // Required. The resource in which to create the sink:
+ //
+ // "projects/[PROJECT_ID]"
+ // "organizations/[ORGANIZATION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]"
+ // "folders/[FOLDER_ID]"
+ //
+ // For examples:
+ //
+ // `"projects/my-project"`
+ // `"organizations/123456789"`
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "logging.googleapis.com/LogSink"
+ }
+ ];
+
+ // Required. The new sink, whose `name` parameter is a sink identifier that
+ // is not already in use.
+ LogSink sink = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. Determines the kind of IAM identity returned as `writer_identity`
+ // in the new sink. If this value is omitted or set to false, and if the
+ // sink's parent is a project, then the value returned as `writer_identity` is
+ // the same group or service account used by Cloud Logging before the addition
+ // of writer identities to this API. The sink's destination must be in the
+ // same project as the sink itself.
+ //
+ // If this field is set to true, or if the sink is owned by a non-project
+ // resource such as an organization, then the value of `writer_identity` will
+ // be a unique service account used only for exports from the new sink. For
+ // more information, see `writer_identity` in [LogSink][google.logging.v2.LogSink].
+ bool unique_writer_identity = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// The parameters to `UpdateSink`.
+message UpdateSinkRequest {
+ // Required. The full resource name of the sink to update, including the parent
+ // resource and the sink identifier:
+ //
+ // "projects/[PROJECT_ID]/sinks/[SINK_ID]"
+ // "organizations/[ORGANIZATION_ID]/sinks/[SINK_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/sinks/[SINK_ID]"
+ // "folders/[FOLDER_ID]/sinks/[SINK_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/sinks/my-sink"`
+ string sink_name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogSink"
+ }
+ ];
+
+ // Required. The updated sink, whose name is the same identifier that appears as part
+ // of `sink_name`.
+ LogSink sink = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. See [sinks.create][google.logging.v2.ConfigServiceV2.CreateSink]
+ // for a description of this field. When updating a sink, the effect of this
+ // field on the value of `writer_identity` in the updated sink depends on both
+ // the old and new values of this field:
+ //
+ // + If the old and new values of this field are both false or both true,
+ // then there is no change to the sink's `writer_identity`.
+ // + If the old value is false and the new value is true, then
+ // `writer_identity` is changed to a unique service account.
+ // + It is an error if the old value is true and the new value is
+ // set to false or defaulted to false.
+ bool unique_writer_identity = 3 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. Field mask that specifies the fields in `sink` that need
+ // an update. A sink field will be overwritten if, and only if, it is
+ // in the update mask. `name` and output only fields cannot be updated.
+ //
+ // An empty `updateMask` is temporarily treated as using the following mask
+ // for backwards compatibility purposes:
+ //
+ // `destination,filter,includeChildren`
+ //
+ // At some point in the future, behavior will be removed and specifying an
+ // empty `updateMask` will be an error.
+ //
+ // For a detailed `FieldMask` definition, see
+ // https://developers.google.com/protocol-buffers/docs/reference/google.protobuf#google.protobuf.FieldMask
+ //
+ // For example: `updateMask=filter`
+ google.protobuf.FieldMask update_mask = 4 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// The parameters to `DeleteSink`.
+message DeleteSinkRequest {
+ // Required. The full resource name of the sink to delete, including the parent
+ // resource and the sink identifier:
+ //
+ // "projects/[PROJECT_ID]/sinks/[SINK_ID]"
+ // "organizations/[ORGANIZATION_ID]/sinks/[SINK_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/sinks/[SINK_ID]"
+ // "folders/[FOLDER_ID]/sinks/[SINK_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/sinks/my-sink"`
+ string sink_name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogSink"
+ }
+ ];
+}
+
+// Specifies a set of log entries that are filtered out by a sink. If
+// your Google Cloud resource receives a large volume of log entries, you can
+// use exclusions to reduce your chargeable logs. Note that exclusions on
+// organization-level and folder-level sinks don't apply to child resources.
+// Note also that you cannot modify the _Required sink or exclude logs from it.
+message LogExclusion {
+ option (google.api.resource) = {
+ type: "logging.googleapis.com/LogExclusion"
+ pattern: "projects/{project}/exclusions/{exclusion}"
+ pattern: "organizations/{organization}/exclusions/{exclusion}"
+ pattern: "folders/{folder}/exclusions/{exclusion}"
+ pattern: "billingAccounts/{billing_account}/exclusions/{exclusion}"
+ };
+
+ // Required. A client-assigned identifier, such as `"load-balancer-exclusion"`.
+ // Identifiers are limited to 100 characters and can include only letters,
+ // digits, underscores, hyphens, and periods. First character has to be
+ // alphanumeric.
+ string name = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. A description of this exclusion.
+ string description = 2 [(google.api.field_behavior) = OPTIONAL];
+
+ // Required. An [advanced logs
+ // filter](https://cloud.google.com/logging/docs/view/advanced-queries) that
+ // matches the log entries to be excluded. By using the [sample
+ // function](https://cloud.google.com/logging/docs/view/advanced-queries#sample),
+ // you can exclude less than 100% of the matching log entries.
+ //
+ // For example, the following query matches 99% of low-severity log entries
+ // from Google Cloud Storage buckets:
+ //
+ // `resource.type=gcs_bucket severity<ERROR sample(insertId, 0.99)`
+ string filter = 3 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. If set to True, then this exclusion is disabled and it does not
+ // exclude any log entries. You can [update an
+ // exclusion][google.logging.v2.ConfigServiceV2.UpdateExclusion] to change the
+ // value of this field.
+ bool disabled = 4 [(google.api.field_behavior) = OPTIONAL];
+
+ // Output only. The creation timestamp of the exclusion.
+ //
+ // This field may not be present for older exclusions.
+ google.protobuf.Timestamp create_time = 5 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Output only. The last update timestamp of the exclusion.
+ //
+ // This field may not be present for older exclusions.
+ google.protobuf.Timestamp update_time = 6 [(google.api.field_behavior) = OUTPUT_ONLY];
+}
+
+// The parameters to `ListExclusions`.
+message ListExclusionsRequest {
+ // Required. The parent resource whose exclusions are to be listed.
+ //
+ // "projects/[PROJECT_ID]"
+ // "organizations/[ORGANIZATION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]"
+ // "folders/[FOLDER_ID]"
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "logging.googleapis.com/LogExclusion"
+ }
+ ];
+
+ // Optional. If present, then retrieve the next batch of results from the
+ // preceding call to this method. `pageToken` must be the value of
+ // `nextPageToken` from the previous response. The values of other method
+ // parameters should be identical to those in the previous call.
+ string page_token = 2 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. The maximum number of results to return from this request.
+ // Non-positive values are ignored. The presence of `nextPageToken` in the
+ // response indicates that more results might be available.
+ int32 page_size = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// Result returned from `ListExclusions`.
+message ListExclusionsResponse {
+ // A list of exclusions.
+ repeated LogExclusion exclusions = 1;
+
+ // If there might be more results than appear in this response, then
+ // `nextPageToken` is included. To get the next set of results, call the same
+ // method again using the value of `nextPageToken` as `pageToken`.
+ string next_page_token = 2;
+}
+
+// The parameters to `GetExclusion`.
+message GetExclusionRequest {
+ // Required. The resource name of an existing exclusion:
+ //
+ // "projects/[PROJECT_ID]/exclusions/[EXCLUSION_ID]"
+ // "organizations/[ORGANIZATION_ID]/exclusions/[EXCLUSION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/exclusions/[EXCLUSION_ID]"
+ // "folders/[FOLDER_ID]/exclusions/[EXCLUSION_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/exclusions/my-exclusion"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogExclusion"
+ }
+ ];
+}
+
+// The parameters to `CreateExclusion`.
+message CreateExclusionRequest {
+ // Required. The parent resource in which to create the exclusion:
+ //
+ // "projects/[PROJECT_ID]"
+ // "organizations/[ORGANIZATION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]"
+ // "folders/[FOLDER_ID]"
+ //
+ // For examples:
+ //
+ // `"projects/my-logging-project"`
+ // `"organizations/123456789"`
+ string parent = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ child_type: "logging.googleapis.com/LogExclusion"
+ }
+ ];
+
+ // Required. The new exclusion, whose `name` parameter is an exclusion name
+ // that is not already used in the parent resource.
+ LogExclusion exclusion = 2 [(google.api.field_behavior) = REQUIRED];
+}
+
+// The parameters to `UpdateExclusion`.
+message UpdateExclusionRequest {
+ // Required. The resource name of the exclusion to update:
+ //
+ // "projects/[PROJECT_ID]/exclusions/[EXCLUSION_ID]"
+ // "organizations/[ORGANIZATION_ID]/exclusions/[EXCLUSION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/exclusions/[EXCLUSION_ID]"
+ // "folders/[FOLDER_ID]/exclusions/[EXCLUSION_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/exclusions/my-exclusion"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogExclusion"
+ }
+ ];
+
+ // Required. New values for the existing exclusion. Only the fields specified in
+ // `update_mask` are relevant.
+ LogExclusion exclusion = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. A non-empty list of fields to change in the existing exclusion. New values
+ // for the fields are taken from the corresponding fields in the
+ // [LogExclusion][google.logging.v2.LogExclusion] included in this request. Fields not mentioned in
+ // `update_mask` are not changed and are ignored in the request.
+ //
+ // For example, to change the filter and description of an exclusion,
+ // specify an `update_mask` of `"filter,description"`.
+ google.protobuf.FieldMask update_mask = 3 [(google.api.field_behavior) = REQUIRED];
+}
+
+// The parameters to `DeleteExclusion`.
+message DeleteExclusionRequest {
+ // Required. The resource name of an existing exclusion to delete:
+ //
+ // "projects/[PROJECT_ID]/exclusions/[EXCLUSION_ID]"
+ // "organizations/[ORGANIZATION_ID]/exclusions/[EXCLUSION_ID]"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/exclusions/[EXCLUSION_ID]"
+ // "folders/[FOLDER_ID]/exclusions/[EXCLUSION_ID]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/exclusions/my-exclusion"`
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/LogExclusion"
+ }
+ ];
+}
+
+// The parameters to
+// [GetCmekSettings][google.logging.v2.ConfigServiceV2.GetCmekSettings].
+//
+// See [Enabling CMEK for Log
+// Router](https://cloud.google.com/logging/docs/routing/managed-encryption) for
+// more information.
+message GetCmekSettingsRequest {
+ // Required. The resource for which to retrieve CMEK settings.
+ //
+ // "projects/[PROJECT_ID]/cmekSettings"
+ // "organizations/[ORGANIZATION_ID]/cmekSettings"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/cmekSettings"
+ // "folders/[FOLDER_ID]/cmekSettings"
+ //
+ // For example:
+ //
+ // `"organizations/12345/cmekSettings"`
+ //
+ // Note: CMEK for the Log Router can be configured for Google Cloud projects,
+ // folders, organizations and billing accounts. Once configured for an
+ // organization, it applies to all projects and folders in the Google Cloud
+ // organization.
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/CmekSettings"
+ }
+ ];
+}
+
+// The parameters to
+// [UpdateCmekSettings][google.logging.v2.ConfigServiceV2.UpdateCmekSettings].
+//
+// See [Enabling CMEK for Log
+// Router](https://cloud.google.com/logging/docs/routing/managed-encryption) for
+// more information.
+message UpdateCmekSettingsRequest {
+ // Required. The resource name for the CMEK settings to update.
+ //
+ // "projects/[PROJECT_ID]/cmekSettings"
+ // "organizations/[ORGANIZATION_ID]/cmekSettings"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/cmekSettings"
+ // "folders/[FOLDER_ID]/cmekSettings"
+ //
+ // For example:
+ //
+ // `"organizations/12345/cmekSettings"`
+ //
+ // Note: CMEK for the Log Router can currently only be configured for Google
+ // Cloud organizations. Once configured, it applies to all projects and
+ // folders in the Google Cloud organization.
+ string name = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The CMEK settings to update.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ CmekSettings cmek_settings = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. Field mask identifying which fields from `cmek_settings` should
+ // be updated. A field will be overwritten if and only if it is in the update
+ // mask. Output only fields cannot be updated.
+ //
+ // See [FieldMask][google.protobuf.FieldMask] for more information.
+ //
+ // For example: `"updateMask=kmsKeyName"`
+ google.protobuf.FieldMask update_mask = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// Describes the customer-managed encryption key (CMEK) settings associated with
+// a project, folder, organization, billing account, or flexible resource.
+//
+// Note: CMEK for the Log Router can currently only be configured for Google
+// Cloud organizations. Once configured, it applies to all projects and folders
+// in the Google Cloud organization.
+//
+// See [Enabling CMEK for Log
+// Router](https://cloud.google.com/logging/docs/routing/managed-encryption) for
+// more information.
+message CmekSettings {
+ option (google.api.resource) = {
+ type: "logging.googleapis.com/CmekSettings"
+ pattern: "projects/{project}/cmekSettings"
+ pattern: "organizations/{organization}/cmekSettings"
+ pattern: "folders/{folder}/cmekSettings"
+ pattern: "billingAccounts/{billing_account}/cmekSettings"
+ };
+
+ // Output only. The resource name of the CMEK settings.
+ string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // The resource name for the configured Cloud KMS key.
+ //
+ // KMS key name format:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION]/keyRings/[KEYRING]/cryptoKeys/[KEY]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/us-central1/keyRings/my-ring/cryptoKeys/my-key"`
+ //
+ //
+ //
+ // To enable CMEK for the Log Router, set this field to a valid
+ // `kms_key_name` for which the associated service account has the required
+ // cloudkms.cryptoKeyEncrypterDecrypter roles assigned for the key.
+ //
+ // The Cloud KMS key used by the Log Router can be updated by changing the
+ // `kms_key_name` to a new valid key name or disabled by setting the key name
+ // to an empty string. Encryption operations that are in progress will be
+ // completed with the key that was in use when they started. Decryption
+ // operations will be completed using the key that was used at the time of
+ // encryption unless access to that key has been revoked.
+ //
+ // To disable CMEK for the Log Router, set this field to an empty string.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ string kms_key_name = 2;
+
+ // Output only. The service account that will be used by the Log Router to access your
+ // Cloud KMS key.
+ //
+ // Before enabling CMEK for Log Router, you must first assign the
+ // cloudkms.cryptoKeyEncrypterDecrypter role to the service account that
+ // the Log Router will use to access your Cloud KMS key. Use
+ // [GetCmekSettings][google.logging.v2.ConfigServiceV2.GetCmekSettings] to
+ // obtain the service account ID.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ string service_account_id = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
+}
+
+// The parameters to
+// [GetSettings][google.logging.v2.ConfigServiceV2.GetSettings].
+//
+// See [Enabling CMEK for Log
+// Router](https://cloud.google.com/logging/docs/routing/managed-encryption) for
+// more information.
+message GetSettingsRequest {
+ // Required. The resource for which to retrieve settings.
+ //
+ // "projects/[PROJECT_ID]/settings"
+ // "organizations/[ORGANIZATION_ID]/settings"
+ // "billingAccounts/[BILLING_ACCOUNT_ID]/settings"
+ // "folders/[FOLDER_ID]/settings"
+ //
+ // For example:
+ //
+ // `"organizations/12345/settings"`
+ //
+ // Note: Settings for the Log Router can be get for Google Cloud projects,
+ // folders, organizations and billing accounts. Currently it can only be
+ // configured for organizations. Once configured for an organization, it
+ // applies to all projects and folders in the Google Cloud organization.
+ string name = 1 [
+ (google.api.field_behavior) = REQUIRED,
+ (google.api.resource_reference) = {
+ type: "logging.googleapis.com/Settings"
+ }
+ ];
+}
+
+// The parameters to
+// [UpdateSettings][google.logging.v2.ConfigServiceV2.UpdateSettings].
+//
+// See [Enabling CMEK for Log
+// Router](https://cloud.google.com/logging/docs/routing/managed-encryption) for
+// more information.
+message UpdateSettingsRequest {
+ // Required. The resource name for the settings to update.
+ //
+ // "organizations/[ORGANIZATION_ID]/settings"
+ //
+ // For example:
+ //
+ // `"organizations/12345/settings"`
+ //
+ // Note: Settings for the Log Router can currently only be configured for
+ // Google Cloud organizations. Once configured, it applies to all projects and
+ // folders in the Google Cloud organization.
+ string name = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Required. The settings to update.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ Settings settings = 2 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. Field mask identifying which fields from `settings` should
+ // be updated. A field will be overwritten if and only if it is in the update
+ // mask. Output only fields cannot be updated.
+ //
+ // See [FieldMask][google.protobuf.FieldMask] for more information.
+ //
+ // For example: `"updateMask=kmsKeyName"`
+ google.protobuf.FieldMask update_mask = 3 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// Describes the settings associated with a project, folder, organization,
+// billing account, or flexible resource.
+message Settings {
+ option (google.api.resource) = {
+ type: "logging.googleapis.com/Settings"
+ pattern: "projects/{project}/settings"
+ pattern: "organizations/{organization}/settings"
+ pattern: "folders/{folder}/settings"
+ pattern: "billingAccounts/{billing_account}/settings"
+ };
+
+ // Output only. The resource name of the settings.
+ string name = 1 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Optional. The resource name for the configured Cloud KMS key.
+ //
+ // KMS key name format:
+ //
+ // "projects/[PROJECT_ID]/locations/[LOCATION]/keyRings/[KEYRING]/cryptoKeys/[KEY]"
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/us-central1/keyRings/my-ring/cryptoKeys/my-key"`
+ //
+ //
+ //
+ // To enable CMEK for the Log Router, set this field to a valid
+ // `kms_key_name` for which the associated service account has the required
+ // `roles/cloudkms.cryptoKeyEncrypterDecrypter` role assigned for the key.
+ //
+ // The Cloud KMS key used by the Log Router can be updated by changing the
+ // `kms_key_name` to a new valid key name. Encryption operations that are in
+ // progress will be completed with the key that was in use when they started.
+ // Decryption operations will be completed using the key that was used at the
+ // time of encryption unless access to that key has been revoked.
+ //
+ // To disable CMEK for the Log Router, set this field to an empty string.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ string kms_key_name = 2 [(google.api.field_behavior) = OPTIONAL];
+
+ // Output only. The service account that will be used by the Log Router to access your
+ // Cloud KMS key.
+ //
+ // Before enabling CMEK for Log Router, you must first assign the role
+ // `roles/cloudkms.cryptoKeyEncrypterDecrypter` to the service account that
+ // the Log Router will use to access your Cloud KMS key. Use
+ // [GetSettings][google.logging.v2.ConfigServiceV2.GetSettings] to
+ // obtain the service account ID.
+ //
+ // See [Enabling CMEK for Log
+ // Router](https://cloud.google.com/logging/docs/routing/managed-encryption)
+ // for more information.
+ string kms_service_account_id = 3 [(google.api.field_behavior) = OUTPUT_ONLY];
+
+ // Optional. The Cloud region that will be used for _Default and _Required log buckets
+ // for newly created projects and folders. For example `europe-west1`.
+ // This setting does not affect the location of custom log buckets.
+ string storage_location = 4 [(google.api.field_behavior) = OPTIONAL];
+
+ // Optional. If set to true, the _Default sink in newly created projects and folders
+ // will created in a disabled state. This can be used to automatically disable
+ // log ingestion if there is already an aggregated sink configured in the
+ // hierarchy. The _Default sink can be re-enabled manually if needed.
+ bool disable_default_sink = 5 [(google.api.field_behavior) = OPTIONAL];
+}
+
+// The parameters to CopyLogEntries.
+message CopyLogEntriesRequest {
+ // Required. Log bucket from which to copy log entries.
+ //
+ // For example:
+ //
+ // `"projects/my-project/locations/global/buckets/my-source-bucket"`
+ string name = 1 [(google.api.field_behavior) = REQUIRED];
+
+ // Optional. A filter specifying which log entries to copy. The filter must be no more
+ // than 20k characters. An empty filter matches all log entries.
+ string filter = 3 [(google.api.field_behavior) = OPTIONAL];
+
+ // Required. Destination to which to copy log entries.
+ string destination = 4 [(google.api.field_behavior) = REQUIRED];
+}
+
+// Metadata for CopyLogEntries long running operations.
+message CopyLogEntriesMetadata {
+ // The create time of an operation.
+ google.protobuf.Timestamp start_time = 1;
+
+ // The end time of an operation.
+ google.protobuf.Timestamp end_time = 2;
+
+ // State of an operation.
+ OperationState state = 3;
+
+ // Identifies whether the user has requested cancellation of the operation.
+ bool cancellation_requested = 4;
+
+ // CopyLogEntries RPC request.
+ CopyLogEntriesRequest request = 5;
+
+ // Estimated progress of the operation (0 - 100%).
+ int32 progress = 6;
+
+ // The IAM identity of a service account that must be granted access to the
+ // destination.
+ //
+ // If the service account is not granted permission to the destination within
+ // an hour, the operation will be cancelled.
+ //
+ // For example: `"serviceAccount:foo@bar.com"`
+ string writer_identity = 7;
+}
+
+// Response type for CopyLogEntries long running operations.
+message CopyLogEntriesResponse {
+ // Number of log entries copied.
+ int64 log_entries_copied_count = 1;
+}
+
+// LogBucket lifecycle states.
+enum LifecycleState {
+ // Unspecified state. This is only used/useful for distinguishing unset
+ // values.
+ LIFECYCLE_STATE_UNSPECIFIED = 0;
+
+ // The normal and active state.
+ ACTIVE = 1;
+
+ // The resource has been marked for deletion by the user. For some resources
+ // (e.g. buckets), this can be reversed by an un-delete operation.
+ DELETE_REQUESTED = 2;
+}
+
+// List of different operation states.
+// High level state of the operation. This is used to report the job's
+// current state to the user. Once a long running operation is created,
+// the current state of the operation can be queried even before the
+// operation is finished and the final result is available.
+enum OperationState {
+ // Should not be used.
+ OPERATION_STATE_UNSPECIFIED = 0;
+
+ // The operation is scheduled.
+ OPERATION_STATE_SCHEDULED = 1;
+
+ // Waiting for necessary permissions.
+ OPERATION_STATE_WAITING_FOR_PERMISSIONS = 2;
+
+ // The operation is running.
+ OPERATION_STATE_RUNNING = 3;
+
+ // The operation was completed successfully.
+ OPERATION_STATE_SUCCEEDED = 4;
+
+ // The operation failed.
+ OPERATION_STATE_FAILED = 5;
+
+ // The operation was cancelled by the user.
+ OPERATION_STATE_CANCELLED = 6;
+}