graphql.execution.instrumentation.Instrumentation Maven / Gradle / Ivy
package graphql.execution.instrumentation;
import graphql.DeprecatedAt;
import graphql.ExecutionInput;
import graphql.ExecutionResult;
import graphql.PublicSpi;
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.execution.instrumentation.SimpleInstrumentationContext.noOp;
/**
* Provides the capability to instrument the execution steps of a GraphQL query.
*
* For example you might want to track which fields are taking the most time to fetch from the backing database
* or log what fields are being asked for.
*
* Remember that graphql calls can cross threads so make sure you think about the thread safety of any instrumentation
* code when you are writing it.
*
* Each step gives back an {@link graphql.execution.instrumentation.InstrumentationContext} object. This has two callbacks on it,
* one for the step is `dispatched` and one for when the step has `completed`. This is done because many of the "steps" are asynchronous
* operations such as fetching data and resolving it into objects.
*/
@PublicSpi
public interface Instrumentation {
/**
* This will be called just before execution to create an object that is given back to all instrumentation methods
* to allow them to have per execution request state
*
* @return a state object that is passed to each method
*
* @deprecated use {@link #createState(InstrumentationCreateStateParameters)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
default InstrumentationState createState() {
return null;
}
/**
* This will be called just before execution to create an object that is given back to all instrumentation methods
* to allow them to have per execution request state
*
* @param parameters the parameters to this step
*
* @return a state object that is passed to each method
*/
@Nullable
default InstrumentationState createState(InstrumentationCreateStateParameters parameters) {
return createState();
}
/**
* This is called right at the start of query execution, and it's the first step in the instrumentation chain.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginExecution(InstrumentationExecutionParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext beginExecution(InstrumentationExecutionParameters parameters) {
return noOp();
}
/**
* This is called right at the start of query execution, and it's the first step in the instrumentation chain.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link InstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default InstrumentationContext beginExecution(InstrumentationExecutionParameters parameters, InstrumentationState state) {
return beginExecution(parameters.withNewState(state));
}
/**
* This is called just before a query is parsed.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginParse(InstrumentationExecutionParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext beginParse(InstrumentationExecutionParameters parameters) {
return noOp();
}
/**
* This is called just before a query is parsed.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link InstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default InstrumentationContext beginParse(InstrumentationExecutionParameters parameters, InstrumentationState state) {
return beginParse(parameters.withNewState(state));
}
/**
* This is called just before the parsed query document is validated.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginValidation(InstrumentationValidationParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext> beginValidation(InstrumentationValidationParameters parameters) {
return noOp();
}
/**
* This is called just before the parsed query document is validated.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link InstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default InstrumentationContext> beginValidation(InstrumentationValidationParameters parameters, InstrumentationState state) {
return beginValidation(parameters.withNewState(state));
}
/**
* This is called just before the execution of the query operation is started.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginExecuteOperation(InstrumentationExecuteOperationParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext beginExecuteOperation(InstrumentationExecuteOperationParameters parameters) {
return noOp();
}
/**
* This is called just before the execution of the query operation is started.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link InstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default InstrumentationContext beginExecuteOperation(InstrumentationExecuteOperationParameters parameters, InstrumentationState state) {
return beginExecuteOperation(parameters.withNewState(state));
}
/**
* This is called each time an {@link graphql.execution.ExecutionStrategy} is invoked, which may be multiple times
* per query as the engine recursively descends down over the query.
*
* @param parameters the parameters to this step
*
* @return a non null {@link ExecutionStrategyInstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginExecutionStrategy(InstrumentationExecutionStrategyParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default ExecutionStrategyInstrumentationContext beginExecutionStrategy(InstrumentationExecutionStrategyParameters parameters) {
return ExecutionStrategyInstrumentationContext.NOOP;
}
/**
* This is called each time an {@link graphql.execution.ExecutionStrategy} is invoked, which may be multiple times
* per query as the engine recursively descends down over the query.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link ExecutionStrategyInstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default ExecutionStrategyInstrumentationContext beginExecutionStrategy(InstrumentationExecutionStrategyParameters parameters, InstrumentationState state) {
return beginExecutionStrategy(parameters.withNewState(state));
}
/**
* This is called each time a subscription field produces a new reactive stream event value and it needs to be mapped over via the graphql field subselection.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginSubscribedFieldEvent(InstrumentationFieldParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext beginSubscribedFieldEvent(InstrumentationFieldParameters parameters) {
return noOp();
}
/**
* This is called each time a subscription field produces a new reactive stream event value and it needs to be mapped over via the graphql field subselection.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link InstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default InstrumentationContext beginSubscribedFieldEvent(InstrumentationFieldParameters parameters, InstrumentationState state) {
return beginSubscribedFieldEvent(parameters.withNewState(state));
}
/**
* This is called just before a field is resolved into a value.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginField(InstrumentationFieldParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext beginField(InstrumentationFieldParameters parameters) {
return noOp();
}
/**
* This is called just before a field is resolved into a value.
*
* @param parameters the parameters to this step
* @param state the state created during the call to {@link #createState(InstrumentationCreateStateParameters)}
*
* @return a nullable {@link InstrumentationContext} object that will be called back when the step ends (assuming it's not null)
*/
@Nullable
default InstrumentationContext beginField(InstrumentationFieldParameters parameters, InstrumentationState state) {
return beginField(parameters.withNewState(state));
}
/**
* This is called just before a field {@link DataFetcher} is invoked.
*
* @param parameters the parameters to this step
*
* @return a non null {@link InstrumentationContext} object that will be called back when the step ends
*
* @deprecated use {@link #beginFieldFetch(InstrumentationFieldFetchParameters, InstrumentationState)} instead
*/
@Deprecated
@DeprecatedAt("2022-07-26")
@NotNull
default InstrumentationContext
© 2015 - 2025 Weber Informatics LLC | Privacy Policy