diff options
author | Minteck <contact@minteck.org> | 2023-01-10 14:54:04 +0100 |
---|---|---|
committer | Minteck <contact@minteck.org> | 2023-01-10 14:54:04 +0100 |
commit | 99c1d9af689e5325f3cf535c4007b3aeb8325229 (patch) | |
tree | e663b3c2ebdbd67c818ac0c5147f0ce1d2463cda /school/node_modules/graphql/error/locatedError.js.flow | |
parent | 9871b03912fc28ad38b4037ebf26a78aa937baba (diff) | |
download | pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.gz pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.tar.bz2 pluralconnect-99c1d9af689e5325f3cf535c4007b3aeb8325229.zip |
Update - This is an automated commit
Diffstat (limited to 'school/node_modules/graphql/error/locatedError.js.flow')
-rw-r--r-- | school/node_modules/graphql/error/locatedError.js.flow | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/school/node_modules/graphql/error/locatedError.js.flow b/school/node_modules/graphql/error/locatedError.js.flow new file mode 100644 index 0000000..3ef40c8 --- /dev/null +++ b/school/node_modules/graphql/error/locatedError.js.flow @@ -0,0 +1,37 @@ +// @flow strict +import inspect from '../jsutils/inspect'; + +import type { ASTNode } from '../language/ast'; + +import { GraphQLError } from './GraphQLError'; + +/** + * Given an arbitrary value, presumably thrown while attempting to execute a + * GraphQL operation, produce a new GraphQLError aware of the location in the + * document responsible for the original Error. + */ +export function locatedError( + rawOriginalError: mixed, + nodes: ASTNode | $ReadOnlyArray<ASTNode> | void | null, + path?: ?$ReadOnlyArray<string | number>, +): GraphQLError { + // Sometimes a non-error is thrown, wrap it as an Error instance to ensure a consistent Error interface. + const originalError: Error | GraphQLError = + rawOriginalError instanceof Error + ? rawOriginalError + : new Error('Unexpected error value: ' + inspect(rawOriginalError)); + + // Note: this uses a brand-check to support GraphQL errors originating from other contexts. + if (Array.isArray(originalError.path)) { + return (originalError: any); + } + + return new GraphQLError( + originalError.message, + (originalError: any).nodes ?? nodes, + (originalError: any).source, + (originalError: any).positions, + path, + originalError, + ); +} |