nitro-graphql 2.0.0-beta.37 → 2.0.0-beta.38

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 (200) hide show
  1. package/dist/cli/commands/generate.d.mts +26 -0
  2. package/dist/cli/commands/generate.mjs +196 -0
  3. package/dist/cli/commands/index.d.mts +4 -0
  4. package/dist/cli/commands/index.mjs +5 -0
  5. package/dist/cli/commands/init.d.mts +12 -0
  6. package/dist/cli/commands/init.mjs +100 -0
  7. package/dist/cli/commands/validate.d.mts +10 -0
  8. package/dist/cli/commands/validate.mjs +69 -0
  9. package/dist/cli/config.d.mts +75 -0
  10. package/dist/cli/config.mjs +20 -0
  11. package/dist/cli/index.d.mts +24 -0
  12. package/dist/cli/index.mjs +219 -0
  13. package/dist/core/codegen/client.d.mts +23 -0
  14. package/dist/core/codegen/client.mjs +150 -0
  15. package/dist/core/codegen/document-loader.d.mts +10 -0
  16. package/dist/core/codegen/document-loader.mjs +18 -0
  17. package/dist/core/codegen/index.d.mts +8 -0
  18. package/dist/core/codegen/index.mjs +9 -0
  19. package/dist/{utils/codegen-plugin.d.mts → core/codegen/plugin.d.mts} +2 -2
  20. package/dist/{utils/codegen-plugin.mjs → core/codegen/plugin.mjs} +1 -1
  21. package/dist/core/codegen/runtime.d.mts +20 -0
  22. package/dist/core/codegen/runtime.mjs +60 -0
  23. package/dist/core/codegen/schema-loader.d.mts +28 -0
  24. package/dist/core/codegen/schema-loader.mjs +128 -0
  25. package/dist/core/codegen/server.d.mts +28 -0
  26. package/dist/core/codegen/server.mjs +143 -0
  27. package/dist/{codegen → core/codegen}/validation.d.mts +1 -1
  28. package/dist/{codegen → core/codegen}/validation.mjs +1 -1
  29. package/dist/core/config.d.mts +50 -0
  30. package/dist/core/config.mjs +82 -0
  31. package/dist/core/constants.d.mts +188 -0
  32. package/dist/core/constants.mjs +210 -0
  33. package/dist/core/index.d.mts +32 -0
  34. package/dist/core/index.mjs +26 -0
  35. package/dist/core/scanning/ast-scanner.d.mts +23 -0
  36. package/dist/core/scanning/ast-scanner.mjs +103 -0
  37. package/dist/core/scanning/common.d.mts +37 -0
  38. package/dist/core/scanning/common.mjs +60 -0
  39. package/dist/core/scanning/directives.d.mts +10 -0
  40. package/dist/core/scanning/directives.mjs +29 -0
  41. package/dist/core/scanning/documents.d.mts +21 -0
  42. package/dist/core/scanning/documents.mjs +43 -0
  43. package/dist/core/scanning/index.d.mts +7 -0
  44. package/dist/core/scanning/index.mjs +8 -0
  45. package/dist/core/scanning/resolvers.d.mts +10 -0
  46. package/dist/core/scanning/resolvers.mjs +58 -0
  47. package/dist/core/scanning/schemas.d.mts +14 -0
  48. package/dist/core/scanning/schemas.mjs +64 -0
  49. package/dist/{utils/schema-builder.d.mts → core/schema/builder.d.mts} +7 -2
  50. package/dist/{utils/schema-builder.mjs → core/schema/builder.mjs} +22 -3
  51. package/dist/{utils → core/schema}/federation.d.mts +10 -5
  52. package/dist/{utils → core/schema}/federation.mjs +1 -1
  53. package/dist/core/schema/index.d.mts +3 -0
  54. package/dist/core/schema/index.mjs +4 -0
  55. package/dist/core/types/adapter.d.mts +58 -0
  56. package/dist/core/types/codegen.d.mts +133 -0
  57. package/dist/core/types/config.d.mts +212 -0
  58. package/dist/{types → core/types}/define.d.mts +3 -7
  59. package/dist/core/types/index.d.mts +5 -0
  60. package/dist/core/types/scanning.d.mts +69 -0
  61. package/dist/core/types/scanning.mjs +1 -0
  62. package/dist/{utils → core/utils}/directive-parser.d.mts +21 -5
  63. package/dist/{utils → core/utils}/directive-parser.mjs +25 -36
  64. package/dist/{utils → core/utils}/errors.d.mts +8 -4
  65. package/dist/{utils → core/utils}/errors.mjs +8 -4
  66. package/dist/core/utils/file-io.d.mts +24 -0
  67. package/dist/core/utils/file-io.mjs +47 -0
  68. package/dist/{utils → core/utils}/imports.d.mts +1 -1
  69. package/dist/{utils → core/utils}/imports.mjs +1 -1
  70. package/dist/core/utils/index.d.mts +7 -0
  71. package/dist/core/utils/index.mjs +8 -0
  72. package/dist/core/utils/logger.d.mts +19 -0
  73. package/dist/core/utils/logger.mjs +38 -0
  74. package/dist/{utils → core/utils}/ofetch-templates.d.mts +1 -1
  75. package/dist/{utils → core/utils}/ofetch-templates.mjs +1 -1
  76. package/dist/core/validation/external-services.d.mts +11 -0
  77. package/dist/{utils/validation.mjs → core/validation/external-services.mjs} +3 -3
  78. package/dist/core/validation/index.d.mts +2 -0
  79. package/dist/core/validation/index.mjs +3 -0
  80. package/dist/define.d.mts +1 -3
  81. package/dist/index.d.mts +6 -44
  82. package/dist/index.mjs +5 -62
  83. package/dist/nitro/adapter.d.mts +30 -0
  84. package/dist/nitro/adapter.mjs +97 -0
  85. package/dist/{utils → nitro}/apollo.d.mts +1 -1
  86. package/dist/{utils → nitro}/apollo.mjs +1 -1
  87. package/dist/nitro/codegen.d.mts +19 -0
  88. package/dist/nitro/codegen.mjs +141 -0
  89. package/dist/nitro/config.d.mts +52 -0
  90. package/dist/nitro/config.mjs +58 -0
  91. package/dist/nitro/index.d.mts +46 -0
  92. package/dist/nitro/index.mjs +65 -0
  93. package/dist/{utils/path-resolver.d.mts → nitro/paths.d.mts} +3 -19
  94. package/dist/{utils/path-resolver.mjs → nitro/paths.mjs} +2 -36
  95. package/dist/{rollup.d.mts → nitro/rollup.d.mts} +1 -1
  96. package/dist/{rollup.mjs → nitro/rollup.mjs} +11 -23
  97. package/dist/{routes → nitro/routes}/apollo-server.d.mts +1 -1
  98. package/dist/{routes → nitro/routes}/apollo-server.mjs +5 -5
  99. package/dist/{routes → nitro/routes}/debug-template.d.mts +1 -1
  100. package/dist/{routes → nitro/routes}/debug-template.mjs +1 -1
  101. package/dist/{routes → nitro/routes}/debug.d.mts +10 -16
  102. package/dist/{routes → nitro/routes}/debug.mjs +2 -2
  103. package/dist/{routes → nitro/routes}/graphql-yoga.d.mts +1 -1
  104. package/dist/{routes → nitro/routes}/graphql-yoga.mjs +3 -3
  105. package/dist/{routes → nitro/routes}/health.d.mts +1 -1
  106. package/dist/{routes → nitro/routes}/health.mjs +1 -1
  107. package/dist/nitro/setup/file-watcher.d.mts +16 -0
  108. package/dist/{setup → nitro/setup}/file-watcher.mjs +14 -18
  109. package/dist/{setup.d.mts → nitro/setup/logging.d.mts} +5 -6
  110. package/dist/nitro/setup/logging.mjs +66 -0
  111. package/dist/nitro/setup/rollup-integration.d.mts +16 -0
  112. package/dist/{setup → nitro/setup}/rollup-integration.mjs +2 -2
  113. package/dist/nitro/setup/routes.d.mts +10 -0
  114. package/dist/nitro/setup/routes.mjs +35 -0
  115. package/dist/nitro/setup/ts-config.d.mts +11 -0
  116. package/dist/{setup → nitro/setup}/ts-config.mjs +3 -3
  117. package/dist/nitro/setup.d.mts +12 -0
  118. package/dist/{setup.mjs → nitro/setup.mjs} +33 -100
  119. package/dist/{types/index.d.mts → nitro/types.d.mts} +125 -43
  120. package/dist/nitro/types.mjs +1 -0
  121. package/dist/nitro/virtual/generators.d.mts +31 -0
  122. package/dist/nitro/virtual/generators.mjs +193 -0
  123. package/dist/nitro/virtual/stubs.d.mts +20 -0
  124. package/dist/nitro/virtual/stubs.mjs +31 -0
  125. package/dist/{ecosystem/nuxt.d.mts → nuxt.d.mts} +1 -1
  126. package/dist/{ecosystem/nuxt.mjs → nuxt.mjs} +2 -2
  127. package/dist/{graphql/server.d.mts → stubs/index.d.mts} +5 -1
  128. package/dist/stubs/index.mjs +1 -0
  129. package/package.json +43 -42
  130. package/dist/codegen/client-types.d.mts +0 -13
  131. package/dist/codegen/client-types.mjs +0 -131
  132. package/dist/codegen/external-types.d.mts +0 -12
  133. package/dist/codegen/external-types.mjs +0 -88
  134. package/dist/codegen/index.d.mts +0 -18
  135. package/dist/codegen/index.mjs +0 -24
  136. package/dist/codegen/server-types.d.mts +0 -13
  137. package/dist/codegen/server-types.mjs +0 -64
  138. package/dist/config/defaults.mjs +0 -36
  139. package/dist/constants/scalars.mjs +0 -27
  140. package/dist/constants.mjs +0 -106
  141. package/dist/graphql/index.d.mts +0 -5
  142. package/dist/setup/graphql-scanner.mjs +0 -25
  143. package/dist/setup/scaffold-generator.mjs +0 -109
  144. package/dist/types/standard-schema.d.mts +0 -59
  145. package/dist/utils/client-codegen.d.mts +0 -41
  146. package/dist/utils/client-codegen.mjs +0 -277
  147. package/dist/utils/file-generator.d.mts +0 -37
  148. package/dist/utils/file-generator.mjs +0 -72
  149. package/dist/utils/file-writer.d.mts +0 -35
  150. package/dist/utils/file-writer.mjs +0 -32
  151. package/dist/utils/index.d.mts +0 -13
  152. package/dist/utils/index.mjs +0 -13
  153. package/dist/utils/layers.d.mts +0 -22
  154. package/dist/utils/layers.mjs +0 -28
  155. package/dist/utils/scanning/common.d.mts +0 -23
  156. package/dist/utils/scanning/common.mjs +0 -39
  157. package/dist/utils/scanning/directives.d.mts +0 -11
  158. package/dist/utils/scanning/directives.mjs +0 -43
  159. package/dist/utils/scanning/documents.d.mts +0 -15
  160. package/dist/utils/scanning/documents.mjs +0 -46
  161. package/dist/utils/scanning/index.d.mts +0 -6
  162. package/dist/utils/scanning/index.mjs +0 -7
  163. package/dist/utils/scanning/resolvers.d.mts +0 -11
  164. package/dist/utils/scanning/resolvers.mjs +0 -100
  165. package/dist/utils/scanning/schemas.d.mts +0 -15
  166. package/dist/utils/scanning/schemas.mjs +0 -29
  167. package/dist/utils/server-codegen.d.mts +0 -7
  168. package/dist/utils/server-codegen.mjs +0 -113
  169. package/dist/utils/type-generation.d.mts +0 -6
  170. package/dist/utils/type-generation.mjs +0 -7
  171. package/dist/utils/validation.d.mts +0 -11
  172. package/dist/virtual/debug-info.d.mts +0 -9
  173. package/dist/virtual/debug-info.mjs +0 -26
  174. package/dist/virtual/generators/config.d.mts +0 -22
  175. package/dist/virtual/generators/config.mjs +0 -36
  176. package/dist/virtual/generators/debug.d.mts +0 -14
  177. package/dist/virtual/generators/debug.mjs +0 -53
  178. package/dist/virtual/generators/directives.d.mts +0 -14
  179. package/dist/virtual/generators/directives.mjs +0 -52
  180. package/dist/virtual/generators/index.d.mts +0 -6
  181. package/dist/virtual/generators/index.mjs +0 -7
  182. package/dist/virtual/generators/resolvers.d.mts +0 -14
  183. package/dist/virtual/generators/resolvers.mjs +0 -55
  184. package/dist/virtual/generators/schemas.d.mts +0 -14
  185. package/dist/virtual/generators/schemas.mjs +0 -43
  186. package/dist/virtual/graphql-config.d.mts +0 -9
  187. package/dist/virtual/graphql-config.mjs +0 -10
  188. package/dist/virtual/module-config.d.mts +0 -9
  189. package/dist/virtual/module-config.mjs +0 -10
  190. package/dist/virtual/server-directives.d.mts +0 -11
  191. package/dist/virtual/server-directives.mjs +0 -10
  192. package/dist/virtual/server-resolvers.d.mts +0 -11
  193. package/dist/virtual/server-resolvers.mjs +0 -10
  194. package/dist/virtual/server-schemas.d.mts +0 -11
  195. package/dist/virtual/server-schemas.mjs +0 -10
  196. /package/dist/{graphql/index.mjs → core/types/adapter.mjs} +0 -0
  197. /package/dist/{graphql/server.mjs → core/types/codegen.mjs} +0 -0
  198. /package/dist/{types/define.mjs → core/types/config.mjs} +0 -0
  199. /package/dist/{types/index.mjs → core/types/define.mjs} +0 -0
  200. /package/dist/{types/standard-schema.mjs → core/types/index.mjs} +0 -0
@@ -0,0 +1,97 @@
1
+ import { scanDirectivesCore } from "../core/scanning/directives.mjs";
2
+ import { scanDocumentsCore } from "../core/scanning/documents.mjs";
3
+ import { scanResolversCore } from "../core/scanning/resolvers.mjs";
4
+ import { scanGraphqlCore, scanSchemasCore } from "../core/scanning/schemas.mjs";
5
+ import { join, relative } from "pathe";
6
+
7
+ //#region src/nitro/adapter.ts
8
+ /**
9
+ * Create a CoreLogger from Nitro's logger
10
+ */
11
+ function createLoggerFromNitro(nitro) {
12
+ return {
13
+ info: (msg, ...args) => nitro.logger.info(msg, ...args),
14
+ warn: (msg, ...args) => nitro.logger.warn(msg, ...args),
15
+ error: (msg, ...args) => nitro.logger.error(msg, ...args),
16
+ success: (msg, ...args) => nitro.logger.success(msg, ...args),
17
+ debug: (msg, ...args) => nitro.logger.debug(msg, ...args)
18
+ };
19
+ }
20
+ /**
21
+ * Create a ScanContext from Nitro instance
22
+ */
23
+ function createScanContextFromNitro(nitro) {
24
+ return {
25
+ rootDir: nitro.options.rootDir,
26
+ serverDir: nitro.graphql.serverDir,
27
+ clientDir: nitro.graphql.clientDir,
28
+ ignorePatterns: nitro.options.ignore,
29
+ isDev: nitro.options.dev,
30
+ logger: createLoggerFromNitro(nitro),
31
+ layerServerDirs: nitro.options.graphql?.layerServerDirs || [],
32
+ layerAppDirs: nitro.options.graphql?.layerAppDirs || []
33
+ };
34
+ }
35
+ /**
36
+ * Create a CoreConfig from Nitro instance
37
+ */
38
+ function createCoreConfigFromNitro(nitro) {
39
+ const graphqlOptions = nitro.options.graphql || {};
40
+ const isNuxt = nitro.options.framework?.name === "nuxt";
41
+ const typesDir = join(nitro.graphql.buildDir, "types");
42
+ return {
43
+ rootDir: nitro.options.rootDir,
44
+ buildDir: nitro.graphql.buildDir,
45
+ serverDir: nitro.graphql.serverDir,
46
+ clientDir: nitro.graphql.clientDir,
47
+ typesDir,
48
+ framework: graphqlOptions.framework || "graphql-yoga",
49
+ isNuxt,
50
+ isDev: nitro.options.dev,
51
+ graphqlOptions: {
52
+ framework: graphqlOptions.framework,
53
+ endpoint: typeof graphqlOptions.endpoint === "object" ? graphqlOptions.endpoint?.graphql : graphqlOptions.endpoint,
54
+ federation: graphqlOptions.federation,
55
+ security: graphqlOptions.security
56
+ },
57
+ logger: createLoggerFromNitro(nitro),
58
+ ignorePatterns: nitro.options.ignore,
59
+ layerServerDirs: nitro.options.graphql?.layerServerDirs || [],
60
+ layerAppDirs: nitro.options.graphql?.layerAppDirs || []
61
+ };
62
+ }
63
+ /**
64
+ * Create a CoreContext from Nitro instance
65
+ */
66
+ function createCoreContextFromNitro(nitro) {
67
+ return {
68
+ config: createCoreConfigFromNitro(nitro),
69
+ graphqlBuildDir: nitro.graphql.buildDir,
70
+ watchDirs: nitro.graphql.watchDirs,
71
+ dir: nitro.graphql.dir
72
+ };
73
+ }
74
+ /**
75
+ * Nitro framework adapter implementation
76
+ */
77
+ const NitroAdapter = {
78
+ name: "nitro",
79
+ createCoreConfig: createCoreConfigFromNitro,
80
+ createCoreContext: createCoreContextFromNitro,
81
+ createScanContext: createScanContextFromNitro,
82
+ getLogger: createLoggerFromNitro,
83
+ scanSchemas: (nitro) => scanSchemasCore(createScanContextFromNitro(nitro)),
84
+ scanGraphql: (nitro) => scanGraphqlCore(createScanContextFromNitro(nitro)),
85
+ scanResolvers: (nitro) => scanResolversCore(createScanContextFromNitro(nitro)),
86
+ scanDirectives: (nitro) => scanDirectivesCore(createScanContextFromNitro(nitro)),
87
+ scanDocuments(nitro) {
88
+ return scanDocumentsCore(createScanContextFromNitro(nitro), {
89
+ externalServices: nitro.options.graphql?.externalServices,
90
+ clientDirRelative: relative(nitro.options.rootDir, nitro.graphql.clientDir)
91
+ });
92
+ }
93
+ };
94
+ var adapter_default = NitroAdapter;
95
+
96
+ //#endregion
97
+ export { NitroAdapter, createCoreConfigFromNitro, createCoreContextFromNitro, createLoggerFromNitro, createScanContextFromNitro, adapter_default as default };
@@ -2,7 +2,7 @@ import { ApolloServer, BaseContext, ContextFunction } from "@apollo/server";
2
2
  import { EventHandler, H3Event } from "nitro/h3";
3
3
  import { Hooks } from "crossws";
4
4
 
5
- //#region src/utils/apollo.d.ts
5
+ //#region src/nitro/apollo.d.ts
6
6
  type WithRequired<T, K extends keyof T> = T & { [P in K]-?: T[P] };
7
7
  interface H3ContextFunctionArgument {
8
8
  event: H3Event;
@@ -1,7 +1,7 @@
1
1
  import { HeaderMap } from "@apollo/server";
2
2
  import { eventHandler, getRequestURL, readBody } from "nitro/h3";
3
3
 
4
- //#region src/utils/apollo.ts
4
+ //#region src/nitro/apollo.ts
5
5
  function startServerAndCreateH3Handler(server, options) {
6
6
  const defaultContext = () => Promise.resolve({});
7
7
  const contextFunction = options?.context ?? defaultContext;
@@ -0,0 +1,19 @@
1
+ import { Nitro } from "nitro/types";
2
+
3
+ //#region src/nitro/codegen.d.ts
4
+
5
+ /**
6
+ * Generate server-side resolver types
7
+ */
8
+ declare function generateServerTypes(nitro: Nitro, options?: {
9
+ silent?: boolean;
10
+ }): Promise<void>;
11
+ /**
12
+ * Generate client-side operation types
13
+ */
14
+ declare function generateClientTypes(nitro: Nitro, options?: {
15
+ silent?: boolean;
16
+ isInitial?: boolean;
17
+ }): Promise<void>;
18
+ //#endregion
19
+ export { generateClientTypes, generateServerTypes };
@@ -0,0 +1,141 @@
1
+ import { LOG_TAG } from "../core/constants.mjs";
2
+ import { loadGraphQLDocuments } from "../core/codegen/document-loader.mjs";
3
+ import { writeFile } from "../core/utils/file-io.mjs";
4
+ import { downloadAndSaveSchema, loadExternalSchema } from "../core/codegen/schema-loader.mjs";
5
+ import { generateClientTypesCore, generateExternalClientTypesCore } from "../core/codegen/client.mjs";
6
+ import { generateServerTypesCore } from "../core/codegen/server.mjs";
7
+ import { validateNoDuplicateTypes } from "../core/codegen/validation.mjs";
8
+ import { loadFederationSupport } from "../core/schema/federation.mjs";
9
+ import { getDefaultPaths, getSdkConfig, getTypesConfig, resolveFilePath, shouldGenerateTypes } from "./paths.mjs";
10
+ import consola from "consola";
11
+ import { join, resolve } from "pathe";
12
+ import { printSchemaWithDirectives } from "@graphql-tools/utils";
13
+ import { buildSchema, parse, print } from "graphql";
14
+ import { existsSync, readFileSync } from "node:fs";
15
+ import { mergeTypeDefs } from "@graphql-tools/merge";
16
+ import { loadFilesSync } from "@graphql-tools/load-files";
17
+
18
+ //#region src/nitro/codegen.ts
19
+ const logger = consola.withTag(LOG_TAG);
20
+ async function buildSchemaFromString(source, federation) {
21
+ if (federation) {
22
+ const buildSubgraph = await loadFederationSupport();
23
+ if (!buildSubgraph) throw new Error("Federation enabled but @apollo/subgraph not installed");
24
+ return buildSubgraph([{ typeDefs: parse(source) }]);
25
+ }
26
+ return buildSchema(source);
27
+ }
28
+ /**
29
+ * Generate server-side resolver types
30
+ */
31
+ async function generateServerTypes(nitro, options = {}) {
32
+ if (!shouldGenerateTypes(nitro)) return;
33
+ const schemas = nitro.scanSchemas || [];
34
+ if (!schemas.length) {
35
+ if (!options.silent) consola.info("No GraphQL schemas found");
36
+ return;
37
+ }
38
+ try {
39
+ const strings = loadFilesSync(schemas).map((s) => typeof s === "string" ? s : s.loc?.source?.body || "").filter(Boolean);
40
+ if (!validateNoDuplicateTypes(schemas, strings)) return;
41
+ const merged = mergeTypeDefs([strings.join("\n\n")], { throwOnConflict: true });
42
+ const federation = nitro.options.graphql?.federation?.enabled === true;
43
+ const schema = await buildSchemaFromString(print(merged), federation);
44
+ const result = await generateServerTypesCore({
45
+ framework: nitro.options.graphql?.framework || "graphql-yoga",
46
+ schema,
47
+ config: nitro.options.graphql?.codegen?.server,
48
+ federationEnabled: federation
49
+ });
50
+ writeFile(resolve(nitro.graphql.buildDir, "schema.graphql"), printSchemaWithDirectives(schema));
51
+ const placeholders = getDefaultPaths(nitro);
52
+ const typesConfig = getTypesConfig(nitro);
53
+ const typesPath = resolveFilePath(typesConfig.server, typesConfig.enabled, true, "{typesDir}/nitro-graphql-server.d.ts", placeholders);
54
+ if (typesPath) {
55
+ writeFile(typesPath, result.types);
56
+ if (!options.silent) logger.success(`Server types: ${typesPath}`);
57
+ }
58
+ } catch (error) {
59
+ logger.error("Server type generation failed:", error);
60
+ }
61
+ }
62
+ /**
63
+ * Generate client-side operation types
64
+ */
65
+ async function generateClientTypes(nitro, options = {}) {
66
+ try {
67
+ if (nitro.scanSchemas?.length) await generateMainClientTypes(nitro, options);
68
+ if (nitro.options.graphql?.externalServices?.length) await generateExternalTypes(nitro, options);
69
+ } catch (error) {
70
+ logger.error("Client type generation failed:", error);
71
+ }
72
+ }
73
+ async function generateMainClientTypes(nitro, options = {}) {
74
+ const schemaPath = join(nitro.graphql.buildDir, "schema.graphql");
75
+ if (!existsSync(schemaPath)) {
76
+ if (!options.silent) consola.info("Schema not ready for client types");
77
+ return;
78
+ }
79
+ const docs = await loadGraphQLDocuments(nitro.scanDocuments);
80
+ const federation = nitro.options.graphql?.federation?.enabled === true;
81
+ const types = await generateClientTypesCore({
82
+ schema: await buildSchemaFromString(readFileSync(schemaPath, "utf-8"), federation),
83
+ documents: docs,
84
+ config: nitro.options.graphql?.codegen?.client,
85
+ sdkConfig: nitro.options.graphql?.codegen?.clientSDK,
86
+ options
87
+ });
88
+ if (types === false) return;
89
+ const placeholders = getDefaultPaths(nitro);
90
+ const typesConfig = getTypesConfig(nitro);
91
+ const sdkConfig = getSdkConfig(nitro);
92
+ const clientPath = resolveFilePath(typesConfig.client, typesConfig.enabled, true, "{typesDir}/nitro-graphql-client.d.ts", placeholders);
93
+ if (clientPath) {
94
+ writeFile(clientPath, types.types);
95
+ if (!options.silent) logger.success(`Client types: ${clientPath}`);
96
+ }
97
+ const sdkPath = resolveFilePath(sdkConfig.main, sdkConfig.enabled, true, "{clientGraphql}/default/sdk.ts", placeholders);
98
+ if (sdkPath) {
99
+ writeFile(sdkPath, types.sdk);
100
+ if (!options.silent) logger.success(`SDK: ${sdkPath}`);
101
+ }
102
+ }
103
+ async function generateExternalTypes(nitro, options = {}) {
104
+ for (const service of nitro.options.graphql?.externalServices || []) try {
105
+ if (!options.silent) consola.info(`[${service.name}] Processing external service`);
106
+ await downloadAndSaveSchema(service, nitro.options.buildDir);
107
+ const schema = await loadExternalSchema(service, nitro.options.buildDir);
108
+ if (!schema) {
109
+ consola.warn(`[${service.name}] Failed to load schema`);
110
+ continue;
111
+ }
112
+ const docs = service.documents?.length ? await loadGraphQLDocuments(service.documents).catch(() => []) : [];
113
+ if (service.documents?.length && !docs.length) {
114
+ consola.warn(`[${service.name}] No documents found`);
115
+ continue;
116
+ }
117
+ const types = await generateExternalClientTypesCore(service, schema, docs);
118
+ if (types === false) continue;
119
+ const placeholders = {
120
+ ...getDefaultPaths(nitro),
121
+ serviceName: service.name
122
+ };
123
+ const typesConfig = getTypesConfig(nitro);
124
+ const sdkConfig = getSdkConfig(nitro);
125
+ const typesPath = resolveFilePath(service.paths?.types ?? typesConfig.external, typesConfig.enabled, true, "{typesDir}/nitro-graphql-client-{serviceName}.d.ts", placeholders);
126
+ if (typesPath) {
127
+ writeFile(typesPath, types.types);
128
+ if (!options.silent) consola.success(`[${service.name}] Types: ${typesPath}`);
129
+ }
130
+ const sdkPath = resolveFilePath(service.paths?.sdk ?? sdkConfig.external, sdkConfig.enabled, true, "{clientGraphql}/{serviceName}/sdk.ts", placeholders);
131
+ if (sdkPath) {
132
+ writeFile(sdkPath, types.sdk);
133
+ if (!options.silent) consola.success(`[${service.name}] SDK: ${sdkPath}`);
134
+ }
135
+ } catch (error) {
136
+ consola.error(`[${service.name}] External service failed:`, error);
137
+ }
138
+ }
139
+
140
+ //#endregion
141
+ export { generateClientTypes, generateServerTypes };
@@ -0,0 +1,52 @@
1
+ import { NitroGraphQLOptions } from "./types.mjs";
2
+
3
+ //#region src/nitro/config.d.ts
4
+
5
+ /**
6
+ * Default type generation configuration
7
+ */
8
+ declare const DEFAULT_TYPES_CONFIG: {
9
+ readonly server: ".graphql/nitro-graphql-server.d.ts";
10
+ readonly client: ".graphql/nitro-graphql-client.d.ts";
11
+ readonly enabled: true;
12
+ };
13
+ /**
14
+ * Default runtime GraphQL configuration
15
+ */
16
+ declare const DEFAULT_RUNTIME_CONFIG: NitroGraphQLOptions;
17
+ /**
18
+ * Default ignore patterns for file watching
19
+ */
20
+ declare const DEFAULT_IGNORE_PATTERNS: string[];
21
+ /**
22
+ * Default SDK configuration
23
+ */
24
+ declare const DEFAULT_SDK_CONFIG: {
25
+ readonly enabled: true;
26
+ readonly main: true;
27
+ readonly external: true;
28
+ };
29
+ /**
30
+ * Default paths configuration
31
+ * These are used as placeholders and resolved based on framework
32
+ */
33
+ declare const DEFAULT_PATHS_CONFIG: {
34
+ readonly serverGraphql: "server/graphql";
35
+ readonly clientGraphql: null;
36
+ readonly buildDir: null;
37
+ readonly typesDir: null;
38
+ };
39
+ /**
40
+ * Default TypeScript strict mode setting
41
+ */
42
+ declare const DEFAULT_TYPESCRIPT_STRICT: true;
43
+ /**
44
+ * Default watcher persistence setting
45
+ */
46
+ declare const DEFAULT_WATCHER_PERSISTENT: true;
47
+ /**
48
+ * Default watcher ignore initial setting
49
+ */
50
+ declare const DEFAULT_WATCHER_IGNORE_INITIAL: true;
51
+ //#endregion
52
+ export { DEFAULT_IGNORE_PATTERNS, DEFAULT_PATHS_CONFIG, DEFAULT_RUNTIME_CONFIG, DEFAULT_SDK_CONFIG, DEFAULT_TYPESCRIPT_STRICT, DEFAULT_TYPES_CONFIG, DEFAULT_WATCHER_IGNORE_INITIAL, DEFAULT_WATCHER_PERSISTENT };
@@ -0,0 +1,58 @@
1
+ import { DEFAULT_CLIENT_TYPES_PATH, DEFAULT_SERVER_TYPES_PATH, ENDPOINT_GRAPHQL, ENDPOINT_HEALTH } from "../core/constants.mjs";
2
+
3
+ //#region src/nitro/config.ts
4
+ /**
5
+ * Default type generation configuration
6
+ */
7
+ const DEFAULT_TYPES_CONFIG = {
8
+ server: DEFAULT_SERVER_TYPES_PATH,
9
+ client: DEFAULT_CLIENT_TYPES_PATH,
10
+ enabled: true
11
+ };
12
+ /**
13
+ * Default runtime GraphQL configuration
14
+ */
15
+ const DEFAULT_RUNTIME_CONFIG = {
16
+ endpoint: {
17
+ graphql: ENDPOINT_GRAPHQL,
18
+ healthCheck: ENDPOINT_HEALTH
19
+ },
20
+ playground: true
21
+ };
22
+ /**
23
+ * Default ignore patterns for file watching
24
+ */
25
+ const DEFAULT_IGNORE_PATTERNS = [];
26
+ /**
27
+ * Default SDK configuration
28
+ */
29
+ const DEFAULT_SDK_CONFIG = {
30
+ enabled: true,
31
+ main: true,
32
+ external: true
33
+ };
34
+ /**
35
+ * Default paths configuration
36
+ * These are used as placeholders and resolved based on framework
37
+ */
38
+ const DEFAULT_PATHS_CONFIG = {
39
+ serverGraphql: "server/graphql",
40
+ clientGraphql: null,
41
+ buildDir: null,
42
+ typesDir: null
43
+ };
44
+ /**
45
+ * Default TypeScript strict mode setting
46
+ */
47
+ const DEFAULT_TYPESCRIPT_STRICT = true;
48
+ /**
49
+ * Default watcher persistence setting
50
+ */
51
+ const DEFAULT_WATCHER_PERSISTENT = true;
52
+ /**
53
+ * Default watcher ignore initial setting
54
+ */
55
+ const DEFAULT_WATCHER_IGNORE_INITIAL = true;
56
+
57
+ //#endregion
58
+ export { DEFAULT_IGNORE_PATTERNS, DEFAULT_PATHS_CONFIG, DEFAULT_RUNTIME_CONFIG, DEFAULT_SDK_CONFIG, DEFAULT_TYPESCRIPT_STRICT, DEFAULT_TYPES_CONFIG, DEFAULT_WATCHER_IGNORE_INITIAL, DEFAULT_WATCHER_PERSISTENT };
@@ -0,0 +1,46 @@
1
+ import { CodegenClientConfig, CodegenServerConfig, DefineDirectiveConfig, DefineServerConfig, DirectiveArgument, DirectiveDefinition, ExtendSource, ExternalGraphQLService, ExternalServicePaths, FederationConfig, FileGenerationConfig, Flatten, GenImport, GenericSdkConfig, GraphQLArgumentType, GraphQLBaseType, GraphQLScalarType, NitroGraphQLOptions, PathsConfig, SdkConfig, SecurityConfig, StandardSchemaV1, TypesConfig } from "./types.mjs";
2
+ import { NitroAdapter } from "./adapter.mjs";
3
+ import { resolveSecurityConfig } from "./setup/logging.mjs";
4
+ import { setupNitroGraphQL } from "./setup.mjs";
5
+ import { NitroModule } from "nitro/types";
6
+ import { Plugin } from "vite";
7
+
8
+ //#region src/nitro/index.d.ts
9
+
10
+ /**
11
+ * Vite plugin to load GraphQL files as strings AND auto-register Nitro module
12
+ * This prevents Vite from trying to parse .graphql/.gql files as JavaScript
13
+ * and automatically sets up the nitro-graphql module via the nitro: hook
14
+ *
15
+ * @example - Vite usage
16
+ * ```ts
17
+ * import { defineConfig } from 'vite'
18
+ * import { nitro } from 'nitro/vite'
19
+ * import graphql from 'nitro-graphql'
20
+ *
21
+ * export default defineConfig({
22
+ * plugins: [
23
+ * graphql({ framework: 'graphql-yoga' }), // Auto-registers Nitro module
24
+ * nitro()
25
+ * ]
26
+ * })
27
+ * ```
28
+ *
29
+ *
30
+ * @example - Nitro direct usage
31
+ * ```ts
32
+ *
33
+ * import graphql from 'nitro-graphql'
34
+ *
35
+ * export default defineConfig({
36
+ * modules: [
37
+ * graphql({ framework: 'graphql-yoga' }) // Auto-registers Nitro module
38
+ * ]
39
+ * })
40
+ * ```
41
+ */
42
+ declare function graphqlModule(options?: NitroGraphQLOptions): Plugin & {
43
+ nitro?: NitroModule;
44
+ };
45
+ //#endregion
46
+ export { CodegenClientConfig, CodegenServerConfig, DefineDirectiveConfig, DefineServerConfig, DirectiveArgument, DirectiveDefinition, ExtendSource, ExternalGraphQLService, ExternalServicePaths, FederationConfig, FileGenerationConfig, Flatten, GenImport, GenericSdkConfig, GraphQLArgumentType, GraphQLBaseType, GraphQLScalarType, NitroAdapter, NitroGraphQLOptions, PathsConfig, SdkConfig, SecurityConfig, StandardSchemaV1, TypesConfig, graphqlModule as default, resolveSecurityConfig, setupNitroGraphQL };
@@ -0,0 +1,65 @@
1
+ import { NitroAdapter } from "./adapter.mjs";
2
+ import { resolveSecurityConfig } from "./setup/logging.mjs";
3
+ import { setupNitroGraphQL } from "./setup.mjs";
4
+ import { readFile } from "node:fs/promises";
5
+ import defu from "defu";
6
+
7
+ //#region src/nitro/index.ts
8
+ /**
9
+ * Vite plugin to load GraphQL files as strings AND auto-register Nitro module
10
+ * This prevents Vite from trying to parse .graphql/.gql files as JavaScript
11
+ * and automatically sets up the nitro-graphql module via the nitro: hook
12
+ *
13
+ * @example - Vite usage
14
+ * ```ts
15
+ * import { defineConfig } from 'vite'
16
+ * import { nitro } from 'nitro/vite'
17
+ * import graphql from 'nitro-graphql'
18
+ *
19
+ * export default defineConfig({
20
+ * plugins: [
21
+ * graphql({ framework: 'graphql-yoga' }), // Auto-registers Nitro module
22
+ * nitro()
23
+ * ]
24
+ * })
25
+ * ```
26
+ *
27
+ *
28
+ * @example - Nitro direct usage
29
+ * ```ts
30
+ *
31
+ * import graphql from 'nitro-graphql'
32
+ *
33
+ * export default defineConfig({
34
+ * modules: [
35
+ * graphql({ framework: 'graphql-yoga' }) // Auto-registers Nitro module
36
+ * ]
37
+ * })
38
+ * ```
39
+ */
40
+ function graphqlModule(options) {
41
+ return {
42
+ name: "nitro-graphql",
43
+ enforce: "pre",
44
+ async load(id) {
45
+ if (!/\.(?:graphql|gql)$/i.test(id)) return null;
46
+ try {
47
+ const content = await readFile(id, "utf-8");
48
+ return `export default ${JSON.stringify(content)}`;
49
+ } catch (error) {
50
+ if (error && typeof error === "object" && "code" in error && error.code === "ENOENT") return null;
51
+ throw error;
52
+ }
53
+ },
54
+ nitro: { async setup(nitro) {
55
+ if (options) nitro.options.graphql = defu(nitro.options.graphql || {}, options);
56
+ nitro.options.graphql = nitro.options.graphql || {};
57
+ nitro.options.graphql._vitePlugin = true;
58
+ await setupNitroGraphQL(nitro);
59
+ } }
60
+ };
61
+ }
62
+ var nitro_default = graphqlModule;
63
+
64
+ //#endregion
65
+ export { NitroAdapter, nitro_default as default, resolveSecurityConfig, setupNitroGraphQL };
@@ -1,7 +1,7 @@
1
- import { ClientUtilsConfig, FileGenerationConfig, ScaffoldConfig, SdkConfig, TypesConfig } from "../types/index.mjs";
1
+ import { FileGenerationConfig, SdkConfig, TypesConfig } from "./types.mjs";
2
2
  import { Nitro } from "nitro/types";
3
3
 
4
- //#region src/utils/path-resolver.d.ts
4
+ //#region src/nitro/paths.d.ts
5
5
 
6
6
  /**
7
7
  * Placeholder values for path resolution
@@ -34,22 +34,6 @@ declare function shouldGenerateFile(config: FileGenerationConfig | undefined, ca
34
34
  * Returns: resolved absolute path or null if file should not be generated
35
35
  */
36
36
  declare function resolveFilePath(config: FileGenerationConfig | undefined, categoryEnabled: boolean | undefined, topLevelEnabled: boolean, defaultPath: string, placeholders: PathPlaceholders): string | null;
37
- /**
38
- * Check if scaffold files should be generated (category-level check)
39
- */
40
- declare function shouldGenerateScaffold(nitro: Nitro): boolean;
41
- /**
42
- * Get scaffold configuration (handles false case)
43
- */
44
- declare function getScaffoldConfig(nitro: Nitro): ScaffoldConfig;
45
- /**
46
- * Check if client utilities should be generated (category-level check)
47
- */
48
- declare function shouldGenerateClientUtils(nitro: Nitro): boolean;
49
- /**
50
- * Get client utilities configuration (handles false case)
51
- */
52
- declare function getClientUtilsConfig(nitro: Nitro): ClientUtilsConfig;
53
37
  /**
54
38
  * Check if SDK files should be generated (category-level check)
55
39
  */
@@ -67,4 +51,4 @@ declare function shouldGenerateTypes(nitro: Nitro): boolean;
67
51
  */
68
52
  declare function getTypesConfig(nitro: Nitro): TypesConfig;
69
53
  //#endregion
70
- export { PathPlaceholders, getClientUtilsConfig, getDefaultPaths, getScaffoldConfig, getSdkConfig, getTypesConfig, replacePlaceholders, resolveFilePath, shouldGenerateClientUtils, shouldGenerateFile, shouldGenerateScaffold, shouldGenerateSdk, shouldGenerateTypes };
54
+ export { PathPlaceholders, getDefaultPaths, getSdkConfig, getTypesConfig, replacePlaceholders, resolveFilePath, shouldGenerateFile, shouldGenerateSdk, shouldGenerateTypes };
@@ -1,6 +1,6 @@
1
1
  import { isAbsolute, resolve } from "pathe";
2
2
 
3
- //#region src/utils/path-resolver.ts
3
+ //#region src/nitro/paths.ts
4
4
  /**
5
5
  * Replace placeholders in a path string
6
6
  * Supports: {serviceName}, {buildDir}, {rootDir}, {framework}, {typesDir}, {serverGraphql}, {clientGraphql}
@@ -55,40 +55,6 @@ function resolveFilePath(config, categoryEnabled, topLevelEnabled, defaultPath,
55
55
  return resolve(placeholders.rootDir, resolvedDefault);
56
56
  }
57
57
  /**
58
- * Check if scaffold files should be generated (category-level check)
59
- */
60
- function shouldGenerateScaffold(nitro) {
61
- const scaffoldConfig = nitro.options.graphql?.scaffold;
62
- if (scaffoldConfig === false) return false;
63
- if (scaffoldConfig && scaffoldConfig.enabled === false) return false;
64
- return true;
65
- }
66
- /**
67
- * Get scaffold configuration (handles false case)
68
- */
69
- function getScaffoldConfig(nitro) {
70
- const scaffoldConfig = nitro.options.graphql?.scaffold;
71
- if (scaffoldConfig === false) return { enabled: false };
72
- return scaffoldConfig || {};
73
- }
74
- /**
75
- * Check if client utilities should be generated (category-level check)
76
- */
77
- function shouldGenerateClientUtils(nitro) {
78
- const clientUtilsConfig = nitro.options.graphql?.clientUtils;
79
- if (clientUtilsConfig === false) return false;
80
- if (clientUtilsConfig && clientUtilsConfig.enabled === false) return false;
81
- return true;
82
- }
83
- /**
84
- * Get client utilities configuration (handles false case)
85
- */
86
- function getClientUtilsConfig(nitro) {
87
- const clientUtilsConfig = nitro.options.graphql?.clientUtils;
88
- if (clientUtilsConfig === false) return { enabled: false };
89
- return clientUtilsConfig || {};
90
- }
91
- /**
92
58
  * Check if SDK files should be generated (category-level check)
93
59
  */
94
60
  function shouldGenerateSdk(nitro) {
@@ -124,4 +90,4 @@ function getTypesConfig(nitro) {
124
90
  }
125
91
 
126
92
  //#endregion
127
- export { getClientUtilsConfig, getDefaultPaths, getScaffoldConfig, getSdkConfig, getTypesConfig, replacePlaceholders, resolveFilePath, shouldGenerateClientUtils, shouldGenerateFile, shouldGenerateScaffold, shouldGenerateSdk, shouldGenerateTypes };
93
+ export { getDefaultPaths, getSdkConfig, getTypesConfig, replacePlaceholders, resolveFilePath, shouldGenerateFile, shouldGenerateSdk, shouldGenerateTypes };
@@ -1,6 +1,6 @@
1
1
  import { Nitro } from "nitro/types";
2
2
 
3
- //#region src/rollup.d.ts
3
+ //#region src/nitro/rollup.d.ts
4
4
  declare function rollupConfig(nitro: Nitro): Promise<void>;
5
5
  //#endregion
6
6
  export { rollupConfig };
@@ -1,23 +1,13 @@
1
- import { generateServerTypes } from "./codegen/server-types.mjs";
2
- import { generateClientTypes } from "./codegen/index.mjs";
3
- import { scanGraphql } from "./utils/scanning/schemas.mjs";
4
- import { virtualGraphQLConfig, virtualModuleConfig } from "./virtual/generators/config.mjs";
5
- import { virtualDebugInfo } from "./virtual/generators/debug.mjs";
6
- import { virtualDirectives } from "./virtual/generators/directives.mjs";
7
- import { virtualResolvers } from "./virtual/generators/resolvers.mjs";
8
- import { virtualSchemas } from "./virtual/generators/schemas.mjs";
1
+ import { NitroAdapter } from "./adapter.mjs";
2
+ import { generateClientTypes, generateServerTypes } from "./codegen.mjs";
3
+ import { registerAllVirtualModules } from "./virtual/generators.mjs";
9
4
  import { readFile } from "node:fs/promises";
10
- import { fileURLToPath } from "node:url";
11
5
  import { parse } from "graphql";
6
+ import { fileURLToPath } from "node:url";
12
7
 
13
- //#region src/rollup.ts
8
+ //#region src/nitro/rollup.ts
14
9
  async function rollupConfig(nitro) {
15
- virtualSchemas(nitro);
16
- virtualResolvers(nitro);
17
- virtualDirectives(nitro);
18
- virtualGraphQLConfig(nitro);
19
- virtualModuleConfig(nitro);
20
- virtualDebugInfo(nitro);
10
+ registerAllVirtualModules(nitro);
21
11
  nitro.hooks.hook("rollup:before", (_, rollupConfig$1) => {
22
12
  rollupConfig$1.plugins = rollupConfig$1.plugins || [];
23
13
  const { include = /\.(?:graphql|gql)$/i, exclude, validate = false } = nitro.options.graphql?.loader || {};
@@ -31,12 +21,10 @@ async function rollupConfig(nitro) {
31
21
  if (id.startsWith("#nitro-graphql/")) return `\0virtual:${id}`;
32
22
  if (parent?.startsWith("\0virtual:#nitro-graphql")) {
33
23
  const runtimeDir = fileURLToPath(new URL("routes", import.meta.url));
34
- const internalRes = await this.resolve(id, runtimeDir, {
35
- skipSelf: true,
36
- ...options
37
- });
38
- if (internalRes) return internalRes;
24
+ const internalRes = await this.resolve(id, runtimeDir, { skipSelf: true });
25
+ if (internalRes) return internalRes.id;
39
26
  }
27
+ return null;
40
28
  }
41
29
  },
42
30
  load: {
@@ -90,8 +78,8 @@ async function rollupConfig(nitro) {
90
78
  buildStart: {
91
79
  order: "pre",
92
80
  async handler() {
93
- const graphqlFiles = await scanGraphql(nitro);
94
- for (const file of graphqlFiles) this.addWatchFile(file);
81
+ const result = await NitroAdapter.scanGraphql(nitro);
82
+ for (const file of result.items) this.addWatchFile(file);
95
83
  }
96
84
  }
97
85
  });
@@ -1,6 +1,6 @@
1
1
  import * as nitro_deps_h30 from "nitro/deps/h3";
2
2
 
3
- //#region src/routes/apollo-server.d.ts
3
+ //#region src/nitro/routes/apollo-server.d.ts
4
4
  declare const _default: nitro_deps_h30.EventHandlerWithFetch<nitro_deps_h30.EventHandlerRequest, Promise<any>>;
5
5
  //#endregion
6
6
  export { _default as default };