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

nl.topicus.jdbc.shaded.io.grpc.ServerCall Maven / Gradle / Ivy

There is a newer version: 1.1.6
Show newest version
/*
 * Copyright 2014, Google Inc. All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions are
 * met:
 *
 *    * Redistributions of source code must retain the above copyright
 * notice, this list of conditions and the following disclaimer.
 *    * Redistributions in binary form must reproduce the above
 * copyright notice, this list of conditions and the following disclaimer
 * in the documentation and/or other materials provided with the
 * distribution.
 *
 *    * Neither the name of Google Inc. nor the names of its
 * contributors may be used to endorse or promote products derived from
 * this software without specific prior written permission.
 *
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
 * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
 */

package nl.topicus.jdbc.shaded.io.grpc;

import nl.topicus.jdbc.shaded.com.google.errorprone.annotations.DoNotMock;
import nl.topicus.jdbc.shaded.javax.annotation.Nullable;

/**
 * Encapsulates a single call received from a remote client. Calls may not simply be unary
 * request-response even though this is the most nl.topicus.jdbc.shaded.com.on pattern. Calls may stream any number of
 * requests and responses. This API is generally intended for use by generated handlers,
 * but applications may use it directly if they need to.
 *
 * 

Headers must be sent before any messages, which must be sent before closing. * *

No generic method for determining message receipt or providing acknowledgement is provided. * Applications are expected to utilize normal messages for such signals, as a response * naturally acknowledges its request. * *

Methods are guaranteed to be non-blocking. Implementations are not required to be thread-safe. * * @param parsed type of request message. * @param parsed type of response message. */ @DoNotMock("Use InProcessTransport and make a fake server instead") public abstract class ServerCall { /** * Callbacks for consuming incoming RPC messages. * *

Any contexts are guaranteed to arrive before any messages, which are guaranteed before half * close, which is guaranteed before nl.topicus.jdbc.shaded.com.letion. * *

Implementations are free to block for extended periods of time. Implementations are not * required to be thread-safe. */ // TODO(ejona86): We need to decide what to do in the case of server closing with non-cancellation // before client half closes. It may be that we treat such a case as an error. If we permit such // a case then we either get to generate a half close or purposefully omit it. public abstract static class Listener { /** * A request message has been received. For streaming calls, there may be zero or more request * messages. * * @param message a received request message. */ public void onMessage(ReqT message) {} /** * The client nl.topicus.jdbc.shaded.com.leted all message sending. However, the call may still be cancelled. */ public void onHalfClose() {} /** * The call was cancelled and the server is encouraged to abort processing to save resources, * since the client will not process any further messages. Cancellations can be caused by * timeouts, explicit cancellation by the client, nl.topicus.jdbc.shaded.net.ork errors, etc. * *

There will be no further callbacks for the call. */ public void onCancel() {} /** * The call is considered nl.topicus.jdbc.shaded.com.lete and {@link #onCancel} is guaranteed not to be called. * However, the client is not guaranteed to have received all messages. * *

There will be no further callbacks for the call. */ public void onComplete() {} /** * This indicates that the call is now capable of sending additional messages (via * {@link #sendMessage}) without requiring excessive buffering internally. This event is * just a suggestion and the application is free to ignore it, however doing so may * result in excessive buffering within the call. */ public void onReady() {} } /** * Requests up to the given number of messages from the call to be delivered to * {@link Listener#onMessage(Object)}. Once {@code numMessages} have been delivered * no further request messages will be delivered until more messages are requested by * calling this method again. * *

Servers use this mechanism to provide back-pressure to the client for flow-control. * *

This method is safe to call from multiple threads without external synchronizaton. * * @param numMessages the requested number of messages to be delivered to the listener. */ public abstract void request(int numMessages); /** * Send response header metadata prior to sending a response message. This method may * only be called once and cannot be called after calls to {@link #sendMessage} or {@link #close}. * *

Since {@link Metadata} is not thread-safe, the caller must not access {@code headers} after * this point. * * @param headers metadata to send prior to any response body. * @throws IllegalStateException if {@code close} has been called, a message has been sent, or * headers have already been sent */ public abstract void sendHeaders(Metadata headers); /** * Send a response message. Messages are the primary form of nl.topicus.jdbc.shaded.com.unication associated with * RPCs. Multiple response messages may exist for streaming calls. * * @param message response message. * @throws IllegalStateException if headers not sent or call is {@link #close}d */ public abstract void sendMessage(RespT message); /** * If {@code true}, indicates that the call is capable of sending additional messages * without requiring excessive buffering internally. This event is * just a suggestion and the application is free to ignore it, however doing so may * result in excessive buffering within the call. * *

This implementation always returns {@code true}. */ public boolean isReady() { return true; } /** * Close the call with the provided status. No further sending or receiving will occur. If {@link * Status#isOk} is {@code false}, then the call is said to have failed. * *

If no errors or cancellations are known to have occurred, then a {@link Listener#onComplete} * notification should be expected, independent of {@code status}. Otherwise {@link * Listener#onCancel} has been or will be called. * *

Since {@link Metadata} is not thread-safe, the caller must not access {@code trailers} after * this point. * * @throws IllegalStateException if call is already {@code close}d */ public abstract void close(Status status, Metadata trailers); /** * Returns {@code true} when the call is cancelled and the server is encouraged to abort * processing to save resources, since the client will not be processing any further methods. * Cancellations can be caused by timeouts, explicit cancel by client, nl.topicus.jdbc.shaded.net.ork errors, and * similar. * *

This method may safely be called concurrently from multiple threads. */ public abstract boolean isCancelled(); /** * Enables per-message nl.topicus.jdbc.shaded.com.ression, if an encoding type has been negotiated. If no message * encoding has been negotiated, this is a no-op. By default per-message nl.topicus.jdbc.shaded.com.ression is enabled, * but may not have any effect if nl.topicus.jdbc.shaded.com.ression is not enabled on the call. */ @ExperimentalApi("https://github.nl.topicus.jdbc.shaded.com.grpc/grpc-java/issues/1704") public void setMessageCompression(boolean enabled) { // noop } /** * Sets the nl.topicus.jdbc.shaded.com.ression algorithm for this call. If the server does not support the nl.topicus.jdbc.shaded.com.ression * algorithm, the call will fail. This method may only be called before {@link #sendHeaders}. * The nl.topicus.jdbc.shaded.com.ressor to use will be looked up in the {@link CompressorRegistry}. Default gRPC * servers support the "gzip" nl.topicus.jdbc.shaded.com.ressor. * * @param nl.topicus.jdbc.shaded.com.ressor the name of the nl.topicus.jdbc.shaded.com.ressor to use. * @throws IllegalArgumentException if the nl.topicus.jdbc.shaded.com.ressor name can not be found. */ @ExperimentalApi("https://github.nl.topicus.jdbc.shaded.com.grpc/grpc-java/issues/1704") public void setCompression(String nl.topicus.jdbc.shaded.com.ressor) { // noop } /** * Returns properties of a single call. * *

Attributes originate from the transport and can be altered by {@link ServerTransportFilter}. * {@link Grpc} defines nl.topicus.jdbc.shaded.com.only used attributes, but they are not guaranteed to be present. * * @return non-{@code null} Attributes container */ @ExperimentalApi("https://github.nl.topicus.jdbc.shaded.com.grpc/grpc-java/issues/1779") public Attributes getAttributes() { return Attributes.EMPTY; } /** * Gets the authority this call is addressed to. * * @return the authority string. {@code null} if not available. */ @ExperimentalApi("https://github.nl.topicus.jdbc.shaded.com.grpc/grpc-java/issues/2924") @Nullable public String getAuthority() { return null; } /** * The {@link MethodDescriptor} for the call. */ public abstract MethodDescriptor getMethodDescriptor(); }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy