nitro-graphql 2.0.0-beta.32 → 2.0.0-beta.34

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 (71) hide show
  1. package/dist/codegen/client-types.mjs +9 -54
  2. package/dist/codegen/external-types.mjs +7 -48
  3. package/dist/codegen/index.d.mts +4 -11
  4. package/dist/codegen/index.mjs +1 -15
  5. package/dist/codegen/server-types.mjs +2 -14
  6. package/dist/constants/scalars.mjs +27 -0
  7. package/dist/constants.mjs +16 -1
  8. package/dist/rollup.d.mts +1 -7
  9. package/dist/rollup.mjs +12 -187
  10. package/dist/routes/apollo-server.d.mts +2 -2
  11. package/dist/routes/apollo-server.mjs +7 -51
  12. package/dist/routes/debug-template.d.mts +15 -0
  13. package/dist/routes/debug-template.mjs +385 -0
  14. package/dist/routes/debug.d.mts +2 -2
  15. package/dist/routes/debug.mjs +1 -344
  16. package/dist/routes/graphql-yoga.d.mts +2 -2
  17. package/dist/routes/graphql-yoga.mjs +7 -51
  18. package/dist/routes/health.d.mts +2 -2
  19. package/dist/setup/file-watcher.mjs +9 -5
  20. package/dist/setup/graphql-scanner.mjs +25 -0
  21. package/dist/setup/scaffold-generator.mjs +1 -1
  22. package/dist/setup/ts-config.mjs +1 -1
  23. package/dist/setup.mjs +38 -47
  24. package/dist/types/index.d.mts +1 -1
  25. package/dist/utils/client-codegen.mjs +4 -30
  26. package/dist/utils/codegen-plugin.d.mts +20 -0
  27. package/dist/utils/codegen-plugin.mjs +30 -0
  28. package/dist/utils/federation.d.mts +29 -0
  29. package/dist/utils/federation.mjs +40 -0
  30. package/dist/utils/file-writer.d.mts +35 -0
  31. package/dist/utils/file-writer.mjs +32 -0
  32. package/dist/utils/imports.d.mts +15 -0
  33. package/dist/utils/imports.mjs +25 -0
  34. package/dist/utils/index.d.mts +11 -38
  35. package/dist/utils/index.mjs +10 -287
  36. package/dist/utils/layers.d.mts +22 -0
  37. package/dist/utils/layers.mjs +28 -0
  38. package/dist/utils/ofetch-templates.d.mts +30 -0
  39. package/dist/utils/ofetch-templates.mjs +135 -0
  40. package/dist/utils/scanning/common.d.mts +23 -0
  41. package/dist/utils/scanning/common.mjs +39 -0
  42. package/dist/utils/scanning/directives.d.mts +11 -0
  43. package/dist/utils/scanning/directives.mjs +43 -0
  44. package/dist/utils/scanning/documents.d.mts +15 -0
  45. package/dist/utils/scanning/documents.mjs +46 -0
  46. package/dist/utils/scanning/index.d.mts +6 -0
  47. package/dist/utils/scanning/index.mjs +7 -0
  48. package/dist/utils/scanning/resolvers.d.mts +11 -0
  49. package/dist/utils/scanning/resolvers.mjs +100 -0
  50. package/dist/utils/scanning/schemas.d.mts +15 -0
  51. package/dist/utils/scanning/schemas.mjs +29 -0
  52. package/dist/utils/schema-builder.d.mts +48 -0
  53. package/dist/utils/schema-builder.mjs +51 -0
  54. package/dist/utils/server-codegen.mjs +3 -29
  55. package/dist/utils/type-generation.d.mts +2 -2
  56. package/dist/utils/type-generation.mjs +2 -2
  57. package/dist/utils/validation.d.mts +11 -0
  58. package/dist/utils/validation.mjs +34 -0
  59. package/dist/virtual/generators/config.d.mts +22 -0
  60. package/dist/virtual/generators/config.mjs +36 -0
  61. package/dist/virtual/generators/debug.d.mts +14 -0
  62. package/dist/virtual/generators/debug.mjs +53 -0
  63. package/dist/virtual/generators/directives.d.mts +14 -0
  64. package/dist/virtual/generators/directives.mjs +52 -0
  65. package/dist/virtual/generators/index.d.mts +6 -0
  66. package/dist/virtual/generators/index.mjs +7 -0
  67. package/dist/virtual/generators/resolvers.d.mts +14 -0
  68. package/dist/virtual/generators/resolvers.mjs +55 -0
  69. package/dist/virtual/generators/schemas.d.mts +14 -0
  70. package/dist/virtual/generators/schemas.mjs +43 -0
  71. package/package.json +22 -18
@@ -1,3 +1,4 @@
1
+ import { generateHtmlDashboard } from "./debug-template.mjs";
1
2
  import { moduleConfig } from "#nitro-graphql/module-config";
2
3
  import { directives } from "#nitro-graphql/server-directives";
3
4
  import { resolvers } from "#nitro-graphql/server-resolvers";
@@ -96,350 +97,6 @@ var debug_default = defineEventHandler(async (event) => {
96
97
  event.res.headers.set("Content-Type", "text/html");
97
98
  return generateHtmlDashboard(fullDebugInfo);
98
99
  });
99
- function generateHtmlDashboard(debugInfo$1) {
100
- return `<!DOCTYPE html>
101
- <html lang="en">
102
- <head>
103
- <meta charset="UTF-8">
104
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
105
- <title>Nitro GraphQL Debug Dashboard</title>
106
- <script src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"><\/script>
107
- <style>
108
- @keyframes fadeIn {
109
- from { opacity: 0; transform: translateY(10px); }
110
- to { opacity: 1; transform: translateY(0); }
111
- }
112
- .animate-fade-in {
113
- animation: fadeIn 0.3s ease-out;
114
- }
115
- /* Custom Scrollbar */
116
- ::-webkit-scrollbar {
117
- width: 8px;
118
- height: 8px;
119
- }
120
- ::-webkit-scrollbar-track {
121
- background: #0f172a;
122
- border-radius: 4px;
123
- }
124
- ::-webkit-scrollbar-thumb {
125
- background: #334155;
126
- border-radius: 4px;
127
- }
128
- ::-webkit-scrollbar-thumb:hover {
129
- background: #475569;
130
- }
131
- </style>
132
- </head>
133
- <body class="bg-slate-950 text-slate-200 min-h-screen">
134
- <div class="container mx-auto max-w-7xl p-6 space-y-6 animate-fade-in">
135
- <!-- Header -->
136
- <div class="mb-8 border-b border-slate-800 pb-6">
137
- <div class="flex items-center gap-3 mb-2">
138
- <svg class="w-10 h-10" viewBox="0 0 400 400" fill="none">
139
- <path d="M57.468 302.66l-14.376-8.3 160.15-277.38 14.376 8.3z" fill="#E535AB"/>
140
- <path d="M39.8 272.2h320.3v16.6H39.8z" fill="#E535AB"/>
141
- <path d="M206.348 374.026l-160.21-92.5 8.3-14.376 160.21 92.5z" fill="#E535AB"/>
142
- <path d="M345.522 132.947l-160.21-92.5 8.3-14.376 160.21 92.5z" fill="#E535AB"/>
143
- <path d="M54.482 132.883l-8.3-14.375 160.21-92.5 8.3 14.376z" fill="#E535AB"/>
144
- <path d="M342.568 302.663l-160.15-277.38 14.376-8.3 160.15 277.38z" fill="#E535AB"/>
145
- <path d="M52.5 107.5h16.6v185H52.5z" fill="#E535AB"/>
146
- <path d="M330.9 107.5h16.6v185h-16.6z" fill="#E535AB"/>
147
- <path d="M203.522 367l-7.25-12.558 139.34-80.45 7.25 12.557z" fill="#E535AB"/>
148
- <path d="M369.5 297.9c-9.6 16.7-31 22.4-47.7 12.8-16.7-9.6-22.4-31-12.8-47.7 9.6-16.7 31-22.4 47.7-12.8 16.8 9.7 22.5 31 12.8 47.7M90.9 137c-9.6 16.7-31 22.4-47.7 12.8-16.7-9.6-22.4-31-12.8-47.7 9.6-16.7 31-22.4 47.7-12.8 16.7 9.7 22.4 31 12.8 47.7M30.5 297.9c-9.6-16.7-3.9-38 12.8-47.7 16.7-9.6 38-3.9 47.7 12.8 9.6 16.7 3.9 38-12.8 47.7-16.8 9.6-38.1 3.9-47.7-12.8M309.1 137c-9.6-16.7-3.9-38 12.8-47.7 16.7-9.6 38-3.9 47.7 12.8 9.6 16.7 3.9 38-12.8 47.7-16.7 9.6-38.1 3.9-47.7-12.8M200 395.8c-19.3 0-34.9-15.6-34.9-34.9 0-19.3 15.6-34.9 34.9-34.9 19.3 0 34.9 15.6 34.9 34.9 0 19.2-15.6 34.9-34.9 34.9M200 74c-19.3 0-34.9-15.6-34.9-34.9 0-19.3 15.6-34.9 34.9-34.9 19.3 0 34.9 15.6 34.9 34.9 0 19.3-15.6 34.9-34.9 34.9" fill="#E535AB"/>
149
- </svg>
150
- <div>
151
- <h1 class="text-3xl font-bold text-slate-100">
152
- Nitro GraphQL Debug
153
- </h1>
154
- <p class="text-sm text-slate-500">Development Diagnostics Dashboard</p>
155
- </div>
156
- </div>
157
- </div>
158
-
159
- <!-- Top Stats Grid -->
160
- <div class="grid grid-cols-1 md:grid-cols-3 gap-4">
161
- <!-- Environment Card -->
162
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6 hover:border-[#E535AB]/30 transition-all">
163
- <h2 class="text-lg font-semibold mb-4 text-slate-200 flex items-center gap-2">
164
- <span class="text-[#E535AB]">●</span> Environment
165
- </h2>
166
- <div class="space-y-3">
167
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
168
- <span class="text-slate-400 text-sm">Mode</span>
169
- <span class="text-slate-200 font-medium text-sm">${debugInfo$1.environment.dev ? "Development" : "Production"}</span>
170
- </div>
171
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
172
- <span class="text-slate-400 text-sm">Framework</span>
173
- <span class="text-slate-200 font-medium text-sm">${debugInfo$1.environment.framework}</span>
174
- </div>
175
- <div class="flex justify-between items-center py-2">
176
- <span class="text-slate-400 text-sm">GraphQL Server</span>
177
- <span class="text-slate-200 font-medium text-sm">${debugInfo$1.graphql.framework || "Not configured"}</span>
178
- </div>
179
- </div>
180
- </div>
181
-
182
- <!-- Scanned Files Card -->
183
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6 hover:border-[#E535AB]/30 transition-all">
184
- <h2 class="text-lg font-semibold mb-4 text-slate-200 flex items-center gap-2">
185
- <span class="text-[#E535AB]">●</span> Scanned Files
186
- </h2>
187
- <div class="space-y-3">
188
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
189
- <span class="text-slate-400 text-sm">Schemas</span>
190
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.scanned.schemas}</span>
191
- </div>
192
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
193
- <span class="text-slate-400 text-sm">Resolvers</span>
194
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.scanned.resolvers}</span>
195
- </div>
196
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
197
- <span class="text-slate-400 text-sm">Directives</span>
198
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.scanned.directives}</span>
199
- </div>
200
- <div class="flex justify-between items-center py-2">
201
- <span class="text-slate-400 text-sm">Documents</span>
202
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.scanned.documents}</span>
203
- </div>
204
- </div>
205
- </div>
206
-
207
- <!-- Runtime Info Card -->
208
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6 hover:border-[#E535AB]/30 transition-all">
209
- <h2 class="text-lg font-semibold mb-4 text-slate-200 flex items-center gap-2">
210
- <span class="text-[#E535AB]">●</span> Runtime Loaded
211
- </h2>
212
- <div class="space-y-3">
213
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
214
- <span class="text-slate-400 text-sm">Resolvers</span>
215
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.runtime.loadedResolvers}</span>
216
- </div>
217
- <div class="flex justify-between items-center py-2 border-b border-slate-800/50">
218
- <span class="text-slate-400 text-sm">Schemas</span>
219
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.runtime.loadedSchemas}</span>
220
- </div>
221
- <div class="flex justify-between items-center py-2">
222
- <span class="text-slate-400 text-sm">Directives</span>
223
- <span class="text-[#E535AB] font-semibold text-sm">${debugInfo$1.runtime.loadedDirectives}</span>
224
- </div>
225
- </div>
226
- </div>
227
- </div>
228
-
229
- <!-- Resolver Exports -->
230
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6">
231
- <div class="flex justify-between items-center mb-4">
232
- <h2 class="text-xl font-semibold text-slate-200 flex items-center gap-2">
233
- <span class="text-[#E535AB]">●</span> Resolver Exports
234
- </h2>
235
- ${debugInfo$1.scanned.resolverFiles.length > 0 ? `<span class="text-xs text-slate-500 bg-slate-800/50 px-2 py-1 rounded">${debugInfo$1.scanned.resolverFiles.length} files</span>` : ""}
236
- </div>
237
- ${debugInfo$1.scanned.resolverFiles.length > 0 ? `
238
- <div class="max-h-96 overflow-y-auto space-y-2 pr-2">
239
- ${debugInfo$1.scanned.resolverFiles.map((r) => {
240
- const totalExports = r.exports.length;
241
- return `
242
- <div class="border border-slate-700/50 rounded-lg p-4 hover:border-[#E535AB]/20 hover:bg-slate-800/30 transition-all">
243
- <div class="flex justify-between items-center mb-3">
244
- <span class="text-slate-300 font-mono text-xs truncate pr-2">${r.file}</span>
245
- <span class="bg-slate-800/80 px-2.5 py-0.5 rounded text-[#E535AB] text-[10px] font-semibold whitespace-nowrap">
246
- ${totalExports} export${totalExports !== 1 ? "s" : ""}
247
- </span>
248
- </div>
249
- <div class="flex flex-wrap gap-1.5">
250
- ${r.exports.map((e) => {
251
- const typeConfig = {
252
- query: {
253
- bg: "bg-blue-500/10",
254
- text: "text-blue-400",
255
- border: "border-blue-500/30",
256
- symbol: "◆",
257
- label: "query"
258
- },
259
- mutation: {
260
- bg: "bg-[#E535AB]/10",
261
- text: "text-[#E535AB]",
262
- border: "border-[#E535AB]/30",
263
- symbol: "●",
264
- label: "mutation"
265
- },
266
- type: {
267
- bg: "bg-purple-500/10",
268
- text: "text-purple-400",
269
- border: "border-purple-500/30",
270
- symbol: "▲",
271
- label: "type"
272
- },
273
- directive: {
274
- bg: "bg-amber-500/10",
275
- text: "text-amber-400",
276
- border: "border-amber-500/30",
277
- symbol: "@",
278
- label: "directive"
279
- },
280
- resolver: {
281
- bg: "bg-emerald-500/10",
282
- text: "text-emerald-400",
283
- border: "border-emerald-500/30",
284
- symbol: "◉",
285
- label: "resolver"
286
- },
287
- subscription: {
288
- bg: "bg-teal-500/10",
289
- text: "text-teal-400",
290
- border: "border-teal-500/30",
291
- symbol: "↻",
292
- label: "subscription"
293
- }
294
- };
295
- const config = typeConfig[e.type] || typeConfig.resolver;
296
- return `<span class="px-2.5 py-1 rounded border text-[11px] font-mono ${config.bg} ${config.text} ${config.border} hover:scale-105 transition-transform inline-flex items-center gap-1.5">
297
- <span class="font-bold">${config.symbol}</span>
298
- <span class="font-medium">${e.name}</span>
299
- <span class="opacity-60 text-[9px] uppercase tracking-wide">${config.label}</span>
300
- </span>`;
301
- }).join("")}
302
- </div>
303
- </div>
304
- `;
305
- }).join("")}
306
- </div>
307
- ` : "<p class=\"text-slate-500 text-sm\">No resolvers found</p>"}
308
- </div>
309
-
310
- <!-- Generated Virtual Modules -->
311
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6">
312
- <div class="flex justify-between items-center mb-4">
313
- <h2 class="text-xl font-semibold text-slate-200 flex items-center gap-2">
314
- <span class="text-[#E535AB]">●</span> Generated Virtual Modules
315
- </h2>
316
- <span class="text-xs text-slate-500 bg-slate-800/50 px-2 py-1 rounded">
317
- ${Object.keys(debugInfo$1.virtualModules).length} modules
318
- </span>
319
- </div>
320
- <div class="space-y-3">
321
- ${Object.entries(debugInfo$1.virtualModules).map(([moduleName, codeContent]) => {
322
- const code = String(codeContent);
323
- const moduleColors = {
324
- "server-schemas": {
325
- bg: "bg-blue-500/5",
326
- border: "border-blue-500/20",
327
- text: "text-blue-400"
328
- },
329
- "server-resolvers": {
330
- bg: "bg-[#E535AB]/5",
331
- border: "border-[#E535AB]/20",
332
- text: "text-[#E535AB]"
333
- },
334
- "server-directives": {
335
- bg: "bg-amber-500/5",
336
- border: "border-amber-500/20",
337
- text: "text-amber-400"
338
- },
339
- "module-config": {
340
- bg: "bg-purple-500/5",
341
- border: "border-purple-500/20",
342
- text: "text-purple-400"
343
- },
344
- "graphql-config": {
345
- bg: "bg-emerald-500/5",
346
- border: "border-emerald-500/20",
347
- text: "text-emerald-400"
348
- }
349
- };
350
- const colorConfig = moduleColors[moduleName] || moduleColors["module-config"];
351
- const lineCount = code.split("\\n").length;
352
- const byteSize = new TextEncoder().encode(code).length;
353
- return `
354
- <details class="border ${colorConfig.border} ${colorConfig.bg} rounded-lg overflow-hidden group">
355
- <summary class="cursor-pointer p-4 hover:bg-slate-800/30 transition-all flex justify-between items-center">
356
- <div class="flex items-center gap-3">
357
- <span class="${colorConfig.text} text-lg">▸</span>
358
- <div>
359
- <span class="font-mono text-sm ${colorConfig.text} font-semibold">#nitro-graphql/${moduleName}</span>
360
- <div class="text-[10px] text-slate-500 mt-0.5">
361
- ${lineCount} lines · ${(byteSize / 1024).toFixed(2)} KB
362
- </div>
363
- </div>
364
- </div>
365
- <button
366
- onclick="event.stopPropagation(); navigator.clipboard.writeText(this.getAttribute('data-code')); this.textContent = '✓ Copied!'; setTimeout(() => this.textContent = 'Copy', 1000)"
367
- data-code="${escapeHtml(code).replace(/"/g, "&quot;")}"
368
- class="text-xs px-3 py-1.5 bg-slate-800 hover:bg-slate-700 text-slate-300 rounded border border-slate-600/50 transition-colors"
369
- >
370
- Copy
371
- </button>
372
- </summary>
373
- <div class="border-t ${colorConfig.border}">
374
- <div class="bg-slate-950/80 p-4 max-h-96 overflow-auto">
375
- <pre class="text-xs font-mono text-slate-300 leading-relaxed"><code>${escapeHtml(code)}</code></pre>
376
- </div>
377
- </div>
378
- </details>
379
- `;
380
- }).join("")}
381
- </div>
382
- </div>
383
-
384
- <!-- Files Grid -->
385
- <div class="grid grid-cols-1 md:grid-cols-2 gap-4">
386
- <!-- Schema Files -->
387
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6 hover:border-[#E535AB]/30 transition-all">
388
- <div class="flex justify-between items-center mb-4">
389
- <h2 class="text-lg font-semibold text-slate-200 flex items-center gap-2">
390
- <span class="text-[#E535AB]">●</span> Schema Files
391
- </h2>
392
- ${debugInfo$1.scanned.schemaFiles.length > 0 ? `<span class="text-xs text-slate-500 bg-slate-800/50 px-2 py-1 rounded">${debugInfo$1.scanned.schemaFiles.length} file${debugInfo$1.scanned.schemaFiles.length !== 1 ? "s" : ""}</span>` : ""}
393
- </div>
394
- <ul class="space-y-2 max-h-64 overflow-y-auto pr-2">
395
- ${debugInfo$1.scanned.schemaFiles.length > 0 ? debugInfo$1.scanned.schemaFiles.map((f) => `<li class="text-slate-400 font-mono text-xs flex items-start gap-2 py-1.5 px-2 rounded hover:bg-slate-800/50 transition-colors group">
396
- <span class="text-[#E535AB] text-[10px] mt-0.5 group-hover:scale-110 transition-transform">▸</span>
397
- <span class="truncate group-hover:text-slate-300">${f}</span>
398
- </li>`).join("") : "<li class=\"text-slate-500 text-sm\">No schemas found</li>"}
399
- </ul>
400
- </div>
401
-
402
- <!-- Document Files -->
403
- <div class="bg-slate-900/50 border border-slate-700/50 rounded-lg p-6 hover:border-[#E535AB]/30 transition-all">
404
- <div class="flex justify-between items-center mb-4">
405
- <h2 class="text-lg font-semibold text-slate-200 flex items-center gap-2">
406
- <span class="text-[#E535AB]">●</span> Document Files
407
- </h2>
408
- ${debugInfo$1.scanned.documentFiles.length > 0 ? `<span class="text-xs text-slate-500 bg-slate-800/50 px-2 py-1 rounded">${debugInfo$1.scanned.documentFiles.length} file${debugInfo$1.scanned.documentFiles.length !== 1 ? "s" : ""}</span>` : ""}
409
- </div>
410
- <ul class="space-y-2 max-h-64 overflow-y-auto pr-2">
411
- ${debugInfo$1.scanned.documentFiles.length > 0 ? debugInfo$1.scanned.documentFiles.map((f) => `<li class="text-slate-400 font-mono text-xs flex items-start gap-2 py-1.5 px-2 rounded hover:bg-slate-800/50 transition-colors group">
412
- <span class="text-[#E535AB] text-[10px] mt-0.5 group-hover:scale-110 transition-transform">▸</span>
413
- <span class="truncate group-hover:text-slate-300">${f}</span>
414
- </li>`).join("") : "<li class=\"text-slate-500 text-sm\">No documents found</li>"}
415
- </ul>
416
- </div>
417
- </div>
418
-
419
- <!-- Reload Button -->
420
- <button
421
- onclick="location.reload()"
422
- class="fixed bottom-8 right-8 bg-[#E535AB] hover:bg-[#d12a99] text-white font-semibold px-6 py-3 rounded-lg shadow-lg hover:shadow-xl hover:shadow-[#E535AB]/20 transform hover:-translate-y-1 transition-all duration-200 flex items-center gap-2 border border-[#E535AB]/20"
423
- >
424
- <svg class="w-4 h-4" fill="none" stroke="currentColor" stroke-width="2" viewBox="0 0 24 24">
425
- <path stroke-linecap="round" stroke-linejoin="round" d="M4 4v5h.582m15.356 2A8.001 8.001 0 004.582 9m0 0H9m11 11v-5h-.581m0 0a8.003 8.003 0 01-15.357-2m15.357 2H15" />
426
- </svg>
427
- Reload
428
- </button>
429
- </div>
430
- </body>
431
- </html>`;
432
- }
433
- function escapeHtml(text) {
434
- const map = {
435
- "&": "&amp;",
436
- "<": "&lt;",
437
- ">": "&gt;",
438
- "\"": "&quot;",
439
- "'": "&#039;"
440
- };
441
- return text.replace(/[&<>"']/g, (m) => map[m] || m);
442
- }
443
100
 
444
101
  //#endregion
445
102
  export { debug_default as default };
@@ -1,6 +1,6 @@
1
- import * as nitro_deps_h33 from "nitro/deps/h3";
1
+ import * as nitro_deps_h30 from "nitro/deps/h3";
2
2
 
3
3
  //#region src/routes/graphql-yoga.d.ts
4
- declare const _default: nitro_deps_h33.EventHandlerWithFetch<nitro_deps_h33.EventHandlerRequest, Promise<Response>>;
4
+ declare const _default: nitro_deps_h30.EventHandlerWithFetch<nitro_deps_h30.EventHandlerRequest, Promise<Response>>;
5
5
  //#endregion
6
6
  export { _default as default };
@@ -1,27 +1,14 @@
1
+ import { createMergedSchema } from "../utils/schema-builder.mjs";
1
2
  import defu from "defu";
2
- import { consola as consola$1 } from "consola";
3
- import { parse } from "graphql";
4
- import { mergeResolvers, mergeTypeDefs } from "@graphql-tools/merge";
5
3
  import { importedConfig } from "#nitro-graphql/graphql-config";
6
4
  import { moduleConfig } from "#nitro-graphql/module-config";
7
5
  import { directives } from "#nitro-graphql/server-directives";
8
6
  import { resolvers } from "#nitro-graphql/server-resolvers";
9
7
  import { schemas } from "#nitro-graphql/server-schemas";
10
- import { makeExecutableSchema } from "@graphql-tools/schema";
11
8
  import { defineEventHandler } from "nitro/h3";
12
9
  import { createYoga } from "graphql-yoga";
13
10
 
14
11
  //#region src/routes/graphql-yoga.ts
15
- let buildSubgraphSchema = null;
16
- async function loadFederationSupport() {
17
- if (buildSubgraphSchema !== null) return buildSubgraphSchema;
18
- try {
19
- buildSubgraphSchema = (await import("@apollo/subgraph")).buildSubgraphSchema;
20
- } catch {
21
- buildSubgraphSchema = false;
22
- }
23
- return buildSubgraphSchema;
24
- }
25
12
  const apolloSandboxHtml = `<!DOCTYPE html>
26
13
  <html lang="en">
27
14
  <body style="margin: 0; overflow-x: hidden; overflow-y: hidden">
@@ -39,46 +26,15 @@ new window.EmbeddedSandbox({
39
26
  <\/script>
40
27
  </body>
41
28
  </html>`;
42
- async function createMergedSchema() {
43
- try {
44
- const typeDefs = mergeTypeDefs([schemas.map((schema$1) => schema$1.def).join("\n\n")], {
45
- throwOnConflict: true,
46
- commentDescriptions: true,
47
- sort: true
48
- });
49
- const mergedResolvers = mergeResolvers(resolvers.map((r) => r.resolver));
50
- const federationEnabled = moduleConfig.federation?.enabled;
51
- let schema;
52
- if (federationEnabled) {
53
- const buildSubgraph = await loadFederationSupport();
54
- if (buildSubgraph) schema = buildSubgraph({
55
- typeDefs: typeof typeDefs === "string" ? parse(typeDefs) : typeDefs,
56
- resolvers: mergedResolvers
57
- });
58
- else {
59
- console.warn("Federation enabled but @apollo/subgraph not available, falling back to regular schema");
60
- schema = makeExecutableSchema({
61
- typeDefs,
62
- resolvers: mergedResolvers
63
- });
64
- }
65
- } else schema = makeExecutableSchema({
66
- typeDefs,
67
- resolvers: mergedResolvers
68
- });
69
- if (directives && directives.length > 0) {
70
- for (const { directive } of directives) if (directive.transformer) schema = directive.transformer(schema);
71
- }
72
- return schema;
73
- } catch (error) {
74
- consola$1.error("Schema merge error:", error);
75
- throw error;
76
- }
77
- }
78
29
  let yoga;
79
30
  var graphql_yoga_default = defineEventHandler(async (event) => {
80
31
  if (!yoga) yoga = createYoga(defu({
81
- schema: await createMergedSchema(),
32
+ schema: await createMergedSchema({
33
+ schemas,
34
+ resolvers,
35
+ directives,
36
+ moduleConfig
37
+ }),
82
38
  graphqlEndpoint: "/api/graphql",
83
39
  landingPage: false,
84
40
  renderGraphiQL: () => apolloSandboxHtml
@@ -1,7 +1,7 @@
1
- import * as nitro_deps_h30 from "nitro/deps/h3";
1
+ import * as nitro_deps_h35 from "nitro/deps/h3";
2
2
 
3
3
  //#region src/routes/health.d.ts
4
- declare const _default: nitro_deps_h30.EventHandlerWithFetch<nitro_deps_h30.EventHandlerRequest, Promise<{
4
+ declare const _default: nitro_deps_h35.EventHandlerWithFetch<nitro_deps_h35.EventHandlerRequest, Promise<{
5
5
  status: string;
6
6
  message: string;
7
7
  timestamp: string;
@@ -1,8 +1,12 @@
1
1
  import { DIRECTIVE_EXTENSIONS, DIR_SERVER_GRAPHQL, DIR_SERVER_GRAPHQL_WIN, GRAPHQL_EXTENSIONS, LOG_TAG, RESOLVER_EXTENSIONS } from "../constants.mjs";
2
+ import { generateServerTypes } from "../codegen/server-types.mjs";
3
+ import { generateClientTypes } from "../codegen/index.mjs";
2
4
  import { DEFAULT_WATCHER_IGNORE_INITIAL, DEFAULT_WATCHER_PERSISTENT } from "../config/defaults.mjs";
3
5
  import { generateDirectiveSchemas } from "../utils/directive-parser.mjs";
4
- import { generateLayerIgnorePatterns, getLayerAppDirectories, getLayerServerDirectories, scanDirectives, scanResolvers, scanSchemas } from "../utils/index.mjs";
5
- import { clientTypeGeneration, serverTypeGeneration } from "../codegen/index.mjs";
6
+ import { generateLayerIgnorePatterns, getLayerAppDirectories, getLayerServerDirectories } from "../utils/layers.mjs";
7
+ import { scanDirectives } from "../utils/scanning/directives.mjs";
8
+ import { scanResolvers } from "../utils/scanning/resolvers.mjs";
9
+ import { scanSchemas } from "../utils/scanning/schemas.mjs";
6
10
  import consola from "consola";
7
11
  import { join } from "pathe";
8
12
  import { watch } from "chokidar";
@@ -33,12 +37,12 @@ function setupFileWatcher(nitro, watchDirs) {
33
37
  nitro.scanSchemas = schemas;
34
38
  await scanResolvers(nitro).then((r) => nitro.scanResolvers = r);
35
39
  logger.success("Types regenerated");
36
- await serverTypeGeneration(nitro, { silent: true });
37
- await clientTypeGeneration(nitro, { silent: true });
40
+ await generateServerTypes(nitro, { silent: true });
41
+ await generateClientTypes(nitro, { silent: true });
38
42
  await nitro.hooks.callHook("dev:reload");
39
43
  } else {
40
44
  logger.success("Types regenerated");
41
- await clientTypeGeneration(nitro, { silent: true });
45
+ await generateClientTypes(nitro, { silent: true });
42
46
  }
43
47
  });
44
48
  return watcher;
@@ -0,0 +1,25 @@
1
+ import { generateDirectiveSchemas } from "../utils/directive-parser.mjs";
2
+ import { scanDirectives } from "../utils/scanning/directives.mjs";
3
+ import { scanDocuments } from "../utils/scanning/documents.mjs";
4
+ import { scanResolvers } from "../utils/scanning/resolvers.mjs";
5
+ import { scanSchemas } from "../utils/scanning/schemas.mjs";
6
+
7
+ //#region src/setup/graphql-scanner.ts
8
+ /**
9
+ * Scan all GraphQL files and update Nitro state
10
+ * Used by both initial setup and dev:start hook
11
+ */
12
+ async function scanAllGraphQLFiles(nitro) {
13
+ const directives = await scanDirectives(nitro);
14
+ nitro.scanDirectives = directives;
15
+ if (!nitro.scanSchemas) nitro.scanSchemas = [];
16
+ const directivesPath = await generateDirectiveSchemas(nitro, directives);
17
+ const schemas = await scanSchemas(nitro);
18
+ if (directivesPath && !schemas.includes(directivesPath)) schemas.push(directivesPath);
19
+ nitro.scanSchemas = schemas;
20
+ nitro.scanDocuments = await scanDocuments(nitro);
21
+ nitro.scanResolvers = await scanResolvers(nitro);
22
+ }
23
+
24
+ //#endregion
25
+ export { scanAllGraphQLFiles };
@@ -1,7 +1,7 @@
1
1
  import { FILE_CONFIG_TS, FILE_CONTEXT_DTS, FILE_CONTEXT_TS, FILE_GRAPHQL_CONFIG, FILE_SCHEMA_TS, LOG_TAG } from "../constants.mjs";
2
- import { relativeWithDot } from "../utils/index.mjs";
3
2
  import { writeFileIfNotExists } from "../utils/file-generator.mjs";
4
3
  import { getDefaultPaths, getScaffoldConfig, resolveFilePath, shouldGenerateScaffold } from "../utils/path-resolver.mjs";
4
+ import { relativeWithDot } from "../utils/imports.mjs";
5
5
  import consola from "consola";
6
6
  import { join, resolve } from "pathe";
7
7
  import { existsSync, mkdirSync } from "node:fs";
@@ -1,5 +1,5 @@
1
- import { relativeWithDot } from "../utils/index.mjs";
2
1
  import { getDefaultPaths, getTypesConfig, resolveFilePath } from "../utils/path-resolver.mjs";
2
+ import { relativeWithDot } from "../utils/imports.mjs";
3
3
  import { dirname, join, resolve } from "pathe";
4
4
 
5
5
  //#region src/setup/ts-config.ts
package/dist/setup.mjs CHANGED
@@ -1,11 +1,12 @@
1
1
  import { ENDPOINT_DEBUG, FRAMEWORK_NITRO, FRAMEWORK_NUXT, GRAPHQL_HTTP_METHODS, LOG_TAG } from "./constants.mjs";
2
- import { DEFAULT_RUNTIME_CONFIG, DEFAULT_TYPESCRIPT_STRICT, DEFAULT_TYPES_CONFIG } from "./config/defaults.mjs";
3
- import { generateDirectiveSchemas } from "./utils/directive-parser.mjs";
4
- import { scanDirectives, scanDocuments, scanResolvers, scanSchemas, validateExternalServices } from "./utils/index.mjs";
5
2
  import { getDefaultPaths } from "./utils/path-resolver.mjs";
6
- import { clientTypeGeneration, serverTypeGeneration } from "./codegen/index.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";
7
7
  import { rollupConfig } from "./rollup.mjs";
8
8
  import { getWatchDirectories, setupFileWatcher } from "./setup/file-watcher.mjs";
9
+ import { scanAllGraphQLFiles } from "./setup/graphql-scanner.mjs";
9
10
  import { setupRollupChunking, setupRollupExternals } from "./setup/rollup-integration.mjs";
10
11
  import { generateScaffoldFiles } from "./setup/scaffold-generator.mjs";
11
12
  import { setupTypeScriptPaths } from "./setup/ts-config.mjs";
@@ -112,15 +113,7 @@ function setupFileWatching(nitro) {
112
113
  * Scan all GraphQL files (schemas, resolvers, directives, documents)
113
114
  */
114
115
  async function scanGraphQLFiles(nitro) {
115
- const directives = await scanDirectives(nitro);
116
- nitro.scanDirectives = directives;
117
- nitro.scanSchemas = [];
118
- const directivesPath = await generateDirectiveSchemas(nitro, directives);
119
- const schemas = await scanSchemas(nitro);
120
- if (directivesPath && !schemas.includes(directivesPath)) schemas.push(directivesPath);
121
- nitro.scanSchemas = schemas;
122
- nitro.scanDocuments = await scanDocuments(nitro);
123
- nitro.scanResolvers = await scanResolvers(nitro);
116
+ await scanAllGraphQLFiles(nitro);
124
117
  }
125
118
  /**
126
119
  * Setup dev mode hooks for rescanning files
@@ -128,55 +121,53 @@ async function scanGraphQLFiles(nitro) {
128
121
  function setupDevHooks(nitro) {
129
122
  let hasShownInitialLogs = false;
130
123
  nitro.hooks.hook("dev:start", async () => {
131
- const directives = await scanDirectives(nitro);
132
- nitro.scanDirectives = directives;
133
- if (!nitro.scanSchemas) nitro.scanSchemas = [];
134
- const directivesPath = await generateDirectiveSchemas(nitro, directives);
135
- const schemas = await scanSchemas(nitro);
136
- if (directivesPath && !schemas.includes(directivesPath)) schemas.push(directivesPath);
137
- nitro.scanSchemas = schemas;
138
- nitro.scanDocuments = await scanDocuments(nitro);
139
- const resolvers = await scanResolvers(nitro);
140
- nitro.scanResolvers = resolvers;
124
+ await scanAllGraphQLFiles(nitro);
141
125
  if (nitro.options.dev && !hasShownInitialLogs) {
142
126
  hasShownInitialLogs = true;
143
- if (resolvers.length > 0) {
144
- const totalExports = resolvers.reduce((sum, r) => sum + r.imports.length, 0);
145
- const typeCount = {
146
- query: 0,
147
- mutation: 0,
148
- resolver: 0,
149
- type: 0,
150
- subscription: 0,
151
- directive: 0
152
- };
153
- for (const resolver of resolvers) for (const imp of resolver.imports) if (imp.type in typeCount) typeCount[imp.type]++;
154
- const breakdown = [];
155
- if (typeCount.query > 0) breakdown.push(`${typeCount.query} query`);
156
- if (typeCount.mutation > 0) breakdown.push(`${typeCount.mutation} mutation`);
157
- if (typeCount.resolver > 0) breakdown.push(`${typeCount.resolver} resolver`);
158
- if (typeCount.type > 0) breakdown.push(`${typeCount.type} type`);
159
- if (typeCount.subscription > 0) breakdown.push(`${typeCount.subscription} subscription`);
160
- if (typeCount.directive > 0) breakdown.push(`${typeCount.directive} directive`);
161
- if (breakdown.length > 0) logger.success(`${totalExports} resolver export(s): ${breakdown.join(", ")}`);
162
- } else logger.warn("No resolvers found. Check /_nitro/graphql/debug for details.");
127
+ logResolverDiagnostics(nitro);
163
128
  }
164
129
  });
165
130
  }
166
131
  /**
132
+ * Log resolver diagnostics for development
133
+ */
134
+ function logResolverDiagnostics(nitro) {
135
+ const resolvers = nitro.scanResolvers || [];
136
+ if (resolvers.length > 0) {
137
+ const totalExports = resolvers.reduce((sum, r) => sum + r.imports.length, 0);
138
+ const typeCount = {
139
+ query: 0,
140
+ mutation: 0,
141
+ resolver: 0,
142
+ type: 0,
143
+ subscription: 0,
144
+ directive: 0
145
+ };
146
+ for (const resolver of resolvers) for (const imp of resolver.imports) if (imp.type in typeCount) typeCount[imp.type]++;
147
+ const breakdown = [];
148
+ if (typeCount.query > 0) breakdown.push(`${typeCount.query} query`);
149
+ if (typeCount.mutation > 0) breakdown.push(`${typeCount.mutation} mutation`);
150
+ if (typeCount.resolver > 0) breakdown.push(`${typeCount.resolver} resolver`);
151
+ if (typeCount.type > 0) breakdown.push(`${typeCount.type} type`);
152
+ if (typeCount.subscription > 0) breakdown.push(`${typeCount.subscription} subscription`);
153
+ if (typeCount.directive > 0) breakdown.push(`${typeCount.directive} directive`);
154
+ if (breakdown.length > 0) logger.success(`${totalExports} resolver export(s): ${breakdown.join(", ")}`);
155
+ } else logger.warn("No resolvers found. Check /_nitro/graphql/debug for details.");
156
+ }
157
+ /**
167
158
  * Generate server and client types
168
159
  */
169
160
  async function generateTypes(nitro) {
170
- await serverTypeGeneration(nitro);
171
- await clientTypeGeneration(nitro, { isInitial: true });
161
+ await generateServerTypes(nitro);
162
+ await generateClientTypes(nitro, { isInitial: true });
172
163
  }
173
164
  /**
174
165
  * Setup close hooks for final type generation
175
166
  */
176
167
  function setupCloseHooks(nitro) {
177
168
  nitro.hooks.hook("close", async () => {
178
- await serverTypeGeneration(nitro, { silent: true });
179
- await clientTypeGeneration(nitro, { silent: true });
169
+ await generateServerTypes(nitro, { silent: true });
170
+ await generateClientTypes(nitro, { silent: true });
180
171
  });
181
172
  }
182
173
  /**