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

graphql.execution.values.InputInterceptor Maven / Gradle / Ivy

package graphql.execution.values;

import graphql.GraphQLContext;
import graphql.Internal;
import graphql.schema.GraphQLInputType;
import org.jetbrains.annotations.NotNull;
import org.jetbrains.annotations.Nullable;

import java.util.Locale;

/**
 * This INTERNAL class can be used to intercept input values before they are coerced into runtime values
 * by the {@link graphql.execution.ValuesResolver} code.
 * 

* You could use it to observe input values and optionally change them. Perhaps some sort of migration of data * needs to happen, and you need to know what data you are getting in type terms. This would help you do that. *

* If this is present in a {@link GraphQLContext} it will be called. By default, it is not present * so no calls to it will be made. *

* There is a performance aspect to using this code. If you take too long to return values then you * are going to slow down your system depending on how big your input objects are. */ @Internal public interface InputInterceptor { /** * This is called with a value that is to be presented to the {@link graphql.execution.ValuesResolver} code. The values * may be scalars, enums and complex input types. * * @param value the input value that can be null * @param graphQLType the input type * @param graphqlContext the graphql context in play * @param locale the locale in play * * @return a value that may differ from the original value */ Object intercept(@Nullable Object value, @NotNull GraphQLInputType graphQLType, @NotNull GraphQLContext graphqlContext, @NotNull Locale locale); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy