nitro-graphql 2.0.0-beta.4 → 2.0.0-beta.41

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 (168) hide show
  1. package/README.md +438 -27
  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 +46 -0
  7. package/dist/cli/commands/init.mjs +195 -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/config.d.mts +2 -0
  17. package/dist/config.mjs +3 -0
  18. package/dist/core/codegen/client.d.mts +23 -0
  19. package/dist/core/codegen/client.mjs +150 -0
  20. package/dist/core/codegen/document-loader.d.mts +10 -0
  21. package/dist/core/codegen/document-loader.mjs +18 -0
  22. package/dist/core/codegen/index.d.mts +8 -0
  23. package/dist/core/codegen/index.mjs +9 -0
  24. package/dist/core/codegen/plugin.d.mts +20 -0
  25. package/dist/core/codegen/plugin.mjs +30 -0
  26. package/dist/core/codegen/runtime.d.mts +20 -0
  27. package/dist/core/codegen/runtime.mjs +60 -0
  28. package/dist/core/codegen/schema-loader.d.mts +28 -0
  29. package/dist/core/codegen/schema-loader.mjs +128 -0
  30. package/dist/core/codegen/server.d.mts +28 -0
  31. package/dist/core/codegen/server.mjs +143 -0
  32. package/dist/core/codegen/validation.d.mts +13 -0
  33. package/dist/core/codegen/validation.mjs +96 -0
  34. package/dist/core/config.d.mts +50 -0
  35. package/dist/core/config.mjs +82 -0
  36. package/dist/core/constants.d.mts +188 -0
  37. package/dist/core/constants.mjs +210 -0
  38. package/dist/core/index.d.mts +33 -0
  39. package/dist/core/index.mjs +27 -0
  40. package/dist/core/manifest.d.mts +46 -0
  41. package/dist/core/manifest.mjs +76 -0
  42. package/dist/core/scanning/ast-scanner.d.mts +28 -0
  43. package/dist/core/scanning/ast-scanner.mjs +122 -0
  44. package/dist/core/scanning/common.d.mts +37 -0
  45. package/dist/core/scanning/common.mjs +60 -0
  46. package/dist/core/scanning/directives.d.mts +10 -0
  47. package/dist/core/scanning/directives.mjs +29 -0
  48. package/dist/core/scanning/documents.d.mts +21 -0
  49. package/dist/core/scanning/documents.mjs +43 -0
  50. package/dist/core/scanning/index.d.mts +7 -0
  51. package/dist/core/scanning/index.mjs +8 -0
  52. package/dist/core/scanning/resolvers.d.mts +15 -0
  53. package/dist/core/scanning/resolvers.mjs +59 -0
  54. package/dist/core/scanning/schemas.d.mts +14 -0
  55. package/dist/core/scanning/schemas.mjs +64 -0
  56. package/dist/core/schema/builder.d.mts +53 -0
  57. package/dist/core/schema/builder.mjs +70 -0
  58. package/dist/core/schema/federation.d.mts +34 -0
  59. package/dist/core/schema/federation.mjs +40 -0
  60. package/dist/core/schema/index.d.mts +3 -0
  61. package/dist/core/schema/index.mjs +4 -0
  62. package/dist/core/types/adapter.d.mts +58 -0
  63. package/dist/core/types/codegen.d.mts +133 -0
  64. package/dist/core/types/config.d.mts +210 -0
  65. package/dist/core/types/config.mjs +1 -0
  66. package/dist/{utils/define.d.ts → core/types/define.d.mts} +3 -30
  67. package/dist/core/types/define.mjs +1 -0
  68. package/dist/core/types/index.d.mts +5 -0
  69. package/dist/core/types/index.mjs +1 -0
  70. package/dist/core/types/scanning.d.mts +69 -0
  71. package/dist/core/types/scanning.mjs +1 -0
  72. package/dist/{utils/directive-parser.d.ts → core/utils/directive-parser.d.mts} +21 -4
  73. package/dist/{utils/directive-parser.js → core/utils/directive-parser.mjs} +25 -34
  74. package/dist/core/utils/errors.d.mts +77 -0
  75. package/dist/core/utils/errors.mjs +93 -0
  76. package/dist/core/utils/file-io.d.mts +24 -0
  77. package/dist/core/utils/file-io.mjs +47 -0
  78. package/dist/core/utils/imports.d.mts +15 -0
  79. package/dist/core/utils/imports.mjs +25 -0
  80. package/dist/core/utils/index.d.mts +7 -0
  81. package/dist/core/utils/index.mjs +8 -0
  82. package/dist/core/utils/logger.d.mts +19 -0
  83. package/dist/core/utils/logger.mjs +38 -0
  84. package/dist/core/utils/ofetch-templates.d.mts +30 -0
  85. package/dist/core/utils/ofetch-templates.mjs +135 -0
  86. package/dist/core/validation/external-services.d.mts +11 -0
  87. package/dist/core/validation/external-services.mjs +34 -0
  88. package/dist/core/validation/index.d.mts +2 -0
  89. package/dist/core/validation/index.mjs +3 -0
  90. package/dist/define.d.mts +294 -0
  91. package/dist/define.mjs +323 -0
  92. package/dist/index.d.mts +6 -0
  93. package/dist/index.mjs +6 -0
  94. package/dist/nitro/adapter.d.mts +30 -0
  95. package/dist/nitro/adapter.mjs +97 -0
  96. package/dist/{utils/apollo.d.ts → nitro/apollo.d.mts} +3 -3
  97. package/dist/nitro/apollo.mjs +59 -0
  98. package/dist/nitro/codegen.d.mts +19 -0
  99. package/dist/nitro/codegen.mjs +141 -0
  100. package/dist/nitro/config.d.mts +51 -0
  101. package/dist/nitro/config.mjs +57 -0
  102. package/dist/nitro/index.d.mts +46 -0
  103. package/dist/nitro/index.mjs +65 -0
  104. package/dist/nitro/paths.d.mts +54 -0
  105. package/dist/nitro/paths.mjs +92 -0
  106. package/dist/nitro/rollup.d.mts +6 -0
  107. package/dist/nitro/rollup.mjs +95 -0
  108. package/dist/nitro/routes/apollo-server.d.mts +6 -0
  109. package/dist/nitro/routes/apollo-server.mjs +71 -0
  110. package/dist/nitro/routes/debug-template.d.mts +15 -0
  111. package/dist/nitro/routes/debug-template.mjs +385 -0
  112. package/dist/nitro/routes/debug.d.mts +55 -0
  113. package/dist/nitro/routes/debug.mjs +102 -0
  114. package/dist/nitro/routes/graphql-yoga.d.mts +6 -0
  115. package/dist/nitro/routes/graphql-yoga.mjs +62 -0
  116. package/dist/nitro/routes/health.d.mts +10 -0
  117. package/dist/{routes/health.js → nitro/routes/health.mjs} +4 -3
  118. package/dist/nitro/setup/extend-loader.d.mts +19 -0
  119. package/dist/nitro/setup/extend-loader.mjs +129 -0
  120. package/dist/nitro/setup/file-watcher.d.mts +16 -0
  121. package/dist/nitro/setup/file-watcher.mjs +98 -0
  122. package/dist/nitro/setup/logging.d.mts +17 -0
  123. package/dist/nitro/setup/logging.mjs +66 -0
  124. package/dist/nitro/setup/rollup-integration.d.mts +16 -0
  125. package/dist/nitro/setup/rollup-integration.mjs +90 -0
  126. package/dist/nitro/setup/routes.d.mts +10 -0
  127. package/dist/nitro/setup/routes.mjs +35 -0
  128. package/dist/nitro/setup/ts-config.d.mts +11 -0
  129. package/dist/nitro/setup/ts-config.mjs +69 -0
  130. package/dist/nitro/setup.d.mts +12 -0
  131. package/dist/nitro/setup.mjs +234 -0
  132. package/dist/nitro/types.d.mts +374 -0
  133. package/dist/nitro/types.mjs +1 -0
  134. package/dist/nitro/virtual/generators.d.mts +31 -0
  135. package/dist/nitro/virtual/generators.mjs +113 -0
  136. package/dist/nitro/virtual/stubs.d.mts +20 -0
  137. package/dist/nitro/virtual/stubs.mjs +31 -0
  138. package/dist/{ecosystem/nuxt.d.ts → nuxt.d.mts} +1 -1
  139. package/dist/nuxt.mjs +109 -0
  140. package/dist/{graphql/server.d.ts → stubs/index.d.mts} +5 -1
  141. package/dist/stubs/index.mjs +1 -0
  142. package/package.json +102 -77
  143. package/dist/ecosystem/nuxt.js +0 -67
  144. package/dist/graphql/index.d.ts +0 -5
  145. package/dist/index.d.ts +0 -8
  146. package/dist/index.js +0 -264
  147. package/dist/rollup.js +0 -119
  148. package/dist/routes/apollo-server.d.ts +0 -6
  149. package/dist/routes/apollo-server.js +0 -89
  150. package/dist/routes/graphql-yoga.d.ts +0 -6
  151. package/dist/routes/graphql-yoga.js +0 -91
  152. package/dist/routes/health.d.ts +0 -6
  153. package/dist/types/index.d.ts +0 -128
  154. package/dist/types/standard-schema.d.ts +0 -59
  155. package/dist/utils/apollo.js +0 -61
  156. package/dist/utils/client-codegen.d.ts +0 -38
  157. package/dist/utils/client-codegen.js +0 -290
  158. package/dist/utils/define.js +0 -57
  159. package/dist/utils/index.d.ts +0 -39
  160. package/dist/utils/index.js +0 -250
  161. package/dist/utils/server-codegen.d.ts +0 -7
  162. package/dist/utils/server-codegen.js +0 -136
  163. package/dist/utils/type-generation.d.ts +0 -7
  164. package/dist/utils/type-generation.js +0 -287
  165. package/dist/vite.d.ts +0 -25
  166. package/dist/vite.js +0 -40
  167. /package/dist/{graphql/index.js → core/types/adapter.mjs} +0 -0
  168. /package/dist/{graphql/server.js → core/types/codegen.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 };
@@ -1,9 +1,9 @@
1
1
  import { ApolloServer, BaseContext, ContextFunction } from "@apollo/server";
2
- import { EventHandler, H3Event } from "h3";
3
- import { WithRequired } from "@apollo/utils.withrequired";
2
+ import { EventHandler, H3Event } from "nitro/h3";
4
3
  import { Hooks } from "crossws";
5
4
 
6
- //#region src/utils/apollo.d.ts
5
+ //#region src/nitro/apollo.d.ts
6
+ type WithRequired<T, K extends keyof T> = T & { [P in K]-?: T[P] };
7
7
  interface H3ContextFunctionArgument {
8
8
  event: H3Event;
9
9
  }
@@ -0,0 +1,59 @@
1
+ import { HeaderMap } from "@apollo/server";
2
+ import { eventHandler, getRequestURL, readBody } from "nitro/h3";
3
+
4
+ //#region src/nitro/apollo.ts
5
+ function startServerAndCreateH3Handler(server, options) {
6
+ const defaultContext = () => Promise.resolve({});
7
+ const contextFunction = options?.context ?? defaultContext;
8
+ return eventHandler(async (event) => {
9
+ const apolloServer = typeof server === "function" ? server() : server;
10
+ if (!options?.serverAlreadyStarted) apolloServer.startInBackgroundHandlingStartupErrorsByLoggingAndFailingAllRequests();
11
+ if (event.req.method === "OPTIONS") {
12
+ event.res.status = 204;
13
+ return null;
14
+ }
15
+ try {
16
+ const graphqlRequest = await toGraphqlRequest(event);
17
+ const { body, headers, status } = await apolloServer.executeHTTPGraphQLRequest({
18
+ httpGraphQLRequest: graphqlRequest,
19
+ context: () => contextFunction({ event })
20
+ });
21
+ if (body.kind === "chunked") throw new Error("Incremental delivery not implemented");
22
+ for (const [key, value] of headers) event.res.headers.set(key, value);
23
+ event.res.status = status || 200;
24
+ return body.string;
25
+ } catch (error) {
26
+ if (error instanceof SyntaxError) {
27
+ event.res.status = 400;
28
+ return error.message;
29
+ } else throw error;
30
+ }
31
+ });
32
+ }
33
+ async function toGraphqlRequest(event) {
34
+ const url = getRequestURL(event);
35
+ return {
36
+ method: event.req.method || "POST",
37
+ headers: normalizeHeaders(Object.fromEntries(event.req.headers.entries())),
38
+ search: url.search.slice(1),
39
+ body: await normalizeBody(event)
40
+ };
41
+ }
42
+ function normalizeHeaders(headers) {
43
+ const headerMap = new HeaderMap();
44
+ for (const [key, value] of Object.entries(headers)) if (value !== void 0) headerMap.set(key, value);
45
+ return headerMap;
46
+ }
47
+ async function normalizeBody(event) {
48
+ const PayloadMethods = [
49
+ "PATCH",
50
+ "POST",
51
+ "PUT",
52
+ "DELETE"
53
+ ];
54
+ const method = event.req.method;
55
+ if (method && PayloadMethods.includes(method)) return await readBody(event);
56
+ }
57
+
58
+ //#endregion
59
+ export { startServerAndCreateH3Handler };
@@ -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, "{clientDir}/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, "{clientDir}/{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,51 @@
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 serverDir: "server/graphql";
35
+ readonly clientDir: null;
36
+ readonly typesDir: null;
37
+ };
38
+ /**
39
+ * Default TypeScript strict mode setting
40
+ */
41
+ declare const DEFAULT_TYPESCRIPT_STRICT: true;
42
+ /**
43
+ * Default watcher persistence setting
44
+ */
45
+ declare const DEFAULT_WATCHER_PERSISTENT: true;
46
+ /**
47
+ * Default watcher ignore initial setting
48
+ */
49
+ declare const DEFAULT_WATCHER_IGNORE_INITIAL: true;
50
+ //#endregion
51
+ 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,57 @@
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
+ serverDir: "server/graphql",
40
+ clientDir: null,
41
+ typesDir: null
42
+ };
43
+ /**
44
+ * Default TypeScript strict mode setting
45
+ */
46
+ const DEFAULT_TYPESCRIPT_STRICT = true;
47
+ /**
48
+ * Default watcher persistence setting
49
+ */
50
+ const DEFAULT_WATCHER_PERSISTENT = true;
51
+ /**
52
+ * Default watcher ignore initial setting
53
+ */
54
+ const DEFAULT_WATCHER_IGNORE_INITIAL = true;
55
+
56
+ //#endregion
57
+ 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, 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, 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 };
@@ -0,0 +1,54 @@
1
+ import { FileGenerationConfig, SdkConfig, TypesConfig } from "./types.mjs";
2
+ import { Nitro } from "nitro/types";
3
+
4
+ //#region src/nitro/paths.d.ts
5
+
6
+ /**
7
+ * Placeholder values for path resolution
8
+ */
9
+ interface PathPlaceholders {
10
+ serviceName?: string;
11
+ buildDir: string;
12
+ rootDir: string;
13
+ framework: 'nuxt' | 'nitro';
14
+ typesDir: string;
15
+ serverDir: string;
16
+ clientDir: string;
17
+ }
18
+ /**
19
+ * Replace placeholders in a path string
20
+ * Supports: {serviceName}, {buildDir}, {rootDir}, {framework}, {typesDir}, {serverDir}, {clientDir}
21
+ */
22
+ declare function replacePlaceholders(path: string, placeholders: PathPlaceholders): string;
23
+ /**
24
+ * Get default paths based on framework and user configuration
25
+ */
26
+ declare function getDefaultPaths(nitro: Nitro): Required<PathPlaceholders>;
27
+ /**
28
+ * Check if a file should be generated based on config
29
+ * Returns: true if should generate, false if should skip
30
+ */
31
+ declare function shouldGenerateFile(config: FileGenerationConfig | undefined, categoryEnabled: boolean | undefined, topLevelEnabled: boolean): boolean;
32
+ /**
33
+ * Resolve the file path based on configuration
34
+ * Returns: resolved absolute path or null if file should not be generated
35
+ */
36
+ declare function resolveFilePath(config: FileGenerationConfig | undefined, categoryEnabled: boolean | undefined, topLevelEnabled: boolean, defaultPath: string, placeholders: PathPlaceholders): string | null;
37
+ /**
38
+ * Check if SDK files should be generated (category-level check)
39
+ */
40
+ declare function shouldGenerateSdk(nitro: Nitro): boolean;
41
+ /**
42
+ * Get SDK configuration (handles false case)
43
+ */
44
+ declare function getSdkConfig(nitro: Nitro): SdkConfig;
45
+ /**
46
+ * Check if type files should be generated (category-level check)
47
+ */
48
+ declare function shouldGenerateTypes(nitro: Nitro): boolean;
49
+ /**
50
+ * Get types configuration (handles false case)
51
+ */
52
+ declare function getTypesConfig(nitro: Nitro): TypesConfig;
53
+ //#endregion
54
+ export { PathPlaceholders, getDefaultPaths, getSdkConfig, getTypesConfig, replacePlaceholders, resolveFilePath, shouldGenerateFile, shouldGenerateSdk, shouldGenerateTypes };