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

com.google.cloud.apigeeconnect.v1.TetherClient Maven / Gradle / Ivy

Go to download

Apigee Connect allows the Apigee hybrid management plane to connect securely to the MART service in the runtime plane without requiring you to expose the MART endpoint on the internet.

There is a newer version: 2.49.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.apigeeconnect.v1;

import com.google.api.gax.core.BackgroundResource;
import com.google.api.gax.rpc.BidiStreamingCallable;
import com.google.cloud.apigeeconnect.v1.stub.TetherStub;
import com.google.cloud.apigeeconnect.v1.stub.TetherStubSettings;
import java.io.IOException;
import java.util.concurrent.TimeUnit;
import javax.annotation.Generated;

// AUTO-GENERATED DOCUMENTATION AND CLASS.
/**
 * Service Description: Tether provides a way for the control plane to send HTTP API requests to
 * services in data planes that runs in a remote datacenter without requiring customers to open
 * firewalls on their runtime plane.
 *
 * 

This class provides the ability to make remote calls to the backing service through method * calls that map to API methods. Sample code to get started: * *

{@code
 * // This snippet has been automatically generated and should be regarded as a code template only.
 * // It will require modifications to work:
 * // - It may require correct/in-range values for request initialization.
 * // - It may require specifying regional endpoints when creating the service client as shown in
 * // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
 * try (TetherClient tetherClient = TetherClient.create()) {
 *   BidiStream bidiStream = tetherClient.egressCallable().call();
 *   EgressResponse request =
 *       EgressResponse.newBuilder()
 *           .setId("id3355")
 *           .setHttpResponse(HttpResponse.newBuilder().build())
 *           .setStatus(Status.newBuilder().build())
 *           .setProject("project-309310695")
 *           .setTraceId("traceId-1067401920")
 *           .setEndpoint(TetherEndpoint.forNumber(0))
 *           .setName("name3373707")
 *           .build();
 *   bidiStream.send(request);
 *   for (EgressRequest response : bidiStream) {
 *     // Do something when a response is received.
 *   }
 * }
 * }
* *

Note: close() needs to be called on the TetherClient object to clean up resources such as * threads. In the example above, try-with-resources is used, which automatically calls close(). * *

* * * * * * * * * * * *
Methods
MethodDescriptionMethod Variants

Egress

Egress streams egress requests and responses. Logically, this is not actually a streaming request, but uses streaming as a mechanism to flip the client-server relationship of gRPC so that the server can act as a client. The listener, the RPC server, accepts connections from the dialer, the RPC client. The listener streams http requests and the dialer streams http responses.

*

Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.

*
    *
  • egressCallable() *

*
* *

See the individual methods for example code. * *

Many parameters require resource names to be formatted in a particular way. To assist with * these names, this class includes a format method for each type of name, and additionally a parse * method to extract the individual identifiers contained within names that are returned. * *

This class can be customized by passing in a custom instance of TetherSettings to create(). * For example: * *

To customize credentials: * *

{@code
 * // This snippet has been automatically generated and should be regarded as a code template only.
 * // It will require modifications to work:
 * // - It may require correct/in-range values for request initialization.
 * // - It may require specifying regional endpoints when creating the service client as shown in
 * // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
 * TetherSettings tetherSettings =
 *     TetherSettings.newBuilder()
 *         .setCredentialsProvider(FixedCredentialsProvider.create(myCredentials))
 *         .build();
 * TetherClient tetherClient = TetherClient.create(tetherSettings);
 * }
* *

To customize the endpoint: * *

{@code
 * // This snippet has been automatically generated and should be regarded as a code template only.
 * // It will require modifications to work:
 * // - It may require correct/in-range values for request initialization.
 * // - It may require specifying regional endpoints when creating the service client as shown in
 * // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
 * TetherSettings tetherSettings = TetherSettings.newBuilder().setEndpoint(myEndpoint).build();
 * TetherClient tetherClient = TetherClient.create(tetherSettings);
 * }
* *

Please refer to the GitHub repository's samples for more quickstart code snippets. */ @Generated("by gapic-generator-java") public class TetherClient implements BackgroundResource { private final TetherSettings settings; private final TetherStub stub; /** Constructs an instance of TetherClient with default settings. */ public static final TetherClient create() throws IOException { return create(TetherSettings.newBuilder().build()); } /** * Constructs an instance of TetherClient, using the given settings. The channels are created * based on the settings passed in, or defaults for any settings that are not set. */ public static final TetherClient create(TetherSettings settings) throws IOException { return new TetherClient(settings); } /** * Constructs an instance of TetherClient, using the given stub for making calls. This is for * advanced usage - prefer using create(TetherSettings). */ public static final TetherClient create(TetherStub stub) { return new TetherClient(stub); } /** * Constructs an instance of TetherClient, 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 TetherClient(TetherSettings settings) throws IOException { this.settings = settings; this.stub = ((TetherStubSettings) settings.getStubSettings()).createStub(); } protected TetherClient(TetherStub stub) { this.settings = null; this.stub = stub; } public final TetherSettings getSettings() { return settings; } public TetherStub getStub() { return stub; } // AUTO-GENERATED DOCUMENTATION AND METHOD. /** * Egress streams egress requests and responses. Logically, this is not actually a streaming * request, but uses streaming as a mechanism to flip the client-server relationship of gRPC so * that the server can act as a client. The listener, the RPC server, accepts connections from the * dialer, the RPC client. The listener streams http requests and the dialer streams http * responses. * *

Sample code: * *

{@code
   * // This snippet has been automatically generated and should be regarded as a code template only.
   * // It will require modifications to work:
   * // - It may require correct/in-range values for request initialization.
   * // - It may require specifying regional endpoints when creating the service client as shown in
   * // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
   * try (TetherClient tetherClient = TetherClient.create()) {
   *   BidiStream bidiStream = tetherClient.egressCallable().call();
   *   EgressResponse request =
   *       EgressResponse.newBuilder()
   *           .setId("id3355")
   *           .setHttpResponse(HttpResponse.newBuilder().build())
   *           .setStatus(Status.newBuilder().build())
   *           .setProject("project-309310695")
   *           .setTraceId("traceId-1067401920")
   *           .setEndpoint(TetherEndpoint.forNumber(0))
   *           .setName("name3373707")
   *           .build();
   *   bidiStream.send(request);
   *   for (EgressRequest response : bidiStream) {
   *     // Do something when a response is received.
   *   }
   * }
   * }
*/ public final BidiStreamingCallable egressCallable() { return stub.egressCallable(); } @Override public final void close() { stub.close(); } @Override public void shutdown() { stub.shutdown(); } @Override public boolean isShutdown() { return stub.isShutdown(); } @Override public boolean isTerminated() { return stub.isTerminated(); } @Override public void shutdownNow() { stub.shutdownNow(); } @Override public boolean awaitTermination(long duration, TimeUnit unit) throws InterruptedException { return stub.awaitTermination(duration, unit); } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy