@graphql-eslint/eslint-plugin 4.0.0-alpha-20220821140530-e968cfc → 4.0.0-alpha-20230810155929-e89edf7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (346) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +14 -252
  3. package/cjs/cache.d.ts +12 -0
  4. package/cjs/cache.js +53 -0
  5. package/cjs/configs/index.d.ts +174 -0
  6. package/cjs/configs/index.js +40 -0
  7. package/cjs/configs/operations-all.d.ts +23 -0
  8. package/cjs/configs/operations-all.js +28 -0
  9. package/cjs/configs/operations-recommended.d.ts +54 -0
  10. package/{configs/operations-recommended.json → cjs/configs/operations-recommended.js} +19 -15
  11. package/cjs/configs/schema-all.d.ts +24 -0
  12. package/cjs/configs/schema-all.js +24 -0
  13. package/cjs/configs/schema-recommended.d.ts +67 -0
  14. package/cjs/configs/schema-recommended.js +68 -0
  15. package/cjs/configs/schema-relay.d.ts +12 -0
  16. package/{configs/relay.json → cjs/configs/schema-relay.js} +6 -4
  17. package/cjs/documents.d.ts +6 -0
  18. package/cjs/documents.js +66 -0
  19. package/cjs/estree-converter/converter.d.ts +8 -0
  20. package/cjs/estree-converter/converter.js +70 -0
  21. package/cjs/estree-converter/index.d.ts +8 -0
  22. package/cjs/estree-converter/index.js +23 -0
  23. package/cjs/estree-converter/types.d.ts +42 -0
  24. package/cjs/estree-converter/types.js +14 -0
  25. package/cjs/estree-converter/utils.d.ts +17 -0
  26. package/cjs/estree-converter/utils.js +105 -0
  27. package/cjs/flat-configs.d.ts +307 -0
  28. package/cjs/flat-configs.js +55 -0
  29. package/cjs/graphql-config.d.ts +14 -0
  30. package/cjs/graphql-config.js +65 -0
  31. package/cjs/index.d.ts +28 -0
  32. package/cjs/index.js +41 -0
  33. package/cjs/parser.d.ts +13 -0
  34. package/cjs/parser.js +96 -0
  35. package/cjs/processor.d.ts +13 -0
  36. package/cjs/processor.js +95 -0
  37. package/cjs/rules/alphabetize.d.ts +74 -0
  38. package/cjs/rules/alphabetize.js +323 -0
  39. package/cjs/rules/description-style.d.ts +29 -0
  40. package/cjs/rules/description-style.js +102 -0
  41. package/cjs/rules/graphql-js-validation.d.ts +13 -0
  42. package/cjs/rules/graphql-js-validation.js +595 -0
  43. package/cjs/rules/index.d.ts +127 -0
  44. package/cjs/rules/index.js +62 -0
  45. package/cjs/rules/input-name.d.ts +44 -0
  46. package/cjs/rules/input-name.js +154 -0
  47. package/cjs/rules/lone-executable-definition.d.ts +35 -0
  48. package/cjs/rules/lone-executable-definition.js +105 -0
  49. package/cjs/rules/match-document-filename.d.ts +81 -0
  50. package/cjs/rules/match-document-filename.js +251 -0
  51. package/cjs/rules/naming-convention.d.ts +108 -0
  52. package/cjs/rules/naming-convention.js +416 -0
  53. package/cjs/rules/no-anonymous-operations.d.ts +13 -0
  54. package/cjs/rules/no-anonymous-operations.js +91 -0
  55. package/cjs/rules/no-deprecated.d.ts +13 -0
  56. package/cjs/rules/no-deprecated.js +143 -0
  57. package/cjs/rules/no-duplicate-fields.d.ts +13 -0
  58. package/cjs/rules/no-duplicate-fields.js +136 -0
  59. package/cjs/rules/no-hashtag-description.d.ts +14 -0
  60. package/cjs/rules/no-hashtag-description.js +127 -0
  61. package/cjs/rules/no-one-place-fragments.d.ts +13 -0
  62. package/cjs/rules/no-one-place-fragments.js +101 -0
  63. package/cjs/rules/no-root-type.d.ts +34 -0
  64. package/cjs/rules/no-root-type.js +103 -0
  65. package/cjs/rules/no-scalar-result-type-on-mutation.d.ts +13 -0
  66. package/cjs/rules/no-scalar-result-type-on-mutation.js +88 -0
  67. package/cjs/rules/no-typename-prefix.d.ts +13 -0
  68. package/cjs/rules/no-typename-prefix.js +91 -0
  69. package/cjs/rules/no-unreachable-types.d.ts +13 -0
  70. package/cjs/rules/no-unreachable-types.js +177 -0
  71. package/cjs/rules/no-unused-fields.d.ts +13 -0
  72. package/cjs/rules/no-unused-fields.js +132 -0
  73. package/cjs/rules/relay-arguments.d.ts +30 -0
  74. package/cjs/rules/relay-arguments.js +126 -0
  75. package/cjs/rules/relay-connection-types.d.ts +14 -0
  76. package/cjs/rules/relay-connection-types.js +111 -0
  77. package/cjs/rules/relay-edge-types.d.ts +40 -0
  78. package/cjs/rules/relay-edge-types.js +161 -0
  79. package/cjs/rules/relay-page-info.d.ts +13 -0
  80. package/cjs/rules/relay-page-info.js +98 -0
  81. package/cjs/rules/require-deprecation-date.d.ts +27 -0
  82. package/cjs/rules/require-deprecation-date.js +148 -0
  83. package/cjs/rules/require-deprecation-reason.d.ts +13 -0
  84. package/cjs/rules/require-deprecation-reason.js +85 -0
  85. package/cjs/rules/require-description.d.ts +24 -0
  86. package/cjs/rules/require-description.js +179 -0
  87. package/cjs/rules/require-field-of-type-query-in-mutation-result.d.ts +13 -0
  88. package/cjs/rules/require-field-of-type-query-in-mutation-result.js +87 -0
  89. package/cjs/rules/require-import-fragment.d.ts +13 -0
  90. package/cjs/rules/require-import-fragment.js +148 -0
  91. package/cjs/rules/require-nullable-fields-with-oneof.d.ts +13 -0
  92. package/cjs/rules/require-nullable-fields-with-oneof.js +81 -0
  93. package/cjs/rules/require-nullable-result-in-root.d.ts +13 -0
  94. package/cjs/rules/require-nullable-result-in-root.js +99 -0
  95. package/cjs/rules/require-selections.d.ts +45 -0
  96. package/cjs/rules/require-selections.js +198 -0
  97. package/cjs/rules/require-type-pattern-with-oneof.d.ts +13 -0
  98. package/cjs/rules/require-type-pattern-with-oneof.js +83 -0
  99. package/cjs/rules/selection-set-depth.d.ts +37 -0
  100. package/cjs/rules/selection-set-depth.js +159 -0
  101. package/cjs/rules/strict-id-in-types.d.ts +66 -0
  102. package/cjs/rules/strict-id-in-types.js +168 -0
  103. package/cjs/rules/unique-enum-value-names.d.ts +13 -0
  104. package/cjs/rules/unique-enum-value-names.js +91 -0
  105. package/cjs/rules/unique-fragment-name.d.ts +14 -0
  106. package/cjs/rules/unique-fragment-name.js +106 -0
  107. package/cjs/rules/unique-operation-name.d.ts +13 -0
  108. package/cjs/rules/unique-operation-name.js +93 -0
  109. package/cjs/schema.d.ts +13 -0
  110. package/cjs/schema.js +52 -0
  111. package/{sibling-operations.d.ts → cjs/siblings.d.ts} +9 -6
  112. package/cjs/siblings.js +96 -0
  113. package/cjs/types.d.ts +75 -0
  114. package/cjs/types.js +14 -0
  115. package/cjs/utils.d.ts +45 -0
  116. package/cjs/utils.js +188 -0
  117. package/esm/cache.d.mts +12 -0
  118. package/esm/cache.js +25 -0
  119. package/esm/chunk-U3TKCM4X.js +8 -0
  120. package/esm/configs/index.d.mts +174 -0
  121. package/esm/configs/index.js +16 -0
  122. package/esm/configs/operations-all.d.mts +23 -0
  123. package/esm/configs/operations-all.js +35 -0
  124. package/esm/configs/operations-recommended.d.mts +54 -0
  125. package/esm/configs/operations-recommended.js +61 -0
  126. package/esm/configs/schema-all.d.mts +24 -0
  127. package/esm/configs/schema-all.js +31 -0
  128. package/esm/configs/schema-recommended.d.mts +67 -0
  129. package/esm/configs/schema-recommended.js +75 -0
  130. package/esm/configs/schema-relay.d.mts +12 -0
  131. package/esm/configs/schema-relay.js +18 -0
  132. package/esm/documents.d.mts +6 -0
  133. package/esm/documents.js +41 -0
  134. package/esm/estree-converter/converter.d.mts +8 -0
  135. package/esm/estree-converter/converter.js +56 -0
  136. package/esm/estree-converter/index.d.mts +8 -0
  137. package/esm/estree-converter/index.js +3 -0
  138. package/esm/estree-converter/types.d.mts +42 -0
  139. package/esm/estree-converter/types.js +0 -0
  140. package/esm/estree-converter/utils.d.mts +17 -0
  141. package/esm/estree-converter/utils.js +87 -0
  142. package/esm/flat-configs.d.mts +307 -0
  143. package/esm/flat-configs.js +36 -0
  144. package/esm/graphql-config.d.mts +14 -0
  145. package/esm/graphql-config.js +39 -0
  146. package/esm/index.d.mts +28 -0
  147. package/esm/index.js +18 -0
  148. package/esm/package.json +1 -0
  149. package/esm/parser.d.mts +13 -0
  150. package/esm/parser.js +76 -0
  151. package/esm/processor.d.mts +13 -0
  152. package/esm/processor.js +81 -0
  153. package/esm/rules/alphabetize.d.mts +74 -0
  154. package/esm/rules/alphabetize.js +299 -0
  155. package/esm/rules/description-style.d.mts +29 -0
  156. package/esm/rules/description-style.js +82 -0
  157. package/esm/rules/graphql-js-validation.d.mts +13 -0
  158. package/esm/rules/graphql-js-validation.js +618 -0
  159. package/esm/rules/index.d.mts +127 -0
  160. package/esm/rules/index.js +76 -0
  161. package/esm/rules/input-name.d.mts +44 -0
  162. package/esm/rules/input-name.js +136 -0
  163. package/esm/rules/lone-executable-definition.d.mts +35 -0
  164. package/esm/rules/lone-executable-definition.js +86 -0
  165. package/esm/rules/match-document-filename.d.mts +81 -0
  166. package/esm/rules/match-document-filename.js +237 -0
  167. package/esm/rules/naming-convention.d.mts +108 -0
  168. package/esm/rules/naming-convention.js +403 -0
  169. package/esm/rules/no-anonymous-operations.d.mts +13 -0
  170. package/esm/rules/no-anonymous-operations.js +72 -0
  171. package/esm/rules/no-deprecated.d.mts +13 -0
  172. package/esm/rules/no-deprecated.js +124 -0
  173. package/esm/rules/no-duplicate-fields.d.mts +13 -0
  174. package/esm/rules/no-duplicate-fields.js +116 -0
  175. package/esm/rules/no-hashtag-description.d.mts +14 -0
  176. package/esm/rules/no-hashtag-description.js +107 -0
  177. package/esm/rules/no-one-place-fragments.d.mts +13 -0
  178. package/esm/rules/no-one-place-fragments.js +83 -0
  179. package/esm/rules/no-root-type.d.mts +34 -0
  180. package/esm/rules/no-root-type.js +83 -0
  181. package/esm/rules/no-scalar-result-type-on-mutation.d.mts +13 -0
  182. package/esm/rules/no-scalar-result-type-on-mutation.js +69 -0
  183. package/esm/rules/no-typename-prefix.d.mts +13 -0
  184. package/esm/rules/no-typename-prefix.js +71 -0
  185. package/esm/rules/no-unreachable-types.d.mts +13 -0
  186. package/esm/rules/no-unreachable-types.js +156 -0
  187. package/esm/rules/no-unused-fields.d.mts +13 -0
  188. package/esm/rules/no-unused-fields.js +113 -0
  189. package/esm/rules/relay-arguments.d.mts +30 -0
  190. package/esm/rules/relay-arguments.js +107 -0
  191. package/esm/rules/relay-connection-types.d.mts +14 -0
  192. package/esm/rules/relay-connection-types.js +90 -0
  193. package/esm/rules/relay-edge-types.d.mts +40 -0
  194. package/esm/rules/relay-edge-types.js +148 -0
  195. package/esm/rules/relay-page-info.d.mts +13 -0
  196. package/esm/rules/relay-page-info.js +80 -0
  197. package/esm/rules/require-deprecation-date.d.mts +27 -0
  198. package/esm/rules/require-deprecation-date.js +129 -0
  199. package/esm/rules/require-deprecation-reason.d.mts +13 -0
  200. package/esm/rules/require-deprecation-reason.js +66 -0
  201. package/esm/rules/require-description.d.mts +24 -0
  202. package/esm/rules/require-description.js +165 -0
  203. package/esm/rules/require-field-of-type-query-in-mutation-result.d.mts +13 -0
  204. package/esm/rules/require-field-of-type-query-in-mutation-result.js +68 -0
  205. package/esm/rules/require-import-fragment.d.mts +13 -0
  206. package/esm/rules/require-import-fragment.js +121 -0
  207. package/esm/rules/require-nullable-fields-with-oneof.d.mts +13 -0
  208. package/esm/rules/require-nullable-fields-with-oneof.js +62 -0
  209. package/esm/rules/require-nullable-result-in-root.d.mts +13 -0
  210. package/esm/rules/require-nullable-result-in-root.js +80 -0
  211. package/esm/rules/require-selections.d.mts +45 -0
  212. package/esm/rules/require-selections.js +194 -0
  213. package/esm/rules/require-type-pattern-with-oneof.d.mts +13 -0
  214. package/esm/rules/require-type-pattern-with-oneof.js +63 -0
  215. package/esm/rules/selection-set-depth.d.mts +37 -0
  216. package/esm/rules/selection-set-depth.js +133 -0
  217. package/esm/rules/strict-id-in-types.d.mts +66 -0
  218. package/esm/rules/strict-id-in-types.js +155 -0
  219. package/esm/rules/unique-enum-value-names.d.mts +13 -0
  220. package/esm/rules/unique-enum-value-names.js +72 -0
  221. package/esm/rules/unique-fragment-name.d.mts +14 -0
  222. package/esm/rules/unique-fragment-name.js +87 -0
  223. package/esm/rules/unique-operation-name.d.mts +13 -0
  224. package/esm/rules/unique-operation-name.js +73 -0
  225. package/esm/schema.d.mts +13 -0
  226. package/esm/schema.js +27 -0
  227. package/esm/siblings.d.mts +24 -0
  228. package/esm/siblings.js +80 -0
  229. package/esm/types.d.mts +75 -0
  230. package/esm/types.js +0 -0
  231. package/esm/utils.d.mts +45 -0
  232. package/esm/utils.js +144 -0
  233. package/index.browser.mjs +5323 -0
  234. package/package.json +43 -35
  235. package/configs/base.json +0 -4
  236. package/configs/operations-all.json +0 -24
  237. package/configs/schema-all.json +0 -26
  238. package/configs/schema-recommended.json +0 -49
  239. package/docs/README.md +0 -75
  240. package/docs/custom-rules.md +0 -148
  241. package/docs/deprecated-rules.md +0 -21
  242. package/docs/parser-options.md +0 -85
  243. package/docs/parser.md +0 -49
  244. package/docs/rules/alphabetize.md +0 -178
  245. package/docs/rules/description-style.md +0 -54
  246. package/docs/rules/executable-definitions.md +0 -17
  247. package/docs/rules/fields-on-correct-type.md +0 -17
  248. package/docs/rules/fragments-on-composite-type.md +0 -17
  249. package/docs/rules/input-name.md +0 -76
  250. package/docs/rules/known-argument-names.md +0 -17
  251. package/docs/rules/known-directives.md +0 -44
  252. package/docs/rules/known-fragment-names.md +0 -69
  253. package/docs/rules/known-type-names.md +0 -17
  254. package/docs/rules/lone-anonymous-operation.md +0 -17
  255. package/docs/rules/lone-schema-definition.md +0 -17
  256. package/docs/rules/match-document-filename.md +0 -156
  257. package/docs/rules/naming-convention.md +0 -300
  258. package/docs/rules/no-anonymous-operations.md +0 -39
  259. package/docs/rules/no-case-insensitive-enum-values-duplicates.md +0 -43
  260. package/docs/rules/no-deprecated.md +0 -85
  261. package/docs/rules/no-duplicate-fields.md +0 -65
  262. package/docs/rules/no-fragment-cycles.md +0 -17
  263. package/docs/rules/no-hashtag-description.md +0 -59
  264. package/docs/rules/no-root-type.md +0 -53
  265. package/docs/rules/no-scalar-result-type-on-mutation.md +0 -37
  266. package/docs/rules/no-typename-prefix.md +0 -39
  267. package/docs/rules/no-undefined-variables.md +0 -17
  268. package/docs/rules/no-unreachable-types.md +0 -49
  269. package/docs/rules/no-unused-fields.md +0 -62
  270. package/docs/rules/no-unused-fragments.md +0 -17
  271. package/docs/rules/no-unused-variables.md +0 -17
  272. package/docs/rules/one-field-subscriptions.md +0 -17
  273. package/docs/rules/overlapping-fields-can-be-merged.md +0 -17
  274. package/docs/rules/possible-fragment-spread.md +0 -17
  275. package/docs/rules/possible-type-extension.md +0 -15
  276. package/docs/rules/provided-required-arguments.md +0 -17
  277. package/docs/rules/relay-arguments.md +0 -57
  278. package/docs/rules/relay-connection-types.md +0 -42
  279. package/docs/rules/relay-edge-types.md +0 -56
  280. package/docs/rules/relay-page-info.md +0 -32
  281. package/docs/rules/require-deprecation-date.md +0 -56
  282. package/docs/rules/require-deprecation-reason.md +0 -47
  283. package/docs/rules/require-description.md +0 -115
  284. package/docs/rules/require-field-of-type-query-in-mutation-result.md +0 -47
  285. package/docs/rules/require-id-when-available.md +0 -88
  286. package/docs/rules/scalar-leafs.md +0 -17
  287. package/docs/rules/selection-set-depth.md +0 -76
  288. package/docs/rules/strict-id-in-types.md +0 -130
  289. package/docs/rules/unique-argument-names.md +0 -17
  290. package/docs/rules/unique-directive-names-per-location.md +0 -17
  291. package/docs/rules/unique-directive-names.md +0 -17
  292. package/docs/rules/unique-enum-value-names.md +0 -15
  293. package/docs/rules/unique-field-definition-names.md +0 -17
  294. package/docs/rules/unique-fragment-name.md +0 -51
  295. package/docs/rules/unique-input-field-names.md +0 -17
  296. package/docs/rules/unique-operation-name.md +0 -55
  297. package/docs/rules/unique-operation-types.md +0 -17
  298. package/docs/rules/unique-type-names.md +0 -17
  299. package/docs/rules/unique-variable-names.md +0 -17
  300. package/docs/rules/value-literals-of-correct-type.md +0 -17
  301. package/docs/rules/variables-are-input-types.md +0 -17
  302. package/docs/rules/variables-in-allowed-position.md +0 -17
  303. package/estree-converter/converter.d.ts +0 -3
  304. package/estree-converter/index.d.ts +0 -3
  305. package/estree-converter/types.d.ts +0 -40
  306. package/estree-converter/utils.d.ts +0 -13
  307. package/graphql-config.d.ts +0 -3
  308. package/index.d.ts +0 -16
  309. package/index.js +0 -4653
  310. package/index.mjs +0 -4641
  311. package/parser.d.ts +0 -2
  312. package/processor.d.ts +0 -7
  313. package/rules/alphabetize.d.ts +0 -16
  314. package/rules/description-style.d.ts +0 -6
  315. package/rules/graphql-js-validation.d.ts +0 -2
  316. package/rules/index.d.ts +0 -41
  317. package/rules/input-name.d.ts +0 -9
  318. package/rules/match-document-filename.d.ts +0 -18
  319. package/rules/naming-convention.d.ts +0 -37
  320. package/rules/no-anonymous-operations.d.ts +0 -3
  321. package/rules/no-case-insensitive-enum-values-duplicates.d.ts +0 -3
  322. package/rules/no-deprecated.d.ts +0 -3
  323. package/rules/no-duplicate-fields.d.ts +0 -3
  324. package/rules/no-hashtag-description.d.ts +0 -3
  325. package/rules/no-root-type.d.ts +0 -7
  326. package/rules/no-scalar-result-type-on-mutation.d.ts +0 -3
  327. package/rules/no-typename-prefix.d.ts +0 -3
  328. package/rules/no-unreachable-types.d.ts +0 -3
  329. package/rules/no-unused-fields.d.ts +0 -3
  330. package/rules/relay-arguments.d.ts +0 -6
  331. package/rules/relay-connection-types.d.ts +0 -5
  332. package/rules/relay-edge-types.d.ts +0 -8
  333. package/rules/relay-page-info.d.ts +0 -3
  334. package/rules/require-deprecation-date.d.ts +0 -5
  335. package/rules/require-deprecation-reason.d.ts +0 -3
  336. package/rules/require-description.d.ts +0 -11
  337. package/rules/require-field-of-type-query-in-mutation-result.d.ts +0 -3
  338. package/rules/require-id-when-available.d.ts +0 -6
  339. package/rules/selection-set-depth.d.ts +0 -7
  340. package/rules/strict-id-in-types.d.ts +0 -11
  341. package/rules/unique-fragment-name.d.ts +0 -6
  342. package/rules/unique-operation-name.d.ts +0 -3
  343. package/schema.d.ts +0 -3
  344. package/testkit.d.ts +0 -27
  345. package/types.d.ts +0 -79
  346. package/utils.d.ts +0 -39
@@ -0,0 +1,68 @@
1
+ import "../chunk-U3TKCM4X.js";
2
+ import { isObjectType } from "graphql";
3
+ import { getTypeName, requireGraphQLSchemaFromContext } from "../utils.js";
4
+ const RULE_ID = "require-field-of-type-query-in-mutation-result", rule = {
5
+ meta: {
6
+ type: "suggestion",
7
+ docs: {
8
+ category: "Schema",
9
+ description: "Allow the client in one round-trip not only to call mutation but also to get a wagon of data to update their application.\n> Currently, no errors are reported for result type `union`, `interface` and `scalar`.",
10
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
11
+ requiresSchema: !0,
12
+ examples: [
13
+ {
14
+ title: "Incorrect",
15
+ code: (
16
+ /* GraphQL */
17
+ `
18
+ type User { ... }
19
+
20
+ type Mutation {
21
+ createUser: User!
22
+ }
23
+ `
24
+ )
25
+ },
26
+ {
27
+ title: "Correct",
28
+ code: (
29
+ /* GraphQL */
30
+ `
31
+ type User { ... }
32
+
33
+ type Query { ... }
34
+
35
+ type CreateUserPayload {
36
+ user: User!
37
+ query: Query!
38
+ }
39
+
40
+ type Mutation {
41
+ createUser: CreateUserPayload!
42
+ }
43
+ `
44
+ )
45
+ }
46
+ ]
47
+ },
48
+ schema: []
49
+ },
50
+ create(context) {
51
+ const schema = requireGraphQLSchemaFromContext(RULE_ID, context), mutationType = schema.getMutationType(), queryType = schema.getQueryType();
52
+ return !mutationType || !queryType ? {} : {
53
+ [`:matches(ObjectTypeDefinition, ObjectTypeExtension)[name.value=${mutationType.name}] > FieldDefinition > .gqlType Name`](node) {
54
+ const typeName = node.value, graphQLType = schema.getType(typeName);
55
+ if (isObjectType(graphQLType)) {
56
+ const { fields } = graphQLType.astNode;
57
+ fields?.some((field) => getTypeName(field) === queryType.name) || context.report({
58
+ node,
59
+ message: `Mutation result type "${graphQLType.name}" must contain field of type "${queryType.name}"`
60
+ });
61
+ }
62
+ }
63
+ };
64
+ }
65
+ };
66
+ export {
67
+ rule
68
+ };
@@ -0,0 +1,13 @@
1
+ import { GraphQLESLintRule } from '../types.mjs';
2
+ import 'eslint';
3
+ import 'estree';
4
+ import 'graphql';
5
+ import 'json-schema-to-ts';
6
+ import '../siblings.mjs';
7
+ import '@graphql-tools/utils';
8
+ import '../estree-converter/types.mjs';
9
+ import 'graphql-config';
10
+
11
+ declare const rule: GraphQLESLintRule;
12
+
13
+ export { rule };
@@ -0,0 +1,121 @@
1
+ import "../chunk-U3TKCM4X.js";
2
+ import path from "node:path";
3
+ import { requireSiblingsOperations } from "../utils.js";
4
+ const RULE_ID = "require-import-fragment", SUGGESTION_ID = "add-import-expression", rule = {
5
+ meta: {
6
+ type: "suggestion",
7
+ docs: {
8
+ category: "Operations",
9
+ description: "Require fragments to be imported via an import expression.",
10
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
11
+ examples: [
12
+ {
13
+ title: "Incorrect",
14
+ code: (
15
+ /* GraphQL */
16
+ `
17
+ query {
18
+ user {
19
+ ...UserFields
20
+ }
21
+ }
22
+ `
23
+ )
24
+ },
25
+ {
26
+ title: "Incorrect",
27
+ code: (
28
+ /* GraphQL */
29
+ `
30
+ # import 'post-fields.fragment.graphql'
31
+ query {
32
+ user {
33
+ ...UserFields
34
+ }
35
+ }
36
+ `
37
+ )
38
+ },
39
+ {
40
+ title: "Incorrect",
41
+ code: (
42
+ /* GraphQL */
43
+ `
44
+ # import UserFields from 'post-fields.fragment.graphql'
45
+ query {
46
+ user {
47
+ ...UserFields
48
+ }
49
+ }
50
+ `
51
+ )
52
+ },
53
+ {
54
+ title: "Correct",
55
+ code: (
56
+ /* GraphQL */
57
+ `
58
+ # import UserFields from 'user-fields.fragment.graphql'
59
+ query {
60
+ user {
61
+ ...UserFields
62
+ }
63
+ }
64
+ `
65
+ )
66
+ }
67
+ ],
68
+ requiresSiblings: !0
69
+ },
70
+ hasSuggestions: !0,
71
+ messages: {
72
+ [RULE_ID]: 'Expected "{{fragmentName}}" fragment to be imported.',
73
+ [SUGGESTION_ID]: 'Add import expression for "{{fragmentName}}".'
74
+ },
75
+ schema: []
76
+ },
77
+ create(context) {
78
+ const comments = context.getSourceCode().getAllComments(), siblings = requireSiblingsOperations(RULE_ID, context), filePath = context.filename;
79
+ return {
80
+ "FragmentSpread > .name"(node) {
81
+ const fragmentName = node.value, fragmentsFromSiblings = siblings.getFragment(fragmentName);
82
+ for (const comment of comments) {
83
+ if (comment.type !== "Line" || !new RegExp(
84
+ `^\\s*import\\s+(${fragmentName}\\s+from\\s+)?['"]`
85
+ ).test(comment.value))
86
+ continue;
87
+ const extractedImportPath = comment.value.match(/(["'])((?:\1|.)*?)\1/)?.[2];
88
+ if (!extractedImportPath)
89
+ continue;
90
+ const importPath = path.join(path.dirname(filePath), extractedImportPath);
91
+ if (fragmentsFromSiblings.some(
92
+ (source) => source.filePath === importPath
93
+ ))
94
+ return;
95
+ }
96
+ if (fragmentsFromSiblings.some(
97
+ (source) => source.filePath === filePath
98
+ ))
99
+ return;
100
+ const suggestedFilePaths = fragmentsFromSiblings.length ? fragmentsFromSiblings.map((o) => path.relative(path.dirname(filePath), o.filePath)) : ["CHANGE_ME.graphql"];
101
+ context.report({
102
+ node,
103
+ messageId: RULE_ID,
104
+ data: { fragmentName },
105
+ suggest: suggestedFilePaths.map((suggestedPath) => ({
106
+ messageId: SUGGESTION_ID,
107
+ data: { fragmentName },
108
+ fix: (fixer) => fixer.insertTextBeforeRange(
109
+ [0, 0],
110
+ `# import ${fragmentName} from '${suggestedPath}'
111
+ `
112
+ )
113
+ }))
114
+ });
115
+ }
116
+ };
117
+ }
118
+ };
119
+ export {
120
+ rule
121
+ };
@@ -0,0 +1,13 @@
1
+ import { GraphQLESLintRule } from '../types.mjs';
2
+ import 'eslint';
3
+ import 'estree';
4
+ import 'graphql';
5
+ import 'json-schema-to-ts';
6
+ import '../siblings.mjs';
7
+ import '@graphql-tools/utils';
8
+ import '../estree-converter/types.mjs';
9
+ import 'graphql-config';
10
+
11
+ declare const rule: GraphQLESLintRule;
12
+
13
+ export { rule };
@@ -0,0 +1,62 @@
1
+ import "../chunk-U3TKCM4X.js";
2
+ import { Kind } from "graphql";
3
+ import { getNodeName } from "../utils.js";
4
+ const RULE_ID = "require-nullable-fields-with-oneof", rule = {
5
+ meta: {
6
+ type: "suggestion",
7
+ docs: {
8
+ category: "Schema",
9
+ description: "Require `input` or `type` fields to be non-nullable with `@oneOf` directive.",
10
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
11
+ examples: [
12
+ {
13
+ title: "Incorrect",
14
+ code: (
15
+ /* GraphQL */
16
+ `
17
+ input Input @oneOf {
18
+ foo: String!
19
+ b: Int
20
+ }
21
+ `
22
+ )
23
+ },
24
+ {
25
+ title: "Correct",
26
+ code: (
27
+ /* GraphQL */
28
+ `
29
+ input Input @oneOf {
30
+ foo: String
31
+ bar: Int
32
+ }
33
+ `
34
+ )
35
+ }
36
+ ]
37
+ },
38
+ messages: {
39
+ [RULE_ID]: '{{ nodeName }} must be nullable when "@oneOf" is in use'
40
+ },
41
+ schema: []
42
+ },
43
+ create(context) {
44
+ return {
45
+ "Directive[name.value=oneOf]"({ parent }) {
46
+ if ([
47
+ Kind.OBJECT_TYPE_DEFINITION,
48
+ Kind.INPUT_OBJECT_TYPE_DEFINITION
49
+ ].includes(parent.kind))
50
+ for (const field of parent.fields || [])
51
+ field.gqlType.kind === Kind.NON_NULL_TYPE && context.report({
52
+ node: field.name,
53
+ messageId: RULE_ID,
54
+ data: { nodeName: getNodeName(field) }
55
+ });
56
+ }
57
+ };
58
+ }
59
+ };
60
+ export {
61
+ rule
62
+ };
@@ -0,0 +1,13 @@
1
+ import { GraphQLESLintRule } from '../types.mjs';
2
+ import 'eslint';
3
+ import 'estree';
4
+ import 'graphql';
5
+ import 'json-schema-to-ts';
6
+ import '../siblings.mjs';
7
+ import '@graphql-tools/utils';
8
+ import '../estree-converter/types.mjs';
9
+ import 'graphql-config';
10
+
11
+ declare const rule: GraphQLESLintRule;
12
+
13
+ export { rule };
@@ -0,0 +1,80 @@
1
+ import "../chunk-U3TKCM4X.js";
2
+ import { Kind } from "graphql";
3
+ import { getNodeName, requireGraphQLSchemaFromContext, truthy } from "../utils.js";
4
+ const RULE_ID = "require-nullable-result-in-root", rule = {
5
+ meta: {
6
+ type: "suggestion",
7
+ hasSuggestions: !0,
8
+ docs: {
9
+ category: "Schema",
10
+ description: "Require nullable fields in root types.",
11
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
12
+ requiresSchema: !0,
13
+ examples: [
14
+ {
15
+ title: "Incorrect",
16
+ code: (
17
+ /* GraphQL */
18
+ `
19
+ type Query {
20
+ user: User!
21
+ }
22
+ `
23
+ )
24
+ },
25
+ {
26
+ title: "Correct",
27
+ code: (
28
+ /* GraphQL */
29
+ `
30
+ type Query {
31
+ foo: User
32
+ baz: [User]!
33
+ bar: [User!]!
34
+ }
35
+ `
36
+ )
37
+ }
38
+ ]
39
+ },
40
+ messages: {
41
+ [RULE_ID]: "Unexpected non-null result {{ resultType }} in {{ rootType }}"
42
+ },
43
+ schema: []
44
+ },
45
+ create(context) {
46
+ const schema = requireGraphQLSchemaFromContext(RULE_ID, context), rootTypeNames = new Set(
47
+ [schema.getQueryType(), schema.getMutationType()].filter(truthy).map((type) => type.name)
48
+ ), sourceCode = context.getSourceCode();
49
+ return {
50
+ "ObjectTypeDefinition,ObjectTypeExtension"(node) {
51
+ if (rootTypeNames.has(node.name.value))
52
+ for (const field of node.fields || []) {
53
+ if (field.gqlType.type !== Kind.NON_NULL_TYPE || field.gqlType.gqlType.type !== Kind.NAMED_TYPE)
54
+ continue;
55
+ const name = field.gqlType.gqlType.name.value, type = schema.getType(name), resultType = type?.astNode ? getNodeName(type.astNode) : type?.name;
56
+ context.report({
57
+ node: field.gqlType,
58
+ messageId: RULE_ID,
59
+ data: {
60
+ resultType: resultType || "",
61
+ rootType: getNodeName(node)
62
+ },
63
+ suggest: [
64
+ {
65
+ desc: `Make ${resultType} nullable`,
66
+ fix(fixer) {
67
+ const text = sourceCode.getText(field.gqlType);
68
+ return fixer.replaceText(field.gqlType, text.replace("!", ""));
69
+ }
70
+ }
71
+ ]
72
+ });
73
+ }
74
+ }
75
+ };
76
+ }
77
+ };
78
+ export {
79
+ rule
80
+ };
@@ -0,0 +1,45 @@
1
+ import { FromSchema } from 'json-schema-to-ts';
2
+ import { GraphQLESLintRule } from '../types.mjs';
3
+ import 'eslint';
4
+ import 'estree';
5
+ import 'graphql';
6
+ import '../siblings.mjs';
7
+ import '@graphql-tools/utils';
8
+ import '../estree-converter/types.mjs';
9
+ import 'graphql-config';
10
+
11
+ declare const schema: {
12
+ readonly definitions: {
13
+ readonly asString: {
14
+ readonly type: "string";
15
+ };
16
+ readonly asArray: {
17
+ readonly type: "array";
18
+ readonly uniqueItems: true;
19
+ readonly minItems: 1;
20
+ readonly items: {
21
+ readonly type: "string";
22
+ };
23
+ };
24
+ };
25
+ readonly type: "array";
26
+ readonly maxItems: 1;
27
+ readonly items: {
28
+ readonly type: "object";
29
+ readonly additionalProperties: false;
30
+ readonly properties: {
31
+ readonly fieldName: {
32
+ readonly oneOf: readonly [{
33
+ readonly $ref: "#/definitions/asString";
34
+ }, {
35
+ readonly $ref: "#/definitions/asArray";
36
+ }];
37
+ readonly default: "id";
38
+ };
39
+ };
40
+ };
41
+ };
42
+ type RuleOptions = FromSchema<typeof schema>;
43
+ declare const rule: GraphQLESLintRule<RuleOptions, true>;
44
+
45
+ export { RuleOptions, rule };
@@ -0,0 +1,194 @@
1
+ import "../chunk-U3TKCM4X.js";
2
+ import { asArray } from "@graphql-tools/utils";
3
+ import {
4
+ GraphQLInterfaceType,
5
+ GraphQLObjectType,
6
+ GraphQLUnionType,
7
+ Kind,
8
+ TypeInfo,
9
+ visit,
10
+ visitWithTypeInfo
11
+ } from "graphql";
12
+ import { getBaseType } from "../estree-converter/index.js";
13
+ import {
14
+ ARRAY_DEFAULT_OPTIONS,
15
+ englishJoinWords,
16
+ requireGraphQLSchemaFromContext,
17
+ requireSiblingsOperations
18
+ } from "../utils.js";
19
+ const RULE_ID = "require-selections", DEFAULT_ID_FIELD_NAME = "id", schema = {
20
+ definitions: {
21
+ asString: {
22
+ type: "string"
23
+ },
24
+ asArray: ARRAY_DEFAULT_OPTIONS
25
+ },
26
+ type: "array",
27
+ maxItems: 1,
28
+ items: {
29
+ type: "object",
30
+ additionalProperties: !1,
31
+ properties: {
32
+ fieldName: {
33
+ oneOf: [{ $ref: "#/definitions/asString" }, { $ref: "#/definitions/asArray" }],
34
+ default: DEFAULT_ID_FIELD_NAME
35
+ }
36
+ }
37
+ }
38
+ }, rule = {
39
+ meta: {
40
+ type: "suggestion",
41
+ hasSuggestions: !0,
42
+ docs: {
43
+ category: "Operations",
44
+ description: "Enforce selecting specific fields when they are available on the GraphQL type.",
45
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
46
+ requiresSchema: !0,
47
+ requiresSiblings: !0,
48
+ examples: [
49
+ {
50
+ title: "Incorrect",
51
+ code: (
52
+ /* GraphQL */
53
+ `
54
+ # In your schema
55
+ type User {
56
+ id: ID!
57
+ name: String!
58
+ }
59
+
60
+ # Query
61
+ query {
62
+ user {
63
+ name
64
+ }
65
+ }
66
+ `
67
+ )
68
+ },
69
+ {
70
+ title: "Correct",
71
+ code: (
72
+ /* GraphQL */
73
+ `
74
+ # In your schema
75
+ type User {
76
+ id: ID!
77
+ name: String!
78
+ }
79
+
80
+ # Query
81
+ query {
82
+ user {
83
+ id
84
+ name
85
+ }
86
+ }
87
+
88
+ # Selecting \`id\` with an alias is also valid
89
+ query {
90
+ user {
91
+ id: name
92
+ }
93
+ }
94
+ `
95
+ )
96
+ }
97
+ ],
98
+ recommended: !0
99
+ },
100
+ messages: {
101
+ [RULE_ID]: `Field{{ pluralSuffix }} {{ fieldName }} must be selected when it's available on a type.
102
+ Include it in your selection set{{ addition }}.`
103
+ },
104
+ schema
105
+ },
106
+ create(context) {
107
+ const schema2 = requireGraphQLSchemaFromContext(RULE_ID, context), siblings = requireSiblingsOperations(RULE_ID, context), { fieldName = DEFAULT_ID_FIELD_NAME } = context.options[0] || {}, idNames = asArray(fieldName), selector = "OperationDefinition SelectionSet[parent.kind!=/(^OperationDefinition|InlineFragment)$/]", typeInfo = new TypeInfo(schema2);
108
+ function checkFragments(node) {
109
+ for (const selection of node.selections) {
110
+ if (selection.kind !== Kind.FRAGMENT_SPREAD)
111
+ continue;
112
+ const [foundSpread] = siblings.getFragment(selection.name.value);
113
+ if (!foundSpread)
114
+ continue;
115
+ const checkedFragmentSpreads = /* @__PURE__ */ new Set(), visitor = visitWithTypeInfo(typeInfo, {
116
+ SelectionSet(node2, key, _parent) {
117
+ const parent = _parent;
118
+ parent.kind === Kind.FRAGMENT_DEFINITION ? checkedFragmentSpreads.add(parent.name.value) : parent.kind !== Kind.INLINE_FRAGMENT && checkSelections(
119
+ node2,
120
+ typeInfo.getType(),
121
+ selection.loc.start,
122
+ parent,
123
+ checkedFragmentSpreads
124
+ );
125
+ }
126
+ });
127
+ visit(foundSpread.document, visitor);
128
+ }
129
+ }
130
+ function checkSelections(node, type, loc, parent, checkedFragmentSpreads = /* @__PURE__ */ new Set()) {
131
+ const rawType = getBaseType(type);
132
+ if (rawType instanceof GraphQLObjectType || rawType instanceof GraphQLInterfaceType)
133
+ checkFields(rawType);
134
+ else if (rawType instanceof GraphQLUnionType) {
135
+ for (const selection of node.selections)
136
+ if (selection.kind === Kind.INLINE_FRAGMENT) {
137
+ const t = rawType.getTypes().find((t2) => t2.name === selection.typeCondition.name.value);
138
+ t && checkFields(t);
139
+ }
140
+ }
141
+ function checkFields(rawType2) {
142
+ const fields = rawType2.getFields();
143
+ if (!idNames.some((name) => fields[name]))
144
+ return;
145
+ function hasIdField({ selections }) {
146
+ return selections.some((selection) => {
147
+ if (selection.kind === Kind.FIELD)
148
+ return selection.alias && idNames.includes(selection.alias.value) ? !0 : idNames.includes(selection.name.value);
149
+ if (selection.kind === Kind.INLINE_FRAGMENT)
150
+ return hasIdField(selection.selectionSet);
151
+ if (selection.kind === Kind.FRAGMENT_SPREAD) {
152
+ const [foundSpread] = siblings.getFragment(selection.name.value);
153
+ if (foundSpread) {
154
+ const fragmentSpread = foundSpread.document;
155
+ return checkedFragmentSpreads.add(fragmentSpread.name.value), hasIdField(fragmentSpread.selectionSet);
156
+ }
157
+ }
158
+ return !1;
159
+ });
160
+ }
161
+ const hasId = hasIdField(node);
162
+ if (checkFragments(node), hasId)
163
+ return;
164
+ const pluralSuffix = idNames.length > 1 ? "s" : "", fieldName2 = englishJoinWords(
165
+ idNames.map((name) => `\`${(parent.alias || parent.name).value}.${name}\``)
166
+ ), addition = checkedFragmentSpreads.size === 0 ? "" : ` or add to used fragment${checkedFragmentSpreads.size > 1 ? "s" : ""} ${englishJoinWords([...checkedFragmentSpreads].map((name) => `\`${name}\``))}`, problem = {
167
+ loc,
168
+ messageId: RULE_ID,
169
+ data: {
170
+ pluralSuffix,
171
+ fieldName: fieldName2,
172
+ addition
173
+ }
174
+ };
175
+ "type" in node && (problem.suggest = idNames.map((idName) => ({
176
+ desc: `Add \`${idName}\` selection`,
177
+ fix: (fixer) => {
178
+ let insertNode = node.selections[0];
179
+ return insertNode = insertNode.kind === Kind.INLINE_FRAGMENT ? insertNode.selectionSet.selections[0] : insertNode, fixer.insertTextBefore(insertNode, `${idName} `);
180
+ }
181
+ }))), context.report(problem);
182
+ }
183
+ }
184
+ return {
185
+ [selector](node) {
186
+ const typeInfo2 = node.typeInfo();
187
+ typeInfo2.gqlType && checkSelections(node, typeInfo2.gqlType, node.loc.start, node.parent);
188
+ }
189
+ };
190
+ }
191
+ };
192
+ export {
193
+ rule
194
+ };
@@ -0,0 +1,13 @@
1
+ import { GraphQLESLintRule } from '../types.mjs';
2
+ import 'eslint';
3
+ import 'estree';
4
+ import 'graphql';
5
+ import 'json-schema-to-ts';
6
+ import '../siblings.mjs';
7
+ import '@graphql-tools/utils';
8
+ import '../estree-converter/types.mjs';
9
+ import 'graphql-config';
10
+
11
+ declare const rule: GraphQLESLintRule;
12
+
13
+ export { rule };
@@ -0,0 +1,63 @@
1
+ import "../chunk-U3TKCM4X.js";
2
+ import { displayNodeName } from "../utils.js";
3
+ const RULE_ID = "require-type-pattern-with-oneof", rule = {
4
+ meta: {
5
+ type: "suggestion",
6
+ docs: {
7
+ category: "Schema",
8
+ description: "Enforce types with `@oneOf` directive have `error` and `ok` fields.",
9
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
10
+ examples: [
11
+ {
12
+ title: "Correct",
13
+ code: (
14
+ /* GraphQL */
15
+ `
16
+ type Mutation {
17
+ doSomething: DoSomethingMutationResult!
18
+ }
19
+
20
+ interface Error {
21
+ message: String!
22
+ }
23
+
24
+ type DoSomethingMutationResult @oneOf {
25
+ ok: DoSomethingSuccess
26
+ error: Error
27
+ }
28
+
29
+ type DoSomethingSuccess {
30
+ # ...
31
+ }
32
+ `
33
+ )
34
+ }
35
+ ]
36
+ },
37
+ messages: {
38
+ [RULE_ID]: '{{ nodeName }} is defined as output with "@oneOf" and must be defined with "{{ fieldName }}" field'
39
+ },
40
+ schema: []
41
+ },
42
+ create(context) {
43
+ return {
44
+ "Directive[name.value=oneOf][parent.kind=ObjectTypeDefinition]"({
45
+ parent
46
+ }) {
47
+ const requiredFields = ["error", "ok"];
48
+ for (const fieldName of requiredFields)
49
+ parent.fields?.some((field) => field.name.value === fieldName) || context.report({
50
+ node: parent.name,
51
+ messageId: RULE_ID,
52
+ data: {
53
+ nodeName: displayNodeName(parent),
54
+ fieldName
55
+ }
56
+ });
57
+ }
58
+ };
59
+ }
60
+ };
61
+ export {
62
+ rule
63
+ };