nitro-nightly 4.0.0-20251010-091516-7cafddba → 4.0.0-20251030-091344-d4418b98

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 (195) hide show
  1. package/dist/{_chunks/build2.mjs → _build/build.mjs} +108 -58
  2. package/dist/_build/build2.mjs +556 -0
  3. package/dist/_build/info.mjs +1002 -0
  4. package/dist/_build/prepare.mjs +1511 -0
  5. package/dist/_build/snapshot.mjs +185 -0
  6. package/dist/{_chunks/plugin.mjs → _build/vite.mjs} +295 -296
  7. package/dist/_build/vite2.mjs +149 -0
  8. package/dist/_chunks/_deps/@jridgewell/gen-mapping.mjs +189 -0
  9. package/dist/_chunks/_deps/@jridgewell/remapping.mjs +137 -0
  10. package/dist/_chunks/_deps/@jridgewell/resolve-uri.mjs +231 -0
  11. package/dist/_chunks/_deps/@jridgewell/sourcemap-codec.mjs +173 -0
  12. package/dist/_chunks/_deps/@jridgewell/trace-mapping.mjs +170 -0
  13. package/dist/_chunks/_deps/@pi0/vite-plugin-fullstack.mjs +575 -0
  14. package/dist/_chunks/_deps/@rollup/plugin-alias.mjs +89 -0
  15. package/dist/_chunks/_deps/@rollup/plugin-commonjs.mjs +2376 -0
  16. package/dist/_chunks/{index2.mjs → _deps/@rollup/plugin-inject.mjs} +5 -90
  17. package/dist/_chunks/_deps/@rollup/plugin-json.mjs +37 -0
  18. package/dist/_chunks/_deps/@rollup/plugin-node-resolve.mjs +1386 -0
  19. package/dist/_chunks/_deps/@rollup/plugin-replace.mjs +133 -0
  20. package/dist/_chunks/_deps/@rollup/pluginutils.mjs +346 -0
  21. package/dist/_chunks/_deps/acorn.mjs +6225 -0
  22. package/dist/_chunks/_deps/c12.mjs +510 -0
  23. package/dist/_chunks/_deps/chokidar.mjs +1428 -0
  24. package/dist/_chunks/_deps/citty.mjs +460 -0
  25. package/dist/_chunks/_deps/commondir.mjs +77 -0
  26. package/dist/_chunks/_deps/compatx.mjs +76 -0
  27. package/dist/_chunks/_deps/confbox.mjs +300 -0
  28. package/dist/_chunks/_deps/debug.mjs +885 -0
  29. package/dist/_chunks/_deps/deepmerge.mjs +147 -0
  30. package/dist/_chunks/_deps/depd.mjs +550 -0
  31. package/dist/_chunks/_deps/dot-prop.mjs +282 -0
  32. package/dist/_chunks/_deps/dotenv.mjs +555 -0
  33. package/dist/_chunks/_deps/duplexer.mjs +1 -0
  34. package/dist/_chunks/_deps/ee-first.mjs +104 -0
  35. package/dist/_chunks/_deps/encodeurl.mjs +69 -0
  36. package/dist/_chunks/_deps/escape-html.mjs +87 -0
  37. package/dist/_chunks/_deps/escape-string-regexp.mjs +13 -0
  38. package/dist/_chunks/_deps/estree-walker.mjs +433 -0
  39. package/dist/_chunks/_deps/etag.mjs +147 -0
  40. package/dist/_chunks/_deps/exsolve.mjs +1416 -0
  41. package/dist/_chunks/_deps/fdir.mjs +569 -0
  42. package/dist/_chunks/_deps/fresh.mjs +145 -0
  43. package/dist/_chunks/_deps/function-bind.mjs +106 -0
  44. package/dist/_chunks/{index4.mjs → _deps/giget.mjs} +21 -776
  45. package/dist/_chunks/_deps/gzip-size.mjs +19 -0
  46. package/dist/_chunks/_deps/hasown.mjs +19 -0
  47. package/dist/_chunks/_deps/http-errors.mjs +307 -0
  48. package/dist/_chunks/_deps/httpxy.mjs +580 -0
  49. package/dist/_chunks/_deps/inherits.mjs +57 -0
  50. package/dist/_chunks/_deps/is-core-module.mjs +596 -0
  51. package/dist/_chunks/_deps/is-module.mjs +25 -0
  52. package/dist/_chunks/_deps/is-reference.mjs +31 -0
  53. package/dist/_chunks/_deps/js-tokens.mjs +411 -0
  54. package/dist/_chunks/_deps/klona.mjs +137 -0
  55. package/dist/_chunks/_deps/knitwork.mjs +172 -0
  56. package/dist/_chunks/_deps/local-pkg.mjs +163 -0
  57. package/dist/_chunks/_deps/magic-string.mjs +1296 -0
  58. package/dist/_chunks/_deps/mime-db.mjs +11685 -0
  59. package/dist/_chunks/_deps/mime-types.mjs +287 -0
  60. package/dist/_chunks/_deps/mime.mjs +1172 -0
  61. package/dist/_chunks/_deps/mlly.mjs +2413 -0
  62. package/dist/_chunks/_deps/ms.mjs +172 -0
  63. package/dist/_chunks/_deps/node-fetch-native.mjs +3 -0
  64. package/dist/_chunks/_deps/nypm.mjs +219 -0
  65. package/dist/_chunks/_deps/on-finished.mjs +246 -0
  66. package/dist/_chunks/_deps/parseurl.mjs +168 -0
  67. package/dist/_chunks/_deps/path-parse.mjs +85 -0
  68. package/dist/_chunks/{pathe.M-eThtNZ.mjs → _deps/pathe.mjs} +48 -1
  69. package/dist/_chunks/_deps/perfect-debounce.mjs +88 -0
  70. package/dist/_chunks/_deps/picomatch.mjs +2144 -0
  71. package/dist/_chunks/_deps/pkg-types.mjs +247 -0
  72. package/dist/_chunks/{snapshot.mjs → _deps/pretty-bytes.mjs} +1 -105
  73. package/dist/_chunks/_deps/quansync.mjs +99 -0
  74. package/dist/_chunks/_deps/range-parser.mjs +171 -0
  75. package/dist/_chunks/_deps/rc9.mjs +219 -0
  76. package/dist/_chunks/_deps/readdirp.mjs +245 -0
  77. package/dist/_chunks/_deps/resolve.mjs +1260 -0
  78. package/dist/_chunks/_deps/rou3.mjs +326 -0
  79. package/dist/_chunks/_deps/send.mjs +1022 -0
  80. package/dist/_chunks/_deps/serve-static.mjs +228 -0
  81. package/dist/_chunks/_deps/setprototypeof.mjs +26 -0
  82. package/dist/_chunks/_deps/statuses.mjs +457 -0
  83. package/dist/_chunks/_deps/std-env.mjs +3 -0
  84. package/dist/_chunks/_deps/strip-literal.mjs +67 -0
  85. package/dist/_chunks/_deps/supports-color.mjs +44 -0
  86. package/dist/_chunks/_deps/tinyexec.mjs +552 -0
  87. package/dist/_chunks/_deps/tinyglobby.mjs +293 -0
  88. package/dist/_chunks/_deps/toidentifier.mjs +41 -0
  89. package/dist/_chunks/_deps/ultrahtml.mjs +3 -0
  90. package/dist/_chunks/_deps/unimport.mjs +2267 -0
  91. package/dist/_chunks/_deps/unplugin-utils.mjs +65 -0
  92. package/dist/_chunks/_deps/unplugin.mjs +1294 -0
  93. package/dist/_chunks/_deps/untyped.mjs +375 -0
  94. package/dist/_chunks/{info.mjs → _deps/unwasm.mjs} +8 -4206
  95. package/dist/_chunks/_deps/webpack-virtual-modules.mjs +360 -0
  96. package/dist/_chunks/_presets/_all.mjs +59 -0
  97. package/dist/_chunks/_presets/_nitro.mjs +74 -0
  98. package/dist/_chunks/_presets/_resolve.mjs +64 -0
  99. package/dist/_chunks/_presets/_static.mjs +69 -0
  100. package/dist/_chunks/_presets/_types.mjs +3 -0
  101. package/dist/_chunks/_presets/_utils.mjs +31 -0
  102. package/dist/_chunks/_presets/alwaysdata.mjs +17 -0
  103. package/dist/_chunks/_presets/aws-amplify.mjs +111 -0
  104. package/dist/_chunks/_presets/aws-lambda.mjs +23 -0
  105. package/dist/_chunks/_presets/azure.mjs +162 -0
  106. package/dist/_chunks/_presets/bun.mjs +19 -0
  107. package/dist/_chunks/_presets/cleavr.mjs +15 -0
  108. package/dist/_chunks/_presets/cloudflare.mjs +608 -0
  109. package/dist/_chunks/_presets/deno.mjs +196 -0
  110. package/dist/_chunks/_presets/digitalocean.mjs +14 -0
  111. package/dist/_chunks/_presets/firebase.mjs +47 -0
  112. package/dist/_chunks/_presets/flightcontrol.mjs +14 -0
  113. package/dist/_chunks/_presets/genezio.mjs +13 -0
  114. package/dist/_chunks/_presets/heroku.mjs +14 -0
  115. package/dist/_chunks/_presets/iis.mjs +194 -0
  116. package/dist/_chunks/_presets/index.mjs +62 -0
  117. package/dist/_chunks/_presets/koyeb.mjs +14 -0
  118. package/dist/_chunks/_presets/netlify.mjs +241 -0
  119. package/dist/_chunks/_presets/node.mjs +54 -0
  120. package/dist/_chunks/_presets/platform.mjs +14 -0
  121. package/dist/_chunks/_presets/render.mjs +14 -0
  122. package/dist/_chunks/_presets/standard.mjs +23 -0
  123. package/dist/_chunks/_presets/stormkit.mjs +18 -0
  124. package/dist/_chunks/_presets/vercel.mjs +375 -0
  125. package/dist/_chunks/_presets/winterjs.mjs +22 -0
  126. package/dist/_chunks/_presets/zeabur.mjs +69 -0
  127. package/dist/_chunks/_presets/zerops.mjs +27 -0
  128. package/dist/_chunks/app.mjs +9 -19206
  129. package/dist/_chunks/{index3.mjs → builder.mjs} +560 -970
  130. package/dist/_chunks/server.mjs +6 -4
  131. package/dist/{cli → _cli}/build.mjs +3 -8
  132. package/dist/{cli → _cli}/dev.mjs +38 -12
  133. package/dist/{cli/index2.mjs → _cli/index.mjs} +1 -2
  134. package/dist/{cli → _cli}/list.mjs +3 -4
  135. package/dist/{cli → _cli}/prepare.mjs +3 -4
  136. package/dist/{cli → _cli}/run.mjs +3 -4
  137. package/dist/{index.d.mts → builder.d.mts} +11 -11
  138. package/dist/builder.mjs +117 -0
  139. package/dist/cli/index.mjs +7 -464
  140. package/dist/node_modules/@speed-highlight/core/dist/index.js +1 -1
  141. package/dist/node_modules/@speed-highlight/core/dist/terminal.js +1 -1
  142. package/dist/node_modules/@speed-highlight/core/package.json +7 -3
  143. package/dist/node_modules/cookie-es/dist/index.mjs +262 -0
  144. package/dist/node_modules/cookie-es/package.json +37 -0
  145. package/dist/node_modules/hookable/dist/index.mjs +243 -266
  146. package/dist/node_modules/hookable/package.json +29 -26
  147. package/dist/node_modules/rendu/dist/index.mjs +380 -0
  148. package/dist/node_modules/rendu/package.json +47 -0
  149. package/dist/presets/_nitro/runtime/nitro-dev.mjs +4 -7
  150. package/dist/presets/_nitro/runtime/nitro-prerenderer.mjs +5 -4
  151. package/dist/presets/azure/runtime/azure-swa.mjs +1 -1
  152. package/dist/presets/cloudflare/runtime/_module-handler.mjs +7 -6
  153. package/dist/presets/cloudflare/runtime/cloudflare-durable.mjs +4 -5
  154. package/dist/presets/cloudflare/runtime/plugin.dev.mjs +7 -10
  155. package/dist/presets/cloudflare/runtime/shims/workers.dev.d.mts +21 -0
  156. package/dist/presets/cloudflare/runtime/shims/workers.dev.mjs +27 -0
  157. package/dist/presets/node/runtime/node-server.mjs +1 -1
  158. package/dist/runtime/index.d.mts +1 -1
  159. package/dist/runtime/index.mjs +1 -1
  160. package/dist/runtime/internal/app.d.mts +3 -1
  161. package/dist/runtime/internal/app.mjs +90 -64
  162. package/dist/runtime/internal/error/prod.d.mts +3 -2
  163. package/dist/runtime/internal/error/prod.mjs +9 -13
  164. package/dist/runtime/internal/renderer.mjs +4 -4
  165. package/dist/runtime/internal/routes/dev-tasks.d.mts +30 -2
  166. package/dist/runtime/internal/shutdown.d.mts +1 -2
  167. package/dist/runtime/internal/shutdown.mjs +3 -2
  168. package/dist/runtime/internal/task.mjs +1 -2
  169. package/dist/types/index.d.mts +1603 -10
  170. package/dist/vite.d.mts +5 -0
  171. package/dist/vite.mjs +94 -30
  172. package/lib/index.mjs +1 -0
  173. package/lib/indexd.mts +1 -0
  174. package/lib/runtime/meta.mjs +35 -0
  175. package/package.json +40 -41
  176. package/dist/_chunks/build.mjs +0 -84
  177. package/dist/_chunks/build3.mjs +0 -6452
  178. package/dist/_chunks/detect-acorn.mjs +0 -503
  179. package/dist/_chunks/index.mjs +0 -22242
  180. package/dist/_chunks/json5.mjs +0 -68
  181. package/dist/_chunks/jsonc.mjs +0 -51
  182. package/dist/_chunks/toml.mjs +0 -259
  183. package/dist/_chunks/yaml.mjs +0 -86
  184. package/dist/index.mjs +0 -55
  185. package/dist/node_modules/klona/dist/index.mjs +0 -81
  186. package/dist/node_modules/klona/full/index.mjs +0 -53
  187. package/dist/node_modules/klona/package.json +0 -74
  188. package/dist/node_modules/std-env/dist/index.mjs +0 -1
  189. package/dist/node_modules/std-env/package.json +0 -46
  190. package/dist/presets.mjs +0 -2460
  191. package/dist/runtime/internal/debug.d.mts +0 -2
  192. package/dist/runtime/internal/debug.mjs +0 -5
  193. package/lib/runtime-meta.mjs +0 -38
  194. /package/dist/{cli → _cli}/common.mjs +0 -0
  195. /package/lib/{runtime-meta.d.mts → runtime/meta.d.mts} +0 -0
@@ -0,0 +1,1002 @@
1
+ import { r as replace$1 } from '../_chunks/_deps/@rollup/plugin-replace.mjs';
2
+ import { defineEnv } from 'unenv';
3
+ import { runtimeDir, runtimeDependencies } from 'nitro/runtime/meta';
4
+ import { j as join, r as resolve, d as dirname, e as extname, a as relative } from '../_chunks/_deps/pathe.mjs';
5
+ import { hash } from 'ohash';
6
+ import { defu } from 'defu';
7
+ import { u as unplugin } from '../_chunks/_deps/unimport.mjs';
8
+ import { r as rollup } from '../_chunks/_deps/unwasm.mjs';
9
+ import { connectors } from 'db0';
10
+ import { camelCase } from 'scule';
11
+ import { readFile, mkdir, unlink, symlink } from 'node:fs/promises';
12
+ import { transform } from 'esbuild';
13
+ import { promises } from 'node:fs';
14
+ import { c as createEtag } from '../_chunks/_deps/etag.mjs';
15
+ import { g as glob } from '../_chunks/_deps/tinyglobby.mjs';
16
+ import { m as mime } from '../_chunks/_deps/mime.mjs';
17
+ import { withTrailingSlash } from 'ufo';
18
+ import { normalizeKey, builtinDrivers } from 'unstorage';
19
+ import { b as genImport, a as genSafeVariableName } from '../_chunks/_deps/knitwork.mjs';
20
+ import { rollupNodeFileTrace } from 'nf3';
21
+ import { hasTemplateSyntax, compileTemplateToString, RENDER_CONTEXT_KEYS } from 'rendu';
22
+ import { version } from 'nitro/meta';
23
+ import { p as presetsWithConfig } from '../_chunks/_presets/_types.mjs';
24
+ import { w as writeFile } from './prepare.mjs';
25
+ import { dirname as dirname$1 } from 'node:path';
26
+
27
+ const NO_REPLACE_RE = /ROLLUP_NO_REPLACE|\\0raw:/;
28
+ function replace(options) {
29
+ const _plugin = replace$1(options);
30
+ return {
31
+ ..._plugin,
32
+ // https://github.com/rollup/plugins/blob/master/packages/replace/src/index.js#L94
33
+ renderChunk(code, chunk, options2) {
34
+ if (!NO_REPLACE_RE.test(code)) {
35
+ return _plugin.renderChunk.call(this, code, chunk, options2);
36
+ }
37
+ }
38
+ };
39
+ }
40
+
41
+ function baseBuildConfig(nitro) {
42
+ const buildServerDir = join(nitro.options.buildDir, "dist/server");
43
+ const presetsDir = resolve(runtimeDir, "../presets");
44
+ const extensions = [".ts", ".mjs", ".js", ".json", ".node", ".tsx", ".jsx"];
45
+ const isNodeless = nitro.options.node === false;
46
+ let NODE_ENV = nitro.options.dev ? "development" : "production";
47
+ if (nitro.options.preset === "nitro-prerender") {
48
+ NODE_ENV = "prerender";
49
+ }
50
+ const buildEnvVars = {
51
+ NODE_ENV,
52
+ prerender: nitro.options.preset === "nitro-prerender",
53
+ server: true,
54
+ client: false,
55
+ dev: String(nitro.options.dev),
56
+ DEBUG: nitro.options.dev
57
+ };
58
+ const staticFlags = {
59
+ dev: nitro.options.dev,
60
+ preset: nitro.options.preset,
61
+ prerender: nitro.options.preset === "nitro-prerender",
62
+ server: true,
63
+ client: false,
64
+ nitro: true,
65
+ baseURL: nitro.options.baseURL,
66
+ // @ts-expect-error
67
+ "versions.nitro": "",
68
+ "versions?.nitro": "",
69
+ // Internal
70
+ _asyncContext: nitro.options.experimental.asyncContext,
71
+ _websocket: nitro.options.experimental.websocket,
72
+ _tasks: nitro.options.experimental.tasks
73
+ };
74
+ const replaceDelimiters = [
75
+ String.raw`\b`,
76
+ String.raw`(?![\w.$])`
77
+ ];
78
+ const replacements = {
79
+ "typeof window": '"undefined"',
80
+ _import_meta_url_: "import.meta.url",
81
+ "globalThis.process.": "process.",
82
+ "process.env.RUNTIME_CONFIG": () => JSON.stringify(nitro.options.runtimeConfig, null, 2),
83
+ ...Object.fromEntries(
84
+ Object.entries(buildEnvVars).map(([key, val]) => [
85
+ `process.env.${key}`,
86
+ JSON.stringify(val)
87
+ ])
88
+ ),
89
+ ...Object.fromEntries(
90
+ Object.entries(buildEnvVars).map(([key, val]) => [
91
+ `import.meta.env.${key}`,
92
+ JSON.stringify(val)
93
+ ])
94
+ ),
95
+ ...Object.fromEntries(
96
+ Object.entries(staticFlags).map(([key, val]) => [
97
+ `process.${key}`,
98
+ JSON.stringify(val)
99
+ ])
100
+ ),
101
+ ...Object.fromEntries(
102
+ Object.entries(staticFlags).map(([key, val]) => [
103
+ `import.meta.${key}`,
104
+ JSON.stringify(val)
105
+ ])
106
+ ),
107
+ ...nitro.options.replace
108
+ };
109
+ const { env } = defineEnv({
110
+ nodeCompat: isNodeless,
111
+ npmShims: true,
112
+ resolve: true,
113
+ presets: nitro.options.unenv,
114
+ overrides: {
115
+ alias: nitro.options.alias
116
+ }
117
+ });
118
+ const aliases = resolveAliases({
119
+ "#internal/nitro": runtimeDir,
120
+ "nitro/runtime": runtimeDir,
121
+ "nitropack/runtime": runtimeDir,
122
+ // Backwards compatibility
123
+ ...env.alias
124
+ });
125
+ return {
126
+ buildServerDir,
127
+ presetsDir,
128
+ extensions,
129
+ isNodeless,
130
+ buildEnvVars,
131
+ staticFlags,
132
+ replaceDelimiters,
133
+ replacements,
134
+ env,
135
+ aliases
136
+ };
137
+ }
138
+ function resolveAliases(_aliases) {
139
+ const aliases = Object.fromEntries(
140
+ Object.entries(_aliases).sort(
141
+ ([a], [b]) => b.split("/").length - a.split("/").length || b.length - a.length
142
+ )
143
+ );
144
+ for (const key in aliases) {
145
+ for (const alias in aliases) {
146
+ if (!["~", "@", "#"].includes(alias[0])) {
147
+ continue;
148
+ }
149
+ if (alias === "@" && !aliases[key].startsWith("@/")) {
150
+ continue;
151
+ }
152
+ if (aliases[key].startsWith(alias)) {
153
+ aliases[key] = aliases[alias] + aliases[key].slice(alias.length);
154
+ }
155
+ }
156
+ }
157
+ return aliases;
158
+ }
159
+
160
+ const PREFIX = "\0virtual:";
161
+ function virtual(modules, cache = {}) {
162
+ const _modules = /* @__PURE__ */ new Map();
163
+ for (const [id, mod] of Object.entries(modules)) {
164
+ cache[id] = mod;
165
+ _modules.set(id, mod);
166
+ _modules.set(resolve(id), mod);
167
+ }
168
+ return {
169
+ name: "virtual",
170
+ resolveId(id, importer) {
171
+ if (id in modules) {
172
+ return PREFIX + id;
173
+ }
174
+ if (importer) {
175
+ const importerNoPrefix = importer.startsWith(PREFIX) ? importer.slice(PREFIX.length) : importer;
176
+ const resolved = resolve(dirname(importerNoPrefix), id);
177
+ if (_modules.has(resolved)) {
178
+ return PREFIX + resolved;
179
+ }
180
+ }
181
+ return null;
182
+ },
183
+ async load(id) {
184
+ if (!id.startsWith(PREFIX)) {
185
+ return null;
186
+ }
187
+ const idNoPrefix = id.slice(PREFIX.length);
188
+ if (!_modules.has(idNoPrefix)) {
189
+ return null;
190
+ }
191
+ let m = _modules.get(idNoPrefix);
192
+ if (typeof m === "function") {
193
+ m = await m();
194
+ }
195
+ if (!m) {
196
+ return null;
197
+ }
198
+ cache[id.replace(PREFIX, "")] = m;
199
+ return {
200
+ code: m,
201
+ map: null
202
+ };
203
+ }
204
+ };
205
+ }
206
+
207
+ function database(nitro) {
208
+ if (!nitro.options.experimental.database) {
209
+ return virtual(
210
+ {
211
+ "#nitro-internal-virtual/database": () => {
212
+ return (
213
+ /* js */
214
+ `export const connectionConfigs = {};`
215
+ );
216
+ }
217
+ },
218
+ nitro.vfs
219
+ );
220
+ }
221
+ const dbConfigs = nitro.options.dev && nitro.options.devDatabase || nitro.options.database;
222
+ const connectorsNames = [
223
+ ...new Set(
224
+ Object.values(dbConfigs || {}).map((config) => config?.connector)
225
+ )
226
+ ].filter(Boolean);
227
+ for (const name of connectorsNames) {
228
+ if (!connectors[name]) {
229
+ throw new Error(`Database connector "${name}" is invalid.`);
230
+ }
231
+ }
232
+ return virtual(
233
+ {
234
+ "#nitro-internal-virtual/database": () => {
235
+ return `
236
+ ${connectorsNames.map(
237
+ (name) => `import ${camelCase(name)}Connector from "${connectors[name]}";`
238
+ ).join("\n")}
239
+
240
+ export const connectionConfigs = {
241
+ ${Object.entries(dbConfigs || {}).map(
242
+ ([name, { connector, options }]) => `${name}: {
243
+ connector: ${camelCase(connector)}Connector,
244
+ options: ${JSON.stringify(options)}
245
+ }`
246
+ ).join(",\n")}
247
+ };
248
+ `;
249
+ }
250
+ },
251
+ nitro.vfs
252
+ );
253
+ }
254
+
255
+ const RuntimeRouteRules = [
256
+ "headers",
257
+ "redirect",
258
+ "proxy",
259
+ "cache"
260
+ ];
261
+ function routing(nitro) {
262
+ return virtual(
263
+ {
264
+ // --- routing (routes, routeRules and middleware) ---
265
+ "#nitro-internal-virtual/routing": () => {
266
+ const allHandlers = uniqueBy(
267
+ [
268
+ ...Object.values(nitro.routing.routes.routes).map((h) => h.data),
269
+ ...Object.values(nitro.routing.routedMiddleware.routes).map(
270
+ (h) => h.data
271
+ ),
272
+ ...nitro.routing.globalMiddleware
273
+ ],
274
+ "_importHash"
275
+ );
276
+ const h3Imports = [
277
+ allHandlers.some((h) => !h.lazy) && "toEventHandler",
278
+ nitro.options.serverEntry && "toMiddleware",
279
+ allHandlers.some((h) => h.lazy) && "defineLazyEventHandler"
280
+ ].filter(Boolean);
281
+ return (
282
+ /* js */
283
+ `
284
+ import * as __routeRules__ from "nitro/runtime/internal/route-rules";
285
+ ${nitro.options.serverEntry ? `import __serverEntry__ from ${JSON.stringify(nitro.options.serverEntry)};` : ""}
286
+ import {${h3Imports.join(", ")}} from "h3";
287
+
288
+ export const findRouteRules = ${nitro.routing.routeRules.compileToString({ serialize: serializeRouteRule, matchAll: true })}
289
+
290
+ ${allHandlers.filter((h) => !h.lazy).map((h) => (
291
+ /* js */
292
+ `import ${h._importHash} from "${h.handler}";`
293
+ )).join("\n")}
294
+
295
+ ${allHandlers.filter((h) => h.lazy).map(
296
+ (h) => (
297
+ /* js */
298
+ `const ${h._importHash} = defineLazyEventHandler(() => import("${h.handler}"));`
299
+ )
300
+ ).join("\n")}
301
+
302
+ export const findRoute = ${nitro.routing.routes.compileToString({ serialize: serializeHandler })}
303
+
304
+ export const findRoutedMiddleware = ${nitro.routing.routedMiddleware.compileToString({ serialize: serializeHandler, matchAll: true })};
305
+
306
+ export const globalMiddleware = [
307
+ ${nitro.routing.globalMiddleware.map((h) => h.lazy ? h._importHash : `toEventHandler(${h._importHash})`).join(",")}
308
+ ${nitro.options.serverEntry ? `,toMiddleware(__serverEntry__)` : ""}
309
+ ].filter(Boolean);
310
+ `
311
+ );
312
+ },
313
+ // --- routing-meta ---
314
+ "#nitro-internal-virtual/routing-meta": () => {
315
+ const routeHandlers = uniqueBy(
316
+ Object.values(nitro.routing.routes.routes).map((h) => h.data),
317
+ "_importHash"
318
+ );
319
+ return (
320
+ /* js */
321
+ `
322
+ ${routeHandlers.map(
323
+ (h) => (
324
+ /* js */
325
+ `import ${h._importHash}Meta from "${h.handler}?meta";`
326
+ )
327
+ ).join("\n")}
328
+ export const handlersMeta = [
329
+ ${routeHandlers.map(
330
+ (h) => (
331
+ /* js */
332
+ `{ route: ${JSON.stringify(h.route)}, method: ${JSON.stringify(
333
+ h.method?.toLowerCase()
334
+ )}, meta: ${h._importHash}Meta }`
335
+ )
336
+ ).join(",\n")}
337
+ ];
338
+ `.trim()
339
+ );
340
+ }
341
+ },
342
+ nitro.vfs
343
+ );
344
+ }
345
+ function uniqueBy(arr, key) {
346
+ return [...new Map(arr.map((item) => [item[key], item])).values()];
347
+ }
348
+ function serializeHandler(h) {
349
+ return `{${[
350
+ `route:${JSON.stringify(h.route)}`,
351
+ h.method && `method:${JSON.stringify(h.method)}`,
352
+ h.meta && `meta:${JSON.stringify(h.meta)}`,
353
+ `handler:${h.lazy ? h._importHash : `toEventHandler(${h._importHash})`}`
354
+ ].filter(Boolean).join(",")}}`;
355
+ }
356
+ function serializeRouteRule(h) {
357
+ return `[${Object.entries(h).filter(([name, options]) => options !== void 0 && name[0] !== "_").map(([name, options]) => {
358
+ return `{${[
359
+ `name:${JSON.stringify(name)}`,
360
+ `route:${JSON.stringify(h._route)}`,
361
+ h._method && `method:${JSON.stringify(h._method)}`,
362
+ RuntimeRouteRules.includes(name) && `handler:__routeRules__.${name}`,
363
+ `options:${JSON.stringify(options)}`
364
+ ].filter(Boolean).join(",")}}`;
365
+ }).join(",")}]`;
366
+ }
367
+
368
+ const virtualPrefix = "\0nitro-handler-meta:";
369
+ const esbuildLoaders = {
370
+ ".ts": "ts",
371
+ ".js": "js",
372
+ ".tsx": "tsx",
373
+ ".jsx": "jsx"
374
+ };
375
+ function routeMeta(nitro) {
376
+ return {
377
+ name: "nitro:route-meta",
378
+ async resolveId(id, importer, resolveOpts) {
379
+ if (id.startsWith("\0")) {
380
+ return;
381
+ }
382
+ if (id.endsWith(`?meta`)) {
383
+ const resolved = await this.resolve(
384
+ id.replace(`?meta`, ``),
385
+ importer,
386
+ resolveOpts
387
+ );
388
+ if (!resolved) {
389
+ return;
390
+ }
391
+ return virtualPrefix + resolved.id;
392
+ }
393
+ },
394
+ load(id) {
395
+ if (id.startsWith(virtualPrefix)) {
396
+ const fullPath = id.slice(virtualPrefix.length);
397
+ return readFile(fullPath, { encoding: "utf8" });
398
+ }
399
+ },
400
+ async transform(code, id) {
401
+ if (!id.startsWith(virtualPrefix)) {
402
+ return;
403
+ }
404
+ let meta = null;
405
+ try {
406
+ const ext = extname(id);
407
+ const jsCode = await transform(code, {
408
+ loader: esbuildLoaders[ext]
409
+ }).then((r) => r.code);
410
+ const ast = this.parse(jsCode);
411
+ for (const node of ast.body) {
412
+ if (node.type === "ExpressionStatement" && node.expression.type === "CallExpression" && node.expression.callee.type === "Identifier" && node.expression.callee.name === "defineRouteMeta" && node.expression.arguments.length === 1) {
413
+ meta = astToObject(node.expression.arguments[0]);
414
+ break;
415
+ }
416
+ }
417
+ } catch (error) {
418
+ nitro.logger.warn(
419
+ `[handlers-meta] Cannot extra route meta for: ${id}: ${error}`
420
+ );
421
+ }
422
+ return {
423
+ code: `export default ${JSON.stringify(meta)};`,
424
+ map: null
425
+ };
426
+ }
427
+ };
428
+ }
429
+ function astToObject(node) {
430
+ switch (node.type) {
431
+ case "ObjectExpression": {
432
+ const obj = {};
433
+ for (const prop of node.properties) {
434
+ if (prop.type === "Property") {
435
+ const key = prop.key.name ?? prop.key.value;
436
+ obj[key] = astToObject(prop.value);
437
+ }
438
+ }
439
+ return obj;
440
+ }
441
+ case "ArrayExpression": {
442
+ return node.elements.map((el) => astToObject(el)).filter(Boolean);
443
+ }
444
+ case "Literal": {
445
+ return node.value;
446
+ }
447
+ }
448
+ }
449
+
450
+ function serverMain(nitro) {
451
+ return {
452
+ name: "nitro:server-main",
453
+ renderChunk(code, chunk) {
454
+ if (chunk.isEntry) {
455
+ return {
456
+ code: `globalThis.__nitro_main__ = import.meta.url; ${code}`,
457
+ map: null
458
+ };
459
+ }
460
+ }
461
+ };
462
+ }
463
+
464
+ const readAssetHandler = {
465
+ true: "node",
466
+ node: "node",
467
+ false: "null",
468
+ deno: "deno",
469
+ inline: "inline"
470
+ };
471
+ function publicAssets(nitro) {
472
+ return virtual(
473
+ {
474
+ // #nitro-internal-virtual/public-assets-data
475
+ "#nitro-internal-virtual/public-assets-data": async () => {
476
+ const assets = {};
477
+ const files = await glob("**", {
478
+ cwd: nitro.options.output.publicDir,
479
+ absolute: false,
480
+ dot: true
481
+ });
482
+ for (const id of files) {
483
+ let mimeType = mime.getType(id.replace(/\.(gz|br)$/, "")) || "text/plain";
484
+ if (mimeType.startsWith("text")) {
485
+ mimeType += "; charset=utf-8";
486
+ }
487
+ const fullPath = resolve(nitro.options.output.publicDir, id);
488
+ const assetData = await promises.readFile(fullPath);
489
+ const etag = createEtag(assetData);
490
+ const stat = await promises.stat(fullPath);
491
+ const assetId = "/" + decodeURIComponent(id);
492
+ let encoding;
493
+ if (id.endsWith(".gz")) {
494
+ encoding = "gzip";
495
+ } else if (id.endsWith(".br")) {
496
+ encoding = "br";
497
+ }
498
+ assets[assetId] = {
499
+ type: nitro._prerenderMeta?.[assetId]?.contentType || mimeType,
500
+ encoding,
501
+ etag,
502
+ mtime: stat.mtime.toJSON(),
503
+ size: stat.size,
504
+ path: relative(nitro.options.output.serverDir, fullPath),
505
+ data: nitro.options.serveStatic === "inline" ? assetData.toString("base64") : void 0
506
+ };
507
+ }
508
+ return `export default ${JSON.stringify(assets, null, 2)};`;
509
+ },
510
+ // #nitro-internal-virtual/public-assets-node
511
+ "#nitro-internal-virtual/public-assets-node": () => {
512
+ return `
513
+ import { promises as fsp } from 'node:fs'
514
+ import { fileURLToPath } from 'node:url'
515
+ import { resolve, dirname } from 'node:path'
516
+ import assets from '#nitro-internal-virtual/public-assets-data'
517
+ export function readAsset (id) {
518
+ const serverDir = dirname(fileURLToPath(globalThis.__nitro_main__))
519
+ return fsp.readFile(resolve(serverDir, assets[id].path))
520
+ }`;
521
+ },
522
+ // #nitro-internal-virtual/public-assets-deno
523
+ "#nitro-internal-virtual/public-assets-deno": () => {
524
+ return `
525
+ import assets from '#nitro-internal-virtual/public-assets-data'
526
+ export function readAsset (id) {
527
+ // https://deno.com/deploy/docs/serve-static-assets
528
+ const path = '.' + decodeURIComponent(new URL(\`../public\${id}\`, 'file://').pathname)
529
+ return Deno.readFile(path);
530
+ }`;
531
+ },
532
+ // #nitro-internal-virtual/public-assets-null
533
+ "#nitro-internal-virtual/public-assets-null": () => {
534
+ return `
535
+ export function readAsset (id) {
536
+ return Promise.resolve(null);
537
+ }`;
538
+ },
539
+ // #nitro-internal-virtual/public-assets-inline
540
+ "#nitro-internal-virtual/public-assets-inline": () => {
541
+ return `
542
+ import assets from '#nitro-internal-virtual/public-assets-data'
543
+ export function readAsset (id) {
544
+ if (!assets[id]) { return undefined }
545
+ if (assets[id]._data) { return assets[id]._data }
546
+ if (!assets[id].data) { return assets[id].data }
547
+ assets[id]._data = Uint8Array.from(atob(assets[id].data), (c) => c.charCodeAt(0))
548
+ return assets[id]._data
549
+ }`;
550
+ },
551
+ // #nitro-internal-virtual/public-assets
552
+ "#nitro-internal-virtual/public-assets": () => {
553
+ const publicAssetBases = Object.fromEntries(
554
+ nitro.options.publicAssets.filter((dir) => !dir.fallthrough && dir.baseURL !== "/").map((dir) => [
555
+ withTrailingSlash(dir.baseURL),
556
+ { maxAge: dir.maxAge }
557
+ ])
558
+ );
559
+ const handlerName = readAssetHandler[nitro.options.serveStatic] || "null";
560
+ const readAssetImport = `#nitro-internal-virtual/public-assets-${handlerName}`;
561
+ return `
562
+ import assets from '#nitro-internal-virtual/public-assets-data'
563
+ export { readAsset } from "${readAssetImport}"
564
+ export const publicAssetBases = ${JSON.stringify(publicAssetBases)}
565
+
566
+ export function isPublicAssetURL(id = '') {
567
+ if (assets[id]) {
568
+ return true
569
+ }
570
+ for (const base in publicAssetBases) {
571
+ if (id.startsWith(base)) { return true }
572
+ }
573
+ return false
574
+ }
575
+
576
+ export function getPublicAssetMeta(id = '') {
577
+ for (const base in publicAssetBases) {
578
+ if (id.startsWith(base)) { return publicAssetBases[base] }
579
+ }
580
+ return {}
581
+ }
582
+
583
+ export function getAsset (id) {
584
+ return assets[id]
585
+ }
586
+ `;
587
+ }
588
+ },
589
+ nitro.vfs
590
+ );
591
+ }
592
+
593
+ function serverAssets(nitro) {
594
+ if (nitro.options.dev || nitro.options.preset === "nitro-prerender") {
595
+ return virtual(
596
+ { "#nitro-internal-virtual/server-assets": getAssetsDev(nitro) },
597
+ nitro.vfs
598
+ );
599
+ }
600
+ return virtual(
601
+ {
602
+ "#nitro-internal-virtual/server-assets": async () => {
603
+ const assets = {};
604
+ for (const asset of nitro.options.serverAssets) {
605
+ const files = await glob(asset.pattern || "**/*", {
606
+ cwd: asset.dir,
607
+ absolute: false,
608
+ ignore: asset.ignore
609
+ });
610
+ for (const _id of files) {
611
+ const fsPath = resolve(asset.dir, _id);
612
+ const id = asset.baseName + "/" + _id;
613
+ assets[id] = { fsPath, meta: {} };
614
+ let type = mime.getType(id) || "text/plain";
615
+ if (type.startsWith("text")) {
616
+ type += "; charset=utf-8";
617
+ }
618
+ const etag = createEtag(await promises.readFile(fsPath));
619
+ const mtime = await promises.stat(fsPath).then((s) => s.mtime.toJSON());
620
+ assets[id].meta = { type, etag, mtime };
621
+ }
622
+ }
623
+ return getAssetProd(assets);
624
+ }
625
+ },
626
+ nitro.vfs
627
+ );
628
+ }
629
+ function getAssetsDev(nitro) {
630
+ return `
631
+ import { createStorage } from 'unstorage'
632
+ import fsDriver from 'unstorage/drivers/fs'
633
+
634
+ const serverAssets = ${JSON.stringify(nitro.options.serverAssets)}
635
+
636
+ export const assets = createStorage()
637
+
638
+ for (const asset of serverAssets) {
639
+ assets.mount(asset.baseName, fsDriver({ base: asset.dir, ignore: (asset?.ignore || []) }))
640
+ }`;
641
+ }
642
+ function getAssetProd(assets) {
643
+ return `
644
+ const _assets = {
645
+ ${Object.entries(assets).map(
646
+ ([id, asset]) => ` [${JSON.stringify(
647
+ normalizeKey(id)
648
+ )}]: {
649
+ import: () => import(${JSON.stringify(
650
+ "raw:" + asset.fsPath
651
+ )}).then(r => r.default || r),
652
+ meta: ${JSON.stringify(
653
+ asset.meta
654
+ )}
655
+ }`
656
+ ).join(",\n")}
657
+ }
658
+
659
+ const normalizeKey = ${normalizeKey.toString()}
660
+
661
+ export const assets = {
662
+ getKeys() {
663
+ return Promise.resolve(Object.keys(_assets))
664
+ },
665
+ hasItem (id) {
666
+ id = normalizeKey(id)
667
+ return Promise.resolve(id in _assets)
668
+ },
669
+ getItem (id) {
670
+ id = normalizeKey(id)
671
+ return Promise.resolve(_assets[id] ? _assets[id].import() : null)
672
+ },
673
+ getMeta (id) {
674
+ id = normalizeKey(id)
675
+ return Promise.resolve(_assets[id] ? _assets[id].meta : {})
676
+ }
677
+ }
678
+ `;
679
+ }
680
+
681
+ function storage(nitro) {
682
+ const mounts = [];
683
+ const isDevOrPrerender = nitro.options.dev || nitro.options.preset === "nitro-prerender";
684
+ const storageMounts = isDevOrPrerender ? { ...nitro.options.storage, ...nitro.options.devStorage } : nitro.options.storage;
685
+ for (const path in storageMounts) {
686
+ const mount = storageMounts[path];
687
+ mounts.push({
688
+ path,
689
+ driver: builtinDrivers[mount.driver] || mount.driver,
690
+ opts: mount
691
+ });
692
+ }
693
+ const driverImports = [...new Set(mounts.map((m) => m.driver))];
694
+ const bundledStorageCode = `
695
+ import { prefixStorage } from 'unstorage'
696
+ import overlay from 'unstorage/drivers/overlay'
697
+ import memory from 'unstorage/drivers/memory'
698
+
699
+ const bundledStorage = ${JSON.stringify(nitro.options.bundledStorage)}
700
+ for (const base of bundledStorage) {
701
+ storage.mount(base, overlay({
702
+ layers: [
703
+ memory(),
704
+ // TODO
705
+ // prefixStorage(storage, base),
706
+ prefixStorage(storage, 'assets:nitro:bundled:' + base)
707
+ ]
708
+ }))
709
+ }`;
710
+ return virtual(
711
+ {
712
+ "#nitro-internal-virtual/storage": (
713
+ /* js */
714
+ `
715
+ import { createStorage } from 'unstorage'
716
+ import { assets } from '#nitro-internal-virtual/server-assets'
717
+
718
+ ${driverImports.map((i) => genImport(i, genSafeVariableName(i))).join("\n")}
719
+
720
+ export function initStorage() {
721
+ const storage = createStorage({})
722
+ storage.mount('/assets', assets)
723
+ ${mounts.map(
724
+ (m) => `storage.mount('${m.path}', ${genSafeVariableName(
725
+ m.driver
726
+ )}(${JSON.stringify(m.opts)}))`
727
+ ).join("\n")}
728
+
729
+ ${!isDevOrPrerender && nitro.options.bundledStorage.length > 0 ? bundledStorageCode : ""}
730
+ return storage
731
+ }
732
+ `
733
+ )
734
+ },
735
+ nitro.vfs
736
+ );
737
+ }
738
+
739
+ function errorHandler(nitro) {
740
+ return virtual(
741
+ {
742
+ "#nitro-internal-virtual/error-handler": () => {
743
+ const errorHandlers = Array.isArray(nitro.options.errorHandler) ? nitro.options.errorHandler : [nitro.options.errorHandler];
744
+ const builtinHandler = join(
745
+ runtimeDir,
746
+ `internal/error/${nitro.options.dev ? "dev" : "prod"}`
747
+ );
748
+ return (
749
+ /* js */
750
+ `
751
+ ${errorHandlers.map((h, i) => `import errorHandler$${i} from "${h}";`).join("\n")}
752
+
753
+ const errorHandlers = [${errorHandlers.map((_, i) => `errorHandler$${i}`).join(", ")}];
754
+
755
+ import { defaultHandler } from "${builtinHandler}";
756
+
757
+ export default async function(error, event) {
758
+ for (const handler of errorHandlers) {
759
+ try {
760
+ const response = await handler(error, event, { defaultHandler });
761
+ if (response) {
762
+ return response;
763
+ }
764
+ } catch(error) {
765
+ // Handler itself thrown, log and continue
766
+ console.error(error);
767
+ }
768
+ }
769
+ // H3 will handle fallback
770
+ }
771
+ `
772
+ );
773
+ }
774
+ },
775
+ nitro.vfs
776
+ );
777
+ }
778
+
779
+ function rendererTemplate(nitro) {
780
+ return virtual(
781
+ {
782
+ "#nitro-internal-virtual/renderer-template": async () => {
783
+ if (typeof nitro.options.renderer?.template !== "string") {
784
+ return `export const rendererTemplate = () => '<!-- renderer.template is not set -->'; export const rendererTemplateFile = undefined;`;
785
+ }
786
+ if (nitro.options.dev) {
787
+ return `import { readFile } from 'node:fs/promises';export const rendererTemplate = () => readFile(${JSON.stringify(nitro.options.renderer?.template)}, "utf8"); export const rendererTemplateFile = ${JSON.stringify(
788
+ nitro.options.renderer?.template
789
+ )};`;
790
+ } else {
791
+ const html = await readFile(nitro.options.renderer?.template, "utf8");
792
+ if (hasTemplateSyntax(html)) {
793
+ const template = compileTemplateToString(html, {
794
+ contextKeys: [...RENDER_CONTEXT_KEYS]
795
+ });
796
+ return (
797
+ /* js */
798
+ `
799
+ import { renderToResponse } from 'rendu'
800
+ const template = ${template};
801
+ export const rendererTemplate = (request) => renderToResponse(template, { request })
802
+ `
803
+ );
804
+ } else {
805
+ return (
806
+ /* js */
807
+ `
808
+ import { HTTPResponse } from "h3";
809
+ export const rendererTemplate = () => new HTTPResponse(${JSON.stringify(html)}, { headers: { "content-type": "text/html; charset=utf-8" } });
810
+ `
811
+ );
812
+ }
813
+ }
814
+ }
815
+ },
816
+ nitro.vfs
817
+ );
818
+ }
819
+
820
+ function featureFlags(nitro) {
821
+ return virtual(
822
+ {
823
+ "#nitro-internal-virtual/feature-flags": () => {
824
+ const featureFlags2 = {
825
+ // Routing
826
+ hasRoutes: nitro.routing.routes.hasRoutes(),
827
+ hasRouteRules: nitro.routing.routeRules.hasRoutes(),
828
+ hasRoutedMiddleware: nitro.routing.routedMiddleware.hasRoutes(),
829
+ hasGlobalMiddleware: nitro.routing.globalMiddleware.length > 0 || !!nitro.options.serverEntry,
830
+ // Plugins
831
+ hasPlugins: nitro.options.plugins.length > 0,
832
+ hasHooks: nitro.options.features?.runtimeHooks ?? nitro.options.plugins.length > 0
833
+ };
834
+ return (
835
+ /* js */
836
+ Object.entries(featureFlags2).map(
837
+ ([key, value]) => (
838
+ /* js */
839
+ `export const ${key} = ${Boolean(value)};`
840
+ )
841
+ ).join("\n")
842
+ );
843
+ }
844
+ },
845
+ nitro.vfs
846
+ );
847
+ }
848
+
849
+ const subpathMap = {
850
+ "nitro/h3": "h3",
851
+ "nitro/deps/h3": "h3",
852
+ "nitro/deps/ofetch": "ofetch"
853
+ };
854
+ function nitroResolveIds() {
855
+ return {
856
+ name: "nitro:resolve-ids",
857
+ resolveId: {
858
+ order: "pre",
859
+ handler(id, importer, rOpts) {
860
+ if (importer && importer.startsWith("\0virtual:#nitro-internal-virtual")) {
861
+ return this.resolve(id, runtimeDir, { skipSelf: true });
862
+ }
863
+ const mappedId = subpathMap[id];
864
+ if (mappedId) {
865
+ return this.resolve(mappedId, runtimeDir, { skipSelf: true });
866
+ }
867
+ }
868
+ }
869
+ };
870
+ }
871
+
872
+ function baseBuildPlugins(nitro, base) {
873
+ const plugins = [];
874
+ if (nitro.options.imports) {
875
+ plugins.push(unplugin.rollup(nitro.options.imports));
876
+ }
877
+ if (nitro.options.experimental.wasm) {
878
+ plugins.push(rollup(nitro.options.wasm || {}));
879
+ }
880
+ plugins.push(serverMain());
881
+ const nitroPlugins = [...new Set(nitro.options.plugins)];
882
+ plugins.push(
883
+ virtual(
884
+ {
885
+ "#nitro-internal-virtual/plugins": (
886
+ /* js */
887
+ `
888
+ ${nitroPlugins.map(
889
+ (plugin) => `import _${hash(plugin).replace(/-/g, "")} from '${plugin}';`
890
+ ).join("\n")}
891
+
892
+ export const plugins = [
893
+ ${nitroPlugins.map((plugin) => `_${hash(plugin).replace(/-/g, "")}`).join(",\n")}
894
+ ]
895
+ `
896
+ )
897
+ },
898
+ nitro.vfs
899
+ )
900
+ );
901
+ plugins.push(featureFlags(nitro));
902
+ plugins.push(nitroResolveIds());
903
+ plugins.push(serverAssets(nitro));
904
+ plugins.push(publicAssets(nitro));
905
+ plugins.push(storage(nitro));
906
+ plugins.push(database(nitro));
907
+ plugins.push(routing(nitro));
908
+ if (nitro.options.experimental.openAPI) {
909
+ plugins.push(routeMeta(nitro));
910
+ }
911
+ plugins.push(errorHandler(nitro));
912
+ plugins.push(
913
+ virtual(
914
+ {
915
+ "#nitro-internal-pollyfills": base.env.polyfill.map((p) => (
916
+ /* js */
917
+ `import '${p}';`
918
+ )).join("\n") || /* js */
919
+ `/* No polyfills */`
920
+ },
921
+ nitro.vfs
922
+ )
923
+ );
924
+ plugins.push(virtual(nitro.options.virtual, nitro.vfs));
925
+ if (nitro.options.renderer?.template) {
926
+ plugins.push(rendererTemplate(nitro));
927
+ }
928
+ if (!nitro.options.noExternals) {
929
+ plugins.push(
930
+ rollupNodeFileTrace(
931
+ defu(nitro.options.externals, {
932
+ outDir: nitro.options.output.serverDir,
933
+ moduleDirectories: nitro.options.nodeModulesDirs,
934
+ external: [
935
+ ...nitro.options.dev ? [nitro.options.buildDir] : [],
936
+ ...nitro.options.nodeModulesDirs
937
+ ],
938
+ inline: [
939
+ "#",
940
+ "~",
941
+ "@/",
942
+ "~~",
943
+ "@@/",
944
+ "virtual:",
945
+ "nitro/runtime",
946
+ dirname(nitro.options.entry),
947
+ ...nitro.options.experimental.wasm ? [(id) => id?.endsWith(".wasm")] : [],
948
+ runtimeDir,
949
+ nitro.options.srcDir,
950
+ ...nitro.options.handlers.map((m) => m.handler).filter((i) => typeof i === "string"),
951
+ ...nitro.options.dev || nitro.options.preset === "nitro-prerender" || nitro.options.experimental.bundleRuntimeDependencies === false ? [] : runtimeDependencies
952
+ ],
953
+ traceOptions: {
954
+ base: "/",
955
+ processCwd: nitro.options.rootDir,
956
+ exportsOnly: true
957
+ },
958
+ traceAlias: {
959
+ "h3-nightly": "h3",
960
+ ...nitro.options.externals?.traceAlias
961
+ },
962
+ exportConditions: nitro.options.exportConditions,
963
+ writePackageJson: true
964
+ })
965
+ )
966
+ );
967
+ }
968
+ return plugins;
969
+ }
970
+
971
+ async function writeBuildInfo(nitro) {
972
+ const buildInfoPath = resolve(nitro.options.output.dir, "nitro.json");
973
+ const buildInfo = {
974
+ date: (/* @__PURE__ */ new Date()).toJSON(),
975
+ preset: nitro.options.preset,
976
+ framework: nitro.options.framework,
977
+ versions: {
978
+ nitro: version
979
+ },
980
+ commands: {
981
+ preview: nitro.options.commands.preview,
982
+ deploy: nitro.options.commands.deploy
983
+ },
984
+ config: {
985
+ ...Object.fromEntries(
986
+ presetsWithConfig.map((key) => [key, nitro.options[key]])
987
+ )
988
+ }
989
+ };
990
+ await writeFile(buildInfoPath, JSON.stringify(buildInfo, null, 2), true);
991
+ const lastBuild = resolve(
992
+ nitro.options.rootDir,
993
+ "node_modules/.nitro/last-build"
994
+ );
995
+ await mkdir(dirname$1(lastBuild), { recursive: true });
996
+ await unlink(lastBuild).catch(() => {
997
+ });
998
+ await symlink(nitro.options.output.dir, lastBuild).catch(console.warn);
999
+ return buildInfo;
1000
+ }
1001
+
1002
+ export { baseBuildPlugins as a, baseBuildConfig as b, replace as r, writeBuildInfo as w };