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

graphql.execution.ExecutionStrategyParameters Maven / Gradle / Ivy

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

import graphql.PublicApi;
import graphql.execution.incremental.DeferredCallContext;
import org.jetbrains.annotations.Nullable;

import java.util.function.Consumer;

import static graphql.Assert.assertNotNull;

/**
 * The parameters that are passed to execution strategies
 */
@PublicApi
public class ExecutionStrategyParameters {
    private final ExecutionStepInfo executionStepInfo;
    private final Object source;
    private final Object localContext;
    private final MergedSelectionSet fields;
    private final NonNullableFieldValidator nonNullableFieldValidator;
    private final ResultPath path;
    private final MergedField currentField;
    private final ExecutionStrategyParameters parent;
    private final DeferredCallContext deferredCallContext;

    private ExecutionStrategyParameters(ExecutionStepInfo executionStepInfo,
                                        Object source,
                                        Object localContext,
                                        MergedSelectionSet fields,
                                        NonNullableFieldValidator nonNullableFieldValidator,
                                        ResultPath path,
                                        MergedField currentField,
                                        ExecutionStrategyParameters parent,
                                        DeferredCallContext deferredCallContext) {

        this.executionStepInfo = assertNotNull(executionStepInfo, () -> "executionStepInfo is null");
        this.localContext = localContext;
        this.fields = assertNotNull(fields, () -> "fields is null");
        this.source = source;
        this.nonNullableFieldValidator = nonNullableFieldValidator;
        this.path = path;
        this.currentField = currentField;
        this.parent = parent;
        this.deferredCallContext = deferredCallContext;
    }

    public ExecutionStepInfo getExecutionStepInfo() {
        return executionStepInfo;
    }

    public Object getSource() {
        return source;
    }

    public MergedSelectionSet getFields() {
        return fields;
    }

    public NonNullableFieldValidator getNonNullFieldValidator() {
        return nonNullableFieldValidator;
    }

    public ResultPath getPath() {
        return path;
    }

    public Object getLocalContext() {
        return localContext;
    }

    public ExecutionStrategyParameters getParent() {
        return parent;
    }

    /**
     * Returns the deferred call context if we're in the scope of a deferred call.
     * A new DeferredCallContext is created for each @defer block, and is passed down to all fields within the deferred call.
     *
     * 
     *     query {
     *        ... @defer {
     *            field1 {        # new DeferredCallContext created here
     *                field1a     # DeferredCallContext passed down to this field
     *            }
     *        }
     *
     *        ... @defer {
     *            field2          # new DeferredCallContext created here
     *        }
     *     }
     * 
* * @return the deferred call context or null if we're not in the scope of a deferred call */ @Nullable public DeferredCallContext getDeferredCallContext() { return deferredCallContext; } /** * Returns true if we're in the scope of a deferred call. * * @return true if we're in the scope of a deferred call */ public boolean isInDeferredContext() { return deferredCallContext != null; } /** * This returns the current field in its query representations. * * @return the current merged fields */ public MergedField getField() { return currentField; } public ExecutionStrategyParameters transform(Consumer builderConsumer) { Builder builder = newParameters(this); builderConsumer.accept(builder); return builder.build(); } @Override public String toString() { return String.format("ExecutionStrategyParameters { path=%s, executionStepInfo=%s, source=%s, fields=%s }", path, executionStepInfo, source, fields); } public static Builder newParameters() { return new Builder(); } public static Builder newParameters(ExecutionStrategyParameters oldParameters) { return new Builder(oldParameters); } public static class Builder { ExecutionStepInfo executionStepInfo; Object source; Object localContext; MergedSelectionSet fields; NonNullableFieldValidator nonNullableFieldValidator; ResultPath path = ResultPath.rootPath(); MergedField currentField; ExecutionStrategyParameters parent; DeferredCallContext deferredCallContext; /** * @see ExecutionStrategyParameters#newParameters() */ private Builder() { } /** * @see ExecutionStrategyParameters#newParameters(ExecutionStrategyParameters) */ private Builder(ExecutionStrategyParameters oldParameters) { this.executionStepInfo = oldParameters.executionStepInfo; this.source = oldParameters.source; this.localContext = oldParameters.localContext; this.fields = oldParameters.fields; this.nonNullableFieldValidator = oldParameters.nonNullableFieldValidator; this.currentField = oldParameters.currentField; this.deferredCallContext = oldParameters.deferredCallContext; this.path = oldParameters.path; this.parent = oldParameters.parent; } public Builder executionStepInfo(ExecutionStepInfo executionStepInfo) { this.executionStepInfo = executionStepInfo; return this; } public Builder executionStepInfo(ExecutionStepInfo.Builder executionStepInfoBuilder) { this.executionStepInfo = executionStepInfoBuilder.build(); return this; } public Builder fields(MergedSelectionSet fields) { this.fields = fields; return this; } public Builder field(MergedField currentField) { this.currentField = currentField; return this; } public Builder source(Object source) { this.source = source; return this; } public Builder localContext(Object localContext) { this.localContext = localContext; return this; } public Builder nonNullFieldValidator(NonNullableFieldValidator nonNullableFieldValidator) { this.nonNullableFieldValidator = assertNotNull(nonNullableFieldValidator, () -> "requires a NonNullValidator"); return this; } public Builder path(ResultPath path) { this.path = path; return this; } public Builder parent(ExecutionStrategyParameters parent) { this.parent = parent; return this; } public Builder deferredCallContext(DeferredCallContext deferredCallContext) { this.deferredCallContext = deferredCallContext; return this; } public ExecutionStrategyParameters build() { return new ExecutionStrategyParameters(executionStepInfo, source, localContext, fields, nonNullableFieldValidator, path, currentField, parent, deferredCallContext); } } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy