graphql.schema.DataFetchingEnvironment Maven / Gradle / Ivy
package graphql.schema;
import graphql.PublicApi;
import graphql.cachecontrol.CacheControl;
import graphql.execution.ExecutionId;
import graphql.execution.ExecutionStepInfo;
import graphql.execution.MergedField;
import graphql.language.Document;
import graphql.language.Field;
import graphql.language.FragmentDefinition;
import graphql.language.OperationDefinition;
import org.dataloader.DataLoader;
import java.util.List;
import java.util.Map;
/**
* A DataFetchingEnvironment instance of passed to a {@link DataFetcher} as a execution context and its
* the place where you can find out information to help you resolve a data value given a graphql field input
*/
@SuppressWarnings("TypeParameterUnusedInFormals")
@PublicApi
public interface DataFetchingEnvironment {
/**
* This is the value of the current object to be queried.
* Or to put it differently: it is the value of the parent field.
*
* For the root query, it is equal to {{@link DataFetchingEnvironment#getRoot}
*
* @param you decide what type it is
*
* @return can be null for the root query, otherwise it is never null
*/
T getSource();
/**
* @return the arguments that have been passed in via the graphql query
*/
Map getArguments();
/**
* Returns true of the named argument is present
*
* @param name the name of the argument
*
* @return true of the named argument is present
*/
boolean containsArgument(String name);
/**
* Returns the named argument
*
* @param name the name of the argument
* @param you decide what type it is
*
* @return the named argument or null if its not [present
*/
T getArgument(String name);
/**
* Returns a context argument that is set up when the {@link graphql.GraphQL#execute} method
* is invoked.
*
* This is a info object which is provided to all DataFetchers, but never used by graphql-java itself.
*
* @param you decide what type it is
*
* @return can be null
*/
T getContext();
/**
* This returns a context object that parent fields may have returned returned
* via {@link graphql.execution.DataFetcherResult#getLocalContext()} which can be used to pass down extra information to
* fields beyond the normal {@link #getSource()}
*
* This differs from {@link #getContext()} in that its field specific and passed from parent field to child field,
* whilst {@link #getContext()} is global for the whole query.
*
* If the field is a top level field then 'localContext' equals the global 'context'
*
* @param you decide what type it is
*
* @return can be null if no field context objects are passed back by previous parent fields
*/
T getLocalContext();
/**
* This is the source object for the root query.
*
* @param you decide what type it is
*
* @return can be null
*/
T getRoot();
/**
* @return the definition of the current field
*/
GraphQLFieldDefinition getFieldDefinition();
/**
* @return the list of fields
*
* @deprecated Use {@link #getMergedField()}.
*/
@Deprecated
List getFields();
/**
* It can happen that a query has overlapping fields which are
* are querying the same data. If this is the case they get merged
* together and fetched only once, but this method returns all of the Fields
* from the query.
*
* Most of the time you probably want to use {@link #getField()}.
*
* Example query with more than one Field returned:
*
*
* {@code
*
* query Foo {
* bar
* ...BarFragment
* }
*
* fragment BarFragment on Query {
* bar
* }
* }
*
*
* @return the list of fields currently queried
*/
MergedField getMergedField();
/**
* @return returns the field which is currently queried. See also {@link #getMergedField()}.
*/
Field getField();
/**
* @return graphql type of the current field
*/
GraphQLOutputType getFieldType();
/**
* @return the field {@link ExecutionStepInfo} for the current data fetch operation
*/
ExecutionStepInfo getExecutionStepInfo();
/**
* @return the type of the parent of the current field
*/
GraphQLType getParentType();
/**
* @return the underlying graphql schema
*/
GraphQLSchema getGraphQLSchema();
/**
* @return the {@link FragmentDefinition} map for the current data fetch operation
*/
Map getFragmentsByName();
/**
* @return the {@link ExecutionId} for the current data fetch operation
*/
ExecutionId getExecutionId();
/**
* @return the {@link DataFetchingFieldSelectionSet} for the current data fetch operation
*/
DataFetchingFieldSelectionSet getSelectionSet();
/**
* This allows you to retrieve a named dataloader from the underlying {@link org.dataloader.DataLoaderRegistry}
*
* @param dataLoaderName the name of the data loader to fetch
* @param the key type
* @param the value type
*
* @return the named data loader or null
*
* @see graphql.execution.ExecutionContext#getDataLoaderRegistry()
* @see org.dataloader.DataLoaderRegistry#getDataLoader(String)
*/
DataLoader getDataLoader(String dataLoaderName);
/**
* @return the current {@link CacheControl} instance used to add cache hints to the response
*/
CacheControl getCacheControl();
/**
* @return the current operation that is being executed
*/
OperationDefinition getOperationDefinition();
/**
* @return the current query Document that is being executed
*/
Document getDocument();
/**
* This returns the variables that have been passed into the query. Note that this is the raw variables themselves and not the
* arguments to the field, which is accessed via {@link #getArguments()}
*
* The field arguments are created by interpolating any referenced variables and AST literals and resolving them into the arguments
*
* @return the variables that have been passed to the query that is being executed
*/
Map getVariables();
}