index.mjs 67 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672
  1. import process from 'node:process';globalThis._importMeta_={url:import.meta.url,env:process.env};import { mkdirSync } from 'node:fs';
  2. import { Server } from 'node:http';
  3. import { tmpdir } from 'node:os';
  4. import { join } from 'node:path';
  5. import { parentPort, threadId } from 'node:worker_threads';
  6. import { getRequestHeader, splitCookiesString, setResponseStatus, setResponseHeader, send, getRequestHeaders, defineEventHandler, handleCacheHeaders, createEvent, fetchWithEvent, isEvent, eventHandler, setHeaders, sendRedirect, proxyRequest, createApp, createRouter as createRouter$1, toNodeListener, lazyEventHandler, getResponseStatus, setResponseHeaders, createError, getRouterParam, getQuery as getQuery$1, readBody, getResponseStatusText } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/h3/dist/index.mjs';
  7. import { getRequestDependencies, getPreloadLinks, getPrefetchLinks, createRenderer } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/vue-bundle-renderer/dist/runtime.mjs';
  8. import { stringify, uneval } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/devalue/index.js';
  9. import destr from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/destr/dist/index.mjs';
  10. import { withQuery, joinURL, withTrailingSlash, parseURL, withoutBase, getQuery, joinRelativeURL } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/ufo/dist/index.mjs';
  11. import { renderToString } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/vue/server-renderer/index.mjs';
  12. import { propsToString, renderSSRHead } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/@unhead/ssr/dist/index.mjs';
  13. import { createServerHead as createServerHead$1, CapoPlugin } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/unhead/dist/index.mjs';
  14. import { klona } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/klona/dist/index.mjs';
  15. import defu, { defuFn } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/defu/dist/defu.mjs';
  16. import { snakeCase } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/scule/dist/index.mjs';
  17. import { createHooks } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/hookable/dist/index.mjs';
  18. import { createFetch as createFetch$1, Headers as Headers$1 } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/ofetch/dist/node.mjs';
  19. import { createCall, createFetch } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/unenv/runtime/fetch/index.mjs';
  20. import { AsyncLocalStorage } from 'node:async_hooks';
  21. import { consola } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/consola/dist/index.mjs';
  22. import { getContext } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/unctx/dist/index.mjs';
  23. import { captureRawStackTrace, parseRawStackTrace } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/errx/dist/index.js';
  24. import { isVNode, version, unref } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/vue/index.mjs';
  25. import { hash } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/ohash/dist/index.mjs';
  26. import { createStorage, prefixStorage } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/unstorage/dist/index.mjs';
  27. import unstorage_47drivers_47fs from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/unstorage/drivers/fs.mjs';
  28. import { toRouteMatcher, createRouter } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/radix3/dist/index.mjs';
  29. import { defineHeadPlugin } from 'file://D:/dev/nuxt/sannongzixunwang_web/node_modules/@unhead/shared/dist/index.mjs';
  30. import { getRequestHeader, splitCookiesString, setResponseStatus, setResponseHeader, send, getRequestHeaders, defineEventHandler, handleCacheHeaders, createEvent, fetchWithEvent, isEvent, eventHandler, setHeaders, sendRedirect, proxyRequest, createApp, createRouter as createRouter$1, toNodeListener, lazyEventHandler, getResponseStatus, setResponseHeaders, createError, getRouterParam, getQuery as getQuery$1, readBody, getResponseStatusText } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/h3/dist/index.mjs';
  31. import { getRequestDependencies, getPreloadLinks, getPrefetchLinks, createRenderer } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/vue-bundle-renderer/dist/runtime.mjs';
  32. import { stringify, uneval } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/devalue/index.js';
  33. import destr from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/destr/dist/index.mjs';
  34. import { withQuery, joinURL, withTrailingSlash, parseURL, withoutBase, getQuery, joinRelativeURL } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/ufo/dist/index.mjs';
  35. import { renderToString } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/vue/server-renderer/index.mjs';
  36. import { propsToString, renderSSRHead } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/@unhead/ssr/dist/index.mjs';
  37. import { createServerHead as createServerHead$1, CapoPlugin } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/unhead/dist/index.mjs';
  38. import { klona } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/klona/dist/index.mjs';
  39. import defu, { defuFn } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/defu/dist/defu.mjs';
  40. import { snakeCase } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/scule/dist/index.mjs';
  41. import { createHooks } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/hookable/dist/index.mjs';
  42. import { createFetch as createFetch$1, Headers as Headers$1 } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/ofetch/dist/node.mjs';
  43. import { createCall, createFetch } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/unenv/runtime/fetch/index.mjs';
  44. import { AsyncLocalStorage } from 'node:async_hooks';
  45. import { consola } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/consola/dist/index.mjs';
  46. import { getContext } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/unctx/dist/index.mjs';
  47. import { captureRawStackTrace, parseRawStackTrace } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/errx/dist/index.js';
  48. import { isVNode, version, unref } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/vue/index.mjs';
  49. import { hash } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/ohash/dist/index.mjs';
  50. import { createStorage, prefixStorage } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/unstorage/dist/index.mjs';
  51. import unstorage_47drivers_47fs from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/unstorage/drivers/fs.mjs';
  52. import { toRouteMatcher, createRouter } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/radix3/dist/index.mjs';
  53. import { defineHeadPlugin } from 'file://D:/MyProject/105/sannongzixunwang_web/node_modules/@unhead/shared/dist/index.mjs';
  54. function hasReqHeader(event, name, includes) {
  55. const value = getRequestHeader(event, name);
  56. return value && typeof value === "string" && value.toLowerCase().includes(includes);
  57. }
  58. function isJsonRequest(event) {
  59. if (hasReqHeader(event, "accept", "text/html")) {
  60. return false;
  61. }
  62. return hasReqHeader(event, "accept", "application/json") || hasReqHeader(event, "user-agent", "curl/") || hasReqHeader(event, "user-agent", "httpie/") || hasReqHeader(event, "sec-fetch-mode", "cors") || event.path.startsWith("/api/") || event.path.endsWith(".json");
  63. }
  64. function normalizeError(error, isDev) {
  65. const cwd = typeof process.cwd === "function" ? process.cwd() : "/";
  66. const stack = (error.unhandled || error.fatal) ? [] : (error.stack || "").split("\n").splice(1).filter((line) => line.includes("at ")).map((line) => {
  67. const text = line.replace(cwd + "/", "./").replace("webpack:/", "").replace("file://", "").trim();
  68. return {
  69. text,
  70. internal: line.includes("node_modules") && !line.includes(".cache") || line.includes("internal") || line.includes("new Promise")
  71. };
  72. });
  73. const statusCode = error.statusCode || 500;
  74. const statusMessage = error.statusMessage ?? (statusCode === 404 ? "Not Found" : "");
  75. const message = error.unhandled ? "internal server error" : error.message || error.toString();
  76. return {
  77. stack,
  78. statusCode,
  79. statusMessage,
  80. message
  81. };
  82. }
  83. function _captureError(error, type) {
  84. console.error(`[nitro] [${type}]`, error);
  85. useNitroApp().captureError(error, { tags: [type] });
  86. }
  87. function trapUnhandledNodeErrors() {
  88. process.on(
  89. "unhandledRejection",
  90. (error) => _captureError(error, "unhandledRejection")
  91. );
  92. process.on(
  93. "uncaughtException",
  94. (error) => _captureError(error, "uncaughtException")
  95. );
  96. }
  97. function joinHeaders(value) {
  98. return Array.isArray(value) ? value.join(", ") : String(value);
  99. }
  100. function normalizeFetchResponse(response) {
  101. if (!response.headers.has("set-cookie")) {
  102. return response;
  103. }
  104. return new Response(response.body, {
  105. status: response.status,
  106. statusText: response.statusText,
  107. headers: normalizeCookieHeaders(response.headers)
  108. });
  109. }
  110. function normalizeCookieHeader(header = "") {
  111. return splitCookiesString(joinHeaders(header));
  112. }
  113. function normalizeCookieHeaders(headers) {
  114. const outgoingHeaders = new Headers();
  115. for (const [name, header] of headers) {
  116. if (name === "set-cookie") {
  117. for (const cookie of normalizeCookieHeader(header)) {
  118. outgoingHeaders.append("set-cookie", cookie);
  119. }
  120. } else {
  121. outgoingHeaders.set(name, joinHeaders(header));
  122. }
  123. }
  124. return outgoingHeaders;
  125. }
  126. const errorHandler = (async function errorhandler(error, event) {
  127. const { stack, statusCode, statusMessage, message } = normalizeError(error);
  128. const errorObject = {
  129. url: event.path,
  130. statusCode,
  131. statusMessage,
  132. message,
  133. stack: statusCode !== 404 ? `<pre>${stack.map((i) => `<span class="stack${i.internal ? " internal" : ""}">${i.text}</span>`).join("\n")}</pre>` : "",
  134. // TODO: check and validate error.data for serialisation into query
  135. data: error.data
  136. };
  137. if (error.unhandled || error.fatal) {
  138. const tags = [
  139. "[nuxt]",
  140. "[request error]",
  141. error.unhandled && "[unhandled]",
  142. error.fatal && "[fatal]",
  143. Number(errorObject.statusCode) !== 200 && `[${errorObject.statusCode}]`
  144. ].filter(Boolean).join(" ");
  145. console.error(tags, (error.message || error.toString() || "internal server error") + "\n" + stack.map((l) => " " + l.text).join(" \n"));
  146. }
  147. if (event.handled) {
  148. return;
  149. }
  150. setResponseStatus(event, errorObject.statusCode !== 200 && errorObject.statusCode || 500, errorObject.statusMessage);
  151. if (isJsonRequest(event)) {
  152. setResponseHeader(event, "Content-Type", "application/json");
  153. return send(event, JSON.stringify(errorObject));
  154. }
  155. const reqHeaders = getRequestHeaders(event);
  156. const isRenderingError = event.path.startsWith("/__nuxt_error") || !!reqHeaders["x-nuxt-error"];
  157. const res = isRenderingError ? null : await useNitroApp().localFetch(
  158. withQuery(joinURL(useRuntimeConfig(event).app.baseURL, "/__nuxt_error"), errorObject),
  159. {
  160. headers: { ...reqHeaders, "x-nuxt-error": "true" },
  161. redirect: "manual"
  162. }
  163. ).catch(() => null);
  164. if (!res) {
  165. const { template } = await Promise.resolve().then(function () { return errorDev; }) ;
  166. {
  167. errorObject.description = errorObject.message;
  168. }
  169. if (event.handled) {
  170. return;
  171. }
  172. setResponseHeader(event, "Content-Type", "text/html;charset=UTF-8");
  173. return send(event, template(errorObject));
  174. }
  175. const html = await res.text();
  176. if (event.handled) {
  177. return;
  178. }
  179. for (const [header, value] of res.headers.entries()) {
  180. setResponseHeader(event, header, value);
  181. }
  182. setResponseStatus(event, res.status && res.status !== 200 ? res.status : undefined, res.statusText);
  183. return send(event, html);
  184. });
  185. const script = `
  186. if (!window.__NUXT_DEVTOOLS_TIME_METRIC__) {
  187. Object.defineProperty(window, '__NUXT_DEVTOOLS_TIME_METRIC__', {
  188. value: {},
  189. enumerable: false,
  190. configurable: true,
  191. })
  192. }
  193. window.__NUXT_DEVTOOLS_TIME_METRIC__.appInit = Date.now()
  194. `;
  195. <<<<<<< HEAD
  196. const _o3yZBW1Rnc = (function(nitro) {
  197. =======
  198. const _MoCGaRUN7w = (function(nitro) {
  199. >>>>>>> b7384efd13504e61e59724eb6cefc1617c5b0127
  200. nitro.hooks.hook("render:html", (htmlContext) => {
  201. htmlContext.head.push(`<script>${script}<\/script>`);
  202. });
  203. });
  204. <<<<<<< HEAD
  205. const rootDir = "D:/dev/nuxt/sannongzixunwang_web";
  206. =======
  207. const rootDir = "D:/MyProject/105/sannongzixunwang_web";
  208. >>>>>>> b7384efd13504e61e59724eb6cefc1617c5b0127
  209. const appHead = {"meta":[{"name":"viewport","content":"width=device-width, initial-scale=1"},{"charset":"utf-8"}],"link":[],"style":[],"script":[],"noscript":[]};
  210. const appRootTag = "div";
  211. const appRootAttrs = {"id":"__nuxt"};
  212. const appTeleportTag = "div";
  213. const appTeleportAttrs = {"id":"teleports"};
  214. const appId = "nuxt-app";
  215. const devReducers = {
  216. VNode: (data) => isVNode(data) ? { type: data.type, props: data.props } : undefined,
  217. URL: (data) => data instanceof URL ? data.toString() : undefined
  218. };
  219. const asyncContext = getContext("nuxt-dev", { asyncContext: true, AsyncLocalStorage });
  220. <<<<<<< HEAD
  221. const _e2UTql7fjT = (nitroApp) => {
  222. =======
  223. const _oeSAu3NnQa = (nitroApp) => {
  224. >>>>>>> b7384efd13504e61e59724eb6cefc1617c5b0127
  225. const handler = nitroApp.h3App.handler;
  226. nitroApp.h3App.handler = (event) => {
  227. return asyncContext.callAsync({ logs: [], event }, () => handler(event));
  228. };
  229. onConsoleLog((_log) => {
  230. const ctx = asyncContext.tryUse();
  231. if (!ctx) {
  232. return;
  233. }
  234. const rawStack = captureRawStackTrace();
  235. if (!rawStack || rawStack.includes("runtime/vite-node.mjs")) {
  236. return;
  237. }
  238. const trace = [];
  239. let filename = "";
  240. for (const entry of parseRawStackTrace(rawStack)) {
  241. if (entry.source === globalThis._importMeta_.url) {
  242. continue;
  243. }
  244. if (EXCLUDE_TRACE_RE.test(entry.source)) {
  245. continue;
  246. }
  247. filename ||= entry.source.replace(withTrailingSlash(rootDir), "");
  248. trace.push({
  249. ...entry,
  250. source: entry.source.startsWith("file://") ? entry.source.replace("file://", "") : entry.source
  251. });
  252. }
  253. const log = {
  254. ..._log,
  255. // Pass along filename to allow the client to display more info about where log comes from
  256. filename,
  257. // Clean up file names in stack trace
  258. stack: trace
  259. };
  260. ctx.logs.push(log);
  261. });
  262. nitroApp.hooks.hook("afterResponse", () => {
  263. const ctx = asyncContext.tryUse();
  264. if (!ctx) {
  265. return;
  266. }
  267. return nitroApp.hooks.callHook("dev:ssr-logs", { logs: ctx.logs, path: ctx.event.path });
  268. });
  269. nitroApp.hooks.hook("render:html", (htmlContext) => {
  270. const ctx = asyncContext.tryUse();
  271. if (!ctx) {
  272. return;
  273. }
  274. try {
  275. const reducers = Object.assign(/* @__PURE__ */ Object.create(null), devReducers, ctx.event.context._payloadReducers);
  276. htmlContext.bodyAppend.unshift(`<script type="application/json" data-nuxt-logs="${appId}">${stringify(ctx.logs, reducers)}<\/script>`);
  277. } catch (e) {
  278. const shortError = e instanceof Error && "toString" in e ? ` Received \`${e.toString()}\`.` : "";
  279. console.warn(`[nuxt] Failed to stringify dev server logs.${shortError} You can define your own reducer/reviver for rich types following the instructions in https://nuxt.com/docs/api/composables/use-nuxt-app#payload.`);
  280. }
  281. });
  282. };
  283. const EXCLUDE_TRACE_RE = /\/node_modules\/(?:.*\/)?(?:nuxt|nuxt-nightly|nuxt-edge|nuxt3|consola|@vue)\/|core\/runtime\/nitro/;
  284. function onConsoleLog(callback) {
  285. consola.addReporter({
  286. log(logObj) {
  287. callback(logObj);
  288. }
  289. });
  290. consola.wrapConsole();
  291. }
  292. const plugins = [
  293. <<<<<<< HEAD
  294. _o3yZBW1Rnc,
  295. _e2UTql7fjT
  296. ];
  297. const _lazy_jrhRVs = () => Promise.resolve().then(function () { return index; });
  298. const _lazy_rdHII7 = () => Promise.resolve().then(function () { return renderer$1; });
  299. const handlers = [
  300. { route: '/api', handler: _lazy_jrhRVs, lazy: true, middleware: false, method: undefined },
  301. { route: '/__nuxt_error', handler: _lazy_rdHII7, lazy: true, middleware: false, method: undefined },
  302. { route: '/**', handler: _lazy_rdHII7, lazy: true, middleware: false, method: undefined }
  303. ];
  304. const serverAssets = [{"baseName":"server","dir":"D:/dev/nuxt/sannongzixunwang_web/server/assets"}];
  305. =======
  306. _MoCGaRUN7w,
  307. _oeSAu3NnQa
  308. ];
  309. const _lazy_MneAP7 = () => Promise.resolve().then(function () { return index; });
  310. const _lazy_spp1nD = () => Promise.resolve().then(function () { return renderer$1; });
  311. const handlers = [
  312. { route: '/api', handler: _lazy_MneAP7, lazy: true, middleware: false, method: undefined },
  313. { route: '/__nuxt_error', handler: _lazy_spp1nD, lazy: true, middleware: false, method: undefined },
  314. { route: '/**', handler: _lazy_spp1nD, lazy: true, middleware: false, method: undefined }
  315. ];
  316. const serverAssets = [{"baseName":"server","dir":"D:/MyProject/105/sannongzixunwang_web/server/assets"}];
  317. >>>>>>> b7384efd13504e61e59724eb6cefc1617c5b0127
  318. const assets = createStorage();
  319. for (const asset of serverAssets) {
  320. assets.mount(asset.baseName, unstorage_47drivers_47fs({ base: asset.dir, ignore: (asset?.ignore || []) }));
  321. }
  322. const storage = createStorage({});
  323. storage.mount('/assets', assets);
  324. <<<<<<< HEAD
  325. storage.mount('root', unstorage_47drivers_47fs({"driver":"fs","readOnly":true,"base":"D:\\dev\\nuxt\\sannongzixunwang_web","ignore":["**/node_modules/**","**/.git/**"]}));
  326. storage.mount('src', unstorage_47drivers_47fs({"driver":"fs","readOnly":true,"base":"D:\\dev\\nuxt\\sannongzixunwang_web\\server","ignore":["**/node_modules/**","**/.git/**"]}));
  327. storage.mount('build', unstorage_47drivers_47fs({"driver":"fs","readOnly":false,"base":"D:\\dev\\nuxt\\sannongzixunwang_web\\.nuxt","ignore":["**/node_modules/**","**/.git/**"]}));
  328. storage.mount('cache', unstorage_47drivers_47fs({"driver":"fs","readOnly":false,"base":"D:\\dev\\nuxt\\sannongzixunwang_web\\.nuxt\\cache","ignore":["**/node_modules/**","**/.git/**"]}));
  329. storage.mount('data', unstorage_47drivers_47fs({"driver":"fs","base":"D:\\dev\\nuxt\\sannongzixunwang_web\\.data\\kv","ignore":["**/node_modules/**","**/.git/**"]}));
  330. =======
  331. storage.mount('root', unstorage_47drivers_47fs({"driver":"fs","readOnly":true,"base":"D:\\MyProject\\105\\sannongzixunwang_web","ignore":["**/node_modules/**","**/.git/**"]}));
  332. storage.mount('src', unstorage_47drivers_47fs({"driver":"fs","readOnly":true,"base":"D:\\MyProject\\105\\sannongzixunwang_web\\server","ignore":["**/node_modules/**","**/.git/**"]}));
  333. storage.mount('build', unstorage_47drivers_47fs({"driver":"fs","readOnly":false,"base":"D:\\MyProject\\105\\sannongzixunwang_web\\.nuxt","ignore":["**/node_modules/**","**/.git/**"]}));
  334. storage.mount('cache', unstorage_47drivers_47fs({"driver":"fs","readOnly":false,"base":"D:\\MyProject\\105\\sannongzixunwang_web\\.nuxt\\cache","ignore":["**/node_modules/**","**/.git/**"]}));
  335. storage.mount('data', unstorage_47drivers_47fs({"driver":"fs","base":"D:\\MyProject\\105\\sannongzixunwang_web\\.data\\kv","ignore":["**/node_modules/**","**/.git/**"]}));
  336. >>>>>>> b7384efd13504e61e59724eb6cefc1617c5b0127
  337. function useStorage(base = "") {
  338. return base ? prefixStorage(storage, base) : storage;
  339. }
  340. function defaultCacheOptions() {
  341. return {
  342. name: "_",
  343. base: "/cache",
  344. swr: true,
  345. maxAge: 1
  346. };
  347. }
  348. function defineCachedFunction(fn, opts = {}) {
  349. opts = { ...defaultCacheOptions(), ...opts };
  350. const pending = {};
  351. const group = opts.group || "nitro/functions";
  352. const name = opts.name || fn.name || "_";
  353. const integrity = opts.integrity || hash([fn, opts]);
  354. const validate = opts.validate || ((entry) => entry.value !== undefined);
  355. async function get(key, resolver, shouldInvalidateCache, event) {
  356. const cacheKey = [opts.base, group, name, key + ".json"].filter(Boolean).join(":").replace(/:\/$/, ":index");
  357. let entry = await useStorage().getItem(cacheKey).catch((error) => {
  358. console.error(`[nitro] [cache] Cache read error.`, error);
  359. useNitroApp().captureError(error, { event, tags: ["cache"] });
  360. }) || {};
  361. if (typeof entry !== "object") {
  362. entry = {};
  363. const error = new Error("Malformed data read from cache.");
  364. console.error("[nitro] [cache]", error);
  365. useNitroApp().captureError(error, { event, tags: ["cache"] });
  366. }
  367. const ttl = (opts.maxAge ?? 0) * 1e3;
  368. if (ttl) {
  369. entry.expires = Date.now() + ttl;
  370. }
  371. const expired = shouldInvalidateCache || entry.integrity !== integrity || ttl && Date.now() - (entry.mtime || 0) > ttl || validate(entry) === false;
  372. const _resolve = async () => {
  373. const isPending = pending[key];
  374. if (!isPending) {
  375. if (entry.value !== undefined && (opts.staleMaxAge || 0) >= 0 && opts.swr === false) {
  376. entry.value = undefined;
  377. entry.integrity = undefined;
  378. entry.mtime = undefined;
  379. entry.expires = undefined;
  380. }
  381. pending[key] = Promise.resolve(resolver());
  382. }
  383. try {
  384. entry.value = await pending[key];
  385. } catch (error) {
  386. if (!isPending) {
  387. delete pending[key];
  388. }
  389. throw error;
  390. }
  391. if (!isPending) {
  392. entry.mtime = Date.now();
  393. entry.integrity = integrity;
  394. delete pending[key];
  395. if (validate(entry) !== false) {
  396. let setOpts;
  397. if (opts.maxAge && !opts.swr) {
  398. setOpts = { ttl: opts.maxAge };
  399. }
  400. const promise = useStorage().setItem(cacheKey, entry, setOpts).catch((error) => {
  401. console.error(`[nitro] [cache] Cache write error.`, error);
  402. useNitroApp().captureError(error, { event, tags: ["cache"] });
  403. });
  404. if (event?.waitUntil) {
  405. event.waitUntil(promise);
  406. }
  407. }
  408. }
  409. };
  410. const _resolvePromise = expired ? _resolve() : Promise.resolve();
  411. if (entry.value === undefined) {
  412. await _resolvePromise;
  413. } else if (expired && event && event.waitUntil) {
  414. event.waitUntil(_resolvePromise);
  415. }
  416. if (opts.swr && validate(entry) !== false) {
  417. _resolvePromise.catch((error) => {
  418. console.error(`[nitro] [cache] SWR handler error.`, error);
  419. useNitroApp().captureError(error, { event, tags: ["cache"] });
  420. });
  421. return entry;
  422. }
  423. return _resolvePromise.then(() => entry);
  424. }
  425. return async (...args) => {
  426. const shouldBypassCache = await opts.shouldBypassCache?.(...args);
  427. if (shouldBypassCache) {
  428. return fn(...args);
  429. }
  430. const key = await (opts.getKey || getKey)(...args);
  431. const shouldInvalidateCache = await opts.shouldInvalidateCache?.(...args);
  432. const entry = await get(
  433. key,
  434. () => fn(...args),
  435. shouldInvalidateCache,
  436. args[0] && isEvent(args[0]) ? args[0] : undefined
  437. );
  438. let value = entry.value;
  439. if (opts.transform) {
  440. value = await opts.transform(entry, ...args) || value;
  441. }
  442. return value;
  443. };
  444. }
  445. function cachedFunction(fn, opts = {}) {
  446. return defineCachedFunction(fn, opts);
  447. }
  448. function getKey(...args) {
  449. return args.length > 0 ? hash(args, {}) : "";
  450. }
  451. function escapeKey(key) {
  452. return String(key).replace(/\W/g, "");
  453. }
  454. function defineCachedEventHandler(handler, opts = defaultCacheOptions()) {
  455. const variableHeaderNames = (opts.varies || []).filter(Boolean).map((h) => h.toLowerCase()).sort();
  456. const _opts = {
  457. ...opts,
  458. getKey: async (event) => {
  459. const customKey = await opts.getKey?.(event);
  460. if (customKey) {
  461. return escapeKey(customKey);
  462. }
  463. const _path = event.node.req.originalUrl || event.node.req.url || event.path;
  464. let _pathname;
  465. try {
  466. _pathname = escapeKey(decodeURI(parseURL(_path).pathname)).slice(0, 16) || "index";
  467. } catch {
  468. _pathname = "-";
  469. }
  470. const _hashedPath = `${_pathname}.${hash(_path)}`;
  471. const _headers = variableHeaderNames.map((header) => [header, event.node.req.headers[header]]).map(([name, value]) => `${escapeKey(name)}.${hash(value)}`);
  472. return [_hashedPath, ..._headers].join(":");
  473. },
  474. validate: (entry) => {
  475. if (!entry.value) {
  476. return false;
  477. }
  478. if (entry.value.code >= 400) {
  479. return false;
  480. }
  481. if (entry.value.body === undefined) {
  482. return false;
  483. }
  484. if (entry.value.headers.etag === "undefined" || entry.value.headers["last-modified"] === "undefined") {
  485. return false;
  486. }
  487. return true;
  488. },
  489. group: opts.group || "nitro/handlers",
  490. integrity: opts.integrity || hash([handler, opts])
  491. };
  492. const _cachedHandler = cachedFunction(
  493. async (incomingEvent) => {
  494. const variableHeaders = {};
  495. for (const header of variableHeaderNames) {
  496. const value = incomingEvent.node.req.headers[header];
  497. if (value !== undefined) {
  498. variableHeaders[header] = value;
  499. }
  500. }
  501. const reqProxy = cloneWithProxy(incomingEvent.node.req, {
  502. headers: variableHeaders
  503. });
  504. const resHeaders = {};
  505. let _resSendBody;
  506. const resProxy = cloneWithProxy(incomingEvent.node.res, {
  507. statusCode: 200,
  508. writableEnded: false,
  509. writableFinished: false,
  510. headersSent: false,
  511. closed: false,
  512. getHeader(name) {
  513. return resHeaders[name];
  514. },
  515. setHeader(name, value) {
  516. resHeaders[name] = value;
  517. return this;
  518. },
  519. getHeaderNames() {
  520. return Object.keys(resHeaders);
  521. },
  522. hasHeader(name) {
  523. return name in resHeaders;
  524. },
  525. removeHeader(name) {
  526. delete resHeaders[name];
  527. },
  528. getHeaders() {
  529. return resHeaders;
  530. },
  531. end(chunk, arg2, arg3) {
  532. if (typeof chunk === "string") {
  533. _resSendBody = chunk;
  534. }
  535. if (typeof arg2 === "function") {
  536. arg2();
  537. }
  538. if (typeof arg3 === "function") {
  539. arg3();
  540. }
  541. return this;
  542. },
  543. write(chunk, arg2, arg3) {
  544. if (typeof chunk === "string") {
  545. _resSendBody = chunk;
  546. }
  547. if (typeof arg2 === "function") {
  548. arg2(undefined);
  549. }
  550. if (typeof arg3 === "function") {
  551. arg3();
  552. }
  553. return true;
  554. },
  555. writeHead(statusCode, headers2) {
  556. this.statusCode = statusCode;
  557. if (headers2) {
  558. if (Array.isArray(headers2) || typeof headers2 === "string") {
  559. throw new TypeError("Raw headers is not supported.");
  560. }
  561. for (const header in headers2) {
  562. const value = headers2[header];
  563. if (value !== undefined) {
  564. this.setHeader(
  565. header,
  566. value
  567. );
  568. }
  569. }
  570. }
  571. return this;
  572. }
  573. });
  574. const event = createEvent(reqProxy, resProxy);
  575. event.fetch = (url, fetchOptions) => fetchWithEvent(event, url, fetchOptions, {
  576. fetch: useNitroApp().localFetch
  577. });
  578. event.$fetch = (url, fetchOptions) => fetchWithEvent(event, url, fetchOptions, {
  579. fetch: globalThis.$fetch
  580. });
  581. event.context = incomingEvent.context;
  582. event.context.cache = {
  583. options: _opts
  584. };
  585. const body = await handler(event) || _resSendBody;
  586. const headers = event.node.res.getHeaders();
  587. headers.etag = String(
  588. headers.Etag || headers.etag || `W/"${hash(body)}"`
  589. );
  590. headers["last-modified"] = String(
  591. headers["Last-Modified"] || headers["last-modified"] || (/* @__PURE__ */ new Date()).toUTCString()
  592. );
  593. const cacheControl = [];
  594. if (opts.swr) {
  595. if (opts.maxAge) {
  596. cacheControl.push(`s-maxage=${opts.maxAge}`);
  597. }
  598. if (opts.staleMaxAge) {
  599. cacheControl.push(`stale-while-revalidate=${opts.staleMaxAge}`);
  600. } else {
  601. cacheControl.push("stale-while-revalidate");
  602. }
  603. } else if (opts.maxAge) {
  604. cacheControl.push(`max-age=${opts.maxAge}`);
  605. }
  606. if (cacheControl.length > 0) {
  607. headers["cache-control"] = cacheControl.join(", ");
  608. }
  609. const cacheEntry = {
  610. code: event.node.res.statusCode,
  611. headers,
  612. body
  613. };
  614. return cacheEntry;
  615. },
  616. _opts
  617. );
  618. return defineEventHandler(async (event) => {
  619. if (opts.headersOnly) {
  620. if (handleCacheHeaders(event, { maxAge: opts.maxAge })) {
  621. return;
  622. }
  623. return handler(event);
  624. }
  625. const response = await _cachedHandler(
  626. event
  627. );
  628. if (event.node.res.headersSent || event.node.res.writableEnded) {
  629. return response.body;
  630. }
  631. if (handleCacheHeaders(event, {
  632. modifiedTime: new Date(response.headers["last-modified"]),
  633. etag: response.headers.etag,
  634. maxAge: opts.maxAge
  635. })) {
  636. return;
  637. }
  638. event.node.res.statusCode = response.code;
  639. for (const name in response.headers) {
  640. const value = response.headers[name];
  641. if (name === "set-cookie") {
  642. event.node.res.appendHeader(
  643. name,
  644. splitCookiesString(value)
  645. );
  646. } else {
  647. if (value !== undefined) {
  648. event.node.res.setHeader(name, value);
  649. }
  650. }
  651. }
  652. return response.body;
  653. });
  654. }
  655. function cloneWithProxy(obj, overrides) {
  656. return new Proxy(obj, {
  657. get(target, property, receiver) {
  658. if (property in overrides) {
  659. return overrides[property];
  660. }
  661. return Reflect.get(target, property, receiver);
  662. },
  663. set(target, property, value, receiver) {
  664. if (property in overrides) {
  665. overrides[property] = value;
  666. return true;
  667. }
  668. return Reflect.set(target, property, value, receiver);
  669. }
  670. });
  671. }
  672. const cachedEventHandler = defineCachedEventHandler;
  673. const inlineAppConfig = {
  674. "nuxt": {}
  675. };
  676. const appConfig = defuFn(inlineAppConfig);
  677. function getEnv(key, opts) {
  678. const envKey = snakeCase(key).toUpperCase();
  679. return destr(
  680. process.env[opts.prefix + envKey] ?? process.env[opts.altPrefix + envKey]
  681. );
  682. }
  683. function _isObject(input) {
  684. return typeof input === "object" && !Array.isArray(input);
  685. }
  686. function applyEnv(obj, opts, parentKey = "") {
  687. for (const key in obj) {
  688. const subKey = parentKey ? `${parentKey}_${key}` : key;
  689. const envValue = getEnv(subKey, opts);
  690. if (_isObject(obj[key])) {
  691. if (_isObject(envValue)) {
  692. obj[key] = { ...obj[key], ...envValue };
  693. applyEnv(obj[key], opts, subKey);
  694. } else if (envValue === undefined) {
  695. applyEnv(obj[key], opts, subKey);
  696. } else {
  697. obj[key] = envValue ?? obj[key];
  698. }
  699. } else {
  700. obj[key] = envValue ?? obj[key];
  701. }
  702. if (opts.envExpansion && typeof obj[key] === "string") {
  703. obj[key] = _expandFromEnv(obj[key]);
  704. }
  705. }
  706. return obj;
  707. }
  708. const envExpandRx = /{{(.*?)}}/g;
  709. function _expandFromEnv(value) {
  710. return value.replace(envExpandRx, (match, key) => {
  711. return process.env[key] || match;
  712. });
  713. }
  714. const _inlineRuntimeConfig = {
  715. "app": {
  716. "baseURL": "/",
  717. "buildId": "dev",
  718. "buildAssetsDir": "/_nuxt/",
  719. "cdnURL": ""
  720. },
  721. "nitro": {
  722. "envPrefix": "NUXT_",
  723. "routeRules": {
  724. "/__nuxt_error": {
  725. "cache": false
  726. },
  727. "/_nuxt/builds/meta/**": {
  728. "headers": {
  729. "cache-control": "public, max-age=31536000, immutable"
  730. }
  731. },
  732. "/_nuxt/builds/**": {
  733. "headers": {
  734. "cache-control": "public, max-age=1, immutable"
  735. }
  736. }
  737. }
  738. },
  739. "public": {}
  740. };
  741. const envOptions = {
  742. prefix: "NITRO_",
  743. altPrefix: _inlineRuntimeConfig.nitro.envPrefix ?? process.env.NITRO_ENV_PREFIX ?? "_",
  744. envExpansion: _inlineRuntimeConfig.nitro.envExpansion ?? process.env.NITRO_ENV_EXPANSION ?? false
  745. };
  746. const _sharedRuntimeConfig = _deepFreeze(
  747. applyEnv(klona(_inlineRuntimeConfig), envOptions)
  748. );
  749. function useRuntimeConfig(event) {
  750. if (!event) {
  751. return _sharedRuntimeConfig;
  752. }
  753. if (event.context.nitro.runtimeConfig) {
  754. return event.context.nitro.runtimeConfig;
  755. }
  756. const runtimeConfig = klona(_inlineRuntimeConfig);
  757. applyEnv(runtimeConfig, envOptions);
  758. event.context.nitro.runtimeConfig = runtimeConfig;
  759. return runtimeConfig;
  760. }
  761. _deepFreeze(klona(appConfig));
  762. function _deepFreeze(object) {
  763. const propNames = Object.getOwnPropertyNames(object);
  764. for (const name of propNames) {
  765. const value = object[name];
  766. if (value && typeof value === "object") {
  767. _deepFreeze(value);
  768. }
  769. }
  770. return Object.freeze(object);
  771. }
  772. new Proxy(/* @__PURE__ */ Object.create(null), {
  773. get: (_, prop) => {
  774. console.warn(
  775. "Please use `useRuntimeConfig()` instead of accessing config directly."
  776. );
  777. const runtimeConfig = useRuntimeConfig();
  778. if (prop in runtimeConfig) {
  779. return runtimeConfig[prop];
  780. }
  781. return undefined;
  782. }
  783. });
  784. const config = useRuntimeConfig();
  785. const _routeRulesMatcher = toRouteMatcher(
  786. createRouter({ routes: config.nitro.routeRules })
  787. );
  788. function createRouteRulesHandler(ctx) {
  789. return eventHandler((event) => {
  790. const routeRules = getRouteRules(event);
  791. if (routeRules.headers) {
  792. setHeaders(event, routeRules.headers);
  793. }
  794. if (routeRules.redirect) {
  795. let target = routeRules.redirect.to;
  796. if (target.endsWith("/**")) {
  797. let targetPath = event.path;
  798. const strpBase = routeRules.redirect._redirectStripBase;
  799. if (strpBase) {
  800. targetPath = withoutBase(targetPath, strpBase);
  801. }
  802. target = joinURL(target.slice(0, -3), targetPath);
  803. } else if (event.path.includes("?")) {
  804. const query = getQuery(event.path);
  805. target = withQuery(target, query);
  806. }
  807. return sendRedirect(event, target, routeRules.redirect.statusCode);
  808. }
  809. if (routeRules.proxy) {
  810. let target = routeRules.proxy.to;
  811. if (target.endsWith("/**")) {
  812. let targetPath = event.path;
  813. const strpBase = routeRules.proxy._proxyStripBase;
  814. if (strpBase) {
  815. targetPath = withoutBase(targetPath, strpBase);
  816. }
  817. target = joinURL(target.slice(0, -3), targetPath);
  818. } else if (event.path.includes("?")) {
  819. const query = getQuery(event.path);
  820. target = withQuery(target, query);
  821. }
  822. return proxyRequest(event, target, {
  823. fetch: ctx.localFetch,
  824. ...routeRules.proxy
  825. });
  826. }
  827. });
  828. }
  829. function getRouteRules(event) {
  830. event.context._nitro = event.context._nitro || {};
  831. if (!event.context._nitro.routeRules) {
  832. event.context._nitro.routeRules = getRouteRulesForPath(
  833. withoutBase(event.path.split("?")[0], useRuntimeConfig().app.baseURL)
  834. );
  835. }
  836. return event.context._nitro.routeRules;
  837. }
  838. function getRouteRulesForPath(path) {
  839. return defu({}, ..._routeRulesMatcher.matchAll(path).reverse());
  840. }
  841. function createNitroApp() {
  842. const config = useRuntimeConfig();
  843. const hooks = createHooks();
  844. const captureError = (error, context = {}) => {
  845. const promise = hooks.callHookParallel("error", error, context).catch((error_) => {
  846. console.error("Error while capturing another error", error_);
  847. });
  848. if (context.event && isEvent(context.event)) {
  849. const errors = context.event.context.nitro?.errors;
  850. if (errors) {
  851. errors.push({ error, context });
  852. }
  853. if (context.event.waitUntil) {
  854. context.event.waitUntil(promise);
  855. }
  856. }
  857. };
  858. const h3App = createApp({
  859. debug: destr(true),
  860. onError: (error, event) => {
  861. captureError(error, { event, tags: ["request"] });
  862. return errorHandler(error, event);
  863. },
  864. onRequest: async (event) => {
  865. await nitroApp$1.hooks.callHook("request", event).catch((error) => {
  866. captureError(error, { event, tags: ["request"] });
  867. });
  868. },
  869. onBeforeResponse: async (event, response) => {
  870. await nitroApp$1.hooks.callHook("beforeResponse", event, response).catch((error) => {
  871. captureError(error, { event, tags: ["request", "response"] });
  872. });
  873. },
  874. onAfterResponse: async (event, response) => {
  875. await nitroApp$1.hooks.callHook("afterResponse", event, response).catch((error) => {
  876. captureError(error, { event, tags: ["request", "response"] });
  877. });
  878. }
  879. });
  880. const router = createRouter$1({
  881. preemptive: true
  882. });
  883. const localCall = createCall(toNodeListener(h3App));
  884. const _localFetch = createFetch(localCall, globalThis.fetch);
  885. const localFetch = (input, init) => _localFetch(input, init).then(
  886. (response) => normalizeFetchResponse(response)
  887. );
  888. const $fetch = createFetch$1({
  889. fetch: localFetch,
  890. Headers: Headers$1,
  891. defaults: { baseURL: config.app.baseURL }
  892. });
  893. globalThis.$fetch = $fetch;
  894. h3App.use(createRouteRulesHandler({ localFetch }));
  895. h3App.use(
  896. eventHandler((event) => {
  897. event.context.nitro = event.context.nitro || { errors: [] };
  898. const envContext = event.node.req?.__unenv__;
  899. if (envContext) {
  900. Object.assign(event.context, envContext);
  901. }
  902. event.fetch = (req, init) => fetchWithEvent(event, req, init, { fetch: localFetch });
  903. event.$fetch = (req, init) => fetchWithEvent(event, req, init, {
  904. fetch: $fetch
  905. });
  906. event.waitUntil = (promise) => {
  907. if (!event.context.nitro._waitUntilPromises) {
  908. event.context.nitro._waitUntilPromises = [];
  909. }
  910. event.context.nitro._waitUntilPromises.push(promise);
  911. if (envContext?.waitUntil) {
  912. envContext.waitUntil(promise);
  913. }
  914. };
  915. event.captureError = (error, context) => {
  916. captureError(error, { event, ...context });
  917. };
  918. })
  919. );
  920. for (const h of handlers) {
  921. let handler = h.lazy ? lazyEventHandler(h.handler) : h.handler;
  922. if (h.middleware || !h.route) {
  923. const middlewareBase = (config.app.baseURL + (h.route || "/")).replace(
  924. /\/+/g,
  925. "/"
  926. );
  927. h3App.use(middlewareBase, handler);
  928. } else {
  929. const routeRules = getRouteRulesForPath(
  930. h.route.replace(/:\w+|\*\*/g, "_")
  931. );
  932. if (routeRules.cache) {
  933. handler = cachedEventHandler(handler, {
  934. group: "nitro/routes",
  935. ...routeRules.cache
  936. });
  937. }
  938. router.use(h.route, handler, h.method);
  939. }
  940. }
  941. h3App.use(config.app.baseURL, router.handler);
  942. const app = {
  943. hooks,
  944. h3App,
  945. router,
  946. localCall,
  947. localFetch,
  948. captureError
  949. };
  950. return app;
  951. }
  952. function runNitroPlugins(nitroApp2) {
  953. for (const plugin of plugins) {
  954. try {
  955. plugin(nitroApp2);
  956. } catch (error) {
  957. nitroApp2.captureError(error, { tags: ["plugin"] });
  958. throw error;
  959. }
  960. }
  961. }
  962. const nitroApp$1 = createNitroApp();
  963. function useNitroApp() {
  964. return nitroApp$1;
  965. }
  966. runNitroPlugins(nitroApp$1);
  967. function defineRenderHandler(render) {
  968. const runtimeConfig = useRuntimeConfig();
  969. return eventHandler(async (event) => {
  970. const nitroApp = useNitroApp();
  971. const ctx = { event, render, response: undefined };
  972. await nitroApp.hooks.callHook("render:before", ctx);
  973. if (!ctx.response) {
  974. if (event.path === `${runtimeConfig.app.baseURL}favicon.ico`) {
  975. setResponseHeader(event, "Content-Type", "image/x-icon");
  976. return send(
  977. event,
  978. "data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7"
  979. );
  980. }
  981. ctx.response = await ctx.render(event);
  982. if (!ctx.response) {
  983. const _currentStatus = getResponseStatus(event);
  984. setResponseStatus(event, _currentStatus === 200 ? 500 : _currentStatus);
  985. return send(
  986. event,
  987. "No response returned from render handler: " + event.path
  988. );
  989. }
  990. }
  991. await nitroApp.hooks.callHook("render:response", ctx.response, ctx);
  992. if (ctx.response.headers) {
  993. setResponseHeaders(event, ctx.response.headers);
  994. }
  995. if (ctx.response.statusCode || ctx.response.statusMessage) {
  996. setResponseStatus(
  997. event,
  998. ctx.response.statusCode,
  999. ctx.response.statusMessage
  1000. );
  1001. }
  1002. return ctx.response.body;
  1003. });
  1004. }
  1005. const r=Object.create(null),i=e=>globalThis.process?.env||globalThis._importMeta_.env||globalThis.Deno?.env.toObject()||globalThis.__env__||(e?r:globalThis),s=new Proxy(r,{get(e,o){return i()[o]??r[o]},has(e,o){const E=i();return o in E||o in r},set(e,o,E){const b=i(true);return b[o]=E,true},deleteProperty(e,o){if(!o)return false;const E=i(true);return delete E[o],true},ownKeys(){const e=i(true);return Object.keys(e)}}),t=typeof process<"u"&&process.env&&"development"||"",B=[["APPVEYOR"],["AWS_AMPLIFY","AWS_APP_ID",{ci:true}],["AZURE_PIPELINES","SYSTEM_TEAMFOUNDATIONCOLLECTIONURI"],["AZURE_STATIC","INPUT_AZURE_STATIC_WEB_APPS_API_TOKEN"],["APPCIRCLE","AC_APPCIRCLE"],["BAMBOO","bamboo_planKey"],["BITBUCKET","BITBUCKET_COMMIT"],["BITRISE","BITRISE_IO"],["BUDDY","BUDDY_WORKSPACE_ID"],["BUILDKITE"],["CIRCLE","CIRCLECI"],["CIRRUS","CIRRUS_CI"],["CLOUDFLARE_PAGES","CF_PAGES",{ci:true}],["CODEBUILD","CODEBUILD_BUILD_ARN"],["CODEFRESH","CF_BUILD_ID"],["DRONE"],["DRONE","DRONE_BUILD_EVENT"],["DSARI"],["GITHUB_ACTIONS"],["GITLAB","GITLAB_CI"],["GITLAB","CI_MERGE_REQUEST_ID"],["GOCD","GO_PIPELINE_LABEL"],["LAYERCI"],["HUDSON","HUDSON_URL"],["JENKINS","JENKINS_URL"],["MAGNUM"],["NETLIFY"],["NETLIFY","NETLIFY_LOCAL",{ci:false}],["NEVERCODE"],["RENDER"],["SAIL","SAILCI"],["SEMAPHORE"],["SCREWDRIVER"],["SHIPPABLE"],["SOLANO","TDDIUM"],["STRIDER"],["TEAMCITY","TEAMCITY_VERSION"],["TRAVIS"],["VERCEL","NOW_BUILDER"],["VERCEL","VERCEL",{ci:false}],["VERCEL","VERCEL_ENV",{ci:false}],["APPCENTER","APPCENTER_BUILD_ID"],["CODESANDBOX","CODESANDBOX_SSE",{ci:false}],["STACKBLITZ"],["STORMKIT"],["CLEAVR"],["ZEABUR"],["CODESPHERE","CODESPHERE_APP_ID",{ci:true}],["RAILWAY","RAILWAY_PROJECT_ID"],["RAILWAY","RAILWAY_SERVICE_ID"],["DENO-DEPLOY","DENO_DEPLOYMENT_ID"],["FIREBASE_APP_HOSTING","FIREBASE_APP_HOSTING",{ci:true}]];function p(){if(globalThis.process?.env)for(const e of B){const o=e[1]||e[0];if(globalThis.process?.env[o])return {name:e[0].toLowerCase(),...e[2]}}return globalThis.process?.env?.SHELL==="/bin/jsh"&&globalThis.process?.versions?.webcontainer?{name:"stackblitz",ci:false}:{name:"",ci:false}}const l=p(),d=l.name;function n(e){return e?e!=="false":false}const I=globalThis.process?.platform||"",T=n(s.CI)||l.ci!==false,R=n(globalThis.process?.stdout&&globalThis.process?.stdout.isTTY);n(s.DEBUG);const A=t==="test"||n(s.TEST);n(s.MINIMAL)||T||A||!R;const _=/^win/i.test(I);!n(s.NO_COLOR)&&(n(s.FORCE_COLOR)||(R||_)&&s.TERM!=="dumb"||T);const C=(globalThis.process?.versions?.node||"").replace(/^v/,"")||null;Number(C?.split(".")[0])||null;const y=globalThis.process||Object.create(null),c={versions:{}};new Proxy(y,{get(e,o){if(o==="env")return s;if(o in e)return e[o];if(o in c)return c[o]}});const L=globalThis.process?.release?.name==="node",a=!!globalThis.Bun||!!globalThis.process?.versions?.bun,D=!!globalThis.Deno,O=!!globalThis.fastly,S=!!globalThis.Netlify,N=!!globalThis.EdgeRuntime,P=globalThis.navigator?.userAgent==="Cloudflare-Workers",F=[[S,"netlify"],[N,"edge-light"],[P,"workerd"],[O,"fastly"],[D,"deno"],[a,"bun"],[L,"node"]];function G(){const e=F.find(o=>o[0]);if(e)return {name:e[1]}}const u=G();u?.name||"";
  1006. const scheduledTasks = false;
  1007. const tasks = {
  1008. };
  1009. const __runningTasks__ = {};
  1010. async function runTask(name, {
  1011. payload = {},
  1012. context = {}
  1013. } = {}) {
  1014. if (__runningTasks__[name]) {
  1015. return __runningTasks__[name];
  1016. }
  1017. if (!(name in tasks)) {
  1018. throw createError({
  1019. message: `Task \`${name}\` is not available!`,
  1020. statusCode: 404
  1021. });
  1022. }
  1023. if (!tasks[name].resolve) {
  1024. throw createError({
  1025. message: `Task \`${name}\` is not implemented!`,
  1026. statusCode: 501
  1027. });
  1028. }
  1029. const handler = await tasks[name].resolve();
  1030. const taskEvent = { name, payload, context };
  1031. __runningTasks__[name] = handler.run(taskEvent);
  1032. try {
  1033. const res = await __runningTasks__[name];
  1034. return res;
  1035. } finally {
  1036. delete __runningTasks__[name];
  1037. }
  1038. }
  1039. const nitroApp = useNitroApp();
  1040. const server = new Server(toNodeListener(nitroApp.h3App));
  1041. function getAddress() {
  1042. if (d === "stackblitz" || process.env.NITRO_NO_UNIX_SOCKET || process.versions.bun) {
  1043. return 0;
  1044. }
  1045. const socketName = `worker-${process.pid}-${threadId}.sock`;
  1046. if (_) {
  1047. return join(String.raw`\\.\pipe\nitro`, socketName);
  1048. }
  1049. const socketDir = join(tmpdir(), "nitro");
  1050. mkdirSync(socketDir, { recursive: true });
  1051. return join(socketDir, socketName);
  1052. }
  1053. const listenAddress = getAddress();
  1054. server.listen(listenAddress, () => {
  1055. const _address = server.address();
  1056. parentPort?.postMessage({
  1057. event: "listen",
  1058. address: typeof _address === "string" ? { socketPath: _address } : { host: "localhost", port: _address?.port }
  1059. });
  1060. });
  1061. nitroApp.router.get(
  1062. "/_nitro/tasks",
  1063. defineEventHandler(async (event) => {
  1064. const _tasks = await Promise.all(
  1065. Object.entries(tasks).map(async ([name, task]) => {
  1066. const _task = await task.resolve?.();
  1067. return [name, { description: _task?.meta?.description }];
  1068. })
  1069. );
  1070. return {
  1071. tasks: Object.fromEntries(_tasks),
  1072. scheduledTasks
  1073. };
  1074. })
  1075. );
  1076. nitroApp.router.use(
  1077. "/_nitro/tasks/:name",
  1078. defineEventHandler(async (event) => {
  1079. const name = getRouterParam(event, "name");
  1080. const payload = {
  1081. ...getQuery$1(event),
  1082. ...await readBody(event).then((r) => r?.payload).catch(() => ({}))
  1083. };
  1084. return await runTask(name, { payload });
  1085. })
  1086. );
  1087. trapUnhandledNodeErrors();
  1088. async function onShutdown(signal) {
  1089. await nitroApp.hooks.callHook("close");
  1090. }
  1091. parentPort?.on("message", async (msg) => {
  1092. if (msg && msg.event === "shutdown") {
  1093. await onShutdown();
  1094. parentPort?.postMessage({ event: "exit" });
  1095. }
  1096. });
  1097. const _messages = { "appName": "Nuxt", "version": "", "statusCode": 500, "statusMessage": "Server error", "description": "An error occurred in the application and the page could not be served. If you are the application owner, check your server logs for details.", "stack": "" };
  1098. const template$1 = (messages) => {
  1099. messages = { ..._messages, ...messages };
  1100. return '<!DOCTYPE html><html lang="en"><head><title>' + messages.statusCode + " - " + messages.statusMessage + " | " + messages.appName + `</title><meta charset="utf-8"><meta content="width=device-width,initial-scale=1.0,minimum-scale=1.0" name="viewport"><style>.spotlight{background:linear-gradient(45deg,#00dc82,#36e4da 50%,#0047e1);bottom:-40vh;filter:blur(30vh);height:60vh;opacity:.8}*,:after,:before{border-color:var(--un-default-border-color,#e5e7eb);border-style:solid;border-width:0;box-sizing:border-box}:after,:before{--un-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-moz-tab-size:4;tab-size:4;-webkit-tap-highlight-color:transparent}body{line-height:inherit;margin:0}h1{font-size:inherit;font-weight:inherit}pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-size:1em;font-variation-settings:normal}h1,p,pre{margin:0}*,:after,:before{--un-rotate:0;--un-rotate-x:0;--un-rotate-y:0;--un-rotate-z:0;--un-scale-x:1;--un-scale-y:1;--un-scale-z:1;--un-skew-x:0;--un-skew-y:0;--un-translate-x:0;--un-translate-y:0;--un-translate-z:0;--un-pan-x: ;--un-pan-y: ;--un-pinch-zoom: ;--un-scroll-snap-strictness:proximity;--un-ordinal: ;--un-slashed-zero: ;--un-numeric-figure: ;--un-numeric-spacing: ;--un-numeric-fraction: ;--un-border-spacing-x:0;--un-border-spacing-y:0;--un-ring-offset-shadow:0 0 transparent;--un-ring-shadow:0 0 transparent;--un-shadow-inset: ;--un-shadow:0 0 transparent;--un-ring-inset: ;--un-ring-offset-width:0px;--un-ring-offset-color:#fff;--un-ring-width:0px;--un-ring-color:rgba(147,197,253,.5);--un-blur: ;--un-brightness: ;--un-contrast: ;--un-drop-shadow: ;--un-grayscale: ;--un-hue-rotate: ;--un-invert: ;--un-saturate: ;--un-sepia: ;--un-backdrop-blur: ;--un-backdrop-brightness: ;--un-backdrop-contrast: ;--un-backdrop-grayscale: ;--un-backdrop-hue-rotate: ;--un-backdrop-invert: ;--un-backdrop-opacity: ;--un-backdrop-saturate: ;--un-backdrop-sepia: }.fixed{position:fixed}.left-0{left:0}.right-0{right:0}.z-10{z-index:10}.mb-6{margin-bottom:1.5rem}.mb-8{margin-bottom:2rem}.h-auto{height:auto}.min-h-screen{min-height:100vh}.flex{display:flex}.flex-1{flex:1 1 0%}.flex-col{flex-direction:column}.overflow-y-auto{overflow-y:auto}.rounded-t-md{border-top-left-radius:.375rem;border-top-right-radius:.375rem}.bg-black\\/5{background-color:#0000000d}.bg-white{--un-bg-opacity:1;background-color:rgb(255 255 255/var(--un-bg-opacity))}.p-8{padding:2rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.pt-14{padding-top:3.5rem}.text-6xl{font-size:3.75rem;line-height:1}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-black{--un-text-opacity:1;color:rgb(0 0 0/var(--un-text-opacity))}.font-light{font-weight:300}.font-medium{font-weight:500}.leading-tight{line-height:1.25}.font-sans{font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji}.antialiased{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){.dark\\:bg-black{--un-bg-opacity:1;background-color:rgb(0 0 0/var(--un-bg-opacity))}.dark\\:bg-white\\/10{background-color:#ffffff1a}.dark\\:text-white{--un-text-opacity:1;color:rgb(255 255 255/var(--un-text-opacity))}}@media (min-width:640px){.sm\\:text-2xl{font-size:1.5rem;line-height:2rem}.sm\\:text-8xl{font-size:6rem;line-height:1}}</style><script>!function(){const e=document.createElement("link").relList;if(!(e&&e.supports&&e.supports("modulepreload"))){for(const e of document.querySelectorAll('link[rel="modulepreload"]'))r(e);new MutationObserver((e=>{for(const o of e)if("childList"===o.type)for(const e of o.addedNodes)"LINK"===e.tagName&&"modulepreload"===e.rel&&r(e)})).observe(document,{childList:!0,subtree:!0})}function r(e){if(e.ep)return;e.ep=!0;const r=function(e){const r={};return e.integrity&&(r.integrity=e.integrity),e.referrerPolicy&&(r.referrerPolicy=e.referrerPolicy),"use-credentials"===e.crossOrigin?r.credentials="include":"anonymous"===e.crossOrigin?r.credentials="omit":r.credentials="same-origin",r}(e);fetch(e.href,r)}}();<\/script></head><body class="antialiased bg-white dark:bg-black dark:text-white flex flex-col font-sans min-h-screen pt-14 px-10 text-black"><div class="fixed left-0 right-0 spotlight"></div><h1 class="font-medium mb-6 sm:text-8xl text-6xl">` + messages.statusCode + '</h1><p class="font-light leading-tight mb-8 sm:text-2xl text-xl">' + messages.description + '</p><div class="bg-black/5 bg-white dark:bg-white/10 flex-1 h-auto overflow-y-auto rounded-t-md"><pre class="font-light leading-tight p-8 text-xl z-10">' + messages.stack + "</pre></div></body></html>";
  1101. };
  1102. const errorDev = /*#__PURE__*/Object.freeze({
  1103. __proto__: null,
  1104. template: template$1
  1105. });
  1106. const index = /*#__PURE__*/Object.freeze({
  1107. __proto__: null
  1108. });
  1109. const Vue3 = version[0] === "3";
  1110. function resolveUnref(r) {
  1111. return typeof r === "function" ? r() : unref(r);
  1112. }
  1113. function resolveUnrefHeadInput(ref) {
  1114. if (ref instanceof Promise || ref instanceof Date || ref instanceof RegExp)
  1115. return ref;
  1116. const root = resolveUnref(ref);
  1117. if (!ref || !root)
  1118. return root;
  1119. if (Array.isArray(root))
  1120. return root.map((r) => resolveUnrefHeadInput(r));
  1121. if (typeof root === "object") {
  1122. const resolved = {};
  1123. for (const k in root) {
  1124. if (!Object.prototype.hasOwnProperty.call(root, k)) {
  1125. continue;
  1126. }
  1127. if (k === "titleTemplate" || k[0] === "o" && k[1] === "n") {
  1128. resolved[k] = unref(root[k]);
  1129. continue;
  1130. }
  1131. resolved[k] = resolveUnrefHeadInput(root[k]);
  1132. }
  1133. return resolved;
  1134. }
  1135. return root;
  1136. }
  1137. const VueReactivityPlugin = defineHeadPlugin({
  1138. hooks: {
  1139. "entries:resolve": (ctx) => {
  1140. for (const entry of ctx.entries)
  1141. entry.resolvedInput = resolveUnrefHeadInput(entry.input);
  1142. }
  1143. }
  1144. });
  1145. const headSymbol = "usehead";
  1146. function vueInstall(head) {
  1147. const plugin = {
  1148. install(app) {
  1149. if (Vue3) {
  1150. app.config.globalProperties.$unhead = head;
  1151. app.config.globalProperties.$head = head;
  1152. app.provide(headSymbol, head);
  1153. }
  1154. }
  1155. };
  1156. return plugin.install;
  1157. }
  1158. function createServerHead(options = {}) {
  1159. const head = createServerHead$1(options);
  1160. head.use(VueReactivityPlugin);
  1161. head.install = vueInstall(head);
  1162. return head;
  1163. }
  1164. const unheadPlugins = true ? [CapoPlugin({ track: true })] : [];
  1165. const renderSSRHeadOptions = {"omitLineBreaks":false};
  1166. function buildAssetsDir() {
  1167. return useRuntimeConfig().app.buildAssetsDir;
  1168. }
  1169. function buildAssetsURL(...path) {
  1170. return joinRelativeURL(publicAssetsURL(), buildAssetsDir(), ...path);
  1171. }
  1172. function publicAssetsURL(...path) {
  1173. const app = useRuntimeConfig().app;
  1174. const publicBase = app.cdnURL || app.baseURL;
  1175. return path.length ? joinRelativeURL(publicBase, ...path) : publicBase;
  1176. }
  1177. globalThis.__buildAssetsURL = buildAssetsURL;
  1178. globalThis.__publicAssetsURL = publicAssetsURL;
  1179. <<<<<<< HEAD
  1180. const getClientManifest = () => import('file://D:/dev/nuxt/sannongzixunwang_web/.nuxt/dist/server/client.manifest.mjs').then((r) => r.default || r).then((r) => typeof r === "function" ? r() : r);
  1181. const getServerEntry = () => import('file://D:/dev/nuxt/sannongzixunwang_web/.nuxt/dist/server/server.mjs').then((r) => r.default || r);
  1182. =======
  1183. const getClientManifest = () => import('file://D:/MyProject/105/sannongzixunwang_web/.nuxt/dist/server/client.manifest.mjs').then((r) => r.default || r).then((r) => typeof r === "function" ? r() : r);
  1184. const getServerEntry = () => import('file://D:/MyProject/105/sannongzixunwang_web/.nuxt/dist/server/server.mjs').then((r) => r.default || r);
  1185. >>>>>>> b7384efd13504e61e59724eb6cefc1617c5b0127
  1186. const getSSRStyles = lazyCachedFunction(() => Promise.resolve().then(function () { return styles$1; }).then((r) => r.default || r));
  1187. const getSSRRenderer = lazyCachedFunction(async () => {
  1188. const manifest = await getClientManifest();
  1189. if (!manifest) {
  1190. throw new Error("client.manifest is not available");
  1191. }
  1192. const createSSRApp = await getServerEntry();
  1193. if (!createSSRApp) {
  1194. throw new Error("Server bundle is not available");
  1195. }
  1196. const options = {
  1197. manifest,
  1198. renderToString: renderToString$1,
  1199. buildAssetsURL
  1200. };
  1201. const renderer = createRenderer(createSSRApp, options);
  1202. async function renderToString$1(input, context) {
  1203. const html = await renderToString(input, context);
  1204. if (process.env.NUXT_VITE_NODE_OPTIONS) {
  1205. renderer.rendererContext.updateManifest(await getClientManifest());
  1206. }
  1207. return APP_ROOT_OPEN_TAG + html + APP_ROOT_CLOSE_TAG;
  1208. }
  1209. return renderer;
  1210. });
  1211. const getSPARenderer = lazyCachedFunction(async () => {
  1212. const manifest = await getClientManifest();
  1213. const spaTemplate = await Promise.resolve().then(function () { return _virtual__spaTemplate; }).then((r) => r.template).catch(() => "").then((r) => {
  1214. {
  1215. return APP_ROOT_OPEN_TAG + r + APP_ROOT_CLOSE_TAG;
  1216. }
  1217. });
  1218. const options = {
  1219. manifest,
  1220. renderToString: () => spaTemplate,
  1221. buildAssetsURL
  1222. };
  1223. const renderer = createRenderer(() => () => {
  1224. }, options);
  1225. const result = await renderer.renderToString({});
  1226. const renderToString = (ssrContext) => {
  1227. const config = useRuntimeConfig(ssrContext.event);
  1228. ssrContext.modules = ssrContext.modules || /* @__PURE__ */ new Set();
  1229. ssrContext.payload.serverRendered = false;
  1230. ssrContext.config = {
  1231. public: config.public,
  1232. app: config.app
  1233. };
  1234. return Promise.resolve(result);
  1235. };
  1236. return {
  1237. rendererContext: renderer.rendererContext,
  1238. renderToString
  1239. };
  1240. });
  1241. const ISLAND_SUFFIX_RE = /\.json(\?.*)?$/;
  1242. async function getIslandContext(event) {
  1243. let url = event.path || "";
  1244. const componentParts = url.substring("/__nuxt_island".length + 1).replace(ISLAND_SUFFIX_RE, "").split("_");
  1245. const hashId = componentParts.length > 1 ? componentParts.pop() : undefined;
  1246. const componentName = componentParts.join("_");
  1247. const context = event.method === "GET" ? getQuery$1(event) : await readBody(event);
  1248. const ctx = {
  1249. url: "/",
  1250. ...context,
  1251. id: hashId,
  1252. name: componentName,
  1253. props: destr(context.props) || {},
  1254. slots: {},
  1255. components: {}
  1256. };
  1257. return ctx;
  1258. }
  1259. const HAS_APP_TELEPORTS = !!(appTeleportAttrs.id);
  1260. const APP_TELEPORT_OPEN_TAG = HAS_APP_TELEPORTS ? `<${appTeleportTag}${propsToString(appTeleportAttrs)}>` : "";
  1261. const APP_TELEPORT_CLOSE_TAG = HAS_APP_TELEPORTS ? `</${appTeleportTag}>` : "";
  1262. const APP_ROOT_OPEN_TAG = `<${appRootTag}${propsToString(appRootAttrs)}>`;
  1263. const APP_ROOT_CLOSE_TAG = `</${appRootTag}>`;
  1264. const PAYLOAD_URL_RE = /\/_payload.json(\?.*)?$/ ;
  1265. const ROOT_NODE_REGEX = new RegExp(`^<${appRootTag}[^>]*>([\\s\\S]*)<\\/${appRootTag}>$`);
  1266. const renderer = defineRenderHandler(async (event) => {
  1267. const nitroApp = useNitroApp();
  1268. const ssrError = event.path.startsWith("/__nuxt_error") ? getQuery$1(event) : null;
  1269. if (ssrError && ssrError.statusCode) {
  1270. ssrError.statusCode = Number.parseInt(ssrError.statusCode);
  1271. }
  1272. if (ssrError && !("__unenv__" in event.node.req)) {
  1273. throw createError({
  1274. statusCode: 404,
  1275. statusMessage: "Page Not Found: /__nuxt_error"
  1276. });
  1277. }
  1278. const isRenderingIsland = event.path.startsWith("/__nuxt_island");
  1279. const islandContext = isRenderingIsland ? await getIslandContext(event) : undefined;
  1280. let url = ssrError?.url || islandContext?.url || event.path;
  1281. const isRenderingPayload = PAYLOAD_URL_RE.test(url) && !isRenderingIsland;
  1282. if (isRenderingPayload) {
  1283. url = url.substring(0, url.lastIndexOf("/")) || "/";
  1284. event._path = url;
  1285. event.node.req.url = url;
  1286. }
  1287. const routeOptions = getRouteRules(event);
  1288. const head = createServerHead({
  1289. plugins: unheadPlugins
  1290. });
  1291. const headEntryOptions = { mode: "server" };
  1292. if (!isRenderingIsland) {
  1293. head.push(appHead, headEntryOptions);
  1294. }
  1295. const ssrContext = {
  1296. url,
  1297. event,
  1298. runtimeConfig: useRuntimeConfig(event),
  1299. noSSR: event.context.nuxt?.noSSR || routeOptions.ssr === false && !isRenderingIsland || (false),
  1300. head,
  1301. error: !!ssrError,
  1302. nuxt: undefined,
  1303. /* NuxtApp */
  1304. payload: ssrError ? { error: ssrError } : {},
  1305. _payloadReducers: /* @__PURE__ */ Object.create(null),
  1306. modules: /* @__PURE__ */ new Set(),
  1307. islandContext
  1308. };
  1309. const renderer = ssrContext.noSSR ? await getSPARenderer() : await getSSRRenderer();
  1310. const _rendered = await renderer.renderToString(ssrContext).catch(async (error) => {
  1311. if (ssrContext._renderResponse && error.message === "skipping render") {
  1312. return {};
  1313. }
  1314. const _err = !ssrError && ssrContext.payload?.error || error;
  1315. await ssrContext.nuxt?.hooks.callHook("app:error", _err);
  1316. throw _err;
  1317. });
  1318. await ssrContext.nuxt?.hooks.callHook("app:rendered", { ssrContext, renderResult: _rendered });
  1319. if (ssrContext._renderResponse) {
  1320. return ssrContext._renderResponse;
  1321. }
  1322. if (ssrContext.payload?.error && !ssrError) {
  1323. throw ssrContext.payload.error;
  1324. }
  1325. if (isRenderingPayload) {
  1326. const response2 = renderPayloadResponse(ssrContext);
  1327. return response2;
  1328. }
  1329. const inlinedStyles = isRenderingIsland ? await renderInlineStyles(ssrContext.modules ?? []) : [];
  1330. const NO_SCRIPTS = routeOptions.experimentalNoScripts;
  1331. const { styles, scripts } = getRequestDependencies(ssrContext, renderer.rendererContext);
  1332. if (ssrContext._preloadManifest) {
  1333. head.push({
  1334. link: [
  1335. { rel: "preload", as: "fetch", fetchpriority: "low", crossorigin: "anonymous", href: buildAssetsURL(`builds/meta/${ssrContext.runtimeConfig.app.buildId}.json`) }
  1336. ]
  1337. }, { ...headEntryOptions, tagPriority: "low" });
  1338. }
  1339. if (inlinedStyles.length) {
  1340. head.push({ style: inlinedStyles });
  1341. }
  1342. {
  1343. const link = [];
  1344. for (const resource of Object.values(styles)) {
  1345. if ("inline" in getQuery(resource.file)) {
  1346. continue;
  1347. }
  1348. if (!isRenderingIsland || resource.file.includes("scoped") && !resource.file.includes("pages/")) {
  1349. link.push({ rel: "stylesheet", href: renderer.rendererContext.buildAssetsURL(resource.file), crossorigin: "" });
  1350. }
  1351. }
  1352. if (link.length) {
  1353. head.push({ link }, headEntryOptions);
  1354. }
  1355. }
  1356. if (!NO_SCRIPTS && !isRenderingIsland) {
  1357. head.push({
  1358. link: getPreloadLinks(ssrContext, renderer.rendererContext)
  1359. }, headEntryOptions);
  1360. head.push({
  1361. link: getPrefetchLinks(ssrContext, renderer.rendererContext)
  1362. }, headEntryOptions);
  1363. head.push({
  1364. script: renderPayloadJsonScript({ ssrContext, data: ssrContext.payload })
  1365. }, {
  1366. ...headEntryOptions,
  1367. // this should come before another end of body scripts
  1368. tagPosition: "bodyClose",
  1369. tagPriority: "high"
  1370. });
  1371. }
  1372. if (!routeOptions.experimentalNoScripts && !isRenderingIsland) {
  1373. head.push({
  1374. script: Object.values(scripts).map((resource) => ({
  1375. type: resource.module ? "module" : null,
  1376. src: renderer.rendererContext.buildAssetsURL(resource.file),
  1377. defer: resource.module ? null : true,
  1378. // if we are rendering script tag payloads that import an async payload
  1379. // we need to ensure this resolves before executing the Nuxt entry
  1380. tagPosition: "head",
  1381. crossorigin: ""
  1382. }))
  1383. }, headEntryOptions);
  1384. }
  1385. const { headTags, bodyTags, bodyTagsOpen, htmlAttrs, bodyAttrs } = await renderSSRHead(head, renderSSRHeadOptions);
  1386. const htmlContext = {
  1387. island: isRenderingIsland,
  1388. htmlAttrs: htmlAttrs ? [htmlAttrs] : [],
  1389. head: normalizeChunks([headTags]),
  1390. bodyAttrs: bodyAttrs ? [bodyAttrs] : [],
  1391. bodyPrepend: normalizeChunks([bodyTagsOpen, ssrContext.teleports?.body]),
  1392. body: [
  1393. replaceIslandTeleports(ssrContext, _rendered.html) ,
  1394. APP_TELEPORT_OPEN_TAG + (HAS_APP_TELEPORTS ? joinTags([ssrContext.teleports?.[`#${appTeleportAttrs.id}`]]) : "") + APP_TELEPORT_CLOSE_TAG
  1395. ],
  1396. bodyAppend: [bodyTags]
  1397. };
  1398. await nitroApp.hooks.callHook("render:html", htmlContext, { event });
  1399. if (isRenderingIsland && islandContext) {
  1400. const islandHead = {};
  1401. for (const entry of head.headEntries()) {
  1402. for (const [key, value] of Object.entries(resolveUnrefHeadInput(entry.input))) {
  1403. const currentValue = islandHead[key];
  1404. if (Array.isArray(currentValue)) {
  1405. currentValue.push(...value);
  1406. }
  1407. islandHead[key] = value;
  1408. }
  1409. }
  1410. islandHead.link ||= [];
  1411. islandHead.style ||= [];
  1412. const islandResponse = {
  1413. id: islandContext.id,
  1414. head: islandHead,
  1415. html: getServerComponentHTML(htmlContext.body),
  1416. components: getClientIslandResponse(ssrContext),
  1417. slots: getSlotIslandResponse(ssrContext)
  1418. };
  1419. await nitroApp.hooks.callHook("render:island", islandResponse, { event, islandContext });
  1420. const response2 = {
  1421. body: JSON.stringify(islandResponse, null, 2),
  1422. statusCode: getResponseStatus(event),
  1423. statusMessage: getResponseStatusText(event),
  1424. headers: {
  1425. "content-type": "application/json;charset=utf-8",
  1426. "x-powered-by": "Nuxt"
  1427. }
  1428. };
  1429. return response2;
  1430. }
  1431. const response = {
  1432. body: renderHTMLDocument(htmlContext),
  1433. statusCode: getResponseStatus(event),
  1434. statusMessage: getResponseStatusText(event),
  1435. headers: {
  1436. "content-type": "text/html;charset=utf-8",
  1437. "x-powered-by": "Nuxt"
  1438. }
  1439. };
  1440. return response;
  1441. });
  1442. function lazyCachedFunction(fn) {
  1443. let res = null;
  1444. return () => {
  1445. if (res === null) {
  1446. res = fn().catch((err) => {
  1447. res = null;
  1448. throw err;
  1449. });
  1450. }
  1451. return res;
  1452. };
  1453. }
  1454. function normalizeChunks(chunks) {
  1455. return chunks.filter(Boolean).map((i) => i.trim());
  1456. }
  1457. function joinTags(tags) {
  1458. return tags.join("");
  1459. }
  1460. function joinAttrs(chunks) {
  1461. if (chunks.length === 0) {
  1462. return "";
  1463. }
  1464. return " " + chunks.join(" ");
  1465. }
  1466. function renderHTMLDocument(html) {
  1467. return `<!DOCTYPE html><html${joinAttrs(html.htmlAttrs)}><head>${joinTags(html.head)}</head><body${joinAttrs(html.bodyAttrs)}>${joinTags(html.bodyPrepend)}${joinTags(html.body)}${joinTags(html.bodyAppend)}</body></html>`;
  1468. }
  1469. async function renderInlineStyles(usedModules) {
  1470. const styleMap = await getSSRStyles();
  1471. const inlinedStyles = /* @__PURE__ */ new Set();
  1472. for (const mod of usedModules) {
  1473. if (mod in styleMap && styleMap[mod]) {
  1474. for (const style of await styleMap[mod]()) {
  1475. inlinedStyles.add(style);
  1476. }
  1477. }
  1478. }
  1479. return Array.from(inlinedStyles).map((style) => ({ innerHTML: style }));
  1480. }
  1481. function renderPayloadResponse(ssrContext) {
  1482. return {
  1483. body: stringify(splitPayload(ssrContext).payload, ssrContext._payloadReducers) ,
  1484. statusCode: getResponseStatus(ssrContext.event),
  1485. statusMessage: getResponseStatusText(ssrContext.event),
  1486. headers: {
  1487. "content-type": "application/json;charset=utf-8" ,
  1488. "x-powered-by": "Nuxt"
  1489. }
  1490. };
  1491. }
  1492. function renderPayloadJsonScript(opts) {
  1493. const contents = opts.data ? stringify(opts.data, opts.ssrContext._payloadReducers) : "";
  1494. const payload = {
  1495. "type": "application/json",
  1496. "innerHTML": contents,
  1497. "data-nuxt-data": appId,
  1498. "data-ssr": !(opts.ssrContext.noSSR)
  1499. };
  1500. {
  1501. payload.id = "__NUXT_DATA__";
  1502. }
  1503. if (opts.src) {
  1504. payload["data-src"] = opts.src;
  1505. }
  1506. const config = uneval(opts.ssrContext.config);
  1507. return [
  1508. payload,
  1509. {
  1510. innerHTML: `window.__NUXT__={};window.__NUXT__.config=${config}`
  1511. }
  1512. ];
  1513. }
  1514. function splitPayload(ssrContext) {
  1515. const { data, prerenderedAt, ...initial } = ssrContext.payload;
  1516. return {
  1517. initial: { ...initial, prerenderedAt },
  1518. payload: { data, prerenderedAt }
  1519. };
  1520. }
  1521. function getServerComponentHTML(body) {
  1522. const match = body[0].match(ROOT_NODE_REGEX);
  1523. return match?.[1] || body[0];
  1524. }
  1525. const SSR_SLOT_TELEPORT_MARKER = /^uid=([^;]*);slot=(.*)$/;
  1526. const SSR_CLIENT_TELEPORT_MARKER = /^uid=([^;]*);client=(.*)$/;
  1527. const SSR_CLIENT_SLOT_MARKER = /^island-slot=[^;]*;(.*)$/;
  1528. function getSlotIslandResponse(ssrContext) {
  1529. if (!ssrContext.islandContext || !Object.keys(ssrContext.islandContext.slots).length) {
  1530. return undefined;
  1531. }
  1532. const response = {};
  1533. for (const [name, slot] of Object.entries(ssrContext.islandContext.slots)) {
  1534. response[name] = {
  1535. ...slot,
  1536. fallback: ssrContext.teleports?.[`island-fallback=${name}`]
  1537. };
  1538. }
  1539. return response;
  1540. }
  1541. function getClientIslandResponse(ssrContext) {
  1542. if (!ssrContext.islandContext || !Object.keys(ssrContext.islandContext.components).length) {
  1543. return undefined;
  1544. }
  1545. const response = {};
  1546. for (const [clientUid, component] of Object.entries(ssrContext.islandContext.components)) {
  1547. const html = ssrContext.teleports?.[clientUid]?.replaceAll("<!--teleport start anchor-->", "") || "";
  1548. response[clientUid] = {
  1549. ...component,
  1550. html,
  1551. slots: getComponentSlotTeleport(ssrContext.teleports ?? {})
  1552. };
  1553. }
  1554. return response;
  1555. }
  1556. function getComponentSlotTeleport(teleports) {
  1557. const entries = Object.entries(teleports);
  1558. const slots = {};
  1559. for (const [key, value] of entries) {
  1560. const match = key.match(SSR_CLIENT_SLOT_MARKER);
  1561. if (match) {
  1562. const [, slot] = match;
  1563. if (!slot) {
  1564. continue;
  1565. }
  1566. slots[slot] = value;
  1567. }
  1568. }
  1569. return slots;
  1570. }
  1571. function replaceIslandTeleports(ssrContext, html) {
  1572. const { teleports, islandContext } = ssrContext;
  1573. if (islandContext || !teleports) {
  1574. return html;
  1575. }
  1576. for (const key in teleports) {
  1577. const matchClientComp = key.match(SSR_CLIENT_TELEPORT_MARKER);
  1578. if (matchClientComp) {
  1579. const [, uid, clientId] = matchClientComp;
  1580. if (!uid || !clientId) {
  1581. continue;
  1582. }
  1583. html = html.replace(new RegExp(` data-island-uid="${uid}" data-island-component="${clientId}"[^>]*>`), (full) => {
  1584. return full + teleports[key];
  1585. });
  1586. continue;
  1587. }
  1588. const matchSlot = key.match(SSR_SLOT_TELEPORT_MARKER);
  1589. if (matchSlot) {
  1590. const [, uid, slot] = matchSlot;
  1591. if (!uid || !slot) {
  1592. continue;
  1593. }
  1594. html = html.replace(new RegExp(` data-island-uid="${uid}" data-island-slot="${slot}"[^>]*>`), (full) => {
  1595. return full + teleports[key];
  1596. });
  1597. }
  1598. }
  1599. return html;
  1600. }
  1601. const renderer$1 = /*#__PURE__*/Object.freeze({
  1602. __proto__: null,
  1603. default: renderer
  1604. });
  1605. const styles = {};
  1606. const styles$1 = /*#__PURE__*/Object.freeze({
  1607. __proto__: null,
  1608. default: styles
  1609. });
  1610. const template = "";
  1611. const _virtual__spaTemplate = /*#__PURE__*/Object.freeze({
  1612. __proto__: null,
  1613. template: template
  1614. });
  1615. //# sourceMappingURL=index.mjs.map