summaryrefslogtreecommitdiff
path: root/school/node_modules/graphql/utilities/astFromValue.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/utilities/astFromValue.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/utilities/astFromValue.js.flow')
-rw-r--r--school/node_modules/graphql/utilities/astFromValue.js.flow154
1 files changed, 154 insertions, 0 deletions
diff --git a/school/node_modules/graphql/utilities/astFromValue.js.flow b/school/node_modules/graphql/utilities/astFromValue.js.flow
new file mode 100644
index 0000000..d7528ee
--- /dev/null
+++ b/school/node_modules/graphql/utilities/astFromValue.js.flow
@@ -0,0 +1,154 @@
+// @flow strict
+import isFinite from '../polyfills/isFinite';
+import objectValues from '../polyfills/objectValues';
+
+import inspect from '../jsutils/inspect';
+import invariant from '../jsutils/invariant';
+import isObjectLike from '../jsutils/isObjectLike';
+import safeArrayFrom from '../jsutils/safeArrayFrom';
+
+import type { ValueNode } from '../language/ast';
+import { Kind } from '../language/kinds';
+
+import type { GraphQLInputType } from '../type/definition';
+import { GraphQLID } from '../type/scalars';
+import {
+ isLeafType,
+ isEnumType,
+ isInputObjectType,
+ isListType,
+ isNonNullType,
+} from '../type/definition';
+
+/**
+ * Produces a GraphQL Value AST given a JavaScript object.
+ * Function will match JavaScript/JSON values to GraphQL AST schema format
+ * by using suggested GraphQLInputType. For example:
+ *
+ * astFromValue("value", GraphQLString)
+ *
+ * A GraphQL type must be provided, which will be used to interpret different
+ * JavaScript values.
+ *
+ * | JSON Value | GraphQL Value |
+ * | ------------- | -------------------- |
+ * | Object | Input Object |
+ * | Array | List |
+ * | Boolean | Boolean |
+ * | String | String / Enum Value |
+ * | Number | Int / Float |
+ * | Mixed | Enum Value |
+ * | null | NullValue |
+ *
+ */
+export function astFromValue(value: mixed, type: GraphQLInputType): ?ValueNode {
+ if (isNonNullType(type)) {
+ const astValue = astFromValue(value, type.ofType);
+ if (astValue?.kind === Kind.NULL) {
+ return null;
+ }
+ return astValue;
+ }
+
+ // only explicit null, not undefined, NaN
+ if (value === null) {
+ return { kind: Kind.NULL };
+ }
+
+ // undefined
+ if (value === undefined) {
+ return null;
+ }
+
+ // Convert JavaScript array to GraphQL list. If the GraphQLType is a list, but
+ // the value is not an array, convert the value using the list's item type.
+ if (isListType(type)) {
+ const itemType = type.ofType;
+
+ const items = safeArrayFrom(value);
+ if (items != null) {
+ const valuesNodes = [];
+ for (const item of items) {
+ const itemNode = astFromValue(item, itemType);
+ if (itemNode != null) {
+ valuesNodes.push(itemNode);
+ }
+ }
+ return { kind: Kind.LIST, values: valuesNodes };
+ }
+
+ return astFromValue(value, itemType);
+ }
+
+ // Populate the fields of the input object by creating ASTs from each value
+ // in the JavaScript object according to the fields in the input type.
+ if (isInputObjectType(type)) {
+ if (!isObjectLike(value)) {
+ return null;
+ }
+ const fieldNodes = [];
+ for (const field of objectValues(type.getFields())) {
+ const fieldValue = astFromValue(value[field.name], field.type);
+ if (fieldValue) {
+ fieldNodes.push({
+ kind: Kind.OBJECT_FIELD,
+ name: { kind: Kind.NAME, value: field.name },
+ value: fieldValue,
+ });
+ }
+ }
+ return { kind: Kind.OBJECT, fields: fieldNodes };
+ }
+
+ // istanbul ignore else (See: 'https://github.com/graphql/graphql-js/issues/2618')
+ if (isLeafType(type)) {
+ // Since value is an internally represented value, it must be serialized
+ // to an externally represented value before converting into an AST.
+ const serialized = type.serialize(value);
+ if (serialized == null) {
+ return null;
+ }
+
+ // Others serialize based on their corresponding JavaScript scalar types.
+ if (typeof serialized === 'boolean') {
+ return { kind: Kind.BOOLEAN, value: serialized };
+ }
+
+ // JavaScript numbers can be Int or Float values.
+ if (typeof serialized === 'number' && isFinite(serialized)) {
+ const stringNum = String(serialized);
+ return integerStringRegExp.test(stringNum)
+ ? { kind: Kind.INT, value: stringNum }
+ : { kind: Kind.FLOAT, value: stringNum };
+ }
+
+ if (typeof serialized === 'string') {
+ // Enum types use Enum literals.
+ if (isEnumType(type)) {
+ return { kind: Kind.ENUM, value: serialized };
+ }
+
+ // ID types can use Int literals.
+ if (type === GraphQLID && integerStringRegExp.test(serialized)) {
+ return { kind: Kind.INT, value: serialized };
+ }
+
+ return {
+ kind: Kind.STRING,
+ value: serialized,
+ };
+ }
+
+ throw new TypeError(`Cannot convert value to AST: ${inspect(serialized)}.`);
+ }
+
+ // istanbul ignore next (Not reachable. All possible input types have been considered)
+ invariant(false, 'Unexpected input type: ' + inspect((type: empty)));
+}
+
+/**
+ * IntValue:
+ * - NegativeSign? 0
+ * - NegativeSign? NonZeroDigit ( Digit+ )?
+ */
+const integerStringRegExp = /^-?(?:0|[1-9][0-9]*)$/;