VariablePredicate.java

package graphql.normalized;

import graphql.PublicSpi;
import graphql.execution.directives.QueryAppliedDirective;

/**
 * This predicate indicates whether a variable should be made for this field argument OR whether it will be compiled
 * into a graphql AST literal.
 */
@PublicSpi
public interface VariablePredicate {
    /**
     * Return true if a variable should be made for this field argument
     *
     * @param executableNormalizedField the field in question
     * @param argName                   the argument on the field
     * @param normalizedInputValue      the input value for that argument
     *
     * @return true if a variable should be made
     */
    boolean shouldMakeVariable(ExecutableNormalizedField executableNormalizedField,
                               String argName,
                               NormalizedInputValue normalizedInputValue);

    /**
     * Return true if a variable should be made for this query directive argument
     * on the specified field
     *
     * @param executableNormalizedField the field in question
     * @param queryAppliedDirective     the query directive in question
     * @param argName                   the argument on the directive
     * @param normalizedInputValue      the input value for that argument
     *
     * @return true if a variable should be made
     */
    default boolean shouldMakeVariable(ExecutableNormalizedField executableNormalizedField,
                                       QueryAppliedDirective queryAppliedDirective,
                                       String argName,
                                       NormalizedInputValue normalizedInputValue) {
        return false;
    }
}