nitro-nightly 3.0.1-20260106-130706-e20c92d9 → 3.0.1-20260106-182834-5019d347

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/_build/rolldown.mjs +7 -5
  2. package/dist/_build/rollup.mjs +15 -5
  3. package/dist/_build/shared.mjs +2 -1
  4. package/dist/_build/shared2.mjs +1 -1
  5. package/dist/_build/shared3.mjs +1 -1
  6. package/dist/_build/vite.build.mjs +7 -6
  7. package/dist/_dev.mjs +2 -1
  8. package/dist/_libs/@hiogawa/vite-plugin-fullstack.mjs +5 -1560
  9. package/dist/_libs/@jridgewell/gen-mapping.mjs +2 -304
  10. package/dist/_libs/@jridgewell/remapping.mjs +2 -1
  11. package/dist/_libs/@jridgewell/resolve-uri.mjs +166 -0
  12. package/dist/_libs/@jridgewell/sourcemap-codec.mjs +167 -0
  13. package/dist/_libs/@jridgewell/trace-mapping.mjs +141 -0
  14. package/dist/_libs/@rolldown/pluginutils.mjs +31 -0
  15. package/dist/_libs/@rollup/plugin-commonjs.mjs +33 -2636
  16. package/dist/_libs/@rollup/plugin-inject.mjs +3 -2
  17. package/dist/_libs/@rollup/plugin-json.mjs +1 -1
  18. package/dist/_libs/@rollup/plugin-node-resolve.mjs +7 -1111
  19. package/dist/_libs/@rollup/plugin-replace.mjs +2 -2
  20. package/dist/_libs/@rollup/pluginutils.mjs +241 -0
  21. package/dist/_libs/c12.mjs +63 -2513
  22. package/dist/_libs/chokidar.mjs +1 -234
  23. package/dist/_libs/commondir.mjs +22 -0
  24. package/dist/_libs/confbox.mjs +1102 -502
  25. package/dist/_libs/deepmerge.mjs +86 -0
  26. package/dist/_libs/dotenv.mjs +345 -0
  27. package/dist/_libs/estree-walker.mjs +144 -1
  28. package/dist/_libs/exsolve.mjs +1007 -0
  29. package/dist/_libs/fdir.mjs +514 -0
  30. package/dist/_libs/function-bind.mjs +63 -0
  31. package/dist/_libs/giget.mjs +1376 -2234
  32. package/dist/_libs/hasown.mjs +14 -0
  33. package/dist/_libs/is-core-module.mjs +220 -0
  34. package/dist/_libs/is-module.mjs +13 -0
  35. package/dist/_libs/is-reference.mjs +33 -0
  36. package/dist/_libs/js-tokens.mjs +382 -0
  37. package/dist/_libs/local-pkg.mjs +6 -1560
  38. package/dist/_libs/magic-string.mjs +939 -0
  39. package/dist/_libs/mlly.mjs +1415 -0
  40. package/dist/_libs/node-fetch-native.mjs +7 -0
  41. package/dist/_libs/nypm.mjs +239 -0
  42. package/dist/_libs/path-parse.mjs +47 -0
  43. package/dist/_libs/pathe.mjs +163 -2
  44. package/dist/_libs/perfect-debounce.mjs +89 -0
  45. package/dist/_libs/picomatch.mjs +1673 -0
  46. package/dist/_libs/pkg-types.mjs +197 -0
  47. package/dist/_libs/quansync.mjs +90 -0
  48. package/dist/_libs/rc9.mjs +136 -0
  49. package/dist/_libs/readdirp.mjs +237 -0
  50. package/dist/_libs/resolve.mjs +689 -0
  51. package/dist/_libs/strip-literal.mjs +51 -0
  52. package/dist/_libs/tinyexec.mjs +627 -0
  53. package/dist/_libs/tinyglobby.mjs +2 -1
  54. package/dist/_libs/unimport.mjs +42 -1575
  55. package/dist/_libs/unplugin-utils.mjs +61 -0
  56. package/dist/_libs/unplugin.mjs +1225 -0
  57. package/dist/_libs/unwasm.mjs +3 -2
  58. package/dist/_libs/webpack-virtual-modules.mjs +272 -0
  59. package/dist/_nitro.mjs +5 -2
  60. package/dist/_nitro2.mjs +3 -3
  61. package/dist/_presets.mjs +5 -3
  62. package/dist/builder.mjs +4 -4
  63. package/dist/cli/_chunks/build.mjs +1 -1
  64. package/dist/cli/_chunks/dev.mjs +1 -1
  65. package/dist/cli/_chunks/list.mjs +1 -1
  66. package/dist/cli/_chunks/prepare.mjs +1 -1
  67. package/dist/cli/_chunks/run.mjs +1 -1
  68. package/dist/vite.mjs +1824 -19
  69. package/package.json +2 -2
  70. package/dist/_build/shared4.mjs +0 -1114
  71. package/dist/_build/vite.plugin.mjs +0 -712
@@ -1,712 +0,0 @@
1
- import { A as resolve$1, S as dirname$1, T as join$1, k as relative$1, s as debounce, w as isAbsolute$1, x as basename$1, y as resolveModulePath } from "../_libs/c12.mjs";
2
- import { t as formatCompatibilityDate } from "../_libs/compatx.mjs";
3
- import { i as a, r as T } from "../_libs/std-env.mjs";
4
- import { a as copyPublicAssets, i as prepare, s as createNitro } from "../_nitro.mjs";
5
- import { n as prettyPath } from "./shared2.mjs";
6
- import { i as scanHandlers } from "../_nitro2.mjs";
7
- import { r as assetsPlugin } from "../_libs/@hiogawa/vite-plugin-fullstack.mjs";
8
- import { n as writeBuildInfo, t as getBuildInfo } from "./shared3.mjs";
9
- import { i as NodeEnvRunner, r as NitroDevApp } from "../_dev.mjs";
10
- import { a as watch$1 } from "../_libs/chokidar.mjs";
11
- import { t as alias } from "../_libs/@rollup/plugin-alias.mjs";
12
- import { t as inject } from "../_libs/@rollup/plugin-inject.mjs";
13
- import { a as baseBuildConfig, i as libChunkName, n as NODE_MODULES_RE, r as getChunkName, t as baseBuildPlugins } from "./shared4.mjs";
14
- import consola$1 from "consola";
15
- import { existsSync, watch } from "node:fs";
16
- import { mkdir, readFile, rm, writeFile } from "node:fs/promises";
17
- import { join, resolve } from "node:path";
18
- import { defu } from "defu";
19
- import { runtimeDependencies, runtimeDir } from "nitro/meta";
20
- import { colors } from "consola/utils";
21
- import { NodeRequest, sendNodeResponse } from "srvx/node";
22
- import { DevEnvironment } from "vite";
23
- import { spawn } from "node:child_process";
24
-
25
- //#region src/build/vite/rollup.ts
26
- const getViteRollupConfig = async (ctx) => {
27
- const nitro$1 = ctx.nitro;
28
- const base = baseBuildConfig(nitro$1);
29
- let config = {
30
- input: nitro$1.options.entry,
31
- external: [...base.env.external],
32
- plugins: [
33
- ...await baseBuildPlugins(nitro$1, base),
34
- alias({ entries: base.aliases }),
35
- !ctx._isRolldown && inject(base.env.inject)
36
- ].filter(Boolean),
37
- ...ctx._isRolldown ? { transform: { inject: base.env.inject } } : {},
38
- treeshake: { moduleSideEffects(id) {
39
- return nitro$1.options.moduleSideEffects.some((p) => id.startsWith(p));
40
- } },
41
- onwarn(warning, warn) {
42
- if (!base.ignoreWarningCodes.has(warning.code || "")) warn(warning);
43
- },
44
- output: {
45
- format: "esm",
46
- entryFileNames: "index.mjs",
47
- chunkFileNames: (chunk) => getChunkName(chunk, nitro$1),
48
- ...ctx._isRolldown ? { advancedChunks: { groups: [{
49
- test: NODE_MODULES_RE,
50
- name: (id) => libChunkName(id)
51
- }] } } : { manualChunks(id) {
52
- if (NODE_MODULES_RE.test(id)) return libChunkName(id);
53
- } },
54
- inlineDynamicImports: nitro$1.options.inlineDynamicImports,
55
- dir: nitro$1.options.output.serverDir,
56
- generatedCode: { ...ctx._isRolldown ? {} : { constBindings: true } },
57
- ...ctx._isRolldown ? {} : { sourcemapExcludeSources: true },
58
- sourcemapIgnoreList: (id) => id.includes("node_modules")
59
- }
60
- };
61
- config = defu(nitro$1.options.rollupConfig, config);
62
- return {
63
- config,
64
- base
65
- };
66
- };
67
-
68
- //#endregion
69
- //#region src/build/vite/prod.ts
70
- const BuilderNames = {
71
- nitro: colors.magenta("Nitro"),
72
- client: colors.green("Client"),
73
- ssr: colors.blue("SSR")
74
- };
75
- async function buildEnvironments(ctx, builder) {
76
- const nitro$1 = ctx.nitro;
77
- for (const [envName, env] of Object.entries(builder.environments)) {
78
- const fmtName = BuilderNames[envName] || (envName.length <= 3 ? envName.toUpperCase() : envName[0].toUpperCase() + envName.slice(1));
79
- if (envName === "nitro" || !env.config.build.rollupOptions.input || env.isBuilt) {
80
- if (![
81
- "nitro",
82
- "ssr",
83
- "client"
84
- ].includes(envName)) nitro$1.logger.info(env.isBuilt ? `Skipping ${fmtName} (already built)` : `Skipping ${fmtName} (no input defined)`);
85
- continue;
86
- }
87
- if (!a && !T) console.log();
88
- nitro$1.logger.start(`Building [${fmtName}]`);
89
- await builder.build(env);
90
- }
91
- const nitroOptions = ctx.nitro.options;
92
- const clientInput = builder.environments.client?.config?.build?.rollupOptions?.input;
93
- if (nitroOptions.renderer?.template && nitroOptions.renderer?.template === clientInput) {
94
- const outputPath = resolve$1(nitroOptions.output.publicDir, basename$1(clientInput));
95
- if (existsSync(outputPath)) {
96
- const html = await readFile(outputPath, "utf8").then((r) => r.replace("<!--ssr-outlet-->", `{{{ globalThis.__nitro_vite_envs__?.["ssr"]?.fetch($REQUEST) || "" }}}`));
97
- await rm(outputPath);
98
- const tmp = resolve$1(nitroOptions.buildDir, "vite/index.html");
99
- await mkdir(dirname$1(tmp), { recursive: true });
100
- await writeFile(tmp, html, "utf8");
101
- nitroOptions.renderer.template = tmp;
102
- }
103
- }
104
- await builder.writeAssetsManifest?.();
105
- if (!a && !T) console.log();
106
- const buildInfo = [["preset", nitro$1.options.preset], ["compatibility", formatCompatibilityDate(nitro$1.options.compatibilityDate)]].filter((e) => e[1]);
107
- nitro$1.logger.start(`Building [${BuilderNames.nitro}] ${colors.dim(`(${buildInfo.map(([k, v]) => `${k}: \`${v}\``).join(", ")})`)}`);
108
- await copyPublicAssets(nitro$1);
109
- const assetDirs = new Set(Object.values(builder.environments).filter((env) => env.config.consumer === "client").map((env) => env.config.build.assetsDir).filter(Boolean));
110
- for (const assetsDir of assetDirs) {
111
- if (!existsSync(resolve$1(nitro$1.options.output.publicDir, assetsDir))) continue;
112
- const rule = ctx.nitro.options.routeRules[`/${assetsDir}/**`] ??= {};
113
- if (!rule.headers?.["cache-control"]) rule.headers = {
114
- ...rule.headers,
115
- "cache-control": `public, max-age=31536000, immutable`
116
- };
117
- }
118
- ctx.nitro.routing.sync();
119
- await builder.build(builder.environments.nitro);
120
- await nitro$1.close();
121
- await nitro$1.hooks.callHook("compiled", nitro$1);
122
- await writeBuildInfo(nitro$1);
123
- const rOutput = relative$1(process.cwd(), nitro$1.options.output.dir);
124
- const rewriteRelativePaths = (input) => {
125
- return input.replace(/([\s:])\.\/(\S*)/g, `$1${rOutput}/$2`);
126
- };
127
- if (!a && !T) console.log();
128
- if (nitro$1.options.commands.preview) nitro$1.logger.success(`You can preview this build using \`${rewriteRelativePaths(nitro$1.options.commands.preview)}\``);
129
- if (nitro$1.options.commands.deploy) nitro$1.logger.success(`You can deploy this build using \`${rewriteRelativePaths(nitro$1.options.commands.deploy)}\``);
130
- }
131
- function prodSetup(ctx) {
132
- return `
133
- function lazyService(loader) {
134
- let promise, mod
135
- return {
136
- fetch(req) {
137
- if (mod) { return mod.fetch(req) }
138
- if (!promise) {
139
- promise = loader().then(_mod => (mod = _mod.default || _mod))
140
- }
141
- return promise.then(mod => mod.fetch(req))
142
- }
143
- }
144
- }
145
-
146
- const services = {
147
- ${Object.keys(ctx.services).map((name) => {
148
- return [name, resolve$1(ctx.nitro.options.buildDir, "vite/services", name, ctx._entryPoints[name])];
149
- }).map(([name, entry]) => `[${JSON.stringify(name)}]: lazyService(() => import(${JSON.stringify(entry)}))`).join(",\n")}
150
- };
151
-
152
- globalThis.__nitro_vite_envs__ = services;
153
- `;
154
- }
155
-
156
- //#endregion
157
- //#region src/build/vite/dev.ts
158
- function createFetchableDevEnvironment(name, config, devServer, entry) {
159
- return new FetchableDevEnvironment(name, config, {
160
- hot: true,
161
- transport: createTransport(name, devServer)
162
- }, devServer, entry);
163
- }
164
- var FetchableDevEnvironment = class extends DevEnvironment {
165
- devServer;
166
- constructor(name, config, context, devServer, entry) {
167
- super(name, config, context);
168
- this.devServer = devServer;
169
- this.devServer.sendMessage({
170
- type: "custom",
171
- event: "nitro:vite-env",
172
- data: {
173
- name,
174
- entry
175
- }
176
- });
177
- }
178
- async dispatchFetch(request) {
179
- return this.devServer.fetch(request);
180
- }
181
- async init(...args) {
182
- await this.devServer.init?.();
183
- return super.init(...args);
184
- }
185
- };
186
- function createTransport(name, hooks) {
187
- const listeners = /* @__PURE__ */ new WeakMap();
188
- return {
189
- send: (data) => hooks.sendMessage({
190
- ...data,
191
- viteEnv: name
192
- }),
193
- on: (event, handler) => {
194
- if (event === "connection") return;
195
- const listener = (value) => {
196
- if (value?.type === "custom" && value.event === event && value.viteEnv === name) handler(value.data, { send: (payload) => hooks.sendMessage({
197
- ...payload,
198
- viteEnv: name
199
- }) });
200
- };
201
- listeners.set(handler, listener);
202
- hooks.onMessage(listener);
203
- },
204
- off: (event, handler) => {
205
- if (event === "connection") return;
206
- const listener = listeners.get(handler);
207
- if (listener) {
208
- hooks.offMessage(listener);
209
- listeners.delete(handler);
210
- }
211
- }
212
- };
213
- }
214
- async function configureViteDevServer(ctx, server) {
215
- const nitro$1 = ctx.nitro;
216
- const nitroEnv$1 = server.environments.nitro;
217
- const nitroConfigFile = nitro$1.options._c12.configFile;
218
- if (nitroConfigFile) server.config.configFileDependencies.push(nitroConfigFile);
219
- if (nitro$1.options.features.websocket ?? nitro$1.options.experimental.websocket) server.httpServer.on("upgrade", (req, socket, head) => {
220
- if (req.url?.startsWith("/?token")) return;
221
- getEnvRunner(ctx).upgrade?.(req, socket, head);
222
- });
223
- const reload = debounce(async () => {
224
- await scanHandlers(nitro$1);
225
- nitro$1.routing.sync();
226
- nitroEnv$1.moduleGraph.invalidateAll();
227
- nitroEnv$1.hot.send({ type: "full-reload" });
228
- });
229
- const scanDirs = nitro$1.options.scanDirs.flatMap((dir) => [
230
- join$1(dir, nitro$1.options.apiDir || "api"),
231
- join$1(dir, nitro$1.options.routesDir || "routes"),
232
- join$1(dir, "middleware"),
233
- join$1(dir, "plugins"),
234
- join$1(dir, "modules")
235
- ]);
236
- const watchReloadEvents = new Set([
237
- "add",
238
- "addDir",
239
- "unlink",
240
- "unlinkDir"
241
- ]);
242
- const scanDirsWatcher = watch$1(scanDirs, { ignoreInitial: true }).on("all", (event, path$1, stat$2) => {
243
- if (watchReloadEvents.has(event)) reload();
244
- });
245
- const rootDirWatcher = watch(nitro$1.options.rootDir, { persistent: false }, (_event, filename) => {
246
- if (filename && /^server\.[mc]?[jt]sx?$/.test(filename)) reload();
247
- });
248
- nitro$1.hooks.hook("close", () => {
249
- scanDirsWatcher.close();
250
- rootDirWatcher.close();
251
- });
252
- const hostIPC = { async transformHTML(html) {
253
- return server.transformIndexHtml("/", html).then((r) => r.replace("<!--ssr-outlet-->", `{{{ globalThis.__nitro_vite_envs__?.["ssr"]?.fetch($REQUEST) || "" }}}`));
254
- } };
255
- nitroEnv$1.devServer.onMessage(async (payload) => {
256
- if (payload.type === "custom" && payload.event === "nitro:vite-invoke") {
257
- const res = await hostIPC[payload.data.name](payload.data.data).then((data) => ({ data })).catch((error) => ({ error }));
258
- nitroEnv$1.devServer.sendMessage({
259
- type: "custom",
260
- event: "nitro:vite-invoke-response",
261
- data: {
262
- id: payload.data.id,
263
- data: res
264
- }
265
- });
266
- }
267
- });
268
- const nitroDevMiddleware = async (nodeReq, nodeRes, next) => {
269
- if (!nodeReq.url || /^\/@(?:vite|fs|id)\//.test(nodeReq.url) || nodeReq._nitroHandled || server.middlewares.stack.map((mw) => mw.route).some((base) => base && nodeReq.url.startsWith(base))) return next();
270
- nodeReq._nitroHandled = true;
271
- try {
272
- const req = new NodeRequest({
273
- req: nodeReq,
274
- res: nodeRes
275
- });
276
- const devAppRes = await ctx.devApp.fetch(req);
277
- if (nodeRes.writableEnded || nodeRes.headersSent) return;
278
- if (devAppRes.status !== 404) return await sendNodeResponse(nodeRes, devAppRes);
279
- const envRes = await nitroEnv$1.dispatchFetch(req);
280
- if (nodeRes.writableEnded || nodeRes.headersSent) return;
281
- return await sendNodeResponse(nodeRes, envRes);
282
- } catch (error) {
283
- return next(error);
284
- }
285
- };
286
- server.middlewares.use(function nitroDevMiddlewarePre(req, res, next) {
287
- const fetchDest = req.headers["sec-fetch-dest"];
288
- res.setHeader("vary", "sec-fetch-dest");
289
- if ((!fetchDest || /^(document|iframe|frame|empty)$/.test(fetchDest)) && !req.url.match(/\.([a-z0-9]+)(?:[?#]|$)/i)?.[1] && !/^\/(?:__|@)/.test(req.url)) nitroDevMiddleware(req, res, next);
290
- else next();
291
- });
292
- return () => {
293
- server.middlewares.use(nitroDevMiddleware);
294
- };
295
- }
296
-
297
- //#endregion
298
- //#region src/build/vite/env.ts
299
- function getEnvRunner(ctx) {
300
- return ctx._envRunner ??= new NodeEnvRunner({
301
- name: "nitro-vite",
302
- entry: resolve(runtimeDir, "internal/vite/node-runner.mjs"),
303
- data: { server: true }
304
- });
305
- }
306
- function createNitroEnvironment(ctx) {
307
- return {
308
- consumer: "server",
309
- build: {
310
- rollupOptions: ctx.rollupConfig.config,
311
- minify: ctx.nitro.options.minify,
312
- emptyOutDir: false,
313
- sourcemap: ctx.nitro.options.sourcemap,
314
- commonjsOptions: ctx.nitro.options.commonJS
315
- },
316
- resolve: {
317
- noExternal: ctx.nitro.options.dev ? [
318
- /^nitro$/,
319
- /* @__PURE__ */ new RegExp(`^(${runtimeDependencies.join("|")})$`),
320
- ...ctx.rollupConfig.base.noExternal
321
- ] : true,
322
- conditions: ctx.nitro.options.exportConditions,
323
- externalConditions: ctx.nitro.options.exportConditions?.filter((c) => !/browser|wasm|module/.test(c))
324
- },
325
- define: { "process.env.NODE_ENV": JSON.stringify(ctx.nitro.options.dev ? "development" : "production") },
326
- dev: { createEnvironment: (envName, envConfig) => createFetchableDevEnvironment(envName, envConfig, getEnvRunner(ctx), resolve(runtimeDir, "internal/vite/dev-entry.mjs")) }
327
- };
328
- }
329
- function createServiceEnvironment(ctx, name, serviceConfig) {
330
- return {
331
- consumer: "server",
332
- build: {
333
- rollupOptions: { input: { index: serviceConfig.entry } },
334
- minify: ctx.nitro.options.minify,
335
- sourcemap: ctx.nitro.options.sourcemap,
336
- outDir: join(ctx.nitro.options.buildDir, "vite/services", name),
337
- emptyOutDir: true
338
- },
339
- resolve: {
340
- conditions: ctx.nitro.options.exportConditions,
341
- externalConditions: ctx.nitro.options.exportConditions?.filter((c) => !/browser|wasm|module/.test(c))
342
- },
343
- dev: { createEnvironment: (envName, envConfig) => createFetchableDevEnvironment(envName, envConfig, getEnvRunner(ctx), tryResolve(serviceConfig.entry)) }
344
- };
345
- }
346
- function createServiceEnvironments(ctx) {
347
- return Object.fromEntries(Object.entries(ctx.services).map(([name, config]) => [name, createServiceEnvironment(ctx, name, config)]));
348
- }
349
- function tryResolve(id) {
350
- if (/^[~#/\0]/.test(id) || isAbsolute$1(id)) return id;
351
- return resolveModulePath(id, {
352
- suffixes: ["", "/index"],
353
- extensions: [
354
- "",
355
- ".ts",
356
- ".mjs",
357
- ".cjs",
358
- ".js",
359
- ".mts",
360
- ".cts"
361
- ],
362
- try: true
363
- }) || id;
364
- }
365
-
366
- //#endregion
367
- //#region src/build/vite/preview.ts
368
- function nitroPreviewPlugin(ctx) {
369
- return {
370
- name: "nitro:preview",
371
- apply: (_config, configEnv) => !!configEnv.isPreview,
372
- config(config) {
373
- return { preview: { port: config.preview?.port || 3e3 } };
374
- },
375
- async configurePreviewServer(server) {
376
- const { outputDir, buildInfo } = await getBuildInfo(server.config.root);
377
- if (!buildInfo) throw this.error("Cannot load nitro build info. Make sure to build first.");
378
- const info = [
379
- ["Build Directory:", prettyPath(outputDir)],
380
- ["Date:", buildInfo.date && new Date(buildInfo.date).toLocaleString()],
381
- ["Nitro Version:", buildInfo.versions.nitro],
382
- ["Nitro Preset:", buildInfo.preset],
383
- buildInfo.framework?.name !== "nitro" && ["Framework:", buildInfo.framework?.name + (buildInfo.framework?.version ? ` (v${buildInfo.framework.version})` : "")]
384
- ].filter((i) => i && i[1]);
385
- consola$1.box({
386
- title: " [Build Info] ",
387
- message: info.map((i) => `- ${i[0]} ${i[1]}`).join("\n")
388
- });
389
- if (!buildInfo.commands?.preview) {
390
- consola$1.warn("No nitro build preview command found for this preset.");
391
- return;
392
- }
393
- const dotEnvEntries = await loadPreviewDotEnv(server.config.root);
394
- if (dotEnvEntries.length > 0) consola$1.box({
395
- title: " [Environment Variables] ",
396
- message: [
397
- "Loaded variables from .env files (preview mode only).",
398
- "Set platform environment variables for production:",
399
- ...dotEnvEntries.map(([key, val]) => ` - ${key}`)
400
- ].join("\n")
401
- });
402
- const [command, ...args] = buildInfo.commands.preview.split(" ");
403
- consola$1.info(`Spawning preview server...`);
404
- consola$1.info(buildInfo.commands?.preview);
405
- console.log("");
406
- const { getRandomPort, waitForPort } = await import("get-port-please");
407
- const randomPort = await getRandomPort();
408
- const child = spawn(command, args, {
409
- stdio: "inherit",
410
- cwd: outputDir,
411
- env: {
412
- ...process.env,
413
- ...Object.fromEntries(dotEnvEntries),
414
- PORT: String(randomPort)
415
- }
416
- });
417
- const killChild = (signal) => {
418
- if (child && !child.killed) child.kill(signal);
419
- };
420
- for (const sig of ["SIGINT", "SIGHUP"]) process.once(sig, () => {
421
- consola$1.info(`Stopping preview server...`);
422
- killChild(sig);
423
- process.exit();
424
- });
425
- server.httpServer.once("close", () => {
426
- killChild("SIGTERM");
427
- });
428
- child.once("exit", (code) => {
429
- if (code && code !== 0) consola$1.error(`[nitro] Preview server exited with code ${code}`);
430
- });
431
- const { createProxyServer } = await import("../_libs/httpxy.mjs").then((n) => n.r);
432
- const proxy = createProxyServer({ target: `http://localhost:${randomPort}` });
433
- server.middlewares.use((req, res, next) => {
434
- if (child && !child.killed) proxy.web(req, res).catch(next);
435
- else res.end(`Nitro preview server is not running.`);
436
- });
437
- await waitForPort(randomPort, {
438
- retries: 20,
439
- delay: 500
440
- });
441
- }
442
- };
443
- }
444
- async function loadPreviewDotEnv(root) {
445
- const { loadDotenv } = await import("../_libs/c12.mjs").then((n) => n.n);
446
- const env = await loadDotenv({
447
- cwd: root,
448
- fileName: [
449
- ".env.preview",
450
- ".env.production",
451
- ".env"
452
- ]
453
- });
454
- return Object.entries(env).filter(([_key, val]) => val);
455
- }
456
-
457
- //#endregion
458
- //#region src/build/vite/plugin.ts
459
- const DEFAULT_EXTENSIONS = [
460
- ".ts",
461
- ".js",
462
- ".mts",
463
- ".mjs",
464
- ".tsx",
465
- ".jsx"
466
- ];
467
- const debug = process.env.NITRO_DEBUG ? (...args) => console.log("[nitro]", ...args) : () => {};
468
- function nitro(pluginConfig = {}) {
469
- const ctx = createContext(pluginConfig);
470
- return [
471
- nitroInit(ctx),
472
- nitroEnv(ctx),
473
- nitroMain(ctx),
474
- nitroPrepare(ctx),
475
- nitroService(ctx),
476
- nitroPreviewPlugin(ctx),
477
- pluginConfig.experimental?.vite?.assetsImport !== false && assetsPlugin({ experimental: { clientBuildFallback: false } })
478
- ].filter(Boolean);
479
- }
480
- function nitroInit(ctx) {
481
- return {
482
- name: "nitro:init",
483
- sharedDuringBuild: true,
484
- apply: (_config, configEnv) => !configEnv.isPreview,
485
- async config(config, configEnv) {
486
- ctx._isRolldown = !!this.meta.rolldownVersion;
487
- if (!ctx._initialized) {
488
- debug("[init] Initializing nitro");
489
- ctx._initialized = true;
490
- await setupNitroContext(ctx, configEnv, config);
491
- }
492
- },
493
- applyToEnvironment(env) {
494
- if (env.name === "nitro" && ctx.nitro?.options.dev) {
495
- debug("[init] Adding rollup plugins for dev");
496
- return [...ctx.rollupConfig?.config.plugins || []];
497
- }
498
- }
499
- };
500
- }
501
- function nitroEnv(ctx) {
502
- return {
503
- name: "nitro:env",
504
- sharedDuringBuild: true,
505
- apply: (_config, configEnv) => !configEnv.isPreview,
506
- async config(userConfig, _configEnv) {
507
- debug("[env] Extending config (environments)");
508
- const environments = {
509
- ...createServiceEnvironments(ctx),
510
- nitro: createNitroEnvironment(ctx)
511
- };
512
- environments.client = {
513
- consumer: userConfig.environments?.client?.consumer ?? "client",
514
- build: { rollupOptions: { input: userConfig.environments?.client?.build?.rollupOptions?.input ?? useNitro(ctx).options.renderer?.template } }
515
- };
516
- debug("[env] Environments:", Object.keys(environments).join(", "));
517
- return { environments };
518
- },
519
- configEnvironment(name, config) {
520
- if (config.consumer === "client") {
521
- debug("[env] Configuring client environment", name === "client" ? "" : ` (${name})`);
522
- config.build.emptyOutDir = false;
523
- config.build.outDir = useNitro(ctx).options.output.publicDir;
524
- }
525
- }
526
- };
527
- }
528
- function nitroMain(ctx) {
529
- return {
530
- name: "nitro:main",
531
- sharedDuringBuild: true,
532
- apply: (_config, configEnv) => !configEnv.isPreview,
533
- async config(userConfig, _configEnv) {
534
- debug("[main] Extending config (appType, resolve, server)");
535
- if (!ctx.rollupConfig) throw new Error("Nitro rollup config is not initialized yet.");
536
- return {
537
- appType: userConfig.appType || "custom",
538
- resolve: { alias: ctx.rollupConfig.base.aliases },
539
- builder: { sharedConfigBuild: true },
540
- server: {
541
- port: Number.parseInt(process.env.PORT || "") || userConfig.server?.port || useNitro(ctx).options.devServer?.port || 3e3,
542
- cors: false
543
- }
544
- };
545
- },
546
- buildApp: {
547
- order: "post",
548
- handler(builder) {
549
- debug("[main] Building environments");
550
- return buildEnvironments(ctx, builder);
551
- }
552
- },
553
- generateBundle: { handler(_options, bundle) {
554
- const environment = this.environment;
555
- debug("[main] Generating manifest and entry points for environment:", environment.name);
556
- const isRegisteredService = Object.keys(ctx.services).includes(environment.name);
557
- let entryFile;
558
- for (const [_name, file] of Object.entries(bundle)) if (file.type === "chunk" && isRegisteredService && file.isEntry) if (entryFile === void 0) entryFile = file.fileName;
559
- else this.warn(`Multiple entry points found for service "${environment.name}"`);
560
- if (isRegisteredService) {
561
- if (entryFile === void 0) this.error(`No entry point found for service "${this.environment.name}".`);
562
- ctx._entryPoints[this.environment.name] = entryFile;
563
- }
564
- } },
565
- configureServer: (server) => {
566
- debug("[main] Configuring dev server");
567
- return configureViteDevServer(ctx, server);
568
- },
569
- async hotUpdate({ server, modules, timestamp }) {
570
- const env = this.environment;
571
- if (ctx.pluginConfig.experimental?.vite.serverReload === false || env.config.consumer === "client") return;
572
- const clientEnvs = Object.values(server.environments).filter((env$1) => env$1.config.consumer === "client");
573
- let hasServerOnlyModule = false;
574
- const invalidated = /* @__PURE__ */ new Set();
575
- for (const mod of modules) if (mod.id && !clientEnvs.some((env$1) => env$1.moduleGraph.getModuleById(mod.id))) {
576
- hasServerOnlyModule = true;
577
- env.moduleGraph.invalidateModule(mod, invalidated, timestamp, false);
578
- }
579
- if (hasServerOnlyModule) {
580
- env.hot.send({ type: "full-reload" });
581
- server.ws.send({ type: "full-reload" });
582
- return [];
583
- }
584
- }
585
- };
586
- }
587
- function nitroPrepare(ctx) {
588
- return {
589
- name: "nitro:prepare",
590
- sharedDuringBuild: true,
591
- applyToEnvironment: (env) => env.name === "nitro",
592
- buildApp: {
593
- order: "pre",
594
- async handler() {
595
- debug("[prepare] Preparing output directory");
596
- const nitro$1 = ctx.nitro;
597
- await prepare(nitro$1);
598
- }
599
- }
600
- };
601
- }
602
- function nitroService(ctx) {
603
- return {
604
- name: "nitro:service",
605
- enforce: "pre",
606
- sharedDuringBuild: true,
607
- applyToEnvironment: (env) => env.name === "nitro",
608
- resolveId: {
609
- filter: { id: /^#nitro-vite-setup$/ },
610
- async handler(id) {
611
- if (id === "#nitro-vite-setup") return {
612
- id,
613
- moduleSideEffects: true
614
- };
615
- }
616
- },
617
- load: {
618
- filter: { id: /^#nitro-vite-setup$/ },
619
- async handler(id) {
620
- if (id === "#nitro-vite-setup") return prodSetup(ctx);
621
- }
622
- }
623
- };
624
- }
625
- function createContext(pluginConfig) {
626
- return {
627
- pluginConfig,
628
- services: { ...pluginConfig.experimental?.vite?.services },
629
- _entryPoints: {}
630
- };
631
- }
632
- function useNitro(ctx) {
633
- if (!ctx.nitro) throw new Error("Nitro instance is not initialized yet.");
634
- return ctx.nitro;
635
- }
636
- async function setupNitroContext(ctx, configEnv, userConfig) {
637
- const nitroConfig = {
638
- dev: configEnv.command === "serve",
639
- builder: "vite",
640
- rootDir: userConfig.root,
641
- ...defu(ctx.pluginConfig, ctx.pluginConfig.config, userConfig.nitro)
642
- };
643
- nitroConfig.modules ??= [];
644
- for (const plugin of flattenPlugins(userConfig.plugins || [])) if (plugin.nitro) nitroConfig.modules.push(plugin.nitro);
645
- ctx.nitro = ctx.pluginConfig._nitro || await createNitro(nitroConfig);
646
- if (!ctx.services?.ssr) if (userConfig.environments?.ssr === void 0) {
647
- const ssrEntry = resolveModulePath("./entry-server", {
648
- from: [
649
- "app",
650
- "src",
651
- ""
652
- ].flatMap((d) => [ctx.nitro.options.rootDir, ...ctx.nitro.options.scanDirs].map((s) => join$1(s, d) + "/")),
653
- extensions: DEFAULT_EXTENSIONS,
654
- try: true
655
- });
656
- if (ssrEntry) {
657
- ctx.services.ssr = { entry: ssrEntry };
658
- ctx.nitro.logger.info(`Using \`${prettyPath(ssrEntry)}\` as vite ssr entry.`);
659
- }
660
- } else {
661
- let ssrEntry = getEntry(userConfig.environments.ssr.build?.rollupOptions?.input);
662
- if (typeof ssrEntry === "string") {
663
- ssrEntry = resolveModulePath(ssrEntry, {
664
- from: [ctx.nitro.options.rootDir, ...ctx.nitro.options.scanDirs],
665
- extensions: DEFAULT_EXTENSIONS,
666
- suffixes: ["", "/index"],
667
- try: true
668
- }) || ssrEntry;
669
- ctx.services.ssr = { entry: ssrEntry };
670
- }
671
- }
672
- if (ctx.nitro.options.serverEntry && ctx.nitro.options.serverEntry.handler === ctx.services.ssr?.entry) {
673
- ctx.nitro.logger.warn(`Nitro server entry and Vite SSR both set to ${prettyPath(ctx.services.ssr.entry)}. Use a separate SSR entry (e.g. \`src/server.ts\`).`);
674
- ctx.nitro.options.serverEntry = false;
675
- }
676
- if (!ctx.nitro.options.renderer?.handler && !ctx.nitro.options.renderer?.template && ctx.services.ssr?.entry) {
677
- ctx.nitro.options.renderer ??= {};
678
- ctx.nitro.options.renderer.handler = resolve$1(runtimeDir, "internal/vite/ssr-renderer");
679
- ctx.nitro.routing.sync();
680
- }
681
- const publicDistDir = ctx._publicDistDir = userConfig.build?.outDir || resolve$1(ctx.nitro.options.buildDir, "vite/public");
682
- ctx.nitro.options.publicAssets.push({
683
- dir: publicDistDir,
684
- maxAge: 0,
685
- baseURL: "/",
686
- fallthrough: true
687
- });
688
- if (!ctx.nitro.options.dev) ctx.nitro.options.unenv.push({
689
- meta: { name: "nitro-vite" },
690
- polyfill: ["#nitro-vite-setup"]
691
- });
692
- await ctx.nitro.hooks.callHook("build:before", ctx.nitro);
693
- ctx.rollupConfig = await getViteRollupConfig(ctx);
694
- await ctx.nitro.hooks.callHook("rollup:before", ctx.nitro, ctx.rollupConfig.config);
695
- if (ctx.nitro.options.dev) getEnvRunner(ctx);
696
- ctx.nitro.fetch = (req) => getEnvRunner(ctx).fetch(req);
697
- if (ctx.nitro.options.dev && !ctx.devApp) ctx.devApp = new NitroDevApp(ctx.nitro);
698
- ctx.nitro.hooks.hook("close", async () => {
699
- if (ctx._envRunner) await ctx._envRunner.close();
700
- });
701
- }
702
- function getEntry(input) {
703
- if (typeof input === "string") return input;
704
- else if (Array.isArray(input) && input.length > 0) return input[0];
705
- else if (input && "index" in input) return input.index;
706
- }
707
- function flattenPlugins(plugins) {
708
- return plugins.flatMap((plugin) => Array.isArray(plugin) ? flattenPlugins(plugin) : [plugin]).filter((p) => p && !(p instanceof Promise));
709
- }
710
-
711
- //#endregion
712
- export { nitro as t };