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

graphql.execution.batched.UnbatchedDataFetcher Maven / Gradle / Ivy

There is a newer version: 230521-nf-execution
Show newest version
package graphql.execution.batched;


import graphql.execution.Async;
import graphql.schema.DataFetcher;
import graphql.schema.DataFetchingEnvironment;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.CompletionStage;

import static graphql.schema.DataFetchingEnvironmentBuilder.newDataFetchingEnvironment;

/**
 * Given a normal data fetcher as a delegate,
 * uses that fetcher in a batched context by iterating through each source value and calling
 * the delegate.
 */
public class UnbatchedDataFetcher implements BatchedDataFetcher {

    private final DataFetcher delegate;

    public UnbatchedDataFetcher(DataFetcher delegate) {
        this.delegate = delegate;
    }


    @Override
    public CompletableFuture> get(DataFetchingEnvironment environment) {
        List sources = environment.getSource();
        List> results = new ArrayList<>();
        for (Object source : sources) {

            DataFetchingEnvironment singleEnv = newDataFetchingEnvironment(environment)
                    .source(source).build();
            results.add(getResult(delegate.get(singleEnv)));
        }

        return Async.each(results);
    }

    private CompletableFuture getResult(Object rawResult) {
        if (!(rawResult instanceof CompletionStage)) {
            return CompletableFuture.completedFuture(rawResult);
        }
        return ((CompletionStage) rawResult).toCompletableFuture();
    }
}