nitro-graphql 0.0.1
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.
- package/LICENSE +21 -0
- package/README.md +476 -0
- package/dist/client-codegen-DM2n5Gt2.js +86 -0
- package/dist/client-codegen-DM2n5Gt2.js.map +1 -0
- package/dist/client-watcher.d.ts +10 -0
- package/dist/client-watcher.d.ts.map +1 -0
- package/dist/client-watcher.js +92 -0
- package/dist/client-watcher.js.map +1 -0
- package/dist/codegen-DWJuLowd.d.ts +16 -0
- package/dist/codegen-DWJuLowd.d.ts.map +1 -0
- package/dist/codegen-Dbw6gEZt.js +110 -0
- package/dist/codegen-Dbw6gEZt.js.map +1 -0
- package/dist/codegen.d.ts +2 -0
- package/dist/codegen.js +3 -0
- package/dist/context-BgqNJFCT.d.ts +13 -0
- package/dist/context-BgqNJFCT.d.ts.map +1 -0
- package/dist/context-CZdhkJYD.js +0 -0
- package/dist/context.d.ts +2 -0
- package/dist/context.js +1 -0
- package/dist/index.d.ts +11 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +424 -0
- package/dist/index.js.map +1 -0
- package/dist/scanner-BdcKEPQk.js +119 -0
- package/dist/scanner-BdcKEPQk.js.map +1 -0
- package/dist/types-D_NqyCcy.d.ts +47 -0
- package/dist/types-D_NqyCcy.d.ts.map +1 -0
- package/dist/utils-87_22aIA.js +41 -0
- package/dist/utils-87_22aIA.js.map +1 -0
- package/dist/utils-BuYDOLIi.d.ts +22 -0
- package/dist/utils-BuYDOLIi.d.ts.map +1 -0
- package/dist/utils.d.ts +3 -0
- package/dist/utils.js +3 -0
- package/dist/watcher.d.ts +9 -0
- package/dist/watcher.d.ts.map +1 -0
- package/dist/watcher.js +96 -0
- package/dist/watcher.js.map +1 -0
- package/package.json +87 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","names":["nitro: Nitro","options: NitroGraphQLOptions","nitro"],"sources":["../src/index.ts"],"sourcesContent":["import type { Nitro } from 'nitropack/types'\nimport type { NitroGraphQLOptions } from './types'\nimport { mkdir, writeFile } from 'node:fs/promises'\nimport { mergeTypeDefs } from '@graphql-tools/merge'\nimport { makeExecutableSchema } from '@graphql-tools/schema'\nimport { consola } from 'consola'\nimport { defineNitroModule } from 'nitropack/kit'\nimport { join } from 'pathe'\n// import { generateTypes } from './codegen' // Conditionally imported to prevent bundling\nimport { scanGraphQLFiles } from './scanner'\n\nconst logger = consola.withTag('graphql')\n\nexport default defineNitroModule({\n name: 'nitro:graphql-yoga',\n async setup(nitro: Nitro) {\n // console.log('Setting up nitro:graphql-yoga module', nitro.options.framework)\n // Get module options from nitro config\n const options: NitroGraphQLOptions = {\n endpoint: '/api/graphql',\n playground: true,\n cors: false,\n cacheHeaders: {\n enabled: true,\n maxAge: 604800, // 1 week\n },\n client: {\n enabled: false,\n outputPath: undefined, // Will default to buildDir/types/graphql-client.generated.ts\n watchPatterns: undefined, // Will default to src/**/*.{graphql,gql} excluding server/graphql\n config: {\n documentMode: 'string',\n emitLegacyCommonJSImports: false,\n useTypeImports: true,\n enumsAsTypes: true,\n },\n },\n // Merge with user config from nitro.options\n ...(nitro.options as any).graphqlYoga,\n // Fallback to runtimeConfig for backward compatibility\n ...nitro.options.runtimeConfig?.graphqlYoga,\n }\n // Add GraphQL path to known chunk prefixes\n const graphqlPath = join(nitro.options.srcDir, 'graphql')\n\n // Access the internal rollup config and add our prefix\n nitro.hooks.hook('rollup:before', (nitro, rollupConfig) => {\n // Add codegen packages as external dependencies to prevent bundling\n rollupConfig.external = rollupConfig.external || []\n const codegenExternals = [\n '@graphql-codegen/core',\n '@graphql-codegen/typescript',\n '@graphql-codegen/typescript-resolvers',\n '@graphql-codegen/typescript-operations',\n '@graphql-codegen/typescript-generic-sdk',\n '@graphql-tools/graphql-file-loader',\n '@graphql-tools/load',\n ]\n\n if (Array.isArray(rollupConfig.external)) {\n rollupConfig.external.push(...codegenExternals)\n }\n else if (typeof rollupConfig.external === 'function') {\n const originalExternal = rollupConfig.external\n rollupConfig.external = (id, parent, isResolved) => {\n if (codegenExternals.some(external => id.includes(external))) {\n return true\n }\n return originalExternal(id, parent, isResolved)\n }\n }\n\n // Add GraphQL path to chunkNamePrefixes\n const originalChunkFileNames = rollupConfig.output.chunkFileNames\n rollupConfig.output.chunkFileNames = (chunk) => {\n // Only GraphQL resolvers (actual resolver files) should go to graphql folder\n const allIds = chunk.moduleIds || []\n\n const hasGraphQLResolverFile = allIds.some(id =>\n // Only server/graphql resolver files (not node_modules, not virtual modules)\n id.includes(graphqlPath)\n && !id.includes('node_modules')\n && !id.includes('#nitro-graphql')\n && (id.endsWith('.ts') || id.endsWith('.js') || id.endsWith('.mjs')),\n )\n\n if (hasGraphQLResolverFile) {\n return `chunks/graphql/[name].mjs`\n }\n // Use original logic for other chunks\n if (typeof originalChunkFileNames === 'function') {\n return originalChunkFileNames(chunk)\n }\n return originalChunkFileNames || 'chunks/_/[name].mjs'\n }\n })\n\n // Add virtual imports\n nitro.options.virtual ??= {}\n\n // Add context type\n nitro.options.virtual['#nitro-graphql/context'] = () => `\nexport type { GraphQLContext } from 'nitro-graphql/context'\n`\n\n // Initial scan\n const scanResult = await scanGraphQLFiles(nitro)\n\n // Log resolver discovery for debugging\n if (scanResult.resolvers.length > 0) {\n logger.success(`Found ${scanResult.resolvers.length} resolvers`)\n }\n\n // Generate types for both development and build modes\n if (scanResult.typeDefs.length > 0) {\n const mergedTypeDefs = mergeTypeDefs(scanResult.typeDefs)\n const schema = makeExecutableSchema({\n typeDefs: mergedTypeDefs,\n resolvers: {},\n })\n\n // Use Function constructor to prevent bundling in production\n const { generateTypes } = await (new Function('return import(\"nitro-graphql/codegen\")'))()\n const generatedTypes = await generateTypes(schema)\n\n // Write to file\n const outputPath = join(nitro.options.buildDir, 'types', 'graphql-types.generated.ts')\n const typesDir = join(nitro.options.buildDir, 'types')\n await mkdir(typesDir, { recursive: true })\n await writeFile(outputPath, generatedTypes)\n\n // Create graphql.d.ts that declares the module\n const graphqlDtsPath = join(typesDir, 'graphql.d.ts')\n const graphqlDtsContent = `// Auto-generated by nitro-graphql\nimport type { Resolvers as Test } from './graphql-types.generated'\n\ndeclare module 'nitro-graphql' {\n interface Resolvers extends Test {}\n}\n`\n await writeFile(graphqlDtsPath, graphqlDtsContent)\n\n logger.success('Types generated')\n }\n else {\n // Create minimal types when no schema files found\n const typesDir = join(nitro.options.buildDir, 'types')\n await mkdir(typesDir, { recursive: true })\n\n const minimalTypes = `// Generated by nitro-graphql (no schema found)\nexport type Resolvers = any\n`\n const outputPath = join(typesDir, 'graphql-types.generated.ts')\n await writeFile(outputPath, minimalTypes)\n\n const graphqlDtsPath = join(typesDir, 'graphql.d.ts')\n const graphqlDtsContent = `// Auto-generated by nitro-graphql\nimport type { Resolvers as Test } from './graphql-types.generated'\n\ndeclare module 'nitro-graphql' {\n interface Resolvers extends Test {}\n}\n`\n await writeFile(graphqlDtsPath, graphqlDtsContent)\n\n logger.info('Created minimal types (no schema found)')\n }\n\n // Setup file watchers in dev mode - completely excluded from production\n if (nitro.options.dev) {\n // Use Function constructor to prevent bundling in production\n const setupGraphQLWatcher = (await (new Function('return import(\"nitro-graphql/watcher\")'))()).setupGraphQLWatcher\n const setupClientWatcher = (await (new Function('return import(\"nitro-graphql/client-watcher\")'))()).setupClientWatcher\n await setupGraphQLWatcher(nitro)\n await setupClientWatcher(nitro, options)\n }\n\n // Add GraphQL Yoga handlers\n nitro.options.handlers = nitro.options.handlers || []\n const endpoint = options.endpoint || '/api/graphql'\n\n // Main GraphQL endpoint\n nitro.options.handlers.push({\n route: endpoint,\n handler: '#nitro-graphql/handler',\n method: 'get',\n })\n\n nitro.options.handlers.push({\n route: endpoint,\n handler: '#nitro-graphql/handler',\n method: 'post',\n })\n\n nitro.options.handlers.push({\n route: endpoint,\n handler: '#nitro-graphql/handler',\n method: 'options',\n })\n\n // Health check endpoint\n nitro.options.handlers.push({\n route: `${endpoint}/health`,\n handler: '#nitro-graphql/health',\n method: 'get',\n })\n\n // Create GraphQL handler\n nitro.options.virtual['#nitro-graphql/handler'] = () => `\nimport { createYoga } from 'graphql-yoga'\nimport { defineEventHandler, readRawBody, setHeader, setResponseStatus } from 'h3'\nimport { useStorage } from 'nitro/runtime'\nimport { makeExecutableSchema } from '@graphql-tools/schema'\nimport { mergeTypeDefs, mergeResolvers } from '@graphql-tools/merge'\nimport { join } from 'pathe'\n// Types are generated at build time to .nitro/graphql-types.generated.ts\n\n// GraphQL Context type is injected via context module\n\n// Create resolver helper\nglobalThis.createResolver = function(resolvers) {\n return resolvers\n}\n\n// Dynamic schema loading function\nasync function loadTypeDefs() {\n const schemaPath = join('${nitro.options.srcDir}', 'graphql', '**', '*.graphql')\n const { loadFilesSync } = await import('@graphql-tools/load-files')\n return loadFilesSync(schemaPath, {\n recursive: true,\n })\n}\n\n// Load resolvers using dynamic imports (Nitro handles the bundling)\nconst resolverImports = [\n${scanResult.resolvers.map(resolver => ` () => import('${resolver.path}')`).join(',\\n')}\n]\n\n// Async function to load resolvers\nasync function loadResolvers() {\n let resolvers = {}\n try {\n if (resolverImports.length > 0) {\n const resolverModules = []\n \n for (let i = 0; i < resolverImports.length; i++) {\n try {\n const resolverModule = await resolverImports[i]()\n const resolver = resolverModule.default || resolverModule\n \n if (resolver) {\n resolverModules.push(resolver)\n }\n } catch (error) {\n console.warn('[graphql] Failed to load resolver:', i, error.message)\n }\n }\n \n if (resolverModules.length > 0) {\n resolvers = mergeResolvers(resolverModules)\n } else {\n console.warn('[graphql] No resolvers could be loaded')\n resolvers = { Query: {}, Mutation: {} }\n }\n } else {\n console.warn('[graphql] No resolvers found')\n resolvers = { Query: {}, Mutation: {} }\n }\n } catch (error) {\n console.warn('[graphql] Error loading resolvers:', error.message)\n resolvers = { Query: {}, Mutation: {} }\n }\n return resolvers\n}\n\n// Apollo Sandbox HTML with 1 week cache\nconst apolloSandboxHtml = \\`<!DOCTYPE html>\n<html lang=\"en\">\n<body style=\"margin: 0; overflow-x: hidden; overflow-y: hidden\">\n<div id=\"sandbox\" style=\"height:100vh; width:100vw;\"></div>\n<script src=\"https://embeddable-sandbox.cdn.apollographql.com/02e2da0fccbe0240ef03d2396d6c98559bab5b06/embeddable-sandbox.umd.production.min.js\"></script>\n<script>\nnew window.EmbeddedSandbox({\n target: \"#sandbox\",\n initialEndpoint: window.location.href,\n hideCookieToggle: false,\n initialState: {\n includeCookies: true\n }\n});\n</script>\n</body>\n</html>\\`\n\n// Set cache headers for Apollo Sandbox HTML (1 week = 604800 seconds)\nfunction setApolloSandboxCacheHeaders(event) {\n setHeader(event, 'Cache-Control', 'public, max-age=604800, s-maxage=604800')\n setHeader(event, 'Expires', new Date(Date.now() + 604800000).toUTCString())\n setHeader(event, 'ETag', \\`\"apollo-sandbox-\\${Date.now()}\"\\`)\n}\n\n// Lazy initialization\nlet yoga = null\nlet initPromise = null\n\nasync function getYoga() {\n // In development mode, always reload schema for hot updates\n const isDev = ${nitro.options.dev}\n if (yoga && !isDev) return yoga\n \n if (!initPromise || isDev) {\n // Reset yoga instance in development mode\n if (isDev) {\n yoga = null\n }\n \n initPromise = (async () => {\n // Load custom yoga config first (separate from resolvers)\n let customYogaConfig = {}\n ${scanResult.yogaConfigPath\n ? `\n try {\n const yogaConfigModule = await import('${scanResult.yogaConfigPath}')\n customYogaConfig = yogaConfigModule.default || yogaConfigModule\n } catch (error) {\n console.warn('[graphql] Failed to load yoga config:', error.message)\n }`\n : ''}\n\n const resolvers = await loadResolvers()\n const typeDefs = await loadTypeDefs()\n \n // Merge schema and resolvers (without yoga config interfering)\n const schema = makeExecutableSchema({\n typeDefs: mergeTypeDefs(typeDefs),\n resolvers,\n })\n\n // Default yoga configuration\n const defaultYogaConfig = {\n schema,\n context: async ({ request }) => {\n const event = request.$$event\n return {\n event,\n request,\n storage: useStorage(),\n }\n },\n graphqlEndpoint: '${endpoint}',\n graphiql: ${options.playground !== false},\n renderGraphiQL: () => apolloSandboxHtml,\n landingPage: false,\n cors: ${JSON.stringify(options.cors || false)},\n }\n\n // Clean up custom config (remove properties that could be mistaken for GraphQL resolvers)\n const cleanCustomConfig = { ...customYogaConfig }\n \n // Remove empty arrays and functions that GraphQL Tools might confuse with resolvers\n if (Array.isArray(cleanCustomConfig.plugins) && cleanCustomConfig.plugins.length === 0) {\n delete cleanCustomConfig.plugins\n }\n \n // Remove these yoga-specific configs from resolver merging\n const yogaOnlyConfigs = ['context', 'plugins', 'maskedErrors', 'graphiql', 'cors']\n const cleanResolverConfig = { ...cleanCustomConfig }\n yogaOnlyConfigs.forEach(key => {\n delete cleanResolverConfig[key]\n })\n\n // Merge custom config with defaults\n const yogaConfig = {\n ...defaultYogaConfig,\n ...cleanCustomConfig,\n // Always override schema and endpoint from default config\n schema,\n graphqlEndpoint: '${endpoint}',\n }\n\n yoga = createYoga(yogaConfig)\n \n return yoga\n })()\n }\n \n return initPromise\n}\n\nexport default defineEventHandler(async (event) => {\n const { req } = event.node\n const host = req.headers.host || 'localhost'\n const protocol = 'http'\n const url = new URL(req.url || '/', protocol + '://' + host)\n \n // Attach event to request for context\n req.$$event = event\n \n const yogaInstance = await getYoga()\n const response = await yogaInstance.fetch(url.toString(), {\n method: req.method || 'GET',\n headers: req.headers,\n body: req.method !== 'GET' && req.method !== 'HEAD' ? await readRawBody(event) : undefined,\n }, {\n event,\n })\n \n // Set response headers\n response.headers.forEach((value, key) => {\n setHeader(event, key, value)\n })\n \n // Set status code\n setResponseStatus(event, response.status)\n \n // Return response body\n if (response.body) {\n const contentType = response.headers.get('content-type')\n if (contentType?.includes('text/html')) {\n // Set cache headers for Apollo Sandbox HTML\n setApolloSandboxCacheHeaders(event)\n return await response.text()\n }\n if (contentType?.includes('application/json')) {\n return await response.text()\n }\n return response.body\n }\n \n return null\n})\n`\n\n // Health check handler\n nitro.options.virtual['#nitro-graphql/health'] = () => `\nimport { defineEventHandler, setResponseStatus } from 'h3'\n\nexport default defineEventHandler(async (event) => {\n try {\n const response = await $fetch('${endpoint}', {\n method: 'POST',\n body: {\n query: 'query Health { __typename }',\n operationName: 'Health',\n },\n headers: {\n 'Content-Type': 'application/json',\n 'Accept': 'application/json',\n },\n })\n \n if (response && typeof response === 'object' && 'data' in response) {\n return {\n status: 'healthy',\n message: 'GraphQL server is running',\n timestamp: new Date().toISOString(),\n }\n }\n \n throw new Error('Invalid response from GraphQL server')\n } catch (error) {\n setResponseStatus(event, 503)\n return {\n status: 'unhealthy',\n message: error.message || 'GraphQL server is not responding',\n timestamp: new Date().toISOString(),\n }\n }\n})\n`\n\n // Auto-import utilities\n if (nitro.options.imports) {\n nitro.options.imports.presets.push({\n from: 'nitro-graphql',\n imports: [\n 'createResolver',\n 'defineGraphQLResolver',\n 'defineGraphQLSchema',\n 'defineGraphQLResolvers',\n 'defineYogaConfig',\n 'gql',\n ],\n })\n }\n\n // Add TypeScript path alias for IDE support\n nitro.options.typescript ??= {} as any\n nitro.options.typescript.tsConfig ??= {}\n nitro.options.typescript.tsConfig.compilerOptions ??= {}\n nitro.options.typescript.tsConfig.compilerOptions.paths ??= {}\n nitro.options.typescript.tsConfig.compilerOptions.paths['#build/graphql-types.generated'] = [\n join(nitro.options.buildDir, 'types', 'graphql-types.generated.ts'),\n ]\n nitro.options.typescript.tsConfig.include = nitro.options.typescript.tsConfig.include || []\n nitro.options.typescript.tsConfig.include.push(\n join(nitro.options.buildDir, 'types', 'graphql-types.generated.ts'),\n join(nitro.options.buildDir, 'types', 'graphql.d.ts'),\n )\n },\n})\n\nexport * from './codegen'\nexport * from './context'\nexport * from './types'\nexport { createResolver, defineGraphQLResolver, defineYogaConfig } from './utils'\n"],"mappings":"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"}
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
import { consola } from "consola";
|
|
2
|
+
import { basename, join, relative } from "pathe";
|
|
3
|
+
import { existsSync, readFileSync } from "node:fs";
|
|
4
|
+
import { globby } from "globby";
|
|
5
|
+
|
|
6
|
+
//#region src/scanner.ts
|
|
7
|
+
async function scanGraphQLFiles(nitro) {
|
|
8
|
+
try {
|
|
9
|
+
const graphqlFiles = await scanGraphQLFilesWithResolvers(nitro);
|
|
10
|
+
const typeDefs = graphqlFiles.map((f) => f.typeDefs).filter(Boolean);
|
|
11
|
+
const resolvers = await scanResolverFiles(nitro);
|
|
12
|
+
const resolverPaths = resolvers.map((r) => r.path);
|
|
13
|
+
const yogaConfigPath = await scanForYogaConfig(nitro);
|
|
14
|
+
consola.info(`[graphql] Found ${typeDefs.length} schema files and ${resolvers.length} resolvers`);
|
|
15
|
+
return {
|
|
16
|
+
typeDefs,
|
|
17
|
+
resolverPaths,
|
|
18
|
+
resolvers,
|
|
19
|
+
graphqlFiles,
|
|
20
|
+
yogaConfigPath
|
|
21
|
+
};
|
|
22
|
+
} catch (error) {
|
|
23
|
+
consola.warn("[graphql] Error scanning files:", error);
|
|
24
|
+
return {
|
|
25
|
+
typeDefs: [],
|
|
26
|
+
resolverPaths: [],
|
|
27
|
+
resolvers: [],
|
|
28
|
+
graphqlFiles: []
|
|
29
|
+
};
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
async function scanResolverFiles(nitro) {
|
|
33
|
+
const NITRO_GLOB_PATTERN = "**/*.{js,mjs,cjs,ts,mts,cts,tsx,jsx}";
|
|
34
|
+
const resolverFiles = await Promise.all(nitro.options.scanDirs.map(async (scanDir) => {
|
|
35
|
+
const graphqlDir = join(scanDir, "graphql");
|
|
36
|
+
if (!existsSync(graphqlDir)) return [];
|
|
37
|
+
return globby([
|
|
38
|
+
join(graphqlDir, NITRO_GLOB_PATTERN),
|
|
39
|
+
`!${join(graphqlDir, "**/*.d.ts")}`,
|
|
40
|
+
`!${join(graphqlDir, "**/*.test.*")}`,
|
|
41
|
+
`!${join(graphqlDir, "**/*.spec.*")}`,
|
|
42
|
+
`!${join(graphqlDir, "**/yoga.config.ts")}`
|
|
43
|
+
], {
|
|
44
|
+
cwd: scanDir,
|
|
45
|
+
dot: true,
|
|
46
|
+
ignore: nitro.options.ignore || [],
|
|
47
|
+
absolute: true
|
|
48
|
+
});
|
|
49
|
+
})).then((results) => results.flat());
|
|
50
|
+
const resolvers = [];
|
|
51
|
+
for (const filePath of resolverFiles) {
|
|
52
|
+
const scanDir = nitro.options.scanDirs.find((dir) => filePath.startsWith(dir));
|
|
53
|
+
if (!scanDir) continue;
|
|
54
|
+
const graphqlDir = join(scanDir, "graphql");
|
|
55
|
+
const relativePath = relative(graphqlDir, filePath);
|
|
56
|
+
const fileName = basename(relativePath, ".ts") || basename(relativePath, ".js") || basename(relativePath, ".mjs");
|
|
57
|
+
const importPath = relativePath.replace(/\.(ts|js|mjs|tsx|jsx|cjs|mts|cts)$/, "");
|
|
58
|
+
resolvers.push({
|
|
59
|
+
path: filePath,
|
|
60
|
+
relativePath,
|
|
61
|
+
name: fileName,
|
|
62
|
+
importPath,
|
|
63
|
+
isGraphQLFile: false
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
return resolvers;
|
|
67
|
+
}
|
|
68
|
+
async function scanGraphQLFilesWithResolvers(nitro) {
|
|
69
|
+
const graphqlFiles = await Promise.all(nitro.options.scanDirs.map(async (scanDir) => {
|
|
70
|
+
const graphqlDir = join(scanDir, "graphql");
|
|
71
|
+
if (!existsSync(graphqlDir)) return [];
|
|
72
|
+
return globby([join(graphqlDir, "**/*.graphql"), join(graphqlDir, "**/*.gql")], {
|
|
73
|
+
cwd: scanDir,
|
|
74
|
+
dot: true,
|
|
75
|
+
ignore: nitro.options.ignore || [],
|
|
76
|
+
absolute: true
|
|
77
|
+
});
|
|
78
|
+
})).then((results) => results.flat());
|
|
79
|
+
const files = [];
|
|
80
|
+
for (const filePath of graphqlFiles) {
|
|
81
|
+
const scanDir = nitro.options.scanDirs.find((dir) => filePath.startsWith(dir));
|
|
82
|
+
if (!scanDir) continue;
|
|
83
|
+
const graphqlDir = join(scanDir, "graphql");
|
|
84
|
+
const relativePath = relative(graphqlDir, filePath);
|
|
85
|
+
const contentStr = readFileSync(filePath, "utf-8");
|
|
86
|
+
const hasResolvers = contentStr.includes("# @resolver") || contentStr.includes("# @resolvers");
|
|
87
|
+
let typeDefs = contentStr;
|
|
88
|
+
if (hasResolvers) {
|
|
89
|
+
const lines = contentStr.split("\n");
|
|
90
|
+
const schemaLines = [];
|
|
91
|
+
for (const line of lines) {
|
|
92
|
+
if (line.match(/^#\s*@resolver/)) break;
|
|
93
|
+
schemaLines.push(line);
|
|
94
|
+
}
|
|
95
|
+
typeDefs = schemaLines.join("\n").trim();
|
|
96
|
+
}
|
|
97
|
+
files.push({
|
|
98
|
+
path: filePath,
|
|
99
|
+
relativePath,
|
|
100
|
+
content: contentStr,
|
|
101
|
+
hasResolvers,
|
|
102
|
+
typeDefs
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
return files;
|
|
106
|
+
}
|
|
107
|
+
async function scanForYogaConfig(nitro) {
|
|
108
|
+
const configFileName = "yoga.config.ts";
|
|
109
|
+
for (const scanDir of nitro.options.scanDirs) {
|
|
110
|
+
const graphqlDir = join(scanDir, "graphql");
|
|
111
|
+
const configPath = join(graphqlDir, configFileName);
|
|
112
|
+
if (existsSync(configPath)) return configPath;
|
|
113
|
+
}
|
|
114
|
+
return void 0;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
//#endregion
|
|
118
|
+
export { scanGraphQLFiles };
|
|
119
|
+
//# sourceMappingURL=scanner-BdcKEPQk.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"scanner-BdcKEPQk.js","names":["nitro: Nitro","resolvers: ResolverInfo[]","files: GraphQLFileInfo[]"],"sources":["../src/scanner.ts"],"sourcesContent":["import type { Nitro } from 'nitropack/types'\nimport { existsSync, readFileSync } from 'node:fs'\nimport { consola } from 'consola'\nimport { globby } from 'globby'\nimport { basename, join, relative } from 'pathe'\n\nexport interface ResolverInfo {\n path: string\n relativePath: string\n name: string\n importPath: string\n isGraphQLFile?: boolean\n}\n\nexport interface GraphQLFileInfo {\n path: string\n relativePath: string\n content: string\n hasResolvers: boolean\n typeDefs?: string\n resolvers?: any\n}\n\nexport interface ScanResult {\n typeDefs: string[]\n resolverPaths: string[]\n resolvers: ResolverInfo[]\n graphqlFiles: GraphQLFileInfo[]\n yogaConfigPath?: string\n}\n\nexport async function scanGraphQLFiles(nitro: Nitro): Promise<ScanResult> {\n try {\n // Scan GraphQL files with enhanced parsing\n const graphqlFiles = await scanGraphQLFilesWithResolvers(nitro)\n const typeDefs = graphqlFiles.map(f => f.typeDefs).filter(Boolean) as string[]\n\n // Scan separate resolver files\n const resolvers = await scanResolverFiles(nitro)\n const resolverPaths = resolvers.map(r => r.path)\n\n // Scan for GraphQL Yoga config file\n const yogaConfigPath = await scanForYogaConfig(nitro)\n\n consola.info(`[graphql] Found ${typeDefs.length} schema files and ${resolvers.length} resolvers`)\n\n return {\n typeDefs,\n resolverPaths,\n resolvers,\n graphqlFiles,\n yogaConfigPath,\n }\n }\n catch (error) {\n consola.warn('[graphql] Error scanning files:', error)\n return {\n typeDefs: [],\n resolverPaths: [],\n resolvers: [],\n graphqlFiles: [],\n }\n }\n}\n\nexport async function scanResolverFiles(nitro: Nitro): Promise<ResolverInfo[]> {\n // Use Nitro's scan pattern (same as API routes)\n const NITRO_GLOB_PATTERN = '**/*.{js,mjs,cjs,ts,mts,cts,tsx,jsx}'\n\n // Scan all configured scan directories (like Nitro does)\n const resolverFiles = await Promise.all(\n nitro.options.scanDirs.map(async (scanDir) => {\n const graphqlDir = join(scanDir, 'graphql')\n if (!existsSync(graphqlDir))\n return []\n\n return globby([\n join(graphqlDir, NITRO_GLOB_PATTERN),\n `!${join(graphqlDir, '**/*.d.ts')}`,\n `!${join(graphqlDir, '**/*.test.*')}`,\n `!${join(graphqlDir, '**/*.spec.*')}`,\n `!${join(graphqlDir, '**/yoga.config.ts')}`,\n ], {\n cwd: scanDir,\n dot: true,\n ignore: nitro.options.ignore || [],\n absolute: true,\n })\n }),\n ).then(results => results.flat())\n\n const resolvers: ResolverInfo[] = []\n\n for (const filePath of resolverFiles) {\n // Find which scan directory this file belongs to\n const scanDir = nitro.options.scanDirs.find(dir => filePath.startsWith(dir))\n if (!scanDir)\n continue\n\n const graphqlDir = join(scanDir, 'graphql')\n const relativePath = relative(graphqlDir, filePath)\n const fileName = basename(relativePath, '.ts') || basename(relativePath, '.js') || basename(relativePath, '.mjs')\n\n // Create import path relative to the graphql directory\n const importPath = relativePath.replace(/\\.(ts|js|mjs|tsx|jsx|cjs|mts|cts)$/, '')\n\n resolvers.push({\n path: filePath,\n relativePath,\n name: fileName,\n importPath,\n isGraphQLFile: false,\n })\n }\n\n return resolvers\n}\n\nexport async function scanGraphQLFilesWithResolvers(nitro: Nitro): Promise<GraphQLFileInfo[]> {\n // Scan all configured scan directories (like Nitro does)\n const graphqlFiles = await Promise.all(\n nitro.options.scanDirs.map(async (scanDir) => {\n const graphqlDir = join(scanDir, 'graphql')\n if (!existsSync(graphqlDir))\n return []\n\n return globby([\n join(graphqlDir, '**/*.graphql'),\n join(graphqlDir, '**/*.gql'),\n ], {\n cwd: scanDir,\n dot: true,\n ignore: nitro.options.ignore || [],\n absolute: true,\n })\n }),\n ).then(results => results.flat())\n\n const files: GraphQLFileInfo[] = []\n\n for (const filePath of graphqlFiles) {\n // Find which scan directory this file belongs to\n const scanDir = nitro.options.scanDirs.find(dir => filePath.startsWith(dir))\n if (!scanDir)\n continue\n\n const graphqlDir = join(scanDir, 'graphql')\n const relativePath = relative(graphqlDir, filePath)\n const contentStr = readFileSync(filePath, 'utf-8')\n\n // Check if file contains resolver definitions\n const hasResolvers = contentStr.includes('# @resolver') || contentStr.includes('# @resolvers')\n\n // Extract only the schema part (before resolver definitions)\n let typeDefs = contentStr\n if (hasResolvers) {\n const lines = contentStr.split('\\n')\n const schemaLines = []\n\n for (const line of lines) {\n if (line.match(/^#\\s*@resolver/)) {\n break\n }\n schemaLines.push(line)\n }\n\n typeDefs = schemaLines.join('\\n').trim()\n }\n\n files.push({\n path: filePath,\n relativePath,\n content: contentStr,\n hasResolvers,\n typeDefs,\n })\n }\n\n return files\n}\n\nexport async function scanForYogaConfig(nitro: Nitro): Promise<string | undefined> {\n // Only support yoga.config.ts for simplicity\n const configFileName = 'yoga.config.ts'\n\n // Only check in server/graphql directory\n for (const scanDir of nitro.options.scanDirs) {\n const graphqlDir = join(scanDir, 'graphql')\n const configPath = join(graphqlDir, configFileName)\n\n if (existsSync(configPath)) {\n return configPath\n }\n }\n\n return undefined\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { TypeScriptPluginConfig } from "@graphql-codegen/typescript";
|
|
2
|
+
import { TypeScriptDocumentsPluginConfig } from "@graphql-codegen/typescript-operations";
|
|
3
|
+
import { YogaServerOptions } from "graphql-yoga";
|
|
4
|
+
import { IncomingMessage, ServerResponse } from "node:http";
|
|
5
|
+
|
|
6
|
+
//#region src/types.d.ts
|
|
7
|
+
interface GraphQLSchemaConfig {
|
|
8
|
+
typeDefs: string | string[];
|
|
9
|
+
resolvers: any;
|
|
10
|
+
}
|
|
11
|
+
interface CodegenClientConfig extends TypeScriptPluginConfig, TypeScriptDocumentsPluginConfig {
|
|
12
|
+
endpoint?: string;
|
|
13
|
+
documentMode?: 'string' | 'graphQLTag' | 'documentNode' | 'documentNodeImportFragments' | 'external';
|
|
14
|
+
}
|
|
15
|
+
interface NitroGraphQLOptions {
|
|
16
|
+
endpoint?: string;
|
|
17
|
+
healthCheckEndpoint?: string;
|
|
18
|
+
playground?: boolean;
|
|
19
|
+
cors?: YogaServerOptions<{
|
|
20
|
+
req: IncomingMessage;
|
|
21
|
+
res: ServerResponse;
|
|
22
|
+
}, any>['cors'];
|
|
23
|
+
cacheHeaders?: {
|
|
24
|
+
enabled?: boolean;
|
|
25
|
+
maxAge?: number;
|
|
26
|
+
};
|
|
27
|
+
client?: {
|
|
28
|
+
enabled?: boolean;
|
|
29
|
+
outputPath?: string;
|
|
30
|
+
watchPatterns?: string[];
|
|
31
|
+
config?: CodegenClientConfig;
|
|
32
|
+
};
|
|
33
|
+
yogaConfig?: Partial<YogaServerOptions<any, any>>;
|
|
34
|
+
}
|
|
35
|
+
declare module 'nitropack' {
|
|
36
|
+
interface NitroOptions {
|
|
37
|
+
graphqlYoga?: NitroGraphQLOptions;
|
|
38
|
+
}
|
|
39
|
+
interface NitroRuntimeConfig {
|
|
40
|
+
graphqlYoga?: NitroGraphQLOptions;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
interface Resolvers {}
|
|
44
|
+
//# sourceMappingURL=types.d.ts.map
|
|
45
|
+
//#endregion
|
|
46
|
+
export { CodegenClientConfig, GraphQLSchemaConfig, NitroGraphQLOptions, Resolvers };
|
|
47
|
+
//# sourceMappingURL=types-D_NqyCcy.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types-D_NqyCcy.d.ts","names":[],"sources":["../src/types.ts"],"sourcesContent":[],"mappings":";;;;;;UAKiB,mBAAA;;EAAA,SAAA,EAAA,GAAA;AAKjB;AAAqC,UAApB,mBAAA,SAA4B,sBAAR,EAAgC,+BAAhC,CAAA;EAAA,QAAQ,CAAA,EAAA,MAAA;EAAsB,YAAE,CAAA,EAAA,QAAA,GAAA,YAAA,GAAA,cAAA,GAAA,6BAAA,GAAA,UAAA;AAA+B;AAKnF,UAAA,mBAAA,CAAmB;EAAA,QAAA,CAAA,EAAA,MAAA;EAAA,mBAIF,CAAA,EAAA,MAAA;EAAe,UAAO,CAAA,EAAA,OAAA;EAAc,IAA7D,CAAA,EAAA,iBAAA,CAAA;IASI,GAAA,EATqB,eASrB;IAEU,GAAA,EAXiC,cAWjC;EAAiB,CAAA,EAAzB,GAAA,CAAA,CAAA,MAAA,CAAA;EAAO,YAAA,CAAA,EAAA;IACrB,OAAA,CAAA,EAAA,OAAA;IAAA,MAAA,CAAA,EAAA,MAAA;EAAA,CAAA;EAIoC,MAInB,CAAA,EAAA;IAAmB,OAAA,CAAA,EAAA,OAAA;IAAA,UAAA,CAAA,EAAA,MAAA;IAIpB,aAAS,CAAA,EAAA,MAAA,EAAA;aAfb;;eAEE,QAAQ;;;;kBAKL;;;kBAIA;;;UAID,SAAA"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
//#region src/utils.ts
|
|
2
|
+
function defineGraphQLSchema(config) {
|
|
3
|
+
return config;
|
|
4
|
+
}
|
|
5
|
+
function defineGraphQLResolver(resolvers) {
|
|
6
|
+
return resolvers;
|
|
7
|
+
}
|
|
8
|
+
function createResolver(resolvers) {
|
|
9
|
+
return resolvers;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Define GraphQL resolvers map
|
|
13
|
+
*/
|
|
14
|
+
function defineGraphQLResolvers(resolvers) {
|
|
15
|
+
return resolvers;
|
|
16
|
+
}
|
|
17
|
+
function gql(strings, ...values) {
|
|
18
|
+
let result = "";
|
|
19
|
+
strings.forEach((string, i) => {
|
|
20
|
+
result += string;
|
|
21
|
+
if (i < values.length) result += values[i];
|
|
22
|
+
});
|
|
23
|
+
return result;
|
|
24
|
+
}
|
|
25
|
+
function debounce(func, wait) {
|
|
26
|
+
let timeout;
|
|
27
|
+
return function(...args) {
|
|
28
|
+
clearTimeout(timeout);
|
|
29
|
+
timeout = setTimeout(() => func(...args), wait);
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Helper function to define GraphQL Yoga configuration with type safety
|
|
34
|
+
*/
|
|
35
|
+
function defineYogaConfig(config) {
|
|
36
|
+
return config;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
//#endregion
|
|
40
|
+
export { createResolver, debounce, defineGraphQLResolver, defineGraphQLResolvers, defineGraphQLSchema, defineYogaConfig, gql };
|
|
41
|
+
//# sourceMappingURL=utils-87_22aIA.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils-87_22aIA.js","names":["config: GraphQLSchemaConfig","resolvers: Resolvers","strings: TemplateStringsArray","func: T","wait: number","timeout: NodeJS.Timeout | undefined","config: Partial<YogaServerOptions<TServerContext, TUserContext>>"],"sources":["../src/utils.ts"],"sourcesContent":["import type { YogaServerOptions } from 'graphql-yoga'\nimport type { GraphQLSchemaConfig, Resolvers } from './types'\n\nexport function defineGraphQLSchema(config: GraphQLSchemaConfig): GraphQLSchemaConfig {\n return config\n}\n\nexport function defineGraphQLResolver(\n resolvers: Resolvers,\n): Resolvers {\n return resolvers\n}\n\nexport function createResolver(\n resolvers: Resolvers,\n): Resolvers {\n return resolvers\n}\n\n/**\n * Define GraphQL resolvers map\n */\nexport function defineGraphQLResolvers(resolvers: Resolvers): Resolvers {\n return resolvers\n}\n\nexport function gql(strings: TemplateStringsArray, ...values: any[]): string {\n let result = ''\n strings.forEach((string, i) => {\n result += string\n if (i < values.length) {\n result += values[i]\n }\n })\n return result\n}\n\nexport function debounce<T extends (...args: any[]) => any>(\n func: T,\n wait: number,\n): (...args: Parameters<T>) => void {\n let timeout: NodeJS.Timeout | undefined\n\n return function (...args: Parameters<T>) {\n clearTimeout(timeout)\n timeout = setTimeout(() => func(...args), wait)\n }\n}\n\n/**\n * Helper function to define GraphQL Yoga configuration with type safety\n */\nexport function defineYogaConfig<TServerContext = any, TUserContext = any>(\n config: Partial<YogaServerOptions<TServerContext, TUserContext>>,\n): Partial<YogaServerOptions<TServerContext, TUserContext>> {\n return config\n}\n"],"mappings":";AAGA,SAAgB,oBAAoBA,QAAkD;AACpF,QAAO;AACR;AAED,SAAgB,sBACdC,WACW;AACX,QAAO;AACR;AAED,SAAgB,eACdA,WACW;AACX,QAAO;AACR;;;;AAKD,SAAgB,uBAAuBA,WAAiC;AACtE,QAAO;AACR;AAED,SAAgB,IAAIC,SAA+B,GAAG,QAAuB;CAC3E,IAAI,SAAS;AACb,SAAQ,QAAQ,CAAC,QAAQ,MAAM;AAC7B,YAAU;AACV,MAAI,IAAI,OAAO,OACb,WAAU,OAAO;CAEpB,EAAC;AACF,QAAO;AACR;AAED,SAAgB,SACdC,MACAC,MACkC;CAClC,IAAIC;AAEJ,QAAO,SAAU,GAAG,MAAqB;AACvC,eAAa,QAAQ;AACrB,YAAU,WAAW,MAAM,KAAK,GAAG,KAAK,EAAE,KAAK;CAChD;AACF;;;;AAKD,SAAgB,iBACdC,QAC0D;AAC1D,QAAO;AACR"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { GraphQLSchemaConfig, Resolvers } from "./types-D_NqyCcy.js";
|
|
2
|
+
import { YogaServerOptions } from "graphql-yoga";
|
|
3
|
+
|
|
4
|
+
//#region src/utils.d.ts
|
|
5
|
+
declare function defineGraphQLSchema(config: GraphQLSchemaConfig): GraphQLSchemaConfig;
|
|
6
|
+
declare function defineGraphQLResolver(resolvers: Resolvers): Resolvers;
|
|
7
|
+
declare function createResolver(resolvers: Resolvers): Resolvers;
|
|
8
|
+
/**
|
|
9
|
+
* Define GraphQL resolvers map
|
|
10
|
+
*/
|
|
11
|
+
declare function defineGraphQLResolvers(resolvers: Resolvers): Resolvers;
|
|
12
|
+
declare function gql(strings: TemplateStringsArray, ...values: any[]): string;
|
|
13
|
+
declare function debounce<T extends (...args: any[]) => any>(func: T, wait: number): (...args: Parameters<T>) => void;
|
|
14
|
+
/**
|
|
15
|
+
* Helper function to define GraphQL Yoga configuration with type safety
|
|
16
|
+
*/
|
|
17
|
+
declare function defineYogaConfig<TServerContext = any, TUserContext = any>(config: Partial<YogaServerOptions<TServerContext, TUserContext>>): Partial<YogaServerOptions<TServerContext, TUserContext>>;
|
|
18
|
+
//# sourceMappingURL=utils.d.ts.map
|
|
19
|
+
|
|
20
|
+
//#endregion
|
|
21
|
+
export { createResolver, debounce, defineGraphQLResolver, defineGraphQLResolvers, defineGraphQLSchema, defineYogaConfig, gql };
|
|
22
|
+
//# sourceMappingURL=utils-BuYDOLIi.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils-BuYDOLIi.d.ts","names":[],"sources":["../src/utils.ts"],"sourcesContent":[],"mappings":";;;;iBAGgB,mBAAA,SAA4B,sBAAsB;iBAIlD,qBAAA,YACH,YACV;AANa,iBAUA,cAAA,CAVmB,SAAA,EAWtB,SAXsB,CAAA,EAYhC,SAZgC;;;;AAAkD,iBAmBrE,sBAAA,CAnBqE,SAAA,EAmBnC,SAnBmC,CAAA,EAmBvB,SAnBuB;AAIrE,iBAmBA,GAAA,CAnBqB,OAAA,EAmBR,oBAnBQ,EAAA,GAAA,MAAA,EAAA,GAAA,EAAA,CAAA,EAAA,MAAA;AAAA,iBA8BrB,QA9BqB,CAAA,UAAA,CAAA,GAAA,IAAA,EAAA,GAAA,EAAA,EAAA,GAAA,GAAA,CAAA,CAAA,IAAA,EA+B7B,CA/B6B,EAAA,IAAA,EAAA,MAAA,CAAA,EAAA,CAAA,GAAA,IAAA,EAiCxB,UAjCwB,CAiCb,CAjCa,CAAA,EAAA,GAAA,IAAA;;;AAEzB;AAII,iBAuCA,gBAvCc,CAAA,iBAAA,GAAA,EAAA,eAAA,GAAA,CAAA,CAAA,MAAA,EAwCpB,OAxCoB,CAwCZ,iBAxCY,CAwCM,cAxCN,EAwCsB,YAxCtB,CAAA,CAAA,CAAA,EAyC3B,OAzC2B,CAyCnB,iBAzCmB,CAyCD,cAzCC,EAyCe,YAzCf,CAAA,CAAA"}
|
package/dist/utils.d.ts
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import "./types-D_NqyCcy.js";
|
|
2
|
+
import { createResolver, debounce, defineGraphQLResolver, defineGraphQLResolvers, defineGraphQLSchema, defineYogaConfig, gql } from "./utils-BuYDOLIi.js";
|
|
3
|
+
export { createResolver, debounce, defineGraphQLResolver, defineGraphQLResolvers, defineGraphQLSchema, defineYogaConfig, gql };
|
package/dist/utils.js
ADDED
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
import { createResolver, debounce, defineGraphQLResolver, defineGraphQLResolvers, defineGraphQLSchema, defineYogaConfig, gql } from "./utils-87_22aIA.js";
|
|
2
|
+
|
|
3
|
+
export { createResolver, debounce, defineGraphQLResolver, defineGraphQLResolvers, defineGraphQLSchema, defineYogaConfig, gql };
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { Nitro } from "nitropack/types";
|
|
2
|
+
|
|
3
|
+
//#region src/watcher.d.ts
|
|
4
|
+
declare function setupGraphQLWatcher(nitro: Nitro): Promise<void>;
|
|
5
|
+
//# sourceMappingURL=watcher.d.ts.map
|
|
6
|
+
|
|
7
|
+
//#endregion
|
|
8
|
+
export { setupGraphQLWatcher };
|
|
9
|
+
//# sourceMappingURL=watcher.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watcher.d.ts","names":[],"sources":["../src/watcher.ts"],"sourcesContent":[],"mappings":";;;iBA6DsB,mBAAA,QAA2B,QAAK"}
|
package/dist/watcher.js
ADDED
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
import { scanGraphQLFiles } from "./scanner-BdcKEPQk.js";
|
|
2
|
+
import { debounce } from "./utils-87_22aIA.js";
|
|
3
|
+
import { mkdir, writeFile } from "node:fs/promises";
|
|
4
|
+
import { mergeTypeDefs } from "@graphql-tools/merge";
|
|
5
|
+
import { makeExecutableSchema } from "@graphql-tools/schema";
|
|
6
|
+
import { consola } from "consola";
|
|
7
|
+
import { join } from "node:path";
|
|
8
|
+
|
|
9
|
+
//#region src/watcher.ts
|
|
10
|
+
const logger = consola.withTag("graphql");
|
|
11
|
+
async function regenerateGraphQLTypes(nitro) {
|
|
12
|
+
try {
|
|
13
|
+
const scanResult = await scanGraphQLFiles(nitro);
|
|
14
|
+
if (scanResult.typeDefs.length === 0) {
|
|
15
|
+
logger.warn("⚠️ No schema files found");
|
|
16
|
+
return;
|
|
17
|
+
}
|
|
18
|
+
const mergedTypeDefs = mergeTypeDefs(scanResult.typeDefs);
|
|
19
|
+
const schema = makeExecutableSchema({
|
|
20
|
+
typeDefs: mergedTypeDefs,
|
|
21
|
+
resolvers: {}
|
|
22
|
+
});
|
|
23
|
+
const { generateTypes } = await import("./codegen.js");
|
|
24
|
+
const generatedTypes = await generateTypes(schema);
|
|
25
|
+
const outputPath = join(nitro.options.buildDir, "types", "graphql-types.generated.ts");
|
|
26
|
+
const typesDir = join(nitro.options.buildDir, "types");
|
|
27
|
+
await mkdir(typesDir, { recursive: true });
|
|
28
|
+
await writeFile(outputPath, generatedTypes);
|
|
29
|
+
const graphqlDtsPath = join(typesDir, "graphql.d.ts");
|
|
30
|
+
const graphqlDtsContent = `// Auto-generated by nitro-graphql
|
|
31
|
+
import type { Resolvers as Test } from './graphql-types.generated'
|
|
32
|
+
|
|
33
|
+
declare module 'nitro-graphql' {
|
|
34
|
+
interface Resolvers extends Test {}
|
|
35
|
+
}
|
|
36
|
+
`;
|
|
37
|
+
await writeFile(graphqlDtsPath, graphqlDtsContent);
|
|
38
|
+
} catch (error) {
|
|
39
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
40
|
+
logger.error("❌ Type generation failed:", errorMessage);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
async function setupGraphQLWatcher(nitro) {
|
|
44
|
+
const watchPatterns = nitro.options.scanDirs.flatMap((dir) => [
|
|
45
|
+
join(dir, "graphql", "**/*.graphql"),
|
|
46
|
+
join(dir, "graphql", "**/*.gql"),
|
|
47
|
+
join(dir, "graphql", "**/*.{js,mjs,cjs,ts,mts,cts,tsx,jsx}")
|
|
48
|
+
]);
|
|
49
|
+
const generateTypesDebounced = debounce(async () => {
|
|
50
|
+
await regenerateGraphQLTypes(nitro);
|
|
51
|
+
}, 300);
|
|
52
|
+
const { watch } = await import("chokidar");
|
|
53
|
+
const existingFiles = await Promise.all(nitro.options.scanDirs.map(async (scanDir) => {
|
|
54
|
+
const { globby } = await import("globby");
|
|
55
|
+
const graphqlDir = join(scanDir, "graphql");
|
|
56
|
+
return globby([
|
|
57
|
+
join(graphqlDir, "**/*.graphql"),
|
|
58
|
+
join(graphqlDir, "**/*.gql"),
|
|
59
|
+
join(graphqlDir, "**/*.{js,mjs,cjs,ts,mts,cts,tsx,jsx}")
|
|
60
|
+
], { absolute: true });
|
|
61
|
+
})).then((results) => results.flat());
|
|
62
|
+
const watcher = watch(existingFiles.length > 0 ? existingFiles : watchPatterns, {
|
|
63
|
+
persistent: true,
|
|
64
|
+
ignoreInitial: true,
|
|
65
|
+
ignored: /(^|[/\\])\../,
|
|
66
|
+
followSymlinks: false,
|
|
67
|
+
depth: 10,
|
|
68
|
+
usePolling: true,
|
|
69
|
+
interval: 1e3,
|
|
70
|
+
binaryInterval: 1e3
|
|
71
|
+
});
|
|
72
|
+
watcher.on("change", (_path) => {
|
|
73
|
+
generateTypesDebounced();
|
|
74
|
+
});
|
|
75
|
+
watcher.on("add", (_path) => {
|
|
76
|
+
generateTypesDebounced();
|
|
77
|
+
});
|
|
78
|
+
watcher.on("unlink", (_path) => {
|
|
79
|
+
generateTypesDebounced();
|
|
80
|
+
});
|
|
81
|
+
watcher.on("error", (error) => {
|
|
82
|
+
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
83
|
+
logger.error("❌ Watcher error:", errorMessage);
|
|
84
|
+
});
|
|
85
|
+
nitro.hooks.hook("close", () => {
|
|
86
|
+
watcher.close();
|
|
87
|
+
});
|
|
88
|
+
nitro.hooks.hook("dev:reload", () => {
|
|
89
|
+
generateTypesDebounced();
|
|
90
|
+
});
|
|
91
|
+
logger.success("✅ Watcher ready");
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
//#endregion
|
|
95
|
+
export { setupGraphQLWatcher };
|
|
96
|
+
//# sourceMappingURL=watcher.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"watcher.js","names":["nitro: Nitro"],"sources":["../src/watcher.ts"],"sourcesContent":["import type { Nitro } from 'nitropack/types'\nimport { mkdir, writeFile } from 'node:fs/promises'\nimport { join } from 'node:path'\nimport { mergeTypeDefs } from '@graphql-tools/merge'\nimport { makeExecutableSchema } from '@graphql-tools/schema'\nimport { consola } from 'consola'\n// import { generateTypes } from './codegen' // Conditionally imported to prevent bundling\nimport { scanGraphQLFiles } from './scanner'\nimport { debounce } from './utils'\n\nconst logger = consola.withTag('graphql')\n\n// Type generation function that can be called from hooks\nasync function regenerateGraphQLTypes(nitro: Nitro) {\n try {\n // Scan all GraphQL files and resolvers\n const scanResult = await scanGraphQLFiles(nitro)\n\n if (scanResult.typeDefs.length === 0) {\n logger.warn('⚠️ No schema files found')\n return\n }\n\n // Merge all type definitions\n const mergedTypeDefs = mergeTypeDefs(scanResult.typeDefs)\n\n // Create schema\n const schema = makeExecutableSchema({\n typeDefs: mergedTypeDefs,\n resolvers: {}, // Empty resolvers for type generation\n })\n\n // Generate types using dynamic import\n const { generateTypes } = await import('./codegen')\n const generatedTypes = await generateTypes(schema)\n\n // Write to file\n const outputPath = join(nitro.options.buildDir, 'types', 'graphql-types.generated.ts')\n const typesDir = join(nitro.options.buildDir, 'types')\n await mkdir(typesDir, { recursive: true })\n await writeFile(outputPath, generatedTypes)\n\n // Update graphql.d.ts\n const graphqlDtsPath = join(typesDir, 'graphql.d.ts')\n const graphqlDtsContent = `// Auto-generated by nitro-graphql\nimport type { Resolvers as Test } from './graphql-types.generated'\n\ndeclare module 'nitro-graphql' {\n interface Resolvers extends Test {}\n}\n`\n await writeFile(graphqlDtsPath, graphqlDtsContent)\n\n // Types updated silently\n }\n catch (error) {\n const errorMessage = error instanceof Error ? error.message : String(error)\n logger.error('❌ Type generation failed:', errorMessage)\n }\n}\n\nexport async function setupGraphQLWatcher(nitro: Nitro) {\n // Use chokidar directly for reliable file watching\n const watchPatterns = nitro.options.scanDirs.flatMap(dir => [\n join(dir, 'graphql', '**/*.graphql'),\n join(dir, 'graphql', '**/*.gql'),\n join(dir, 'graphql', '**/*.{js,mjs,cjs,ts,mts,cts,tsx,jsx}'),\n ])\n\n // Setup file watcher\n\n // Create debounced function for type generation\n const generateTypesDebounced = debounce(async () => {\n // Regenerate types silently\n await regenerateGraphQLTypes(nitro)\n }, 300)\n\n // Use chokidar for reliable file watching with specific files\n const { watch } = await import('chokidar')\n\n // Watch specific existing files instead of patterns for better reliability\n const existingFiles = await Promise.all(nitro.options.scanDirs.map(async (scanDir) => {\n const { globby } = await import('globby')\n const graphqlDir = join(scanDir, 'graphql')\n return globby([\n join(graphqlDir, '**/*.graphql'),\n join(graphqlDir, '**/*.gql'),\n join(graphqlDir, '**/*.{js,mjs,cjs,ts,mts,cts,tsx,jsx}'),\n ], { absolute: true })\n })).then(results => results.flat())\n\n // File watching setup complete\n\n const watcher = watch(existingFiles.length > 0 ? existingFiles : watchPatterns, {\n persistent: true,\n ignoreInitial: true,\n ignored: /(^|[/\\\\])\\../, // ignore dotfiles\n followSymlinks: false,\n depth: 10,\n usePolling: true, // Enable polling for better compatibility\n interval: 1000, // Check every second\n binaryInterval: 1000,\n })\n\n // watcher.on('ready', () => {})\n\n watcher.on('change', (_path) => {\n generateTypesDebounced()\n })\n\n watcher.on('add', (_path) => {\n generateTypesDebounced()\n })\n\n watcher.on('unlink', (_path) => {\n generateTypesDebounced()\n })\n\n watcher.on('error', (error) => {\n const errorMessage = error instanceof Error ? error.message : String(error)\n logger.error('❌ Watcher error:', errorMessage)\n })\n\n // Hook into Nitro's lifecycle to clean up watcher\n nitro.hooks.hook('close', () => {\n watcher.close()\n })\n\n // Also try to hook into Nitro's dev:reload for additional triggering\n nitro.hooks.hook('dev:reload', () => {\n generateTypesDebounced()\n })\n\n logger.success('✅ Watcher ready')\n}\n"],"mappings":";;;;;;;;;AAUA,MAAM,SAAS,QAAQ,QAAQ,UAAU;AAGzC,eAAe,uBAAuBA,OAAc;AAClD,KAAI;EAEF,MAAM,aAAa,MAAM,iBAAiB,MAAM;AAEhD,MAAI,WAAW,SAAS,WAAW,GAAG;AACpC,UAAO,KAAK,4BAA4B;AACxC;EACD;EAGD,MAAM,iBAAiB,cAAc,WAAW,SAAS;EAGzD,MAAM,SAAS,qBAAqB;GAClC,UAAU;GACV,WAAW,CAAE;EACd,EAAC;EAGF,MAAM,EAAE,eAAe,GAAG,MAAM,OAAO;EACvC,MAAM,iBAAiB,MAAM,cAAc,OAAO;EAGlD,MAAM,aAAa,KAAK,MAAM,QAAQ,UAAU,SAAS,6BAA6B;EACtF,MAAM,WAAW,KAAK,MAAM,QAAQ,UAAU,QAAQ;AACtD,QAAM,MAAM,UAAU,EAAE,WAAW,KAAM,EAAC;AAC1C,QAAM,UAAU,YAAY,eAAe;EAG3C,MAAM,iBAAiB,KAAK,UAAU,eAAe;EACrD,MAAM,oBAAoB,CAAC;;;;;;AAM/B,CAAC;AACG,QAAM,UAAU,gBAAgB,kBAAkB;CAGnD,SACM,OAAO;EACZ,MAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AAC3E,SAAO,MAAM,6BAA6B,aAAa;CACxD;AACF;AAED,eAAsB,oBAAoBA,OAAc;CAEtD,MAAM,gBAAgB,MAAM,QAAQ,SAAS,QAAQ,SAAO;EAC1D,KAAK,KAAK,WAAW,eAAe;EACpC,KAAK,KAAK,WAAW,WAAW;EAChC,KAAK,KAAK,WAAW,uCAAuC;CAC7D,EAAC;CAKF,MAAM,yBAAyB,SAAS,YAAY;AAElD,QAAM,uBAAuB,MAAM;CACpC,GAAE,IAAI;CAGP,MAAM,EAAE,OAAO,GAAG,MAAM,OAAO;CAG/B,MAAM,gBAAgB,MAAM,QAAQ,IAAI,MAAM,QAAQ,SAAS,IAAI,OAAO,YAAY;EACpF,MAAM,EAAE,QAAQ,GAAG,MAAM,OAAO;EAChC,MAAM,aAAa,KAAK,SAAS,UAAU;AAC3C,SAAO,OAAO;GACZ,KAAK,YAAY,eAAe;GAChC,KAAK,YAAY,WAAW;GAC5B,KAAK,YAAY,uCAAuC;EACzD,GAAE,EAAE,UAAU,KAAM,EAAC;CACvB,EAAC,CAAC,CAAC,KAAK,aAAW,QAAQ,MAAM,CAAC;CAInC,MAAM,UAAU,MAAM,cAAc,SAAS,IAAI,gBAAgB,eAAe;EAC9E,YAAY;EACZ,eAAe;EACf,SAAS;EACT,gBAAgB;EAChB,OAAO;EACP,YAAY;EACZ,UAAU;EACV,gBAAgB;CACjB,EAAC;AAIF,SAAQ,GAAG,UAAU,CAAC,UAAU;AAC9B,0BAAwB;CACzB,EAAC;AAEF,SAAQ,GAAG,OAAO,CAAC,UAAU;AAC3B,0BAAwB;CACzB,EAAC;AAEF,SAAQ,GAAG,UAAU,CAAC,UAAU;AAC9B,0BAAwB;CACzB,EAAC;AAEF,SAAQ,GAAG,SAAS,CAAC,UAAU;EAC7B,MAAM,eAAe,iBAAiB,QAAQ,MAAM,UAAU,OAAO,MAAM;AAC3E,SAAO,MAAM,oBAAoB,aAAa;CAC/C,EAAC;AAGF,OAAM,MAAM,KAAK,SAAS,MAAM;AAC9B,UAAQ,OAAO;CAChB,EAAC;AAGF,OAAM,MAAM,KAAK,cAAc,MAAM;AACnC,0BAAwB;CACzB,EAAC;AAEF,QAAO,QAAQ,kBAAkB;AAClC"}
|
package/package.json
ADDED
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "nitro-graphql",
|
|
3
|
+
"type": "module",
|
|
4
|
+
"version": "0.0.1",
|
|
5
|
+
"description": "GraphQL integration for Nitro",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"sideEffects": false,
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"types": "./dist/index.d.ts",
|
|
11
|
+
"import": "./dist/index.js"
|
|
12
|
+
},
|
|
13
|
+
"./codegen": {
|
|
14
|
+
"types": "./dist/codegen.d.ts",
|
|
15
|
+
"import": "./dist/codegen.js"
|
|
16
|
+
},
|
|
17
|
+
"./watcher": {
|
|
18
|
+
"types": "./dist/watcher.d.ts",
|
|
19
|
+
"import": "./dist/watcher.js"
|
|
20
|
+
},
|
|
21
|
+
"./client-watcher": {
|
|
22
|
+
"types": "./dist/client-watcher.d.ts",
|
|
23
|
+
"import": "./dist/client-watcher.js"
|
|
24
|
+
},
|
|
25
|
+
"./context": {
|
|
26
|
+
"types": "./dist/context.d.ts",
|
|
27
|
+
"import": "./dist/context.js"
|
|
28
|
+
},
|
|
29
|
+
"./utils": {
|
|
30
|
+
"types": "./dist/utils.d.ts",
|
|
31
|
+
"import": "./dist/utils.js"
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
"main": "./dist/index.js",
|
|
35
|
+
"types": "./dist/index.d.ts",
|
|
36
|
+
"files": [
|
|
37
|
+
"dist"
|
|
38
|
+
],
|
|
39
|
+
"peerDependencies": {
|
|
40
|
+
"nitropack": "^2.11.13"
|
|
41
|
+
},
|
|
42
|
+
"dependencies": {
|
|
43
|
+
"@graphql-codegen/core": "^4.0.2",
|
|
44
|
+
"@graphql-codegen/plugin-helpers": "^5.1.1",
|
|
45
|
+
"@graphql-codegen/typescript": "^4.1.6",
|
|
46
|
+
"@graphql-codegen/typescript-generic-sdk": "^4.0.2",
|
|
47
|
+
"@graphql-codegen/typescript-operations": "^4.6.1",
|
|
48
|
+
"@graphql-codegen/typescript-resolvers": "^4.5.1",
|
|
49
|
+
"@graphql-tools/graphql-file-loader": "^8.0.20",
|
|
50
|
+
"@graphql-tools/load": "^8.1.0",
|
|
51
|
+
"@graphql-tools/load-files": "^7.0.1",
|
|
52
|
+
"@graphql-tools/merge": "^9.0.24",
|
|
53
|
+
"@graphql-tools/schema": "^10.0.23",
|
|
54
|
+
"@graphql-tools/utils": "^10.8.6",
|
|
55
|
+
"chokidar": "^4.0.3",
|
|
56
|
+
"consola": "^3.4.2",
|
|
57
|
+
"defu": "^6.1.4",
|
|
58
|
+
"globby": "^14.1.0",
|
|
59
|
+
"graphql": "^16.11.0",
|
|
60
|
+
"graphql-scalars": "^1.24.2",
|
|
61
|
+
"graphql-yoga": "^5.14.0",
|
|
62
|
+
"pathe": "^2.0.3"
|
|
63
|
+
},
|
|
64
|
+
"devDependencies": {
|
|
65
|
+
"@antfu/eslint-config": "^4.16.2",
|
|
66
|
+
"@types/node": "^20.19.6",
|
|
67
|
+
"bumpp": "^10.2.0",
|
|
68
|
+
"changelogen": "^0.6.2",
|
|
69
|
+
"eslint": "^9.30.1",
|
|
70
|
+
"h3": "^1.15.3",
|
|
71
|
+
"nitropack": "^2.11.13",
|
|
72
|
+
"tsdown": "^0.12.9",
|
|
73
|
+
"typescript": "^5.8.3"
|
|
74
|
+
},
|
|
75
|
+
"resolutions": {
|
|
76
|
+
"nitro-graphql": "link:."
|
|
77
|
+
},
|
|
78
|
+
"scripts": {
|
|
79
|
+
"build": "tsdown",
|
|
80
|
+
"dev": "tsdown --watch",
|
|
81
|
+
"bumpp": "bumpp package.json",
|
|
82
|
+
"release": "pnpm build && pnpm bumpp && pnpm publish --no-git-checks --access public",
|
|
83
|
+
"playground": "cd playground && pnpm install && pnpm dev",
|
|
84
|
+
"lint": "eslint .",
|
|
85
|
+
"lint:fix": "eslint . --fix"
|
|
86
|
+
}
|
|
87
|
+
}
|