node_modules.graphql.validation.rules.PossibleFragmentSpreads.js.flow Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of apollo-client-maven-plugin Show documentation
Show all versions of apollo-client-maven-plugin Show documentation
Maven plugin for generating graphql clients
/* @flow */
/**
* Copyright (c) 2015, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
*/
import type { ValidationContext } from '../index';
import { GraphQLError } from '../../error';
import { doTypesOverlap } from '../../utilities/typeComparators';
import { typeFromAST } from '../../utilities/typeFromAST';
import type { GraphQLType } from '../../type/definition';
export function typeIncompatibleSpreadMessage(
fragName: string,
parentType: GraphQLType,
fragType: GraphQLType
): string {
return `Fragment "${fragName}" cannot be spread here as objects of ` +
`type "${String(parentType)}" can never be of type "${String(fragType)}".`;
}
export function typeIncompatibleAnonSpreadMessage(
parentType: GraphQLType,
fragType: GraphQLType
): string {
return 'Fragment cannot be spread here as objects of ' +
`type "${String(parentType)}" can never be of type "${String(fragType)}".`;
}
/**
* Possible fragment spread
*
* A fragment spread is only valid if the type condition could ever possibly
* be true: if there is a non-empty intersection of the possible parent types,
* and possible types which pass the type condition.
*/
export function PossibleFragmentSpreads(context: ValidationContext): any {
return {
InlineFragment(node) {
const fragType = context.getType();
const parentType = context.getParentType();
if (fragType &&
parentType &&
!doTypesOverlap(context.getSchema(), fragType, parentType)) {
context.reportError(new GraphQLError(
typeIncompatibleAnonSpreadMessage(parentType, fragType),
[ node ]
));
}
},
FragmentSpread(node) {
const fragName = node.name.value;
const fragType = getFragmentType(context, fragName);
const parentType = context.getParentType();
if (fragType &&
parentType &&
!doTypesOverlap(context.getSchema(), fragType, parentType)) {
context.reportError(new GraphQLError(
typeIncompatibleSpreadMessage(fragName, parentType, fragType),
[ node ]
));
}
}
};
}
function getFragmentType(context, name) {
const frag = context.getFragment(name);
return frag && typeFromAST(context.getSchema(), frag.typeCondition);
}