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.
- package/README.md +438 -27
- package/dist/cli/commands/generate.d.mts +26 -0
- package/dist/cli/commands/generate.mjs +196 -0
- package/dist/cli/commands/index.d.mts +4 -0
- package/dist/cli/commands/index.mjs +5 -0
- package/dist/cli/commands/init.d.mts +46 -0
- package/dist/cli/commands/init.mjs +195 -0
- package/dist/cli/commands/validate.d.mts +10 -0
- package/dist/cli/commands/validate.mjs +69 -0
- package/dist/cli/completions.d.mts +7 -0
- package/dist/cli/completions.mjs +34 -0
- package/dist/cli/config.d.mts +75 -0
- package/dist/cli/config.mjs +20 -0
- package/dist/cli/index.d.mts +24 -0
- package/dist/cli/index.mjs +253 -0
- package/dist/config.d.mts +2 -0
- package/dist/config.mjs +3 -0
- package/dist/core/codegen/client.d.mts +23 -0
- package/dist/core/codegen/client.mjs +150 -0
- package/dist/core/codegen/document-loader.d.mts +10 -0
- package/dist/core/codegen/document-loader.mjs +18 -0
- package/dist/core/codegen/index.d.mts +8 -0
- package/dist/core/codegen/index.mjs +9 -0
- package/dist/core/codegen/plugin.d.mts +20 -0
- package/dist/core/codegen/plugin.mjs +30 -0
- package/dist/core/codegen/runtime.d.mts +20 -0
- package/dist/core/codegen/runtime.mjs +60 -0
- package/dist/core/codegen/schema-loader.d.mts +28 -0
- package/dist/core/codegen/schema-loader.mjs +128 -0
- package/dist/core/codegen/server.d.mts +28 -0
- package/dist/core/codegen/server.mjs +143 -0
- package/dist/core/codegen/validation.d.mts +13 -0
- package/dist/core/codegen/validation.mjs +96 -0
- package/dist/core/config.d.mts +50 -0
- package/dist/core/config.mjs +82 -0
- package/dist/core/constants.d.mts +188 -0
- package/dist/core/constants.mjs +210 -0
- package/dist/core/index.d.mts +33 -0
- package/dist/core/index.mjs +27 -0
- package/dist/core/manifest.d.mts +46 -0
- package/dist/core/manifest.mjs +76 -0
- package/dist/core/scanning/ast-scanner.d.mts +28 -0
- package/dist/core/scanning/ast-scanner.mjs +122 -0
- package/dist/core/scanning/common.d.mts +37 -0
- package/dist/core/scanning/common.mjs +60 -0
- package/dist/core/scanning/directives.d.mts +10 -0
- package/dist/core/scanning/directives.mjs +29 -0
- package/dist/core/scanning/documents.d.mts +21 -0
- package/dist/core/scanning/documents.mjs +43 -0
- package/dist/core/scanning/index.d.mts +7 -0
- package/dist/core/scanning/index.mjs +8 -0
- package/dist/core/scanning/resolvers.d.mts +15 -0
- package/dist/core/scanning/resolvers.mjs +59 -0
- package/dist/core/scanning/schemas.d.mts +14 -0
- package/dist/core/scanning/schemas.mjs +64 -0
- package/dist/core/schema/builder.d.mts +53 -0
- package/dist/core/schema/builder.mjs +70 -0
- package/dist/core/schema/federation.d.mts +34 -0
- package/dist/core/schema/federation.mjs +40 -0
- package/dist/core/schema/index.d.mts +3 -0
- package/dist/core/schema/index.mjs +4 -0
- package/dist/core/types/adapter.d.mts +58 -0
- package/dist/core/types/codegen.d.mts +133 -0
- package/dist/core/types/config.d.mts +210 -0
- package/dist/core/types/config.mjs +1 -0
- package/dist/{utils/define.d.ts → core/types/define.d.mts} +3 -30
- package/dist/core/types/define.mjs +1 -0
- package/dist/core/types/index.d.mts +5 -0
- package/dist/core/types/index.mjs +1 -0
- package/dist/core/types/scanning.d.mts +69 -0
- package/dist/core/types/scanning.mjs +1 -0
- package/dist/{utils/directive-parser.d.ts → core/utils/directive-parser.d.mts} +21 -4
- package/dist/{utils/directive-parser.js → core/utils/directive-parser.mjs} +25 -34
- package/dist/core/utils/errors.d.mts +77 -0
- package/dist/core/utils/errors.mjs +93 -0
- package/dist/core/utils/file-io.d.mts +24 -0
- package/dist/core/utils/file-io.mjs +47 -0
- package/dist/core/utils/imports.d.mts +15 -0
- package/dist/core/utils/imports.mjs +25 -0
- package/dist/core/utils/index.d.mts +7 -0
- package/dist/core/utils/index.mjs +8 -0
- package/dist/core/utils/logger.d.mts +19 -0
- package/dist/core/utils/logger.mjs +38 -0
- package/dist/core/utils/ofetch-templates.d.mts +30 -0
- package/dist/core/utils/ofetch-templates.mjs +135 -0
- package/dist/core/validation/external-services.d.mts +11 -0
- package/dist/core/validation/external-services.mjs +34 -0
- package/dist/core/validation/index.d.mts +2 -0
- package/dist/core/validation/index.mjs +3 -0
- package/dist/define.d.mts +294 -0
- package/dist/define.mjs +323 -0
- package/dist/index.d.mts +6 -0
- package/dist/index.mjs +6 -0
- package/dist/nitro/adapter.d.mts +30 -0
- package/dist/nitro/adapter.mjs +97 -0
- package/dist/{utils/apollo.d.ts → nitro/apollo.d.mts} +3 -3
- package/dist/nitro/apollo.mjs +59 -0
- package/dist/nitro/codegen.d.mts +19 -0
- package/dist/nitro/codegen.mjs +141 -0
- package/dist/nitro/config.d.mts +51 -0
- package/dist/nitro/config.mjs +57 -0
- package/dist/nitro/index.d.mts +46 -0
- package/dist/nitro/index.mjs +65 -0
- package/dist/nitro/paths.d.mts +54 -0
- package/dist/nitro/paths.mjs +92 -0
- package/dist/nitro/rollup.d.mts +6 -0
- package/dist/nitro/rollup.mjs +95 -0
- package/dist/nitro/routes/apollo-server.d.mts +6 -0
- package/dist/nitro/routes/apollo-server.mjs +71 -0
- package/dist/nitro/routes/debug-template.d.mts +15 -0
- package/dist/nitro/routes/debug-template.mjs +385 -0
- package/dist/nitro/routes/debug.d.mts +55 -0
- package/dist/nitro/routes/debug.mjs +102 -0
- package/dist/nitro/routes/graphql-yoga.d.mts +6 -0
- package/dist/nitro/routes/graphql-yoga.mjs +62 -0
- package/dist/nitro/routes/health.d.mts +10 -0
- package/dist/{routes/health.js → nitro/routes/health.mjs} +4 -3
- package/dist/nitro/setup/extend-loader.d.mts +19 -0
- package/dist/nitro/setup/extend-loader.mjs +129 -0
- package/dist/nitro/setup/file-watcher.d.mts +16 -0
- package/dist/nitro/setup/file-watcher.mjs +98 -0
- package/dist/nitro/setup/logging.d.mts +17 -0
- package/dist/nitro/setup/logging.mjs +66 -0
- package/dist/nitro/setup/rollup-integration.d.mts +16 -0
- package/dist/nitro/setup/rollup-integration.mjs +90 -0
- package/dist/nitro/setup/routes.d.mts +10 -0
- package/dist/nitro/setup/routes.mjs +35 -0
- package/dist/nitro/setup/ts-config.d.mts +11 -0
- package/dist/nitro/setup/ts-config.mjs +69 -0
- package/dist/nitro/setup.d.mts +12 -0
- package/dist/nitro/setup.mjs +234 -0
- package/dist/nitro/types.d.mts +374 -0
- package/dist/nitro/types.mjs +1 -0
- package/dist/nitro/virtual/generators.d.mts +31 -0
- package/dist/nitro/virtual/generators.mjs +113 -0
- package/dist/nitro/virtual/stubs.d.mts +20 -0
- package/dist/nitro/virtual/stubs.mjs +31 -0
- package/dist/{ecosystem/nuxt.d.ts → nuxt.d.mts} +1 -1
- package/dist/nuxt.mjs +109 -0
- package/dist/{graphql/server.d.ts → stubs/index.d.mts} +5 -1
- package/dist/stubs/index.mjs +1 -0
- package/package.json +102 -77
- package/dist/ecosystem/nuxt.js +0 -67
- package/dist/graphql/index.d.ts +0 -5
- package/dist/index.d.ts +0 -8
- package/dist/index.js +0 -264
- package/dist/rollup.js +0 -119
- package/dist/routes/apollo-server.d.ts +0 -6
- package/dist/routes/apollo-server.js +0 -89
- package/dist/routes/graphql-yoga.d.ts +0 -6
- package/dist/routes/graphql-yoga.js +0 -91
- package/dist/routes/health.d.ts +0 -6
- package/dist/types/index.d.ts +0 -128
- package/dist/types/standard-schema.d.ts +0 -59
- package/dist/utils/apollo.js +0 -61
- package/dist/utils/client-codegen.d.ts +0 -38
- package/dist/utils/client-codegen.js +0 -290
- package/dist/utils/define.js +0 -57
- package/dist/utils/index.d.ts +0 -39
- package/dist/utils/index.js +0 -250
- package/dist/utils/server-codegen.d.ts +0 -7
- package/dist/utils/server-codegen.js +0 -136
- package/dist/utils/type-generation.d.ts +0 -7
- package/dist/utils/type-generation.js +0 -287
- package/dist/vite.d.ts +0 -25
- package/dist/vite.js +0 -40
- /package/dist/{graphql/index.js → core/types/adapter.mjs} +0 -0
- /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/
|
|
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 };
|