summaryrefslogtreecommitdiff
path: root/school/node_modules/graphql/error/locatedError.js.flow
diff options
context:
space:
mode:
authorMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
committerMinteck <contact@minteck.org>2023-01-10 14:54:04 +0100
commit99c1d9af689e5325f3cf535c4007b3aeb8325229 (patch)
treee663b3c2ebdbd67c818ac0c5147f0ce1d2463cda /school/node_modules/graphql/error/locatedError.js.flow
parent9871b03912fc28ad38b4037ebf26a78aa937baba (diff)
downloadpluralconnect-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.flow37
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,
+ );
+}