graphql.execution.NonNullableFieldValidator Maven / Gradle / Ivy
package graphql.execution;
import graphql.Internal;
/**
* This will check that a value is non null when the type definition says it must be and it will throw {@link NonNullableFieldWasNullException}
* if this is not the case.
*
* See: http://facebook.github.io/graphql/#sec-Errors-and-Non-Nullability
*/
@Internal
public class NonNullableFieldValidator {
private final ExecutionContext executionContext;
private final ExecutionStepInfo executionStepInfo;
public NonNullableFieldValidator(ExecutionContext executionContext, ExecutionStepInfo executionStepInfo) {
this.executionContext = executionContext;
this.executionStepInfo = executionStepInfo;
}
/**
* Called to check that a value is non null if the type requires it to be non null
*
* @param path the path to this place
* @param result the result to check
* @param the type of the result
*
* @return the result back
*
* @throws NonNullableFieldWasNullException if the value is null but the type requires it to be non null
*/
public T validate(ResultPath path, T result) throws NonNullableFieldWasNullException {
if (result == null) {
if (executionStepInfo.isNonNullType()) {
// see http://facebook.github.io/graphql/#sec-Errors-and-Non-Nullability
//
// > If the field returns null because of an error which has already been added to the "errors" list in the response,
// > the "errors" list must not be further affected. That is, only one error should be added to the errors list per field.
//
// We interpret this to cover the null field path only. So here we use the variant of addError() that checks
// for the current path already.
//
// Other places in the code base use the addError() that does not care about previous errors on that path being there.
//
// We will do this until the spec makes this more explicit.
//
NonNullableFieldWasNullException nonNullException = new NonNullableFieldWasNullException(executionStepInfo, path);
executionContext.addError(new NonNullableFieldWasNullError(nonNullException), path);
throw nonNullException;
}
}
return result;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy