@graphql-eslint/eslint-plugin 3.19.3 → 3.20.0-alpha-20230703154330-0d51273

Sign up to get free protection for your applications and to get access to all the features.
Files changed (302) hide show
  1. package/{typings → cjs}/cache.d.ts +3 -1
  2. package/cjs/cache.js +57 -26
  3. package/{typings → cjs}/configs/index.d.ts +3 -1
  4. package/cjs/configs/index.js +47 -14
  5. package/{typings → cjs}/configs/operations-all.d.ts +2 -1
  6. package/cjs/configs/operations-all.js +47 -30
  7. package/{typings → cjs}/configs/operations-recommended.d.ts +2 -1
  8. package/cjs/configs/operations-recommended.js +72 -55
  9. package/{typings → cjs}/configs/relay.d.ts +2 -1
  10. package/cjs/configs/relay.js +31 -11
  11. package/{typings → cjs}/configs/schema-all.d.ts +2 -1
  12. package/cjs/configs/schema-all.js +41 -24
  13. package/{typings → cjs}/configs/schema-recommended.d.ts +2 -1
  14. package/cjs/configs/schema-recommended.js +68 -51
  15. package/{typings → cjs}/documents.d.ts +4 -1
  16. package/cjs/documents.js +74 -43
  17. package/cjs/estree-converter/converter.d.ts +8 -0
  18. package/cjs/estree-converter/converter.js +80 -59
  19. package/cjs/estree-converter/index.d.ts +8 -0
  20. package/cjs/estree-converter/index.js +25 -5
  21. package/{typings → cjs}/estree-converter/types.d.ts +7 -5
  22. package/cjs/estree-converter/types.js +16 -0
  23. package/cjs/estree-converter/utils.d.ts +18 -0
  24. package/cjs/estree-converter/utils.js +119 -95
  25. package/{typings → cjs}/flat-configs.d.ts +12 -1
  26. package/cjs/flat-configs.js +56 -32
  27. package/cjs/graphql-config.d.ts +13 -0
  28. package/cjs/graphql-config.js +78 -47
  29. package/cjs/index.d.ts +22 -0
  30. package/cjs/index.js +50 -18
  31. package/cjs/parser.d.ts +12 -0
  32. package/cjs/parser.js +96 -76
  33. package/cjs/processor.d.ts +9 -0
  34. package/cjs/processor.js +119 -88
  35. package/{typings → cjs}/rules/alphabetize.d.ts +12 -4
  36. package/cjs/rules/alphabetize.js +337 -295
  37. package/{typings → cjs}/rules/description-style.d.ts +12 -4
  38. package/cjs/rules/description-style.js +96 -66
  39. package/cjs/rules/graphql-js-validation.d.ts +12 -0
  40. package/cjs/rules/graphql-js-validation.js +595 -433
  41. package/cjs/rules/index.d.ts +125 -0
  42. package/cjs/rules/index.js +97 -76
  43. package/{typings → cjs}/rules/input-name.d.ts +12 -4
  44. package/cjs/rules/input-name.js +153 -123
  45. package/{typings → cjs}/rules/lone-executable-definition.d.ts +12 -4
  46. package/cjs/rules/lone-executable-definition.js +101 -72
  47. package/{typings → cjs}/rules/match-document-filename.d.ts +14 -6
  48. package/cjs/rules/match-document-filename.js +229 -182
  49. package/{typings → cjs}/rules/naming-convention.d.ts +12 -4
  50. package/cjs/rules/naming-convention.js +380 -316
  51. package/cjs/rules/no-anonymous-operations.d.ts +12 -0
  52. package/cjs/rules/no-anonymous-operations.js +88 -57
  53. package/cjs/rules/no-case-insensitive-enum-values-duplicates.d.ts +12 -0
  54. package/cjs/rules/no-case-insensitive-enum-values-duplicates.js +82 -50
  55. package/cjs/rules/no-deprecated.d.ts +12 -0
  56. package/cjs/rules/no-deprecated.js +106 -75
  57. package/cjs/rules/no-duplicate-fields.d.ts +12 -0
  58. package/cjs/rules/no-duplicate-fields.js +116 -82
  59. package/cjs/rules/no-hashtag-description.d.ts +13 -0
  60. package/cjs/rules/no-hashtag-description.js +119 -82
  61. package/cjs/rules/no-one-place-fragments.d.ts +12 -0
  62. package/cjs/rules/no-one-place-fragments.js +88 -58
  63. package/{typings → cjs}/rules/no-root-type.d.ts +12 -4
  64. package/cjs/rules/no-root-type.js +101 -74
  65. package/cjs/rules/no-scalar-result-type-on-mutation.d.ts +12 -0
  66. package/cjs/rules/no-scalar-result-type-on-mutation.js +90 -60
  67. package/cjs/rules/no-typename-prefix.d.ts +12 -0
  68. package/cjs/rules/no-typename-prefix.js +88 -55
  69. package/cjs/rules/no-unreachable-types.d.ts +12 -0
  70. package/cjs/rules/no-unreachable-types.js +169 -134
  71. package/cjs/rules/no-unused-fields.d.ts +12 -0
  72. package/cjs/rules/no-unused-fields.js +117 -92
  73. package/{typings → cjs}/rules/relay-arguments.d.ts +12 -4
  74. package/cjs/rules/relay-arguments.js +136 -110
  75. package/cjs/rules/relay-connection-types.d.ts +13 -0
  76. package/cjs/rules/relay-connection-types.js +123 -94
  77. package/{typings → cjs}/rules/relay-edge-types.d.ts +12 -4
  78. package/cjs/rules/relay-edge-types.js +196 -179
  79. package/cjs/rules/relay-page-info.d.ts +12 -0
  80. package/cjs/rules/relay-page-info.js +108 -89
  81. package/{typings → cjs}/rules/require-deprecation-date.d.ts +12 -4
  82. package/cjs/rules/require-deprecation-date.js +143 -112
  83. package/cjs/rules/require-deprecation-reason.d.ts +12 -0
  84. package/cjs/rules/require-deprecation-reason.js +80 -46
  85. package/{typings → cjs}/rules/require-description.d.ts +13 -5
  86. package/cjs/rules/require-description.js +170 -132
  87. package/cjs/rules/require-field-of-type-query-in-mutation-result.d.ts +12 -0
  88. package/cjs/rules/require-field-of-type-query-in-mutation-result.js +81 -51
  89. package/{typings → cjs}/rules/require-id-when-available.d.ts +12 -4
  90. package/cjs/rules/require-id-when-available.js +196 -173
  91. package/cjs/rules/require-import-fragment.d.ts +12 -0
  92. package/cjs/rules/require-import-fragment.js +138 -88
  93. package/cjs/rules/require-nullable-fields-with-oneof.d.ts +12 -0
  94. package/cjs/rules/require-nullable-fields-with-oneof.js +80 -50
  95. package/cjs/rules/require-nullable-result-in-root.d.ts +12 -0
  96. package/cjs/rules/require-nullable-result-in-root.js +97 -68
  97. package/cjs/rules/require-type-pattern-with-oneof.d.ts +12 -0
  98. package/cjs/rules/require-type-pattern-with-oneof.js +70 -42
  99. package/{typings → cjs}/rules/selection-set-depth.d.ts +12 -4
  100. package/cjs/rules/selection-set-depth.js +147 -107
  101. package/{typings → cjs}/rules/strict-id-in-types.d.ts +12 -4
  102. package/cjs/rules/strict-id-in-types.js +143 -122
  103. package/cjs/rules/unique-fragment-name.d.ts +13 -0
  104. package/cjs/rules/unique-fragment-name.js +88 -62
  105. package/cjs/rules/unique-operation-name.d.ts +12 -0
  106. package/cjs/rules/unique-operation-name.js +65 -35
  107. package/cjs/schema.d.ts +12 -0
  108. package/cjs/schema.js +62 -30
  109. package/cjs/siblings.d.ts +8 -0
  110. package/cjs/siblings.js +124 -106
  111. package/cjs/testkit.d.ts +8 -0
  112. package/cjs/testkit.js +165 -144
  113. package/cjs/types-e3367e3c.d.ts +129 -0
  114. package/cjs/types.d.ts +8 -0
  115. package/cjs/types.js +16 -0
  116. package/cjs/utils.d.ts +44 -0
  117. package/cjs/utils.js +181 -124
  118. package/{typings/cache.d.cts → esm/cache.d.mts} +3 -1
  119. package/esm/cache.js +25 -23
  120. package/{typings/configs/index.d.cts → esm/configs/index.d.mts} +3 -1
  121. package/esm/configs/index.js +14 -11
  122. package/{typings/configs/operations-all.d.cts → esm/configs/operations-all.d.mts} +2 -1
  123. package/esm/configs/operations-all.js +28 -28
  124. package/{typings/configs/operations-recommended.d.cts → esm/configs/operations-recommended.d.mts} +2 -1
  125. package/esm/configs/operations-recommended.js +53 -53
  126. package/{typings/configs/relay.d.cts → esm/configs/relay.d.mts} +2 -1
  127. package/esm/configs/relay.js +12 -9
  128. package/{typings/configs/schema-all.d.cts → esm/configs/schema-all.d.mts} +2 -1
  129. package/esm/configs/schema-all.js +22 -22
  130. package/{typings/configs/schema-recommended.d.cts → esm/configs/schema-recommended.d.mts} +2 -1
  131. package/esm/configs/schema-recommended.js +49 -49
  132. package/{typings/documents.d.cts → esm/documents.d.mts} +4 -1
  133. package/esm/documents.js +41 -39
  134. package/esm/estree-converter/converter.d.mts +8 -0
  135. package/esm/estree-converter/converter.js +63 -57
  136. package/esm/estree-converter/index.d.mts +8 -0
  137. package/esm/estree-converter/index.js +3 -3
  138. package/{typings/estree-converter/types.d.cts → esm/estree-converter/types.d.mts} +7 -5
  139. package/esm/estree-converter/utils.d.mts +18 -0
  140. package/esm/estree-converter/utils.js +102 -93
  141. package/{typings/flat-configs.d.cts → esm/flat-configs.d.mts} +13 -2
  142. package/esm/flat-configs.js +33 -30
  143. package/esm/graphql-config.d.mts +13 -0
  144. package/esm/graphql-config.js +49 -44
  145. package/esm/index.d.mts +22 -0
  146. package/esm/index.js +18 -9
  147. package/esm/package.json +1 -1
  148. package/esm/parser.d.mts +12 -0
  149. package/esm/parser.js +64 -73
  150. package/esm/processor.d.mts +9 -0
  151. package/esm/processor.js +98 -86
  152. package/{typings/rules/alphabetize.d.cts → esm/rules/alphabetize.d.mts} +12 -4
  153. package/esm/rules/alphabetize.js +304 -290
  154. package/{typings/rules/description-style.d.cts → esm/rules/description-style.d.mts} +12 -4
  155. package/esm/rules/description-style.js +73 -64
  156. package/esm/rules/graphql-js-validation.d.mts +12 -0
  157. package/esm/rules/graphql-js-validation.js +580 -429
  158. package/esm/rules/index.d.mts +125 -0
  159. package/esm/rules/index.js +74 -74
  160. package/{typings/rules/input-name.d.cts → esm/rules/input-name.d.mts} +12 -4
  161. package/esm/rules/input-name.js +132 -121
  162. package/{typings/rules/lone-executable-definition.d.cts → esm/rules/lone-executable-definition.d.mts} +12 -4
  163. package/esm/rules/lone-executable-definition.js +78 -70
  164. package/{typings/rules/match-document-filename.d.cts → esm/rules/match-document-filename.d.mts} +14 -6
  165. package/esm/rules/match-document-filename.js +210 -180
  166. package/{typings/rules/naming-convention.d.cts → esm/rules/naming-convention.d.mts} +12 -4
  167. package/esm/rules/naming-convention.js +363 -314
  168. package/esm/rules/no-anonymous-operations.d.mts +12 -0
  169. package/esm/rules/no-anonymous-operations.js +65 -55
  170. package/esm/rules/no-case-insensitive-enum-values-duplicates.d.mts +12 -0
  171. package/esm/rules/no-case-insensitive-enum-values-duplicates.js +59 -48
  172. package/esm/rules/no-deprecated.d.mts +12 -0
  173. package/esm/rules/no-deprecated.js +83 -73
  174. package/esm/rules/no-duplicate-fields.d.mts +12 -0
  175. package/esm/rules/no-duplicate-fields.js +93 -80
  176. package/esm/rules/no-hashtag-description.d.mts +13 -0
  177. package/esm/rules/no-hashtag-description.js +95 -80
  178. package/esm/rules/no-one-place-fragments.d.mts +12 -0
  179. package/esm/rules/no-one-place-fragments.js +65 -56
  180. package/{typings/rules/no-root-type.d.cts → esm/rules/no-root-type.d.mts} +12 -4
  181. package/esm/rules/no-root-type.js +78 -72
  182. package/esm/rules/no-scalar-result-type-on-mutation.d.mts +12 -0
  183. package/esm/rules/no-scalar-result-type-on-mutation.js +67 -58
  184. package/esm/rules/no-typename-prefix.d.mts +12 -0
  185. package/esm/rules/no-typename-prefix.js +65 -53
  186. package/esm/rules/no-unreachable-types.d.mts +12 -0
  187. package/esm/rules/no-unreachable-types.js +141 -131
  188. package/esm/rules/no-unused-fields.d.mts +12 -0
  189. package/esm/rules/no-unused-fields.js +94 -90
  190. package/{typings/rules/relay-arguments.d.cts → esm/rules/relay-arguments.d.mts} +12 -4
  191. package/esm/rules/relay-arguments.js +113 -108
  192. package/esm/rules/relay-connection-types.d.mts +13 -0
  193. package/esm/rules/relay-connection-types.js +98 -91
  194. package/{typings/rules/relay-edge-types.d.cts → esm/rules/relay-edge-types.d.mts} +12 -4
  195. package/esm/rules/relay-edge-types.js +178 -177
  196. package/esm/rules/relay-page-info.d.mts +12 -0
  197. package/esm/rules/relay-page-info.js +84 -86
  198. package/{typings/rules/require-deprecation-date.d.cts → esm/rules/require-deprecation-date.d.mts} +12 -4
  199. package/esm/rules/require-deprecation-date.js +120 -110
  200. package/esm/rules/require-deprecation-reason.d.mts +12 -0
  201. package/esm/rules/require-deprecation-reason.js +57 -44
  202. package/{typings/rules/require-description.d.cts → esm/rules/require-description.d.mts} +13 -5
  203. package/esm/rules/require-description.js +151 -130
  204. package/esm/rules/require-field-of-type-query-in-mutation-result.d.mts +12 -0
  205. package/esm/rules/require-field-of-type-query-in-mutation-result.js +58 -49
  206. package/{typings/rules/require-id-when-available.d.cts → esm/rules/require-id-when-available.d.mts} +12 -4
  207. package/esm/rules/require-id-when-available.js +186 -171
  208. package/esm/rules/require-import-fragment.d.mts +12 -0
  209. package/esm/rules/require-import-fragment.js +105 -85
  210. package/esm/rules/require-nullable-fields-with-oneof.d.mts +12 -0
  211. package/esm/rules/require-nullable-fields-with-oneof.js +57 -48
  212. package/esm/rules/require-nullable-result-in-root.d.mts +12 -0
  213. package/esm/rules/require-nullable-result-in-root.js +74 -66
  214. package/esm/rules/require-type-pattern-with-oneof.d.mts +12 -0
  215. package/esm/rules/require-type-pattern-with-oneof.js +47 -40
  216. package/{typings/rules/selection-set-depth.d.cts → esm/rules/selection-set-depth.d.mts} +12 -4
  217. package/esm/rules/selection-set-depth.js +114 -104
  218. package/{typings/rules/strict-id-in-types.d.cts → esm/rules/strict-id-in-types.d.mts} +12 -4
  219. package/esm/rules/strict-id-in-types.js +125 -119
  220. package/esm/rules/unique-fragment-name.d.mts +13 -0
  221. package/esm/rules/unique-fragment-name.js +65 -60
  222. package/esm/rules/unique-operation-name.d.mts +12 -0
  223. package/esm/rules/unique-operation-name.js +42 -33
  224. package/esm/schema.d.mts +12 -0
  225. package/esm/schema.js +29 -26
  226. package/esm/siblings.d.mts +8 -0
  227. package/esm/siblings.js +105 -104
  228. package/esm/testkit.d.mts +8 -0
  229. package/esm/testkit.js +132 -141
  230. package/esm/types-2e1afd7c.d.ts +129 -0
  231. package/esm/types.d.mts +8 -0
  232. package/esm/utils.d.mts +44 -0
  233. package/esm/utils.js +138 -116
  234. package/package.json +40 -30
  235. package/typings/estree-converter/converter.d.cts +0 -3
  236. package/typings/estree-converter/converter.d.ts +0 -3
  237. package/typings/estree-converter/index.d.cts +0 -3
  238. package/typings/estree-converter/index.d.ts +0 -3
  239. package/typings/estree-converter/utils.d.cts +0 -13
  240. package/typings/estree-converter/utils.d.ts +0 -13
  241. package/typings/graphql-config.d.cts +0 -4
  242. package/typings/graphql-config.d.ts +0 -4
  243. package/typings/index.d.cts +0 -10
  244. package/typings/index.d.ts +0 -10
  245. package/typings/parser.d.cts +0 -2
  246. package/typings/parser.d.ts +0 -2
  247. package/typings/processor.d.cts +0 -6
  248. package/typings/processor.d.ts +0 -6
  249. package/typings/rules/graphql-js-validation.d.cts +0 -2
  250. package/typings/rules/graphql-js-validation.d.ts +0 -2
  251. package/typings/rules/index.d.cts +0 -111
  252. package/typings/rules/index.d.ts +0 -111
  253. package/typings/rules/no-anonymous-operations.d.cts +0 -2
  254. package/typings/rules/no-anonymous-operations.d.ts +0 -2
  255. package/typings/rules/no-case-insensitive-enum-values-duplicates.d.cts +0 -2
  256. package/typings/rules/no-case-insensitive-enum-values-duplicates.d.ts +0 -2
  257. package/typings/rules/no-deprecated.d.cts +0 -2
  258. package/typings/rules/no-deprecated.d.ts +0 -2
  259. package/typings/rules/no-duplicate-fields.d.cts +0 -2
  260. package/typings/rules/no-duplicate-fields.d.ts +0 -2
  261. package/typings/rules/no-hashtag-description.d.cts +0 -3
  262. package/typings/rules/no-hashtag-description.d.ts +0 -3
  263. package/typings/rules/no-one-place-fragments.d.cts +0 -2
  264. package/typings/rules/no-one-place-fragments.d.ts +0 -2
  265. package/typings/rules/no-scalar-result-type-on-mutation.d.cts +0 -2
  266. package/typings/rules/no-scalar-result-type-on-mutation.d.ts +0 -2
  267. package/typings/rules/no-typename-prefix.d.cts +0 -2
  268. package/typings/rules/no-typename-prefix.d.ts +0 -2
  269. package/typings/rules/no-unreachable-types.d.cts +0 -2
  270. package/typings/rules/no-unreachable-types.d.ts +0 -2
  271. package/typings/rules/no-unused-fields.d.cts +0 -2
  272. package/typings/rules/no-unused-fields.d.ts +0 -2
  273. package/typings/rules/relay-connection-types.d.cts +0 -4
  274. package/typings/rules/relay-connection-types.d.ts +0 -4
  275. package/typings/rules/relay-page-info.d.cts +0 -2
  276. package/typings/rules/relay-page-info.d.ts +0 -2
  277. package/typings/rules/require-deprecation-reason.d.cts +0 -2
  278. package/typings/rules/require-deprecation-reason.d.ts +0 -2
  279. package/typings/rules/require-field-of-type-query-in-mutation-result.d.cts +0 -2
  280. package/typings/rules/require-field-of-type-query-in-mutation-result.d.ts +0 -2
  281. package/typings/rules/require-import-fragment.d.cts +0 -2
  282. package/typings/rules/require-import-fragment.d.ts +0 -2
  283. package/typings/rules/require-nullable-fields-with-oneof.d.cts +0 -2
  284. package/typings/rules/require-nullable-fields-with-oneof.d.ts +0 -2
  285. package/typings/rules/require-nullable-result-in-root.d.cts +0 -2
  286. package/typings/rules/require-nullable-result-in-root.d.ts +0 -2
  287. package/typings/rules/require-type-pattern-with-oneof.d.cts +0 -2
  288. package/typings/rules/require-type-pattern-with-oneof.d.ts +0 -2
  289. package/typings/rules/unique-fragment-name.d.cts +0 -5
  290. package/typings/rules/unique-fragment-name.d.ts +0 -5
  291. package/typings/rules/unique-operation-name.d.cts +0 -2
  292. package/typings/rules/unique-operation-name.d.ts +0 -2
  293. package/typings/schema.d.cts +0 -3
  294. package/typings/schema.d.ts +0 -3
  295. package/typings/siblings.d.cts +0 -22
  296. package/typings/siblings.d.ts +0 -22
  297. package/typings/testkit.d.cts +0 -29
  298. package/typings/testkit.d.ts +0 -29
  299. package/typings/types.d.cts +0 -83
  300. package/typings/types.d.ts +0 -83
  301. package/typings/utils.d.cts +0 -40
  302. package/typings/utils.d.ts +0 -40
@@ -1,59 +1,68 @@
1
- import { Kind } from 'graphql';
2
- import { getNodeName } from '../utils.js';
3
- const RULE_ID = 'require-nullable-fields-with-oneof';
4
- export const 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: /* GraphQL */ `
1
+ import { Kind } from "graphql";
2
+ import { getNodeName } from "../utils.js";
3
+ const RULE_ID = "require-nullable-fields-with-oneof";
4
+ const 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
+ `
15
17
  input Input @oneOf {
16
18
  foo: String!
17
19
  b: Int
18
20
  }
19
- `,
20
- },
21
- {
22
- title: 'Correct',
23
- code: /* GraphQL */ `
21
+ `
22
+ )
23
+ },
24
+ {
25
+ title: "Correct",
26
+ code: (
27
+ /* GraphQL */
28
+ `
24
29
  input Input @oneOf {
25
30
  foo: String
26
31
  bar: Int
27
32
  }
28
- `,
29
- },
30
- ],
31
- },
32
- messages: {
33
- [RULE_ID]: '{{ nodeName }} must be nullable when "@oneOf" is in use',
34
- },
35
- schema: [],
33
+ `
34
+ )
35
+ }
36
+ ]
36
37
  },
37
- create(context) {
38
- return {
39
- 'Directive[name.value=oneOf]'({ parent }) {
40
- const isTypeOrInput = [
41
- Kind.OBJECT_TYPE_DEFINITION,
42
- Kind.INPUT_OBJECT_TYPE_DEFINITION,
43
- ].includes(parent.kind);
44
- if (!isTypeOrInput) {
45
- return;
46
- }
47
- for (const field of parent.fields || []) {
48
- if (field.gqlType.kind === Kind.NON_NULL_TYPE) {
49
- context.report({
50
- node: field.name,
51
- messageId: RULE_ID,
52
- data: { nodeName: getNodeName(field) },
53
- });
54
- }
55
- }
56
- },
57
- };
38
+ messages: {
39
+ [RULE_ID]: '{{ nodeName }} must be nullable when "@oneOf" is in use'
58
40
  },
41
+ schema: []
42
+ },
43
+ create(context) {
44
+ return {
45
+ "Directive[name.value=oneOf]"({ parent }) {
46
+ const isTypeOrInput = [
47
+ Kind.OBJECT_TYPE_DEFINITION,
48
+ Kind.INPUT_OBJECT_TYPE_DEFINITION
49
+ ].includes(parent.kind);
50
+ if (!isTypeOrInput) {
51
+ return;
52
+ }
53
+ for (const field of parent.fields || []) {
54
+ if (field.gqlType.kind === Kind.NON_NULL_TYPE) {
55
+ context.report({
56
+ node: field.name,
57
+ messageId: RULE_ID,
58
+ data: { nodeName: getNodeName(field) }
59
+ });
60
+ }
61
+ }
62
+ }
63
+ };
64
+ }
65
+ };
66
+ export {
67
+ rule
59
68
  };
@@ -0,0 +1,12 @@
1
+ import { i as GraphQLESLintRule } from '../types-2e1afd7c.js';
2
+ import '@graphql-tools/utils';
3
+ import 'eslint';
4
+ import 'estree';
5
+ import 'graphql';
6
+ import 'graphql-config';
7
+ import 'json-schema-to-ts';
8
+ import '../estree-converter/types.mjs';
9
+
10
+ declare const rule: GraphQLESLintRule;
11
+
12
+ export { rule };
@@ -1,77 +1,85 @@
1
- import { Kind } from 'graphql';
2
- import { getNodeName, requireGraphQLSchemaFromContext, truthy } from '../utils.js';
3
- const RULE_ID = 'require-nullable-result-in-root';
4
- export const rule = {
5
- meta: {
6
- type: 'suggestion',
7
- hasSuggestions: true,
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: true,
13
- examples: [
14
- {
15
- title: 'Incorrect',
16
- code: /* GraphQL */ `
1
+ import { Kind } from "graphql";
2
+ import { getNodeName, requireGraphQLSchemaFromContext, truthy } from "../utils.js";
3
+ const RULE_ID = "require-nullable-result-in-root";
4
+ const rule = {
5
+ meta: {
6
+ type: "suggestion",
7
+ hasSuggestions: true,
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: true,
13
+ examples: [
14
+ {
15
+ title: "Incorrect",
16
+ code: (
17
+ /* GraphQL */
18
+ `
17
19
  type Query {
18
20
  user: User!
19
21
  }
20
- `,
21
- },
22
- {
23
- title: 'Correct',
24
- code: /* GraphQL */ `
22
+ `
23
+ )
24
+ },
25
+ {
26
+ title: "Correct",
27
+ code: (
28
+ /* GraphQL */
29
+ `
25
30
  type Query {
26
31
  foo: User
27
32
  baz: [User]!
28
33
  bar: [User!]!
29
34
  }
30
- `,
31
- },
32
- ],
33
- },
34
- messages: {
35
- [RULE_ID]: 'Unexpected non-null result {{ resultType }} in {{ rootType }}',
36
- },
37
- schema: [],
35
+ `
36
+ )
37
+ }
38
+ ]
38
39
  },
39
- create(context) {
40
- const schema = requireGraphQLSchemaFromContext(RULE_ID, context);
41
- const rootTypeNames = new Set([schema.getQueryType(), schema.getMutationType(), schema.getSubscriptionType()]
42
- .filter(truthy)
43
- .map(type => type.name));
44
- const sourceCode = context.getSourceCode();
45
- return {
46
- 'ObjectTypeDefinition,ObjectTypeExtension'(node) {
47
- if (!rootTypeNames.has(node.name.value))
48
- return;
49
- for (const field of node.fields || []) {
50
- if (field.gqlType.type !== Kind.NON_NULL_TYPE ||
51
- field.gqlType.gqlType.type !== Kind.NAMED_TYPE)
52
- continue;
53
- const name = field.gqlType.gqlType.name.value;
54
- const type = schema.getType(name);
55
- const resultType = (type === null || type === void 0 ? void 0 : type.astNode) ? getNodeName(type.astNode) : type === null || type === void 0 ? void 0 : 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
- };
40
+ messages: {
41
+ [RULE_ID]: "Unexpected non-null result {{ resultType }} in {{ rootType }}"
76
42
  },
43
+ schema: []
44
+ },
45
+ create(context) {
46
+ const schema = requireGraphQLSchemaFromContext(RULE_ID, context);
47
+ const rootTypeNames = new Set(
48
+ [schema.getQueryType(), schema.getMutationType(), schema.getSubscriptionType()].filter(truthy).map((type) => type.name)
49
+ );
50
+ const sourceCode = context.getSourceCode();
51
+ return {
52
+ "ObjectTypeDefinition,ObjectTypeExtension"(node) {
53
+ if (!rootTypeNames.has(node.name.value))
54
+ return;
55
+ for (const field of node.fields || []) {
56
+ if (field.gqlType.type !== Kind.NON_NULL_TYPE || field.gqlType.gqlType.type !== Kind.NAMED_TYPE)
57
+ continue;
58
+ const name = field.gqlType.gqlType.name.value;
59
+ const type = schema.getType(name);
60
+ const resultType = type?.astNode ? getNodeName(type.astNode) : type?.name;
61
+ context.report({
62
+ node: field.gqlType,
63
+ messageId: RULE_ID,
64
+ data: {
65
+ resultType: resultType || "",
66
+ rootType: getNodeName(node)
67
+ },
68
+ suggest: [
69
+ {
70
+ desc: `Make ${resultType} nullable`,
71
+ fix(fixer) {
72
+ const text = sourceCode.getText(field.gqlType);
73
+ return fixer.replaceText(field.gqlType, text.replace("!", ""));
74
+ }
75
+ }
76
+ ]
77
+ });
78
+ }
79
+ }
80
+ };
81
+ }
82
+ };
83
+ export {
84
+ rule
77
85
  };
@@ -0,0 +1,12 @@
1
+ import { i as GraphQLESLintRule } from '../types-2e1afd7c.js';
2
+ import '@graphql-tools/utils';
3
+ import 'eslint';
4
+ import 'estree';
5
+ import 'graphql';
6
+ import 'graphql-config';
7
+ import 'json-schema-to-ts';
8
+ import '../estree-converter/types.mjs';
9
+
10
+ declare const rule: GraphQLESLintRule;
11
+
12
+ export { rule };
@@ -1,16 +1,18 @@
1
- import { displayNodeName } from '../utils.js';
2
- const RULE_ID = 'require-type-pattern-with-oneof';
3
- export const 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: /* GraphQL */ `
1
+ import { displayNodeName } from "../utils.js";
2
+ const RULE_ID = "require-type-pattern-with-oneof";
3
+ const 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
+ `
14
16
  type Mutation {
15
17
  doSomething: DoSomethingMutationResult!
16
18
  }
@@ -27,33 +29,38 @@ export const rule = {
27
29
  type DoSomethingSuccess {
28
30
  # ...
29
31
  }
30
- `,
31
- },
32
- ],
33
- },
34
- messages: {
35
- [RULE_ID]: '{{ nodeName }} is defined as output with "@oneOf" and must be defined with "{{ fieldName }}" field',
36
- },
37
- schema: [],
32
+ `
33
+ )
34
+ }
35
+ ]
38
36
  },
39
- create(context) {
40
- return {
41
- 'Directive[name.value=oneOf][parent.kind=ObjectTypeDefinition]'({ parent, }) {
42
- var _a;
43
- const requiredFields = ['error', 'ok'];
44
- for (const fieldName of requiredFields) {
45
- if (!((_a = parent.fields) === null || _a === void 0 ? void 0 : _a.some(field => field.name.value === fieldName))) {
46
- context.report({
47
- node: parent.name,
48
- messageId: RULE_ID,
49
- data: {
50
- nodeName: displayNodeName(parent),
51
- fieldName,
52
- },
53
- });
54
- }
55
- }
56
- },
57
- };
37
+ messages: {
38
+ [RULE_ID]: '{{ nodeName }} is defined as output with "@oneOf" and must be defined with "{{ fieldName }}" field'
58
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
+ if (!parent.fields?.some((field) => field.name.value === fieldName)) {
50
+ context.report({
51
+ node: parent.name,
52
+ messageId: RULE_ID,
53
+ data: {
54
+ nodeName: displayNodeName(parent),
55
+ fieldName
56
+ }
57
+ });
58
+ }
59
+ }
60
+ }
61
+ };
62
+ }
63
+ };
64
+ export {
65
+ rule
59
66
  };
@@ -1,5 +1,12 @@
1
1
  import { FromSchema } from 'json-schema-to-ts';
2
- import { GraphQLESLintRule } from '../types.cjs';
2
+ import { i as GraphQLESLintRule } from '../types-2e1afd7c.js';
3
+ import '@graphql-tools/utils';
4
+ import 'eslint';
5
+ import 'estree';
6
+ import 'graphql';
7
+ import 'graphql-config';
8
+ import '../estree-converter/types.mjs';
9
+
3
10
  declare const schema: {
4
11
  readonly type: "array";
5
12
  readonly minItems: 1;
@@ -23,6 +30,7 @@ declare const schema: {
23
30
  };
24
31
  };
25
32
  };
26
- export type RuleOptions = FromSchema<typeof schema>;
27
- export declare const rule: GraphQLESLintRule<RuleOptions>;
28
- export {};
33
+ type RuleOptions = FromSchema<typeof schema>;
34
+ declare const rule: GraphQLESLintRule<RuleOptions>;
35
+
36
+ export { RuleOptions, rule };
@@ -1,37 +1,37 @@
1
- import { Kind } from 'graphql';
2
- import depthLimit from 'graphql-depth-limit';
3
- import { ARRAY_DEFAULT_OPTIONS, logger, requireSiblingsOperations } from '../utils.js';
4
- const RULE_ID = 'selection-set-depth';
1
+ import { Kind } from "graphql";
2
+ import depthLimit from "graphql-depth-limit";
3
+ import { ARRAY_DEFAULT_OPTIONS, logger, requireSiblingsOperations } from "../utils.js";
4
+ const RULE_ID = "selection-set-depth";
5
5
  const schema = {
6
- type: 'array',
7
- minItems: 1,
8
- maxItems: 1,
9
- items: {
10
- type: 'object',
11
- additionalProperties: false,
12
- required: ['maxDepth'],
13
- properties: {
14
- maxDepth: {
15
- type: 'number',
16
- },
17
- ignore: ARRAY_DEFAULT_OPTIONS,
18
- },
19
- },
6
+ type: "array",
7
+ minItems: 1,
8
+ maxItems: 1,
9
+ items: {
10
+ type: "object",
11
+ additionalProperties: false,
12
+ required: ["maxDepth"],
13
+ properties: {
14
+ maxDepth: {
15
+ type: "number"
16
+ },
17
+ ignore: ARRAY_DEFAULT_OPTIONS
18
+ }
19
+ }
20
20
  };
21
- export const rule = {
22
- meta: {
23
- type: 'suggestion',
24
- hasSuggestions: true,
25
- docs: {
26
- category: 'Operations',
27
- description: 'Limit the complexity of the GraphQL operations solely by their depth. Based on [graphql-depth-limit](https://npmjs.com/package/graphql-depth-limit).',
28
- url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
29
- requiresSiblings: true,
30
- examples: [
31
- {
32
- title: 'Incorrect',
33
- usage: [{ maxDepth: 1 }],
34
- code: `
21
+ const rule = {
22
+ meta: {
23
+ type: "suggestion",
24
+ hasSuggestions: true,
25
+ docs: {
26
+ category: "Operations",
27
+ description: "Limit the complexity of the GraphQL operations solely by their depth. Based on [graphql-depth-limit](https://npmjs.com/package/graphql-depth-limit).",
28
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
29
+ requiresSiblings: true,
30
+ examples: [
31
+ {
32
+ title: "Incorrect",
33
+ usage: [{ maxDepth: 1 }],
34
+ code: `
35
35
  query deep2 {
36
36
  viewer { # Level 0
37
37
  albums { # Level 1
@@ -39,12 +39,12 @@ export const rule = {
39
39
  }
40
40
  }
41
41
  }
42
- `,
43
- },
44
- {
45
- title: 'Correct',
46
- usage: [{ maxDepth: 4 }],
47
- code: `
42
+ `
43
+ },
44
+ {
45
+ title: "Correct",
46
+ usage: [{ maxDepth: 4 }],
47
+ code: `
48
48
  query deep2 {
49
49
  viewer { # Level 0
50
50
  albums { # Level 1
@@ -52,12 +52,12 @@ export const rule = {
52
52
  }
53
53
  }
54
54
  }
55
- `,
56
- },
57
- {
58
- title: 'Correct (ignored field)',
59
- usage: [{ maxDepth: 1, ignore: ['albums'] }],
60
- code: `
55
+ `
56
+ },
57
+ {
58
+ title: "Correct (ignored field)",
59
+ usage: [{ maxDepth: 1, ignore: ["albums"] }],
60
+ code: `
61
61
  query deep2 {
62
62
  viewer { # Level 0
63
63
  albums { # Level 1
@@ -65,67 +65,77 @@ export const rule = {
65
65
  }
66
66
  }
67
67
  }
68
- `,
69
- },
70
- ],
71
- recommended: true,
72
- configOptions: [{ maxDepth: 7 }],
73
- },
74
- schema,
68
+ `
69
+ }
70
+ ],
71
+ recommended: true,
72
+ configOptions: [{ maxDepth: 7 }]
75
73
  },
76
- create(context) {
77
- let siblings = null;
74
+ schema
75
+ },
76
+ create(context) {
77
+ let siblings = null;
78
+ try {
79
+ siblings = requireSiblingsOperations(RULE_ID, context);
80
+ } catch {
81
+ logger.warn(
82
+ `Rule "${RULE_ID}" works best with siblings operations loaded. For more info: https://bit.ly/graphql-eslint-operations`
83
+ );
84
+ }
85
+ const { maxDepth, ignore = [] } = context.options[0];
86
+ const checkFn = depthLimit(maxDepth, { ignore });
87
+ return {
88
+ "OperationDefinition, FragmentDefinition"(node) {
78
89
  try {
79
- siblings = requireSiblingsOperations(RULE_ID, context);
80
- }
81
- catch (_a) {
82
- logger.warn(`Rule "${RULE_ID}" works best with siblings operations loaded. For more info: https://bit.ly/graphql-eslint-operations`);
83
- }
84
- const { maxDepth, ignore = [] } = context.options[0];
85
- const checkFn = depthLimit(maxDepth, { ignore });
86
- return {
87
- 'OperationDefinition, FragmentDefinition'(node) {
88
- try {
89
- const rawNode = node.rawNode();
90
- const fragmentsInUse = siblings ? siblings.getFragmentsInUse(rawNode) : [];
91
- const document = {
92
- kind: Kind.DOCUMENT,
93
- definitions: [rawNode, ...fragmentsInUse],
94
- };
95
- checkFn({
96
- getDocument: () => document,
97
- reportError(error) {
98
- const { line, column } = error.locations[0];
99
- const ancestors = context.getAncestors();
100
- const token = ancestors[0].tokens.find(token => token.loc.start.line === line && token.loc.start.column === column - 1);
101
- context.report({
102
- loc: {
103
- line,
104
- column: column - 1,
105
- },
106
- message: error.message,
107
- // Don't provide suggestions for fragment that can be in a separate file
108
- ...(token && {
109
- suggest: [
110
- {
111
- desc: 'Remove selections',
112
- fix(fixer) {
113
- const sourceCode = context.getSourceCode();
114
- const foundNode = sourceCode.getNodeByRangeIndex(token.range[0]);
115
- const parentNode = foundNode.parent.parent;
116
- return fixer.remove(foundNode.kind === 'Name' ? parentNode.parent : parentNode);
117
- },
118
- },
119
- ],
120
- }),
121
- });
122
- },
123
- });
124
- }
125
- catch (e) {
126
- logger.warn(`Rule "${RULE_ID}" check failed due to a missing siblings operations. For more info: https://bit.ly/graphql-eslint-operations`, e);
90
+ const rawNode = node.rawNode();
91
+ const fragmentsInUse = siblings ? siblings.getFragmentsInUse(rawNode) : [];
92
+ const document = {
93
+ kind: Kind.DOCUMENT,
94
+ definitions: [rawNode, ...fragmentsInUse]
95
+ };
96
+ checkFn({
97
+ getDocument: () => document,
98
+ reportError(error) {
99
+ const { line, column } = error.locations[0];
100
+ const ancestors = context.getAncestors();
101
+ const token = ancestors[0].tokens.find(
102
+ (token2) => token2.loc.start.line === line && token2.loc.start.column === column - 1
103
+ );
104
+ context.report({
105
+ loc: {
106
+ line,
107
+ column: column - 1
108
+ },
109
+ message: error.message,
110
+ // Don't provide suggestions for fragment that can be in a separate file
111
+ ...token && {
112
+ suggest: [
113
+ {
114
+ desc: "Remove selections",
115
+ fix(fixer) {
116
+ const sourceCode = context.getSourceCode();
117
+ const foundNode = sourceCode.getNodeByRangeIndex(token.range[0]);
118
+ const parentNode = foundNode.parent.parent;
119
+ return fixer.remove(
120
+ foundNode.kind === "Name" ? parentNode.parent : parentNode
121
+ );
122
+ }
123
+ }
124
+ ]
127
125
  }
128
- },
129
- };
130
- },
126
+ });
127
+ }
128
+ });
129
+ } catch (e) {
130
+ logger.warn(
131
+ `Rule "${RULE_ID}" check failed due to a missing siblings operations. For more info: https://bit.ly/graphql-eslint-operations`,
132
+ e
133
+ );
134
+ }
135
+ }
136
+ };
137
+ }
138
+ };
139
+ export {
140
+ rule
131
141
  };