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

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 (204) hide show
  1. package/README.md +2 -2
  2. package/dist/cli/commands/generate.d.mts +26 -0
  3. package/dist/cli/commands/generate.mjs +196 -0
  4. package/dist/cli/commands/index.d.mts +4 -0
  5. package/dist/cli/commands/index.mjs +5 -0
  6. package/dist/cli/commands/init.d.mts +43 -0
  7. package/dist/cli/commands/init.mjs +191 -0
  8. package/dist/cli/commands/validate.d.mts +10 -0
  9. package/dist/cli/commands/validate.mjs +69 -0
  10. package/dist/cli/completions.d.mts +7 -0
  11. package/dist/cli/completions.mjs +34 -0
  12. package/dist/cli/config.d.mts +75 -0
  13. package/dist/cli/config.mjs +20 -0
  14. package/dist/cli/index.d.mts +24 -0
  15. package/dist/cli/index.mjs +253 -0
  16. package/dist/core/codegen/client.d.mts +23 -0
  17. package/dist/core/codegen/client.mjs +150 -0
  18. package/dist/core/codegen/document-loader.d.mts +10 -0
  19. package/dist/core/codegen/document-loader.mjs +18 -0
  20. package/dist/core/codegen/index.d.mts +8 -0
  21. package/dist/core/codegen/index.mjs +9 -0
  22. package/dist/{utils/codegen-plugin.d.mts → core/codegen/plugin.d.mts} +2 -2
  23. package/dist/{utils/codegen-plugin.mjs → core/codegen/plugin.mjs} +1 -1
  24. package/dist/core/codegen/runtime.d.mts +20 -0
  25. package/dist/core/codegen/runtime.mjs +60 -0
  26. package/dist/core/codegen/schema-loader.d.mts +28 -0
  27. package/dist/core/codegen/schema-loader.mjs +128 -0
  28. package/dist/core/codegen/server.d.mts +28 -0
  29. package/dist/core/codegen/server.mjs +143 -0
  30. package/dist/{codegen → core/codegen}/validation.d.mts +1 -1
  31. package/dist/{codegen → core/codegen}/validation.mjs +1 -1
  32. package/dist/core/config.d.mts +50 -0
  33. package/dist/core/config.mjs +82 -0
  34. package/dist/core/constants.d.mts +188 -0
  35. package/dist/core/constants.mjs +210 -0
  36. package/dist/core/index.d.mts +32 -0
  37. package/dist/core/index.mjs +26 -0
  38. package/dist/core/scanning/ast-scanner.d.mts +23 -0
  39. package/dist/core/scanning/ast-scanner.mjs +103 -0
  40. package/dist/core/scanning/common.d.mts +37 -0
  41. package/dist/core/scanning/common.mjs +60 -0
  42. package/dist/core/scanning/directives.d.mts +10 -0
  43. package/dist/core/scanning/directives.mjs +29 -0
  44. package/dist/core/scanning/documents.d.mts +21 -0
  45. package/dist/core/scanning/documents.mjs +43 -0
  46. package/dist/core/scanning/index.d.mts +7 -0
  47. package/dist/core/scanning/index.mjs +8 -0
  48. package/dist/core/scanning/resolvers.d.mts +10 -0
  49. package/dist/core/scanning/resolvers.mjs +58 -0
  50. package/dist/core/scanning/schemas.d.mts +14 -0
  51. package/dist/core/scanning/schemas.mjs +64 -0
  52. package/dist/{utils/schema-builder.d.mts → core/schema/builder.d.mts} +7 -2
  53. package/dist/{utils/schema-builder.mjs → core/schema/builder.mjs} +22 -3
  54. package/dist/{utils → core/schema}/federation.d.mts +10 -5
  55. package/dist/{utils → core/schema}/federation.mjs +1 -1
  56. package/dist/core/schema/index.d.mts +3 -0
  57. package/dist/core/schema/index.mjs +4 -0
  58. package/dist/core/types/adapter.d.mts +58 -0
  59. package/dist/core/types/codegen.d.mts +133 -0
  60. package/dist/core/types/config.d.mts +212 -0
  61. package/dist/{types → core/types}/define.d.mts +3 -7
  62. package/dist/core/types/index.d.mts +5 -0
  63. package/dist/core/types/scanning.d.mts +69 -0
  64. package/dist/core/types/scanning.mjs +1 -0
  65. package/dist/{utils → core/utils}/directive-parser.d.mts +21 -5
  66. package/dist/{utils → core/utils}/directive-parser.mjs +25 -36
  67. package/dist/{utils → core/utils}/errors.d.mts +8 -4
  68. package/dist/{utils → core/utils}/errors.mjs +8 -4
  69. package/dist/core/utils/file-io.d.mts +24 -0
  70. package/dist/core/utils/file-io.mjs +47 -0
  71. package/dist/{utils → core/utils}/imports.d.mts +1 -1
  72. package/dist/{utils → core/utils}/imports.mjs +1 -1
  73. package/dist/core/utils/index.d.mts +7 -0
  74. package/dist/core/utils/index.mjs +8 -0
  75. package/dist/core/utils/logger.d.mts +19 -0
  76. package/dist/core/utils/logger.mjs +38 -0
  77. package/dist/{utils → core/utils}/ofetch-templates.d.mts +1 -1
  78. package/dist/{utils → core/utils}/ofetch-templates.mjs +1 -1
  79. package/dist/core/validation/external-services.d.mts +11 -0
  80. package/dist/{utils/validation.mjs → core/validation/external-services.mjs} +3 -3
  81. package/dist/core/validation/index.d.mts +2 -0
  82. package/dist/core/validation/index.mjs +3 -0
  83. package/dist/define.d.mts +2 -4
  84. package/dist/define.mjs +1 -1
  85. package/dist/index.d.mts +6 -44
  86. package/dist/index.mjs +5 -62
  87. package/dist/nitro/adapter.d.mts +30 -0
  88. package/dist/nitro/adapter.mjs +97 -0
  89. package/dist/{utils → nitro}/apollo.d.mts +1 -1
  90. package/dist/{utils → nitro}/apollo.mjs +1 -1
  91. package/dist/nitro/codegen.d.mts +19 -0
  92. package/dist/nitro/codegen.mjs +141 -0
  93. package/dist/nitro/config.d.mts +52 -0
  94. package/dist/nitro/config.mjs +58 -0
  95. package/dist/nitro/index.d.mts +46 -0
  96. package/dist/nitro/index.mjs +65 -0
  97. package/dist/{utils/path-resolver.d.mts → nitro/paths.d.mts} +3 -19
  98. package/dist/{utils/path-resolver.mjs → nitro/paths.mjs} +2 -36
  99. package/dist/{rollup.d.mts → nitro/rollup.d.mts} +1 -1
  100. package/dist/{rollup.mjs → nitro/rollup.mjs} +11 -23
  101. package/dist/{routes → nitro/routes}/apollo-server.d.mts +1 -1
  102. package/dist/{routes → nitro/routes}/apollo-server.mjs +5 -5
  103. package/dist/{routes → nitro/routes}/debug-template.d.mts +1 -1
  104. package/dist/{routes → nitro/routes}/debug-template.mjs +1 -1
  105. package/dist/{routes → nitro/routes}/debug.d.mts +10 -16
  106. package/dist/{routes → nitro/routes}/debug.mjs +2 -2
  107. package/dist/{routes → nitro/routes}/graphql-yoga.d.mts +1 -1
  108. package/dist/{routes → nitro/routes}/graphql-yoga.mjs +3 -3
  109. package/dist/{routes → nitro/routes}/health.d.mts +1 -1
  110. package/dist/{routes → nitro/routes}/health.mjs +1 -1
  111. package/dist/nitro/setup/file-watcher.d.mts +16 -0
  112. package/dist/{setup → nitro/setup}/file-watcher.mjs +14 -18
  113. package/dist/{setup.d.mts → nitro/setup/logging.d.mts} +5 -6
  114. package/dist/nitro/setup/logging.mjs +66 -0
  115. package/dist/nitro/setup/rollup-integration.d.mts +16 -0
  116. package/dist/{setup → nitro/setup}/rollup-integration.mjs +2 -2
  117. package/dist/nitro/setup/routes.d.mts +10 -0
  118. package/dist/nitro/setup/routes.mjs +35 -0
  119. package/dist/nitro/setup/ts-config.d.mts +11 -0
  120. package/dist/{setup → nitro/setup}/ts-config.mjs +3 -3
  121. package/dist/nitro/setup.d.mts +12 -0
  122. package/dist/{setup.mjs → nitro/setup.mjs} +33 -100
  123. package/dist/{types/index.d.mts → nitro/types.d.mts} +125 -43
  124. package/dist/nitro/types.mjs +1 -0
  125. package/dist/nitro/virtual/generators.d.mts +31 -0
  126. package/dist/nitro/virtual/generators.mjs +193 -0
  127. package/dist/nitro/virtual/stubs.d.mts +20 -0
  128. package/dist/nitro/virtual/stubs.mjs +31 -0
  129. package/dist/{ecosystem/nuxt.d.mts → nuxt.d.mts} +1 -1
  130. package/dist/{ecosystem/nuxt.mjs → nuxt.mjs} +2 -2
  131. package/dist/{graphql/server.d.mts → stubs/index.d.mts} +5 -1
  132. package/dist/stubs/index.mjs +1 -0
  133. package/package.json +45 -42
  134. package/dist/codegen/client-types.d.mts +0 -13
  135. package/dist/codegen/client-types.mjs +0 -131
  136. package/dist/codegen/external-types.d.mts +0 -12
  137. package/dist/codegen/external-types.mjs +0 -88
  138. package/dist/codegen/index.d.mts +0 -18
  139. package/dist/codegen/index.mjs +0 -24
  140. package/dist/codegen/server-types.d.mts +0 -13
  141. package/dist/codegen/server-types.mjs +0 -64
  142. package/dist/config/defaults.mjs +0 -36
  143. package/dist/constants/scalars.mjs +0 -27
  144. package/dist/constants.mjs +0 -106
  145. package/dist/graphql/index.d.mts +0 -5
  146. package/dist/setup/graphql-scanner.mjs +0 -25
  147. package/dist/setup/scaffold-generator.mjs +0 -109
  148. package/dist/types/standard-schema.d.mts +0 -59
  149. package/dist/utils/client-codegen.d.mts +0 -41
  150. package/dist/utils/client-codegen.mjs +0 -277
  151. package/dist/utils/file-generator.d.mts +0 -37
  152. package/dist/utils/file-generator.mjs +0 -72
  153. package/dist/utils/file-writer.d.mts +0 -35
  154. package/dist/utils/file-writer.mjs +0 -32
  155. package/dist/utils/index.d.mts +0 -13
  156. package/dist/utils/index.mjs +0 -13
  157. package/dist/utils/layers.d.mts +0 -22
  158. package/dist/utils/layers.mjs +0 -28
  159. package/dist/utils/scanning/common.d.mts +0 -23
  160. package/dist/utils/scanning/common.mjs +0 -39
  161. package/dist/utils/scanning/directives.d.mts +0 -11
  162. package/dist/utils/scanning/directives.mjs +0 -43
  163. package/dist/utils/scanning/documents.d.mts +0 -15
  164. package/dist/utils/scanning/documents.mjs +0 -46
  165. package/dist/utils/scanning/index.d.mts +0 -6
  166. package/dist/utils/scanning/index.mjs +0 -7
  167. package/dist/utils/scanning/resolvers.d.mts +0 -11
  168. package/dist/utils/scanning/resolvers.mjs +0 -100
  169. package/dist/utils/scanning/schemas.d.mts +0 -15
  170. package/dist/utils/scanning/schemas.mjs +0 -29
  171. package/dist/utils/server-codegen.d.mts +0 -7
  172. package/dist/utils/server-codegen.mjs +0 -113
  173. package/dist/utils/type-generation.d.mts +0 -6
  174. package/dist/utils/type-generation.mjs +0 -7
  175. package/dist/utils/validation.d.mts +0 -11
  176. package/dist/virtual/debug-info.d.mts +0 -9
  177. package/dist/virtual/debug-info.mjs +0 -26
  178. package/dist/virtual/generators/config.d.mts +0 -22
  179. package/dist/virtual/generators/config.mjs +0 -36
  180. package/dist/virtual/generators/debug.d.mts +0 -14
  181. package/dist/virtual/generators/debug.mjs +0 -53
  182. package/dist/virtual/generators/directives.d.mts +0 -14
  183. package/dist/virtual/generators/directives.mjs +0 -52
  184. package/dist/virtual/generators/index.d.mts +0 -6
  185. package/dist/virtual/generators/index.mjs +0 -7
  186. package/dist/virtual/generators/resolvers.d.mts +0 -14
  187. package/dist/virtual/generators/resolvers.mjs +0 -55
  188. package/dist/virtual/generators/schemas.d.mts +0 -14
  189. package/dist/virtual/generators/schemas.mjs +0 -43
  190. package/dist/virtual/graphql-config.d.mts +0 -9
  191. package/dist/virtual/graphql-config.mjs +0 -10
  192. package/dist/virtual/module-config.d.mts +0 -9
  193. package/dist/virtual/module-config.mjs +0 -10
  194. package/dist/virtual/server-directives.d.mts +0 -11
  195. package/dist/virtual/server-directives.mjs +0 -10
  196. package/dist/virtual/server-resolvers.d.mts +0 -11
  197. package/dist/virtual/server-resolvers.mjs +0 -10
  198. package/dist/virtual/server-schemas.d.mts +0 -11
  199. package/dist/virtual/server-schemas.mjs +0 -10
  200. /package/dist/{graphql/index.mjs → core/types/adapter.mjs} +0 -0
  201. /package/dist/{graphql/server.mjs → core/types/codegen.mjs} +0 -0
  202. /package/dist/{types/define.mjs → core/types/config.mjs} +0 -0
  203. /package/dist/{types/index.mjs → core/types/define.mjs} +0 -0
  204. /package/dist/{types/standard-schema.mjs → core/types/index.mjs} +0 -0
@@ -1,8 +1,8 @@
1
- import { getDefaultPaths, getTypesConfig, resolveFilePath } from "../utils/path-resolver.mjs";
2
- import { relativeWithDot } from "../utils/imports.mjs";
1
+ import { relativeWithDot } from "../../core/utils/imports.mjs";
2
+ import { getDefaultPaths, getTypesConfig, resolveFilePath } from "../paths.mjs";
3
3
  import { dirname, join, resolve } from "pathe";
4
4
 
5
- //#region src/setup/ts-config.ts
5
+ //#region src/nitro/setup/ts-config.ts
6
6
  /**
7
7
  * Setup TypeScript path aliases for GraphQL types
8
8
  * Called via nitro:config hook to extend tsconfig.json
@@ -0,0 +1,12 @@
1
+ import { resolveSecurityConfig } from "./setup/logging.mjs";
2
+ import { Nitro } from "nitro/types";
3
+
4
+ //#region src/nitro/setup.d.ts
5
+
6
+ /**
7
+ * Main setup function for nitro-graphql
8
+ * Coordinates all initialization steps for the module
9
+ */
10
+ declare function setupNitroGraphQL(nitro: Nitro): Promise<void>;
11
+ //#endregion
12
+ export { resolveSecurityConfig, setupNitroGraphQL };
@@ -1,35 +1,35 @@
1
- import { ENDPOINT_DEBUG, FRAMEWORK_NITRO, FRAMEWORK_NUXT, GRAPHQL_HTTP_METHODS, LOG_TAG } from "./constants.mjs";
2
- import { getDefaultPaths } from "./utils/path-resolver.mjs";
3
- import { generateServerTypes } from "./codegen/server-types.mjs";
4
- import { generateClientTypes } from "./codegen/index.mjs";
5
- import { DEFAULT_RUNTIME_CONFIG, DEFAULT_TYPESCRIPT_STRICT, DEFAULT_TYPES_CONFIG } from "./config/defaults.mjs";
6
- import { validateExternalServices } from "./utils/validation.mjs";
1
+ import { FRAMEWORK_NITRO, FRAMEWORK_NUXT, LOG_TAG } from "../core/constants.mjs";
2
+ import { generateDirectiveSchemas } from "../core/utils/directive-parser.mjs";
3
+ import { validateExternalServices } from "../core/validation/external-services.mjs";
4
+ import { NitroAdapter } from "./adapter.mjs";
5
+ import { getDefaultPaths } from "./paths.mjs";
6
+ import { generateClientTypes, generateServerTypes } from "./codegen.mjs";
7
+ import { DEFAULT_RUNTIME_CONFIG, DEFAULT_TYPESCRIPT_STRICT, DEFAULT_TYPES_CONFIG } from "./config.mjs";
7
8
  import { rollupConfig } from "./rollup.mjs";
8
9
  import { getWatchDirectories, setupFileWatcher } from "./setup/file-watcher.mjs";
9
- import { scanAllGraphQLFiles } from "./setup/graphql-scanner.mjs";
10
+ import { logStartupInfo, resolveSecurityConfig } from "./setup/logging.mjs";
10
11
  import { setupRollupChunking, setupRollupExternals } from "./setup/rollup-integration.mjs";
11
- import { generateScaffoldFiles } from "./setup/scaffold-generator.mjs";
12
+ import { registerRouteHandlers } from "./setup/routes.mjs";
12
13
  import { setupTypeScriptPaths } from "./setup/ts-config.mjs";
13
14
  import defu from "defu";
14
- import { fileURLToPath } from "node:url";
15
15
  import consola from "consola";
16
- import { join, relative, resolve } from "pathe";
16
+ import { relative, resolve } from "pathe";
17
17
 
18
- //#region src/setup.ts
18
+ //#region src/nitro/setup.ts
19
19
  const logger = consola.withTag(LOG_TAG);
20
20
  /**
21
- * Resolves security configuration with environment-aware defaults
22
- * In production: introspection off, playground off, errors masked, suggestions disabled
23
- * In development: introspection on, playground on, errors shown, suggestions enabled
21
+ * Scan all GraphQL files and update Nitro state
24
22
  */
25
- function resolveSecurityConfig(config) {
26
- const isProd = process.env.NODE_ENV === "production";
27
- return {
28
- introspection: config?.introspection ?? !isProd,
29
- playground: config?.playground ?? !isProd,
30
- maskErrors: config?.maskErrors ?? isProd,
31
- disableSuggestions: config?.disableSuggestions ?? isProd
32
- };
23
+ async function scanAllGraphQLFiles(nitro) {
24
+ const directivesResult = await NitroAdapter.scanDirectives(nitro);
25
+ nitro.scanDirectives = directivesResult.items;
26
+ if (!nitro.scanSchemas) nitro.scanSchemas = [];
27
+ const directivesPath = await generateDirectiveSchemas(nitro, directivesResult.items);
28
+ const schemas = (await NitroAdapter.scanSchemas(nitro)).items;
29
+ if (directivesPath && !schemas.includes(directivesPath)) schemas.push(directivesPath);
30
+ nitro.scanSchemas = schemas;
31
+ nitro.scanDocuments = (await NitroAdapter.scanDocuments(nitro)).items;
32
+ nitro.scanResolvers = (await NitroAdapter.scanResolvers(nitro)).items;
33
33
  }
34
34
  /**
35
35
  * Main setup function for nitro-graphql
@@ -54,7 +54,6 @@ async function setupNitroGraphQL(nitro) {
54
54
  if (serverEnabled) registerRouteHandlers(nitro);
55
55
  setupTypeScriptConfiguration(nitro);
56
56
  setupNuxtIntegration(nitro);
57
- if (serverEnabled) generateScaffoldFiles(nitro);
58
57
  logStartupInfo(nitro, serverEnabled);
59
58
  }
60
59
  /**
@@ -139,11 +138,18 @@ function setupFileWatching(nitro, serverEnabled) {
139
138
  * Scan all GraphQL files (schemas, resolvers, directives, documents)
140
139
  */
141
140
  async function scanGraphQLFiles(nitro, serverEnabled) {
142
- if (serverEnabled) await scanAllGraphQLFiles(nitro);
143
- else {
144
- const { scanDocuments } = await import("./utils/index.mjs");
145
- nitro.scanDocuments = await scanDocuments(nitro);
141
+ const skipLocalScan = nitro.options.graphql?.skipLocalScan === true;
142
+ const extendSources = nitro.options.graphql?.extend;
143
+ if (skipLocalScan && extendSources?.length) {
144
+ logger.info(`Using ${extendSources.length} extend source(s), skipping local scanning`);
145
+ nitro.scanSchemas = [];
146
+ nitro.scanResolvers = [];
147
+ nitro.scanDirectives = [];
148
+ nitro.scanDocuments = (await NitroAdapter.scanDocuments(nitro)).items;
149
+ return;
146
150
  }
151
+ if (serverEnabled) await scanAllGraphQLFiles(nitro);
152
+ else nitro.scanDocuments = (await NitroAdapter.scanDocuments(nitro)).items;
147
153
  }
148
154
  /**
149
155
  * Setup dev mode hooks for rescanning files
@@ -203,33 +209,6 @@ function setupCloseHooks(nitro, serverEnabled) {
203
209
  });
204
210
  }
205
211
  /**
206
- * Register GraphQL route handlers
207
- */
208
- function registerRouteHandlers(nitro) {
209
- const runtime = fileURLToPath(new URL("routes", import.meta.url));
210
- const framework = nitro.options.graphql?.framework;
211
- if (framework === "graphql-yoga") for (const method of GRAPHQL_HTTP_METHODS) nitro.options.handlers.push({
212
- route: nitro.options.runtimeConfig.graphql?.endpoint?.graphql || "/api/graphql",
213
- handler: join(runtime, "graphql-yoga"),
214
- method
215
- });
216
- if (framework === "apollo-server") for (const method of GRAPHQL_HTTP_METHODS) nitro.options.handlers.push({
217
- route: nitro.options.runtimeConfig.graphql?.endpoint?.graphql || "/api/graphql",
218
- handler: join(runtime, "apollo-server"),
219
- method
220
- });
221
- nitro.options.handlers.push({
222
- route: nitro.options.runtimeConfig.graphql?.endpoint?.healthCheck || "/api/graphql/health",
223
- handler: join(runtime, "health"),
224
- method: "GET"
225
- });
226
- if (nitro.options.dev) nitro.options.handlers.push({
227
- route: ENDPOINT_DEBUG,
228
- handler: join(runtime, "debug"),
229
- method: "GET"
230
- });
231
- }
232
- /**
233
212
  * Setup TypeScript configuration and path aliases
234
213
  */
235
214
  function setupTypeScriptConfiguration(nitro) {
@@ -247,52 +226,6 @@ function setupNuxtIntegration(nitro) {
247
226
  if (nuxtOptions) nuxtOptions.nitroGraphqlExternalServices = nitro.options.graphql?.externalServices || [];
248
227
  });
249
228
  }
250
- /**
251
- * Log startup information
252
- */
253
- function logStartupInfo(nitro, serverEnabled) {
254
- const externalServicesCount = nitro.options.graphql?.externalServices?.length || 0;
255
- const docs = nitro.scanDocuments || [];
256
- const isProd = process.env.NODE_ENV === "production";
257
- if (serverEnabled) {
258
- const securityConfig = resolveSecurityConfig(nitro.options.graphql?.security);
259
- const framework = nitro.options.graphql?.framework || "unknown";
260
- const schemas = nitro.scanSchemas?.length || 0;
261
- const resolvers = nitro.scanResolvers?.length || 0;
262
- consola.box({
263
- title: "Nitro GraphQL",
264
- message: [
265
- `Framework: ${framework}`,
266
- `Environment: ${isProd ? "production" : "development"}`,
267
- `Schemas: ${schemas}`,
268
- `Resolvers: ${resolvers}`,
269
- externalServicesCount > 0 ? `External Services: ${externalServicesCount}` : "",
270
- docs.length > 0 ? `Documents: ${docs.length}` : "",
271
- "",
272
- "Security:",
273
- `├─ Introspection: ${securityConfig.introspection ? "enabled" : "disabled"}`,
274
- `├─ Playground: ${securityConfig.playground ? "enabled" : "disabled"}`,
275
- `├─ Error Masking: ${securityConfig.maskErrors ? "enabled" : "disabled"}`,
276
- `└─ Field Suggestions: ${securityConfig.disableSuggestions ? "disabled" : "enabled"}`
277
- ].filter(Boolean).join("\n"),
278
- style: {
279
- borderColor: isProd ? "yellow" : "cyan",
280
- borderStyle: "rounded"
281
- }
282
- });
283
- } else consola.box({
284
- title: "Nitro GraphQL (Client Only)",
285
- message: [
286
- "Server mode: disabled",
287
- `External Services: ${externalServicesCount}`,
288
- `Documents: ${docs.length}`
289
- ].join("\n"),
290
- style: {
291
- borderColor: "blue",
292
- borderStyle: "rounded"
293
- }
294
- });
295
- }
296
229
 
297
230
  //#endregion
298
231
  export { resolveSecurityConfig, setupNitroGraphQL };
@@ -1,12 +1,113 @@
1
- import { StandardSchemaV1 } from "./standard-schema.mjs";
2
1
  import { TypeScriptPluginConfig } from "@graphql-codegen/typescript";
3
2
  import { plugin as plugin$1 } from "@graphql-codegen/typescript-generic-sdk";
4
3
  import { TypeScriptDocumentsPluginConfig } from "@graphql-codegen/typescript-operations";
5
4
  import { IResolvers } from "@graphql-tools/utils";
5
+ import { GraphQLSchema } from "graphql";
6
6
  import { TypeScriptResolversPluginConfig } from "@graphql-codegen/typescript-resolvers";
7
7
  import { ESMCodeGenOptions } from "knitwork";
8
+ import { ApolloServerOptions } from "@apollo/server";
9
+ import { H3Event } from "nitro/h3";
10
+ import { YogaServerOptions } from "graphql-yoga";
11
+ import { NPMConfig } from "#graphql/server";
8
12
 
9
- //#region src/types/index.d.ts
13
+ //#region src/nitro/types.d.ts
14
+
15
+ /** The Standard Schema interface. */
16
+ interface StandardSchemaV1<Input = unknown, Output = Input> {
17
+ /** The Standard Schema properties. */
18
+ readonly '~standard': StandardSchemaV1.Props<Input, Output>;
19
+ }
20
+ declare namespace StandardSchemaV1 {
21
+ /** The Standard Schema properties interface. */
22
+ export interface Props<Input = unknown, Output = Input> {
23
+ /** The version number of the standard. */
24
+ readonly version: 1;
25
+ /** The vendor name of the schema library. */
26
+ readonly vendor: string;
27
+ /** Validates unknown input values. */
28
+ readonly validate: (value: unknown) => Result<Output> | Promise<Result<Output>>;
29
+ /** Inferred types associated with the schema. */
30
+ readonly types?: Types<Input, Output> | undefined;
31
+ }
32
+ /** The result interface of the validate function. */
33
+ export type Result<Output> = SuccessResult<Output> | FailureResult;
34
+ /** The result interface if validation succeeds. */
35
+ export interface SuccessResult<Output> {
36
+ /** The typed output value. */
37
+ readonly value: Output;
38
+ /** The non-existent issues. */
39
+ readonly issues?: undefined;
40
+ }
41
+ /** The result interface if validation fails. */
42
+ export interface FailureResult {
43
+ /** The issues of failed validation. */
44
+ readonly issues: ReadonlyArray<Issue>;
45
+ }
46
+ /** The issue interface of the failure output. */
47
+ export interface Issue {
48
+ /** The error message of the issue. */
49
+ readonly message: string;
50
+ /** The path of the issue, if any. */
51
+ readonly path?: ReadonlyArray<PropertyKey | PathSegment> | undefined;
52
+ }
53
+ /** The path segment interface of the issue. */
54
+ export interface PathSegment {
55
+ /** The key representing a path segment. */
56
+ readonly key: PropertyKey;
57
+ }
58
+ /** The Standard Schema types interface. */
59
+ export interface Types<Input = unknown, Output = Input> {
60
+ /** The input type of the schema. */
61
+ readonly input: Input;
62
+ /** The output type of the schema. */
63
+ readonly output: Output;
64
+ }
65
+ /** Infers the input type of a Standard Schema. */
66
+ export type InferInput<Schema extends StandardSchemaV1> = NonNullable<Schema['~standard']['types']>['input'];
67
+ /** Infers the output type of a Standard Schema. */
68
+ export type InferOutput<Schema extends StandardSchemaV1> = NonNullable<Schema['~standard']['types']>['output'];
69
+ export {};
70
+ }
71
+ type Flatten<T> = T extends infer U ? { [K in keyof U]: U[K] } : never;
72
+ type DefineServerConfig<T extends NPMConfig = NPMConfig> = T['framework'] extends 'graphql-yoga' ? Partial<YogaServerOptions<H3Event, Partial<H3Event>>> : T['framework'] extends 'apollo-server' ? Partial<ApolloServerOptions<H3Event>> : Partial<YogaServerOptions<H3Event, Partial<H3Event>>> | Partial<ApolloServerOptions<H3Event>>;
73
+ type DirectiveLocationName = 'QUERY' | 'MUTATION' | 'SUBSCRIPTION' | 'FIELD' | 'FRAGMENT_DEFINITION' | 'FRAGMENT_SPREAD' | 'INLINE_FRAGMENT' | 'VARIABLE_DEFINITION' | 'SCHEMA' | 'SCALAR' | 'OBJECT' | 'FIELD_DEFINITION' | 'ARGUMENT_DEFINITION' | 'INTERFACE' | 'UNION' | 'ENUM' | 'ENUM_VALUE' | 'INPUT_OBJECT' | 'INPUT_FIELD_DEFINITION';
74
+ type GraphQLScalarType = 'String' | 'Int' | 'Float' | 'Boolean' | 'ID' | 'JSON' | 'DateTime';
75
+ type GraphQLBaseType = GraphQLScalarType | (string & {});
76
+ type GraphQLArgumentType = 'String' | 'Int' | 'Float' | 'Boolean' | 'ID' | 'JSON' | 'DateTime' | 'String!' | 'Int!' | 'Float!' | 'Boolean!' | 'ID!' | 'JSON!' | 'DateTime!' | '[String]' | '[String!]' | '[String]!' | '[String!]!' | '[Int]' | '[Int!]' | '[Int]!' | '[Int!]!' | '[Float]' | '[Float!]' | '[Float]!' | '[Float!]!' | '[Boolean]' | '[Boolean!]' | '[Boolean]!' | '[Boolean!]!' | '[ID]' | '[ID!]' | '[ID]!' | '[ID!]!' | '[JSON]' | '[JSON!]' | '[JSON]!' | '[JSON!]!' | '[DateTime]' | '[DateTime!]' | '[DateTime]!' | '[DateTime!]!' | (string & {});
77
+ interface DirectiveArgument<T extends GraphQLArgumentType = GraphQLArgumentType> {
78
+ /**
79
+ * GraphQL type for the argument
80
+ * @example 'String', 'Int!', '[String!]!', 'DateTime', 'JSON'
81
+ */
82
+ type: T;
83
+ defaultValue?: any;
84
+ description?: string;
85
+ }
86
+ interface DirectiveArg {
87
+ type: GraphQLArgumentType;
88
+ defaultValue?: any;
89
+ description?: string;
90
+ }
91
+ interface DirectiveDefinition {
92
+ name: string;
93
+ locations: DirectiveLocationName[];
94
+ args?: Record<string, DirectiveArg>;
95
+ description?: string;
96
+ isRepeatable?: boolean;
97
+ transformer?: (schema: GraphQLSchema) => GraphQLSchema;
98
+ }
99
+ interface DefineDirectiveConfig {
100
+ name: string;
101
+ locations: ReadonlyArray<DirectiveLocationName>;
102
+ args?: Record<string, {
103
+ type: GraphQLArgumentType;
104
+ defaultValue?: any;
105
+ description?: string;
106
+ }>;
107
+ description?: string;
108
+ isRepeatable?: boolean;
109
+ transformer?: (schema: GraphQLSchema) => GraphQLSchema;
110
+ }
10
111
  type CodegenServerConfig = TypeScriptPluginConfig & TypeScriptResolversPluginConfig;
11
112
  type DocumentModeConfig = Pick<Parameters<typeof plugin$1>[2], 'documentMode'>;
12
113
  type DocumentModeEnum = NonNullable<DocumentModeConfig['documentMode']>;
@@ -73,8 +174,6 @@ interface ExternalServicePaths {
73
174
  sdk?: FileGenerationConfig;
74
175
  /** Type definitions file path (overrides global types.external config) */
75
176
  types?: FileGenerationConfig;
76
- /** ofetch client wrapper path (overrides global clientUtils.ofetch config) */
77
- ofetch?: FileGenerationConfig;
78
177
  }
79
178
  interface ExternalGraphQLService {
80
179
  /** Unique name for this service (used for file naming and type generation) */
@@ -129,34 +228,6 @@ interface FederationConfig {
129
228
  * - string: Generate at custom path (supports placeholders: {serviceName}, {buildDir}, {rootDir}, {framework})
130
229
  */
131
230
  type FileGenerationConfig = boolean | string;
132
- /**
133
- * Scaffold files configuration
134
- * Control auto-generation of scaffold/boilerplate files
135
- */
136
- interface ScaffoldConfig {
137
- /** Enable/disable all scaffold files */
138
- enabled?: boolean;
139
- /** graphql.config.ts - GraphQL Config file for IDE tooling */
140
- graphqlConfig?: FileGenerationConfig;
141
- /** server/graphql/schema.ts - Schema definition file */
142
- serverSchema?: FileGenerationConfig;
143
- /** server/graphql/config.ts - GraphQL server configuration */
144
- serverConfig?: FileGenerationConfig;
145
- /** server/graphql/context.ts - H3 context augmentation */
146
- serverContext?: FileGenerationConfig;
147
- }
148
- /**
149
- * Client utilities configuration
150
- * Control auto-generation of client-side utility files (Nuxt only)
151
- */
152
- interface ClientUtilsConfig {
153
- /** Enable/disable all client utilities */
154
- enabled?: boolean;
155
- /** app/graphql/index.ts - Main exports file */
156
- index?: FileGenerationConfig;
157
- /** app/graphql/{serviceName}/ofetch.ts - ofetch client wrapper */
158
- ofetch?: FileGenerationConfig;
159
- }
160
231
  /**
161
232
  * SDK files configuration
162
233
  * Control auto-generation of GraphQL SDK files
@@ -261,16 +332,6 @@ interface NitroGraphQLOptions {
261
332
  layerDirectories?: string[];
262
333
  layerServerDirs?: string[];
263
334
  layerAppDirs?: string[];
264
- /**
265
- * Scaffold files configuration
266
- * Set to false to disable all scaffold file generation (library mode)
267
- */
268
- scaffold?: false | ScaffoldConfig;
269
- /**
270
- * Client utilities configuration
271
- * Set to false to disable all client utility generation
272
- */
273
- clientUtils?: false | ClientUtilsConfig;
274
335
  /**
275
336
  * SDK files configuration
276
337
  * Set to false to disable all SDK generation
@@ -291,6 +352,27 @@ interface NitroGraphQLOptions {
291
352
  * Auto-detects NODE_ENV and applies secure defaults in production
292
353
  */
293
354
  security?: SecurityConfig;
355
+ /**
356
+ * Extend GraphQL server with external packages
357
+ * Auto-appends /resolvers and /schema to each package path
358
+ * @example extend: ['@myorg/graphql', './generated']
359
+ */
360
+ extend?: ExtendSource[];
361
+ /**
362
+ * Skip local file scanning, use only extend sources
363
+ * When true, only files from `extend` are used (local server/graphql ignored)
364
+ * @default false
365
+ */
366
+ skipLocalScan?: boolean;
294
367
  }
368
+ /**
369
+ * Extend source - package path or detailed config
370
+ * - string: auto-appends /resolvers and /schema
371
+ * - object: explicit paths for resolvers and/or schemas
372
+ */
373
+ type ExtendSource = string | {
374
+ resolvers?: string | string[];
375
+ schemas?: string | string[];
376
+ };
295
377
  //#endregion
296
- export { ClientUtilsConfig, CodegenClientConfig, CodegenServerConfig, ExternalGraphQLService, ExternalServicePaths, FederationConfig, FileGenerationConfig, GenImport, GenericSdkConfig, NitroGraphQLOptions, PathsConfig, ScaffoldConfig, SdkConfig, SecurityConfig, StandardSchemaV1, TypesConfig };
378
+ export { CodegenClientConfig, CodegenServerConfig, DefineDirectiveConfig, DefineServerConfig, DirectiveArgument, DirectiveDefinition, ExtendSource, ExternalGraphQLService, ExternalServicePaths, FederationConfig, FileGenerationConfig, Flatten, GenImport, GenericSdkConfig, GraphQLArgumentType, GraphQLBaseType, GraphQLScalarType, NitroGraphQLOptions, PathsConfig, SdkConfig, SecurityConfig, StandardSchemaV1, TypesConfig };
@@ -0,0 +1 @@
1
+ export { };
@@ -0,0 +1,31 @@
1
+ import { Nitro } from "nitro/types";
2
+
3
+ //#region src/nitro/virtual/generators.d.ts
4
+
5
+ declare const serverSchemas: {
6
+ id: string;
7
+ getCode: (nitro: Nitro) => string;
8
+ };
9
+ declare const serverResolvers: {
10
+ id: string;
11
+ getCode: (nitro: Nitro) => string;
12
+ };
13
+ declare const serverDirectives: {
14
+ id: string;
15
+ getCode: (nitro: Nitro) => string;
16
+ };
17
+ declare const graphqlConfig: {
18
+ id: string;
19
+ getCode: (nitro: Nitro) => string;
20
+ };
21
+ declare const moduleConfig: {
22
+ id: string;
23
+ getCode: (nitro: Nitro) => string;
24
+ };
25
+ declare const debugInfo: {
26
+ id: string;
27
+ getCode: (nitro: Nitro) => string;
28
+ };
29
+ declare function registerAllVirtualModules(nitro: Nitro): void;
30
+ //#endregion
31
+ export { debugInfo, graphqlConfig, moduleConfig, registerAllVirtualModules, serverDirectives, serverResolvers, serverSchemas };
@@ -0,0 +1,193 @@
1
+ import { getImportId } from "../../core/utils/imports.mjs";
2
+ import { isAbsolute, resolve } from "pathe";
3
+ import { genImport } from "knitwork";
4
+
5
+ //#region src/nitro/virtual/generators.ts
6
+ function normalizeExtendConfig(extend) {
7
+ if (!extend || !Array.isArray(extend) || extend.length === 0) return null;
8
+ const resolvers = [];
9
+ const schemas = [];
10
+ for (const source of extend) if (typeof source === "string") {
11
+ resolvers.push(`${source}/resolvers`);
12
+ schemas.push(`${source}/schema`);
13
+ } else if (source && typeof source === "object") {
14
+ const obj = source;
15
+ if (obj.resolvers) {
16
+ const r = Array.isArray(obj.resolvers) ? obj.resolvers : [obj.resolvers];
17
+ resolvers.push(...r);
18
+ }
19
+ if (obj.schemas) {
20
+ const s = Array.isArray(obj.schemas) ? obj.schemas : [obj.schemas];
21
+ schemas.push(...s);
22
+ }
23
+ }
24
+ if (resolvers.length === 0 && schemas.length === 0) return null;
25
+ return {
26
+ resolvers,
27
+ schemas
28
+ };
29
+ }
30
+ /**
31
+ * Resolve extend path to absolute path
32
+ * Supports: relative paths, absolute paths, package names
33
+ */
34
+ function resolveExtendPath(nitro, inputPath) {
35
+ if (inputPath.startsWith("@") || !inputPath.startsWith(".") && !inputPath.startsWith("/")) return inputPath;
36
+ if (isAbsolute(inputPath)) return inputPath;
37
+ return resolve(nitro.options.rootDir, inputPath);
38
+ }
39
+ function generateImportModule(items, exportName, wrapperKey) {
40
+ if (!items.length) return `export const ${exportName} = []`;
41
+ const imports = items.flatMap(({ specifier, imports: list, options }) => list?.length ? [genImport(specifier, list, options)] : []);
42
+ const data = items.flatMap(({ imports: list }) => list.map((i) => `{ ${wrapperKey}: ${i.as || i.name} }`));
43
+ return `${imports.join("\n")}\n\nexport const ${exportName} = [\n${data.join(",\n")}\n]`;
44
+ }
45
+ function safeGenerateModuleCode(nitro, moduleName) {
46
+ try {
47
+ const generator = nitro.options.virtual?.[moduleName];
48
+ if (generator && typeof generator === "function") return generator();
49
+ return "// Module not found";
50
+ } catch (error) {
51
+ return `// Error: ${error instanceof Error ? error.message : String(error)}`;
52
+ }
53
+ }
54
+ const serverSchemas = {
55
+ id: "#nitro-graphql/server-schemas",
56
+ getCode: (nitro) => {
57
+ const ext = normalizeExtendConfig(nitro.options.graphql?.extend);
58
+ const skipLocalScan = nitro.options.graphql?.skipLocalScan === true;
59
+ if (ext && ext.schemas.length > 0) {
60
+ const schemaPaths = ext.schemas.map((p) => resolveExtendPath(nitro, p));
61
+ const scannedSchemas = [...nitro.scanSchemas, ...nitro.options.graphql?.typedefs ?? []];
62
+ if (!skipLocalScan && scannedSchemas.length > 0) {
63
+ const extImports = schemaPaths.map((p, i) => `import { schemaString as extSchema${i} } from '${p}'`);
64
+ const scannedImports = scannedSchemas.map((s) => `import ${getImportId(s)} from '${s}';`);
65
+ const extDefs = schemaPaths.map((_, i) => `{ def: extSchema${i} }`);
66
+ const scannedDefs = scannedSchemas.map((s) => `{ def: ${getImportId(s)} }`);
67
+ return `${extImports.join("\n")}
68
+ ${scannedImports.join("\n")}
69
+
70
+ export const schemas = [
71
+ ${[...extDefs, ...scannedDefs].join(",\n")}
72
+ ]`;
73
+ }
74
+ if (schemaPaths.length === 1) return `import { schemaString, typeDefs } from '${schemaPaths[0]}'
75
+ export { schemaString, typeDefs }
76
+ export const schemas = [{ def: schemaString }]`;
77
+ const imports = schemaPaths.map((p, i) => `import { schemaString as schema${i} } from '${p}'`);
78
+ const schemaVars = schemaPaths.map((_, i) => `schema${i}`);
79
+ const mergeCode = `export const schemaString = [${schemaVars.join(", ")}].join('\\n\\n')
80
+ import { parse } from 'graphql'
81
+ export const typeDefs = parse(schemaString)
82
+ export const schemas = [${schemaVars.map((v) => `{ def: ${v} }`).join(", ")}]`;
83
+ return `${imports.join("\n")}\n\n${mergeCode}`;
84
+ }
85
+ const schemas = [...nitro.scanSchemas, ...nitro.options.graphql?.typedefs ?? []];
86
+ if (!schemas.length) {
87
+ if (nitro.options.dev) nitro.logger.warn("[nitro-graphql] No schemas found. Virtual module will export empty array.");
88
+ return "export const schemas = []";
89
+ }
90
+ const importStatements = schemas.map((s) => `import ${getImportId(s)} from '${s}';`);
91
+ const schemaArray = schemas.map((s) => `{ def: ${getImportId(s)} }`);
92
+ return `${importStatements.join("\n")}\n\nexport const schemas = [\n${schemaArray.join(",\n")}\n];`;
93
+ }
94
+ };
95
+ const serverResolvers = {
96
+ id: "#nitro-graphql/server-resolvers",
97
+ getCode: (nitro) => {
98
+ const ext = normalizeExtendConfig(nitro.options.graphql?.extend);
99
+ const skipLocalScan = nitro.options.graphql?.skipLocalScan === true;
100
+ if (ext && ext.resolvers.length > 0) {
101
+ const resolverPaths = ext.resolvers.map((p) => resolveExtendPath(nitro, p));
102
+ const imports$1 = resolverPaths.map((p, i) => `import { resolvers as resolvers${i} } from '${p}'`);
103
+ if (!skipLocalScan && nitro.scanResolvers.length > 0) {
104
+ const scannedCode = generateImportModule(nitro.scanResolvers, "scannedResolvers", "resolver");
105
+ const spreadAll$1 = [...resolverPaths.map((_, i) => `...resolvers${i}`), "...scannedResolvers"];
106
+ return `${imports$1.join("\n")}
107
+ ${scannedCode}
108
+
109
+ export const resolvers = [${spreadAll$1.join(", ")}]`;
110
+ }
111
+ if (resolverPaths.length === 1) return `export { resolvers } from '${resolverPaths[0]}'`;
112
+ const spreadAll = resolverPaths.map((_, i) => `...resolvers${i}`);
113
+ return `${imports$1.join("\n")}
114
+
115
+ export const resolvers = [${spreadAll.join(", ")}]`;
116
+ }
117
+ const imports = [...nitro.scanResolvers];
118
+ if (!imports.length) {
119
+ if (nitro.options.dev) nitro.logger.warn("[nitro-graphql] No resolvers found. Virtual module will export empty array.");
120
+ return "export const resolvers = []";
121
+ }
122
+ return generateImportModule(imports, "resolvers", "resolver");
123
+ }
124
+ };
125
+ const serverDirectives = {
126
+ id: "#nitro-graphql/server-directives",
127
+ getCode: (nitro) => {
128
+ const imports = nitro.scanDirectives || [];
129
+ if (!imports.length) return "export const directives = []";
130
+ return generateImportModule(imports, "directives", "directive");
131
+ }
132
+ };
133
+ const graphqlConfig = {
134
+ id: "#nitro-graphql/graphql-config",
135
+ getCode: (nitro) => {
136
+ return `import config from '${resolve(nitro.graphql.serverDir, "config.ts")}'
137
+ const importedConfig = config
138
+ export { importedConfig }
139
+ `;
140
+ }
141
+ };
142
+ const moduleConfig = {
143
+ id: "#nitro-graphql/module-config",
144
+ getCode: (nitro) => {
145
+ const config = nitro.options.graphql || {};
146
+ return `export const moduleConfig = ${JSON.stringify(config, null, 2)};`;
147
+ }
148
+ };
149
+ const debugInfo = {
150
+ id: "#nitro-graphql/debug-info",
151
+ getCode: (nitro) => {
152
+ const virtualModuleCodes = {
153
+ "server-schemas": safeGenerateModuleCode(nitro, "#nitro-graphql/server-schemas"),
154
+ "server-resolvers": safeGenerateModuleCode(nitro, "#nitro-graphql/server-resolvers"),
155
+ "server-directives": safeGenerateModuleCode(nitro, "#nitro-graphql/server-directives"),
156
+ "module-config": safeGenerateModuleCode(nitro, "#nitro-graphql/module-config"),
157
+ "graphql-config": safeGenerateModuleCode(nitro, "#nitro-graphql/graphql-config")
158
+ };
159
+ const info = {
160
+ isDev: nitro.options.dev,
161
+ framework: nitro.options.framework.name,
162
+ graphqlFramework: nitro.options.graphql?.framework,
163
+ federation: nitro.options.graphql?.federation,
164
+ scanned: {
165
+ schemas: nitro.scanSchemas?.length || 0,
166
+ schemaFiles: nitro.scanSchemas || [],
167
+ resolvers: nitro.scanResolvers?.length || 0,
168
+ resolverFiles: nitro.scanResolvers || [],
169
+ directives: nitro.scanDirectives?.length || 0,
170
+ directiveFiles: nitro.scanDirectives || [],
171
+ documents: nitro.scanDocuments?.length || 0,
172
+ documentFiles: nitro.scanDocuments || []
173
+ },
174
+ virtualModules: virtualModuleCodes
175
+ };
176
+ return `export const debugInfo = ${JSON.stringify(info, null, 2)};`;
177
+ }
178
+ };
179
+ const allModules = [
180
+ serverSchemas,
181
+ serverResolvers,
182
+ serverDirectives,
183
+ graphqlConfig,
184
+ moduleConfig,
185
+ debugInfo
186
+ ];
187
+ function registerAllVirtualModules(nitro) {
188
+ nitro.options.virtual ??= {};
189
+ for (const mod of allModules) nitro.options.virtual[mod.id] = () => mod.getCode(nitro);
190
+ }
191
+
192
+ //#endregion
193
+ export { debugInfo, graphqlConfig, moduleConfig, registerAllVirtualModules, serverDirectives, serverResolvers, serverSchemas };
@@ -0,0 +1,20 @@
1
+ //#region src/nitro/virtual/stubs.d.ts
2
+ /**
3
+ * Virtual module stubs for #nitro-graphql/*
4
+ * Used during build to prevent import resolution errors.
5
+ * At runtime, Nitro overrides these with actual virtual modules.
6
+ */
7
+ declare const schemas: Array<{
8
+ def: string;
9
+ }>;
10
+ declare const resolvers: Array<{
11
+ resolver: any;
12
+ }>;
13
+ declare const directives: Array<{
14
+ directive: any;
15
+ }>;
16
+ declare const moduleConfig: {};
17
+ declare const importedConfig: {};
18
+ declare const debugInfo: Record<string, any>;
19
+ //#endregion
20
+ export { debugInfo, directives, importedConfig, moduleConfig, resolvers, schemas };