nl.topicus.jdbc.shaded.io.grpc.stub.ClientResponseObserver Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of spanner-jdbc Show documentation
Show all versions of spanner-jdbc Show documentation
JDBC Driver for Google Cloud Spanner
/*
* Copyright 2016, gRPC Authors All rights reserved.
*
* 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.
*/
package nl.topicus.jdbc.shaded.io.grpc.stub;
import nl.topicus.jdbc.shaded.io.grpc.ExperimentalApi;
/**
* Specialization of {@link StreamObserver} implemented by clients in order to interact with the
* advanced features of a call such as flow-control.
*/
@ExperimentalApi
public interface ClientResponseObserver extends StreamObserver {
/**
* Called by the runtime priot to the start of a call to provide a reference to the
* {@link ClientCallStreamObserver} for the outbound stream. This can be used to listen to
* onReady events, disable auto inbound flow and perform other advanced functions.
*
* Only the methods {@link ClientCallStreamObserver#setOnReadyHandler(Runnable)} and
* {@link ClientCallStreamObserver#disableAutoInboundFlowControl()} may be called within this
* callback
*
*
* // Copy an iterator to the request stream under flow-control
* someStub.fullDuplexCall(new ClientResponseObserver<ReqT, RespT>() {
* public void beforeStart(final ClientCallStreamObserver<Req> requestStream) {
* StreamObservers.copyWithFlowControl(someIterator, requestStream);
* });
*
*/
void beforeStart(final ClientCallStreamObserver requestStream);
}