@graphql-eslint/eslint-plugin 4.0.0-alpha-20220821140530-e968cfc → 4.0.0-alpha-20230801163310-8bc4340

Sign up to get free protection for your applications and to get access to all the features.
Files changed (347) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +13 -253
  3. package/cjs/cache.d.ts +12 -0
  4. package/cjs/cache.js +62 -0
  5. package/cjs/configs/index.d.ts +148 -0
  6. package/cjs/configs/index.js +49 -0
  7. package/cjs/configs/operations-all.d.ts +22 -0
  8. package/cjs/configs/operations-all.js +27 -0
  9. package/cjs/configs/operations-recommended.d.ts +52 -0
  10. package/{configs/operations-recommended.json → cjs/configs/operations-recommended.js} +16 -14
  11. package/cjs/configs/relay.d.ts +12 -0
  12. package/{configs/relay.json → cjs/configs/relay.js} +6 -4
  13. package/cjs/configs/schema-all.d.ts +19 -0
  14. package/cjs/configs/schema-all.js +21 -0
  15. package/cjs/configs/schema-recommended.d.ts +49 -0
  16. package/{configs/schema-recommended.json → cjs/configs/schema-recommended.js} +19 -20
  17. package/cjs/documents.d.ts +6 -0
  18. package/cjs/documents.js +81 -0
  19. package/cjs/estree-converter/converter.d.ts +8 -0
  20. package/cjs/estree-converter/converter.js +83 -0
  21. package/cjs/estree-converter/index.d.ts +8 -0
  22. package/cjs/estree-converter/index.js +26 -0
  23. package/cjs/estree-converter/types.d.ts +42 -0
  24. package/cjs/estree-converter/types.js +16 -0
  25. package/cjs/estree-converter/utils.d.ts +18 -0
  26. package/cjs/estree-converter/utils.js +135 -0
  27. package/cjs/flat-configs.d.ts +260 -0
  28. package/cjs/flat-configs.js +60 -0
  29. package/cjs/graphql-config.d.ts +13 -0
  30. package/cjs/graphql-config.js +86 -0
  31. package/cjs/index.d.ts +22 -0
  32. package/cjs/index.js +49 -0
  33. package/cjs/parser.d.ts +12 -0
  34. package/cjs/parser.js +103 -0
  35. package/cjs/processor.d.ts +9 -0
  36. package/cjs/processor.js +127 -0
  37. package/cjs/rules/alphabetize.d.ts +84 -0
  38. package/cjs/rules/alphabetize.js +395 -0
  39. package/cjs/rules/description-style.d.ts +28 -0
  40. package/cjs/rules/description-style.js +109 -0
  41. package/cjs/rules/graphql-js-validation.d.ts +12 -0
  42. package/cjs/rules/graphql-js-validation.js +669 -0
  43. package/cjs/rules/index.d.ts +125 -0
  44. package/cjs/rules/index.js +99 -0
  45. package/cjs/rules/input-name.d.ts +43 -0
  46. package/cjs/rules/input-name.js +170 -0
  47. package/cjs/rules/lone-executable-definition.d.ts +34 -0
  48. package/cjs/rules/lone-executable-definition.js +119 -0
  49. package/cjs/rules/match-document-filename.d.ts +80 -0
  50. package/cjs/rules/match-document-filename.js +282 -0
  51. package/cjs/rules/naming-convention.d.ts +107 -0
  52. package/cjs/rules/naming-convention.js +434 -0
  53. package/cjs/rules/no-anonymous-operations.d.ts +12 -0
  54. package/cjs/rules/no-anonymous-operations.js +98 -0
  55. package/cjs/rules/no-case-insensitive-enum-values-duplicates.d.ts +12 -0
  56. package/cjs/rules/no-case-insensitive-enum-values-duplicates.js +96 -0
  57. package/cjs/rules/no-deprecated.d.ts +12 -0
  58. package/cjs/rules/no-deprecated.js +157 -0
  59. package/cjs/rules/no-duplicate-fields.d.ts +12 -0
  60. package/cjs/rules/no-duplicate-fields.js +146 -0
  61. package/cjs/rules/no-hashtag-description.d.ts +13 -0
  62. package/cjs/rules/no-hashtag-description.js +140 -0
  63. package/cjs/rules/no-one-place-fragments.d.ts +12 -0
  64. package/cjs/rules/no-one-place-fragments.js +113 -0
  65. package/cjs/rules/no-root-type.d.ts +33 -0
  66. package/cjs/rules/no-root-type.js +113 -0
  67. package/cjs/rules/no-scalar-result-type-on-mutation.d.ts +12 -0
  68. package/cjs/rules/no-scalar-result-type-on-mutation.js +100 -0
  69. package/cjs/rules/no-typename-prefix.d.ts +12 -0
  70. package/cjs/rules/no-typename-prefix.js +98 -0
  71. package/cjs/rules/no-unreachable-types.d.ts +12 -0
  72. package/cjs/rules/no-unreachable-types.js +199 -0
  73. package/cjs/rules/no-unused-fields.d.ts +12 -0
  74. package/cjs/rules/no-unused-fields.js +157 -0
  75. package/cjs/rules/relay-arguments.d.ts +29 -0
  76. package/cjs/rules/relay-arguments.js +149 -0
  77. package/cjs/rules/relay-connection-types.d.ts +13 -0
  78. package/cjs/rules/relay-connection-types.js +142 -0
  79. package/cjs/rules/relay-edge-types.d.ts +39 -0
  80. package/cjs/rules/relay-edge-types.js +212 -0
  81. package/cjs/rules/relay-page-info.d.ts +12 -0
  82. package/cjs/rules/relay-page-info.js +121 -0
  83. package/cjs/rules/require-deprecation-date.d.ts +26 -0
  84. package/cjs/rules/require-deprecation-date.js +164 -0
  85. package/cjs/rules/require-deprecation-reason.d.ts +12 -0
  86. package/cjs/rules/require-deprecation-reason.js +93 -0
  87. package/cjs/rules/require-description.d.ts +23 -0
  88. package/cjs/rules/require-description.js +205 -0
  89. package/cjs/rules/require-field-of-type-query-in-mutation-result.d.ts +12 -0
  90. package/cjs/rules/require-field-of-type-query-in-mutation-result.js +102 -0
  91. package/cjs/rules/require-id-when-available.d.ts +44 -0
  92. package/cjs/rules/require-id-when-available.js +241 -0
  93. package/cjs/rules/require-import-fragment.d.ts +12 -0
  94. package/cjs/rules/require-import-fragment.js +166 -0
  95. package/cjs/rules/require-nullable-fields-with-oneof.d.ts +12 -0
  96. package/cjs/rules/require-nullable-fields-with-oneof.js +92 -0
  97. package/cjs/rules/require-nullable-result-in-root.d.ts +12 -0
  98. package/cjs/rules/require-nullable-result-in-root.js +109 -0
  99. package/cjs/rules/require-type-pattern-with-oneof.d.ts +12 -0
  100. package/cjs/rules/require-type-pattern-with-oneof.js +91 -0
  101. package/cjs/rules/selection-set-depth.d.ts +36 -0
  102. package/cjs/rules/selection-set-depth.js +175 -0
  103. package/cjs/rules/strict-id-in-types.d.ts +65 -0
  104. package/cjs/rules/strict-id-in-types.js +186 -0
  105. package/cjs/rules/unique-fragment-name.d.ts +13 -0
  106. package/cjs/rules/unique-fragment-name.js +118 -0
  107. package/cjs/rules/unique-operation-name.d.ts +12 -0
  108. package/cjs/rules/unique-operation-name.js +95 -0
  109. package/cjs/schema.d.ts +12 -0
  110. package/cjs/schema.js +65 -0
  111. package/cjs/siblings.d.ts +8 -0
  112. package/cjs/siblings.js +136 -0
  113. package/cjs/types-8d5f4ae0.d.ts +107 -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 +205 -0
  118. package/esm/cache.d.mts +12 -0
  119. package/esm/cache.js +29 -0
  120. package/esm/chunk-BMTV3EA2.js +8 -0
  121. package/esm/configs/index.d.mts +148 -0
  122. package/esm/configs/index.js +16 -0
  123. package/esm/configs/operations-all.d.mts +22 -0
  124. package/esm/configs/operations-all.js +34 -0
  125. package/esm/configs/operations-recommended.d.mts +52 -0
  126. package/esm/configs/operations-recommended.js +59 -0
  127. package/esm/configs/relay.d.mts +12 -0
  128. package/esm/configs/relay.js +18 -0
  129. package/esm/configs/schema-all.d.mts +19 -0
  130. package/esm/configs/schema-all.js +28 -0
  131. package/esm/configs/schema-recommended.d.mts +49 -0
  132. package/esm/configs/schema-recommended.js +55 -0
  133. package/esm/documents.d.mts +6 -0
  134. package/esm/documents.js +48 -0
  135. package/esm/estree-converter/converter.d.mts +8 -0
  136. package/esm/estree-converter/converter.js +65 -0
  137. package/esm/estree-converter/index.d.mts +8 -0
  138. package/esm/estree-converter/index.js +3 -0
  139. package/esm/estree-converter/types.d.mts +42 -0
  140. package/esm/estree-converter/types.js +0 -0
  141. package/esm/estree-converter/utils.d.mts +18 -0
  142. package/esm/estree-converter/utils.js +114 -0
  143. package/esm/flat-configs.d.mts +260 -0
  144. package/esm/flat-configs.js +37 -0
  145. package/esm/graphql-config.d.mts +13 -0
  146. package/esm/graphql-config.js +55 -0
  147. package/esm/index.d.mts +22 -0
  148. package/esm/index.js +18 -0
  149. package/esm/package.json +1 -0
  150. package/esm/parser.d.mts +12 -0
  151. package/esm/parser.js +70 -0
  152. package/esm/processor.d.mts +9 -0
  153. package/esm/processor.js +106 -0
  154. package/esm/rules/alphabetize.d.mts +84 -0
  155. package/esm/rules/alphabetize.js +364 -0
  156. package/esm/rules/description-style.d.mts +28 -0
  157. package/esm/rules/description-style.js +86 -0
  158. package/esm/rules/graphql-js-validation.d.mts +12 -0
  159. package/esm/rules/graphql-js-validation.js +658 -0
  160. package/esm/rules/index.d.mts +125 -0
  161. package/esm/rules/index.js +76 -0
  162. package/esm/rules/input-name.d.mts +43 -0
  163. package/esm/rules/input-name.js +149 -0
  164. package/esm/rules/lone-executable-definition.d.mts +34 -0
  165. package/esm/rules/lone-executable-definition.js +96 -0
  166. package/esm/rules/match-document-filename.d.mts +80 -0
  167. package/esm/rules/match-document-filename.js +263 -0
  168. package/esm/rules/naming-convention.d.mts +107 -0
  169. package/esm/rules/naming-convention.js +417 -0
  170. package/esm/rules/no-anonymous-operations.d.mts +12 -0
  171. package/esm/rules/no-anonymous-operations.js +75 -0
  172. package/esm/rules/no-case-insensitive-enum-values-duplicates.d.mts +12 -0
  173. package/esm/rules/no-case-insensitive-enum-values-duplicates.js +73 -0
  174. package/esm/rules/no-deprecated.d.mts +12 -0
  175. package/esm/rules/no-deprecated.js +134 -0
  176. package/esm/rules/no-duplicate-fields.d.mts +12 -0
  177. package/esm/rules/no-duplicate-fields.js +123 -0
  178. package/esm/rules/no-hashtag-description.d.mts +13 -0
  179. package/esm/rules/no-hashtag-description.js +116 -0
  180. package/esm/rules/no-one-place-fragments.d.mts +12 -0
  181. package/esm/rules/no-one-place-fragments.js +90 -0
  182. package/esm/rules/no-root-type.d.mts +33 -0
  183. package/esm/rules/no-root-type.js +90 -0
  184. package/esm/rules/no-scalar-result-type-on-mutation.d.mts +12 -0
  185. package/esm/rules/no-scalar-result-type-on-mutation.js +77 -0
  186. package/esm/rules/no-typename-prefix.d.mts +12 -0
  187. package/esm/rules/no-typename-prefix.js +75 -0
  188. package/esm/rules/no-unreachable-types.d.mts +12 -0
  189. package/esm/rules/no-unreachable-types.js +171 -0
  190. package/esm/rules/no-unused-fields.d.mts +12 -0
  191. package/esm/rules/no-unused-fields.js +134 -0
  192. package/esm/rules/relay-arguments.d.mts +29 -0
  193. package/esm/rules/relay-arguments.js +126 -0
  194. package/esm/rules/relay-connection-types.d.mts +13 -0
  195. package/esm/rules/relay-connection-types.js +118 -0
  196. package/esm/rules/relay-edge-types.d.mts +39 -0
  197. package/esm/rules/relay-edge-types.js +194 -0
  198. package/esm/rules/relay-page-info.d.mts +12 -0
  199. package/esm/rules/relay-page-info.js +98 -0
  200. package/esm/rules/require-deprecation-date.d.mts +26 -0
  201. package/esm/rules/require-deprecation-date.js +141 -0
  202. package/esm/rules/require-deprecation-reason.d.mts +12 -0
  203. package/esm/rules/require-deprecation-reason.js +70 -0
  204. package/esm/rules/require-description.d.mts +23 -0
  205. package/esm/rules/require-description.js +186 -0
  206. package/esm/rules/require-field-of-type-query-in-mutation-result.d.mts +12 -0
  207. package/esm/rules/require-field-of-type-query-in-mutation-result.js +79 -0
  208. package/esm/rules/require-id-when-available.d.mts +44 -0
  209. package/esm/rules/require-id-when-available.js +231 -0
  210. package/esm/rules/require-import-fragment.d.mts +12 -0
  211. package/esm/rules/require-import-fragment.js +133 -0
  212. package/esm/rules/require-nullable-fields-with-oneof.d.mts +12 -0
  213. package/esm/rules/require-nullable-fields-with-oneof.js +69 -0
  214. package/esm/rules/require-nullable-result-in-root.d.mts +12 -0
  215. package/esm/rules/require-nullable-result-in-root.js +86 -0
  216. package/esm/rules/require-type-pattern-with-oneof.d.mts +12 -0
  217. package/esm/rules/require-type-pattern-with-oneof.js +68 -0
  218. package/esm/rules/selection-set-depth.d.mts +36 -0
  219. package/esm/rules/selection-set-depth.js +142 -0
  220. package/esm/rules/strict-id-in-types.d.mts +65 -0
  221. package/esm/rules/strict-id-in-types.js +169 -0
  222. package/esm/rules/unique-fragment-name.d.mts +13 -0
  223. package/esm/rules/unique-fragment-name.js +94 -0
  224. package/esm/rules/unique-operation-name.d.mts +12 -0
  225. package/esm/rules/unique-operation-name.js +72 -0
  226. package/esm/schema.d.mts +12 -0
  227. package/esm/schema.js +32 -0
  228. package/esm/siblings.d.mts +8 -0
  229. package/esm/siblings.js +116 -0
  230. package/esm/types-ace77d86.d.ts +107 -0
  231. package/esm/types.d.mts +8 -0
  232. package/esm/types.js +0 -0
  233. package/esm/utils.d.mts +44 -0
  234. package/esm/utils.js +155 -0
  235. package/package.json +47 -34
  236. package/configs/base.json +0 -4
  237. package/configs/operations-all.json +0 -24
  238. package/configs/schema-all.json +0 -26
  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/sibling-operations.d.ts +0 -21
  345. package/testkit.d.ts +0 -27
  346. package/types.d.ts +0 -79
  347. package/utils.d.ts +0 -39
@@ -0,0 +1,134 @@
1
+ import "../chunk-BMTV3EA2.js";
2
+ import { Kind } from "graphql";
3
+ import { requireGraphQLSchemaFromContext } from "../utils.js";
4
+ const RULE_ID = "no-deprecated";
5
+ const rule = {
6
+ meta: {
7
+ type: "suggestion",
8
+ hasSuggestions: true,
9
+ docs: {
10
+ category: "Operations",
11
+ description: "Enforce that deprecated fields or enum values are not in use by operations.",
12
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
13
+ requiresSchema: true,
14
+ examples: [
15
+ {
16
+ title: "Incorrect (field)",
17
+ code: (
18
+ /* GraphQL */
19
+ `
20
+ # In your schema
21
+ type User {
22
+ id: ID!
23
+ name: String! @deprecated(reason: "old field, please use fullName instead")
24
+ fullName: String!
25
+ }
26
+
27
+ # Query
28
+ query user {
29
+ user {
30
+ name # This is deprecated, so you'll get an error
31
+ }
32
+ }
33
+ `
34
+ )
35
+ },
36
+ {
37
+ title: "Incorrect (enum value)",
38
+ code: (
39
+ /* GraphQL */
40
+ `
41
+ # In your schema
42
+ type Mutation {
43
+ changeSomething(type: SomeType): Boolean!
44
+ }
45
+
46
+ enum SomeType {
47
+ NEW
48
+ OLD @deprecated(reason: "old field, please use NEW instead")
49
+ }
50
+
51
+ # Mutation
52
+ mutation {
53
+ changeSomething(
54
+ type: OLD # This is deprecated, so you'll get an error
55
+ ) {
56
+ ...
57
+ }
58
+ }
59
+ `
60
+ )
61
+ },
62
+ {
63
+ title: "Correct",
64
+ code: (
65
+ /* GraphQL */
66
+ `
67
+ # In your schema
68
+ type User {
69
+ id: ID!
70
+ name: String! @deprecated(reason: "old field, please use fullName instead")
71
+ fullName: String!
72
+ }
73
+
74
+ # Query
75
+ query user {
76
+ user {
77
+ id
78
+ fullName
79
+ }
80
+ }
81
+ `
82
+ )
83
+ }
84
+ ],
85
+ recommended: true
86
+ },
87
+ messages: {
88
+ [RULE_ID]: "This {{ type }} is marked as deprecated in your GraphQL schema (reason: {{ reason }})"
89
+ },
90
+ schema: []
91
+ },
92
+ create(context) {
93
+ requireGraphQLSchemaFromContext(RULE_ID, context);
94
+ function report(node, reason) {
95
+ const nodeName = node.kind === Kind.ENUM ? node.value : node.name.value;
96
+ const nodeType = node.kind === Kind.ENUM ? "enum value" : "field";
97
+ context.report({
98
+ node,
99
+ messageId: RULE_ID,
100
+ data: {
101
+ type: nodeType,
102
+ reason
103
+ },
104
+ suggest: [
105
+ {
106
+ desc: `Remove \`${nodeName}\` ${nodeType}`,
107
+ fix: (fixer) => fixer.remove(node)
108
+ }
109
+ ]
110
+ });
111
+ }
112
+ return {
113
+ EnumValue(node) {
114
+ var _a;
115
+ const typeInfo = node.typeInfo();
116
+ const reason = (_a = typeInfo.enumValue) == null ? void 0 : _a.deprecationReason;
117
+ if (reason) {
118
+ report(node, reason);
119
+ }
120
+ },
121
+ Field(node) {
122
+ var _a;
123
+ const typeInfo = node.typeInfo();
124
+ const reason = (_a = typeInfo.fieldDef) == null ? void 0 : _a.deprecationReason;
125
+ if (reason) {
126
+ report(node, reason);
127
+ }
128
+ }
129
+ };
130
+ }
131
+ };
132
+ export {
133
+ rule
134
+ };
@@ -0,0 +1,12 @@
1
+ import { f as GraphQLESLintRule } from '../types-ace77d86.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 };
@@ -0,0 +1,123 @@
1
+ import "../chunk-BMTV3EA2.js";
2
+ import { Kind } from "graphql";
3
+ const RULE_ID = "no-duplicate-fields";
4
+ const rule = {
5
+ meta: {
6
+ type: "suggestion",
7
+ hasSuggestions: true,
8
+ docs: {
9
+ description: "Checks for duplicate fields in selection set, variables in operation definition, or in arguments set of a field.",
10
+ category: "Operations",
11
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
12
+ recommended: true,
13
+ examples: [
14
+ {
15
+ title: "Incorrect",
16
+ code: (
17
+ /* GraphQL */
18
+ `
19
+ query {
20
+ user {
21
+ name
22
+ email
23
+ name # duplicate field
24
+ }
25
+ }
26
+ `
27
+ )
28
+ },
29
+ {
30
+ title: "Incorrect",
31
+ code: (
32
+ /* GraphQL */
33
+ `
34
+ query {
35
+ users(
36
+ first: 100
37
+ skip: 50
38
+ after: "cji629tngfgou0b73kt7vi5jo"
39
+ first: 100 # duplicate argument
40
+ ) {
41
+ id
42
+ }
43
+ }
44
+ `
45
+ )
46
+ },
47
+ {
48
+ title: "Incorrect",
49
+ code: (
50
+ /* GraphQL */
51
+ `
52
+ query (
53
+ $first: Int!
54
+ $first: Int! # duplicate variable
55
+ ) {
56
+ users(first: $first, skip: 50) {
57
+ id
58
+ }
59
+ }
60
+ `
61
+ )
62
+ }
63
+ ]
64
+ },
65
+ messages: {
66
+ [RULE_ID]: "{{ type }} `{{ fieldName }}` defined multiple times."
67
+ },
68
+ schema: []
69
+ },
70
+ create(context) {
71
+ function checkNode(usedFields, node) {
72
+ const fieldName = node.value;
73
+ if (usedFields.has(fieldName)) {
74
+ const { parent } = node;
75
+ context.report({
76
+ node,
77
+ messageId: RULE_ID,
78
+ data: {
79
+ type: parent.type,
80
+ fieldName
81
+ },
82
+ suggest: [
83
+ {
84
+ desc: `Remove \`${fieldName}\` ${parent.type.toLowerCase()}`,
85
+ fix(fixer) {
86
+ return fixer.remove(
87
+ parent.type === Kind.VARIABLE ? parent.parent : parent
88
+ );
89
+ }
90
+ }
91
+ ]
92
+ });
93
+ } else {
94
+ usedFields.add(fieldName);
95
+ }
96
+ }
97
+ return {
98
+ OperationDefinition(node) {
99
+ const set = /* @__PURE__ */ new Set();
100
+ for (const varDef of node.variableDefinitions || []) {
101
+ checkNode(set, varDef.variable.name);
102
+ }
103
+ },
104
+ Field(node) {
105
+ const set = /* @__PURE__ */ new Set();
106
+ for (const arg of node.arguments || []) {
107
+ checkNode(set, arg.name);
108
+ }
109
+ },
110
+ SelectionSet(node) {
111
+ const set = /* @__PURE__ */ new Set();
112
+ for (const selection of node.selections) {
113
+ if (selection.kind === Kind.FIELD) {
114
+ checkNode(set, selection.alias || selection.name);
115
+ }
116
+ }
117
+ }
118
+ };
119
+ }
120
+ };
121
+ export {
122
+ rule
123
+ };
@@ -0,0 +1,13 @@
1
+ import { f as GraphQLESLintRule } from '../types-ace77d86.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_ID = "HASHTAG_COMMENT";
11
+ declare const rule: GraphQLESLintRule;
12
+
13
+ export { RULE_ID, rule };
@@ -0,0 +1,116 @@
1
+ import "../chunk-BMTV3EA2.js";
2
+ import { TokenKind } from "graphql";
3
+ import { getNodeName } from "../utils.js";
4
+ const RULE_ID = "HASHTAG_COMMENT";
5
+ const rule = {
6
+ meta: {
7
+ type: "suggestion",
8
+ hasSuggestions: true,
9
+ schema: [],
10
+ messages: {
11
+ [RULE_ID]: 'Unexpected GraphQL descriptions as hashtag `#` for {{ nodeName }}.\nPrefer using `"""` for multiline, or `"` for a single line description.'
12
+ },
13
+ docs: {
14
+ description: 'Requires to use `"""` or `"` for adding a GraphQL description instead of `#`.\nAllows to use hashtag for comments, as long as it\'s not attached to an AST definition.',
15
+ category: "Schema",
16
+ url: "https://the-guild.dev/graphql/eslint/rules/no-hashtag-description",
17
+ examples: [
18
+ {
19
+ title: "Incorrect",
20
+ code: (
21
+ /* GraphQL */
22
+ `
23
+ # Represents a user
24
+ type User {
25
+ id: ID!
26
+ name: String
27
+ }
28
+ `
29
+ )
30
+ },
31
+ {
32
+ title: "Correct",
33
+ code: (
34
+ /* GraphQL */
35
+ `
36
+ " Represents a user "
37
+ type User {
38
+ id: ID!
39
+ name: String
40
+ }
41
+ `
42
+ )
43
+ },
44
+ {
45
+ title: "Correct",
46
+ code: (
47
+ /* GraphQL */
48
+ `
49
+ # This file defines the basic User type.
50
+ # This comment is valid because it's not attached specifically to an AST object.
51
+
52
+ " Represents a user "
53
+ type User {
54
+ id: ID! # This one is also valid, since it comes after the AST object
55
+ name: String
56
+ }
57
+ `
58
+ )
59
+ }
60
+ ],
61
+ recommended: true
62
+ }
63
+ },
64
+ create(context) {
65
+ const selector = "Document[definitions.0.kind!=/^(OperationDefinition|FragmentDefinition)$/]";
66
+ return {
67
+ [selector](node) {
68
+ const rawNode = node.rawNode();
69
+ let token = rawNode.loc.startToken;
70
+ while (token) {
71
+ const { kind, prev, next, value, line, column } = token;
72
+ if (kind === TokenKind.COMMENT && prev && next) {
73
+ const isEslintComment = value.trimStart().startsWith("eslint");
74
+ const linesAfter = next.line - line;
75
+ if (!isEslintComment && line !== prev.line && next.kind === TokenKind.NAME && linesAfter < 2) {
76
+ const sourceCode = context.getSourceCode();
77
+ const { tokens } = sourceCode.ast;
78
+ const t = tokens.find(
79
+ (token2) => token2.loc.start.line === next.line && token2.loc.start.column === next.column - 1
80
+ );
81
+ const nextNode = sourceCode.getNodeByRangeIndex(t.range[1] + 1);
82
+ context.report({
83
+ messageId: RULE_ID,
84
+ data: {
85
+ nodeName: getNodeName(
86
+ "name" in nextNode ? nextNode : nextNode.parent
87
+ )
88
+ },
89
+ loc: {
90
+ line,
91
+ column: column - 1
92
+ },
93
+ suggest: ['"""', '"'].map((descriptionSyntax) => ({
94
+ desc: `Replace with \`${descriptionSyntax}\` description syntax`,
95
+ fix: (fixer) => fixer.replaceTextRange(
96
+ [token.start, token.end],
97
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion -- TODO: remove `!` when drop support of graphql@15
98
+ [descriptionSyntax, value.trim(), descriptionSyntax].join("")
99
+ )
100
+ }))
101
+ });
102
+ }
103
+ }
104
+ if (!next) {
105
+ break;
106
+ }
107
+ token = next;
108
+ }
109
+ }
110
+ };
111
+ }
112
+ };
113
+ export {
114
+ RULE_ID,
115
+ rule
116
+ };
@@ -0,0 +1,12 @@
1
+ import { f as GraphQLESLintRule } from '../types-ace77d86.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 };
@@ -0,0 +1,90 @@
1
+ import "../chunk-BMTV3EA2.js";
2
+ import { relative } from "path";
3
+ import { visit } from "graphql";
4
+ import { CWD, requireSiblingsOperations } from "../utils.js";
5
+ const RULE_ID = "no-one-place-fragments";
6
+ const rule = {
7
+ meta: {
8
+ type: "suggestion",
9
+ docs: {
10
+ category: "Operations",
11
+ description: "Disallow fragments that are used only in one place.",
12
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
13
+ examples: [
14
+ {
15
+ title: "Incorrect",
16
+ code: (
17
+ /* GraphQL */
18
+ `
19
+ fragment UserFields on User {
20
+ id
21
+ }
22
+
23
+ {
24
+ user {
25
+ ...UserFields
26
+ }
27
+ }
28
+ `
29
+ )
30
+ },
31
+ {
32
+ title: "Correct",
33
+ code: (
34
+ /* GraphQL */
35
+ `
36
+ fragment UserFields on User {
37
+ id
38
+ }
39
+
40
+ {
41
+ user {
42
+ ...UserFields
43
+ friends {
44
+ ...UserFields
45
+ }
46
+ }
47
+ }
48
+ `
49
+ )
50
+ }
51
+ ],
52
+ requiresSiblings: true
53
+ },
54
+ messages: {
55
+ [RULE_ID]: 'Fragment `{{fragmentName}}` used only once. Inline him in "{{filePath}}".'
56
+ },
57
+ schema: []
58
+ },
59
+ create(context) {
60
+ const operations = requireSiblingsOperations(RULE_ID, context);
61
+ const allDocuments = [...operations.getOperations(), ...operations.getFragments()];
62
+ const usedFragmentsMap = /* @__PURE__ */ Object.create(null);
63
+ for (const { document, filePath } of allDocuments) {
64
+ const relativeFilePath = relative(CWD, filePath);
65
+ visit(document, {
66
+ FragmentSpread({ name }) {
67
+ const spreadName = name.value;
68
+ usedFragmentsMap[spreadName] || (usedFragmentsMap[spreadName] = []);
69
+ usedFragmentsMap[spreadName].push(relativeFilePath);
70
+ }
71
+ });
72
+ }
73
+ return {
74
+ "FragmentDefinition > Name"(node) {
75
+ const fragmentName = node.value;
76
+ const fragmentUsage = usedFragmentsMap[fragmentName];
77
+ if (fragmentUsage.length === 1) {
78
+ context.report({
79
+ node,
80
+ messageId: RULE_ID,
81
+ data: { fragmentName, filePath: fragmentUsage[0] }
82
+ });
83
+ }
84
+ }
85
+ };
86
+ }
87
+ };
88
+ export {
89
+ rule
90
+ };
@@ -0,0 +1,33 @@
1
+ import { FromSchema } from 'json-schema-to-ts';
2
+ import { f as GraphQLESLintRule } from '../types-ace77d86.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
+
10
+ declare const schema: {
11
+ readonly type: "array";
12
+ readonly minItems: 1;
13
+ readonly maxItems: 1;
14
+ readonly items: {
15
+ readonly type: "object";
16
+ readonly additionalProperties: false;
17
+ readonly required: readonly ["disallow"];
18
+ readonly properties: {
19
+ readonly disallow: {
20
+ readonly items: {
21
+ readonly enum: readonly ["mutation", "subscription"];
22
+ };
23
+ readonly type: "array";
24
+ readonly uniqueItems: true;
25
+ readonly minItems: 1;
26
+ };
27
+ };
28
+ };
29
+ };
30
+ type RuleOptions = FromSchema<typeof schema>;
31
+ declare const rule: GraphQLESLintRule<RuleOptions>;
32
+
33
+ export { RuleOptions, rule };
@@ -0,0 +1,90 @@
1
+ import "../chunk-BMTV3EA2.js";
2
+ import { ARRAY_DEFAULT_OPTIONS, requireGraphQLSchemaFromContext, truthy } from "../utils.js";
3
+ const schema = {
4
+ type: "array",
5
+ minItems: 1,
6
+ maxItems: 1,
7
+ items: {
8
+ type: "object",
9
+ additionalProperties: false,
10
+ required: ["disallow"],
11
+ properties: {
12
+ disallow: {
13
+ ...ARRAY_DEFAULT_OPTIONS,
14
+ items: {
15
+ enum: ["mutation", "subscription"]
16
+ }
17
+ }
18
+ }
19
+ }
20
+ };
21
+ const rule = {
22
+ meta: {
23
+ type: "suggestion",
24
+ hasSuggestions: true,
25
+ docs: {
26
+ category: "Schema",
27
+ description: "Disallow using root types `mutation` and/or `subscription`.",
28
+ url: "https://the-guild.dev/graphql/eslint/rules/no-root-type",
29
+ requiresSchema: true,
30
+ isDisabledForAllConfig: true,
31
+ examples: [
32
+ {
33
+ title: "Incorrect",
34
+ usage: [{ disallow: ["mutation", "subscription"] }],
35
+ code: (
36
+ /* GraphQL */
37
+ `
38
+ type Mutation {
39
+ createUser(input: CreateUserInput!): User!
40
+ }
41
+ `
42
+ )
43
+ },
44
+ {
45
+ title: "Correct",
46
+ usage: [{ disallow: ["mutation", "subscription"] }],
47
+ code: (
48
+ /* GraphQL */
49
+ `
50
+ type Query {
51
+ users: [User!]!
52
+ }
53
+ `
54
+ )
55
+ }
56
+ ]
57
+ },
58
+ schema
59
+ },
60
+ create(context) {
61
+ const schema2 = requireGraphQLSchemaFromContext("no-root-type", context);
62
+ const disallow = new Set(context.options[0].disallow);
63
+ const rootTypeNames = [
64
+ disallow.has("mutation") && schema2.getMutationType(),
65
+ disallow.has("subscription") && schema2.getSubscriptionType()
66
+ ].filter(truthy).map((type) => type.name).join("|");
67
+ if (!rootTypeNames) {
68
+ return {};
69
+ }
70
+ const selector = `:matches(ObjectTypeDefinition, ObjectTypeExtension) > .name[value=/^(${rootTypeNames})$/]`;
71
+ return {
72
+ [selector](node) {
73
+ const typeName = node.value;
74
+ context.report({
75
+ node,
76
+ message: `Root type \`${typeName}\` is forbidden.`,
77
+ suggest: [
78
+ {
79
+ desc: `Remove \`${typeName}\` type`,
80
+ fix: (fixer) => fixer.remove(node.parent)
81
+ }
82
+ ]
83
+ });
84
+ }
85
+ };
86
+ }
87
+ };
88
+ export {
89
+ rule
90
+ };
@@ -0,0 +1,12 @@
1
+ import { f as GraphQLESLintRule } from '../types-ace77d86.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 };