| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548 | // 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.cloud.gkemulticloud.v1;import "google/api/annotations.proto";import "google/api/client.proto";import "google/api/field_behavior.proto";import "google/api/resource.proto";import "google/cloud/gkemulticloud/v1/aws_resources.proto";import "google/longrunning/operations.proto";import "google/protobuf/field_mask.proto";import "google/protobuf/timestamp.proto";option csharp_namespace = "Google.Cloud.GkeMultiCloud.V1";option go_package = "google.golang.org/genproto/googleapis/cloud/gkemulticloud/v1;gkemulticloud";option java_multiple_files = true;option java_outer_classname = "AwsServiceProto";option java_package = "com.google.cloud.gkemulticloud.v1";option php_namespace = "Google\\Cloud\\GkeMultiCloud\\V1";option ruby_package = "Google::Cloud::GkeMultiCloud::V1";// The AwsClusters API provides a single centrally managed service// to create and manage Anthos clusters that run on AWS infrastructure.service AwsClusters {  option (google.api.default_host) = "gkemulticloud.googleapis.com";  option (google.api.oauth_scopes) = "https://www.googleapis.com/auth/cloud-platform";  // Creates a new [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource on a given GCP project and region.  //  // If successful, the response contains a newly created  // [Operation][google.longrunning.Operation] resource that can be  // described to track the status of the operation.  rpc CreateAwsCluster(CreateAwsClusterRequest) returns (google.longrunning.Operation) {    option (google.api.http) = {      post: "/v1/{parent=projects/*/locations/*}/awsClusters"      body: "aws_cluster"    };    option (google.api.method_signature) = "parent,aws_cluster,aws_cluster_id";    option (google.longrunning.operation_info) = {      response_type: "AwsCluster"      metadata_type: "OperationMetadata"    };  }  // Updates an [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster].  rpc UpdateAwsCluster(UpdateAwsClusterRequest) returns (google.longrunning.Operation) {    option (google.api.http) = {      patch: "/v1/{aws_cluster.name=projects/*/locations/*/awsClusters/*}"      body: "aws_cluster"    };    option (google.api.method_signature) = "aws_cluster,update_mask";    option (google.longrunning.operation_info) = {      response_type: "AwsCluster"      metadata_type: "OperationMetadata"    };  }  // Describes a specific [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource.  rpc GetAwsCluster(GetAwsClusterRequest) returns (AwsCluster) {    option (google.api.http) = {      get: "/v1/{name=projects/*/locations/*/awsClusters/*}"    };    option (google.api.method_signature) = "name";  }  // Lists all [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resources on a given Google Cloud project and  // region.  rpc ListAwsClusters(ListAwsClustersRequest) returns (ListAwsClustersResponse) {    option (google.api.http) = {      get: "/v1/{parent=projects/*/locations/*}/awsClusters"    };    option (google.api.method_signature) = "parent";  }  // Deletes a specific [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource.  //  // Fails if the cluster has one or more associated [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool]  // resources.  //  // If successful, the response contains a newly created  // [Operation][google.longrunning.Operation] resource that can be  // described to track the status of the operation.  rpc DeleteAwsCluster(DeleteAwsClusterRequest) returns (google.longrunning.Operation) {    option (google.api.http) = {      delete: "/v1/{name=projects/*/locations/*/awsClusters/*}"    };    option (google.api.method_signature) = "name";    option (google.longrunning.operation_info) = {      response_type: "google.protobuf.Empty"      metadata_type: "OperationMetadata"    };  }  // Generates a short-lived access token to authenticate to a given  // [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource.  rpc GenerateAwsAccessToken(GenerateAwsAccessTokenRequest) returns (GenerateAwsAccessTokenResponse) {    option (google.api.http) = {      get: "/v1/{aws_cluster=projects/*/locations/*/awsClusters/*}:generateAwsAccessToken"    };  }  // Creates a new [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool], attached to a given [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster].  //  // If successful, the response contains a newly created  // [Operation][google.longrunning.Operation] resource that can be  // described to track the status of the operation.  rpc CreateAwsNodePool(CreateAwsNodePoolRequest) returns (google.longrunning.Operation) {    option (google.api.http) = {      post: "/v1/{parent=projects/*/locations/*/awsClusters/*}/awsNodePools"      body: "aws_node_pool"    };    option (google.api.method_signature) = "parent,aws_node_pool,aws_node_pool_id";    option (google.longrunning.operation_info) = {      response_type: "AwsNodePool"      metadata_type: "OperationMetadata"    };  }  // Updates an [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool].  rpc UpdateAwsNodePool(UpdateAwsNodePoolRequest) returns (google.longrunning.Operation) {    option (google.api.http) = {      patch: "/v1/{aws_node_pool.name=projects/*/locations/*/awsClusters/*/awsNodePools/*}"      body: "aws_node_pool"    };    option (google.api.method_signature) = "aws_node_pool,update_mask";    option (google.longrunning.operation_info) = {      response_type: "AwsNodePool"      metadata_type: "OperationMetadata"    };  }  // Describes a specific [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resource.  rpc GetAwsNodePool(GetAwsNodePoolRequest) returns (AwsNodePool) {    option (google.api.http) = {      get: "/v1/{name=projects/*/locations/*/awsClusters/*/awsNodePools/*}"    };    option (google.api.method_signature) = "name";  }  // Lists all [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resources on a given [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster].  rpc ListAwsNodePools(ListAwsNodePoolsRequest) returns (ListAwsNodePoolsResponse) {    option (google.api.http) = {      get: "/v1/{parent=projects/*/locations/*/awsClusters/*}/awsNodePools"    };    option (google.api.method_signature) = "parent";  }  // Deletes a specific [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resource.  //  // If successful, the response contains a newly created  // [Operation][google.longrunning.Operation] resource that can be  // described to track the status of the operation.  rpc DeleteAwsNodePool(DeleteAwsNodePoolRequest) returns (google.longrunning.Operation) {    option (google.api.http) = {      delete: "/v1/{name=projects/*/locations/*/awsClusters/*/awsNodePools/*}"    };    option (google.api.method_signature) = "name";    option (google.longrunning.operation_info) = {      response_type: "google.protobuf.Empty"      metadata_type: "OperationMetadata"    };  }  // Returns information, such as supported AWS regions and Kubernetes  // versions, on a given Google Cloud location.  rpc GetAwsServerConfig(GetAwsServerConfigRequest) returns (AwsServerConfig) {    option (google.api.http) = {      get: "/v1/{name=projects/*/locations/*/awsServerConfig}"    };    option (google.api.method_signature) = "name";  }}// Request message for `AwsClusters.CreateAwsCluster` method.message CreateAwsClusterRequest {  // Required. The parent location where this [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource  // will be created.  //  // Location names are formatted as `projects/<project-id>/locations/<region>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string parent = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      child_type: "gkemulticloud.googleapis.com/AwsCluster"    }  ];  // Required. The specification of the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] to create.  AwsCluster aws_cluster = 2 [(google.api.field_behavior) = REQUIRED];  // Required. A client provided ID the resource. Must be unique within the parent  // resource.  //  // The provided ID will be part of the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster]  // resource name formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>`.  //  // Valid characters are `/[a-z][0-9]-/`. Cannot be longer than 40 characters.  string aws_cluster_id = 3 [(google.api.field_behavior) = REQUIRED];  // If set, only validate the request, but do not actually create the cluster.  bool validate_only = 4;}// Request message for `AwsClusters.UpdateAwsCluster` method.message UpdateAwsClusterRequest {  // Required. The [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource to update.  AwsCluster aws_cluster = 1 [(google.api.field_behavior) = REQUIRED];  // If set, only validate the request, but do not actually update the cluster.  bool validate_only = 2;  // Required. Mask of fields to update. At least one path must be supplied in  // this field. The elements of the repeated paths field can only include these  // fields from [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster]:  //  //  *   `description`.  //  *   `annotations`.  //  *   `control_plane.version`.  //  *   `authorization.admin_users`.  //  *   `control_plane.aws_services_authentication.role_arn`.  //  *   `control_plane.aws_services_authentication.role_session_name`.  //  *   `control_plane.config_encryption.kms_key_arn`.  //  *   `control_plane.instance_type`.  //  *   `control_plane.security_group_ids`.  //  *   `control_plane.proxy_config`.  //  *   `control_plane.proxy_config.secret_arn`.  //  *   `control_plane.proxy_config.secret_version`.  //  *   `control_plane.root_volume.iops`.  //  *   `control_plane.root_volume.kms_key_arn`.  //  *   `control_plane.root_volume.volume_type`.  //  *   `control_plane.root_volume.size_gib`.  //  *   `control_plane.ssh_config`.  //  *   `control_plane.ssh_config.ec2_key_pair`.  //  *   `control_plane.instance_placement.tenancy`.  //  *   `logging_config`.  google.protobuf.FieldMask update_mask = 4 [(google.api.field_behavior) = REQUIRED];}// Request message for `AwsClusters.GetAwsCluster` method.message GetAwsClusterRequest {  // Required. The name of the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource to describe.  //  // `AwsCluster` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on GCP resource names.  string name = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      type: "gkemulticloud.googleapis.com/AwsCluster"    }  ];}// Request message for `AwsClusters.ListAwsClusters` method.message ListAwsClustersRequest {  // Required. The parent location which owns this collection of  // [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resources.  //  // Location names are formatted as `projects/<project-id>/locations/<region>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on GCP resource names.  string parent = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      child_type: "gkemulticloud.googleapis.com/AwsCluster"    }  ];  // The maximum number of items to return.  //  // If not specified, a default value of 50 will be used by the service.  // Regardless of the pageSize value, the response can include a partial list  // and a caller should only rely on response's  // [nextPageToken][google.cloud.gkemulticloud.v1.ListAwsClustersResponse.next_page_token] to determine if  // there are more instances left to be queried.  int32 page_size = 2;  // The `nextPageToken` value returned from a previous  // [awsClusters.list][google.cloud.gkemulticloud.v1.AwsClusters.ListAwsClusters] request, if any.  string page_token = 3;}// Response message for `AwsClusters.ListAwsClusters` method.message ListAwsClustersResponse {  // A list of [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resources in the specified GCP  // project and region region.  repeated AwsCluster aws_clusters = 1;  // Token to retrieve the next page of results, or empty if there are no more  // results in the list.  string next_page_token = 2;}// Request message for `AwsClusters.DeleteAwsCluster` method.message DeleteAwsClusterRequest {  // Required. The resource name the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] to delete.  //  // `AwsCluster` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on GCP resource names.  string name = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      type: "gkemulticloud.googleapis.com/AwsCluster"    }  ];  // If set, only validate the request, but do not actually delete the resource.  bool validate_only = 2;  // If set to true, and the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource is not found,  // the request will succeed but no action will be taken on the server and a  // completed [Operation][google.longrunning.Operation] will be returned.  //  // Useful for idempotent deletion.  bool allow_missing = 3;  // The current etag of the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster].  //  // Allows clients to perform deletions through optimistic concurrency control.  //  // If the provided etag does not match the current etag of the cluster,  // the request will fail and an ABORTED error will be returned.  string etag = 4;}// Response message for `AwsClusters.CreateAwsNodePool` method.message CreateAwsNodePoolRequest {  // Required. The [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource where this node pool will be created.  //  // `AwsCluster` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string parent = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      child_type: "gkemulticloud.googleapis.com/AwsNodePool"    }  ];  // Required. The specification of the [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] to create.  AwsNodePool aws_node_pool = 2 [(google.api.field_behavior) = REQUIRED];  // Required. A client provided ID the resource. Must be unique within the parent  // resource.  //  // The provided ID will be part of the [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool]  // resource name formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>/awsNodePools/<node-pool-id>`.  //  // Valid characters are `/[a-z][0-9]-/`. Cannot be longer than 40 characters.  string aws_node_pool_id = 3 [(google.api.field_behavior) = REQUIRED];  // If set, only validate the request, but do not actually create the node  // pool.  bool validate_only = 4;}// Request message for `AwsClusters.UpdateAwsNodePool` method.message UpdateAwsNodePoolRequest {  // Required. The [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resource to update.  AwsNodePool aws_node_pool = 1 [(google.api.field_behavior) = REQUIRED];  // If set, only validate the request, but don't actually update the node pool.  bool validate_only = 2;  // Required. Mask of fields to update. At least one path must be supplied in  // this field. The elements of the repeated paths field can only include these  // fields from [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool]:  //  //  *   `annotations`.  //  *   `version`.  //  *   `autoscaling.min_node_count`.  //  *   `autoscaling.max_node_count`.  //  *   `config.config_encryption.kms_key_arn`.  //  *   `config.security_group_ids`.  //  *   `config.root_volume.iops`.  //  *   `config.root_volume.kms_key_arn`.  //  *   `config.root_volume.volume_type`.  //  *   `config.root_volume.size_gib`.  //  *   `config.proxy_config`.  //  *   `config.proxy_config.secret_arn`.  //  *   `config.proxy_config.secret_version`.  //  *   `config.ssh_config`.  //  *   `config.ssh_config.ec2_key_pair`.  google.protobuf.FieldMask update_mask = 3 [(google.api.field_behavior) = REQUIRED];}// Request message for `AwsClusters.GetAwsNodePool` method.message GetAwsNodePoolRequest {  // Required. The name of the [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resource to describe.  //  // `AwsNodePool` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>/awsNodePools/<node-pool-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string name = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      type: "gkemulticloud.googleapis.com/AwsNodePool"    }  ];}// Request message for `AwsClusters.ListAwsNodePools` method.message ListAwsNodePoolsRequest {  // Required. The parent `AwsCluster` which owns this collection of  // [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resources.  //  // `AwsCluster` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string parent = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      child_type: "gkemulticloud.googleapis.com/AwsNodePool"    }  ];  // The maximum number of items to return.  //  // If not specified, a default value of 50 will be used by the service.  // Regardless of the pageSize value, the response can include a partial list  // and a caller should only rely on response's  // [nextPageToken][google.cloud.gkemulticloud.v1.ListAwsNodePoolsResponse.next_page_token] to determine if  // there are more instances left to be queried.  int32 page_size = 2;  // The `nextPageToken` value returned from a previous  // [awsNodePools.list][google.cloud.gkemulticloud.v1.AwsClusters.ListAwsNodePools] request, if any.  string page_token = 3;}// Response message for `AwsClusters.ListAwsNodePools` method.message ListAwsNodePoolsResponse {  // A list of [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resources in the specified `AwsCluster`.  repeated AwsNodePool aws_node_pools = 1;  // Token to retrieve the next page of results, or empty if there are no more  // results in the list.  string next_page_token = 2;}// Request message for `AwsClusters.DeleteNodePool` method.message DeleteAwsNodePoolRequest {  // Required. The resource name the [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] to delete.  //  // `AwsNodePool` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>/awsNodePools/<node-pool-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string name = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      type: "gkemulticloud.googleapis.com/AwsNodePool"    }  ];  // If set, only validate the request, but do not actually delete the node  // pool.  bool validate_only = 2;  // If set to true, and the [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool] resource is not found,  // the request will succeed but no action will be taken on the server and a  // completed [Operation][google.longrunning.Operation] will be returned.  //  // Useful for idempotent deletion.  bool allow_missing = 3;  // The current ETag of the [AwsNodePool][google.cloud.gkemulticloud.v1.AwsNodePool].  //  // Allows clients to perform deletions through optimistic concurrency control.  //  // If the provided ETag does not match the current etag of the node pool,  // the request will fail and an ABORTED error will be returned.  string etag = 4;}// GetAwsServerConfigRequest gets the server config of GKE cluster on AWS.message GetAwsServerConfigRequest {  // Required. The name of the [AwsServerConfig][google.cloud.gkemulticloud.v1.AwsServerConfig] resource to describe.  //  // `AwsServerConfig` names are formatted as  // `projects/<project-id>/locations/<region>/awsServerConfig`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string name = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      type: "gkemulticloud.googleapis.com/AwsServerConfig"    }  ];}// Request message for `AwsClusters.GenerateAwsAccessToken` method.message GenerateAwsAccessTokenRequest {  // Required. The name of the [AwsCluster][google.cloud.gkemulticloud.v1.AwsCluster] resource to authenticate to.  //  // `AwsCluster` names are formatted as  // `projects/<project-id>/locations/<region>/awsClusters/<cluster-id>`.  //  // See [Resource Names](https://cloud.google.com/apis/design/resource_names)  // for more details on Google Cloud resource names.  string aws_cluster = 1 [    (google.api.field_behavior) = REQUIRED,    (google.api.resource_reference) = {      type: "gkemulticloud.googleapis.com/AwsCluster"    }  ];}// Response message for `AwsClusters.GenerateAwsAccessToken` method.message GenerateAwsAccessTokenResponse {  // Output only. Access token to authenticate to k8s api-server.  string access_token = 1 [(google.api.field_behavior) = OUTPUT_ONLY];  // Output only. Timestamp at which the token will expire.  google.protobuf.Timestamp expiration_time = 2 [(google.api.field_behavior) = OUTPUT_ONLY];}
 |