graphql.TypeResolutionEnvironment Maven / Gradle / Ivy
package graphql;
import graphql.execution.MergedField;
import graphql.schema.GraphQLSchema;
import graphql.schema.GraphQLType;
import java.util.Map;
/**
* This is passed to a {@link graphql.schema.TypeResolver} to help with object type resolution.
*
* See {@link graphql.schema.TypeResolver#getType(TypeResolutionEnvironment)} for how this is used
*/
@SuppressWarnings("TypeParameterUnusedInFormals")
@PublicApi
public class TypeResolutionEnvironment {
private final Object object;
private final Map arguments;
private final MergedField field;
private final GraphQLType fieldType;
private final GraphQLSchema schema;
private final Object context;
public TypeResolutionEnvironment(Object object, Map arguments, MergedField field, GraphQLType fieldType, GraphQLSchema schema, final Object context) {
this.object = object;
this.arguments = arguments;
this.field = field;
this.fieldType = fieldType;
this.schema = schema;
this.context = context;
}
/**
* You will be passed the specific source object that needs to be resolve into a concrete graphql object type
*
* @param you decide what type it is
*
* @return the object that needs to be resolved into a specific graphql object type
*/
@SuppressWarnings("unchecked")
public T getObject() {
return (T) object;
}
/**
* @return the runtime arguments to this the graphql field
*/
public Map getArguments() {
return arguments;
}
/**
* @return the graphql field in question
*/
public MergedField getField() {
return field;
}
/**
* @return the type of the graphql field, which still be either a {@link graphql.schema.GraphQLUnionType} or a
* {@link graphql.schema.GraphQLInterfaceType}
*/
public GraphQLType getFieldType() {
return fieldType;
}
/**
* @return the graphql schema in question
*/
public GraphQLSchema getSchema() {
return schema;
}
public T getContext() {
return (T) context;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy