All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.cloud.gkemulticloud.v1.stub.HttpJsonAwsClustersStub Maven / Gradle / Ivy

Go to download

Anthos Multicloud enables you to provision and manage GKE clusters running on AWS and Azure infrastructure through a centralized Google Cloud backed control plane.

There is a newer version: 0.48.0
Show newest version
/*
 * Copyright 2024 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
 *
 *      https://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.
 */

package com.google.cloud.gkemulticloud.v1.stub;

import static com.google.cloud.gkemulticloud.v1.AwsClustersClient.ListAwsClustersPagedResponse;
import static com.google.cloud.gkemulticloud.v1.AwsClustersClient.ListAwsNodePoolsPagedResponse;

import com.google.api.HttpRule;
import com.google.api.core.InternalApi;
import com.google.api.gax.core.BackgroundResource;
import com.google.api.gax.core.BackgroundResourceAggregation;
import com.google.api.gax.httpjson.ApiMethodDescriptor;
import com.google.api.gax.httpjson.HttpJsonCallSettings;
import com.google.api.gax.httpjson.HttpJsonOperationSnapshot;
import com.google.api.gax.httpjson.HttpJsonStubCallableFactory;
import com.google.api.gax.httpjson.ProtoMessageRequestFormatter;
import com.google.api.gax.httpjson.ProtoMessageResponseParser;
import com.google.api.gax.httpjson.ProtoRestSerializer;
import com.google.api.gax.httpjson.longrunning.stub.HttpJsonOperationsStub;
import com.google.api.gax.rpc.ClientContext;
import com.google.api.gax.rpc.OperationCallable;
import com.google.api.gax.rpc.RequestParamsBuilder;
import com.google.api.gax.rpc.UnaryCallable;
import com.google.cloud.gkemulticloud.v1.AwsCluster;
import com.google.cloud.gkemulticloud.v1.AwsJsonWebKeys;
import com.google.cloud.gkemulticloud.v1.AwsNodePool;
import com.google.cloud.gkemulticloud.v1.AwsOpenIdConfig;
import com.google.cloud.gkemulticloud.v1.AwsServerConfig;
import com.google.cloud.gkemulticloud.v1.CreateAwsClusterRequest;
import com.google.cloud.gkemulticloud.v1.CreateAwsNodePoolRequest;
import com.google.cloud.gkemulticloud.v1.DeleteAwsClusterRequest;
import com.google.cloud.gkemulticloud.v1.DeleteAwsNodePoolRequest;
import com.google.cloud.gkemulticloud.v1.GenerateAwsAccessTokenRequest;
import com.google.cloud.gkemulticloud.v1.GenerateAwsAccessTokenResponse;
import com.google.cloud.gkemulticloud.v1.GenerateAwsClusterAgentTokenRequest;
import com.google.cloud.gkemulticloud.v1.GenerateAwsClusterAgentTokenResponse;
import com.google.cloud.gkemulticloud.v1.GetAwsClusterRequest;
import com.google.cloud.gkemulticloud.v1.GetAwsJsonWebKeysRequest;
import com.google.cloud.gkemulticloud.v1.GetAwsNodePoolRequest;
import com.google.cloud.gkemulticloud.v1.GetAwsOpenIdConfigRequest;
import com.google.cloud.gkemulticloud.v1.GetAwsServerConfigRequest;
import com.google.cloud.gkemulticloud.v1.ListAwsClustersRequest;
import com.google.cloud.gkemulticloud.v1.ListAwsClustersResponse;
import com.google.cloud.gkemulticloud.v1.ListAwsNodePoolsRequest;
import com.google.cloud.gkemulticloud.v1.ListAwsNodePoolsResponse;
import com.google.cloud.gkemulticloud.v1.OperationMetadata;
import com.google.cloud.gkemulticloud.v1.RollbackAwsNodePoolUpdateRequest;
import com.google.cloud.gkemulticloud.v1.UpdateAwsClusterRequest;
import com.google.cloud.gkemulticloud.v1.UpdateAwsNodePoolRequest;
import com.google.common.collect.ImmutableMap;
import com.google.longrunning.Operation;
import com.google.protobuf.Empty;
import com.google.protobuf.TypeRegistry;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.TimeUnit;
import javax.annotation.Generated;

// AUTO-GENERATED DOCUMENTATION AND CLASS.
/**
 * REST stub implementation for the AwsClusters service API.
 *
 * 

This class is for advanced usage and reflects the underlying API directly. */ @Generated("by gapic-generator-java") public class HttpJsonAwsClustersStub extends AwsClustersStub { private static final TypeRegistry typeRegistry = TypeRegistry.newBuilder() .add(OperationMetadata.getDescriptor()) .add(Empty.getDescriptor()) .add(AwsCluster.getDescriptor()) .add(AwsNodePool.getDescriptor()) .build(); private static final ApiMethodDescriptor createAwsClusterMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/CreateAwsCluster") .setHttpMethod("POST") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{parent=projects/*/locations/*}/awsClusters", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "parent", request.getParent()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam( fields, "awsClusterId", request.getAwsClusterId()); serializer.putQueryParam( fields, "validateOnly", request.getValidateOnly()); return fields; }) .setRequestBodyExtractor( request -> ProtoRestSerializer.create() .toBody("awsCluster", request.getAwsCluster(), false)) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (CreateAwsClusterRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor updateAwsClusterMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/UpdateAwsCluster") .setHttpMethod("PATCH") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{awsCluster.name=projects/*/locations/*/awsClusters/*}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam( fields, "awsCluster.name", request.getAwsCluster().getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam(fields, "updateMask", request.getUpdateMask()); serializer.putQueryParam( fields, "validateOnly", request.getValidateOnly()); return fields; }) .setRequestBodyExtractor( request -> ProtoRestSerializer.create() .toBody("awsCluster", request.getAwsCluster(), false)) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (UpdateAwsClusterRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor getAwsClusterMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/GetAwsCluster") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{name=projects/*/locations/*/awsClusters/*}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "name", request.getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(AwsCluster.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor listAwsClustersMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/ListAwsClusters") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{parent=projects/*/locations/*}/awsClusters", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "parent", request.getParent()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam(fields, "pageSize", request.getPageSize()); serializer.putQueryParam(fields, "pageToken", request.getPageToken()); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(ListAwsClustersResponse.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor deleteAwsClusterMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/DeleteAwsCluster") .setHttpMethod("DELETE") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{name=projects/*/locations/*/awsClusters/*}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "name", request.getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam( fields, "allowMissing", request.getAllowMissing()); serializer.putQueryParam(fields, "etag", request.getEtag()); serializer.putQueryParam( fields, "ignoreErrors", request.getIgnoreErrors()); serializer.putQueryParam( fields, "validateOnly", request.getValidateOnly()); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (DeleteAwsClusterRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor< GenerateAwsClusterAgentTokenRequest, GenerateAwsClusterAgentTokenResponse> generateAwsClusterAgentTokenMethodDescriptor = ApiMethodDescriptor . newBuilder() .setFullMethodName( "google.cloud.gkemulticloud.v1.AwsClusters/GenerateAwsClusterAgentToken") .setHttpMethod("POST") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{awsCluster=projects/*/locations/*/awsClusters/*}:generateAwsClusterAgentToken", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "awsCluster", request.getAwsCluster()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor( request -> ProtoRestSerializer.create() .toBody( "*", request.toBuilder().clearAwsCluster().build(), false)) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(GenerateAwsClusterAgentTokenResponse.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor< GenerateAwsAccessTokenRequest, GenerateAwsAccessTokenResponse> generateAwsAccessTokenMethodDescriptor = ApiMethodDescriptor .newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/GenerateAwsAccessToken") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{awsCluster=projects/*/locations/*/awsClusters/*}:generateAwsAccessToken", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "awsCluster", request.getAwsCluster()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(GenerateAwsAccessTokenResponse.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor createAwsNodePoolMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/CreateAwsNodePool") .setHttpMethod("POST") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{parent=projects/*/locations/*/awsClusters/*}/awsNodePools", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "parent", request.getParent()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam( fields, "awsNodePoolId", request.getAwsNodePoolId()); serializer.putQueryParam( fields, "validateOnly", request.getValidateOnly()); return fields; }) .setRequestBodyExtractor( request -> ProtoRestSerializer.create() .toBody("awsNodePool", request.getAwsNodePool(), false)) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (CreateAwsNodePoolRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor updateAwsNodePoolMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/UpdateAwsNodePool") .setHttpMethod("PATCH") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{awsNodePool.name=projects/*/locations/*/awsClusters/*/awsNodePools/*}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam( fields, "awsNodePool.name", request.getAwsNodePool().getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam(fields, "updateMask", request.getUpdateMask()); serializer.putQueryParam( fields, "validateOnly", request.getValidateOnly()); return fields; }) .setRequestBodyExtractor( request -> ProtoRestSerializer.create() .toBody("awsNodePool", request.getAwsNodePool(), false)) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (UpdateAwsNodePoolRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor rollbackAwsNodePoolUpdateMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName( "google.cloud.gkemulticloud.v1.AwsClusters/RollbackAwsNodePoolUpdate") .setHttpMethod("POST") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{name=projects/*/locations/*/awsClusters/*/awsNodePools/*}:rollback", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "name", request.getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor( request -> ProtoRestSerializer.create() .toBody("*", request.toBuilder().clearName().build(), false)) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (RollbackAwsNodePoolUpdateRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor getAwsNodePoolMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/GetAwsNodePool") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{name=projects/*/locations/*/awsClusters/*/awsNodePools/*}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "name", request.getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(AwsNodePool.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor listAwsNodePoolsMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/ListAwsNodePools") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{parent=projects/*/locations/*/awsClusters/*}/awsNodePools", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "parent", request.getParent()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam(fields, "pageSize", request.getPageSize()); serializer.putQueryParam(fields, "pageToken", request.getPageToken()); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(ListAwsNodePoolsResponse.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor deleteAwsNodePoolMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/DeleteAwsNodePool") .setHttpMethod("DELETE") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{name=projects/*/locations/*/awsClusters/*/awsNodePools/*}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "name", request.getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putQueryParam( fields, "allowMissing", request.getAllowMissing()); serializer.putQueryParam(fields, "etag", request.getEtag()); serializer.putQueryParam( fields, "ignoreErrors", request.getIgnoreErrors()); serializer.putQueryParam( fields, "validateOnly", request.getValidateOnly()); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(Operation.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .setOperationSnapshotFactory( (DeleteAwsNodePoolRequest request, Operation response) -> HttpJsonOperationSnapshot.create(response)) .build(); private static final ApiMethodDescriptor getAwsOpenIdConfigMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/GetAwsOpenIdConfig") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{awsCluster=projects/*/locations/*/awsClusters/*}/.well-known/openid-configuration", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "awsCluster", request.getAwsCluster()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(AwsOpenIdConfig.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor getAwsJsonWebKeysMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/GetAwsJsonWebKeys") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{awsCluster=projects/*/locations/*/awsClusters/*}/jwks", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "awsCluster", request.getAwsCluster()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(AwsJsonWebKeys.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private static final ApiMethodDescriptor getAwsServerConfigMethodDescriptor = ApiMethodDescriptor.newBuilder() .setFullMethodName("google.cloud.gkemulticloud.v1.AwsClusters/GetAwsServerConfig") .setHttpMethod("GET") .setType(ApiMethodDescriptor.MethodType.UNARY) .setRequestFormatter( ProtoMessageRequestFormatter.newBuilder() .setPath( "/v1/{name=projects/*/locations/*/awsServerConfig}", request -> { Map fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); serializer.putPathParam(fields, "name", request.getName()); return fields; }) .setQueryParamsExtractor( request -> { Map> fields = new HashMap<>(); ProtoRestSerializer serializer = ProtoRestSerializer.create(); return fields; }) .setRequestBodyExtractor(request -> null) .build()) .setResponseParser( ProtoMessageResponseParser.newBuilder() .setDefaultInstance(AwsServerConfig.getDefaultInstance()) .setDefaultTypeRegistry(typeRegistry) .build()) .build(); private final UnaryCallable createAwsClusterCallable; private final OperationCallable createAwsClusterOperationCallable; private final UnaryCallable updateAwsClusterCallable; private final OperationCallable updateAwsClusterOperationCallable; private final UnaryCallable getAwsClusterCallable; private final UnaryCallable listAwsClustersCallable; private final UnaryCallable listAwsClustersPagedCallable; private final UnaryCallable deleteAwsClusterCallable; private final OperationCallable deleteAwsClusterOperationCallable; private final UnaryCallable< GenerateAwsClusterAgentTokenRequest, GenerateAwsClusterAgentTokenResponse> generateAwsClusterAgentTokenCallable; private final UnaryCallable generateAwsAccessTokenCallable; private final UnaryCallable createAwsNodePoolCallable; private final OperationCallable createAwsNodePoolOperationCallable; private final UnaryCallable updateAwsNodePoolCallable; private final OperationCallable updateAwsNodePoolOperationCallable; private final UnaryCallable rollbackAwsNodePoolUpdateCallable; private final OperationCallable rollbackAwsNodePoolUpdateOperationCallable; private final UnaryCallable getAwsNodePoolCallable; private final UnaryCallable listAwsNodePoolsCallable; private final UnaryCallable listAwsNodePoolsPagedCallable; private final UnaryCallable deleteAwsNodePoolCallable; private final OperationCallable deleteAwsNodePoolOperationCallable; private final UnaryCallable getAwsOpenIdConfigCallable; private final UnaryCallable getAwsJsonWebKeysCallable; private final UnaryCallable getAwsServerConfigCallable; private final BackgroundResource backgroundResources; private final HttpJsonOperationsStub httpJsonOperationsStub; private final HttpJsonStubCallableFactory callableFactory; public static final HttpJsonAwsClustersStub create(AwsClustersStubSettings settings) throws IOException { return new HttpJsonAwsClustersStub(settings, ClientContext.create(settings)); } public static final HttpJsonAwsClustersStub create(ClientContext clientContext) throws IOException { return new HttpJsonAwsClustersStub( AwsClustersStubSettings.newHttpJsonBuilder().build(), clientContext); } public static final HttpJsonAwsClustersStub create( ClientContext clientContext, HttpJsonStubCallableFactory callableFactory) throws IOException { return new HttpJsonAwsClustersStub( AwsClustersStubSettings.newHttpJsonBuilder().build(), clientContext, callableFactory); } /** * Constructs an instance of HttpJsonAwsClustersStub, using the given settings. This is protected * so that it is easy to make a subclass, but otherwise, the static factory methods should be * preferred. */ protected HttpJsonAwsClustersStub(AwsClustersStubSettings settings, ClientContext clientContext) throws IOException { this(settings, clientContext, new HttpJsonAwsClustersCallableFactory()); } /** * Constructs an instance of HttpJsonAwsClustersStub, using the given settings. This is protected * so that it is easy to make a subclass, but otherwise, the static factory methods should be * preferred. */ protected HttpJsonAwsClustersStub( AwsClustersStubSettings settings, ClientContext clientContext, HttpJsonStubCallableFactory callableFactory) throws IOException { this.callableFactory = callableFactory; this.httpJsonOperationsStub = HttpJsonOperationsStub.create( clientContext, callableFactory, typeRegistry, ImmutableMap.builder() .put( "google.longrunning.Operations.CancelOperation", HttpRule.newBuilder() .setPost("/v1/{name=projects/*/locations/*/operations/*}:cancel") .build()) .put( "google.longrunning.Operations.DeleteOperation", HttpRule.newBuilder() .setDelete("/v1/{name=projects/*/locations/*/operations/*}") .build()) .put( "google.longrunning.Operations.GetOperation", HttpRule.newBuilder() .setGet("/v1/{name=projects/*/locations/*/operations/*}") .build()) .put( "google.longrunning.Operations.ListOperations", HttpRule.newBuilder() .setGet("/v1/{name=projects/*/locations/*}/operations") .build()) .build()); HttpJsonCallSettings createAwsClusterTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(createAwsClusterMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("parent", String.valueOf(request.getParent())); return builder.build(); }) .build(); HttpJsonCallSettings updateAwsClusterTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(updateAwsClusterMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add( "aws_cluster.name", String.valueOf(request.getAwsCluster().getName())); return builder.build(); }) .build(); HttpJsonCallSettings getAwsClusterTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(getAwsClusterMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("name", String.valueOf(request.getName())); return builder.build(); }) .build(); HttpJsonCallSettings listAwsClustersTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(listAwsClustersMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("parent", String.valueOf(request.getParent())); return builder.build(); }) .build(); HttpJsonCallSettings deleteAwsClusterTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(deleteAwsClusterMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("name", String.valueOf(request.getName())); return builder.build(); }) .build(); HttpJsonCallSettings generateAwsClusterAgentTokenTransportSettings = HttpJsonCallSettings . newBuilder() .setMethodDescriptor(generateAwsClusterAgentTokenMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("aws_cluster", String.valueOf(request.getAwsCluster())); return builder.build(); }) .build(); HttpJsonCallSettings generateAwsAccessTokenTransportSettings = HttpJsonCallSettings .newBuilder() .setMethodDescriptor(generateAwsAccessTokenMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("aws_cluster", String.valueOf(request.getAwsCluster())); return builder.build(); }) .build(); HttpJsonCallSettings createAwsNodePoolTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(createAwsNodePoolMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("parent", String.valueOf(request.getParent())); return builder.build(); }) .build(); HttpJsonCallSettings updateAwsNodePoolTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(updateAwsNodePoolMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add( "aws_node_pool.name", String.valueOf(request.getAwsNodePool().getName())); return builder.build(); }) .build(); HttpJsonCallSettings rollbackAwsNodePoolUpdateTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(rollbackAwsNodePoolUpdateMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("name", String.valueOf(request.getName())); return builder.build(); }) .build(); HttpJsonCallSettings getAwsNodePoolTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(getAwsNodePoolMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("name", String.valueOf(request.getName())); return builder.build(); }) .build(); HttpJsonCallSettings listAwsNodePoolsTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(listAwsNodePoolsMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("parent", String.valueOf(request.getParent())); return builder.build(); }) .build(); HttpJsonCallSettings deleteAwsNodePoolTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(deleteAwsNodePoolMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("name", String.valueOf(request.getName())); return builder.build(); }) .build(); HttpJsonCallSettings getAwsOpenIdConfigTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(getAwsOpenIdConfigMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("aws_cluster", String.valueOf(request.getAwsCluster())); return builder.build(); }) .build(); HttpJsonCallSettings getAwsJsonWebKeysTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(getAwsJsonWebKeysMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("aws_cluster", String.valueOf(request.getAwsCluster())); return builder.build(); }) .build(); HttpJsonCallSettings getAwsServerConfigTransportSettings = HttpJsonCallSettings.newBuilder() .setMethodDescriptor(getAwsServerConfigMethodDescriptor) .setTypeRegistry(typeRegistry) .setParamsExtractor( request -> { RequestParamsBuilder builder = RequestParamsBuilder.create(); builder.add("name", String.valueOf(request.getName())); return builder.build(); }) .build(); this.createAwsClusterCallable = callableFactory.createUnaryCallable( createAwsClusterTransportSettings, settings.createAwsClusterSettings(), clientContext); this.createAwsClusterOperationCallable = callableFactory.createOperationCallable( createAwsClusterTransportSettings, settings.createAwsClusterOperationSettings(), clientContext, httpJsonOperationsStub); this.updateAwsClusterCallable = callableFactory.createUnaryCallable( updateAwsClusterTransportSettings, settings.updateAwsClusterSettings(), clientContext); this.updateAwsClusterOperationCallable = callableFactory.createOperationCallable( updateAwsClusterTransportSettings, settings.updateAwsClusterOperationSettings(), clientContext, httpJsonOperationsStub); this.getAwsClusterCallable = callableFactory.createUnaryCallable( getAwsClusterTransportSettings, settings.getAwsClusterSettings(), clientContext); this.listAwsClustersCallable = callableFactory.createUnaryCallable( listAwsClustersTransportSettings, settings.listAwsClustersSettings(), clientContext); this.listAwsClustersPagedCallable = callableFactory.createPagedCallable( listAwsClustersTransportSettings, settings.listAwsClustersSettings(), clientContext); this.deleteAwsClusterCallable = callableFactory.createUnaryCallable( deleteAwsClusterTransportSettings, settings.deleteAwsClusterSettings(), clientContext); this.deleteAwsClusterOperationCallable = callableFactory.createOperationCallable( deleteAwsClusterTransportSettings, settings.deleteAwsClusterOperationSettings(), clientContext, httpJsonOperationsStub); this.generateAwsClusterAgentTokenCallable = callableFactory.createUnaryCallable( generateAwsClusterAgentTokenTransportSettings, settings.generateAwsClusterAgentTokenSettings(), clientContext); this.generateAwsAccessTokenCallable = callableFactory.createUnaryCallable( generateAwsAccessTokenTransportSettings, settings.generateAwsAccessTokenSettings(), clientContext); this.createAwsNodePoolCallable = callableFactory.createUnaryCallable( createAwsNodePoolTransportSettings, settings.createAwsNodePoolSettings(), clientContext); this.createAwsNodePoolOperationCallable = callableFactory.createOperationCallable( createAwsNodePoolTransportSettings, settings.createAwsNodePoolOperationSettings(), clientContext, httpJsonOperationsStub); this.updateAwsNodePoolCallable = callableFactory.createUnaryCallable( updateAwsNodePoolTransportSettings, settings.updateAwsNodePoolSettings(), clientContext); this.updateAwsNodePoolOperationCallable = callableFactory.createOperationCallable( updateAwsNodePoolTransportSettings, settings.updateAwsNodePoolOperationSettings(), clientContext, httpJsonOperationsStub); this.rollbackAwsNodePoolUpdateCallable = callableFactory.createUnaryCallable( rollbackAwsNodePoolUpdateTransportSettings, settings.rollbackAwsNodePoolUpdateSettings(), clientContext); this.rollbackAwsNodePoolUpdateOperationCallable = callableFactory.createOperationCallable( rollbackAwsNodePoolUpdateTransportSettings, settings.rollbackAwsNodePoolUpdateOperationSettings(), clientContext, httpJsonOperationsStub); this.getAwsNodePoolCallable = callableFactory.createUnaryCallable( getAwsNodePoolTransportSettings, settings.getAwsNodePoolSettings(), clientContext); this.listAwsNodePoolsCallable = callableFactory.createUnaryCallable( listAwsNodePoolsTransportSettings, settings.listAwsNodePoolsSettings(), clientContext); this.listAwsNodePoolsPagedCallable = callableFactory.createPagedCallable( listAwsNodePoolsTransportSettings, settings.listAwsNodePoolsSettings(), clientContext); this.deleteAwsNodePoolCallable = callableFactory.createUnaryCallable( deleteAwsNodePoolTransportSettings, settings.deleteAwsNodePoolSettings(), clientContext); this.deleteAwsNodePoolOperationCallable = callableFactory.createOperationCallable( deleteAwsNodePoolTransportSettings, settings.deleteAwsNodePoolOperationSettings(), clientContext, httpJsonOperationsStub); this.getAwsOpenIdConfigCallable = callableFactory.createUnaryCallable( getAwsOpenIdConfigTransportSettings, settings.getAwsOpenIdConfigSettings(), clientContext); this.getAwsJsonWebKeysCallable = callableFactory.createUnaryCallable( getAwsJsonWebKeysTransportSettings, settings.getAwsJsonWebKeysSettings(), clientContext); this.getAwsServerConfigCallable = callableFactory.createUnaryCallable( getAwsServerConfigTransportSettings, settings.getAwsServerConfigSettings(), clientContext); this.backgroundResources = new BackgroundResourceAggregation(clientContext.getBackgroundResources()); } @InternalApi public static List getMethodDescriptors() { List methodDescriptors = new ArrayList<>(); methodDescriptors.add(createAwsClusterMethodDescriptor); methodDescriptors.add(updateAwsClusterMethodDescriptor); methodDescriptors.add(getAwsClusterMethodDescriptor); methodDescriptors.add(listAwsClustersMethodDescriptor); methodDescriptors.add(deleteAwsClusterMethodDescriptor); methodDescriptors.add(generateAwsClusterAgentTokenMethodDescriptor); methodDescriptors.add(generateAwsAccessTokenMethodDescriptor); methodDescriptors.add(createAwsNodePoolMethodDescriptor); methodDescriptors.add(updateAwsNodePoolMethodDescriptor); methodDescriptors.add(rollbackAwsNodePoolUpdateMethodDescriptor); methodDescriptors.add(getAwsNodePoolMethodDescriptor); methodDescriptors.add(listAwsNodePoolsMethodDescriptor); methodDescriptors.add(deleteAwsNodePoolMethodDescriptor); methodDescriptors.add(getAwsOpenIdConfigMethodDescriptor); methodDescriptors.add(getAwsJsonWebKeysMethodDescriptor); methodDescriptors.add(getAwsServerConfigMethodDescriptor); return methodDescriptors; } public HttpJsonOperationsStub getHttpJsonOperationsStub() { return httpJsonOperationsStub; } @Override public UnaryCallable createAwsClusterCallable() { return createAwsClusterCallable; } @Override public OperationCallable createAwsClusterOperationCallable() { return createAwsClusterOperationCallable; } @Override public UnaryCallable updateAwsClusterCallable() { return updateAwsClusterCallable; } @Override public OperationCallable updateAwsClusterOperationCallable() { return updateAwsClusterOperationCallable; } @Override public UnaryCallable getAwsClusterCallable() { return getAwsClusterCallable; } @Override public UnaryCallable listAwsClustersCallable() { return listAwsClustersCallable; } @Override public UnaryCallable listAwsClustersPagedCallable() { return listAwsClustersPagedCallable; } @Override public UnaryCallable deleteAwsClusterCallable() { return deleteAwsClusterCallable; } @Override public OperationCallable deleteAwsClusterOperationCallable() { return deleteAwsClusterOperationCallable; } @Override public UnaryCallable generateAwsClusterAgentTokenCallable() { return generateAwsClusterAgentTokenCallable; } @Override public UnaryCallable generateAwsAccessTokenCallable() { return generateAwsAccessTokenCallable; } @Override public UnaryCallable createAwsNodePoolCallable() { return createAwsNodePoolCallable; } @Override public OperationCallable createAwsNodePoolOperationCallable() { return createAwsNodePoolOperationCallable; } @Override public UnaryCallable updateAwsNodePoolCallable() { return updateAwsNodePoolCallable; } @Override public OperationCallable updateAwsNodePoolOperationCallable() { return updateAwsNodePoolOperationCallable; } @Override public UnaryCallable rollbackAwsNodePoolUpdateCallable() { return rollbackAwsNodePoolUpdateCallable; } @Override public OperationCallable rollbackAwsNodePoolUpdateOperationCallable() { return rollbackAwsNodePoolUpdateOperationCallable; } @Override public UnaryCallable getAwsNodePoolCallable() { return getAwsNodePoolCallable; } @Override public UnaryCallable listAwsNodePoolsCallable() { return listAwsNodePoolsCallable; } @Override public UnaryCallable listAwsNodePoolsPagedCallable() { return listAwsNodePoolsPagedCallable; } @Override public UnaryCallable deleteAwsNodePoolCallable() { return deleteAwsNodePoolCallable; } @Override public OperationCallable deleteAwsNodePoolOperationCallable() { return deleteAwsNodePoolOperationCallable; } @Override public UnaryCallable getAwsOpenIdConfigCallable() { return getAwsOpenIdConfigCallable; } @Override public UnaryCallable getAwsJsonWebKeysCallable() { return getAwsJsonWebKeysCallable; } @Override public UnaryCallable getAwsServerConfigCallable() { return getAwsServerConfigCallable; } @Override public final void close() { try { backgroundResources.close(); } catch (RuntimeException e) { throw e; } catch (Exception e) { throw new IllegalStateException("Failed to close resource", e); } } @Override public void shutdown() { backgroundResources.shutdown(); } @Override public boolean isShutdown() { return backgroundResources.isShutdown(); } @Override public boolean isTerminated() { return backgroundResources.isTerminated(); } @Override public void shutdownNow() { backgroundResources.shutdownNow(); } @Override public boolean awaitTermination(long duration, TimeUnit unit) throws InterruptedException { return backgroundResources.awaitTermination(duration, unit); } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy