graphql.execution.instrumentation.SimplePerformantInstrumentation Maven / Gradle / Ivy
package graphql.execution.instrumentation;
import graphql.ExecutionInput;
import graphql.ExecutionResult;
import graphql.PublicApi;
import graphql.execution.ExecutionContext;
import graphql.execution.instrumentation.parameters.InstrumentationCreateStateParameters;
import graphql.execution.instrumentation.parameters.InstrumentationExecuteOperationParameters;
import graphql.execution.instrumentation.parameters.InstrumentationExecutionParameters;
import graphql.execution.instrumentation.parameters.InstrumentationExecutionStrategyParameters;
import graphql.execution.instrumentation.parameters.InstrumentationFieldCompleteParameters;
import graphql.execution.instrumentation.parameters.InstrumentationFieldFetchParameters;
import graphql.execution.instrumentation.parameters.InstrumentationFieldParameters;
import graphql.execution.instrumentation.parameters.InstrumentationValidationParameters;
import graphql.language.Document;
import graphql.schema.DataFetcher;
import graphql.schema.GraphQLSchema;
import graphql.validation.ValidationError;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import static graphql.Assert.assertShouldNeverHappen;
import static graphql.execution.instrumentation.SimpleInstrumentationContext.noOp;
/**
* An implementation of {@link Instrumentation} that does nothing. It can be used
* as a base for derived classes where you only implement the methods you want to. The reason this
* class is designated as more performant is that it does not delegate back to the deprecated methods
* and allocate a new state object per call.
*
* This behavior was left in place for backwards compatibility reasons inside {@link Instrumentation}
* and {@link SimpleInstrumentation} but has not been done in this class since no existing classes
* could have derived from it. If you want more performant behavior on methods you don't implement
* then this is the base class to use, since it will not delegate back to old methods
* and cause a new state to be allocated.
*/
@SuppressWarnings("deprecation")
@PublicApi
public class SimplePerformantInstrumentation implements Instrumentation {
/**
* A singleton instance of a {@link Instrumentation} that does nothing
*/
public static final SimplePerformantInstrumentation INSTANCE = new SimplePerformantInstrumentation();
@Override
public InstrumentationState createState() {
return assertShouldNeverHappen("The deprecated " + "createState" + " was called");
}
@Override
public @Nullable InstrumentationState createState(InstrumentationCreateStateParameters parameters) {
return null;
}
@Override
public @Nullable CompletableFuture createStateAsync(InstrumentationCreateStateParameters parameters) {
InstrumentationState state = createState(parameters);
return state == null ? null : CompletableFuture.completedFuture(state);
}
@Override
public @NotNull InstrumentationContext beginExecution(InstrumentationExecutionParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginExecution" + " was called");
}
@Override
public @Nullable InstrumentationContext beginExecution(InstrumentationExecutionParameters parameters, InstrumentationState state) {
return noOp();
}
@Override
public @NotNull InstrumentationContext beginParse(InstrumentationExecutionParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginParse" + " was called");
}
@Override
public @Nullable InstrumentationContext beginParse(InstrumentationExecutionParameters parameters, InstrumentationState state) {
return noOp();
}
@Override
public @NotNull InstrumentationContext> beginValidation(InstrumentationValidationParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginValidation" + " was called");
}
@Override
public @Nullable InstrumentationContext> beginValidation(InstrumentationValidationParameters parameters, InstrumentationState state) {
return noOp();
}
@Override
public @NotNull InstrumentationContext beginExecuteOperation(InstrumentationExecuteOperationParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginExecuteOperation" + " was called");
}
@Override
public @Nullable InstrumentationContext beginExecuteOperation(InstrumentationExecuteOperationParameters parameters, InstrumentationState state) {
return noOp();
}
@Override
public @NotNull ExecutionStrategyInstrumentationContext beginExecutionStrategy(InstrumentationExecutionStrategyParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginExecutionStrategy" + " was called");
}
@Override
public @Nullable ExecutionStrategyInstrumentationContext beginExecutionStrategy(InstrumentationExecutionStrategyParameters parameters, InstrumentationState state) {
return ExecutionStrategyInstrumentationContext.NOOP;
}
@Override
public @NotNull InstrumentationContext beginSubscribedFieldEvent(InstrumentationFieldParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginSubscribedFieldEvent" + " was called");
}
@Override
public @Nullable InstrumentationContext beginSubscribedFieldEvent(InstrumentationFieldParameters parameters, InstrumentationState state) {
return noOp();
}
@Override
public @NotNull InstrumentationContext beginField(InstrumentationFieldParameters parameters) {
return assertShouldNeverHappen("The deprecated " + "beginField" + " was called");
}
@Override
public @Nullable InstrumentationContext beginField(InstrumentationFieldParameters parameters, InstrumentationState state) {
return noOp();
}
@Override
public @NotNull InstrumentationContext