graphql.execution.AsyncSerialExecutionStrategy Maven / Gradle / Ivy
package graphql.execution;
import graphql.ExecutionResult;
import graphql.PublicApi;
import graphql.execution.instrumentation.Instrumentation;
import graphql.execution.instrumentation.InstrumentationContext;
import graphql.execution.instrumentation.parameters.InstrumentationExecutionStrategyParameters;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CompletableFuture;
/**
* Async non-blocking execution, but serial: only one field at the the time will be resolved.
* See {@link AsyncExecutionStrategy} for a non serial (parallel) execution of every field.
*/
@PublicApi
public class AsyncSerialExecutionStrategy extends AbstractAsyncExecutionStrategy {
public AsyncSerialExecutionStrategy() {
super(new SimpleDataFetcherExceptionHandler());
}
public AsyncSerialExecutionStrategy(DataFetcherExceptionHandler exceptionHandler) {
super(exceptionHandler);
}
@Override
@SuppressWarnings({"TypeParameterUnusedInFormals", "FutureReturnValueIgnored"})
public CompletableFuture execute(ExecutionContext executionContext, ExecutionStrategyParameters parameters) throws NonNullableFieldWasNullException {
Instrumentation instrumentation = executionContext.getInstrumentation();
InstrumentationExecutionStrategyParameters instrumentationParameters = new InstrumentationExecutionStrategyParameters(executionContext, parameters);
InstrumentationContext executionStrategyCtx = instrumentation.beginExecutionStrategy(instrumentationParameters);
MergedSelectionSet fields = parameters.getFields();
List fieldNames = new ArrayList<>(fields.keySet());
CompletableFuture> resultsFuture = Async.eachSequentially(fieldNames, (fieldName, index, prevResults) -> {
MergedField currentField = fields.getSubField(fieldName);
ResultPath fieldPath = parameters.getPath().segment(mkNameForPath(currentField));
ExecutionStrategyParameters newParameters = parameters
.transform(builder -> builder.field(currentField).path(fieldPath));
return resolveField(executionContext, newParameters);
});
CompletableFuture overallResult = new CompletableFuture<>();
executionStrategyCtx.onDispatched(overallResult);
resultsFuture.whenComplete(handleResults(executionContext, fieldNames, overallResult, parameters));
overallResult.whenComplete(executionStrategyCtx::onCompleted);
return overallResult;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy