graphql.execution.AbstractAsyncExecutionStrategy Maven / Gradle / Ivy
package graphql.execution;
import com.google.common.collect.Maps;
import graphql.ExecutionResult;
import graphql.ExecutionResultImpl;
import graphql.PublicSpi;
import java.util.LinkedHashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.CompletableFuture;
import java.util.function.BiConsumer;
@PublicSpi
public abstract class AbstractAsyncExecutionStrategy extends ExecutionStrategy {
public AbstractAsyncExecutionStrategy() {
}
public AbstractAsyncExecutionStrategy(DataFetcherExceptionHandler dataFetcherExceptionHandler) {
super(dataFetcherExceptionHandler);
}
// This method is kept for backward compatibility. Prefer calling/overriding another handleResults method
protected BiConsumer, Throwable> handleResults(ExecutionContext executionContext, List fieldNames, CompletableFuture overallResult) {
return (List results, Throwable exception) -> {
if (exception != null) {
handleNonNullException(executionContext, overallResult, exception);
return;
}
Map resolvedValuesByField = Maps.newLinkedHashMapWithExpectedSize(fieldNames.size());
int ix = 0;
for (ExecutionResult executionResult : results) {
String fieldName = fieldNames.get(ix++);
resolvedValuesByField.put(fieldName, executionResult.getData());
}
overallResult.complete(new ExecutionResultImpl(resolvedValuesByField, executionContext.getErrors()));
};
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy