index.mjs 60 KB

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