graphql 0.0.1-test.1

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 (390) hide show
  1. package/LICENSE +21 -0
  2. package/NotSupportedTSVersion.d.ts +1 -0
  3. package/README.md +158 -0
  4. package/error/GraphQLError.d.ts +142 -0
  5. package/error/GraphQLError.js +267 -0
  6. package/error/GraphQLError.mjs +253 -0
  7. package/error/index.d.ts +7 -0
  8. package/error/index.js +41 -0
  9. package/error/index.mjs +3 -0
  10. package/error/locatedError.d.ts +13 -0
  11. package/error/locatedError.js +40 -0
  12. package/error/locatedError.mjs +32 -0
  13. package/error/syntaxError.d.ts +11 -0
  14. package/error/syntaxError.js +21 -0
  15. package/error/syntaxError.mjs +11 -0
  16. package/execution/collectFields.d.ts +45 -0
  17. package/execution/collectFields.js +229 -0
  18. package/execution/collectFields.mjs +213 -0
  19. package/execution/execute.d.ts +185 -0
  20. package/execution/execute.js +1016 -0
  21. package/execution/execute.mjs +988 -0
  22. package/execution/index.d.ts +14 -0
  23. package/execution/index.js +67 -0
  24. package/execution/index.mjs +9 -0
  25. package/execution/mapAsyncIterator.d.ts +9 -0
  26. package/execution/mapAsyncIterator.js +68 -0
  27. package/execution/mapAsyncIterator.mjs +61 -0
  28. package/execution/subscribe.d.ts +68 -0
  29. package/execution/subscribe.js +261 -0
  30. package/execution/subscribe.mjs +239 -0
  31. package/execution/values.d.ts +81 -0
  32. package/execution/values.js +292 -0
  33. package/execution/values.mjs +255 -0
  34. package/graphql.d.ts +67 -0
  35. package/graphql.js +96 -0
  36. package/graphql.mjs +122 -0
  37. package/index.d.ts +411 -0
  38. package/index.js +1263 -0
  39. package/index.mjs +254 -0
  40. package/jsutils/Maybe.d.ts +2 -0
  41. package/jsutils/Maybe.js +5 -0
  42. package/jsutils/Maybe.mjs +1 -0
  43. package/jsutils/ObjMap.d.ts +16 -0
  44. package/jsutils/ObjMap.js +5 -0
  45. package/jsutils/ObjMap.mjs +1 -0
  46. package/jsutils/Path.d.ts +20 -0
  47. package/jsutils/Path.js +33 -0
  48. package/jsutils/Path.mjs +25 -0
  49. package/jsutils/PromiseOrValue.d.ts +1 -0
  50. package/jsutils/PromiseOrValue.js +5 -0
  51. package/jsutils/PromiseOrValue.mjs +1 -0
  52. package/jsutils/devAssert.d.ts +1 -0
  53. package/jsutils/devAssert.js +14 -0
  54. package/jsutils/devAssert.mjs +7 -0
  55. package/jsutils/didYouMean.d.ts +8 -0
  56. package/jsutils/didYouMean.js +38 -0
  57. package/jsutils/didYouMean.mjs +32 -0
  58. package/jsutils/groupBy.d.ts +7 -0
  59. package/jsutils/groupBy.js +26 -0
  60. package/jsutils/groupBy.mjs +19 -0
  61. package/jsutils/identityFunc.d.ts +4 -0
  62. package/jsutils/identityFunc.js +13 -0
  63. package/jsutils/identityFunc.mjs +6 -0
  64. package/jsutils/inspect.d.ts +4 -0
  65. package/jsutils/inspect.js +121 -0
  66. package/jsutils/inspect.mjs +115 -0
  67. package/jsutils/instanceOf.d.ts +16 -0
  68. package/jsutils/instanceOf.js +60 -0
  69. package/jsutils/instanceOf.mjs +52 -0
  70. package/jsutils/invariant.d.ts +4 -0
  71. package/jsutils/invariant.js +16 -0
  72. package/jsutils/invariant.mjs +9 -0
  73. package/jsutils/isAsyncIterable.d.ts +7 -0
  74. package/jsutils/isAsyncIterable.js +18 -0
  75. package/jsutils/isAsyncIterable.mjs +11 -0
  76. package/jsutils/isIterableObject.d.ts +20 -0
  77. package/jsutils/isIterableObject.js +32 -0
  78. package/jsutils/isIterableObject.mjs +25 -0
  79. package/jsutils/isObjectLike.d.ts +7 -0
  80. package/jsutils/isObjectLike.js +14 -0
  81. package/jsutils/isObjectLike.mjs +7 -0
  82. package/jsutils/isPromise.d.ts +5 -0
  83. package/jsutils/isPromise.js +17 -0
  84. package/jsutils/isPromise.mjs +10 -0
  85. package/jsutils/keyMap.d.ts +32 -0
  86. package/jsutils/keyMap.js +43 -0
  87. package/jsutils/keyMap.mjs +36 -0
  88. package/jsutils/keyValMap.d.ts +23 -0
  89. package/jsutils/keyValMap.js +33 -0
  90. package/jsutils/keyValMap.mjs +26 -0
  91. package/jsutils/mapValue.d.ts +9 -0
  92. package/jsutils/mapValue.js +20 -0
  93. package/jsutils/mapValue.mjs +13 -0
  94. package/jsutils/memoize3.d.ts +9 -0
  95. package/jsutils/memoize3.js +41 -0
  96. package/jsutils/memoize3.mjs +34 -0
  97. package/jsutils/naturalCompare.d.ts +8 -0
  98. package/jsutils/naturalCompare.js +69 -0
  99. package/jsutils/naturalCompare.mjs +61 -0
  100. package/jsutils/printPathArray.d.ts +6 -0
  101. package/jsutils/printPathArray.js +17 -0
  102. package/jsutils/printPathArray.mjs +10 -0
  103. package/jsutils/promiseForObject.d.ts +11 -0
  104. package/jsutils/promiseForObject.js +25 -0
  105. package/jsutils/promiseForObject.mjs +18 -0
  106. package/jsutils/promiseReduce.d.ts +13 -0
  107. package/jsutils/promiseReduce.js +27 -0
  108. package/jsutils/promiseReduce.mjs +20 -0
  109. package/jsutils/suggestionList.d.ts +8 -0
  110. package/jsutils/suggestionList.js +139 -0
  111. package/jsutils/suggestionList.mjs +130 -0
  112. package/jsutils/toError.d.ts +4 -0
  113. package/jsutils/toError.js +25 -0
  114. package/jsutils/toError.mjs +18 -0
  115. package/jsutils/toObjMap.d.ts +5 -0
  116. package/jsutils/toObjMap.js +24 -0
  117. package/jsutils/toObjMap.mjs +17 -0
  118. package/language/ast.d.ts +536 -0
  119. package/language/ast.js +224 -0
  120. package/language/ast.mjs +206 -0
  121. package/language/blockString.d.ts +28 -0
  122. package/language/blockString.js +195 -0
  123. package/language/blockString.mjs +178 -0
  124. package/language/characterClasses.d.ts +47 -0
  125. package/language/characterClasses.js +75 -0
  126. package/language/characterClasses.mjs +64 -0
  127. package/language/directiveLocation.d.ts +32 -0
  128. package/language/directiveLocation.js +40 -0
  129. package/language/directiveLocation.mjs +31 -0
  130. package/language/index.d.ts +97 -0
  131. package/language/index.js +215 -0
  132. package/language/index.mjs +29 -0
  133. package/language/kinds.d.ts +65 -0
  134. package/language/kinds.js +64 -0
  135. package/language/kinds.mjs +55 -0
  136. package/language/lexer.d.ts +45 -0
  137. package/language/lexer.js +1006 -0
  138. package/language/lexer.mjs +902 -0
  139. package/language/location.d.ts +16 -0
  140. package/language/location.js +38 -0
  141. package/language/location.mjs +30 -0
  142. package/language/parser.d.ts +554 -0
  143. package/language/parser.js +1567 -0
  144. package/language/parser.mjs +1524 -0
  145. package/language/predicates.d.ts +33 -0
  146. package/language/predicates.js +109 -0
  147. package/language/predicates.mjs +81 -0
  148. package/language/printLocation.d.ts +14 -0
  149. package/language/printLocation.js +74 -0
  150. package/language/printLocation.mjs +66 -0
  151. package/language/printString.d.ts +5 -0
  152. package/language/printString.js +183 -0
  153. package/language/printString.mjs +176 -0
  154. package/language/printer.d.ts +6 -0
  155. package/language/printer.js +351 -0
  156. package/language/printer.mjs +339 -0
  157. package/language/source.d.ts +25 -0
  158. package/language/source.js +65 -0
  159. package/language/source.mjs +50 -0
  160. package/language/tokenKind.d.ts +34 -0
  161. package/language/tokenKind.js +44 -0
  162. package/language/tokenKind.mjs +35 -0
  163. package/language/visitor.d.ts +194 -0
  164. package/language/visitor.js +377 -0
  165. package/language/visitor.mjs +361 -0
  166. package/package.json +40 -0
  167. package/subscription/index.d.ts +19 -0
  168. package/subscription/index.js +19 -0
  169. package/subscription/index.mjs +19 -0
  170. package/type/assertName.d.ts +10 -0
  171. package/type/assertName.js +59 -0
  172. package/type/assertName.mjs +44 -0
  173. package/type/definition.d.ts +917 -0
  174. package/type/definition.js +1329 -0
  175. package/type/definition.mjs +1167 -0
  176. package/type/directives.d.ts +86 -0
  177. package/type/directives.js +224 -0
  178. package/type/directives.mjs +190 -0
  179. package/type/index.d.ts +150 -0
  180. package/type/index.js +547 -0
  181. package/type/index.mjs +103 -0
  182. package/type/introspection.d.ts +29 -0
  183. package/type/introspection.js +617 -0
  184. package/type/introspection.mjs +550 -0
  185. package/type/scalars.d.ts +19 -0
  186. package/type/scalars.js +359 -0
  187. package/type/scalars.mjs +299 -0
  188. package/type/schema.d.ts +170 -0
  189. package/type/schema.js +402 -0
  190. package/type/schema.mjs +381 -0
  191. package/type/validate.d.ts +17 -0
  192. package/type/validate.js +672 -0
  193. package/type/validate.mjs +647 -0
  194. package/utilities/TypeInfo.d.ts +67 -0
  195. package/utilities/TypeInfo.js +418 -0
  196. package/utilities/TypeInfo.mjs +395 -0
  197. package/utilities/assertValidName.d.ts +13 -0
  198. package/utilities/assertValidName.js +51 -0
  199. package/utilities/assertValidName.mjs +40 -0
  200. package/utilities/astFromValue.d.ts +28 -0
  201. package/utilities/astFromValue.js +190 -0
  202. package/utilities/astFromValue.mjs +177 -0
  203. package/utilities/buildASTSchema.d.ts +35 -0
  204. package/utilities/buildASTSchema.js +115 -0
  205. package/utilities/buildASTSchema.mjs +97 -0
  206. package/utilities/buildClientSchema.d.ts +19 -0
  207. package/utilities/buildClientSchema.js +386 -0
  208. package/utilities/buildClientSchema.mjs +363 -0
  209. package/utilities/coerceInputValue.d.ts +16 -0
  210. package/utilities/coerceInputValue.js +191 -0
  211. package/utilities/coerceInputValue.mjs +172 -0
  212. package/utilities/concatAST.d.ts +9 -0
  213. package/utilities/concatAST.js +26 -0
  214. package/utilities/concatAST.mjs +19 -0
  215. package/utilities/extendSchema.d.ts +40 -0
  216. package/utilities/extendSchema.js +798 -0
  217. package/utilities/extendSchema.mjs +789 -0
  218. package/utilities/findBreakingChanges.d.ts +51 -0
  219. package/utilities/findBreakingChanges.js +547 -0
  220. package/utilities/findBreakingChanges.mjs +516 -0
  221. package/utilities/getIntrospectionQuery.d.ts +182 -0
  222. package/utilities/getIntrospectionQuery.js +134 -0
  223. package/utilities/getIntrospectionQuery.mjs +127 -0
  224. package/utilities/getOperationAST.d.ts +11 -0
  225. package/utilities/getOperationAST.js +43 -0
  226. package/utilities/getOperationAST.mjs +36 -0
  227. package/utilities/getOperationRootType.d.ts +15 -0
  228. package/utilities/getOperationRootType.js +59 -0
  229. package/utilities/getOperationRootType.mjs +52 -0
  230. package/utilities/index.d.ts +61 -0
  231. package/utilities/index.js +233 -0
  232. package/utilities/index.mjs +55 -0
  233. package/utilities/introspectionFromSchema.d.ts +18 -0
  234. package/utilities/introspectionFromSchema.js +42 -0
  235. package/utilities/introspectionFromSchema.mjs +30 -0
  236. package/utilities/lexicographicSortSchema.d.ts +9 -0
  237. package/utilities/lexicographicSortSchema.js +177 -0
  238. package/utilities/lexicographicSortSchema.mjs +172 -0
  239. package/utilities/printSchema.d.ts +5 -0
  240. package/utilities/printSchema.js +333 -0
  241. package/utilities/printSchema.mjs +309 -0
  242. package/utilities/separateOperations.d.ts +11 -0
  243. package/utilities/separateOperations.js +88 -0
  244. package/utilities/separateOperations.mjs +80 -0
  245. package/utilities/sortValueNode.d.ts +9 -0
  246. package/utilities/sortValueNode.js +47 -0
  247. package/utilities/sortValueNode.mjs +39 -0
  248. package/utilities/stripIgnoredCharacters.d.ts +62 -0
  249. package/utilities/stripIgnoredCharacters.js +121 -0
  250. package/utilities/stripIgnoredCharacters.mjs +104 -0
  251. package/utilities/typeComparators.d.ts +32 -0
  252. package/utilities/typeComparators.js +116 -0
  253. package/utilities/typeComparators.mjs +106 -0
  254. package/utilities/typeFromAST.d.ts +32 -0
  255. package/utilities/typeFromAST.js +27 -0
  256. package/utilities/typeFromAST.mjs +18 -0
  257. package/utilities/typedQueryDocumentNode.d.ts +22 -0
  258. package/utilities/typedQueryDocumentNode.js +5 -0
  259. package/utilities/typedQueryDocumentNode.mjs +1 -0
  260. package/utilities/valueFromAST.d.ts +29 -0
  261. package/utilities/valueFromAST.js +185 -0
  262. package/utilities/valueFromAST.mjs +172 -0
  263. package/utilities/valueFromASTUntyped.d.ts +23 -0
  264. package/utilities/valueFromASTUntyped.js +61 -0
  265. package/utilities/valueFromASTUntyped.mjs +53 -0
  266. package/validation/ValidationContext.d.ts +95 -0
  267. package/validation/ValidationContext.js +232 -0
  268. package/validation/ValidationContext.mjs +212 -0
  269. package/validation/index.d.ts +40 -0
  270. package/validation/index.js +317 -0
  271. package/validation/index.mjs +68 -0
  272. package/validation/rules/ExecutableDefinitionsRule.d.ts +13 -0
  273. package/validation/rules/ExecutableDefinitionsRule.js +44 -0
  274. package/validation/rules/ExecutableDefinitionsRule.mjs +35 -0
  275. package/validation/rules/FieldsOnCorrectTypeRule.d.ts +13 -0
  276. package/validation/rules/FieldsOnCorrectTypeRule.js +143 -0
  277. package/validation/rules/FieldsOnCorrectTypeRule.mjs +125 -0
  278. package/validation/rules/FragmentsOnCompositeTypesRule.d.ts +14 -0
  279. package/validation/rules/FragmentsOnCompositeTypesRule.js +65 -0
  280. package/validation/rules/FragmentsOnCompositeTypesRule.mjs +49 -0
  281. package/validation/rules/KnownArgumentNamesRule.d.ts +23 -0
  282. package/validation/rules/KnownArgumentNamesRule.js +116 -0
  283. package/validation/rules/KnownArgumentNamesRule.mjs +98 -0
  284. package/validation/rules/KnownDirectivesRule.d.ts +16 -0
  285. package/validation/rules/KnownDirectivesRule.js +163 -0
  286. package/validation/rules/KnownDirectivesRule.mjs +146 -0
  287. package/validation/rules/KnownFragmentNamesRule.d.ts +13 -0
  288. package/validation/rules/KnownFragmentNamesRule.js +34 -0
  289. package/validation/rules/KnownFragmentNamesRule.mjs +24 -0
  290. package/validation/rules/KnownTypeNamesRule.d.ts +16 -0
  291. package/validation/rules/KnownTypeNamesRule.js +87 -0
  292. package/validation/rules/KnownTypeNamesRule.mjs +75 -0
  293. package/validation/rules/LoneAnonymousOperationRule.d.ts +13 -0
  294. package/validation/rules/LoneAnonymousOperationRule.js +40 -0
  295. package/validation/rules/LoneAnonymousOperationRule.mjs +32 -0
  296. package/validation/rules/LoneSchemaDefinitionRule.d.ts +10 -0
  297. package/validation/rules/LoneSchemaDefinitionRule.js +63 -0
  298. package/validation/rules/LoneSchemaDefinitionRule.mjs +53 -0
  299. package/validation/rules/NoFragmentCyclesRule.d.ts +13 -0
  300. package/validation/rules/NoFragmentCyclesRule.js +83 -0
  301. package/validation/rules/NoFragmentCyclesRule.mjs +76 -0
  302. package/validation/rules/NoUndefinedVariablesRule.d.ts +13 -0
  303. package/validation/rules/NoUndefinedVariablesRule.js +50 -0
  304. package/validation/rules/NoUndefinedVariablesRule.mjs +43 -0
  305. package/validation/rules/NoUnusedFragmentsRule.d.ts +13 -0
  306. package/validation/rules/NoUnusedFragmentsRule.js +59 -0
  307. package/validation/rules/NoUnusedFragmentsRule.mjs +52 -0
  308. package/validation/rules/NoUnusedVariablesRule.d.ts +13 -0
  309. package/validation/rules/NoUnusedVariablesRule.js +55 -0
  310. package/validation/rules/NoUnusedVariablesRule.mjs +48 -0
  311. package/validation/rules/OverlappingFieldsCanBeMergedRule-old.js +805 -0
  312. package/validation/rules/OverlappingFieldsCanBeMergedRule-old.mjs +788 -0
  313. package/validation/rules/OverlappingFieldsCanBeMergedRule.d.ts +14 -0
  314. package/validation/rules/OverlappingFieldsCanBeMergedRule.js +805 -0
  315. package/validation/rules/OverlappingFieldsCanBeMergedRule.mjs +788 -0
  316. package/validation/rules/PossibleFragmentSpreadsRule.d.ts +12 -0
  317. package/validation/rules/PossibleFragmentSpreadsRule.js +91 -0
  318. package/validation/rules/PossibleFragmentSpreadsRule.mjs +69 -0
  319. package/validation/rules/PossibleTypeExtensionsRule.d.ts +10 -0
  320. package/validation/rules/PossibleTypeExtensionsRule.js +167 -0
  321. package/validation/rules/PossibleTypeExtensionsRule.mjs +147 -0
  322. package/validation/rules/ProvidedRequiredArgumentsRule.d.ts +20 -0
  323. package/validation/rules/ProvidedRequiredArgumentsRule.js +158 -0
  324. package/validation/rules/ProvidedRequiredArgumentsRule.mjs +138 -0
  325. package/validation/rules/ScalarLeafsRule.d.ts +9 -0
  326. package/validation/rules/ScalarLeafsRule.js +51 -0
  327. package/validation/rules/ScalarLeafsRule.mjs +42 -0
  328. package/validation/rules/SingleFieldSubscriptionsRule.d.ts +13 -0
  329. package/validation/rules/SingleFieldSubscriptionsRule.js +82 -0
  330. package/validation/rules/SingleFieldSubscriptionsRule.mjs +73 -0
  331. package/validation/rules/UniqueArgumentDefinitionNamesRule.d.ts +11 -0
  332. package/validation/rules/UniqueArgumentDefinitionNamesRule.js +90 -0
  333. package/validation/rules/UniqueArgumentDefinitionNamesRule.mjs +79 -0
  334. package/validation/rules/UniqueArgumentNamesRule.d.ts +13 -0
  335. package/validation/rules/UniqueArgumentNamesRule.js +53 -0
  336. package/validation/rules/UniqueArgumentNamesRule.mjs +42 -0
  337. package/validation/rules/UniqueDirectiveNamesRule.d.ts +10 -0
  338. package/validation/rules/UniqueDirectiveNamesRule.js +50 -0
  339. package/validation/rules/UniqueDirectiveNamesRule.mjs +43 -0
  340. package/validation/rules/UniqueDirectivesPerLocationRule.d.ts +16 -0
  341. package/validation/rules/UniqueDirectivesPerLocationRule.js +93 -0
  342. package/validation/rules/UniqueDirectivesPerLocationRule.mjs +83 -0
  343. package/validation/rules/UniqueEnumValueNamesRule.d.ts +10 -0
  344. package/validation/rules/UniqueEnumValueNamesRule.js +71 -0
  345. package/validation/rules/UniqueEnumValueNamesRule.mjs +60 -0
  346. package/validation/rules/UniqueFieldDefinitionNamesRule.d.ts +10 -0
  347. package/validation/rules/UniqueFieldDefinitionNamesRule.js +83 -0
  348. package/validation/rules/UniqueFieldDefinitionNamesRule.mjs +75 -0
  349. package/validation/rules/UniqueFragmentNamesRule.d.ts +12 -0
  350. package/validation/rules/UniqueFragmentNamesRule.js +39 -0
  351. package/validation/rules/UniqueFragmentNamesRule.mjs +32 -0
  352. package/validation/rules/UniqueInputFieldNamesRule.d.ts +13 -0
  353. package/validation/rules/UniqueInputFieldNamesRule.js +52 -0
  354. package/validation/rules/UniqueInputFieldNamesRule.mjs +44 -0
  355. package/validation/rules/UniqueOperationNamesRule.d.ts +12 -0
  356. package/validation/rules/UniqueOperationNamesRule.js +41 -0
  357. package/validation/rules/UniqueOperationNamesRule.mjs +34 -0
  358. package/validation/rules/UniqueOperationTypesRule.d.ts +10 -0
  359. package/validation/rules/UniqueOperationTypesRule.js +67 -0
  360. package/validation/rules/UniqueOperationTypesRule.mjs +60 -0
  361. package/validation/rules/UniqueTypeNamesRule.d.ts +10 -0
  362. package/validation/rules/UniqueTypeNamesRule.js +53 -0
  363. package/validation/rules/UniqueTypeNamesRule.mjs +46 -0
  364. package/validation/rules/UniqueVariableNamesRule.d.ts +10 -0
  365. package/validation/rules/UniqueVariableNamesRule.js +47 -0
  366. package/validation/rules/UniqueVariableNamesRule.mjs +39 -0
  367. package/validation/rules/ValuesOfCorrectTypeRule.d.ts +13 -0
  368. package/validation/rules/ValuesOfCorrectTypeRule.js +183 -0
  369. package/validation/rules/ValuesOfCorrectTypeRule.mjs +164 -0
  370. package/validation/rules/VariablesAreInputTypesRule.d.ts +13 -0
  371. package/validation/rules/VariablesAreInputTypesRule.js +44 -0
  372. package/validation/rules/VariablesAreInputTypesRule.mjs +31 -0
  373. package/validation/rules/VariablesInAllowedPositionRule.d.ts +12 -0
  374. package/validation/rules/VariablesInAllowedPositionRule.js +114 -0
  375. package/validation/rules/VariablesInAllowedPositionRule.mjs +95 -0
  376. package/validation/rules/custom/NoDeprecatedCustomRule.d.ts +15 -0
  377. package/validation/rules/custom/NoDeprecatedCustomRule.js +121 -0
  378. package/validation/rules/custom/NoDeprecatedCustomRule.mjs +107 -0
  379. package/validation/rules/custom/NoSchemaIntrospectionCustomRule.d.ts +15 -0
  380. package/validation/rules/custom/NoSchemaIntrospectionCustomRule.js +39 -0
  381. package/validation/rules/custom/NoSchemaIntrospectionCustomRule.mjs +30 -0
  382. package/validation/specifiedRules.d.ts +12 -0
  383. package/validation/specifiedRules.js +160 -0
  384. package/validation/specifiedRules.mjs +123 -0
  385. package/validation/validate.d.ts +61 -0
  386. package/validation/validate.js +151 -0
  387. package/validation/validate.mjs +133 -0
  388. package/version.d.ts +13 -0
  389. package/version.js +25 -0
  390. package/version.mjs +17 -0
@@ -0,0 +1,229 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', {
4
+ value: true,
5
+ });
6
+ exports.collectFields = collectFields;
7
+ exports.collectSubfields = collectSubfields;
8
+
9
+ var _kinds = require('../language/kinds.js');
10
+
11
+ var _definition = require('../type/definition.js');
12
+
13
+ var _directives = require('../type/directives.js');
14
+
15
+ var _typeFromAST = require('../utilities/typeFromAST.js');
16
+
17
+ var _values = require('./values.js');
18
+
19
+ /**
20
+ * Given a selectionSet, collects all of the fields and returns them.
21
+ *
22
+ * CollectFields requires the "runtime type" of an object. For a field that
23
+ * returns an Interface or Union type, the "runtime type" will be the actual
24
+ * object type returned by that field.
25
+ *
26
+ * @internal
27
+ */
28
+ function collectFields(
29
+ schema,
30
+ fragments,
31
+ variableValues,
32
+ runtimeType,
33
+ selectionSet,
34
+ ) {
35
+ const fields = new Map();
36
+ collectFieldsImpl(
37
+ schema,
38
+ fragments,
39
+ variableValues,
40
+ runtimeType,
41
+ selectionSet,
42
+ fields,
43
+ new Set(),
44
+ );
45
+ return fields;
46
+ }
47
+ /**
48
+ * Given an array of field nodes, collects all of the subfields of the passed
49
+ * in fields, and returns them at the end.
50
+ *
51
+ * CollectSubFields requires the "return type" of an object. For a field that
52
+ * returns an Interface or Union type, the "return type" will be the actual
53
+ * object type returned by that field.
54
+ *
55
+ * @internal
56
+ */
57
+
58
+ function collectSubfields(
59
+ schema,
60
+ fragments,
61
+ variableValues,
62
+ returnType,
63
+ fieldNodes,
64
+ ) {
65
+ const subFieldNodes = new Map();
66
+ const visitedFragmentNames = new Set();
67
+
68
+ for (const node of fieldNodes) {
69
+ if (node.selectionSet) {
70
+ collectFieldsImpl(
71
+ schema,
72
+ fragments,
73
+ variableValues,
74
+ returnType,
75
+ node.selectionSet,
76
+ subFieldNodes,
77
+ visitedFragmentNames,
78
+ );
79
+ }
80
+ }
81
+
82
+ return subFieldNodes;
83
+ }
84
+
85
+ function collectFieldsImpl(
86
+ schema,
87
+ fragments,
88
+ variableValues,
89
+ runtimeType,
90
+ selectionSet,
91
+ fields,
92
+ visitedFragmentNames,
93
+ ) {
94
+ for (const selection of selectionSet.selections) {
95
+ switch (selection.kind) {
96
+ case _kinds.Kind.FIELD: {
97
+ if (!shouldIncludeNode(variableValues, selection)) {
98
+ continue;
99
+ }
100
+
101
+ const name = getFieldEntryKey(selection);
102
+ const fieldList = fields.get(name);
103
+
104
+ if (fieldList !== undefined) {
105
+ fieldList.push(selection);
106
+ } else {
107
+ fields.set(name, [selection]);
108
+ }
109
+
110
+ break;
111
+ }
112
+
113
+ case _kinds.Kind.INLINE_FRAGMENT: {
114
+ if (
115
+ !shouldIncludeNode(variableValues, selection) ||
116
+ !doesFragmentConditionMatch(schema, selection, runtimeType)
117
+ ) {
118
+ continue;
119
+ }
120
+
121
+ collectFieldsImpl(
122
+ schema,
123
+ fragments,
124
+ variableValues,
125
+ runtimeType,
126
+ selection.selectionSet,
127
+ fields,
128
+ visitedFragmentNames,
129
+ );
130
+ break;
131
+ }
132
+
133
+ case _kinds.Kind.FRAGMENT_SPREAD: {
134
+ const fragName = selection.name.value;
135
+
136
+ if (
137
+ visitedFragmentNames.has(fragName) ||
138
+ !shouldIncludeNode(variableValues, selection)
139
+ ) {
140
+ continue;
141
+ }
142
+
143
+ visitedFragmentNames.add(fragName);
144
+ const fragment = fragments[fragName];
145
+
146
+ if (
147
+ !fragment ||
148
+ !doesFragmentConditionMatch(schema, fragment, runtimeType)
149
+ ) {
150
+ continue;
151
+ }
152
+
153
+ collectFieldsImpl(
154
+ schema,
155
+ fragments,
156
+ variableValues,
157
+ runtimeType,
158
+ fragment.selectionSet,
159
+ fields,
160
+ visitedFragmentNames,
161
+ );
162
+ break;
163
+ }
164
+ }
165
+ }
166
+ }
167
+ /**
168
+ * Determines if a field should be included based on the `@include` and `@skip`
169
+ * directives, where `@skip` has higher precedence than `@include`.
170
+ */
171
+
172
+ function shouldIncludeNode(variableValues, node) {
173
+ const skip = (0, _values.getDirectiveValues)(
174
+ _directives.GraphQLSkipDirective,
175
+ node,
176
+ variableValues,
177
+ );
178
+
179
+ if ((skip === null || skip === void 0 ? void 0 : skip.if) === true) {
180
+ return false;
181
+ }
182
+
183
+ const include = (0, _values.getDirectiveValues)(
184
+ _directives.GraphQLIncludeDirective,
185
+ node,
186
+ variableValues,
187
+ );
188
+
189
+ if (
190
+ (include === null || include === void 0 ? void 0 : include.if) === false
191
+ ) {
192
+ return false;
193
+ }
194
+
195
+ return true;
196
+ }
197
+ /**
198
+ * Determines if a fragment is applicable to the given type.
199
+ */
200
+
201
+ function doesFragmentConditionMatch(schema, fragment, type) {
202
+ const typeConditionNode = fragment.typeCondition;
203
+
204
+ if (!typeConditionNode) {
205
+ return true;
206
+ }
207
+
208
+ const conditionalType = (0, _typeFromAST.typeFromAST)(
209
+ schema,
210
+ typeConditionNode,
211
+ );
212
+
213
+ if (conditionalType === type) {
214
+ return true;
215
+ }
216
+
217
+ if ((0, _definition.isAbstractType)(conditionalType)) {
218
+ return schema.isSubType(conditionalType, type);
219
+ }
220
+
221
+ return false;
222
+ }
223
+ /**
224
+ * Implements the logic to compute the key of a given field's entry
225
+ */
226
+
227
+ function getFieldEntryKey(node) {
228
+ return node.alias ? node.alias.value : node.name.value;
229
+ }
@@ -0,0 +1,213 @@
1
+ import { Kind } from '../language/kinds.mjs';
2
+ import { isAbstractType } from '../type/definition.mjs';
3
+ import {
4
+ GraphQLIncludeDirective,
5
+ GraphQLSkipDirective,
6
+ } from '../type/directives.mjs';
7
+ import { typeFromAST } from '../utilities/typeFromAST.mjs';
8
+ import { getDirectiveValues } from './values.mjs';
9
+ /**
10
+ * Given a selectionSet, collects all of the fields and returns them.
11
+ *
12
+ * CollectFields requires the "runtime type" of an object. For a field that
13
+ * returns an Interface or Union type, the "runtime type" will be the actual
14
+ * object type returned by that field.
15
+ *
16
+ * @internal
17
+ */
18
+
19
+ export function collectFields(
20
+ schema,
21
+ fragments,
22
+ variableValues,
23
+ runtimeType,
24
+ selectionSet,
25
+ ) {
26
+ const fields = new Map();
27
+ collectFieldsImpl(
28
+ schema,
29
+ fragments,
30
+ variableValues,
31
+ runtimeType,
32
+ selectionSet,
33
+ fields,
34
+ new Set(),
35
+ );
36
+ return fields;
37
+ }
38
+ /**
39
+ * Given an array of field nodes, collects all of the subfields of the passed
40
+ * in fields, and returns them at the end.
41
+ *
42
+ * CollectSubFields requires the "return type" of an object. For a field that
43
+ * returns an Interface or Union type, the "return type" will be the actual
44
+ * object type returned by that field.
45
+ *
46
+ * @internal
47
+ */
48
+
49
+ export function collectSubfields(
50
+ schema,
51
+ fragments,
52
+ variableValues,
53
+ returnType,
54
+ fieldNodes,
55
+ ) {
56
+ const subFieldNodes = new Map();
57
+ const visitedFragmentNames = new Set();
58
+
59
+ for (const node of fieldNodes) {
60
+ if (node.selectionSet) {
61
+ collectFieldsImpl(
62
+ schema,
63
+ fragments,
64
+ variableValues,
65
+ returnType,
66
+ node.selectionSet,
67
+ subFieldNodes,
68
+ visitedFragmentNames,
69
+ );
70
+ }
71
+ }
72
+
73
+ return subFieldNodes;
74
+ }
75
+
76
+ function collectFieldsImpl(
77
+ schema,
78
+ fragments,
79
+ variableValues,
80
+ runtimeType,
81
+ selectionSet,
82
+ fields,
83
+ visitedFragmentNames,
84
+ ) {
85
+ for (const selection of selectionSet.selections) {
86
+ switch (selection.kind) {
87
+ case Kind.FIELD: {
88
+ if (!shouldIncludeNode(variableValues, selection)) {
89
+ continue;
90
+ }
91
+
92
+ const name = getFieldEntryKey(selection);
93
+ const fieldList = fields.get(name);
94
+
95
+ if (fieldList !== undefined) {
96
+ fieldList.push(selection);
97
+ } else {
98
+ fields.set(name, [selection]);
99
+ }
100
+
101
+ break;
102
+ }
103
+
104
+ case Kind.INLINE_FRAGMENT: {
105
+ if (
106
+ !shouldIncludeNode(variableValues, selection) ||
107
+ !doesFragmentConditionMatch(schema, selection, runtimeType)
108
+ ) {
109
+ continue;
110
+ }
111
+
112
+ collectFieldsImpl(
113
+ schema,
114
+ fragments,
115
+ variableValues,
116
+ runtimeType,
117
+ selection.selectionSet,
118
+ fields,
119
+ visitedFragmentNames,
120
+ );
121
+ break;
122
+ }
123
+
124
+ case Kind.FRAGMENT_SPREAD: {
125
+ const fragName = selection.name.value;
126
+
127
+ if (
128
+ visitedFragmentNames.has(fragName) ||
129
+ !shouldIncludeNode(variableValues, selection)
130
+ ) {
131
+ continue;
132
+ }
133
+
134
+ visitedFragmentNames.add(fragName);
135
+ const fragment = fragments[fragName];
136
+
137
+ if (
138
+ !fragment ||
139
+ !doesFragmentConditionMatch(schema, fragment, runtimeType)
140
+ ) {
141
+ continue;
142
+ }
143
+
144
+ collectFieldsImpl(
145
+ schema,
146
+ fragments,
147
+ variableValues,
148
+ runtimeType,
149
+ fragment.selectionSet,
150
+ fields,
151
+ visitedFragmentNames,
152
+ );
153
+ break;
154
+ }
155
+ }
156
+ }
157
+ }
158
+ /**
159
+ * Determines if a field should be included based on the `@include` and `@skip`
160
+ * directives, where `@skip` has higher precedence than `@include`.
161
+ */
162
+
163
+ function shouldIncludeNode(variableValues, node) {
164
+ const skip = getDirectiveValues(GraphQLSkipDirective, node, variableValues);
165
+
166
+ if ((skip === null || skip === void 0 ? void 0 : skip.if) === true) {
167
+ return false;
168
+ }
169
+
170
+ const include = getDirectiveValues(
171
+ GraphQLIncludeDirective,
172
+ node,
173
+ variableValues,
174
+ );
175
+
176
+ if (
177
+ (include === null || include === void 0 ? void 0 : include.if) === false
178
+ ) {
179
+ return false;
180
+ }
181
+
182
+ return true;
183
+ }
184
+ /**
185
+ * Determines if a fragment is applicable to the given type.
186
+ */
187
+
188
+ function doesFragmentConditionMatch(schema, fragment, type) {
189
+ const typeConditionNode = fragment.typeCondition;
190
+
191
+ if (!typeConditionNode) {
192
+ return true;
193
+ }
194
+
195
+ const conditionalType = typeFromAST(schema, typeConditionNode);
196
+
197
+ if (conditionalType === type) {
198
+ return true;
199
+ }
200
+
201
+ if (isAbstractType(conditionalType)) {
202
+ return schema.isSubType(conditionalType, type);
203
+ }
204
+
205
+ return false;
206
+ }
207
+ /**
208
+ * Implements the logic to compute the key of a given field's entry
209
+ */
210
+
211
+ function getFieldEntryKey(node) {
212
+ return node.alias ? node.alias.value : node.name.value;
213
+ }
@@ -0,0 +1,185 @@
1
+ import type { Maybe } from '../jsutils/Maybe';
2
+ import type { ObjMap } from '../jsutils/ObjMap';
3
+ import type { Path } from '../jsutils/Path';
4
+ import type { PromiseOrValue } from '../jsutils/PromiseOrValue';
5
+ import type { GraphQLFormattedError } from '../error/GraphQLError';
6
+ import { GraphQLError } from '../error/GraphQLError';
7
+ import type {
8
+ DocumentNode,
9
+ FieldNode,
10
+ FragmentDefinitionNode,
11
+ OperationDefinitionNode,
12
+ } from '../language/ast';
13
+ import type {
14
+ GraphQLField,
15
+ GraphQLFieldResolver,
16
+ GraphQLObjectType,
17
+ GraphQLResolveInfo,
18
+ GraphQLTypeResolver,
19
+ } from '../type/definition';
20
+ import type { GraphQLSchema } from '../type/schema';
21
+ /**
22
+ * Terminology
23
+ *
24
+ * "Definitions" are the generic name for top-level statements in the document.
25
+ * Examples of this include:
26
+ * 1) Operations (such as a query)
27
+ * 2) Fragments
28
+ *
29
+ * "Operations" are a generic name for requests in the document.
30
+ * Examples of this include:
31
+ * 1) query,
32
+ * 2) mutation
33
+ *
34
+ * "Selections" are the definitions that can appear legally and at
35
+ * single level of the query. These include:
36
+ * 1) field references e.g `a`
37
+ * 2) fragment "spreads" e.g. `...c`
38
+ * 3) inline fragment "spreads" e.g. `...on Type { a }`
39
+ */
40
+ /**
41
+ * Data that must be available at all points during query execution.
42
+ *
43
+ * Namely, schema of the type system that is currently executing,
44
+ * and the fragments defined in the query document
45
+ */
46
+ export interface ExecutionContext {
47
+ schema: GraphQLSchema;
48
+ fragments: ObjMap<FragmentDefinitionNode>;
49
+ rootValue: unknown;
50
+ contextValue: unknown;
51
+ operation: OperationDefinitionNode;
52
+ variableValues: {
53
+ [variable: string]: unknown;
54
+ };
55
+ fieldResolver: GraphQLFieldResolver<any, any>;
56
+ typeResolver: GraphQLTypeResolver<any, any>;
57
+ subscribeFieldResolver: GraphQLFieldResolver<any, any>;
58
+ errors: Array<GraphQLError>;
59
+ }
60
+ /**
61
+ * The result of GraphQL execution.
62
+ *
63
+ * - `errors` is included when any errors occurred as a non-empty array.
64
+ * - `data` is the result of a successful execution of the query.
65
+ * - `extensions` is reserved for adding non-standard properties.
66
+ */
67
+ export interface ExecutionResult<
68
+ TData = ObjMap<unknown>,
69
+ TExtensions = ObjMap<unknown>,
70
+ > {
71
+ errors?: ReadonlyArray<GraphQLError>;
72
+ data?: TData | null;
73
+ extensions?: TExtensions;
74
+ }
75
+ export interface FormattedExecutionResult<
76
+ TData = ObjMap<unknown>,
77
+ TExtensions = ObjMap<unknown>,
78
+ > {
79
+ errors?: ReadonlyArray<GraphQLFormattedError>;
80
+ data?: TData | null;
81
+ extensions?: TExtensions;
82
+ }
83
+ export interface ExecutionArgs {
84
+ schema: GraphQLSchema;
85
+ document: DocumentNode;
86
+ rootValue?: unknown;
87
+ contextValue?: unknown;
88
+ variableValues?: Maybe<{
89
+ readonly [variable: string]: unknown;
90
+ }>;
91
+ operationName?: Maybe<string>;
92
+ fieldResolver?: Maybe<GraphQLFieldResolver<any, any>>;
93
+ typeResolver?: Maybe<GraphQLTypeResolver<any, any>>;
94
+ subscribeFieldResolver?: Maybe<GraphQLFieldResolver<any, any>>;
95
+ }
96
+ /**
97
+ * Implements the "Executing requests" section of the GraphQL specification.
98
+ *
99
+ * Returns either a synchronous ExecutionResult (if all encountered resolvers
100
+ * are synchronous), or a Promise of an ExecutionResult that will eventually be
101
+ * resolved and never rejected.
102
+ *
103
+ * If the arguments to this function do not result in a legal execution context,
104
+ * a GraphQLError will be thrown immediately explaining the invalid input.
105
+ */
106
+ export declare function execute(
107
+ args: ExecutionArgs,
108
+ ): PromiseOrValue<ExecutionResult>;
109
+ /**
110
+ * Also implements the "Executing requests" section of the GraphQL specification.
111
+ * However, it guarantees to complete synchronously (or throw an error) assuming
112
+ * that all field resolvers are also synchronous.
113
+ */
114
+ export declare function executeSync(args: ExecutionArgs): ExecutionResult;
115
+ /**
116
+ * Essential assertions before executing to provide developer feedback for
117
+ * improper use of the GraphQL library.
118
+ *
119
+ * @internal
120
+ */
121
+ export declare function assertValidExecutionArguments(
122
+ schema: GraphQLSchema,
123
+ document: DocumentNode,
124
+ rawVariableValues: Maybe<{
125
+ readonly [variable: string]: unknown;
126
+ }>,
127
+ ): void;
128
+ /**
129
+ * Constructs a ExecutionContext object from the arguments passed to
130
+ * execute, which we will pass throughout the other execution methods.
131
+ *
132
+ * Throws a GraphQLError if a valid execution context cannot be created.
133
+ *
134
+ * @internal
135
+ */
136
+ export declare function buildExecutionContext(
137
+ args: ExecutionArgs,
138
+ ): ReadonlyArray<GraphQLError> | ExecutionContext;
139
+ /**
140
+ * @internal
141
+ */
142
+ export declare function buildResolveInfo(
143
+ exeContext: ExecutionContext,
144
+ fieldDef: GraphQLField<unknown, unknown>,
145
+ fieldNodes: ReadonlyArray<FieldNode>,
146
+ parentType: GraphQLObjectType,
147
+ path: Path,
148
+ ): GraphQLResolveInfo;
149
+ /**
150
+ * If a resolveType function is not given, then a default resolve behavior is
151
+ * used which attempts two strategies:
152
+ *
153
+ * First, See if the provided value has a `__typename` field defined, if so, use
154
+ * that value as name of the resolved type.
155
+ *
156
+ * Otherwise, test each possible type for the abstract type by calling
157
+ * isTypeOf for the object being coerced, returning the first type that matches.
158
+ */
159
+ export declare const defaultTypeResolver: GraphQLTypeResolver<unknown, unknown>;
160
+ /**
161
+ * If a resolve function is not given, then a default resolve behavior is used
162
+ * which takes the property of the source object of the same name as the field
163
+ * and returns it as the result, or if it's a function, returns the result
164
+ * of calling that function while passing along args and context value.
165
+ */
166
+ export declare const defaultFieldResolver: GraphQLFieldResolver<
167
+ unknown,
168
+ unknown
169
+ >;
170
+ /**
171
+ * This method looks up the field on the given type definition.
172
+ * It has special casing for the three introspection fields,
173
+ * __schema, __type and __typename. __typename is special because
174
+ * it can always be queried as a field, even in situations where no
175
+ * other fields are allowed, like on a Union. __schema and __type
176
+ * could get automatically added to the query type, but that would
177
+ * require mutating type definitions, which would cause issues.
178
+ *
179
+ * @internal
180
+ */
181
+ export declare function getFieldDef(
182
+ schema: GraphQLSchema,
183
+ parentType: GraphQLObjectType,
184
+ fieldNode: FieldNode,
185
+ ): Maybe<GraphQLField<unknown, unknown>>;