@graphql-eslint/eslint-plugin 3.19.3-alpha-20230702093957-98f7783 → 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,63 +1,75 @@
1
- import { getRootTypeNames } from '@graphql-tools/utils';
2
- import { Kind, TokenKind } from 'graphql';
3
- import { getLocation, getNodeName, requireGraphQLSchemaFromContext, TYPES_KINDS, } from '../utils.js';
4
- export const RULE_ID = 'require-description';
1
+ import { getRootTypeNames } from "@graphql-tools/utils";
2
+ import { Kind, TokenKind } from "graphql";
3
+ import {
4
+ getLocation,
5
+ getNodeName,
6
+ requireGraphQLSchemaFromContext,
7
+ TYPES_KINDS
8
+ } from "../utils.js";
9
+ const RULE_ID = "require-description";
5
10
  const ALLOWED_KINDS = [
6
- ...TYPES_KINDS,
7
- Kind.DIRECTIVE_DEFINITION,
8
- Kind.FIELD_DEFINITION,
9
- Kind.INPUT_VALUE_DEFINITION,
10
- Kind.ENUM_VALUE_DEFINITION,
11
- Kind.OPERATION_DEFINITION,
11
+ ...TYPES_KINDS,
12
+ Kind.DIRECTIVE_DEFINITION,
13
+ Kind.FIELD_DEFINITION,
14
+ Kind.INPUT_VALUE_DEFINITION,
15
+ Kind.ENUM_VALUE_DEFINITION,
16
+ Kind.OPERATION_DEFINITION
12
17
  ];
13
18
  const schema = {
14
- type: 'array',
15
- minItems: 1,
16
- maxItems: 1,
17
- items: {
18
- type: 'object',
19
- additionalProperties: false,
20
- minProperties: 1,
21
- properties: {
22
- types: {
23
- type: 'boolean',
24
- description: `Includes:\n${TYPES_KINDS.map(kind => `- \`${kind}\``).join('\n')}`,
25
- },
26
- rootField: {
27
- type: 'boolean',
28
- description: 'Definitions within `Query`, `Mutation`, and `Subscription` root types.',
29
- },
30
- ...Object.fromEntries([...ALLOWED_KINDS].sort().map(kind => {
31
- let description = `Read more about this kind on [spec.graphql.org](https://spec.graphql.org/October2021/#${kind}).`;
32
- if (kind === Kind.OPERATION_DEFINITION) {
33
- description +=
34
- '\n> You must use only comment syntax `#` and not description syntax `"""` or `"`.';
35
- }
36
- return [kind, { type: 'boolean', description }];
37
- })),
38
- },
39
- },
19
+ type: "array",
20
+ minItems: 1,
21
+ maxItems: 1,
22
+ items: {
23
+ type: "object",
24
+ additionalProperties: false,
25
+ minProperties: 1,
26
+ properties: {
27
+ types: {
28
+ type: "boolean",
29
+ description: `Includes:
30
+ ${TYPES_KINDS.map((kind) => `- \`${kind}\``).join("\n")}`
31
+ },
32
+ rootField: {
33
+ type: "boolean",
34
+ description: "Definitions within `Query`, `Mutation`, and `Subscription` root types."
35
+ },
36
+ ...Object.fromEntries(
37
+ [...ALLOWED_KINDS].sort().map((kind) => {
38
+ let description = `Read more about this kind on [spec.graphql.org](https://spec.graphql.org/October2021/#${kind}).`;
39
+ if (kind === Kind.OPERATION_DEFINITION) {
40
+ description += '\n> You must use only comment syntax `#` and not description syntax `"""` or `"`.';
41
+ }
42
+ return [kind, { type: "boolean", description }];
43
+ })
44
+ )
45
+ }
46
+ }
40
47
  };
41
- export const rule = {
42
- meta: {
43
- docs: {
44
- category: 'Schema',
45
- description: 'Enforce descriptions in type definitions and operations.',
46
- url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
47
- examples: [
48
- {
49
- title: 'Incorrect',
50
- usage: [{ types: true, FieldDefinition: true }],
51
- code: /* GraphQL */ `
48
+ const rule = {
49
+ meta: {
50
+ docs: {
51
+ category: "Schema",
52
+ description: "Enforce descriptions in type definitions and operations.",
53
+ url: `https://the-guild.dev/graphql/eslint/rules/${RULE_ID}`,
54
+ examples: [
55
+ {
56
+ title: "Incorrect",
57
+ usage: [{ types: true, FieldDefinition: true }],
58
+ code: (
59
+ /* GraphQL */
60
+ `
52
61
  type someTypeName {
53
62
  name: String
54
63
  }
55
- `,
56
- },
57
- {
58
- title: 'Correct',
59
- usage: [{ types: true, FieldDefinition: true }],
60
- code: /* GraphQL */ `
64
+ `
65
+ )
66
+ },
67
+ {
68
+ title: "Correct",
69
+ usage: [{ types: true, FieldDefinition: true }],
70
+ code: (
71
+ /* GraphQL */
72
+ `
61
73
  """
62
74
  Some type description
63
75
  """
@@ -67,22 +79,28 @@ export const rule = {
67
79
  """
68
80
  name: String
69
81
  }
70
- `,
71
- },
72
- {
73
- title: 'Correct',
74
- usage: [{ OperationDefinition: true }],
75
- code: /* GraphQL */ `
82
+ `
83
+ )
84
+ },
85
+ {
86
+ title: "Correct",
87
+ usage: [{ OperationDefinition: true }],
88
+ code: (
89
+ /* GraphQL */
90
+ `
76
91
  # Create a new user
77
92
  mutation createUser {
78
93
  # ...
79
94
  }
80
- `,
81
- },
82
- {
83
- title: 'Correct',
84
- usage: [{ rootField: true }],
85
- code: /* GraphQL */ `
95
+ `
96
+ )
97
+ },
98
+ {
99
+ title: "Correct",
100
+ usage: [{ rootField: true }],
101
+ code: (
102
+ /* GraphQL */
103
+ `
86
104
  type Mutation {
87
105
  "Create a new user"
88
106
  createUser: User
@@ -91,73 +109,76 @@ export const rule = {
91
109
  type User {
92
110
  name: String
93
111
  }
94
- `,
95
- },
96
- ],
97
- configOptions: [
98
- {
99
- types: true,
100
- [Kind.DIRECTIVE_DEFINITION]: true,
101
- // rootField: true TODO enable in graphql-eslint v4
102
- },
103
- ],
104
- recommended: true,
105
- },
106
- type: 'suggestion',
107
- messages: {
108
- [RULE_ID]: 'Description is required for {{ nodeName }}',
109
- },
110
- schema,
112
+ `
113
+ )
114
+ }
115
+ ],
116
+ configOptions: [
117
+ {
118
+ types: true,
119
+ [Kind.DIRECTIVE_DEFINITION]: true
120
+ // rootField: true TODO enable in graphql-eslint v4
121
+ }
122
+ ],
123
+ recommended: true
111
124
  },
112
- create(context) {
113
- const { types, rootField, ...restOptions } = context.options[0] || {};
114
- const kinds = new Set(types ? TYPES_KINDS : []);
115
- for (const [kind, isEnabled] of Object.entries(restOptions)) {
116
- if (isEnabled) {
117
- kinds.add(kind);
118
- }
119
- else {
120
- kinds.delete(kind);
125
+ type: "suggestion",
126
+ messages: {
127
+ [RULE_ID]: "Description is required for {{ nodeName }}"
128
+ },
129
+ schema
130
+ },
131
+ create(context) {
132
+ const { types, rootField, ...restOptions } = context.options[0] || {};
133
+ const kinds = new Set(types ? TYPES_KINDS : []);
134
+ for (const [kind, isEnabled] of Object.entries(restOptions)) {
135
+ if (isEnabled) {
136
+ kinds.add(kind);
137
+ } else {
138
+ kinds.delete(kind);
139
+ }
140
+ }
141
+ if (rootField) {
142
+ const schema2 = requireGraphQLSchemaFromContext(RULE_ID, context);
143
+ const rootTypeNames = getRootTypeNames(schema2);
144
+ kinds.add(
145
+ `:matches(ObjectTypeDefinition, ObjectTypeExtension)[name.value=/^(${[
146
+ ...rootTypeNames
147
+ ].join(",")})$/] > FieldDefinition`
148
+ );
149
+ }
150
+ const selector = [...kinds].join(",");
151
+ return {
152
+ [selector](node) {
153
+ let description = "";
154
+ const isOperation = node.kind === Kind.OPERATION_DEFINITION;
155
+ if (isOperation) {
156
+ const rawNode = node.rawNode();
157
+ const { prev, line } = rawNode.loc.startToken;
158
+ if (prev?.kind === TokenKind.COMMENT) {
159
+ const value = prev.value.trim();
160
+ const linesBefore = line - prev.line;
161
+ if (!value.startsWith("eslint") && linesBefore === 1) {
162
+ description = value;
121
163
  }
164
+ }
165
+ } else {
166
+ description = node.description?.value.trim() || "";
122
167
  }
123
- if (rootField) {
124
- const schema = requireGraphQLSchemaFromContext(RULE_ID, context);
125
- const rootTypeNames = getRootTypeNames(schema);
126
- kinds.add(`:matches(ObjectTypeDefinition, ObjectTypeExtension)[name.value=/^(${[
127
- ...rootTypeNames,
128
- ].join(',')})$/] > FieldDefinition`);
168
+ if (description.length === 0) {
169
+ context.report({
170
+ loc: isOperation ? getLocation(node.loc.start, node.operation) : node.name.loc,
171
+ messageId: RULE_ID,
172
+ data: {
173
+ nodeName: getNodeName(node)
174
+ }
175
+ });
129
176
  }
130
- const selector = [...kinds].join(',');
131
- return {
132
- [selector](node) {
133
- var _a;
134
- let description = '';
135
- const isOperation = node.kind === Kind.OPERATION_DEFINITION;
136
- if (isOperation) {
137
- const rawNode = node.rawNode();
138
- const { prev, line } = rawNode.loc.startToken;
139
- if ((prev === null || prev === void 0 ? void 0 : prev.kind) === TokenKind.COMMENT) {
140
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-type-assertion -- TODO: remove `!` when drop support of graphql@15
141
- const value = prev.value.trim();
142
- const linesBefore = line - prev.line;
143
- if (!value.startsWith('eslint') && linesBefore === 1) {
144
- description = value;
145
- }
146
- }
147
- }
148
- else {
149
- description = ((_a = node.description) === null || _a === void 0 ? void 0 : _a.value.trim()) || '';
150
- }
151
- if (description.length === 0) {
152
- context.report({
153
- loc: isOperation ? getLocation(node.loc.start, node.operation) : node.name.loc,
154
- messageId: RULE_ID,
155
- data: {
156
- nodeName: getNodeName(node),
157
- },
158
- });
159
- }
160
- },
161
- };
162
- },
177
+ }
178
+ };
179
+ }
180
+ };
181
+ export {
182
+ RULE_ID,
183
+ rule
163
184
  };
@@ -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,28 +1,33 @@
1
- import { isObjectType } from 'graphql';
2
- import { getTypeName, requireGraphQLSchemaFromContext } from '../utils.js';
3
- const RULE_ID = 'require-field-of-type-query-in-mutation-result';
4
- export const 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: true,
12
- examples: [
13
- {
14
- title: 'Incorrect',
15
- code: /* GraphQL */ `
1
+ import { isObjectType } from "graphql";
2
+ import { getTypeName, requireGraphQLSchemaFromContext } from "../utils.js";
3
+ const RULE_ID = "require-field-of-type-query-in-mutation-result";
4
+ const 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: true,
12
+ examples: [
13
+ {
14
+ title: "Incorrect",
15
+ code: (
16
+ /* GraphQL */
17
+ `
16
18
  type User { ... }
17
19
 
18
20
  type Mutation {
19
21
  createUser: User!
20
22
  }
21
- `,
22
- },
23
- {
24
- title: 'Correct',
25
- code: /* GraphQL */ `
23
+ `
24
+ )
25
+ },
26
+ {
27
+ title: "Correct",
28
+ code: (
29
+ /* GraphQL */
30
+ `
26
31
  type User { ... }
27
32
 
28
33
  type Query { ... }
@@ -35,35 +40,39 @@ export const rule = {
35
40
  type Mutation {
36
41
  createUser: CreateUserPayload!
37
42
  }
38
- `,
39
- },
40
- ],
41
- },
42
- schema: [],
43
- },
44
- create(context) {
45
- const schema = requireGraphQLSchemaFromContext(RULE_ID, context);
46
- const mutationType = schema.getMutationType();
47
- const queryType = schema.getQueryType();
48
- if (!mutationType || !queryType) {
49
- return {};
43
+ `
44
+ )
50
45
  }
51
- const selector = `:matches(ObjectTypeDefinition, ObjectTypeExtension)[name.value=${mutationType.name}] > FieldDefinition > .gqlType Name`;
52
- return {
53
- [selector](node) {
54
- const typeName = node.value;
55
- const graphQLType = schema.getType(typeName);
56
- if (isObjectType(graphQLType)) {
57
- const { fields } = graphQLType.astNode;
58
- const hasQueryType = fields === null || fields === void 0 ? void 0 : fields.some(field => getTypeName(field) === queryType.name);
59
- if (!hasQueryType) {
60
- context.report({
61
- node,
62
- message: `Mutation result type "${graphQLType.name}" must contain field of type "${queryType.name}"`,
63
- });
64
- }
65
- }
66
- },
67
- };
46
+ ]
68
47
  },
48
+ schema: []
49
+ },
50
+ create(context) {
51
+ const schema = requireGraphQLSchemaFromContext(RULE_ID, context);
52
+ const mutationType = schema.getMutationType();
53
+ const queryType = schema.getQueryType();
54
+ if (!mutationType || !queryType) {
55
+ return {};
56
+ }
57
+ const selector = `:matches(ObjectTypeDefinition, ObjectTypeExtension)[name.value=${mutationType.name}] > FieldDefinition > .gqlType Name`;
58
+ return {
59
+ [selector](node) {
60
+ const typeName = node.value;
61
+ const graphQLType = schema.getType(typeName);
62
+ if (isObjectType(graphQLType)) {
63
+ const { fields } = graphQLType.astNode;
64
+ const hasQueryType = fields?.some((field) => getTypeName(field) === queryType.name);
65
+ if (!hasQueryType) {
66
+ context.report({
67
+ node,
68
+ message: `Mutation result type "${graphQLType.name}" must contain field of type "${queryType.name}"`
69
+ });
70
+ }
71
+ }
72
+ }
73
+ };
74
+ }
75
+ };
76
+ export {
77
+ rule
69
78
  };
@@ -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 definitions: {
5
12
  readonly asString: {
@@ -31,6 +38,7 @@ declare const schema: {
31
38
  };
32
39
  };
33
40
  };
34
- export type RuleOptions = FromSchema<typeof schema>;
35
- export declare const rule: GraphQLESLintRule<RuleOptions, true>;
36
- export {};
41
+ type RuleOptions = FromSchema<typeof schema>;
42
+ declare const rule: GraphQLESLintRule<RuleOptions, true>;
43
+
44
+ export { RuleOptions, rule };