@graphitation/supermassive 3.0.0-alpha.1 → 3.0.0-alpha.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (207) hide show
  1. package/.eslintcache +1 -1
  2. package/CHANGELOG.md +18 -2
  3. package/lib/__testUtils__/execute.d.ts +13 -0
  4. package/lib/__testUtils__/execute.d.ts.map +1 -0
  5. package/lib/__testUtils__/execute.js +203 -0
  6. package/lib/__testUtils__/execute.js.map +7 -0
  7. package/lib/__testUtils__/execute.mjs +181 -0
  8. package/lib/__testUtils__/execute.mjs.map +7 -0
  9. package/lib/__testUtils__/gql.d.ts +7 -0
  10. package/lib/__testUtils__/gql.d.ts.map +1 -0
  11. package/lib/{supermassive-ast/TypedAST.js → __testUtils__/gql.js} +8 -10
  12. package/lib/__testUtils__/gql.js.map +7 -0
  13. package/lib/__testUtils__/gql.mjs +8 -0
  14. package/lib/__testUtils__/gql.mjs.map +7 -0
  15. package/lib/benchmarks/index.js +15 -20
  16. package/lib/benchmarks/index.js.map +3 -3
  17. package/lib/benchmarks/index.mjs +16 -23
  18. package/lib/benchmarks/index.mjs.map +2 -2
  19. package/lib/collectFields.d.ts +4 -9
  20. package/lib/collectFields.d.ts.map +1 -1
  21. package/lib/collectFields.js +38 -99
  22. package/lib/collectFields.js.map +2 -2
  23. package/lib/collectFields.mjs +41 -100
  24. package/lib/collectFields.mjs.map +2 -2
  25. package/lib/executeWithSchema.d.ts +1 -1
  26. package/lib/executeWithSchema.d.ts.map +1 -1
  27. package/lib/executeWithSchema.js +27 -17
  28. package/lib/executeWithSchema.js.map +2 -2
  29. package/lib/executeWithSchema.mjs +32 -24
  30. package/lib/executeWithSchema.mjs.map +2 -2
  31. package/lib/executeWithoutSchema.d.ts +9 -5
  32. package/lib/executeWithoutSchema.d.ts.map +1 -1
  33. package/lib/executeWithoutSchema.js +217 -242
  34. package/lib/executeWithoutSchema.js.map +3 -3
  35. package/lib/executeWithoutSchema.mjs +225 -249
  36. package/lib/executeWithoutSchema.mjs.map +3 -3
  37. package/lib/index.d.ts +16 -11
  38. package/lib/index.d.ts.map +1 -1
  39. package/lib/index.js +24 -11
  40. package/lib/index.js.map +2 -2
  41. package/lib/index.mjs +32 -11
  42. package/lib/index.mjs.map +2 -2
  43. package/lib/schema/definition.d.ts +100 -0
  44. package/lib/schema/definition.d.ts.map +1 -0
  45. package/lib/schema/definition.js +77 -0
  46. package/lib/schema/definition.js.map +7 -0
  47. package/lib/schema/definition.mjs +58 -0
  48. package/lib/schema/definition.mjs.map +7 -0
  49. package/lib/schema/directives.d.ts +42 -0
  50. package/lib/schema/directives.d.ts.map +1 -0
  51. package/lib/schema/directives.js +87 -0
  52. package/lib/schema/directives.js.map +7 -0
  53. package/lib/schema/directives.mjs +70 -0
  54. package/lib/schema/directives.mjs.map +7 -0
  55. package/lib/schema/fragment.d.ts +63 -0
  56. package/lib/schema/fragment.d.ts.map +1 -0
  57. package/lib/schema/fragment.js +295 -0
  58. package/lib/schema/fragment.js.map +7 -0
  59. package/lib/schema/fragment.mjs +292 -0
  60. package/lib/schema/fragment.mjs.map +7 -0
  61. package/lib/schema/reference.d.ts +12 -0
  62. package/lib/schema/reference.d.ts.map +1 -0
  63. package/lib/schema/reference.js +137 -0
  64. package/lib/schema/reference.js.map +7 -0
  65. package/lib/schema/reference.mjs +118 -0
  66. package/lib/schema/reference.mjs.map +7 -0
  67. package/lib/schema/resolvers.d.ts +9 -0
  68. package/lib/schema/resolvers.d.ts.map +1 -0
  69. package/lib/schema/resolvers.js +47 -0
  70. package/lib/schema/resolvers.js.map +7 -0
  71. package/lib/schema/resolvers.mjs +35 -0
  72. package/lib/schema/resolvers.mjs.map +7 -0
  73. package/lib/subscribeWithSchema.d.ts +1 -1
  74. package/lib/subscribeWithSchema.d.ts.map +1 -1
  75. package/lib/subscribeWithSchema.js +27 -17
  76. package/lib/subscribeWithSchema.js.map +2 -2
  77. package/lib/subscribeWithSchema.mjs +32 -24
  78. package/lib/subscribeWithSchema.mjs.map +2 -2
  79. package/lib/types.d.ts +16 -27
  80. package/lib/types.d.ts.map +1 -1
  81. package/lib/types.js +0 -14
  82. package/lib/types.js.map +2 -2
  83. package/lib/types.mjs +0 -11
  84. package/lib/types.mjs.map +3 -3
  85. package/lib/utilities/addMinimalViableSchemaToRequestDocument.d.ts +12 -0
  86. package/lib/utilities/addMinimalViableSchemaToRequestDocument.d.ts.map +1 -0
  87. package/lib/utilities/addMinimalViableSchemaToRequestDocument.js +116 -0
  88. package/lib/utilities/addMinimalViableSchemaToRequestDocument.js.map +7 -0
  89. package/lib/utilities/addMinimalViableSchemaToRequestDocument.mjs +105 -0
  90. package/lib/utilities/addMinimalViableSchemaToRequestDocument.mjs.map +7 -0
  91. package/lib/utilities/annotateDocumentGraphQLTransform.d.ts +4 -0
  92. package/lib/utilities/annotateDocumentGraphQLTransform.d.ts.map +1 -0
  93. package/lib/{supermassive-ast → utilities}/annotateDocumentGraphQLTransform.js +3 -10
  94. package/lib/utilities/annotateDocumentGraphQLTransform.js.map +7 -0
  95. package/lib/utilities/annotateDocumentGraphQLTransform.mjs +10 -0
  96. package/lib/utilities/annotateDocumentGraphQLTransform.mjs.map +7 -0
  97. package/lib/utilities/coerceInputValue.d.ts +10 -0
  98. package/lib/utilities/coerceInputValue.d.ts.map +1 -0
  99. package/lib/utilities/coerceInputValue.js +181 -0
  100. package/lib/utilities/coerceInputValue.js.map +7 -0
  101. package/lib/utilities/coerceInputValue.mjs +167 -0
  102. package/lib/utilities/coerceInputValue.mjs.map +7 -0
  103. package/lib/utilities/decodeASTSchema.d.ts +7 -0
  104. package/lib/utilities/decodeASTSchema.d.ts.map +1 -0
  105. package/lib/utilities/decodeASTSchema.js +246 -0
  106. package/lib/utilities/decodeASTSchema.js.map +7 -0
  107. package/lib/utilities/decodeASTSchema.mjs +245 -0
  108. package/lib/utilities/decodeASTSchema.mjs.map +7 -0
  109. package/lib/utilities/encodeASTSchema.d.ts +4 -0
  110. package/lib/utilities/encodeASTSchema.d.ts.map +1 -0
  111. package/lib/utilities/encodeASTSchema.js +151 -0
  112. package/lib/utilities/encodeASTSchema.js.map +7 -0
  113. package/lib/utilities/encodeASTSchema.mjs +134 -0
  114. package/lib/utilities/encodeASTSchema.mjs.map +7 -0
  115. package/lib/utilities/extractMinimalViableSchemaForRequestDocument.d.ts +8 -0
  116. package/lib/utilities/extractMinimalViableSchemaForRequestDocument.d.ts.map +1 -0
  117. package/lib/utilities/extractMinimalViableSchemaForRequestDocument.js +238 -0
  118. package/lib/utilities/extractMinimalViableSchemaForRequestDocument.js.map +7 -0
  119. package/lib/utilities/extractMinimalViableSchemaForRequestDocument.mjs +245 -0
  120. package/lib/utilities/extractMinimalViableSchemaForRequestDocument.mjs.map +7 -0
  121. package/lib/utilities/makeReadableErrorPath.d.ts +3 -0
  122. package/lib/utilities/makeReadableErrorPath.d.ts.map +1 -0
  123. package/lib/utilities/makeReadableErrorPath.js +47 -0
  124. package/lib/utilities/makeReadableErrorPath.js.map +7 -0
  125. package/lib/utilities/makeReadableErrorPath.mjs +28 -0
  126. package/lib/utilities/makeReadableErrorPath.mjs.map +7 -0
  127. package/lib/utilities/mergeResolvers.d.ts +2 -2
  128. package/lib/utilities/mergeResolvers.d.ts.map +1 -1
  129. package/lib/utilities/mergeResolvers.js +20 -22
  130. package/lib/utilities/mergeResolvers.js.map +2 -2
  131. package/lib/utilities/mergeResolvers.mjs +20 -25
  132. package/lib/utilities/mergeResolvers.mjs.map +2 -2
  133. package/lib/utilities/mergeSchemaDefinitions.d.ts +8 -0
  134. package/lib/utilities/mergeSchemaDefinitions.d.ts.map +1 -0
  135. package/lib/utilities/mergeSchemaDefinitions.js +126 -0
  136. package/lib/utilities/mergeSchemaDefinitions.js.map +7 -0
  137. package/lib/utilities/mergeSchemaDefinitions.mjs +114 -0
  138. package/lib/utilities/mergeSchemaDefinitions.mjs.map +7 -0
  139. package/lib/utilities/typeNameFromAST.d.ts +1 -1
  140. package/lib/utilities/typeNameFromAST.d.ts.map +1 -1
  141. package/lib/utilities/typeNameFromAST.js.map +2 -2
  142. package/lib/utilities/typeNameFromAST.mjs.map +2 -2
  143. package/lib/utilities/valueFromAST.d.ts +27 -0
  144. package/lib/utilities/valueFromAST.d.ts.map +1 -0
  145. package/lib/utilities/valueFromAST.js +139 -0
  146. package/lib/utilities/valueFromAST.js.map +7 -0
  147. package/lib/utilities/valueFromAST.mjs +125 -0
  148. package/lib/utilities/valueFromAST.mjs.map +7 -0
  149. package/lib/utilities/valueFromASTUntyped.d.ts +21 -0
  150. package/lib/utilities/valueFromASTUntyped.d.ts.map +1 -0
  151. package/lib/utilities/valueFromASTUntyped.js +51 -0
  152. package/lib/utilities/valueFromASTUntyped.js.map +7 -0
  153. package/lib/utilities/valueFromASTUntyped.mjs +32 -0
  154. package/lib/utilities/valueFromASTUntyped.mjs.map +7 -0
  155. package/lib/values.d.ts +8 -12
  156. package/lib/values.d.ts.map +1 -1
  157. package/lib/values.js +75 -63
  158. package/lib/values.js.map +2 -2
  159. package/lib/values.mjs +77 -71
  160. package/lib/values.mjs.map +2 -2
  161. package/package.json +8 -6
  162. package/lib/definition.d.ts +0 -7
  163. package/lib/definition.d.ts.map +0 -1
  164. package/lib/definition.js +0 -59
  165. package/lib/definition.js.map +0 -7
  166. package/lib/definition.mjs +0 -40
  167. package/lib/definition.mjs.map +0 -7
  168. package/lib/directives.d.ts +0 -8
  169. package/lib/directives.d.ts.map +0 -1
  170. package/lib/directives.js +0 -47
  171. package/lib/directives.js.map +0 -7
  172. package/lib/directives.mjs +0 -37
  173. package/lib/directives.mjs.map +0 -7
  174. package/lib/extractImplicitTypesRuntime.d.ts +0 -4
  175. package/lib/extractImplicitTypesRuntime.d.ts.map +0 -1
  176. package/lib/extractImplicitTypesRuntime.js +0 -123
  177. package/lib/extractImplicitTypesRuntime.js.map +0 -7
  178. package/lib/extractImplicitTypesRuntime.mjs +0 -114
  179. package/lib/extractImplicitTypesRuntime.mjs.map +0 -7
  180. package/lib/supermassive-ast/TypedAST.d.ts +0 -370
  181. package/lib/supermassive-ast/TypedAST.d.ts.map +0 -1
  182. package/lib/supermassive-ast/TypedAST.js.map +0 -7
  183. package/lib/supermassive-ast/TypedAST.mjs +0 -10
  184. package/lib/supermassive-ast/TypedAST.mjs.map +0 -7
  185. package/lib/supermassive-ast/addTypesToRequestDocument.d.ts +0 -56
  186. package/lib/supermassive-ast/addTypesToRequestDocument.d.ts.map +0 -1
  187. package/lib/supermassive-ast/addTypesToRequestDocument.js +0 -473
  188. package/lib/supermassive-ast/addTypesToRequestDocument.js.map +0 -7
  189. package/lib/supermassive-ast/addTypesToRequestDocument.mjs +0 -463
  190. package/lib/supermassive-ast/addTypesToRequestDocument.mjs.map +0 -7
  191. package/lib/supermassive-ast/annotateDocumentGraphQLTransform.d.ts +0 -3
  192. package/lib/supermassive-ast/annotateDocumentGraphQLTransform.d.ts.map +0 -1
  193. package/lib/supermassive-ast/annotateDocumentGraphQLTransform.js.map +0 -7
  194. package/lib/supermassive-ast/annotateDocumentGraphQLTransform.mjs +0 -17
  195. package/lib/supermassive-ast/annotateDocumentGraphQLTransform.mjs.map +0 -7
  196. package/lib/supermassive-ast/directives.d.ts +0 -36
  197. package/lib/supermassive-ast/directives.d.ts.map +0 -1
  198. package/lib/supermassive-ast/directives.js +0 -165
  199. package/lib/supermassive-ast/directives.js.map +0 -7
  200. package/lib/supermassive-ast/directives.mjs +0 -153
  201. package/lib/supermassive-ast/directives.mjs.map +0 -7
  202. package/lib/supermassive-ast/index.d.ts +0 -6
  203. package/lib/supermassive-ast/index.d.ts.map +0 -1
  204. package/lib/supermassive-ast/index.js +0 -37
  205. package/lib/supermassive-ast/index.js.map +0 -7
  206. package/lib/supermassive-ast/index.mjs +0 -27
  207. package/lib/supermassive-ast/index.mjs.map +0 -7
@@ -0,0 +1,245 @@
1
+ // src/utilities/decodeASTSchema.ts
2
+ import {
3
+ Kind
4
+ } from "graphql";
5
+ import {
6
+ DirectiveKeys,
7
+ EnumKeys,
8
+ FieldKeys,
9
+ InputObjectKeys,
10
+ InputValueKeys,
11
+ InterfaceKeys,
12
+ ObjectKeys,
13
+ TypeKind,
14
+ UnionKeys
15
+ } from "../schema/definition.mjs";
16
+ import {
17
+ inspectTypeReference,
18
+ isListType,
19
+ isNonNullType,
20
+ typeNameFromReference,
21
+ unwrap
22
+ } from "../schema/reference.mjs";
23
+ import { invariant } from "../jsutils/invariant.mjs";
24
+ import { inspect } from "../jsutils/inspect.mjs";
25
+ function decodeASTSchema(encodedSchemaFragments) {
26
+ if (encodedSchemaFragments.length !== 1) {
27
+ throw new Error("decodeSchema does not support decoding extensions yet");
28
+ }
29
+ const definitions = [];
30
+ const types = encodedSchemaFragments[0].types;
31
+ const directives = encodedSchemaFragments[0].directives;
32
+ for (const typeName in types) {
33
+ const tuple = types[typeName];
34
+ switch (tuple[0]) {
35
+ case TypeKind.SCALAR:
36
+ definitions.push(decodeScalarType(typeName));
37
+ break;
38
+ case TypeKind.ENUM:
39
+ definitions.push(decodeEnumType(typeName, tuple));
40
+ break;
41
+ case TypeKind.OBJECT:
42
+ definitions.push(decodeObjectType(typeName, tuple, types));
43
+ break;
44
+ case TypeKind.INTERFACE:
45
+ definitions.push(decodeInterfaceType(typeName, tuple, types));
46
+ break;
47
+ case TypeKind.UNION:
48
+ definitions.push(decodeUnionType(typeName, tuple));
49
+ break;
50
+ case TypeKind.INPUT:
51
+ definitions.push(decodeInputObjectType(typeName, tuple, types));
52
+ break;
53
+ }
54
+ }
55
+ for (const directive of directives != null ? directives : []) {
56
+ definitions.push(decodeDirective(directive, types));
57
+ }
58
+ return { kind: Kind.DOCUMENT, definitions };
59
+ }
60
+ function nameNode(value) {
61
+ return { kind: Kind.NAME, value };
62
+ }
63
+ function decodeScalarType(typeName) {
64
+ return {
65
+ kind: Kind.SCALAR_TYPE_DEFINITION,
66
+ name: nameNode(typeName)
67
+ };
68
+ }
69
+ function decodeEnumType(typeName, tuple) {
70
+ return {
71
+ kind: Kind.ENUM_TYPE_DEFINITION,
72
+ name: nameNode(typeName),
73
+ values: tuple[EnumKeys.values].map((value) => ({
74
+ kind: Kind.ENUM_VALUE_DEFINITION,
75
+ name: nameNode(value)
76
+ }))
77
+ };
78
+ }
79
+ function decodeObjectType(typeName, tuple, types) {
80
+ return {
81
+ kind: Kind.OBJECT_TYPE_DEFINITION,
82
+ name: nameNode(typeName),
83
+ fields: decodeFields(tuple[ObjectKeys.fields], types),
84
+ interfaces: (tuple[ObjectKeys.interfaces] || []).map((name) => ({
85
+ kind: Kind.NAMED_TYPE,
86
+ name: nameNode(name)
87
+ }))
88
+ };
89
+ }
90
+ function decodeInterfaceType(typeName, tuple, types) {
91
+ return {
92
+ kind: Kind.INTERFACE_TYPE_DEFINITION,
93
+ name: nameNode(typeName),
94
+ fields: decodeFields(tuple[InterfaceKeys.fields], types),
95
+ interfaces: (tuple[InterfaceKeys.interfaces] || []).map((name) => ({
96
+ kind: Kind.NAMED_TYPE,
97
+ name: nameNode(name)
98
+ }))
99
+ };
100
+ }
101
+ function decodeUnionType(typeName, tuple) {
102
+ return {
103
+ kind: Kind.UNION_TYPE_DEFINITION,
104
+ name: nameNode(typeName),
105
+ types: tuple[UnionKeys.types].map((name) => ({
106
+ kind: Kind.NAMED_TYPE,
107
+ name: nameNode(name)
108
+ }))
109
+ };
110
+ }
111
+ function decodeInputObjectType(typeName, tuple, types) {
112
+ return {
113
+ kind: Kind.INPUT_OBJECT_TYPE_DEFINITION,
114
+ name: nameNode(typeName),
115
+ fields: Object.entries(tuple[InputObjectKeys.fields]).map(
116
+ ([name, value]) => decodeInputValue(name, value, types)
117
+ )
118
+ };
119
+ }
120
+ function decodeFields(fields, types) {
121
+ return Object.entries(fields).map(([name, value]) => {
122
+ var _a;
123
+ const type = Array.isArray(value) ? decodeTypeReference(value[FieldKeys.type]) : decodeTypeReference(value);
124
+ return {
125
+ kind: Kind.FIELD_DEFINITION,
126
+ name: nameNode(name),
127
+ type,
128
+ arguments: decodeArguments(
129
+ Array.isArray(value) ? (_a = value[FieldKeys.arguments]) != null ? _a : {} : {},
130
+ types
131
+ )
132
+ };
133
+ });
134
+ }
135
+ function decodeInputValue(name, value, types) {
136
+ const type = Array.isArray(value) ? decodeTypeReference(value[InputValueKeys.type]) : decodeTypeReference(value);
137
+ return {
138
+ kind: Kind.INPUT_VALUE_DEFINITION,
139
+ name: nameNode(name),
140
+ type,
141
+ defaultValue: Array.isArray(value) ? valueToConstValueNode(
142
+ value[InputValueKeys.defaultValue],
143
+ value[InputValueKeys.type],
144
+ types
145
+ ) : void 0
146
+ };
147
+ }
148
+ function valueToConstValueNode(jsValue, typeRef, types) {
149
+ const typeName = typeNameFromReference(typeRef);
150
+ if (typeof jsValue === "string") {
151
+ return typeName === "String" ? { kind: Kind.STRING, value: jsValue } : { kind: Kind.ENUM, value: jsValue };
152
+ }
153
+ if (jsValue === null) {
154
+ invariant(!isNonNullType(typeRef), "Expecting nullable type");
155
+ return { kind: Kind.NULL };
156
+ }
157
+ if (Number.isInteger(jsValue)) {
158
+ return { kind: Kind.INT, value: String(jsValue) };
159
+ }
160
+ if (typeof jsValue === "number") {
161
+ return { kind: Kind.FLOAT, value: String(jsValue) };
162
+ }
163
+ if (Array.isArray(jsValue)) {
164
+ invariant(isListType(typeRef), "Expecting list type");
165
+ return {
166
+ kind: Kind.LIST,
167
+ values: jsValue.map(
168
+ (item) => valueToConstValueNode(item, unwrap(typeRef), types)
169
+ )
170
+ };
171
+ }
172
+ if (typeof jsValue === "object") {
173
+ const typeDef = types[typeName];
174
+ invariant(
175
+ Array.isArray(typeDef) && typeDef[0] === TypeKind.INPUT,
176
+ `Expecting input object type for ${typeName}, got ${typeDef == null ? void 0 : typeDef[0]}`
177
+ );
178
+ const fields = typeDef[InputObjectKeys.fields];
179
+ return {
180
+ kind: Kind.OBJECT,
181
+ fields: Object.entries(jsValue).map(([name, value]) => {
182
+ const fieldDef = fields[name];
183
+ const fieldTypeRef = Array.isArray(fieldDef) ? fieldDef[FieldKeys.type] : fieldDef;
184
+ invariant(
185
+ fieldTypeRef !== void 0,
186
+ `Could not find field definition for ${typeName}.${name}`
187
+ );
188
+ return {
189
+ kind: Kind.OBJECT_FIELD,
190
+ name: nameNode(name),
191
+ value: valueToConstValueNode(value, fieldTypeRef, types)
192
+ };
193
+ })
194
+ };
195
+ }
196
+ invariant(
197
+ false,
198
+ `Unexpected value for type ${inspectTypeReference(typeRef)}: ${inspect(
199
+ jsValue
200
+ )}`
201
+ );
202
+ }
203
+ function decodeArguments(args, types) {
204
+ return Object.entries(args).map(
205
+ ([name, value]) => decodeInputValue(name, value, types)
206
+ );
207
+ }
208
+ function decodeTypeReference(ref) {
209
+ if (isListType(ref)) {
210
+ return {
211
+ kind: Kind.LIST_TYPE,
212
+ type: decodeTypeReference(unwrap(ref))
213
+ };
214
+ }
215
+ if (isNonNullType(ref)) {
216
+ const unwrappedType = decodeTypeReference(unwrap(ref));
217
+ invariant(
218
+ unwrappedType.kind !== Kind.NON_NULL_TYPE,
219
+ "Non-null modifier cannot be nested"
220
+ );
221
+ return {
222
+ kind: Kind.NON_NULL_TYPE,
223
+ type: unwrappedType
224
+ };
225
+ }
226
+ return {
227
+ kind: Kind.NAMED_TYPE,
228
+ name: nameNode(typeNameFromReference(ref))
229
+ };
230
+ }
231
+ function decodeDirective(tuple, types) {
232
+ const name = tuple[DirectiveKeys.name];
233
+ const args = tuple[DirectiveKeys.arguments] ? decodeArguments(tuple[DirectiveKeys.arguments], types) : [];
234
+ return {
235
+ kind: Kind.DIRECTIVE_DEFINITION,
236
+ name: nameNode(name),
237
+ arguments: args,
238
+ // TODO? locations and repeatable are irrelevant for execution
239
+ repeatable: false,
240
+ locations: []
241
+ };
242
+ }
243
+ export {
244
+ decodeASTSchema
245
+ };
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../src/utilities/decodeASTSchema.ts"],
4
+ "sourcesContent": ["import {\n DirectiveDefinitionNode,\n DocumentNode,\n EnumTypeDefinitionNode,\n FieldDefinitionNode,\n InputObjectTypeDefinitionNode,\n InputValueDefinitionNode,\n InterfaceTypeDefinitionNode,\n Kind,\n ListTypeNode,\n NamedTypeNode,\n NameNode,\n NonNullTypeNode,\n ObjectTypeDefinitionNode,\n ScalarTypeDefinitionNode,\n UnionTypeDefinitionNode,\n} from \"graphql\";\nimport {\n DirectiveDefinitionTuple,\n DirectiveKeys,\n SchemaDefinitions,\n EnumKeys,\n EnumTypeDefinitionTuple,\n FieldDefinition,\n FieldKeys,\n InputObjectKeys,\n InputObjectTypeDefinitionTuple,\n InputValueDefinition,\n InputValueKeys,\n InterfaceKeys,\n InterfaceTypeDefinitionTuple,\n ObjectKeys,\n ObjectTypeDefinitionTuple,\n TypeDefinitionsRecord,\n TypeKind,\n TypeReference,\n UnionKeys,\n UnionTypeDefinitionTuple,\n} from \"../schema/definition\";\nimport {\n inspectTypeReference,\n isListType,\n isNonNullType,\n typeNameFromReference,\n unwrap,\n} from \"../schema/reference\";\nimport { invariant } from \"../jsutils/invariant\";\nimport { ConstValueNode } from \"graphql/language/ast\";\nimport { inspect } from \"../jsutils/inspect\";\n\n/**\n * Converts encoded schema to standard AST representation of the same schema\n */\nexport function decodeASTSchema(\n encodedSchemaFragments: SchemaDefinitions[],\n): DocumentNode {\n if (encodedSchemaFragments.length !== 1) {\n // TODO:\n throw new Error(\"decodeSchema does not support decoding extensions yet\");\n }\n const definitions = [];\n const types = encodedSchemaFragments[0].types;\n const directives = encodedSchemaFragments[0].directives;\n\n for (const typeName in types) {\n const tuple = types[typeName];\n switch (tuple[0]) {\n case TypeKind.SCALAR:\n definitions.push(decodeScalarType(typeName));\n break;\n case TypeKind.ENUM:\n definitions.push(decodeEnumType(typeName, tuple));\n break;\n case TypeKind.OBJECT:\n definitions.push(decodeObjectType(typeName, tuple, types));\n break;\n case TypeKind.INTERFACE:\n definitions.push(decodeInterfaceType(typeName, tuple, types));\n break;\n case TypeKind.UNION:\n definitions.push(decodeUnionType(typeName, tuple));\n break;\n case TypeKind.INPUT:\n definitions.push(decodeInputObjectType(typeName, tuple, types));\n break;\n }\n }\n\n for (const directive of directives ?? []) {\n definitions.push(decodeDirective(directive, types));\n }\n\n return { kind: Kind.DOCUMENT, definitions };\n}\n\nfunction nameNode(value: string): NameNode {\n return { kind: Kind.NAME, value };\n}\n\nfunction decodeScalarType(typeName: string): ScalarTypeDefinitionNode {\n return {\n kind: Kind.SCALAR_TYPE_DEFINITION,\n name: nameNode(typeName),\n };\n}\n\nfunction decodeEnumType(\n typeName: string,\n tuple: EnumTypeDefinitionTuple,\n): EnumTypeDefinitionNode {\n return {\n kind: Kind.ENUM_TYPE_DEFINITION,\n name: nameNode(typeName),\n values: tuple[EnumKeys.values].map((value) => ({\n kind: Kind.ENUM_VALUE_DEFINITION,\n name: nameNode(value),\n })),\n };\n}\n\nfunction decodeObjectType(\n typeName: string,\n tuple: ObjectTypeDefinitionTuple,\n types: TypeDefinitionsRecord,\n): ObjectTypeDefinitionNode {\n return {\n kind: Kind.OBJECT_TYPE_DEFINITION,\n name: nameNode(typeName),\n fields: decodeFields(tuple[ObjectKeys.fields], types),\n interfaces: (tuple[ObjectKeys.interfaces] || []).map((name) => ({\n kind: Kind.NAMED_TYPE,\n name: nameNode(name),\n })),\n };\n}\n\nfunction decodeInterfaceType(\n typeName: string,\n tuple: InterfaceTypeDefinitionTuple,\n types: TypeDefinitionsRecord,\n): InterfaceTypeDefinitionNode {\n return {\n kind: Kind.INTERFACE_TYPE_DEFINITION,\n name: nameNode(typeName),\n fields: decodeFields(tuple[InterfaceKeys.fields], types),\n interfaces: (tuple[InterfaceKeys.interfaces] || []).map((name) => ({\n kind: Kind.NAMED_TYPE,\n name: nameNode(name),\n })),\n };\n}\n\nfunction decodeUnionType(\n typeName: string,\n tuple: UnionTypeDefinitionTuple,\n): UnionTypeDefinitionNode {\n return {\n kind: Kind.UNION_TYPE_DEFINITION,\n name: nameNode(typeName),\n types: tuple[UnionKeys.types].map((name) => ({\n kind: Kind.NAMED_TYPE,\n name: nameNode(name),\n })),\n };\n}\n\nfunction decodeInputObjectType(\n typeName: string,\n tuple: InputObjectTypeDefinitionTuple,\n types: TypeDefinitionsRecord,\n): InputObjectTypeDefinitionNode {\n return {\n kind: Kind.INPUT_OBJECT_TYPE_DEFINITION,\n name: nameNode(typeName),\n fields: Object.entries(tuple[InputObjectKeys.fields]).map(([name, value]) =>\n decodeInputValue(name, value, types),\n ),\n };\n}\n\nfunction decodeFields(\n fields: Record<string, FieldDefinition>,\n types: TypeDefinitionsRecord,\n): FieldDefinitionNode[] {\n return Object.entries(fields).map(([name, value]) => {\n const type = Array.isArray(value)\n ? decodeTypeReference(value[FieldKeys.type])\n : decodeTypeReference(value);\n return {\n kind: Kind.FIELD_DEFINITION,\n name: nameNode(name),\n type,\n arguments: decodeArguments(\n Array.isArray(value) ? value[FieldKeys.arguments] ?? {} : {},\n types,\n ),\n };\n });\n}\n\nfunction decodeInputValue(\n name: string,\n value: InputValueDefinition,\n types: TypeDefinitionsRecord,\n): InputValueDefinitionNode {\n const type = Array.isArray(value)\n ? decodeTypeReference(value[InputValueKeys.type])\n : decodeTypeReference(value);\n\n return {\n kind: Kind.INPUT_VALUE_DEFINITION,\n name: nameNode(name),\n type,\n defaultValue: Array.isArray(value)\n ? valueToConstValueNode(\n value[InputValueKeys.defaultValue],\n value[InputValueKeys.type],\n types,\n )\n : undefined,\n };\n}\n\nfunction valueToConstValueNode(\n jsValue: unknown,\n typeRef: TypeReference,\n types: TypeDefinitionsRecord,\n): ConstValueNode {\n const typeName = typeNameFromReference(typeRef);\n if (typeof jsValue === \"string\") {\n return typeName === \"String\"\n ? { kind: Kind.STRING, value: jsValue }\n : { kind: Kind.ENUM, value: jsValue };\n }\n if (jsValue === null) {\n invariant(!isNonNullType(typeRef), \"Expecting nullable type\");\n return { kind: Kind.NULL };\n }\n if (Number.isInteger(jsValue)) {\n return { kind: Kind.INT, value: String(jsValue) };\n }\n if (typeof jsValue === \"number\") {\n return { kind: Kind.FLOAT, value: String(jsValue) };\n }\n if (Array.isArray(jsValue)) {\n invariant(isListType(typeRef), \"Expecting list type\");\n return {\n kind: Kind.LIST,\n values: jsValue.map((item) =>\n valueToConstValueNode(item, unwrap(typeRef), types),\n ),\n };\n }\n if (typeof jsValue === \"object\") {\n const typeDef = types[typeName];\n invariant(\n Array.isArray(typeDef) && typeDef[0] === TypeKind.INPUT,\n `Expecting input object type for ${typeName}, got ${typeDef?.[0]}`,\n );\n const fields = typeDef[InputObjectKeys.fields];\n return {\n kind: Kind.OBJECT,\n fields: Object.entries(jsValue).map(([name, value]) => {\n const fieldDef = fields[name];\n const fieldTypeRef = Array.isArray(fieldDef)\n ? fieldDef[FieldKeys.type]\n : fieldDef;\n invariant(\n fieldTypeRef !== undefined,\n `Could not find field definition for ${typeName}.${name}`,\n );\n return {\n kind: Kind.OBJECT_FIELD,\n name: nameNode(name),\n value: valueToConstValueNode(value, fieldTypeRef, types),\n };\n }),\n };\n }\n invariant(\n false,\n `Unexpected value for type ${inspectTypeReference(typeRef)}: ${inspect(\n jsValue,\n )}`,\n );\n}\n\nfunction decodeArguments(\n args: Record<string, InputValueDefinition>,\n types: TypeDefinitionsRecord,\n): InputValueDefinitionNode[] {\n return Object.entries(args).map(([name, value]) =>\n decodeInputValue(name, value, types),\n );\n}\n\nfunction decodeTypeReference(\n ref: TypeReference,\n): NamedTypeNode | ListTypeNode | NonNullTypeNode {\n if (isListType(ref)) {\n return {\n kind: Kind.LIST_TYPE,\n type: decodeTypeReference(unwrap(ref)),\n };\n }\n if (isNonNullType(ref)) {\n const unwrappedType = decodeTypeReference(unwrap(ref));\n invariant(\n unwrappedType.kind !== Kind.NON_NULL_TYPE,\n \"Non-null modifier cannot be nested\",\n );\n return {\n kind: Kind.NON_NULL_TYPE,\n type: unwrappedType,\n };\n }\n return {\n kind: Kind.NAMED_TYPE,\n name: nameNode(typeNameFromReference(ref)),\n };\n}\n\nfunction decodeDirective(\n tuple: DirectiveDefinitionTuple,\n types: TypeDefinitionsRecord,\n): DirectiveDefinitionNode {\n const name = tuple[DirectiveKeys.name];\n const args = tuple[DirectiveKeys.arguments]\n ? decodeArguments(tuple[DirectiveKeys.arguments], types)\n : [];\n return {\n kind: Kind.DIRECTIVE_DEFINITION,\n name: nameNode(name),\n arguments: args,\n // TODO? locations and repeatable are irrelevant for execution\n repeatable: false,\n locations: [],\n };\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,4 @@
1
+ import { DocumentNode } from "graphql";
2
+ import { SchemaDefinitions } from "../schema/definition";
3
+ export declare function encodeASTSchema(schemaFragment: DocumentNode): SchemaDefinitions[];
4
+ //# sourceMappingURL=encodeASTSchema.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"encodeASTSchema.d.ts","sourceRoot":"","sources":["../../src/utilities/encodeASTSchema.ts"],"names":[],"mappings":"AAAA,OAAO,EAUL,YAAY,EAOb,MAAM,SAAS,CAAC;AACjB,OAAO,EAWL,iBAAiB,EAIlB,MAAM,sBAAsB,CAAC;AAI9B,wBAAgB,eAAe,CAC7B,cAAc,EAAE,YAAY,GAC3B,iBAAiB,EAAE,CAsCrB"}
@@ -0,0 +1,151 @@
1
+ "use strict";
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
6
+ var __export = (target, all) => {
7
+ for (var name in all)
8
+ __defProp(target, name, { get: all[name], enumerable: true });
9
+ };
10
+ var __copyProps = (to, from, except, desc) => {
11
+ if (from && typeof from === "object" || typeof from === "function") {
12
+ for (let key of __getOwnPropNames(from))
13
+ if (!__hasOwnProp.call(to, key) && key !== except)
14
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
+ }
16
+ return to;
17
+ };
18
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
+ var encodeASTSchema_exports = {};
20
+ __export(encodeASTSchema_exports, {
21
+ encodeASTSchema: () => encodeASTSchema
22
+ });
23
+ module.exports = __toCommonJS(encodeASTSchema_exports);
24
+ var import_definition = require("../schema/definition");
25
+ var import_reference = require("../schema/reference");
26
+ var import_valueFromASTUntyped = require("./valueFromASTUntyped");
27
+ function encodeASTSchema(schemaFragment) {
28
+ const fragments = [{ types: {} }];
29
+ const add = (name, def, extension = false) => addTypeDefinition(fragments, name, def, extension);
30
+ for (const definition of schemaFragment.definitions) {
31
+ if (definition.kind === "ObjectTypeDefinition") {
32
+ add(definition.name.value, encodeObjectType(definition));
33
+ } else if (definition.kind === "InputObjectTypeDefinition") {
34
+ add(definition.name.value, encodeInputObjectType(definition));
35
+ } else if (definition.kind === "EnumTypeDefinition") {
36
+ add(definition.name.value, encodeEnumType(definition));
37
+ } else if (definition.kind === "UnionTypeDefinition") {
38
+ add(definition.name.value, encodeUnionType(definition));
39
+ } else if (definition.kind === "InterfaceTypeDefinition") {
40
+ add(definition.name.value, encodeInterfaceType(definition));
41
+ } else if (definition.kind === "ScalarTypeDefinition") {
42
+ add(definition.name.value, encodeScalarType(definition));
43
+ } else if (definition.kind === "ObjectTypeExtension") {
44
+ add(definition.name.value, encodeObjectType(definition), true);
45
+ } else if (definition.kind === "InputObjectTypeExtension") {
46
+ add(definition.name.value, encodeInputObjectType(definition), true);
47
+ } else if (definition.kind === "EnumTypeExtension") {
48
+ add(definition.name.value, encodeEnumType(definition), true);
49
+ } else if (definition.kind === "UnionTypeExtension") {
50
+ add(definition.name.value, encodeUnionType(definition), true);
51
+ } else if (definition.kind === "InterfaceTypeExtension") {
52
+ add(definition.name.value, encodeInterfaceType(definition), true);
53
+ } else if (definition.kind === "ScalarTypeExtension") {
54
+ add(definition.name.value, encodeScalarType(definition), true);
55
+ } else if (definition.kind === "DirectiveDefinition") {
56
+ if (!fragments[0].directives) {
57
+ fragments[0].directives = [];
58
+ }
59
+ fragments[0].directives.push(encodeDirective(definition));
60
+ }
61
+ }
62
+ return fragments;
63
+ }
64
+ function addTypeDefinition(fragments, typeName, typeDef, isExtension = false) {
65
+ for (let i = 0; i < fragments.length; i++) {
66
+ if (i === 0 && isExtension) {
67
+ continue;
68
+ }
69
+ const fragment = fragments[i];
70
+ if (!fragment.types[typeName]) {
71
+ fragment.types[typeName] = typeDef;
72
+ return;
73
+ }
74
+ }
75
+ const newFragment = { types: { [typeName]: typeDef } };
76
+ fragments.push(newFragment);
77
+ }
78
+ function encodeScalarType(_type) {
79
+ return [import_definition.TypeKind.SCALAR];
80
+ }
81
+ function encodeEnumType(node) {
82
+ var _a;
83
+ return [import_definition.TypeKind.ENUM, ((_a = node.values) != null ? _a : []).map((value) => value.name.value)];
84
+ }
85
+ function encodeObjectType(node) {
86
+ var _a;
87
+ const fields = /* @__PURE__ */ Object.create(null);
88
+ for (const field of (_a = node.fields) != null ? _a : []) {
89
+ fields[field.name.value] = encodeField(field);
90
+ }
91
+ if (!node.interfaces) {
92
+ return [import_definition.TypeKind.OBJECT, fields];
93
+ }
94
+ return [
95
+ import_definition.TypeKind.OBJECT,
96
+ fields,
97
+ node.interfaces.map((iface) => iface.name.value)
98
+ ];
99
+ }
100
+ function encodeInterfaceType(node) {
101
+ var _a;
102
+ const fields = /* @__PURE__ */ Object.create(null);
103
+ for (const field of (_a = node.fields) != null ? _a : []) {
104
+ fields[field.name.value] = encodeField(field);
105
+ }
106
+ if (!node.interfaces) {
107
+ return [import_definition.TypeKind.INTERFACE, fields];
108
+ }
109
+ return [
110
+ import_definition.TypeKind.INTERFACE,
111
+ fields,
112
+ node.interfaces.map((iface) => iface.name.value)
113
+ ];
114
+ }
115
+ function encodeUnionType(node) {
116
+ var _a;
117
+ return [import_definition.TypeKind.UNION, ((_a = node.types) != null ? _a : []).map((type) => type.name.value)];
118
+ }
119
+ function encodeInputObjectType(node) {
120
+ var _a;
121
+ const fields = /* @__PURE__ */ Object.create(null);
122
+ for (const field of (_a = node.fields) != null ? _a : []) {
123
+ fields[field.name.value] = encodeInputValue(field);
124
+ }
125
+ return [import_definition.TypeKind.INPUT, fields];
126
+ }
127
+ function encodeField(node) {
128
+ var _a;
129
+ return !((_a = node.arguments) == null ? void 0 : _a.length) ? (0, import_reference.typeReferenceFromNode)(node.type) : [(0, import_reference.typeReferenceFromNode)(node.type), encodeArguments(node)];
130
+ }
131
+ function encodeArguments(node) {
132
+ var _a;
133
+ const args = /* @__PURE__ */ Object.create(null);
134
+ for (const argument of (_a = node.arguments) != null ? _a : []) {
135
+ args[argument.name.value] = encodeInputValue(argument);
136
+ }
137
+ return args;
138
+ }
139
+ function encodeInputValue(node) {
140
+ if (!node.defaultValue) {
141
+ return (0, import_reference.typeReferenceFromNode)(node.type);
142
+ }
143
+ return [
144
+ (0, import_reference.typeReferenceFromNode)(node.type),
145
+ (0, import_valueFromASTUntyped.valueFromASTUntyped)(node.defaultValue)
146
+ ];
147
+ }
148
+ function encodeDirective(node) {
149
+ var _a;
150
+ return !((_a = node.arguments) == null ? void 0 : _a.length) ? [node.name.value] : [node.name.value, encodeArguments(node)];
151
+ }
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../src/utilities/encodeASTSchema.ts"],
4
+ "sourcesContent": ["import {\n DirectiveDefinitionNode,\n EnumTypeDefinitionNode,\n FieldDefinitionNode,\n InputObjectTypeDefinitionNode,\n InputValueDefinitionNode,\n InterfaceTypeDefinitionNode,\n ObjectTypeDefinitionNode,\n ScalarTypeDefinitionNode,\n UnionTypeDefinitionNode,\n DocumentNode,\n ObjectTypeExtensionNode,\n InputObjectTypeExtensionNode,\n InterfaceTypeExtensionNode,\n UnionTypeExtensionNode,\n EnumTypeExtensionNode,\n ScalarTypeExtensionNode,\n} from \"graphql\";\nimport {\n DirectiveDefinitionTuple,\n EnumTypeDefinitionTuple,\n FieldDefinitionTuple,\n InputObjectTypeDefinitionTuple,\n InputValueDefinitionRecord,\n InputValueDefinitionTuple,\n InterfaceTypeDefinitionTuple,\n ObjectTypeDefinitionTuple,\n ScalarTypeDefinitionTuple,\n UnionTypeDefinitionTuple,\n SchemaDefinitions,\n TypeKind,\n TypeReference,\n TypeDefinitionTuple,\n} from \"../schema/definition\";\nimport { typeReferenceFromNode } from \"../schema/reference\";\nimport { valueFromASTUntyped } from \"./valueFromASTUntyped\";\n\nexport function encodeASTSchema(\n schemaFragment: DocumentNode,\n): SchemaDefinitions[] {\n const fragments: SchemaDefinitions[] = [{ types: {} }];\n const add = (name: string, def: TypeDefinitionTuple, extension = false) =>\n addTypeDefinition(fragments, name, def, extension);\n\n for (const definition of schemaFragment.definitions) {\n if (definition.kind === \"ObjectTypeDefinition\") {\n add(definition.name.value, encodeObjectType(definition));\n } else if (definition.kind === \"InputObjectTypeDefinition\") {\n add(definition.name.value, encodeInputObjectType(definition));\n } else if (definition.kind === \"EnumTypeDefinition\") {\n add(definition.name.value, encodeEnumType(definition));\n } else if (definition.kind === \"UnionTypeDefinition\") {\n add(definition.name.value, encodeUnionType(definition));\n } else if (definition.kind === \"InterfaceTypeDefinition\") {\n add(definition.name.value, encodeInterfaceType(definition));\n } else if (definition.kind === \"ScalarTypeDefinition\") {\n add(definition.name.value, encodeScalarType(definition));\n } else if (definition.kind === \"ObjectTypeExtension\") {\n add(definition.name.value, encodeObjectType(definition), true);\n } else if (definition.kind === \"InputObjectTypeExtension\") {\n add(definition.name.value, encodeInputObjectType(definition), true);\n } else if (definition.kind === \"EnumTypeExtension\") {\n add(definition.name.value, encodeEnumType(definition), true);\n } else if (definition.kind === \"UnionTypeExtension\") {\n add(definition.name.value, encodeUnionType(definition), true);\n } else if (definition.kind === \"InterfaceTypeExtension\") {\n add(definition.name.value, encodeInterfaceType(definition), true);\n } else if (definition.kind === \"ScalarTypeExtension\") {\n add(definition.name.value, encodeScalarType(definition), true);\n } else if (definition.kind === \"DirectiveDefinition\") {\n if (!fragments[0].directives) {\n fragments[0].directives = [];\n }\n fragments[0].directives.push(encodeDirective(definition));\n }\n }\n return fragments;\n}\n\nfunction addTypeDefinition(\n fragments: SchemaDefinitions[],\n typeName: string,\n typeDef: TypeDefinitionTuple,\n isExtension = false,\n) {\n for (let i = 0; i < fragments.length; i++) {\n if (i === 0 && isExtension) {\n // Don't write extensions to the very first fragment (it is reserved for type definitions)\n // Note: 2nd+ type definition with the same name is treated as extension\n continue;\n }\n const fragment = fragments[i];\n if (!fragment.types[typeName]) {\n fragment.types[typeName] = typeDef;\n return;\n }\n }\n const newFragment = { types: { [typeName]: typeDef } };\n fragments.push(newFragment);\n}\n\nfunction encodeScalarType(\n _type: ScalarTypeDefinitionNode | ScalarTypeExtensionNode,\n): ScalarTypeDefinitionTuple {\n return [TypeKind.SCALAR];\n}\n\nfunction encodeEnumType(\n node: EnumTypeDefinitionNode | EnumTypeExtensionNode,\n): EnumTypeDefinitionTuple {\n return [TypeKind.ENUM, (node.values ?? []).map((value) => value.name.value)];\n}\n\nfunction encodeObjectType(\n node: ObjectTypeDefinitionNode | ObjectTypeExtensionNode,\n): ObjectTypeDefinitionTuple {\n const fields = Object.create(null);\n for (const field of node.fields ?? []) {\n fields[field.name.value] = encodeField(field);\n }\n if (!node.interfaces) {\n return [TypeKind.OBJECT, fields];\n }\n return [\n TypeKind.OBJECT,\n fields,\n node.interfaces.map((iface) => iface.name.value),\n ];\n}\n\nfunction encodeInterfaceType(\n node: InterfaceTypeDefinitionNode | InterfaceTypeExtensionNode,\n): InterfaceTypeDefinitionTuple {\n const fields = Object.create(null);\n for (const field of node.fields ?? []) {\n fields[field.name.value] = encodeField(field);\n }\n if (!node.interfaces) {\n return [TypeKind.INTERFACE, fields];\n }\n return [\n TypeKind.INTERFACE,\n fields,\n node.interfaces.map((iface) => iface.name.value),\n ];\n}\n\nfunction encodeUnionType(\n node: UnionTypeDefinitionNode | UnionTypeExtensionNode,\n): UnionTypeDefinitionTuple {\n return [TypeKind.UNION, (node.types ?? []).map((type) => type.name.value)];\n}\n\nfunction encodeInputObjectType(\n node: InputObjectTypeDefinitionNode | InputObjectTypeExtensionNode,\n): InputObjectTypeDefinitionTuple {\n const fields = Object.create(null);\n for (const field of node.fields ?? []) {\n fields[field.name.value] = encodeInputValue(field);\n }\n return [TypeKind.INPUT, fields];\n}\n\nfunction encodeField(\n node: FieldDefinitionNode,\n): TypeReference | FieldDefinitionTuple {\n return !node.arguments?.length\n ? typeReferenceFromNode(node.type)\n : [typeReferenceFromNode(node.type), encodeArguments(node)];\n}\n\nfunction encodeArguments(\n node: FieldDefinitionNode | DirectiveDefinitionNode,\n): InputValueDefinitionRecord {\n const args = Object.create(null);\n for (const argument of node.arguments ?? []) {\n args[argument.name.value] = encodeInputValue(argument);\n }\n return args;\n}\n\nfunction encodeInputValue(\n node: InputValueDefinitionNode,\n): InputValueDefinitionTuple | TypeReference {\n if (!node.defaultValue) {\n return typeReferenceFromNode(node.type);\n }\n return [\n typeReferenceFromNode(node.type),\n valueFromASTUntyped(node.defaultValue),\n ];\n}\n\nfunction encodeDirective(\n node: DirectiveDefinitionNode,\n): DirectiveDefinitionTuple {\n return !node.arguments?.length\n ? [node.name.value]\n : [node.name.value, encodeArguments(node)];\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,134 @@
1
+ // src/utilities/encodeASTSchema.ts
2
+ import {
3
+ TypeKind
4
+ } from "../schema/definition.mjs";
5
+ import { typeReferenceFromNode } from "../schema/reference.mjs";
6
+ import { valueFromASTUntyped } from "./valueFromASTUntyped.mjs";
7
+ function encodeASTSchema(schemaFragment) {
8
+ const fragments = [{ types: {} }];
9
+ const add = (name, def, extension = false) => addTypeDefinition(fragments, name, def, extension);
10
+ for (const definition of schemaFragment.definitions) {
11
+ if (definition.kind === "ObjectTypeDefinition") {
12
+ add(definition.name.value, encodeObjectType(definition));
13
+ } else if (definition.kind === "InputObjectTypeDefinition") {
14
+ add(definition.name.value, encodeInputObjectType(definition));
15
+ } else if (definition.kind === "EnumTypeDefinition") {
16
+ add(definition.name.value, encodeEnumType(definition));
17
+ } else if (definition.kind === "UnionTypeDefinition") {
18
+ add(definition.name.value, encodeUnionType(definition));
19
+ } else if (definition.kind === "InterfaceTypeDefinition") {
20
+ add(definition.name.value, encodeInterfaceType(definition));
21
+ } else if (definition.kind === "ScalarTypeDefinition") {
22
+ add(definition.name.value, encodeScalarType(definition));
23
+ } else if (definition.kind === "ObjectTypeExtension") {
24
+ add(definition.name.value, encodeObjectType(definition), true);
25
+ } else if (definition.kind === "InputObjectTypeExtension") {
26
+ add(definition.name.value, encodeInputObjectType(definition), true);
27
+ } else if (definition.kind === "EnumTypeExtension") {
28
+ add(definition.name.value, encodeEnumType(definition), true);
29
+ } else if (definition.kind === "UnionTypeExtension") {
30
+ add(definition.name.value, encodeUnionType(definition), true);
31
+ } else if (definition.kind === "InterfaceTypeExtension") {
32
+ add(definition.name.value, encodeInterfaceType(definition), true);
33
+ } else if (definition.kind === "ScalarTypeExtension") {
34
+ add(definition.name.value, encodeScalarType(definition), true);
35
+ } else if (definition.kind === "DirectiveDefinition") {
36
+ if (!fragments[0].directives) {
37
+ fragments[0].directives = [];
38
+ }
39
+ fragments[0].directives.push(encodeDirective(definition));
40
+ }
41
+ }
42
+ return fragments;
43
+ }
44
+ function addTypeDefinition(fragments, typeName, typeDef, isExtension = false) {
45
+ for (let i = 0; i < fragments.length; i++) {
46
+ if (i === 0 && isExtension) {
47
+ continue;
48
+ }
49
+ const fragment = fragments[i];
50
+ if (!fragment.types[typeName]) {
51
+ fragment.types[typeName] = typeDef;
52
+ return;
53
+ }
54
+ }
55
+ const newFragment = { types: { [typeName]: typeDef } };
56
+ fragments.push(newFragment);
57
+ }
58
+ function encodeScalarType(_type) {
59
+ return [TypeKind.SCALAR];
60
+ }
61
+ function encodeEnumType(node) {
62
+ var _a;
63
+ return [TypeKind.ENUM, ((_a = node.values) != null ? _a : []).map((value) => value.name.value)];
64
+ }
65
+ function encodeObjectType(node) {
66
+ var _a;
67
+ const fields = /* @__PURE__ */ Object.create(null);
68
+ for (const field of (_a = node.fields) != null ? _a : []) {
69
+ fields[field.name.value] = encodeField(field);
70
+ }
71
+ if (!node.interfaces) {
72
+ return [TypeKind.OBJECT, fields];
73
+ }
74
+ return [
75
+ TypeKind.OBJECT,
76
+ fields,
77
+ node.interfaces.map((iface) => iface.name.value)
78
+ ];
79
+ }
80
+ function encodeInterfaceType(node) {
81
+ var _a;
82
+ const fields = /* @__PURE__ */ Object.create(null);
83
+ for (const field of (_a = node.fields) != null ? _a : []) {
84
+ fields[field.name.value] = encodeField(field);
85
+ }
86
+ if (!node.interfaces) {
87
+ return [TypeKind.INTERFACE, fields];
88
+ }
89
+ return [
90
+ TypeKind.INTERFACE,
91
+ fields,
92
+ node.interfaces.map((iface) => iface.name.value)
93
+ ];
94
+ }
95
+ function encodeUnionType(node) {
96
+ var _a;
97
+ return [TypeKind.UNION, ((_a = node.types) != null ? _a : []).map((type) => type.name.value)];
98
+ }
99
+ function encodeInputObjectType(node) {
100
+ var _a;
101
+ const fields = /* @__PURE__ */ Object.create(null);
102
+ for (const field of (_a = node.fields) != null ? _a : []) {
103
+ fields[field.name.value] = encodeInputValue(field);
104
+ }
105
+ return [TypeKind.INPUT, fields];
106
+ }
107
+ function encodeField(node) {
108
+ var _a;
109
+ return !((_a = node.arguments) == null ? void 0 : _a.length) ? typeReferenceFromNode(node.type) : [typeReferenceFromNode(node.type), encodeArguments(node)];
110
+ }
111
+ function encodeArguments(node) {
112
+ var _a;
113
+ const args = /* @__PURE__ */ Object.create(null);
114
+ for (const argument of (_a = node.arguments) != null ? _a : []) {
115
+ args[argument.name.value] = encodeInputValue(argument);
116
+ }
117
+ return args;
118
+ }
119
+ function encodeInputValue(node) {
120
+ if (!node.defaultValue) {
121
+ return typeReferenceFromNode(node.type);
122
+ }
123
+ return [
124
+ typeReferenceFromNode(node.type),
125
+ valueFromASTUntyped(node.defaultValue)
126
+ ];
127
+ }
128
+ function encodeDirective(node) {
129
+ var _a;
130
+ return !((_a = node.arguments) == null ? void 0 : _a.length) ? [node.name.value] : [node.name.value, encodeArguments(node)];
131
+ }
132
+ export {
133
+ encodeASTSchema
134
+ };
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../src/utilities/encodeASTSchema.ts"],
4
+ "sourcesContent": ["import {\n DirectiveDefinitionNode,\n EnumTypeDefinitionNode,\n FieldDefinitionNode,\n InputObjectTypeDefinitionNode,\n InputValueDefinitionNode,\n InterfaceTypeDefinitionNode,\n ObjectTypeDefinitionNode,\n ScalarTypeDefinitionNode,\n UnionTypeDefinitionNode,\n DocumentNode,\n ObjectTypeExtensionNode,\n InputObjectTypeExtensionNode,\n InterfaceTypeExtensionNode,\n UnionTypeExtensionNode,\n EnumTypeExtensionNode,\n ScalarTypeExtensionNode,\n} from \"graphql\";\nimport {\n DirectiveDefinitionTuple,\n EnumTypeDefinitionTuple,\n FieldDefinitionTuple,\n InputObjectTypeDefinitionTuple,\n InputValueDefinitionRecord,\n InputValueDefinitionTuple,\n InterfaceTypeDefinitionTuple,\n ObjectTypeDefinitionTuple,\n ScalarTypeDefinitionTuple,\n UnionTypeDefinitionTuple,\n SchemaDefinitions,\n TypeKind,\n TypeReference,\n TypeDefinitionTuple,\n} from \"../schema/definition\";\nimport { typeReferenceFromNode } from \"../schema/reference\";\nimport { valueFromASTUntyped } from \"./valueFromASTUntyped\";\n\nexport function encodeASTSchema(\n schemaFragment: DocumentNode,\n): SchemaDefinitions[] {\n const fragments: SchemaDefinitions[] = [{ types: {} }];\n const add = (name: string, def: TypeDefinitionTuple, extension = false) =>\n addTypeDefinition(fragments, name, def, extension);\n\n for (const definition of schemaFragment.definitions) {\n if (definition.kind === \"ObjectTypeDefinition\") {\n add(definition.name.value, encodeObjectType(definition));\n } else if (definition.kind === \"InputObjectTypeDefinition\") {\n add(definition.name.value, encodeInputObjectType(definition));\n } else if (definition.kind === \"EnumTypeDefinition\") {\n add(definition.name.value, encodeEnumType(definition));\n } else if (definition.kind === \"UnionTypeDefinition\") {\n add(definition.name.value, encodeUnionType(definition));\n } else if (definition.kind === \"InterfaceTypeDefinition\") {\n add(definition.name.value, encodeInterfaceType(definition));\n } else if (definition.kind === \"ScalarTypeDefinition\") {\n add(definition.name.value, encodeScalarType(definition));\n } else if (definition.kind === \"ObjectTypeExtension\") {\n add(definition.name.value, encodeObjectType(definition), true);\n } else if (definition.kind === \"InputObjectTypeExtension\") {\n add(definition.name.value, encodeInputObjectType(definition), true);\n } else if (definition.kind === \"EnumTypeExtension\") {\n add(definition.name.value, encodeEnumType(definition), true);\n } else if (definition.kind === \"UnionTypeExtension\") {\n add(definition.name.value, encodeUnionType(definition), true);\n } else if (definition.kind === \"InterfaceTypeExtension\") {\n add(definition.name.value, encodeInterfaceType(definition), true);\n } else if (definition.kind === \"ScalarTypeExtension\") {\n add(definition.name.value, encodeScalarType(definition), true);\n } else if (definition.kind === \"DirectiveDefinition\") {\n if (!fragments[0].directives) {\n fragments[0].directives = [];\n }\n fragments[0].directives.push(encodeDirective(definition));\n }\n }\n return fragments;\n}\n\nfunction addTypeDefinition(\n fragments: SchemaDefinitions[],\n typeName: string,\n typeDef: TypeDefinitionTuple,\n isExtension = false,\n) {\n for (let i = 0; i < fragments.length; i++) {\n if (i === 0 && isExtension) {\n // Don't write extensions to the very first fragment (it is reserved for type definitions)\n // Note: 2nd+ type definition with the same name is treated as extension\n continue;\n }\n const fragment = fragments[i];\n if (!fragment.types[typeName]) {\n fragment.types[typeName] = typeDef;\n return;\n }\n }\n const newFragment = { types: { [typeName]: typeDef } };\n fragments.push(newFragment);\n}\n\nfunction encodeScalarType(\n _type: ScalarTypeDefinitionNode | ScalarTypeExtensionNode,\n): ScalarTypeDefinitionTuple {\n return [TypeKind.SCALAR];\n}\n\nfunction encodeEnumType(\n node: EnumTypeDefinitionNode | EnumTypeExtensionNode,\n): EnumTypeDefinitionTuple {\n return [TypeKind.ENUM, (node.values ?? []).map((value) => value.name.value)];\n}\n\nfunction encodeObjectType(\n node: ObjectTypeDefinitionNode | ObjectTypeExtensionNode,\n): ObjectTypeDefinitionTuple {\n const fields = Object.create(null);\n for (const field of node.fields ?? []) {\n fields[field.name.value] = encodeField(field);\n }\n if (!node.interfaces) {\n return [TypeKind.OBJECT, fields];\n }\n return [\n TypeKind.OBJECT,\n fields,\n node.interfaces.map((iface) => iface.name.value),\n ];\n}\n\nfunction encodeInterfaceType(\n node: InterfaceTypeDefinitionNode | InterfaceTypeExtensionNode,\n): InterfaceTypeDefinitionTuple {\n const fields = Object.create(null);\n for (const field of node.fields ?? []) {\n fields[field.name.value] = encodeField(field);\n }\n if (!node.interfaces) {\n return [TypeKind.INTERFACE, fields];\n }\n return [\n TypeKind.INTERFACE,\n fields,\n node.interfaces.map((iface) => iface.name.value),\n ];\n}\n\nfunction encodeUnionType(\n node: UnionTypeDefinitionNode | UnionTypeExtensionNode,\n): UnionTypeDefinitionTuple {\n return [TypeKind.UNION, (node.types ?? []).map((type) => type.name.value)];\n}\n\nfunction encodeInputObjectType(\n node: InputObjectTypeDefinitionNode | InputObjectTypeExtensionNode,\n): InputObjectTypeDefinitionTuple {\n const fields = Object.create(null);\n for (const field of node.fields ?? []) {\n fields[field.name.value] = encodeInputValue(field);\n }\n return [TypeKind.INPUT, fields];\n}\n\nfunction encodeField(\n node: FieldDefinitionNode,\n): TypeReference | FieldDefinitionTuple {\n return !node.arguments?.length\n ? typeReferenceFromNode(node.type)\n : [typeReferenceFromNode(node.type), encodeArguments(node)];\n}\n\nfunction encodeArguments(\n node: FieldDefinitionNode | DirectiveDefinitionNode,\n): InputValueDefinitionRecord {\n const args = Object.create(null);\n for (const argument of node.arguments ?? []) {\n args[argument.name.value] = encodeInputValue(argument);\n }\n return args;\n}\n\nfunction encodeInputValue(\n node: InputValueDefinitionNode,\n): InputValueDefinitionTuple | TypeReference {\n if (!node.defaultValue) {\n return typeReferenceFromNode(node.type);\n }\n return [\n typeReferenceFromNode(node.type),\n valueFromASTUntyped(node.defaultValue),\n ];\n}\n\nfunction encodeDirective(\n node: DirectiveDefinitionNode,\n): DirectiveDefinitionTuple {\n return !node.arguments?.length\n ? [node.name.value]\n : [node.name.value, encodeArguments(node)];\n}\n"],
5
+ "mappings": "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",
6
+ "names": []
7
+ }
@@ -0,0 +1,8 @@
1
+ import { DirectiveNode, DocumentNode, GraphQLSchema } from "graphql";
2
+ import { SchemaDefinitions } from "../schema/definition";
3
+ export type ExtractMinimalViableSchemaResult = {
4
+ definitions: SchemaDefinitions;
5
+ unknownDirectives: DirectiveNode[];
6
+ };
7
+ export declare function extractMinimalViableSchemaForRequestDocument(schema: GraphQLSchema, requestDocument: DocumentNode): ExtractMinimalViableSchemaResult;
8
+ //# sourceMappingURL=extractMinimalViableSchemaForRequestDocument.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractMinimalViableSchemaForRequestDocument.d.ts","sourceRoot":"","sources":["../../src/utilities/extractMinimalViableSchemaForRequestDocument.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,aAAa,EACb,YAAY,EAYZ,aAAa,EAad,MAAM,SAAS,CAAC;AACjB,OAAO,EAiBL,iBAAiB,EAIlB,MAAM,sBAAsB,CAAC;AAW9B,MAAM,MAAM,gCAAgC,GAAG;IAC7C,WAAW,EAAE,iBAAiB,CAAC;IAC/B,iBAAiB,EAAE,aAAa,EAAE,CAAC;CACpC,CAAC;AAEF,wBAAgB,4CAA4C,CAC1D,MAAM,EAAE,aAAa,EACrB,eAAe,EAAE,YAAY,GAC5B,gCAAgC,CA6DlC"}