@gqlkit-ts/cli 0.0.1 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (362) hide show
  1. package/LICENSE +21 -0
  2. package/dist/auto-type-generator/auto-type-generator.d.ts +62 -0
  3. package/dist/auto-type-generator/auto-type-generator.d.ts.map +1 -0
  4. package/dist/auto-type-generator/auto-type-generator.js +540 -0
  5. package/dist/auto-type-generator/auto-type-generator.js.map +1 -0
  6. package/dist/auto-type-generator/index.d.ts +4 -0
  7. package/dist/auto-type-generator/index.d.ts.map +1 -0
  8. package/dist/auto-type-generator/index.js +3 -0
  9. package/dist/auto-type-generator/index.js.map +1 -0
  10. package/dist/auto-type-generator/inline-enum-collector.d.ts +31 -0
  11. package/dist/auto-type-generator/inline-enum-collector.d.ts.map +1 -0
  12. package/dist/auto-type-generator/inline-enum-collector.js +157 -0
  13. package/dist/auto-type-generator/inline-enum-collector.js.map +1 -0
  14. package/dist/auto-type-generator/name-collision-validator.d.ts +17 -0
  15. package/dist/auto-type-generator/name-collision-validator.d.ts.map +1 -0
  16. package/dist/auto-type-generator/name-collision-validator.js +68 -0
  17. package/dist/auto-type-generator/name-collision-validator.js.map +1 -0
  18. package/dist/auto-type-generator/naming-convention.d.ts +44 -0
  19. package/dist/auto-type-generator/naming-convention.d.ts.map +1 -0
  20. package/dist/auto-type-generator/naming-convention.js +67 -0
  21. package/dist/auto-type-generator/naming-convention.js.map +1 -0
  22. package/dist/cli.d.ts +2 -0
  23. package/dist/cli.d.ts.map +1 -0
  24. package/dist/cli.js +11 -0
  25. package/dist/cli.js.map +1 -0
  26. package/dist/commands/gen.d.ts +32 -0
  27. package/dist/commands/gen.d.ts.map +1 -0
  28. package/dist/commands/gen.js +101 -0
  29. package/dist/commands/gen.js.map +1 -0
  30. package/dist/commands/main.d.ts +12 -0
  31. package/dist/commands/main.d.ts.map +1 -0
  32. package/dist/commands/main.js +5 -0
  33. package/dist/commands/main.js.map +1 -0
  34. package/dist/config/define-config.d.ts +26 -0
  35. package/dist/config/define-config.d.ts.map +1 -0
  36. package/dist/config/define-config.js +27 -0
  37. package/dist/config/define-config.js.map +1 -0
  38. package/dist/config/index.d.ts +3 -0
  39. package/dist/config/index.d.ts.map +1 -0
  40. package/dist/config/index.js +2 -0
  41. package/dist/config/index.js.map +1 -0
  42. package/dist/config/types.d.ts +131 -0
  43. package/dist/config/types.d.ts.map +1 -0
  44. package/dist/config/types.js +2 -0
  45. package/dist/config/types.js.map +1 -0
  46. package/dist/config-loader/index.d.ts +3 -0
  47. package/dist/config-loader/index.d.ts.map +1 -0
  48. package/dist/config-loader/index.js +2 -0
  49. package/dist/config-loader/index.js.map +1 -0
  50. package/dist/config-loader/loader.d.ts +50 -0
  51. package/dist/config-loader/loader.d.ts.map +1 -0
  52. package/dist/config-loader/loader.js +78 -0
  53. package/dist/config-loader/loader.js.map +1 -0
  54. package/dist/config-loader/validator.d.ts +13 -0
  55. package/dist/config-loader/validator.d.ts.map +1 -0
  56. package/dist/config-loader/validator.js +497 -0
  57. package/dist/config-loader/validator.js.map +1 -0
  58. package/dist/gen-orchestrator/hook-executor/hook-executor.d.ts +25 -0
  59. package/dist/gen-orchestrator/hook-executor/hook-executor.d.ts.map +1 -0
  60. package/dist/gen-orchestrator/hook-executor/hook-executor.js +68 -0
  61. package/dist/gen-orchestrator/hook-executor/hook-executor.js.map +1 -0
  62. package/dist/gen-orchestrator/orchestrator.d.ts +30 -0
  63. package/dist/gen-orchestrator/orchestrator.d.ts.map +1 -0
  64. package/dist/gen-orchestrator/orchestrator.js +505 -0
  65. package/dist/gen-orchestrator/orchestrator.js.map +1 -0
  66. package/dist/gen-orchestrator/reporter/diagnostic-reporter.d.ts +9 -0
  67. package/dist/gen-orchestrator/reporter/diagnostic-reporter.d.ts.map +1 -0
  68. package/dist/gen-orchestrator/reporter/diagnostic-reporter.js +32 -0
  69. package/dist/gen-orchestrator/reporter/diagnostic-reporter.js.map +1 -0
  70. package/dist/gen-orchestrator/reporter/progress-reporter.d.ts +19 -0
  71. package/dist/gen-orchestrator/reporter/progress-reporter.d.ts.map +1 -0
  72. package/dist/gen-orchestrator/reporter/progress-reporter.js +38 -0
  73. package/dist/gen-orchestrator/reporter/progress-reporter.js.map +1 -0
  74. package/dist/gen-orchestrator/writer/file-writer.d.ts +13 -0
  75. package/dist/gen-orchestrator/writer/file-writer.d.ts.map +1 -0
  76. package/dist/gen-orchestrator/writer/file-writer.js +22 -0
  77. package/dist/gen-orchestrator/writer/file-writer.js.map +1 -0
  78. package/dist/index.d.ts +3 -0
  79. package/dist/index.d.ts.map +1 -0
  80. package/dist/index.js +2 -0
  81. package/dist/index.js.map +1 -0
  82. package/dist/resolver-extractor/extract-resolvers.d.ts +49 -0
  83. package/dist/resolver-extractor/extract-resolvers.d.ts.map +1 -0
  84. package/dist/resolver-extractor/extract-resolvers.js +2 -0
  85. package/dist/resolver-extractor/extract-resolvers.js.map +1 -0
  86. package/dist/resolver-extractor/extractor/define-api-extractor.d.ts +60 -0
  87. package/dist/resolver-extractor/extractor/define-api-extractor.d.ts.map +1 -0
  88. package/dist/resolver-extractor/extractor/define-api-extractor.js +509 -0
  89. package/dist/resolver-extractor/extractor/define-api-extractor.js.map +1 -0
  90. package/dist/resolver-extractor/index.d.ts +5 -0
  91. package/dist/resolver-extractor/index.d.ts.map +1 -0
  92. package/dist/resolver-extractor/index.js +2 -0
  93. package/dist/resolver-extractor/index.js.map +1 -0
  94. package/dist/resolver-extractor/validator/abstract-resolver-validator.d.ts +25 -0
  95. package/dist/resolver-extractor/validator/abstract-resolver-validator.d.ts.map +1 -0
  96. package/dist/resolver-extractor/validator/abstract-resolver-validator.js +172 -0
  97. package/dist/resolver-extractor/validator/abstract-resolver-validator.js.map +1 -0
  98. package/dist/resolver-extractor/validator/only-validator.d.ts +61 -0
  99. package/dist/resolver-extractor/validator/only-validator.d.ts.map +1 -0
  100. package/dist/resolver-extractor/validator/only-validator.js +76 -0
  101. package/dist/resolver-extractor/validator/only-validator.js.map +1 -0
  102. package/dist/schema-generator/builder/ast-builder.d.ts +7 -0
  103. package/dist/schema-generator/builder/ast-builder.d.ts.map +1 -0
  104. package/dist/schema-generator/builder/ast-builder.js +417 -0
  105. package/dist/schema-generator/builder/ast-builder.js.map +1 -0
  106. package/dist/schema-generator/emitter/code-emitter.d.ts +15 -0
  107. package/dist/schema-generator/emitter/code-emitter.d.ts.map +1 -0
  108. package/dist/schema-generator/emitter/code-emitter.js +216 -0
  109. package/dist/schema-generator/emitter/code-emitter.js.map +1 -0
  110. package/dist/schema-generator/emitter/sdl-emitter.d.ts +7 -0
  111. package/dist/schema-generator/emitter/sdl-emitter.d.ts.map +1 -0
  112. package/dist/schema-generator/emitter/sdl-emitter.js +11 -0
  113. package/dist/schema-generator/emitter/sdl-emitter.js.map +1 -0
  114. package/dist/schema-generator/generate-schema.d.ts +26 -0
  115. package/dist/schema-generator/generate-schema.d.ts.map +1 -0
  116. package/dist/schema-generator/generate-schema.js +93 -0
  117. package/dist/schema-generator/generate-schema.js.map +1 -0
  118. package/dist/schema-generator/index.d.ts +4 -0
  119. package/dist/schema-generator/index.d.ts.map +1 -0
  120. package/dist/schema-generator/index.js +2 -0
  121. package/dist/schema-generator/index.js.map +1 -0
  122. package/dist/schema-generator/integrator/result-integrator.d.ts +113 -0
  123. package/dist/schema-generator/integrator/result-integrator.d.ts.map +1 -0
  124. package/dist/schema-generator/integrator/result-integrator.js +438 -0
  125. package/dist/schema-generator/integrator/result-integrator.js.map +1 -0
  126. package/dist/schema-generator/pruner/schema-pruner.d.ts +16 -0
  127. package/dist/schema-generator/pruner/schema-pruner.d.ts.map +1 -0
  128. package/dist/schema-generator/pruner/schema-pruner.js +66 -0
  129. package/dist/schema-generator/pruner/schema-pruner.js.map +1 -0
  130. package/dist/schema-generator/resolver-collector/resolver-collector.d.ts +24 -0
  131. package/dist/schema-generator/resolver-collector/resolver-collector.d.ts.map +1 -0
  132. package/dist/schema-generator/resolver-collector/resolver-collector.js +61 -0
  133. package/dist/schema-generator/resolver-collector/resolver-collector.js.map +1 -0
  134. package/dist/shared/constants.d.ts +54 -0
  135. package/dist/shared/constants.d.ts.map +1 -0
  136. package/dist/shared/constants.js +109 -0
  137. package/dist/shared/constants.js.map +1 -0
  138. package/dist/shared/default-value-detector.d.ts +40 -0
  139. package/dist/shared/default-value-detector.d.ts.map +1 -0
  140. package/dist/shared/default-value-detector.js +124 -0
  141. package/dist/shared/default-value-detector.js.map +1 -0
  142. package/dist/shared/diagnostics.d.ts +4 -0
  143. package/dist/shared/diagnostics.d.ts.map +1 -0
  144. package/dist/shared/diagnostics.js +25 -0
  145. package/dist/shared/diagnostics.js.map +1 -0
  146. package/dist/shared/directive-definition-extractor.d.ts +64 -0
  147. package/dist/shared/directive-definition-extractor.d.ts.map +1 -0
  148. package/dist/shared/directive-definition-extractor.js +399 -0
  149. package/dist/shared/directive-definition-extractor.js.map +1 -0
  150. package/dist/shared/directive-detector.d.ts +102 -0
  151. package/dist/shared/directive-detector.d.ts.map +1 -0
  152. package/dist/shared/directive-detector.js +415 -0
  153. package/dist/shared/directive-detector.js.map +1 -0
  154. package/dist/shared/file-scanner.d.ts +25 -0
  155. package/dist/shared/file-scanner.d.ts.map +1 -0
  156. package/dist/shared/file-scanner.js +101 -0
  157. package/dist/shared/file-scanner.js.map +1 -0
  158. package/dist/shared/index.d.ts +10 -0
  159. package/dist/shared/index.d.ts.map +1 -0
  160. package/dist/shared/index.js +6 -0
  161. package/dist/shared/index.js.map +1 -0
  162. package/dist/shared/inline-object-extractor.d.ts +13 -0
  163. package/dist/shared/inline-object-extractor.d.ts.map +1 -0
  164. package/dist/shared/inline-object-extractor.js +65 -0
  165. package/dist/shared/inline-object-extractor.js.map +1 -0
  166. package/dist/shared/inline-object-utils.d.ts +7 -0
  167. package/dist/shared/inline-object-utils.d.ts.map +1 -0
  168. package/dist/shared/inline-object-utils.js +23 -0
  169. package/dist/shared/inline-object-utils.js.map +1 -0
  170. package/dist/shared/interface-detector.d.ts +23 -0
  171. package/dist/shared/interface-detector.d.ts.map +1 -0
  172. package/dist/shared/interface-detector.js +133 -0
  173. package/dist/shared/interface-detector.js.map +1 -0
  174. package/dist/shared/interface-validator.d.ts +9 -0
  175. package/dist/shared/interface-validator.d.ts.map +1 -0
  176. package/dist/shared/interface-validator.js +152 -0
  177. package/dist/shared/interface-validator.js.map +1 -0
  178. package/dist/shared/metadata-detector.d.ts +65 -0
  179. package/dist/shared/metadata-detector.d.ts.map +1 -0
  180. package/dist/shared/metadata-detector.js +333 -0
  181. package/dist/shared/metadata-detector.js.map +1 -0
  182. package/dist/shared/path-utils.d.ts +2 -0
  183. package/dist/shared/path-utils.d.ts.map +1 -0
  184. package/dist/shared/path-utils.js +4 -0
  185. package/dist/shared/path-utils.js.map +1 -0
  186. package/dist/shared/program-factory.d.ts +14 -0
  187. package/dist/shared/program-factory.d.ts.map +1 -0
  188. package/dist/shared/program-factory.js +29 -0
  189. package/dist/shared/program-factory.js.map +1 -0
  190. package/dist/shared/source-location.d.ts +11 -0
  191. package/dist/shared/source-location.d.ts.map +1 -0
  192. package/dist/shared/source-location.js +15 -0
  193. package/dist/shared/source-location.js.map +1 -0
  194. package/dist/shared/tsconfig-loader.d.ts +13 -0
  195. package/dist/shared/tsconfig-loader.d.ts.map +1 -0
  196. package/dist/shared/tsconfig-loader.js +90 -0
  197. package/dist/shared/tsconfig-loader.js.map +1 -0
  198. package/dist/shared/tsdoc-parser.d.ts +12 -0
  199. package/dist/shared/tsdoc-parser.d.ts.map +1 -0
  200. package/dist/shared/tsdoc-parser.js +101 -0
  201. package/dist/shared/tsdoc-parser.js.map +1 -0
  202. package/dist/shared/type-converter.d.ts +3 -0
  203. package/dist/shared/type-converter.d.ts.map +1 -0
  204. package/dist/shared/type-converter.js +83 -0
  205. package/dist/shared/type-converter.js.map +1 -0
  206. package/dist/shared/typescript-utils.d.ts +82 -0
  207. package/dist/shared/typescript-utils.d.ts.map +1 -0
  208. package/dist/shared/typescript-utils.js +197 -0
  209. package/dist/shared/typescript-utils.js.map +1 -0
  210. package/dist/type-extractor/collector/result-collector.d.ts +7 -0
  211. package/dist/type-extractor/collector/result-collector.d.ts.map +1 -0
  212. package/dist/type-extractor/collector/result-collector.js +35 -0
  213. package/dist/type-extractor/collector/result-collector.js.map +1 -0
  214. package/dist/type-extractor/collector/scalar-collector.d.ts +108 -0
  215. package/dist/type-extractor/collector/scalar-collector.d.ts.map +1 -0
  216. package/dist/type-extractor/collector/scalar-collector.js +123 -0
  217. package/dist/type-extractor/collector/scalar-collector.js.map +1 -0
  218. package/dist/type-extractor/converter/field-eligibility.d.ts +34 -0
  219. package/dist/type-extractor/converter/field-eligibility.d.ts.map +1 -0
  220. package/dist/type-extractor/converter/field-eligibility.js +89 -0
  221. package/dist/type-extractor/converter/field-eligibility.js.map +1 -0
  222. package/dist/type-extractor/converter/graphql-converter.d.ts +7 -0
  223. package/dist/type-extractor/converter/graphql-converter.d.ts.map +1 -0
  224. package/dist/type-extractor/converter/graphql-converter.js +338 -0
  225. package/dist/type-extractor/converter/graphql-converter.js.map +1 -0
  226. package/dist/type-extractor/extract-types.d.ts +2 -0
  227. package/dist/type-extractor/extract-types.d.ts.map +1 -0
  228. package/dist/type-extractor/extract-types.js +2 -0
  229. package/dist/type-extractor/extract-types.js.map +1 -0
  230. package/dist/type-extractor/extractor/field-type-resolver.d.ts +28 -0
  231. package/dist/type-extractor/extractor/field-type-resolver.d.ts.map +1 -0
  232. package/dist/type-extractor/extractor/field-type-resolver.js +394 -0
  233. package/dist/type-extractor/extractor/field-type-resolver.js.map +1 -0
  234. package/dist/type-extractor/extractor/type-extractor.d.ts +36 -0
  235. package/dist/type-extractor/extractor/type-extractor.d.ts.map +1 -0
  236. package/dist/type-extractor/extractor/type-extractor.js +1082 -0
  237. package/dist/type-extractor/extractor/type-extractor.js.map +1 -0
  238. package/dist/type-extractor/extractor/type-name-collector.d.ts +24 -0
  239. package/dist/type-extractor/extractor/type-name-collector.d.ts.map +1 -0
  240. package/dist/type-extractor/extractor/type-name-collector.js +102 -0
  241. package/dist/type-extractor/extractor/type-name-collector.js.map +1 -0
  242. package/dist/type-extractor/index.d.ts +4 -0
  243. package/dist/type-extractor/index.d.ts.map +1 -0
  244. package/dist/type-extractor/index.js +2 -0
  245. package/dist/type-extractor/index.js.map +1 -0
  246. package/dist/type-extractor/mapper/scalar-base-type-mapper.d.ts +89 -0
  247. package/dist/type-extractor/mapper/scalar-base-type-mapper.d.ts.map +1 -0
  248. package/dist/type-extractor/mapper/scalar-base-type-mapper.js +158 -0
  249. package/dist/type-extractor/mapper/scalar-base-type-mapper.js.map +1 -0
  250. package/dist/type-extractor/types/diagnostics.d.ts +17 -0
  251. package/dist/type-extractor/types/diagnostics.d.ts.map +1 -0
  252. package/dist/type-extractor/types/diagnostics.js +2 -0
  253. package/dist/type-extractor/types/diagnostics.js.map +1 -0
  254. package/dist/type-extractor/types/graphql.d.ts +42 -0
  255. package/dist/type-extractor/types/graphql.d.ts.map +1 -0
  256. package/dist/type-extractor/types/graphql.js +2 -0
  257. package/dist/type-extractor/types/graphql.js.map +1 -0
  258. package/dist/type-extractor/types/index.d.ts +6 -0
  259. package/dist/type-extractor/types/index.d.ts.map +1 -0
  260. package/dist/type-extractor/types/index.js +2 -0
  261. package/dist/type-extractor/types/index.js.map +1 -0
  262. package/dist/type-extractor/types/ts-type-reference-factory.d.ts +39 -0
  263. package/dist/type-extractor/types/ts-type-reference-factory.d.ts.map +1 -0
  264. package/dist/type-extractor/types/ts-type-reference-factory.js +69 -0
  265. package/dist/type-extractor/types/ts-type-reference-factory.js.map +1 -0
  266. package/dist/type-extractor/types/typescript.d.ts +106 -0
  267. package/dist/type-extractor/types/typescript.d.ts.map +1 -0
  268. package/dist/type-extractor/types/typescript.js +2 -0
  269. package/dist/type-extractor/types/typescript.js.map +1 -0
  270. package/dist/type-extractor/validator/type-validator.d.ts +11 -0
  271. package/dist/type-extractor/validator/type-validator.d.ts.map +1 -0
  272. package/dist/type-extractor/validator/type-validator.js +53 -0
  273. package/dist/type-extractor/validator/type-validator.js.map +1 -0
  274. package/docs/configuration.md +163 -0
  275. package/docs/getting-started.md +117 -0
  276. package/docs/index.md +33 -0
  277. package/docs/integration/apollo.md +109 -0
  278. package/docs/integration/drizzle.md +191 -0
  279. package/docs/integration/yoga.md +108 -0
  280. package/docs/schema/abstract-resolvers.md +146 -0
  281. package/docs/schema/directives.md +196 -0
  282. package/docs/schema/documentation.md +176 -0
  283. package/docs/schema/enums.md +370 -0
  284. package/docs/schema/fields.md +186 -0
  285. package/docs/schema/index.md +38 -0
  286. package/docs/schema/inputs.md +279 -0
  287. package/docs/schema/interfaces.md +178 -0
  288. package/docs/schema/objects.md +188 -0
  289. package/docs/schema/queries-mutations.md +207 -0
  290. package/docs/schema/scalars.md +194 -0
  291. package/docs/schema/unions.md +90 -0
  292. package/docs/what-is-gqlkit.md +22 -0
  293. package/package.json +66 -7
  294. package/src/auto-type-generator/auto-type-generator.ts +925 -0
  295. package/src/auto-type-generator/index.ts +21 -0
  296. package/src/auto-type-generator/inline-enum-collector.ts +290 -0
  297. package/src/auto-type-generator/name-collision-validator.ts +119 -0
  298. package/src/auto-type-generator/naming-convention.ts +126 -0
  299. package/src/cli.ts +11 -0
  300. package/src/commands/gen.ts +141 -0
  301. package/src/commands/main.ts +5 -0
  302. package/src/config/define-config.ts +28 -0
  303. package/src/config/index.ts +7 -0
  304. package/src/config/types.ts +144 -0
  305. package/src/config-loader/index.ts +14 -0
  306. package/src/config-loader/loader.ts +143 -0
  307. package/src/config-loader/validator.ts +672 -0
  308. package/src/gen-orchestrator/hook-executor/hook-executor.ts +117 -0
  309. package/src/gen-orchestrator/orchestrator.ts +784 -0
  310. package/src/gen-orchestrator/reporter/diagnostic-reporter.ts +44 -0
  311. package/src/gen-orchestrator/reporter/progress-reporter.ts +61 -0
  312. package/src/gen-orchestrator/writer/file-writer.ts +38 -0
  313. package/src/index.ts +2 -0
  314. package/src/resolver-extractor/extract-resolvers.ts +63 -0
  315. package/src/resolver-extractor/extractor/define-api-extractor.ts +806 -0
  316. package/src/resolver-extractor/index.ts +19 -0
  317. package/src/resolver-extractor/validator/abstract-resolver-validator.ts +251 -0
  318. package/src/resolver-extractor/validator/only-validator.ts +158 -0
  319. package/src/schema-generator/builder/ast-builder.ts +706 -0
  320. package/src/schema-generator/emitter/code-emitter.ts +351 -0
  321. package/src/schema-generator/emitter/sdl-emitter.ts +13 -0
  322. package/src/schema-generator/generate-schema.ts +170 -0
  323. package/src/schema-generator/index.ts +19 -0
  324. package/src/schema-generator/integrator/result-integrator.ts +690 -0
  325. package/src/schema-generator/pruner/schema-pruner.ts +112 -0
  326. package/src/schema-generator/resolver-collector/resolver-collector.ts +123 -0
  327. package/src/shared/constants.ts +122 -0
  328. package/src/shared/default-value-detector.ts +172 -0
  329. package/src/shared/diagnostics.ts +35 -0
  330. package/src/shared/directive-definition-extractor.ts +564 -0
  331. package/src/shared/directive-detector.ts +556 -0
  332. package/src/shared/file-scanner.ts +170 -0
  333. package/src/shared/index.ts +32 -0
  334. package/src/shared/inline-object-extractor.ts +102 -0
  335. package/src/shared/inline-object-utils.ts +23 -0
  336. package/src/shared/interface-detector.ts +176 -0
  337. package/src/shared/interface-validator.ts +211 -0
  338. package/src/shared/metadata-detector.ts +443 -0
  339. package/src/shared/path-utils.ts +3 -0
  340. package/src/shared/program-factory.ts +51 -0
  341. package/src/shared/source-location.ts +27 -0
  342. package/src/shared/tsconfig-loader.ts +126 -0
  343. package/src/shared/tsdoc-parser.ts +155 -0
  344. package/src/shared/type-converter.ts +99 -0
  345. package/src/shared/typescript-utils.ts +246 -0
  346. package/src/type-extractor/collector/result-collector.ts +57 -0
  347. package/src/type-extractor/collector/scalar-collector.ts +254 -0
  348. package/src/type-extractor/converter/field-eligibility.ts +112 -0
  349. package/src/type-extractor/converter/graphql-converter.ts +459 -0
  350. package/src/type-extractor/extract-types.ts +1 -0
  351. package/src/type-extractor/extractor/field-type-resolver.ts +569 -0
  352. package/src/type-extractor/extractor/type-extractor.ts +1567 -0
  353. package/src/type-extractor/extractor/type-name-collector.ts +130 -0
  354. package/src/type-extractor/index.ts +20 -0
  355. package/src/type-extractor/mapper/scalar-base-type-mapper.ts +265 -0
  356. package/src/type-extractor/types/diagnostics.ts +99 -0
  357. package/src/type-extractor/types/graphql.ts +55 -0
  358. package/src/type-extractor/types/index.ts +37 -0
  359. package/src/type-extractor/types/ts-type-reference-factory.ts +137 -0
  360. package/src/type-extractor/types/typescript.ts +133 -0
  361. package/src/type-extractor/validator/type-validator.ts +77 -0
  362. package/README.md +0 -45
@@ -0,0 +1,196 @@
1
+ # Custom Directives
2
+
3
+ Define custom directives using the `GqlDirective` utility type and attach them using `GqlField` or `GqlObject`.
4
+
5
+ ## Defining Directives
6
+
7
+ ```typescript
8
+ // src/gqlkit/schema/directives.ts
9
+ import { type GqlDirective } from "@gqlkit-ts/runtime";
10
+
11
+ export type Role = "USER" | "ADMIN";
12
+
13
+ // Directive with typed arguments
14
+ export type AuthDirective<TArgs extends { role: Role[] }> = GqlDirective<
15
+ "auth",
16
+ TArgs,
17
+ "FIELD_DEFINITION"
18
+ >;
19
+
20
+ // Directive with multiple locations
21
+ export type CacheDirective<TArgs extends { maxAge: number }> = GqlDirective<
22
+ "cache",
23
+ TArgs,
24
+ ["FIELD_DEFINITION", "OBJECT"]
25
+ >;
26
+ ```
27
+
28
+ Generates:
29
+
30
+ ```graphql
31
+ directive @auth(role: [Role!]!) on FIELD_DEFINITION
32
+ directive @cache(maxAge: Float!) on FIELD_DEFINITION | OBJECT
33
+ ```
34
+
35
+ ## GqlDirective Type Parameters
36
+
37
+ `GqlDirective<Name, Args, Location>`:
38
+
39
+ | Parameter | Description |
40
+ |-----------|-------------|
41
+ | `Name` | The directive name (without `@`) |
42
+ | `Args` | The directive arguments type |
43
+ | `Location` | Where the directive can be used (single or array) |
44
+
45
+ ### Directive Locations
46
+
47
+ Common directive locations:
48
+
49
+ | Location | Description |
50
+ |----------|-------------|
51
+ | `FIELD_DEFINITION` | Object type fields |
52
+ | `OBJECT` | Object types |
53
+ | `INPUT_FIELD_DEFINITION` | Input type fields |
54
+ | `ARGUMENT_DEFINITION` | Field arguments |
55
+ | `ENUM_VALUE` | Enum values |
56
+ | `INTERFACE` | Interface types |
57
+
58
+ ## Attaching Directives to Fields
59
+
60
+ Use `GqlField` to attach directives to object type fields:
61
+
62
+ ```typescript
63
+ import { type GqlField, type IDString } from "@gqlkit-ts/runtime";
64
+ import { type AuthDirective } from "./directives.js";
65
+
66
+ export type User = {
67
+ id: IDString;
68
+ name: string;
69
+ // Field with directive
70
+ email: GqlField<string, { directives: [AuthDirective<{ role: ["ADMIN"] }>] }>;
71
+ // Nullable field with directive
72
+ phone: GqlField<string | null, { directives: [AuthDirective<{ role: ["USER"] }>] }>;
73
+ };
74
+ ```
75
+
76
+ Generates:
77
+
78
+ ```graphql
79
+ type User {
80
+ id: ID!
81
+ name: String!
82
+ email: String! @auth(role: [ADMIN])
83
+ phone: String @auth(role: [USER])
84
+ }
85
+ ```
86
+
87
+ ## Attaching Directives to Types
88
+
89
+ Use `GqlObject` to attach directives to type definitions:
90
+
91
+ ```typescript
92
+ import { type GqlObject, type IDString } from "@gqlkit-ts/runtime";
93
+ import { type CacheDirective } from "./directives.js";
94
+
95
+ export type Post = GqlObject<
96
+ {
97
+ id: IDString;
98
+ title: string;
99
+ },
100
+ { directives: [CacheDirective<{ maxAge: 60 }>] }
101
+ >;
102
+ ```
103
+
104
+ Generates:
105
+
106
+ ```graphql
107
+ type Post @cache(maxAge: 60) {
108
+ id: ID!
109
+ title: String!
110
+ }
111
+ ```
112
+
113
+ ## Attaching Directives to Query/Mutation Fields
114
+
115
+ Add a third type parameter to `defineQuery`, `defineMutation`, or `defineField`:
116
+
117
+ ```typescript
118
+ import { defineQuery } from "../gqlkit";
119
+ import type { NoArgs } from "@gqlkit-ts/runtime";
120
+ import { type AuthDirective } from "./directives.js";
121
+ import type { User } from "./user.js";
122
+
123
+ // Query field with directive
124
+ export const me = defineQuery<
125
+ NoArgs,
126
+ User,
127
+ [AuthDirective<{ role: ["USER"] }>]
128
+ >((_root, _args, ctx) => ctx.currentUser);
129
+ ```
130
+
131
+ Generates:
132
+
133
+ ```graphql
134
+ type Query {
135
+ me: User! @auth(role: [USER])
136
+ }
137
+ ```
138
+
139
+ ## Attaching Directives to Field Resolvers
140
+
141
+ ```typescript
142
+ import { defineField } from "../gqlkit";
143
+ import type { NoArgs } from "@gqlkit-ts/runtime";
144
+ import { type AuthDirective } from "./directives.js";
145
+
146
+ export const email = defineField<
147
+ User,
148
+ NoArgs,
149
+ string,
150
+ [AuthDirective<{ role: ["ADMIN"] }>]
151
+ >((parent) => parent.email);
152
+ ```
153
+
154
+ ## Multiple Directives
155
+
156
+ Attach multiple directives by adding them to the array:
157
+
158
+ ```typescript
159
+ export type Post = GqlObject<
160
+ {
161
+ id: IDString;
162
+ title: string;
163
+ },
164
+ {
165
+ directives: [
166
+ CacheDirective<{ maxAge: 60 }>,
167
+ AuthDirective<{ role: ["USER"] }>
168
+ ]
169
+ }
170
+ >;
171
+ ```
172
+
173
+ ## Combining with Other Options
174
+
175
+ Combine directives with `implements` and `defaultValue`:
176
+
177
+ ```typescript
178
+ export type Post = GqlObject<
179
+ {
180
+ id: IDString;
181
+ title: string;
182
+ createdAt: DateTime;
183
+ },
184
+ {
185
+ implements: [Node, Timestamped],
186
+ directives: [CacheDirective<{ maxAge: 60 }>]
187
+ }
188
+ >;
189
+
190
+ export type CreatePostInput = {
191
+ title: GqlField<string, {
192
+ defaultValue: "Untitled";
193
+ directives: [LengthDirective<{ min: 1; max: 200 }>];
194
+ }>;
195
+ };
196
+ ```
@@ -0,0 +1,176 @@
1
+ # Documentation
2
+
3
+ gqlkit extracts TSDoc/JSDoc comments and converts them to GraphQL descriptions.
4
+
5
+ ## Type Descriptions
6
+
7
+ Add descriptions to types using TSDoc/JSDoc comments:
8
+
9
+ ```typescript
10
+ /**
11
+ * A user in the system
12
+ */
13
+ export type User = {
14
+ /** Unique identifier */
15
+ id: IDString;
16
+ /** Display name */
17
+ name: string;
18
+ };
19
+ ```
20
+
21
+ Generates:
22
+
23
+ ```graphql
24
+ """
25
+ A user in the system
26
+
27
+ Defined in: src/gqlkit/schema/user.ts
28
+ """
29
+ type User {
30
+ """Unique identifier"""
31
+ id: ID!
32
+ """Display name"""
33
+ name: String!
34
+ }
35
+ ```
36
+
37
+ ## Field Descriptions
38
+
39
+ Add descriptions to individual fields:
40
+
41
+ ```typescript
42
+ export type User = {
43
+ /** Unique identifier for the user */
44
+ id: IDString;
45
+
46
+ /**
47
+ * The user's display name.
48
+ * This is shown in the UI and can be changed by the user.
49
+ */
50
+ name: string;
51
+
52
+ /** Email address (null if not verified) */
53
+ email: string | null;
54
+ };
55
+ ```
56
+
57
+ ## Resolver Descriptions
58
+
59
+ Add descriptions to Query, Mutation, and Field resolvers:
60
+
61
+ ```typescript
62
+ /** Get the currently authenticated user */
63
+ export const me = defineQuery<NoArgs, User | null>(
64
+ (_root, _args, ctx) => ctx.currentUser
65
+ );
66
+
67
+ /** Create a new user account */
68
+ export const createUser = defineMutation<{ input: CreateUserInput }, User>(
69
+ (_root, args, ctx) => ctx.db.createUser(args.input)
70
+ );
71
+
72
+ /** Get user's profile URL */
73
+ export const profileUrl = defineField<User, NoArgs, string>(
74
+ (parent) => `https://example.com/users/${parent.id}`
75
+ );
76
+ ```
77
+
78
+ ## @deprecated Directive
79
+
80
+ Mark fields and enum values as deprecated using the `@deprecated` JSDoc tag:
81
+
82
+ ### Deprecating Fields
83
+
84
+ ```typescript
85
+ export type User = {
86
+ id: IDString;
87
+ name: string;
88
+ /**
89
+ * Legacy username
90
+ * @deprecated Use `name` field instead
91
+ */
92
+ username: string | null;
93
+ };
94
+ ```
95
+
96
+ Generates:
97
+
98
+ ```graphql
99
+ type User {
100
+ id: ID!
101
+ name: String!
102
+ """Legacy username"""
103
+ username: String @deprecated(reason: "Use `name` field instead")
104
+ }
105
+ ```
106
+
107
+ ### Deprecating Enum Values
108
+
109
+ ```typescript
110
+ export enum UserStatus {
111
+ Active = "ACTIVE",
112
+ /**
113
+ * @deprecated Use `Inactive` instead
114
+ */
115
+ Pending = "PENDING",
116
+ Inactive = "INACTIVE",
117
+ }
118
+ ```
119
+
120
+ Generates:
121
+
122
+ ```graphql
123
+ enum UserStatus {
124
+ ACTIVE
125
+ PENDING @deprecated(reason: "Use `Inactive` instead")
126
+ INACTIVE
127
+ }
128
+ ```
129
+
130
+ ### Deprecating Resolvers
131
+
132
+ ```typescript
133
+ /**
134
+ * Get user by username
135
+ * @deprecated Use `user(id: ID!)` instead
136
+ */
137
+ export const userByUsername = defineQuery<{ username: string }, User | null>(
138
+ (_root, args, ctx) => ctx.db.findUserByUsername(args.username)
139
+ );
140
+ ```
141
+
142
+ ## Multi-line Descriptions
143
+
144
+ Multi-line comments are preserved:
145
+
146
+ ```typescript
147
+ /**
148
+ * Represents a blog post.
149
+ *
150
+ * Posts can be in draft or published state.
151
+ * Only published posts are visible to other users.
152
+ */
153
+ export type Post = {
154
+ id: IDString;
155
+ title: string;
156
+ content: string;
157
+ };
158
+ ```
159
+
160
+ Generates:
161
+
162
+ ```graphql
163
+ """
164
+ Represents a blog post.
165
+
166
+ Posts can be in draft or published state.
167
+ Only published posts are visible to other users.
168
+
169
+ Defined in: src/gqlkit/schema/post.ts
170
+ """
171
+ type Post {
172
+ id: ID!
173
+ title: String!
174
+ content: String!
175
+ }
176
+ ```