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

io.grpc.ServerStreamTracer Maven / Gradle / Ivy

/*
 * Copyright 2017 The gRPC Authors
 *
 * 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 io.grpc;

import javax.annotation.Nullable;
import javax.annotation.concurrent.ThreadSafe;

/**
 * Listens to events on a stream to collect metrics.
 */
@ExperimentalApi("https://github.com/grpc/grpc-java/issues/2861")
@ThreadSafe
public abstract class ServerStreamTracer extends StreamTracer {
  /**
   * Called before the interceptors and the call handlers and make changes to the Context object
   * if needed.
   */
  public Context filterContext(Context context) {
    return context;
  }

  /**
   * Called when {@link ServerCall} is created.  This is for the tracer to access information about
   * the {@code ServerCall}.  Called after {@link #filterContext} and before the application call
   * handler.
   */
  @SuppressWarnings("deprecation")
  public void serverCallStarted(ServerCallInfo callInfo) {
    serverCallStarted(ReadOnlyServerCall.create(callInfo));
  }

  /**
   * Called when {@link ServerCall} is created.  This is for the tracer to access information about
   * the {@code ServerCall}.  Called after {@link #filterContext} and before the application call
   * handler.
   *
   * @deprecated Implement {@link #serverCallStarted(ServerCallInfo)} instead. This method will be
   *     removed in a future release of gRPC.
   */
  @Deprecated
  public void serverCallStarted(ServerCall call) {
  }

  public abstract static class Factory {
    /**
     * Creates a {@link ServerStreamTracer} for a new server stream.
     *
     * 

Called right before the stream is created * * @param fullMethodName the fully qualified method name * @param headers the received request headers. It can be safely mutated within this method. * It should not be saved because it is not safe for read or write after the method * returns. */ public abstract ServerStreamTracer newServerStreamTracer( String fullMethodName, Metadata headers); } /** * A data class with info about the started {@link ServerCall}. */ public abstract static class ServerCallInfo { public abstract MethodDescriptor getMethodDescriptor(); public abstract Attributes getAttributes(); @Nullable public abstract String getAuthority(); } /** * This class exists solely to help transition to the {@link ServerCallInfo} based API. * * @deprecated Will be deleted when {@link #serverCallStarted(ServerCall)} is removed. */ @Deprecated private static final class ReadOnlyServerCall extends ForwardingServerCall { private final ServerCallInfo callInfo; private static ReadOnlyServerCall create( ServerCallInfo callInfo) { return new ReadOnlyServerCall<>(callInfo); } private ReadOnlyServerCall(ServerCallInfo callInfo) { this.callInfo = callInfo; } @Override public MethodDescriptor getMethodDescriptor() { return callInfo.getMethodDescriptor(); } @Override public Attributes getAttributes() { return callInfo.getAttributes(); } @Override public boolean isReady() { // a dummy value return false; } @Override public boolean isCancelled() { // a dummy value return false; } @Override public String getAuthority() { return callInfo.getAuthority(); } @Override protected ServerCall delegate() { throw new UnsupportedOperationException(); } } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy