Rocky_Mountain_Vending/.pnpm-store/v10/files/4e/afe7d90cb99c881e9f655c2ba20de9e79c7aa0ee1d820fc2b6f580e72dda5330ec469abf2ba7e85daa5bd289c1e9d8dc2e687beb6111944087e79473c5954b
DMleadgen 46d973904b
Initial commit: Rocky Mountain Vending website
Next.js website for Rocky Mountain Vending company featuring:
- Product catalog with Stripe integration
- Service areas and parts pages
- Admin dashboard with Clerk authentication
- SEO optimized pages with JSON-LD structured data

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-12 16:22:15 -07:00

1 line
No EOL
600 KiB
Text

{"version":3,"file":"pages-api-turbo.runtime.prod.js","sources":["webpack://next/./dist/compiled/@edge-runtime/cookies/index.js","webpack://next/./dist/compiled/bytes/index.js","webpack://next/./dist/compiled/content-type/index.js","webpack://next/./dist/compiled/cookie/index.js","webpack://next/./dist/compiled/fresh/index.js","webpack://next/./dist/compiled/path-to-regexp/index.js","webpack://next/./dist/compiled/safe-stable-stringify/index.js","webpack://next/./dist/src/lib/constants.ts","webpack://next/./dist/src/lib/format-dynamic-import-path.ts","webpack://next/./dist/src/server/api-utils/index.ts","webpack://next/./dist/src/server/api-utils/node/try-get-preview-data.ts","webpack://next/./dist/src/server/crypto-utils.ts","webpack://next/./dist/src/server/lib/node-fs-methods.ts","webpack://next/./dist/src/server/lib/trace/constants.ts","webpack://next/./dist/src/server/web/spec-extension/adapters/reflect.ts","webpack://next/./dist/src/server/web/spec-extension/adapters/headers.ts","webpack://next/./dist/src/shared/lib/isomorphic/path.js","webpack://next/./dist/src/shared/lib/modern-browserslist-target.js","webpack://next/webpack/runtime/compat_get_default_export","webpack://next/webpack/runtime/create_fake_namespace_object","webpack://next/webpack/runtime/define_property_getters","webpack://next/webpack/runtime/has_own_property","webpack://next/webpack/runtime/make_namespace_object","webpack://next/./dist/src/shared/lib/constants.ts","webpack://next/./dist/src/lib/url.ts","webpack://next/./dist/src/shared/lib/i18n/normalize-locale-path.ts","webpack://next/./dist/src/shared/lib/page-path/ensure-leading-slash.ts","webpack://next/./dist/src/shared/lib/router/utils/app-paths.ts","webpack://next/./dist/src/shared/lib/segment.ts","webpack://next/./dist/src/shared/lib/router/utils/interception-routes.ts","webpack://next/./dist/src/shared/lib/router/utils/is-dynamic.ts","webpack://next/./dist/src/shared/lib/router/utils/parse-path.ts","webpack://next/./dist/src/shared/lib/router/utils/path-has-prefix.ts","webpack://next/./dist/src/shared/lib/router/utils/remove-path-prefix.ts","webpack://next/./dist/src/shared/lib/escape-regexp.ts","webpack://next/./dist/src/shared/lib/router/utils/remove-trailing-slash.ts","webpack://next/./dist/src/shared/lib/invariant-error.ts","webpack://next/./dist/src/shared/lib/router/utils/get-dynamic-param.ts","webpack://next/./dist/src/shared/lib/router/utils/route-regex.ts","webpack://next/./dist/src/shared/lib/utils.ts","webpack://next/./dist/src/lib/route-pattern-normalizer.ts","webpack://next/./dist/src/shared/lib/router/utils/route-match-utils.ts","webpack://next/./dist/src/shared/lib/router/utils/route-matcher.ts","webpack://next/./dist/src/shared/lib/router/utils/querystring.ts","webpack://next/./dist/src/server/api-utils/get-cookie-parser.ts","webpack://next/./dist/src/shared/lib/router/utils/prepare-destination.ts","webpack://next/./dist/src/server/web/utils.ts","webpack://next/./dist/src/server/lib/decode-query-path-parameter.ts","webpack://next/./dist/src/shared/lib/router/utils/format-url.ts","webpack://next/./dist/src/server/server-utils.ts","webpack://next/./dist/src/shared/lib/i18n/detect-domain-locale.ts","webpack://next/./dist/src/shared/lib/get-hostname.ts","webpack://next/./dist/src/shared/lib/page-path/normalize-data-path.ts","webpack://next/./dist/src/server/request-meta.ts","webpack://next/./dist/src/shared/lib/page-path/normalize-page-path.ts","webpack://next/./dist/src/lib/metadata/is-metadata-route.ts","webpack://next/./dist/src/lib/detached-promise.ts","webpack://next/./dist/src/lib/batcher.ts","webpack://next/./dist/src/lib/scheduler.ts","webpack://next/./dist/src/server/response-cache/types.ts","webpack://next/./dist/src/server/stream-utils/node-web-streams-helper.ts","webpack://next/./dist/src/server/stream-utils/encoded-tags.ts","webpack://next/./dist/src/shared/lib/router/utils/add-path-prefix.ts","webpack://next/./dist/src/shared/lib/router/utils/add-path-suffix.ts","webpack://next/./dist/src/server/web/next-url.ts","webpack://next/./dist/src/shared/lib/router/utils/get-next-pathname-info.ts","webpack://next/./dist/src/shared/lib/router/utils/format-next-pathname-info.ts","webpack://next/./dist/src/shared/lib/router/utils/add-locale.ts","webpack://next/./dist/src/server/web/spec-extension/request.ts","webpack://next/./dist/src/server/web/spec-extension/adapters/next-request.ts","webpack://next/./dist/src/server/client-component-renderer-logger.ts","webpack://next/./dist/src/server/pipe-readable.ts","webpack://next/./dist/src/server/render-result.ts","webpack://next/./dist/src/server/route-kind.ts","webpack://next/./dist/src/server/response-cache/utils.ts","webpack://next/./dist/src/server/response-cache/index.ts","webpack://next/./dist/src/lib/multi-file-writer.ts","webpack://next/./dist/src/server/lib/incremental-cache/file-system-cache.ts","webpack://next/./dist/src/server/lib/to-route.ts","webpack://next/./dist/src/server/lib/incremental-cache/index.ts","webpack://next/./dist/src/server/lib/lru-cache.ts","webpack://next/./dist/src/server/lib/cache-handlers/default.ts","webpack://next/./dist/src/server/use-cache/handlers.ts","webpack://next/./dist/src/server/app-render/interop-default.ts","webpack://next/./dist/src/server/lib/router-utils/router-server-context.ts","webpack://next/./dist/src/lib/generate-interception-routes-rewrites.ts","webpack://next/./dist/src/client/components/app-router-headers.ts","webpack://next/./dist/src/server/route-modules/route-module.ts","webpack://next/./dist/src/lib/is-app-route-route.ts","webpack://next/./dist/src/shared/lib/page-path/normalize-path-sep.ts","webpack://next/./dist/src/shared/lib/router/utils/path-match.ts","webpack://next/./dist/src/shared/lib/router/utils/parse-url.ts","webpack://next/./dist/src/shared/lib/router/utils/parse-relative-url.ts","webpack://next/./dist/src/server/lib/router-utils/decode-path-params.ts","webpack://next/./dist/src/shared/lib/router/utils/escape-path-delimiters.ts","webpack://next/./dist/src/lib/is-error.ts","webpack://next/./dist/src/server/api-utils/node/parse-body.ts","webpack://next/./dist/src/server/api-utils/node/api-resolver.ts","webpack://next/./dist/src/server/lib/etag.ts","webpack://next/./dist/src/server/send-payload.ts","webpack://next/./dist/src/lib/interop-default.ts","webpack://next/./dist/src/server/route-modules/pages-api/module.ts"],"sourcesContent":["\"use strict\";\nvar __defProp = Object.defineProperty;\nvar __getOwnPropDesc = Object.getOwnPropertyDescriptor;\nvar __getOwnPropNames = Object.getOwnPropertyNames;\nvar __hasOwnProp = Object.prototype.hasOwnProperty;\nvar __export = (target, all) => {\n for (var name in all)\n __defProp(target, name, { get: all[name], enumerable: true });\n};\nvar __copyProps = (to, from, except, desc) => {\n if (from && typeof from === \"object\" || typeof from === \"function\") {\n for (let key of __getOwnPropNames(from))\n if (!__hasOwnProp.call(to, key) && key !== except)\n __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });\n }\n return to;\n};\nvar __toCommonJS = (mod) => __copyProps(__defProp({}, \"__esModule\", { value: true }), mod);\n\n// src/index.ts\nvar src_exports = {};\n__export(src_exports, {\n RequestCookies: () => RequestCookies,\n ResponseCookies: () => ResponseCookies,\n parseCookie: () => parseCookie,\n parseSetCookie: () => parseSetCookie,\n stringifyCookie: () => stringifyCookie\n});\nmodule.exports = __toCommonJS(src_exports);\n\n// src/serialize.ts\nfunction stringifyCookie(c) {\n var _a;\n const attrs = [\n \"path\" in c && c.path && `Path=${c.path}`,\n \"expires\" in c && (c.expires || c.expires === 0) && `Expires=${(typeof c.expires === \"number\" ? new Date(c.expires) : c.expires).toUTCString()}`,\n \"maxAge\" in c && typeof c.maxAge === \"number\" && `Max-Age=${c.maxAge}`,\n \"domain\" in c && c.domain && `Domain=${c.domain}`,\n \"secure\" in c && c.secure && \"Secure\",\n \"httpOnly\" in c && c.httpOnly && \"HttpOnly\",\n \"sameSite\" in c && c.sameSite && `SameSite=${c.sameSite}`,\n \"partitioned\" in c && c.partitioned && \"Partitioned\",\n \"priority\" in c && c.priority && `Priority=${c.priority}`\n ].filter(Boolean);\n const stringified = `${c.name}=${encodeURIComponent((_a = c.value) != null ? _a : \"\")}`;\n return attrs.length === 0 ? stringified : `${stringified}; ${attrs.join(\"; \")}`;\n}\nfunction parseCookie(cookie) {\n const map = /* @__PURE__ */ new Map();\n for (const pair of cookie.split(/; */)) {\n if (!pair)\n continue;\n const splitAt = pair.indexOf(\"=\");\n if (splitAt === -1) {\n map.set(pair, \"true\");\n continue;\n }\n const [key, value] = [pair.slice(0, splitAt), pair.slice(splitAt + 1)];\n try {\n map.set(key, decodeURIComponent(value != null ? value : \"true\"));\n } catch {\n }\n }\n return map;\n}\nfunction parseSetCookie(setCookie) {\n if (!setCookie) {\n return void 0;\n }\n const [[name, value], ...attributes] = parseCookie(setCookie);\n const {\n domain,\n expires,\n httponly,\n maxage,\n path,\n samesite,\n secure,\n partitioned,\n priority\n } = Object.fromEntries(\n attributes.map(([key, value2]) => [\n key.toLowerCase().replace(/-/g, \"\"),\n value2\n ])\n );\n const cookie = {\n name,\n value: decodeURIComponent(value),\n domain,\n ...expires && { expires: new Date(expires) },\n ...httponly && { httpOnly: true },\n ...typeof maxage === \"string\" && { maxAge: Number(maxage) },\n path,\n ...samesite && { sameSite: parseSameSite(samesite) },\n ...secure && { secure: true },\n ...priority && { priority: parsePriority(priority) },\n ...partitioned && { partitioned: true }\n };\n return compact(cookie);\n}\nfunction compact(t) {\n const newT = {};\n for (const key in t) {\n if (t[key]) {\n newT[key] = t[key];\n }\n }\n return newT;\n}\nvar SAME_SITE = [\"strict\", \"lax\", \"none\"];\nfunction parseSameSite(string) {\n string = string.toLowerCase();\n return SAME_SITE.includes(string) ? string : void 0;\n}\nvar PRIORITY = [\"low\", \"medium\", \"high\"];\nfunction parsePriority(string) {\n string = string.toLowerCase();\n return PRIORITY.includes(string) ? string : void 0;\n}\nfunction splitCookiesString(cookiesString) {\n if (!cookiesString)\n return [];\n var cookiesStrings = [];\n var pos = 0;\n var start;\n var ch;\n var lastComma;\n var nextStart;\n var cookiesSeparatorFound;\n function skipWhitespace() {\n while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n pos += 1;\n }\n return pos < cookiesString.length;\n }\n function notSpecialChar() {\n ch = cookiesString.charAt(pos);\n return ch !== \"=\" && ch !== \";\" && ch !== \",\";\n }\n while (pos < cookiesString.length) {\n start = pos;\n cookiesSeparatorFound = false;\n while (skipWhitespace()) {\n ch = cookiesString.charAt(pos);\n if (ch === \",\") {\n lastComma = pos;\n pos += 1;\n skipWhitespace();\n nextStart = pos;\n while (pos < cookiesString.length && notSpecialChar()) {\n pos += 1;\n }\n if (pos < cookiesString.length && cookiesString.charAt(pos) === \"=\") {\n cookiesSeparatorFound = true;\n pos = nextStart;\n cookiesStrings.push(cookiesString.substring(start, lastComma));\n start = pos;\n } else {\n pos = lastComma + 1;\n }\n } else {\n pos += 1;\n }\n }\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length));\n }\n }\n return cookiesStrings;\n}\n\n// src/request-cookies.ts\nvar RequestCookies = class {\n constructor(requestHeaders) {\n /** @internal */\n this._parsed = /* @__PURE__ */ new Map();\n this._headers = requestHeaders;\n const header = requestHeaders.get(\"cookie\");\n if (header) {\n const parsed = parseCookie(header);\n for (const [name, value] of parsed) {\n this._parsed.set(name, { name, value });\n }\n }\n }\n [Symbol.iterator]() {\n return this._parsed[Symbol.iterator]();\n }\n /**\n * The amount of cookies received from the client\n */\n get size() {\n return this._parsed.size;\n }\n get(...args) {\n const name = typeof args[0] === \"string\" ? args[0] : args[0].name;\n return this._parsed.get(name);\n }\n getAll(...args) {\n var _a;\n const all = Array.from(this._parsed);\n if (!args.length) {\n return all.map(([_, value]) => value);\n }\n const name = typeof args[0] === \"string\" ? args[0] : (_a = args[0]) == null ? void 0 : _a.name;\n return all.filter(([n]) => n === name).map(([_, value]) => value);\n }\n has(name) {\n return this._parsed.has(name);\n }\n set(...args) {\n const [name, value] = args.length === 1 ? [args[0].name, args[0].value] : args;\n const map = this._parsed;\n map.set(name, { name, value });\n this._headers.set(\n \"cookie\",\n Array.from(map).map(([_, value2]) => stringifyCookie(value2)).join(\"; \")\n );\n return this;\n }\n /**\n * Delete the cookies matching the passed name or names in the request.\n */\n delete(names) {\n const map = this._parsed;\n const result = !Array.isArray(names) ? map.delete(names) : names.map((name) => map.delete(name));\n this._headers.set(\n \"cookie\",\n Array.from(map).map(([_, value]) => stringifyCookie(value)).join(\"; \")\n );\n return result;\n }\n /**\n * Delete all the cookies in the cookies in the request.\n */\n clear() {\n this.delete(Array.from(this._parsed.keys()));\n return this;\n }\n /**\n * Format the cookies in the request as a string for logging\n */\n [Symbol.for(\"edge-runtime.inspect.custom\")]() {\n return `RequestCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`;\n }\n toString() {\n return [...this._parsed.values()].map((v) => `${v.name}=${encodeURIComponent(v.value)}`).join(\"; \");\n }\n};\n\n// src/response-cookies.ts\nvar ResponseCookies = class {\n constructor(responseHeaders) {\n /** @internal */\n this._parsed = /* @__PURE__ */ new Map();\n var _a, _b, _c;\n this._headers = responseHeaders;\n const setCookie = (_c = (_b = (_a = responseHeaders.getSetCookie) == null ? void 0 : _a.call(responseHeaders)) != null ? _b : responseHeaders.get(\"set-cookie\")) != null ? _c : [];\n const cookieStrings = Array.isArray(setCookie) ? setCookie : splitCookiesString(setCookie);\n for (const cookieString of cookieStrings) {\n const parsed = parseSetCookie(cookieString);\n if (parsed)\n this._parsed.set(parsed.name, parsed);\n }\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-get CookieStore#get} without the Promise.\n */\n get(...args) {\n const key = typeof args[0] === \"string\" ? args[0] : args[0].name;\n return this._parsed.get(key);\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-getAll CookieStore#getAll} without the Promise.\n */\n getAll(...args) {\n var _a;\n const all = Array.from(this._parsed.values());\n if (!args.length) {\n return all;\n }\n const key = typeof args[0] === \"string\" ? args[0] : (_a = args[0]) == null ? void 0 : _a.name;\n return all.filter((c) => c.name === key);\n }\n has(name) {\n return this._parsed.has(name);\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-set CookieStore#set} without the Promise.\n */\n set(...args) {\n const [name, value, cookie] = args.length === 1 ? [args[0].name, args[0].value, args[0]] : args;\n const map = this._parsed;\n map.set(name, normalizeCookie({ name, value, ...cookie }));\n replace(map, this._headers);\n return this;\n }\n /**\n * {@link https://wicg.github.io/cookie-store/#CookieStore-delete CookieStore#delete} without the Promise.\n */\n delete(...args) {\n const [name, options] = typeof args[0] === \"string\" ? [args[0]] : [args[0].name, args[0]];\n return this.set({ ...options, name, value: \"\", expires: /* @__PURE__ */ new Date(0) });\n }\n [Symbol.for(\"edge-runtime.inspect.custom\")]() {\n return `ResponseCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`;\n }\n toString() {\n return [...this._parsed.values()].map(stringifyCookie).join(\"; \");\n }\n};\nfunction replace(bag, headers) {\n headers.delete(\"set-cookie\");\n for (const [, value] of bag) {\n const serialized = stringifyCookie(value);\n headers.append(\"set-cookie\", serialized);\n }\n}\nfunction normalizeCookie(cookie = { name: \"\", value: \"\" }) {\n if (typeof cookie.expires === \"number\") {\n cookie.expires = new Date(cookie.expires);\n }\n if (cookie.maxAge) {\n cookie.expires = new Date(Date.now() + cookie.maxAge * 1e3);\n }\n if (cookie.path === null || cookie.path === void 0) {\n cookie.path = \"/\";\n }\n return cookie;\n}\n// Annotate the CommonJS export names for ESM import in node:\n0 && (module.exports = {\n RequestCookies,\n ResponseCookies,\n parseCookie,\n parseSetCookie,\n stringifyCookie\n});\n","(()=>{\"use strict\";var e={56:e=>{\n/*!\n * bytes\n * Copyright(c) 2012-2014 TJ Holowaychuk\n * Copyright(c) 2015 Jed Watson\n * MIT Licensed\n */\ne.exports=bytes;e.exports.format=format;e.exports.parse=parse;var r=/\\B(?=(\\d{3})+(?!\\d))/g;var a=/(?:\\.0*|(\\.[^0]+)0+)$/;var t={b:1,kb:1<<10,mb:1<<20,gb:1<<30,tb:Math.pow(1024,4),pb:Math.pow(1024,5)};var i=/^((-|\\+)?(\\d+(?:\\.\\d+)?)) *(kb|mb|gb|tb|pb)$/i;function bytes(e,r){if(typeof e===\"string\"){return parse(e)}if(typeof e===\"number\"){return format(e,r)}return null}function format(e,i){if(!Number.isFinite(e)){return null}var n=Math.abs(e);var o=i&&i.thousandsSeparator||\"\";var s=i&&i.unitSeparator||\"\";var f=i&&i.decimalPlaces!==undefined?i.decimalPlaces:2;var u=Boolean(i&&i.fixedDecimals);var p=i&&i.unit||\"\";if(!p||!t[p.toLowerCase()]){if(n>=t.pb){p=\"PB\"}else if(n>=t.tb){p=\"TB\"}else if(n>=t.gb){p=\"GB\"}else if(n>=t.mb){p=\"MB\"}else if(n>=t.kb){p=\"KB\"}else{p=\"B\"}}var b=e/t[p.toLowerCase()];var l=b.toFixed(f);if(!u){l=l.replace(a,\"$1\")}if(o){l=l.split(\".\").map((function(e,a){return a===0?e.replace(r,o):e})).join(\".\")}return l+s+p}function parse(e){if(typeof e===\"number\"&&!isNaN(e)){return e}if(typeof e!==\"string\"){return null}var r=i.exec(e);var a;var n=\"b\";if(!r){a=parseInt(e,10);n=\"b\"}else{a=parseFloat(r[1]);n=r[4].toLowerCase()}return Math.floor(t[n]*a)}}};var r={};function __nccwpck_require__(a){var t=r[a];if(t!==undefined){return t.exports}var i=r[a]={exports:{}};var n=true;try{e[a](i,i.exports,__nccwpck_require__);n=false}finally{if(n)delete r[a]}return i.exports}if(typeof __nccwpck_require__!==\"undefined\")__nccwpck_require__.ab=__dirname+\"/\";var a=__nccwpck_require__(56);module.exports=a})();","(()=>{\"use strict\";if(typeof __nccwpck_require__!==\"undefined\")__nccwpck_require__.ab=__dirname+\"/\";var e={};(()=>{var r=e;\n/*!\n * content-type\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */var t=/; *([!#$%&'*+.^_`|~0-9A-Za-z-]+) *= *(\"(?:[\\u000b\\u0020\\u0021\\u0023-\\u005b\\u005d-\\u007e\\u0080-\\u00ff]|\\\\[\\u000b\\u0020-\\u00ff])*\"|[!#$%&'*+.^_`|~0-9A-Za-z-]+) */g;var a=/^[\\u000b\\u0020-\\u007e\\u0080-\\u00ff]+$/;var n=/^[!#$%&'*+.^_`|~0-9A-Za-z-]+$/;var i=/\\\\([\\u000b\\u0020-\\u00ff])/g;var o=/([\\\\\"])/g;var f=/^[!#$%&'*+.^_`|~0-9A-Za-z-]+\\/[!#$%&'*+.^_`|~0-9A-Za-z-]+$/;r.format=format;r.parse=parse;function format(e){if(!e||typeof e!==\"object\"){throw new TypeError(\"argument obj is required\")}var r=e.parameters;var t=e.type;if(!t||!f.test(t)){throw new TypeError(\"invalid type\")}var a=t;if(r&&typeof r===\"object\"){var i;var o=Object.keys(r).sort();for(var u=0;u<o.length;u++){i=o[u];if(!n.test(i)){throw new TypeError(\"invalid parameter name\")}a+=\"; \"+i+\"=\"+qstring(r[i])}}return a}function parse(e){if(!e){throw new TypeError(\"argument string is required\")}var r=typeof e===\"object\"?getcontenttype(e):e;if(typeof r!==\"string\"){throw new TypeError(\"argument string is required to be a string\")}var a=r.indexOf(\";\");var n=a!==-1?r.substr(0,a).trim():r.trim();if(!f.test(n)){throw new TypeError(\"invalid media type\")}var o=new ContentType(n.toLowerCase());if(a!==-1){var u;var p;var s;t.lastIndex=a;while(p=t.exec(r)){if(p.index!==a){throw new TypeError(\"invalid parameter format\")}a+=p[0].length;u=p[1].toLowerCase();s=p[2];if(s[0]==='\"'){s=s.substr(1,s.length-2).replace(i,\"$1\")}o.parameters[u]=s}if(a!==r.length){throw new TypeError(\"invalid parameter format\")}}return o}function getcontenttype(e){var r;if(typeof e.getHeader===\"function\"){r=e.getHeader(\"content-type\")}else if(typeof e.headers===\"object\"){r=e.headers&&e.headers[\"content-type\"]}if(typeof r!==\"string\"){throw new TypeError(\"content-type header is missing from object\")}return r}function qstring(e){var r=String(e);if(n.test(r)){return r}if(r.length>0&&!a.test(r)){throw new TypeError(\"invalid parameter value\")}return'\"'+r.replace(o,\"\\\\$1\")+'\"'}function ContentType(e){this.parameters=Object.create(null);this.type=e}})();module.exports=e})();","(()=>{\"use strict\";if(typeof __nccwpck_require__!==\"undefined\")__nccwpck_require__.ab=__dirname+\"/\";var e={};(()=>{var r=e;\n/*!\n * cookie\n * Copyright(c) 2012-2014 Roman Shtylman\n * Copyright(c) 2015 Douglas Christopher Wilson\n * MIT Licensed\n */r.parse=parse;r.serialize=serialize;var i=decodeURIComponent;var t=encodeURIComponent;var a=/; */;var n=/^[\\u0009\\u0020-\\u007e\\u0080-\\u00ff]+$/;function parse(e,r){if(typeof e!==\"string\"){throw new TypeError(\"argument str must be a string\")}var t={};var n=r||{};var o=e.split(a);var s=n.decode||i;for(var p=0;p<o.length;p++){var f=o[p];var u=f.indexOf(\"=\");if(u<0){continue}var v=f.substr(0,u).trim();var c=f.substr(++u,f.length).trim();if('\"'==c[0]){c=c.slice(1,-1)}if(undefined==t[v]){t[v]=tryDecode(c,s)}}return t}function serialize(e,r,i){var a=i||{};var o=a.encode||t;if(typeof o!==\"function\"){throw new TypeError(\"option encode is invalid\")}if(!n.test(e)){throw new TypeError(\"argument name is invalid\")}var s=o(r);if(s&&!n.test(s)){throw new TypeError(\"argument val is invalid\")}var p=e+\"=\"+s;if(null!=a.maxAge){var f=a.maxAge-0;if(isNaN(f)||!isFinite(f)){throw new TypeError(\"option maxAge is invalid\")}p+=\"; Max-Age=\"+Math.floor(f)}if(a.domain){if(!n.test(a.domain)){throw new TypeError(\"option domain is invalid\")}p+=\"; Domain=\"+a.domain}if(a.path){if(!n.test(a.path)){throw new TypeError(\"option path is invalid\")}p+=\"; Path=\"+a.path}if(a.expires){if(typeof a.expires.toUTCString!==\"function\"){throw new TypeError(\"option expires is invalid\")}p+=\"; Expires=\"+a.expires.toUTCString()}if(a.httpOnly){p+=\"; HttpOnly\"}if(a.secure){p+=\"; Secure\"}if(a.sameSite){var u=typeof a.sameSite===\"string\"?a.sameSite.toLowerCase():a.sameSite;switch(u){case true:p+=\"; SameSite=Strict\";break;case\"lax\":p+=\"; SameSite=Lax\";break;case\"strict\":p+=\"; SameSite=Strict\";break;case\"none\":p+=\"; SameSite=None\";break;default:throw new TypeError(\"option sameSite is invalid\")}}return p}function tryDecode(e,r){try{return r(e)}catch(r){return e}}})();module.exports=e})();","(()=>{\"use strict\";var e={695:e=>{\n/*!\n * fresh\n * Copyright(c) 2012 TJ Holowaychuk\n * Copyright(c) 2016-2017 Douglas Christopher Wilson\n * MIT Licensed\n */\nvar r=/(?:^|,)\\s*?no-cache\\s*?(?:,|$)/;e.exports=fresh;function fresh(e,a){var t=e[\"if-modified-since\"];var s=e[\"if-none-match\"];if(!t&&!s){return false}var i=e[\"cache-control\"];if(i&&r.test(i)){return false}if(s&&s!==\"*\"){var f=a[\"etag\"];if(!f){return false}var n=true;var u=parseTokenList(s);for(var _=0;_<u.length;_++){var o=u[_];if(o===f||o===\"W/\"+f||\"W/\"+o===f){n=false;break}}if(n){return false}}if(t){var p=a[\"last-modified\"];var v=!p||!(parseHttpDate(p)<=parseHttpDate(t));if(v){return false}}return true}function parseHttpDate(e){var r=e&&Date.parse(e);return typeof r===\"number\"?r:NaN}function parseTokenList(e){var r=0;var a=[];var t=0;for(var s=0,i=e.length;s<i;s++){switch(e.charCodeAt(s)){case 32:if(t===r){t=r=s+1}break;case 44:a.push(e.substring(t,r));t=r=s+1;break;default:r=s+1;break}}a.push(e.substring(t,r));return a}}};var r={};function __nccwpck_require__(a){var t=r[a];if(t!==undefined){return t.exports}var s=r[a]={exports:{}};var i=true;try{e[a](s,s.exports,__nccwpck_require__);i=false}finally{if(i)delete r[a]}return s.exports}if(typeof __nccwpck_require__!==\"undefined\")__nccwpck_require__.ab=__dirname+\"/\";var a=__nccwpck_require__(695);module.exports=a})();","(()=>{\"use strict\";if(typeof __nccwpck_require__!==\"undefined\")__nccwpck_require__.ab=__dirname+\"/\";var e={};(()=>{var n=e;Object.defineProperty(n,\"__esModule\",{value:true});n.pathToRegexp=n.tokensToRegexp=n.regexpToFunction=n.match=n.tokensToFunction=n.compile=n.parse=void 0;function lexer(e){var n=[];var r=0;while(r<e.length){var t=e[r];if(t===\"*\"||t===\"+\"||t===\"?\"){n.push({type:\"MODIFIER\",index:r,value:e[r++]});continue}if(t===\"\\\\\"){n.push({type:\"ESCAPED_CHAR\",index:r++,value:e[r++]});continue}if(t===\"{\"){n.push({type:\"OPEN\",index:r,value:e[r++]});continue}if(t===\"}\"){n.push({type:\"CLOSE\",index:r,value:e[r++]});continue}if(t===\":\"){var a=\"\";var i=r+1;while(i<e.length){var o=e.charCodeAt(i);if(o>=48&&o<=57||o>=65&&o<=90||o>=97&&o<=122||o===95){a+=e[i++];continue}break}if(!a)throw new TypeError(\"Missing parameter name at \".concat(r));n.push({type:\"NAME\",index:r,value:a});r=i;continue}if(t===\"(\"){var c=1;var f=\"\";var i=r+1;if(e[i]===\"?\"){throw new TypeError('Pattern cannot start with \"?\" at '.concat(i))}while(i<e.length){if(e[i]===\"\\\\\"){f+=e[i++]+e[i++];continue}if(e[i]===\")\"){c--;if(c===0){i++;break}}else if(e[i]===\"(\"){c++;if(e[i+1]!==\"?\"){throw new TypeError(\"Capturing groups are not allowed at \".concat(i))}}f+=e[i++]}if(c)throw new TypeError(\"Unbalanced pattern at \".concat(r));if(!f)throw new TypeError(\"Missing pattern at \".concat(r));n.push({type:\"PATTERN\",index:r,value:f});r=i;continue}n.push({type:\"CHAR\",index:r,value:e[r++]})}n.push({type:\"END\",index:r,value:\"\"});return n}function parse(e,n){if(n===void 0){n={}}var r=lexer(e);var t=n.prefixes,a=t===void 0?\"./\":t,i=n.delimiter,o=i===void 0?\"/#?\":i;var c=[];var f=0;var u=0;var p=\"\";var tryConsume=function(e){if(u<r.length&&r[u].type===e)return r[u++].value};var mustConsume=function(e){var n=tryConsume(e);if(n!==undefined)return n;var t=r[u],a=t.type,i=t.index;throw new TypeError(\"Unexpected \".concat(a,\" at \").concat(i,\", expected \").concat(e))};var consumeText=function(){var e=\"\";var n;while(n=tryConsume(\"CHAR\")||tryConsume(\"ESCAPED_CHAR\")){e+=n}return e};var isSafe=function(e){for(var n=0,r=o;n<r.length;n++){var t=r[n];if(e.indexOf(t)>-1)return true}return false};var safePattern=function(e){var n=c[c.length-1];var r=e||(n&&typeof n===\"string\"?n:\"\");if(n&&!r){throw new TypeError('Must have text between two parameters, missing text after \"'.concat(n.name,'\"'))}if(!r||isSafe(r))return\"[^\".concat(escapeString(o),\"]+?\");return\"(?:(?!\".concat(escapeString(r),\")[^\").concat(escapeString(o),\"])+?\")};while(u<r.length){var v=tryConsume(\"CHAR\");var s=tryConsume(\"NAME\");var d=tryConsume(\"PATTERN\");if(s||d){var g=v||\"\";if(a.indexOf(g)===-1){p+=g;g=\"\"}if(p){c.push(p);p=\"\"}c.push({name:s||f++,prefix:g,suffix:\"\",pattern:d||safePattern(g),modifier:tryConsume(\"MODIFIER\")||\"\"});continue}var x=v||tryConsume(\"ESCAPED_CHAR\");if(x){p+=x;continue}if(p){c.push(p);p=\"\"}var h=tryConsume(\"OPEN\");if(h){var g=consumeText();var l=tryConsume(\"NAME\")||\"\";var m=tryConsume(\"PATTERN\")||\"\";var T=consumeText();mustConsume(\"CLOSE\");c.push({name:l||(m?f++:\"\"),pattern:l&&!m?safePattern(g):m,prefix:g,suffix:T,modifier:tryConsume(\"MODIFIER\")||\"\"});continue}mustConsume(\"END\")}return c}n.parse=parse;function compile(e,n){return tokensToFunction(parse(e,n),n)}n.compile=compile;function tokensToFunction(e,n){if(n===void 0){n={}}var r=flags(n);var t=n.encode,a=t===void 0?function(e){return e}:t,i=n.validate,o=i===void 0?true:i;var c=e.map((function(e){if(typeof e===\"object\"){return new RegExp(\"^(?:\".concat(e.pattern,\")$\"),r)}}));return function(n){var r=\"\";for(var t=0;t<e.length;t++){var i=e[t];if(typeof i===\"string\"){r+=i;continue}var f=n?n[i.name]:undefined;var u=i.modifier===\"?\"||i.modifier===\"*\";var p=i.modifier===\"*\"||i.modifier===\"+\";if(Array.isArray(f)){if(!p){throw new TypeError('Expected \"'.concat(i.name,'\" to not repeat, but got an array'))}if(f.length===0){if(u)continue;throw new TypeError('Expected \"'.concat(i.name,'\" to not be empty'))}for(var v=0;v<f.length;v++){var s=a(f[v],i);if(o&&!c[t].test(s)){throw new TypeError('Expected all \"'.concat(i.name,'\" to match \"').concat(i.pattern,'\", but got \"').concat(s,'\"'))}r+=i.prefix+s+i.suffix}continue}if(typeof f===\"string\"||typeof f===\"number\"){var s=a(String(f),i);if(o&&!c[t].test(s)){throw new TypeError('Expected \"'.concat(i.name,'\" to match \"').concat(i.pattern,'\", but got \"').concat(s,'\"'))}r+=i.prefix+s+i.suffix;continue}if(u)continue;var d=p?\"an array\":\"a string\";throw new TypeError('Expected \"'.concat(i.name,'\" to be ').concat(d))}return r}}n.tokensToFunction=tokensToFunction;function match(e,n){var r=[];var t=pathToRegexp(e,r,n);return regexpToFunction(t,r,n)}n.match=match;function regexpToFunction(e,n,r){if(r===void 0){r={}}var t=r.decode,a=t===void 0?function(e){return e}:t;return function(r){var t=e.exec(r);if(!t)return false;var i=t[0],o=t.index;var c=Object.create(null);var _loop_1=function(e){if(t[e]===undefined)return\"continue\";var r=n[e-1];if(r.modifier===\"*\"||r.modifier===\"+\"){c[r.name]=t[e].split(r.prefix+r.suffix).map((function(e){return a(e,r)}))}else{c[r.name]=a(t[e],r)}};for(var f=1;f<t.length;f++){_loop_1(f)}return{path:i,index:o,params:c}}}n.regexpToFunction=regexpToFunction;function escapeString(e){return e.replace(/([.+*?=^!:${}()[\\]|/\\\\])/g,\"\\\\$1\")}function flags(e){return e&&e.sensitive?\"\":\"i\"}function regexpToRegexp(e,n){if(!n)return e;var r=/\\((?:\\?<(.*?)>)?(?!\\?)/g;var t=0;var a=r.exec(e.source);while(a){n.push({name:a[1]||t++,prefix:\"\",suffix:\"\",modifier:\"\",pattern:\"\"});a=r.exec(e.source)}return e}function arrayToRegexp(e,n,r){var t=e.map((function(e){return pathToRegexp(e,n,r).source}));return new RegExp(\"(?:\".concat(t.join(\"|\"),\")\"),flags(r))}function stringToRegexp(e,n,r){return tokensToRegexp(parse(e,r),n,r)}function tokensToRegexp(e,n,r){if(r===void 0){r={}}var t=r.strict,a=t===void 0?false:t,i=r.start,o=i===void 0?true:i,c=r.end,f=c===void 0?true:c,u=r.encode,p=u===void 0?function(e){return e}:u,v=r.delimiter,s=v===void 0?\"/#?\":v,d=r.endsWith,g=d===void 0?\"\":d;var x=\"[\".concat(escapeString(g),\"]|$\");var h=\"[\".concat(escapeString(s),\"]\");var l=o?\"^\":\"\";for(var m=0,T=e;m<T.length;m++){var E=T[m];if(typeof E===\"string\"){l+=escapeString(p(E))}else{var w=escapeString(p(E.prefix));var y=escapeString(p(E.suffix));if(E.pattern){if(n)n.push(E);if(w||y){if(E.modifier===\"+\"||E.modifier===\"*\"){var R=E.modifier===\"*\"?\"?\":\"\";l+=\"(?:\".concat(w,\"((?:\").concat(E.pattern,\")(?:\").concat(y).concat(w,\"(?:\").concat(E.pattern,\"))*)\").concat(y,\")\").concat(R)}else{l+=\"(?:\".concat(w,\"(\").concat(E.pattern,\")\").concat(y,\")\").concat(E.modifier)}}else{if(E.modifier===\"+\"||E.modifier===\"*\"){throw new TypeError('Can not repeat \"'.concat(E.name,'\" without a prefix and suffix'))}l+=\"(\".concat(E.pattern,\")\").concat(E.modifier)}}else{l+=\"(?:\".concat(w).concat(y,\")\").concat(E.modifier)}}}if(f){if(!a)l+=\"\".concat(h,\"?\");l+=!r.endsWith?\"$\":\"(?=\".concat(x,\")\")}else{var A=e[e.length-1];var _=typeof A===\"string\"?h.indexOf(A[A.length-1])>-1:A===undefined;if(!a){l+=\"(?:\".concat(h,\"(?=\").concat(x,\"))?\")}if(!_){l+=\"(?=\".concat(h,\"|\").concat(x,\")\")}}return new RegExp(l,flags(r))}n.tokensToRegexp=tokensToRegexp;function pathToRegexp(e,n,r){if(e instanceof RegExp)return regexpToRegexp(e,n);if(Array.isArray(e))return arrayToRegexp(e,n,r);return stringToRegexp(e,n,r)}n.pathToRegexp=pathToRegexp})();module.exports=e})();","(function(){\"use strict\";var e={879:function(e,t){const{hasOwnProperty:n}=Object.prototype;const r=configure();r.configure=configure;r.stringify=r;r.default=r;t.stringify=r;t.configure=configure;e.exports=r;const i=/[\\u0000-\\u001f\\u0022\\u005c\\ud800-\\udfff]/;function strEscape(e){if(e.length<5e3&&!i.test(e)){return`\"${e}\"`}return JSON.stringify(e)}function sort(e,t){if(e.length>200||t){return e.sort(t)}for(let t=1;t<e.length;t++){const n=e[t];let r=t;while(r!==0&&e[r-1]>n){e[r]=e[r-1];r--}e[r]=n}return e}const f=Object.getOwnPropertyDescriptor(Object.getPrototypeOf(Object.getPrototypeOf(new Int8Array)),Symbol.toStringTag).get;function isTypedArrayWithEntries(e){return f.call(e)!==undefined&&e.length!==0}function stringifyTypedArray(e,t,n){if(e.length<n){n=e.length}const r=t===\",\"?\"\":\" \";let i=`\"0\":${r}${e[0]}`;for(let f=1;f<n;f++){i+=`${t}\"${f}\":${r}${e[f]}`}return i}function getCircularValueOption(e){if(n.call(e,\"circularValue\")){const t=e.circularValue;if(typeof t===\"string\"){return`\"${t}\"`}if(t==null){return t}if(t===Error||t===TypeError){return{toString(){throw new TypeError(\"Converting circular structure to JSON\")}}}throw new TypeError('The \"circularValue\" argument must be of type string or the value null or undefined')}return'\"[Circular]\"'}function getDeterministicOption(e){let t;if(n.call(e,\"deterministic\")){t=e.deterministic;if(typeof t!==\"boolean\"&&typeof t!==\"function\"){throw new TypeError('The \"deterministic\" argument must be of type boolean or comparator function')}}return t===undefined?true:t}function getBooleanOption(e,t){let r;if(n.call(e,t)){r=e[t];if(typeof r!==\"boolean\"){throw new TypeError(`The \"${t}\" argument must be of type boolean`)}}return r===undefined?true:r}function getPositiveIntegerOption(e,t){let r;if(n.call(e,t)){r=e[t];if(typeof r!==\"number\"){throw new TypeError(`The \"${t}\" argument must be of type number`)}if(!Number.isInteger(r)){throw new TypeError(`The \"${t}\" argument must be an integer`)}if(r<1){throw new RangeError(`The \"${t}\" argument must be >= 1`)}}return r===undefined?Infinity:r}function getItemCount(e){if(e===1){return\"1 item\"}return`${e} items`}function getUniqueReplacerSet(e){const t=new Set;for(const n of e){if(typeof n===\"string\"||typeof n===\"number\"){t.add(String(n))}}return t}function getStrictOption(e){if(n.call(e,\"strict\")){const t=e.strict;if(typeof t!==\"boolean\"){throw new TypeError('The \"strict\" argument must be of type boolean')}if(t){return e=>{let t=`Object can not safely be stringified. Received type ${typeof e}`;if(typeof e!==\"function\")t+=` (${e.toString()})`;throw new Error(t)}}}}function configure(e){e={...e};const t=getStrictOption(e);if(t){if(e.bigint===undefined){e.bigint=false}if(!(\"circularValue\"in e)){e.circularValue=Error}}const n=getCircularValueOption(e);const r=getBooleanOption(e,\"bigint\");const i=getDeterministicOption(e);const f=typeof i===\"function\"?i:undefined;const u=getPositiveIntegerOption(e,\"maximumDepth\");const o=getPositiveIntegerOption(e,\"maximumBreadth\");function stringifyFnReplacer(e,s,l,c,a,g){let p=s[e];if(typeof p===\"object\"&&p!==null&&typeof p.toJSON===\"function\"){p=p.toJSON(e)}p=c.call(s,e,p);switch(typeof p){case\"string\":return strEscape(p);case\"object\":{if(p===null){return\"null\"}if(l.indexOf(p)!==-1){return n}let e=\"\";let t=\",\";const r=g;if(Array.isArray(p)){if(p.length===0){return\"[]\"}if(u<l.length+1){return'\"[Array]\"'}l.push(p);if(a!==\"\"){g+=a;e+=`\\n${g}`;t=`,\\n${g}`}const n=Math.min(p.length,o);let i=0;for(;i<n-1;i++){const n=stringifyFnReplacer(String(i),p,l,c,a,g);e+=n!==undefined?n:\"null\";e+=t}const f=stringifyFnReplacer(String(i),p,l,c,a,g);e+=f!==undefined?f:\"null\";if(p.length-1>o){const n=p.length-o-1;e+=`${t}\"... ${getItemCount(n)} not stringified\"`}if(a!==\"\"){e+=`\\n${r}`}l.pop();return`[${e}]`}let s=Object.keys(p);const y=s.length;if(y===0){return\"{}\"}if(u<l.length+1){return'\"[Object]\"'}let d=\"\";let h=\"\";if(a!==\"\"){g+=a;t=`,\\n${g}`;d=\" \"}const $=Math.min(y,o);if(i&&!isTypedArrayWithEntries(p)){s=sort(s,f)}l.push(p);for(let n=0;n<$;n++){const r=s[n];const i=stringifyFnReplacer(r,p,l,c,a,g);if(i!==undefined){e+=`${h}${strEscape(r)}:${d}${i}`;h=t}}if(y>o){const n=y-o;e+=`${h}\"...\":${d}\"${getItemCount(n)} not stringified\"`;h=t}if(a!==\"\"&&h.length>1){e=`\\n${g}${e}\\n${r}`}l.pop();return`{${e}}`}case\"number\":return isFinite(p)?String(p):t?t(p):\"null\";case\"boolean\":return p===true?\"true\":\"false\";case\"undefined\":return undefined;case\"bigint\":if(r){return String(p)}default:return t?t(p):undefined}}function stringifyArrayReplacer(e,i,f,s,l,c){if(typeof i===\"object\"&&i!==null&&typeof i.toJSON===\"function\"){i=i.toJSON(e)}switch(typeof i){case\"string\":return strEscape(i);case\"object\":{if(i===null){return\"null\"}if(f.indexOf(i)!==-1){return n}const e=c;let t=\"\";let r=\",\";if(Array.isArray(i)){if(i.length===0){return\"[]\"}if(u<f.length+1){return'\"[Array]\"'}f.push(i);if(l!==\"\"){c+=l;t+=`\\n${c}`;r=`,\\n${c}`}const n=Math.min(i.length,o);let a=0;for(;a<n-1;a++){const e=stringifyArrayReplacer(String(a),i[a],f,s,l,c);t+=e!==undefined?e:\"null\";t+=r}const g=stringifyArrayReplacer(String(a),i[a],f,s,l,c);t+=g!==undefined?g:\"null\";if(i.length-1>o){const e=i.length-o-1;t+=`${r}\"... ${getItemCount(e)} not stringified\"`}if(l!==\"\"){t+=`\\n${e}`}f.pop();return`[${t}]`}f.push(i);let a=\"\";if(l!==\"\"){c+=l;r=`,\\n${c}`;a=\" \"}let g=\"\";for(const e of s){const n=stringifyArrayReplacer(e,i[e],f,s,l,c);if(n!==undefined){t+=`${g}${strEscape(e)}:${a}${n}`;g=r}}if(l!==\"\"&&g.length>1){t=`\\n${c}${t}\\n${e}`}f.pop();return`{${t}}`}case\"number\":return isFinite(i)?String(i):t?t(i):\"null\";case\"boolean\":return i===true?\"true\":\"false\";case\"undefined\":return undefined;case\"bigint\":if(r){return String(i)}default:return t?t(i):undefined}}function stringifyIndent(e,s,l,c,a){switch(typeof s){case\"string\":return strEscape(s);case\"object\":{if(s===null){return\"null\"}if(typeof s.toJSON===\"function\"){s=s.toJSON(e);if(typeof s!==\"object\"){return stringifyIndent(e,s,l,c,a)}if(s===null){return\"null\"}}if(l.indexOf(s)!==-1){return n}const t=a;if(Array.isArray(s)){if(s.length===0){return\"[]\"}if(u<l.length+1){return'\"[Array]\"'}l.push(s);a+=c;let e=`\\n${a}`;const n=`,\\n${a}`;const r=Math.min(s.length,o);let i=0;for(;i<r-1;i++){const t=stringifyIndent(String(i),s[i],l,c,a);e+=t!==undefined?t:\"null\";e+=n}const f=stringifyIndent(String(i),s[i],l,c,a);e+=f!==undefined?f:\"null\";if(s.length-1>o){const t=s.length-o-1;e+=`${n}\"... ${getItemCount(t)} not stringified\"`}e+=`\\n${t}`;l.pop();return`[${e}]`}let r=Object.keys(s);const g=r.length;if(g===0){return\"{}\"}if(u<l.length+1){return'\"[Object]\"'}a+=c;const p=`,\\n${a}`;let y=\"\";let d=\"\";let h=Math.min(g,o);if(isTypedArrayWithEntries(s)){y+=stringifyTypedArray(s,p,o);r=r.slice(s.length);h-=s.length;d=p}if(i){r=sort(r,f)}l.push(s);for(let e=0;e<h;e++){const t=r[e];const n=stringifyIndent(t,s[t],l,c,a);if(n!==undefined){y+=`${d}${strEscape(t)}: ${n}`;d=p}}if(g>o){const e=g-o;y+=`${d}\"...\": \"${getItemCount(e)} not stringified\"`;d=p}if(d!==\"\"){y=`\\n${a}${y}\\n${t}`}l.pop();return`{${y}}`}case\"number\":return isFinite(s)?String(s):t?t(s):\"null\";case\"boolean\":return s===true?\"true\":\"false\";case\"undefined\":return undefined;case\"bigint\":if(r){return String(s)}default:return t?t(s):undefined}}function stringifySimple(e,s,l){switch(typeof s){case\"string\":return strEscape(s);case\"object\":{if(s===null){return\"null\"}if(typeof s.toJSON===\"function\"){s=s.toJSON(e);if(typeof s!==\"object\"){return stringifySimple(e,s,l)}if(s===null){return\"null\"}}if(l.indexOf(s)!==-1){return n}let t=\"\";const r=s.length!==undefined;if(r&&Array.isArray(s)){if(s.length===0){return\"[]\"}if(u<l.length+1){return'\"[Array]\"'}l.push(s);const e=Math.min(s.length,o);let n=0;for(;n<e-1;n++){const e=stringifySimple(String(n),s[n],l);t+=e!==undefined?e:\"null\";t+=\",\"}const r=stringifySimple(String(n),s[n],l);t+=r!==undefined?r:\"null\";if(s.length-1>o){const e=s.length-o-1;t+=`,\"... ${getItemCount(e)} not stringified\"`}l.pop();return`[${t}]`}let c=Object.keys(s);const a=c.length;if(a===0){return\"{}\"}if(u<l.length+1){return'\"[Object]\"'}let g=\"\";let p=Math.min(a,o);if(r&&isTypedArrayWithEntries(s)){t+=stringifyTypedArray(s,\",\",o);c=c.slice(s.length);p-=s.length;g=\",\"}if(i){c=sort(c,f)}l.push(s);for(let e=0;e<p;e++){const n=c[e];const r=stringifySimple(n,s[n],l);if(r!==undefined){t+=`${g}${strEscape(n)}:${r}`;g=\",\"}}if(a>o){const e=a-o;t+=`${g}\"...\":\"${getItemCount(e)} not stringified\"`}l.pop();return`{${t}}`}case\"number\":return isFinite(s)?String(s):t?t(s):\"null\";case\"boolean\":return s===true?\"true\":\"false\";case\"undefined\":return undefined;case\"bigint\":if(r){return String(s)}default:return t?t(s):undefined}}function stringify(e,t,n){if(arguments.length>1){let r=\"\";if(typeof n===\"number\"){r=\" \".repeat(Math.min(n,10))}else if(typeof n===\"string\"){r=n.slice(0,10)}if(t!=null){if(typeof t===\"function\"){return stringifyFnReplacer(\"\",{\"\":e},[],t,r,\"\")}if(Array.isArray(t)){return stringifyArrayReplacer(\"\",e,[],getUniqueReplacerSet(t),r,\"\")}}if(r.length!==0){return stringifyIndent(\"\",e,[],r,\"\")}}return stringifySimple(\"\",e,[])}return stringify}}};var t={};function __nccwpck_require__(n){var r=t[n];if(r!==undefined){return r.exports}var i=t[n]={exports:{}};var f=true;try{e[n](i,i.exports,__nccwpck_require__);f=false}finally{if(f)delete t[n]}return i.exports}if(typeof __nccwpck_require__!==\"undefined\")__nccwpck_require__.ab=__dirname+\"/\";var n=__nccwpck_require__(879);module.exports=n})();","import type { ServerRuntime } from '../types'\n\nexport const TEXT_PLAIN_CONTENT_TYPE_HEADER = 'text/plain'\nexport const HTML_CONTENT_TYPE_HEADER = 'text/html; charset=utf-8'\nexport const JSON_CONTENT_TYPE_HEADER = 'application/json; charset=utf-8'\nexport const NEXT_QUERY_PARAM_PREFIX = 'nxtP'\nexport const NEXT_INTERCEPTION_MARKER_PREFIX = 'nxtI'\n\nexport const MATCHED_PATH_HEADER = 'x-matched-path'\nexport const PRERENDER_REVALIDATE_HEADER = 'x-prerender-revalidate'\nexport const PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER =\n 'x-prerender-revalidate-if-generated'\n\nexport const RSC_PREFETCH_SUFFIX = '.prefetch.rsc'\nexport const RSC_SEGMENTS_DIR_SUFFIX = '.segments'\nexport const RSC_SEGMENT_SUFFIX = '.segment.rsc'\nexport const RSC_SUFFIX = '.rsc'\nexport const ACTION_SUFFIX = '.action'\nexport const NEXT_DATA_SUFFIX = '.json'\nexport const NEXT_META_SUFFIX = '.meta'\nexport const NEXT_BODY_SUFFIX = '.body'\n\nexport const NEXT_CACHE_TAGS_HEADER = 'x-next-cache-tags'\nexport const NEXT_CACHE_REVALIDATED_TAGS_HEADER = 'x-next-revalidated-tags'\nexport const NEXT_CACHE_REVALIDATE_TAG_TOKEN_HEADER =\n 'x-next-revalidate-tag-token'\n\nexport const NEXT_RESUME_HEADER = 'next-resume'\n\n// if these change make sure we update the related\n// documentation as well\nexport const NEXT_CACHE_TAG_MAX_ITEMS = 128\nexport const NEXT_CACHE_TAG_MAX_LENGTH = 256\nexport const NEXT_CACHE_SOFT_TAG_MAX_LENGTH = 1024\nexport const NEXT_CACHE_IMPLICIT_TAG_ID = '_N_T_'\n\n// in seconds\nexport const CACHE_ONE_YEAR = 31536000\n\n// in seconds, represents revalidate=false. I.e. never revaliate.\n// We use this value since it can be represented as a V8 SMI for optimal performance.\n// It can also be serialized as JSON if it ever leaks accidentally as an actual value.\nexport const INFINITE_CACHE = 0xfffffffe\n\n// Patterns to detect middleware files\nexport const MIDDLEWARE_FILENAME = 'middleware'\nexport const MIDDLEWARE_LOCATION_REGEXP = `(?:src/)?${MIDDLEWARE_FILENAME}`\n\n// Patterns to detect proxy files (replacement for middleware)\nexport const PROXY_FILENAME = 'proxy'\nexport const PROXY_LOCATION_REGEXP = `(?:src/)?${PROXY_FILENAME}`\n\n// Pattern to detect instrumentation hooks file\nexport const INSTRUMENTATION_HOOK_FILENAME = 'instrumentation'\n\n// Because on Windows absolute paths in the generated code can break because of numbers, eg 1 in the path,\n// we have to use a private alias\nexport const PAGES_DIR_ALIAS = 'private-next-pages'\nexport const DOT_NEXT_ALIAS = 'private-dot-next'\nexport const ROOT_DIR_ALIAS = 'private-next-root-dir'\nexport const APP_DIR_ALIAS = 'private-next-app-dir'\nexport const RSC_MOD_REF_PROXY_ALIAS = 'private-next-rsc-mod-ref-proxy'\nexport const RSC_ACTION_VALIDATE_ALIAS = 'private-next-rsc-action-validate'\nexport const RSC_ACTION_PROXY_ALIAS = 'private-next-rsc-server-reference'\nexport const RSC_CACHE_WRAPPER_ALIAS = 'private-next-rsc-cache-wrapper'\nexport const RSC_DYNAMIC_IMPORT_WRAPPER_ALIAS =\n 'private-next-rsc-track-dynamic-import'\nexport const RSC_ACTION_ENCRYPTION_ALIAS = 'private-next-rsc-action-encryption'\nexport const RSC_ACTION_CLIENT_WRAPPER_ALIAS =\n 'private-next-rsc-action-client-wrapper'\n\nexport const PUBLIC_DIR_MIDDLEWARE_CONFLICT = `You can not have a '_next' folder inside of your public folder. This conflicts with the internal '/_next' route. https://nextjs.org/docs/messages/public-next-folder-conflict`\n\nexport const SSG_GET_INITIAL_PROPS_CONFLICT = `You can not use getInitialProps with getStaticProps. To use SSG, please remove your getInitialProps`\n\nexport const SERVER_PROPS_GET_INIT_PROPS_CONFLICT = `You can not use getInitialProps with getServerSideProps. Please remove getInitialProps.`\n\nexport const SERVER_PROPS_SSG_CONFLICT = `You can not use getStaticProps or getStaticPaths with getServerSideProps. To use SSG, please remove getServerSideProps`\n\nexport const STATIC_STATUS_PAGE_GET_INITIAL_PROPS_ERROR = `can not have getInitialProps/getServerSideProps, https://nextjs.org/docs/messages/404-get-initial-props`\n\nexport const SERVER_PROPS_EXPORT_ERROR = `pages with \\`getServerSideProps\\` can not be exported. See more info here: https://nextjs.org/docs/messages/gssp-export`\n\nexport const GSP_NO_RETURNED_VALUE =\n 'Your `getStaticProps` function did not return an object. Did you forget to add a `return`?'\nexport const GSSP_NO_RETURNED_VALUE =\n 'Your `getServerSideProps` function did not return an object. Did you forget to add a `return`?'\n\nexport const UNSTABLE_REVALIDATE_RENAME_ERROR =\n 'The `unstable_revalidate` property is available for general use.\\n' +\n 'Please use `revalidate` instead.'\n\nexport const GSSP_COMPONENT_MEMBER_ERROR = `can not be attached to a page's component and must be exported from the page. See more info here: https://nextjs.org/docs/messages/gssp-component-member`\n\nexport const NON_STANDARD_NODE_ENV = `You are using a non-standard \"NODE_ENV\" value in your environment. This creates inconsistencies in the project and is strongly advised against. Read more: https://nextjs.org/docs/messages/non-standard-node-env`\n\nexport const SSG_FALLBACK_EXPORT_ERROR = `Pages with \\`fallback\\` enabled in \\`getStaticPaths\\` can not be exported. See more info here: https://nextjs.org/docs/messages/ssg-fallback-true-export`\n\nexport const ESLINT_DEFAULT_DIRS = ['app', 'pages', 'components', 'lib', 'src']\n\nexport const SERVER_RUNTIME: Record<string, ServerRuntime> = {\n edge: 'edge',\n experimentalEdge: 'experimental-edge',\n nodejs: 'nodejs',\n}\n\nexport const WEB_SOCKET_MAX_RECONNECTIONS = 12\n\n/**\n * The names of the webpack layers. These layers are the primitives for the\n * webpack chunks.\n */\nconst WEBPACK_LAYERS_NAMES = {\n /**\n * The layer for the shared code between the client and server bundles.\n */\n shared: 'shared',\n /**\n * The layer for server-only runtime and picking up `react-server` export conditions.\n * Including app router RSC pages and app router custom routes and metadata routes.\n */\n reactServerComponents: 'rsc',\n /**\n * Server Side Rendering layer for app (ssr).\n */\n serverSideRendering: 'ssr',\n /**\n * The browser client bundle layer for actions.\n */\n actionBrowser: 'action-browser',\n /**\n * The Node.js bundle layer for the API routes.\n */\n apiNode: 'api-node',\n /**\n * The Edge Lite bundle layer for the API routes.\n */\n apiEdge: 'api-edge',\n /**\n * The layer for the middleware code.\n */\n middleware: 'middleware',\n /**\n * The layer for the instrumentation hooks.\n */\n instrument: 'instrument',\n /**\n * The layer for assets on the edge.\n */\n edgeAsset: 'edge-asset',\n /**\n * The browser client bundle layer for App directory.\n */\n appPagesBrowser: 'app-pages-browser',\n /**\n * The browser client bundle layer for Pages directory.\n */\n pagesDirBrowser: 'pages-dir-browser',\n /**\n * The Edge Lite bundle layer for Pages directory.\n */\n pagesDirEdge: 'pages-dir-edge',\n /**\n * The Node.js bundle layer for Pages directory.\n */\n pagesDirNode: 'pages-dir-node',\n} as const\n\nexport type WebpackLayerName =\n (typeof WEBPACK_LAYERS_NAMES)[keyof typeof WEBPACK_LAYERS_NAMES]\n\nconst WEBPACK_LAYERS = {\n ...WEBPACK_LAYERS_NAMES,\n GROUP: {\n builtinReact: [\n WEBPACK_LAYERS_NAMES.reactServerComponents,\n WEBPACK_LAYERS_NAMES.actionBrowser,\n ],\n serverOnly: [\n WEBPACK_LAYERS_NAMES.reactServerComponents,\n WEBPACK_LAYERS_NAMES.actionBrowser,\n WEBPACK_LAYERS_NAMES.instrument,\n WEBPACK_LAYERS_NAMES.middleware,\n ],\n neutralTarget: [\n // pages api\n WEBPACK_LAYERS_NAMES.apiNode,\n WEBPACK_LAYERS_NAMES.apiEdge,\n ],\n clientOnly: [\n WEBPACK_LAYERS_NAMES.serverSideRendering,\n WEBPACK_LAYERS_NAMES.appPagesBrowser,\n ],\n bundled: [\n WEBPACK_LAYERS_NAMES.reactServerComponents,\n WEBPACK_LAYERS_NAMES.actionBrowser,\n WEBPACK_LAYERS_NAMES.serverSideRendering,\n WEBPACK_LAYERS_NAMES.appPagesBrowser,\n WEBPACK_LAYERS_NAMES.shared,\n WEBPACK_LAYERS_NAMES.instrument,\n WEBPACK_LAYERS_NAMES.middleware,\n ],\n appPages: [\n // app router pages and layouts\n WEBPACK_LAYERS_NAMES.reactServerComponents,\n WEBPACK_LAYERS_NAMES.serverSideRendering,\n WEBPACK_LAYERS_NAMES.appPagesBrowser,\n WEBPACK_LAYERS_NAMES.actionBrowser,\n ],\n },\n}\n\nconst WEBPACK_RESOURCE_QUERIES = {\n edgeSSREntry: '__next_edge_ssr_entry__',\n metadata: '__next_metadata__',\n metadataRoute: '__next_metadata_route__',\n metadataImageMeta: '__next_metadata_image_meta__',\n}\n\nexport { WEBPACK_LAYERS, WEBPACK_RESOURCE_QUERIES }\n","import path from 'path'\nimport { pathToFileURL } from 'url'\n\n/**\n * The path for a dynamic route must be URLs with a valid scheme.\n *\n * When an absolute Windows path is passed to it, it interprets the beginning of the path as a protocol (`C:`).\n * Therefore, it is important to always construct a complete path.\n * @param dir File directory\n * @param filePath Absolute or relative path\n */\nexport const formatDynamicImportPath = (dir: string, filePath: string) => {\n const absoluteFilePath = path.isAbsolute(filePath)\n ? filePath\n : path.join(dir, filePath)\n const formattedFilePath = pathToFileURL(absoluteFilePath).toString()\n\n return formattedFilePath\n}\n","import type { IncomingMessage } from 'http'\nimport type { BaseNextRequest } from '../base-http'\nimport type { CookieSerializeOptions } from 'next/dist/compiled/cookie'\nimport type { NextApiResponse } from '../../shared/lib/utils'\n\nimport { HeadersAdapter } from '../web/spec-extension/adapters/headers'\nimport {\n PRERENDER_REVALIDATE_HEADER,\n PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER,\n} from '../../lib/constants'\nimport { getTracer } from '../lib/trace/tracer'\nimport { NodeSpan } from '../lib/trace/constants'\n\nexport type NextApiRequestCookies = Partial<{ [key: string]: string }>\nexport type NextApiRequestQuery = Partial<{ [key: string]: string | string[] }>\n\nexport type __ApiPreviewProps = {\n previewModeId: string\n previewModeEncryptionKey: string\n previewModeSigningKey: string\n}\n\nexport function wrapApiHandler<T extends (...args: any[]) => any>(\n page: string,\n handler: T\n): T {\n return ((...args) => {\n getTracer().setRootSpanAttribute('next.route', page)\n // Call API route method\n return getTracer().trace(\n NodeSpan.runHandler,\n {\n spanName: `executing api route (pages) ${page}`,\n },\n () => handler(...args)\n )\n }) as T\n}\n\n/**\n *\n * @param res response object\n * @param statusCode `HTTP` status code of response\n */\nexport function sendStatusCode(\n res: NextApiResponse,\n statusCode: number\n): NextApiResponse<any> {\n res.statusCode = statusCode\n return res\n}\n\n/**\n *\n * @param res response object\n * @param [statusOrUrl] `HTTP` status code of redirect\n * @param url URL of redirect\n */\nexport function redirect(\n res: NextApiResponse,\n statusOrUrl: string | number,\n url?: string\n): NextApiResponse<any> {\n if (typeof statusOrUrl === 'string') {\n url = statusOrUrl\n statusOrUrl = 307\n }\n if (typeof statusOrUrl !== 'number' || typeof url !== 'string') {\n throw new Error(\n `Invalid redirect arguments. Please use a single argument URL, e.g. res.redirect('/destination') or use a status code and URL, e.g. res.redirect(307, '/destination').`\n )\n }\n res.writeHead(statusOrUrl, { Location: url })\n res.write(url)\n res.end()\n return res\n}\n\nexport function checkIsOnDemandRevalidate(\n req: Request | IncomingMessage | BaseNextRequest,\n previewProps: __ApiPreviewProps\n): {\n isOnDemandRevalidate: boolean\n revalidateOnlyGenerated: boolean\n} {\n const headers = HeadersAdapter.from(req.headers)\n\n const previewModeId = headers.get(PRERENDER_REVALIDATE_HEADER)\n const isOnDemandRevalidate = previewModeId === previewProps.previewModeId\n\n const revalidateOnlyGenerated = headers.has(\n PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER\n )\n\n return { isOnDemandRevalidate, revalidateOnlyGenerated }\n}\n\nexport const COOKIE_NAME_PRERENDER_BYPASS = `__prerender_bypass`\nexport const COOKIE_NAME_PRERENDER_DATA = `__next_preview_data`\n\nexport const RESPONSE_LIMIT_DEFAULT = 4 * 1024 * 1024\n\nexport const SYMBOL_PREVIEW_DATA = Symbol(COOKIE_NAME_PRERENDER_DATA)\nexport const SYMBOL_CLEARED_COOKIES = Symbol(COOKIE_NAME_PRERENDER_BYPASS)\n\nexport function clearPreviewData<T>(\n res: NextApiResponse<T>,\n options: {\n path?: string\n } = {}\n): NextApiResponse<T> {\n if (SYMBOL_CLEARED_COOKIES in res) {\n return res\n }\n\n const { serialize } =\n require('next/dist/compiled/cookie') as typeof import('next/dist/compiled/cookie')\n const previous = res.getHeader('Set-Cookie')\n res.setHeader(`Set-Cookie`, [\n ...(typeof previous === 'string'\n ? [previous]\n : Array.isArray(previous)\n ? previous\n : []),\n serialize(COOKIE_NAME_PRERENDER_BYPASS, '', {\n // To delete a cookie, set `expires` to a date in the past:\n // https://tools.ietf.org/html/rfc6265#section-4.1.1\n // `Max-Age: 0` is not valid, thus ignored, and the cookie is persisted.\n expires: new Date(0),\n httpOnly: true,\n sameSite: process.env.NODE_ENV !== 'development' ? 'none' : 'lax',\n secure: process.env.NODE_ENV !== 'development',\n path: '/',\n ...(options.path !== undefined\n ? ({ path: options.path } as CookieSerializeOptions)\n : undefined),\n }),\n serialize(COOKIE_NAME_PRERENDER_DATA, '', {\n // To delete a cookie, set `expires` to a date in the past:\n // https://tools.ietf.org/html/rfc6265#section-4.1.1\n // `Max-Age: 0` is not valid, thus ignored, and the cookie is persisted.\n expires: new Date(0),\n httpOnly: true,\n sameSite: process.env.NODE_ENV !== 'development' ? 'none' : 'lax',\n secure: process.env.NODE_ENV !== 'development',\n path: '/',\n ...(options.path !== undefined\n ? ({ path: options.path } as CookieSerializeOptions)\n : undefined),\n }),\n ])\n\n Object.defineProperty(res, SYMBOL_CLEARED_COOKIES, {\n value: true,\n enumerable: false,\n })\n return res\n}\n\n/**\n * Custom error class\n */\nexport class ApiError extends Error {\n readonly statusCode: number\n\n constructor(statusCode: number, message: string) {\n super(message)\n this.statusCode = statusCode\n }\n}\n\n/**\n * Sends error in `response`\n * @param res response object\n * @param statusCode of response\n * @param message of response\n */\nexport function sendError(\n res: NextApiResponse,\n statusCode: number,\n message: string\n): void {\n res.statusCode = statusCode\n res.statusMessage = message\n res.end(message)\n}\n\ninterface LazyProps {\n req: IncomingMessage\n}\n\n/**\n * Execute getter function only if its needed\n * @param LazyProps `req` and `params` for lazyProp\n * @param prop name of property\n * @param getter function to get data\n */\nexport function setLazyProp<T>(\n { req }: LazyProps,\n prop: string,\n getter: () => T\n): void {\n const opts = { configurable: true, enumerable: true }\n const optsReset = { ...opts, writable: true }\n\n Object.defineProperty(req, prop, {\n ...opts,\n get: () => {\n const value = getter()\n // we set the property on the object to avoid recalculating it\n Object.defineProperty(req, prop, { ...optsReset, value })\n return value\n },\n set: (value) => {\n Object.defineProperty(req, prop, { ...optsReset, value })\n },\n })\n}\n","import type { IncomingMessage, ServerResponse } from 'http'\nimport type { NextApiResponse } from '../../../shared/lib/utils'\nimport { checkIsOnDemandRevalidate } from '../.'\nimport type { __ApiPreviewProps } from '../.'\nimport type { BaseNextRequest, BaseNextResponse } from '../../base-http'\nimport type { PreviewData } from '../../../types'\n\nimport {\n clearPreviewData,\n COOKIE_NAME_PRERENDER_BYPASS,\n COOKIE_NAME_PRERENDER_DATA,\n SYMBOL_PREVIEW_DATA,\n} from '../index'\nimport { RequestCookies } from '../../web/spec-extension/cookies'\nimport { HeadersAdapter } from '../../web/spec-extension/adapters/headers'\n\nexport function tryGetPreviewData(\n req: IncomingMessage | BaseNextRequest | Request,\n res: ServerResponse | BaseNextResponse,\n options: __ApiPreviewProps,\n multiZoneDraftMode: boolean\n): PreviewData {\n // if an On-Demand revalidation is being done preview mode\n // is disabled\n if (options && checkIsOnDemandRevalidate(req, options).isOnDemandRevalidate) {\n return false\n }\n\n // Read cached preview data if present\n // TODO: use request metadata instead of a symbol\n if (SYMBOL_PREVIEW_DATA in req) {\n return (req as any)[SYMBOL_PREVIEW_DATA] as any\n }\n\n const headers = HeadersAdapter.from(req.headers)\n const cookies = new RequestCookies(headers)\n\n const previewModeId = cookies.get(COOKIE_NAME_PRERENDER_BYPASS)?.value\n const tokenPreviewData = cookies.get(COOKIE_NAME_PRERENDER_DATA)?.value\n\n // Case: preview mode cookie set but data cookie is not set\n if (\n previewModeId &&\n !tokenPreviewData &&\n previewModeId === options.previewModeId\n ) {\n // This is \"Draft Mode\" which doesn't use\n // previewData, so we return an empty object\n // for backwards compat with \"Preview Mode\".\n const data = {}\n Object.defineProperty(req, SYMBOL_PREVIEW_DATA, {\n value: data,\n enumerable: false,\n })\n return data\n }\n\n // Case: neither cookie is set.\n if (!previewModeId && !tokenPreviewData) {\n return false\n }\n\n // Case: one cookie is set, but not the other.\n if (!previewModeId || !tokenPreviewData) {\n if (!multiZoneDraftMode) {\n clearPreviewData(res as NextApiResponse)\n }\n return false\n }\n\n // Case: preview session is for an old build.\n if (previewModeId !== options.previewModeId) {\n if (!multiZoneDraftMode) {\n clearPreviewData(res as NextApiResponse)\n }\n return false\n }\n\n let encryptedPreviewData: {\n data: string\n }\n try {\n const jsonwebtoken =\n require('next/dist/compiled/jsonwebtoken') as typeof import('next/dist/compiled/jsonwebtoken')\n encryptedPreviewData = jsonwebtoken.verify(\n tokenPreviewData,\n options.previewModeSigningKey\n ) as typeof encryptedPreviewData\n } catch {\n // TODO: warn\n clearPreviewData(res as NextApiResponse)\n return false\n }\n\n const { decryptWithSecret } =\n require('../../crypto-utils') as typeof import('../../crypto-utils')\n const decryptedPreviewData = decryptWithSecret(\n Buffer.from(options.previewModeEncryptionKey),\n encryptedPreviewData.data\n )\n\n try {\n // TODO: strict runtime type checking\n const data = JSON.parse(decryptedPreviewData)\n // Cache lookup\n Object.defineProperty(req, SYMBOL_PREVIEW_DATA, {\n value: data,\n enumerable: false,\n })\n return data\n } catch {\n return false\n }\n}\n","import crypto from 'crypto'\n\n// Background:\n// https://security.stackexchange.com/questions/184305/why-would-i-ever-use-aes-256-cbc-if-aes-256-gcm-is-more-secure\n\nconst CIPHER_ALGORITHM = `aes-256-gcm`,\n CIPHER_KEY_LENGTH = 32, // https://stackoverflow.com/a/28307668/4397028\n CIPHER_IV_LENGTH = 16, // https://stackoverflow.com/a/28307668/4397028\n CIPHER_TAG_LENGTH = 16,\n CIPHER_SALT_LENGTH = 64\n\nconst PBKDF2_ITERATIONS = 100_000 // https://support.1password.com/pbkdf2/\n\nexport function encryptWithSecret(secret: Buffer, data: string): string {\n const iv = crypto.randomBytes(CIPHER_IV_LENGTH)\n const salt = crypto.randomBytes(CIPHER_SALT_LENGTH)\n\n // https://nodejs.org/api/crypto.html#crypto_crypto_pbkdf2sync_password_salt_iterations_keylen_digest\n const key = crypto.pbkdf2Sync(\n secret,\n salt,\n PBKDF2_ITERATIONS,\n CIPHER_KEY_LENGTH,\n `sha512`\n )\n\n const cipher = crypto.createCipheriv(CIPHER_ALGORITHM, key, iv)\n const encrypted = Buffer.concat([cipher.update(data, `utf8`), cipher.final()])\n\n // https://nodejs.org/api/crypto.html#crypto_cipher_getauthtag\n const tag = cipher.getAuthTag()\n\n return Buffer.concat([\n // Data as required by:\n // Salt for Key: https://nodejs.org/api/crypto.html#crypto_crypto_pbkdf2sync_password_salt_iterations_keylen_digest\n // IV: https://nodejs.org/api/crypto.html#crypto_class_decipher\n // Tag: https://nodejs.org/api/crypto.html#crypto_decipher_setauthtag_buffer\n salt,\n iv,\n tag,\n encrypted,\n ]).toString(`hex`)\n}\n\nexport function decryptWithSecret(\n secret: Buffer,\n encryptedData: string\n): string {\n const buffer = Buffer.from(encryptedData, `hex`)\n\n const salt = buffer.slice(0, CIPHER_SALT_LENGTH)\n const iv = buffer.slice(\n CIPHER_SALT_LENGTH,\n CIPHER_SALT_LENGTH + CIPHER_IV_LENGTH\n )\n const tag = buffer.slice(\n CIPHER_SALT_LENGTH + CIPHER_IV_LENGTH,\n CIPHER_SALT_LENGTH + CIPHER_IV_LENGTH + CIPHER_TAG_LENGTH\n )\n const encrypted = buffer.slice(\n CIPHER_SALT_LENGTH + CIPHER_IV_LENGTH + CIPHER_TAG_LENGTH\n )\n\n // https://nodejs.org/api/crypto.html#crypto_crypto_pbkdf2sync_password_salt_iterations_keylen_digest\n const key = crypto.pbkdf2Sync(\n secret,\n salt,\n PBKDF2_ITERATIONS,\n CIPHER_KEY_LENGTH,\n `sha512`\n )\n\n const decipher = crypto.createDecipheriv(CIPHER_ALGORITHM, key, iv)\n decipher.setAuthTag(tag)\n\n return decipher.update(encrypted) + decipher.final(`utf8`)\n}\n","import type { CacheFs } from '../../shared/lib/utils'\n\nimport fs from 'fs'\n\nexport const nodeFs: CacheFs = {\n existsSync: fs.existsSync,\n readFile: fs.promises.readFile,\n readFileSync: fs.readFileSync,\n writeFile: (f, d) => fs.promises.writeFile(f, d),\n mkdir: (dir) => fs.promises.mkdir(dir, { recursive: true }),\n stat: (f) => fs.promises.stat(f),\n}\n","/**\n * Contains predefined constants for the trace span name in next/server.\n *\n * Currently, next/server/tracer is internal implementation only for tracking\n * next.js's implementation only with known span names defined here.\n **/\n\n// eslint typescript has a bug with TS enums\n\nenum BaseServerSpan {\n handleRequest = 'BaseServer.handleRequest',\n run = 'BaseServer.run',\n pipe = 'BaseServer.pipe',\n getStaticHTML = 'BaseServer.getStaticHTML',\n render = 'BaseServer.render',\n renderToResponseWithComponents = 'BaseServer.renderToResponseWithComponents',\n renderToResponse = 'BaseServer.renderToResponse',\n renderToHTML = 'BaseServer.renderToHTML',\n renderError = 'BaseServer.renderError',\n renderErrorToResponse = 'BaseServer.renderErrorToResponse',\n renderErrorToHTML = 'BaseServer.renderErrorToHTML',\n render404 = 'BaseServer.render404',\n}\n\nenum LoadComponentsSpan {\n loadDefaultErrorComponents = 'LoadComponents.loadDefaultErrorComponents',\n loadComponents = 'LoadComponents.loadComponents',\n}\n\nenum NextServerSpan {\n getRequestHandler = 'NextServer.getRequestHandler',\n getRequestHandlerWithMetadata = 'NextServer.getRequestHandlerWithMetadata',\n getServer = 'NextServer.getServer',\n getServerRequestHandler = 'NextServer.getServerRequestHandler',\n createServer = 'createServer.createServer',\n}\n\nenum NextNodeServerSpan {\n compression = 'NextNodeServer.compression',\n getBuildId = 'NextNodeServer.getBuildId',\n createComponentTree = 'NextNodeServer.createComponentTree',\n clientComponentLoading = 'NextNodeServer.clientComponentLoading',\n getLayoutOrPageModule = 'NextNodeServer.getLayoutOrPageModule',\n generateStaticRoutes = 'NextNodeServer.generateStaticRoutes',\n generateFsStaticRoutes = 'NextNodeServer.generateFsStaticRoutes',\n generatePublicRoutes = 'NextNodeServer.generatePublicRoutes',\n generateImageRoutes = 'NextNodeServer.generateImageRoutes.route',\n sendRenderResult = 'NextNodeServer.sendRenderResult',\n proxyRequest = 'NextNodeServer.proxyRequest',\n runApi = 'NextNodeServer.runApi',\n render = 'NextNodeServer.render',\n renderHTML = 'NextNodeServer.renderHTML',\n imageOptimizer = 'NextNodeServer.imageOptimizer',\n getPagePath = 'NextNodeServer.getPagePath',\n getRoutesManifest = 'NextNodeServer.getRoutesManifest',\n findPageComponents = 'NextNodeServer.findPageComponents',\n getFontManifest = 'NextNodeServer.getFontManifest',\n getServerComponentManifest = 'NextNodeServer.getServerComponentManifest',\n getRequestHandler = 'NextNodeServer.getRequestHandler',\n renderToHTML = 'NextNodeServer.renderToHTML',\n renderError = 'NextNodeServer.renderError',\n renderErrorToHTML = 'NextNodeServer.renderErrorToHTML',\n render404 = 'NextNodeServer.render404',\n startResponse = 'NextNodeServer.startResponse',\n\n // nested inner span, does not require parent scope name\n route = 'route',\n onProxyReq = 'onProxyReq',\n apiResolver = 'apiResolver',\n internalFetch = 'internalFetch',\n}\n\nenum StartServerSpan {\n startServer = 'startServer.startServer',\n}\n\nenum RenderSpan {\n getServerSideProps = 'Render.getServerSideProps',\n getStaticProps = 'Render.getStaticProps',\n renderToString = 'Render.renderToString',\n renderDocument = 'Render.renderDocument',\n createBodyResult = 'Render.createBodyResult',\n}\n\nenum AppRenderSpan {\n renderToString = 'AppRender.renderToString',\n renderToReadableStream = 'AppRender.renderToReadableStream',\n getBodyResult = 'AppRender.getBodyResult',\n fetch = 'AppRender.fetch',\n}\n\nenum RouterSpan {\n executeRoute = 'Router.executeRoute',\n}\n\nenum NodeSpan {\n runHandler = 'Node.runHandler',\n}\n\nenum AppRouteRouteHandlersSpan {\n runHandler = 'AppRouteRouteHandlers.runHandler',\n}\n\nenum ResolveMetadataSpan {\n generateMetadata = 'ResolveMetadata.generateMetadata',\n generateViewport = 'ResolveMetadata.generateViewport',\n}\n\nenum MiddlewareSpan {\n execute = 'Middleware.execute',\n}\n\ntype SpanTypes =\n | `${BaseServerSpan}`\n | `${LoadComponentsSpan}`\n | `${NextServerSpan}`\n | `${StartServerSpan}`\n | `${NextNodeServerSpan}`\n | `${RenderSpan}`\n | `${RouterSpan}`\n | `${AppRenderSpan}`\n | `${NodeSpan}`\n | `${AppRouteRouteHandlersSpan}`\n | `${ResolveMetadataSpan}`\n | `${MiddlewareSpan}`\n\n// This list is used to filter out spans that are not relevant to the user\nexport const NextVanillaSpanAllowlist = [\n MiddlewareSpan.execute,\n BaseServerSpan.handleRequest,\n RenderSpan.getServerSideProps,\n RenderSpan.getStaticProps,\n AppRenderSpan.fetch,\n AppRenderSpan.getBodyResult,\n RenderSpan.renderDocument,\n NodeSpan.runHandler,\n AppRouteRouteHandlersSpan.runHandler,\n ResolveMetadataSpan.generateMetadata,\n ResolveMetadataSpan.generateViewport,\n NextNodeServerSpan.createComponentTree,\n NextNodeServerSpan.findPageComponents,\n NextNodeServerSpan.getLayoutOrPageModule,\n NextNodeServerSpan.startResponse,\n NextNodeServerSpan.clientComponentLoading,\n]\n\n// These Spans are allowed to be always logged\n// when the otel log prefix env is set\nexport const LogSpanAllowList = [\n NextNodeServerSpan.findPageComponents,\n NextNodeServerSpan.createComponentTree,\n NextNodeServerSpan.clientComponentLoading,\n]\n\nexport {\n BaseServerSpan,\n LoadComponentsSpan,\n NextServerSpan,\n NextNodeServerSpan,\n StartServerSpan,\n RenderSpan,\n RouterSpan,\n AppRenderSpan,\n NodeSpan,\n AppRouteRouteHandlersSpan,\n ResolveMetadataSpan,\n MiddlewareSpan,\n}\n\nexport type { SpanTypes }\n","export class ReflectAdapter {\n static get<T extends object>(\n target: T,\n prop: string | symbol,\n receiver: unknown\n ): any {\n const value = Reflect.get(target, prop, receiver)\n if (typeof value === 'function') {\n return value.bind(target)\n }\n\n return value\n }\n\n static set<T extends object>(\n target: T,\n prop: string | symbol,\n value: any,\n receiver: any\n ): boolean {\n return Reflect.set(target, prop, value, receiver)\n }\n\n static has<T extends object>(target: T, prop: string | symbol): boolean {\n return Reflect.has(target, prop)\n }\n\n static deleteProperty<T extends object>(\n target: T,\n prop: string | symbol\n ): boolean {\n return Reflect.deleteProperty(target, prop)\n }\n}\n","import type { IncomingHttpHeaders } from 'http'\n\nimport { ReflectAdapter } from './reflect'\n\n/**\n * @internal\n */\nexport class ReadonlyHeadersError extends Error {\n constructor() {\n super(\n 'Headers cannot be modified. Read more: https://nextjs.org/docs/app/api-reference/functions/headers'\n )\n }\n\n public static callable() {\n throw new ReadonlyHeadersError()\n }\n}\n\nexport type ReadonlyHeaders = Headers & {\n /** @deprecated Method unavailable on `ReadonlyHeaders`. Read more: https://nextjs.org/docs/app/api-reference/functions/headers */\n append(...args: any[]): void\n /** @deprecated Method unavailable on `ReadonlyHeaders`. Read more: https://nextjs.org/docs/app/api-reference/functions/headers */\n set(...args: any[]): void\n /** @deprecated Method unavailable on `ReadonlyHeaders`. Read more: https://nextjs.org/docs/app/api-reference/functions/headers */\n delete(...args: any[]): void\n}\nexport class HeadersAdapter extends Headers {\n private readonly headers: IncomingHttpHeaders\n\n constructor(headers: IncomingHttpHeaders) {\n // We've already overridden the methods that would be called, so we're just\n // calling the super constructor to ensure that the instanceof check works.\n super()\n\n this.headers = new Proxy(headers, {\n get(target, prop, receiver) {\n // Because this is just an object, we expect that all \"get\" operations\n // are for properties. If it's a \"get\" for a symbol, we'll just return\n // the symbol.\n if (typeof prop === 'symbol') {\n return ReflectAdapter.get(target, prop, receiver)\n }\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, return undefined.\n if (typeof original === 'undefined') return\n\n // If the original casing exists, return the value.\n return ReflectAdapter.get(target, original, receiver)\n },\n set(target, prop, value, receiver) {\n if (typeof prop === 'symbol') {\n return ReflectAdapter.set(target, prop, value, receiver)\n }\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, use the prop as the key.\n return ReflectAdapter.set(target, original ?? prop, value, receiver)\n },\n has(target, prop) {\n if (typeof prop === 'symbol') return ReflectAdapter.has(target, prop)\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, return false.\n if (typeof original === 'undefined') return false\n\n // If the original casing exists, return true.\n return ReflectAdapter.has(target, original)\n },\n deleteProperty(target, prop) {\n if (typeof prop === 'symbol')\n return ReflectAdapter.deleteProperty(target, prop)\n\n const lowercased = prop.toLowerCase()\n\n // Let's find the original casing of the key. This assumes that there is\n // no mixed case keys (e.g. \"Content-Type\" and \"content-type\") in the\n // headers object.\n const original = Object.keys(headers).find(\n (o) => o.toLowerCase() === lowercased\n )\n\n // If the original casing doesn't exist, return true.\n if (typeof original === 'undefined') return true\n\n // If the original casing exists, delete the property.\n return ReflectAdapter.deleteProperty(target, original)\n },\n })\n }\n\n /**\n * Seals a Headers instance to prevent modification by throwing an error when\n * any mutating method is called.\n */\n public static seal(headers: Headers): ReadonlyHeaders {\n return new Proxy<ReadonlyHeaders>(headers, {\n get(target, prop, receiver) {\n switch (prop) {\n case 'append':\n case 'delete':\n case 'set':\n return ReadonlyHeadersError.callable\n default:\n return ReflectAdapter.get(target, prop, receiver)\n }\n },\n })\n }\n\n /**\n * Merges a header value into a string. This stores multiple values as an\n * array, so we need to merge them into a string.\n *\n * @param value a header value\n * @returns a merged header value (a string)\n */\n private merge(value: string | string[]): string {\n if (Array.isArray(value)) return value.join(', ')\n\n return value\n }\n\n /**\n * Creates a Headers instance from a plain object or a Headers instance.\n *\n * @param headers a plain object or a Headers instance\n * @returns a headers instance\n */\n public static from(headers: IncomingHttpHeaders | Headers): Headers {\n if (headers instanceof Headers) return headers\n\n return new HeadersAdapter(headers)\n }\n\n public append(name: string, value: string): void {\n const existing = this.headers[name]\n if (typeof existing === 'string') {\n this.headers[name] = [existing, value]\n } else if (Array.isArray(existing)) {\n existing.push(value)\n } else {\n this.headers[name] = value\n }\n }\n\n public delete(name: string): void {\n delete this.headers[name]\n }\n\n public get(name: string): string | null {\n const value = this.headers[name]\n if (typeof value !== 'undefined') return this.merge(value)\n\n return null\n }\n\n public has(name: string): boolean {\n return typeof this.headers[name] !== 'undefined'\n }\n\n public set(name: string, value: string): void {\n this.headers[name] = value\n }\n\n public forEach(\n callbackfn: (value: string, name: string, parent: Headers) => void,\n thisArg?: any\n ): void {\n for (const [name, value] of this.entries()) {\n callbackfn.call(thisArg, value, name, this)\n }\n }\n\n public *entries(): HeadersIterator<[string, string]> {\n for (const key of Object.keys(this.headers)) {\n const name = key.toLowerCase()\n // We assert here that this is a string because we got it from the\n // Object.keys() call above.\n const value = this.get(name) as string\n\n yield [name, value] as [string, string]\n }\n }\n\n public *keys(): HeadersIterator<string> {\n for (const key of Object.keys(this.headers)) {\n const name = key.toLowerCase()\n yield name\n }\n }\n\n public *values(): HeadersIterator<string> {\n for (const key of Object.keys(this.headers)) {\n // We assert here that this is a string because we got it from the\n // Object.keys() call above.\n const value = this.get(key) as string\n\n yield value\n }\n }\n\n public [Symbol.iterator](): HeadersIterator<[string, string]> {\n return this.entries()\n }\n}\n","/**\n * This module is for next.js server internal usage of path module.\n * It will use native path module for nodejs runtime.\n * It will use path-browserify polyfill for edge runtime.\n */\nlet path\n\nif (process.env.NEXT_RUNTIME === 'edge') {\n path = require('next/dist/compiled/path-browserify')\n} else {\n path = require('path')\n}\n\nmodule.exports = path\n","// Note: This file is JS because it's used by the taskfile-swc.js file, which is JS.\n// Keep file changes in sync with the corresponding `.d.ts` files.\n\n/**\n * These are the minimum browser versions that we consider \"modern\" and thus compile for by default.\n * This list was generated using `pnpm browserslist \"baseline widely available\"` on 2025-10-01.\n */\nconst MODERN_BROWSERSLIST_TARGET = [\n 'chrome 111',\n 'edge 111',\n 'firefox 111',\n 'safari 16.4',\n]\n\nmodule.exports = MODERN_BROWSERSLIST_TARGET\n","// getDefaultExport function for compatibility with non-ESM modules\n__webpack_require__.n = (module) => {\n\tvar getter = module && module.__esModule ?\n\t\t() => (module['default']) :\n\t\t() => (module);\n\t__webpack_require__.d(getter, { a: getter });\n\treturn getter;\n};\n","var getProto = Object.getPrototypeOf ? (obj) => (Object.getPrototypeOf(obj)) : (obj) => (obj.__proto__);\nvar leafPrototypes;\n// create a fake namespace object\n// mode & 1: value is a module id, require it\n// mode & 2: merge all properties of value into the ns\n// mode & 4: return value when already ns object\n// mode & 16: return value when it's Promise-like\n// mode & 8|1: behave like require\n__webpack_require__.t = function(value, mode) {\n\tif(mode & 1) value = this(value);\n\tif(mode & 8) return value;\n\tif(typeof value === 'object' && value) {\n\t\tif((mode & 4) && value.__esModule) return value;\n\t\tif((mode & 16) && typeof value.then === 'function') return value;\n\t}\n\tvar ns = Object.create(null);\n __webpack_require__.r(ns);\n\tvar def = {};\n\tleafPrototypes = leafPrototypes || [null, getProto({}), getProto([]), getProto(getProto)];\n\tfor(var current = mode & 2 && value; typeof current == 'object' && !~leafPrototypes.indexOf(current); current = getProto(current)) {\n\t\tObject.getOwnPropertyNames(current).forEach((key) => { def[key] = () => (value[key]) });\n\t}\n\tdef['default'] = () => (value);\n\t__webpack_require__.d(ns, def);\n\treturn ns;\n};","__webpack_require__.d = (exports, definition) => {\n\tfor(var key in definition) {\n if(__webpack_require__.o(definition, key) && !__webpack_require__.o(exports, key)) {\n Object.defineProperty(exports, key, { enumerable: true, get: definition[key] });\n }\n }\n};","__webpack_require__.o = (obj, prop) => (Object.prototype.hasOwnProperty.call(obj, prop))","// define __esModule on exports\n__webpack_require__.r = (exports) => {\n\tif(typeof Symbol !== 'undefined' && Symbol.toStringTag) {\n\t\tObject.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });\n\t}\n\tObject.defineProperty(exports, '__esModule', { value: true });\n};","import MODERN_BROWSERSLIST_TARGET from './modern-browserslist-target'\n\nexport { MODERN_BROWSERSLIST_TARGET }\n\nexport type ValueOf<T> = Required<T>[keyof T]\n\nexport const COMPILER_NAMES = {\n client: 'client',\n server: 'server',\n edgeServer: 'edge-server',\n} as const\n\nexport type CompilerNameValues = ValueOf<typeof COMPILER_NAMES>\n\nexport const COMPILER_INDEXES: {\n [compilerKey in CompilerNameValues]: number\n} = {\n [COMPILER_NAMES.client]: 0,\n [COMPILER_NAMES.server]: 1,\n [COMPILER_NAMES.edgeServer]: 2,\n} as const\n\n// Re-export entry constants for backward compatibility\nexport {\n UNDERSCORE_NOT_FOUND_ROUTE,\n UNDERSCORE_NOT_FOUND_ROUTE_ENTRY,\n UNDERSCORE_GLOBAL_ERROR_ROUTE,\n UNDERSCORE_GLOBAL_ERROR_ROUTE_ENTRY,\n} from './entry-constants'\n\nexport enum AdapterOutputType {\n /**\n * `PAGES` represents all the React pages that are under `pages/`.\n */\n PAGES = 'PAGES',\n\n /**\n * `PAGES_API` represents all the API routes under `pages/api/`.\n */\n PAGES_API = 'PAGES_API',\n /**\n * `APP_PAGE` represents all the React pages that are under `app/` with the\n * filename of `page.{j,t}s{,x}`.\n */\n APP_PAGE = 'APP_PAGE',\n\n /**\n * `APP_ROUTE` represents all the API routes and metadata routes that are under `app/` with the\n * filename of `route.{j,t}s{,x}`.\n */\n APP_ROUTE = 'APP_ROUTE',\n\n /**\n * `PRERENDER` represents an ISR enabled route that might\n * have a seeded cache entry or fallback generated during build\n */\n PRERENDER = 'PRERENDER',\n\n /**\n * `STATIC_FILE` represents a static file (ie /_next/static)\n */\n STATIC_FILE = 'STATIC_FILE',\n\n /**\n * `MIDDLEWARE` represents the middleware output if present\n */\n MIDDLEWARE = 'MIDDLEWARE',\n}\n\nexport const PHASE_EXPORT = 'phase-export'\nexport const PHASE_PRODUCTION_BUILD = 'phase-production-build'\nexport const PHASE_PRODUCTION_SERVER = 'phase-production-server'\nexport const PHASE_DEVELOPMENT_SERVER = 'phase-development-server'\nexport const PHASE_TEST = 'phase-test'\nexport const PHASE_INFO = 'phase-info'\n\nexport type PHASE_TYPE =\n | typeof PHASE_INFO\n | typeof PHASE_TEST\n | typeof PHASE_EXPORT\n | typeof PHASE_PRODUCTION_BUILD\n | typeof PHASE_PRODUCTION_SERVER\n | typeof PHASE_DEVELOPMENT_SERVER\n\nexport const PAGES_MANIFEST = 'pages-manifest.json'\nexport const WEBPACK_STATS = 'webpack-stats.json'\nexport const APP_PATHS_MANIFEST = 'app-paths-manifest.json'\nexport const APP_PATH_ROUTES_MANIFEST = 'app-path-routes-manifest.json'\nexport const BUILD_MANIFEST = 'build-manifest.json'\nexport const FUNCTIONS_CONFIG_MANIFEST = 'functions-config-manifest.json'\nexport const SUBRESOURCE_INTEGRITY_MANIFEST = 'subresource-integrity-manifest'\nexport const NEXT_FONT_MANIFEST = 'next-font-manifest'\nexport const EXPORT_MARKER = 'export-marker.json'\nexport const EXPORT_DETAIL = 'export-detail.json'\nexport const PRERENDER_MANIFEST = 'prerender-manifest.json'\nexport const ROUTES_MANIFEST = 'routes-manifest.json'\nexport const IMAGES_MANIFEST = 'images-manifest.json'\nexport const SERVER_FILES_MANIFEST = 'required-server-files.json'\nexport const DEV_CLIENT_PAGES_MANIFEST = '_devPagesManifest.json'\nexport const MIDDLEWARE_MANIFEST = 'middleware-manifest.json'\nexport const TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST =\n '_clientMiddlewareManifest.json'\nexport const TURBOPACK_CLIENT_BUILD_MANIFEST = 'client-build-manifest.json'\nexport const DEV_CLIENT_MIDDLEWARE_MANIFEST = '_devMiddlewareManifest.json'\nexport const REACT_LOADABLE_MANIFEST = 'react-loadable-manifest.json'\nexport const SERVER_DIRECTORY = 'server'\nexport const CONFIG_FILES = [\n 'next.config.js',\n 'next.config.mjs',\n 'next.config.ts',\n // process.features can be undefined on Edge runtime\n // TODO: Remove `as any` once we bump @types/node to v22.10.0+\n ...((process?.features as any)?.typescript ? ['next.config.mts'] : []),\n]\nexport const BUILD_ID_FILE = 'BUILD_ID'\nexport const BLOCKED_PAGES = ['/_document', '/_app', '/_error']\nexport const CLIENT_PUBLIC_FILES_PATH = 'public'\nexport const CLIENT_STATIC_FILES_PATH = 'static'\nexport const STRING_LITERAL_DROP_BUNDLE = '__NEXT_DROP_CLIENT_FILE__'\nexport const NEXT_BUILTIN_DOCUMENT = '__NEXT_BUILTIN_DOCUMENT__'\nexport const BARREL_OPTIMIZATION_PREFIX = '__barrel_optimize__'\n\n// server/[entry]/page_client-reference-manifest.js\nexport const CLIENT_REFERENCE_MANIFEST = 'client-reference-manifest'\n// server/server-reference-manifest\nexport const SERVER_REFERENCE_MANIFEST = 'server-reference-manifest'\n// server/middleware-build-manifest.js\nexport const MIDDLEWARE_BUILD_MANIFEST = 'middleware-build-manifest'\n// server/middleware-react-loadable-manifest.js\nexport const MIDDLEWARE_REACT_LOADABLE_MANIFEST =\n 'middleware-react-loadable-manifest'\n// server/interception-route-rewrite-manifest.js\nexport const INTERCEPTION_ROUTE_REWRITE_MANIFEST =\n 'interception-route-rewrite-manifest'\n// server/dynamic-css-manifest.js\nexport const DYNAMIC_CSS_MANIFEST = 'dynamic-css-manifest'\n\n// static/runtime/main.js\nexport const CLIENT_STATIC_FILES_RUNTIME_MAIN = `main`\nexport const CLIENT_STATIC_FILES_RUNTIME_MAIN_APP = `${CLIENT_STATIC_FILES_RUNTIME_MAIN}-app`\n// next internal client components chunk for layouts\nexport const APP_CLIENT_INTERNALS = 'app-pages-internals'\n// static/runtime/react-refresh.js\nexport const CLIENT_STATIC_FILES_RUNTIME_REACT_REFRESH = `react-refresh`\n// static/runtime/webpack.js\nexport const CLIENT_STATIC_FILES_RUNTIME_WEBPACK = `webpack`\n// static/runtime/polyfills.js\nexport const CLIENT_STATIC_FILES_RUNTIME_POLYFILLS = 'polyfills'\nexport const CLIENT_STATIC_FILES_RUNTIME_POLYFILLS_SYMBOL = Symbol(\n CLIENT_STATIC_FILES_RUNTIME_POLYFILLS\n)\nexport const DEFAULT_RUNTIME_WEBPACK = 'webpack-runtime'\nexport const EDGE_RUNTIME_WEBPACK = 'edge-runtime-webpack'\nexport const STATIC_PROPS_ID = '__N_SSG'\nexport const SERVER_PROPS_ID = '__N_SSP'\nexport const DEFAULT_SERIF_FONT = {\n name: 'Times New Roman',\n xAvgCharWidth: 821,\n azAvgWidth: 854.3953488372093,\n unitsPerEm: 2048,\n}\nexport const DEFAULT_SANS_SERIF_FONT = {\n name: 'Arial',\n xAvgCharWidth: 904,\n azAvgWidth: 934.5116279069767,\n unitsPerEm: 2048,\n}\nexport const STATIC_STATUS_PAGES = ['/500']\nexport const TRACE_OUTPUT_VERSION = 1\n// in `MB`\nexport const TURBO_TRACE_DEFAULT_MEMORY_LIMIT = 6000\n\nexport const RSC_MODULE_TYPES = {\n client: 'client',\n server: 'server',\n} as const\n\n// comparing\n// https://nextjs.org/docs/api-reference/edge-runtime\n// with\n// https://nodejs.org/docs/latest/api/globals.html\nexport const EDGE_UNSUPPORTED_NODE_APIS = [\n 'clearImmediate',\n 'setImmediate',\n 'BroadcastChannel',\n 'ByteLengthQueuingStrategy',\n 'CompressionStream',\n 'CountQueuingStrategy',\n 'DecompressionStream',\n 'DomException',\n 'MessageChannel',\n 'MessageEvent',\n 'MessagePort',\n 'ReadableByteStreamController',\n 'ReadableStreamBYOBRequest',\n 'ReadableStreamDefaultController',\n 'TransformStreamDefaultController',\n 'WritableStreamDefaultController',\n]\n\nexport const SYSTEM_ENTRYPOINTS = new Set<string>([\n CLIENT_STATIC_FILES_RUNTIME_MAIN,\n CLIENT_STATIC_FILES_RUNTIME_REACT_REFRESH,\n CLIENT_STATIC_FILES_RUNTIME_MAIN_APP,\n])\n","import type { UrlWithParsedQuery } from 'url'\nimport { NEXT_RSC_UNION_QUERY } from '../client/components/app-router-headers'\n\nconst DUMMY_ORIGIN = 'http://n'\n\nexport function isFullStringUrl(url: string) {\n return /https?:\\/\\//.test(url)\n}\n\nexport function parseUrl(url: string): URL | undefined {\n let parsed: URL | undefined = undefined\n try {\n parsed = new URL(url, DUMMY_ORIGIN)\n } catch {}\n return parsed\n}\n\nexport function parseReqUrl(url: string): UrlWithParsedQuery | undefined {\n const parsedUrl: URL | undefined = parseUrl(url)\n\n if (!parsedUrl) {\n return\n }\n\n const query: Record<string, string | string[]> = {}\n\n for (const key of parsedUrl.searchParams.keys()) {\n const values = parsedUrl.searchParams.getAll(key)\n query[key] = values.length > 1 ? values : values[0]\n }\n\n const legacyUrl: UrlWithParsedQuery = {\n query,\n hash: parsedUrl.hash,\n search: parsedUrl.search,\n path: parsedUrl.pathname,\n pathname: parsedUrl.pathname,\n href: `${parsedUrl.pathname}${parsedUrl.search}${parsedUrl.hash}`,\n host: '',\n hostname: '',\n auth: '',\n protocol: '',\n slashes: null,\n port: '',\n }\n return legacyUrl\n}\n\nexport function stripNextRscUnionQuery(relativeUrl: string): string {\n const urlInstance = new URL(relativeUrl, DUMMY_ORIGIN)\n urlInstance.searchParams.delete(NEXT_RSC_UNION_QUERY)\n\n return urlInstance.pathname + urlInstance.search\n}\n","export interface PathLocale {\n detectedLocale?: string\n pathname: string\n}\n\n/**\n * A cache of lowercased locales for each list of locales. This is stored as a\n * WeakMap so if the locales are garbage collected, the cache entry will be\n * removed as well.\n */\nconst cache = new WeakMap<readonly string[], readonly string[]>()\n\n/**\n * For a pathname that may include a locale from a list of locales, it\n * removes the locale from the pathname returning it alongside with the\n * detected locale.\n *\n * @param pathname A pathname that may include a locale.\n * @param locales A list of locales.\n * @returns The detected locale and pathname without locale\n */\nexport function normalizeLocalePath(\n pathname: string,\n locales?: readonly string[]\n): PathLocale {\n // If locales is undefined, return the pathname as is.\n if (!locales) return { pathname }\n\n // Get the cached lowercased locales or create a new cache entry.\n let lowercasedLocales = cache.get(locales)\n if (!lowercasedLocales) {\n lowercasedLocales = locales.map((locale) => locale.toLowerCase())\n cache.set(locales, lowercasedLocales)\n }\n\n let detectedLocale: string | undefined\n\n // The first segment will be empty, because it has a leading `/`. If\n // there is no further segment, there is no locale (or it's the default).\n const segments = pathname.split('/', 2)\n\n // If there's no second segment (ie, the pathname is just `/`), there's no\n // locale.\n if (!segments[1]) return { pathname }\n\n // The second segment will contain the locale part if any.\n const segment = segments[1].toLowerCase()\n\n // See if the segment matches one of the locales. If it doesn't, there is\n // no locale (or it's the default).\n const index = lowercasedLocales.indexOf(segment)\n if (index < 0) return { pathname }\n\n // Return the case-sensitive locale.\n detectedLocale = locales[index]\n\n // Remove the `/${locale}` part of the pathname.\n pathname = pathname.slice(detectedLocale.length + 1) || '/'\n\n return { pathname, detectedLocale }\n}\n","/**\n * For a given page path, this function ensures that there is a leading slash.\n * If there is not a leading slash, one is added, otherwise it is noop.\n */\nexport function ensureLeadingSlash(path: string) {\n return path.startsWith('/') ? path : `/${path}`\n}\n","import { ensureLeadingSlash } from '../../page-path/ensure-leading-slash'\nimport { isGroupSegment } from '../../segment'\n\n/**\n * Normalizes an app route so it represents the actual request path. Essentially\n * performing the following transformations:\n *\n * - `/(dashboard)/user/[id]/page` to `/user/[id]`\n * - `/(dashboard)/account/page` to `/account`\n * - `/user/[id]/page` to `/user/[id]`\n * - `/account/page` to `/account`\n * - `/page` to `/`\n * - `/(dashboard)/user/[id]/route` to `/user/[id]`\n * - `/(dashboard)/account/route` to `/account`\n * - `/user/[id]/route` to `/user/[id]`\n * - `/account/route` to `/account`\n * - `/route` to `/`\n * - `/` to `/`\n *\n * @param route the app route to normalize\n * @returns the normalized pathname\n */\nexport function normalizeAppPath(route: string) {\n return ensureLeadingSlash(\n route.split('/').reduce((pathname, segment, index, segments) => {\n // Empty segments are ignored.\n if (!segment) {\n return pathname\n }\n\n // Groups are ignored.\n if (isGroupSegment(segment)) {\n return pathname\n }\n\n // Parallel segments are ignored.\n if (segment[0] === '@') {\n return pathname\n }\n\n // The last segment (if it's a leaf) should be ignored.\n if (\n (segment === 'page' || segment === 'route') &&\n index === segments.length - 1\n ) {\n return pathname\n }\n\n return `${pathname}/${segment}`\n }, '')\n )\n}\n\n/**\n * Strips the `.rsc` extension if it's in the pathname.\n * Since this function is used on full urls it checks `?` for searchParams handling.\n */\nexport function normalizeRscURL(url: string) {\n return url.replace(\n /\\.rsc($|\\?)/,\n // $1 ensures `?` is preserved\n '$1'\n )\n}\n","import type { FlightRouterState, Segment } from './app-router-types'\n\nexport function getSegmentValue(segment: Segment) {\n return Array.isArray(segment) ? segment[1] : segment\n}\n\nexport function isGroupSegment(segment: string) {\n // Use array[0] for performant purpose\n return segment[0] === '(' && segment.endsWith(')')\n}\n\nexport function isParallelRouteSegment(segment: string) {\n return segment.startsWith('@') && segment !== '@children'\n}\n\nexport function addSearchParamsIfPageSegment(\n segment: Segment,\n searchParams: Record<string, string | string[] | undefined>\n) {\n const isPageSegment = segment.includes(PAGE_SEGMENT_KEY)\n\n if (isPageSegment) {\n const stringifiedQuery = JSON.stringify(searchParams)\n return stringifiedQuery !== '{}'\n ? PAGE_SEGMENT_KEY + '?' + stringifiedQuery\n : PAGE_SEGMENT_KEY\n }\n\n return segment\n}\n\nexport function computeSelectedLayoutSegment(\n segments: string[] | null,\n parallelRouteKey: string\n): string | null {\n if (!segments || segments.length === 0) {\n return null\n }\n\n // For 'children', use first segment; for other parallel routes, use last segment\n const rawSegment =\n parallelRouteKey === 'children'\n ? segments[0]\n : segments[segments.length - 1]\n\n // If the default slot is showing, return null since it's not technically \"selected\" (it's a fallback)\n // Returning an internal value like `__DEFAULT__` would be confusing\n return rawSegment === DEFAULT_SEGMENT_KEY ? null : rawSegment\n}\n\n/** Get the canonical parameters from the current level to the leaf node. */\nexport function getSelectedLayoutSegmentPath(\n tree: FlightRouterState,\n parallelRouteKey: string,\n first = true,\n segmentPath: string[] = []\n): string[] {\n let node: FlightRouterState\n if (first) {\n // Use the provided parallel route key on the first parallel route\n node = tree[1][parallelRouteKey]\n } else {\n // After first parallel route prefer children, if there's no children pick the first parallel route.\n const parallelRoutes = tree[1]\n node = parallelRoutes.children ?? Object.values(parallelRoutes)[0]\n }\n\n if (!node) return segmentPath\n const segment = node[0]\n\n let segmentValue = getSegmentValue(segment)\n\n if (!segmentValue || segmentValue.startsWith(PAGE_SEGMENT_KEY)) {\n return segmentPath\n }\n\n segmentPath.push(segmentValue)\n\n return getSelectedLayoutSegmentPath(\n node,\n parallelRouteKey,\n false,\n segmentPath\n )\n}\n\nexport const PAGE_SEGMENT_KEY = '__PAGE__'\nexport const DEFAULT_SEGMENT_KEY = '__DEFAULT__'\n","import { normalizeAppPath } from './app-paths'\n\n// order matters here, the first match will be used\nexport const INTERCEPTION_ROUTE_MARKERS = [\n '(..)(..)',\n '(.)',\n '(..)',\n '(...)',\n] as const\n\nexport function isInterceptionRouteAppPath(path: string): boolean {\n // TODO-APP: add more serious validation\n return (\n path\n .split('/')\n .find((segment) =>\n INTERCEPTION_ROUTE_MARKERS.find((m) => segment.startsWith(m))\n ) !== undefined\n )\n}\n\ntype InterceptionRouteInformation = {\n /**\n * The intercepting route. This is the route that is being intercepted or the\n * route that the user was coming from. This is matched by the Next-Url\n * header.\n */\n interceptingRoute: string\n\n /**\n * The intercepted route. This is the route that is being intercepted or the\n * route that the user is going to. This is matched by the request pathname.\n */\n interceptedRoute: string\n}\n\nexport function extractInterceptionRouteInformation(\n path: string\n): InterceptionRouteInformation {\n let interceptingRoute: string | undefined\n let marker: (typeof INTERCEPTION_ROUTE_MARKERS)[number] | undefined\n let interceptedRoute: string | undefined\n\n for (const segment of path.split('/')) {\n marker = INTERCEPTION_ROUTE_MARKERS.find((m) => segment.startsWith(m))\n if (marker) {\n ;[interceptingRoute, interceptedRoute] = path.split(marker, 2)\n break\n }\n }\n\n if (!interceptingRoute || !marker || !interceptedRoute) {\n throw new Error(\n `Invalid interception route: ${path}. Must be in the format /<intercepting route>/(..|...|..)(..)/<intercepted route>`\n )\n }\n\n interceptingRoute = normalizeAppPath(interceptingRoute) // normalize the path, e.g. /(blog)/feed -> /feed\n\n switch (marker) {\n case '(.)':\n // (.) indicates that we should match with sibling routes, so we just need to append the intercepted route to the intercepting route\n if (interceptingRoute === '/') {\n interceptedRoute = `/${interceptedRoute}`\n } else {\n interceptedRoute = interceptingRoute + '/' + interceptedRoute\n }\n break\n case '(..)':\n // (..) indicates that we should match at one level up, so we need to remove the last segment of the intercepting route\n if (interceptingRoute === '/') {\n throw new Error(\n `Invalid interception route: ${path}. Cannot use (..) marker at the root level, use (.) instead.`\n )\n }\n interceptedRoute = interceptingRoute\n .split('/')\n .slice(0, -1)\n .concat(interceptedRoute)\n .join('/')\n break\n case '(...)':\n // (...) will match the route segment in the root directory, so we need to use the root directory to prepend the intercepted route\n interceptedRoute = '/' + interceptedRoute\n break\n case '(..)(..)':\n // (..)(..) indicates that we should match at two levels up, so we need to remove the last two segments of the intercepting route\n\n const splitInterceptingRoute = interceptingRoute.split('/')\n if (splitInterceptingRoute.length <= 2) {\n throw new Error(\n `Invalid interception route: ${path}. Cannot use (..)(..) marker at the root level or one level up.`\n )\n }\n\n interceptedRoute = splitInterceptingRoute\n .slice(0, -2)\n .concat(interceptedRoute)\n .join('/')\n break\n default:\n throw new Error('Invariant: unexpected marker')\n }\n\n return { interceptingRoute, interceptedRoute }\n}\n","import {\n extractInterceptionRouteInformation,\n isInterceptionRouteAppPath,\n} from './interception-routes'\n\n// Identify /.*[param].*/ in route string\nconst TEST_ROUTE = /\\/[^/]*\\[[^/]+\\][^/]*(?=\\/|$)/\n\n// Identify /[param]/ in route string\nconst TEST_STRICT_ROUTE = /\\/\\[[^/]+\\](?=\\/|$)/\n\n/**\n * Check if a route is dynamic.\n *\n * @param route - The route to check.\n * @param strict - Whether to use strict mode which prohibits segments with prefixes/suffixes (default: true).\n * @returns Whether the route is dynamic.\n */\nexport function isDynamicRoute(route: string, strict: boolean = true): boolean {\n if (isInterceptionRouteAppPath(route)) {\n route = extractInterceptionRouteInformation(route).interceptedRoute\n }\n\n if (strict) {\n return TEST_STRICT_ROUTE.test(route)\n }\n\n return TEST_ROUTE.test(route)\n}\n","/**\n * Given a path this function will find the pathname, query and hash and return\n * them. This is useful to parse full paths on the client side.\n * @param path A path to parse e.g. /foo/bar?id=1#hash\n */\nexport function parsePath(path: string) {\n const hashIndex = path.indexOf('#')\n const queryIndex = path.indexOf('?')\n const hasQuery = queryIndex > -1 && (hashIndex < 0 || queryIndex < hashIndex)\n\n if (hasQuery || hashIndex > -1) {\n return {\n pathname: path.substring(0, hasQuery ? queryIndex : hashIndex),\n query: hasQuery\n ? path.substring(queryIndex, hashIndex > -1 ? hashIndex : undefined)\n : '',\n hash: hashIndex > -1 ? path.slice(hashIndex) : '',\n }\n }\n\n return { pathname: path, query: '', hash: '' }\n}\n","import { parsePath } from './parse-path'\n\n/**\n * Checks if a given path starts with a given prefix. It ensures it matches\n * exactly without containing extra chars. e.g. prefix /docs should replace\n * for /docs, /docs/, /docs/a but not /docsss\n * @param path The path to check.\n * @param prefix The prefix to check against.\n */\nexport function pathHasPrefix(path: string, prefix: string) {\n if (typeof path !== 'string') {\n return false\n }\n\n const { pathname } = parsePath(path)\n return pathname === prefix || pathname.startsWith(prefix + '/')\n}\n","import { pathHasPrefix } from './path-has-prefix'\n\n/**\n * Given a path and a prefix it will remove the prefix when it exists in the\n * given path. It ensures it matches exactly without containing extra chars\n * and if the prefix is not there it will be noop.\n *\n * @param path The path to remove the prefix from.\n * @param prefix The prefix to be removed.\n */\nexport function removePathPrefix(path: string, prefix: string): string {\n // If the path doesn't start with the prefix we can return it as is. This\n // protects us from situations where the prefix is a substring of the path\n // prefix such as:\n //\n // For prefix: /blog\n //\n // /blog -> true\n // /blog/ -> true\n // /blog/1 -> true\n // /blogging -> false\n // /blogging/ -> false\n // /blogging/1 -> false\n if (!pathHasPrefix(path, prefix)) {\n return path\n }\n\n // Remove the prefix from the path via slicing.\n const withoutPrefix = path.slice(prefix.length)\n\n // If the path without the prefix starts with a `/` we can return it as is.\n if (withoutPrefix.startsWith('/')) {\n return withoutPrefix\n }\n\n // If the path without the prefix doesn't start with a `/` we need to add it\n // back to the path to make sure it's a valid path.\n return `/${withoutPrefix}`\n}\n","// regexp is based on https://github.com/sindresorhus/escape-string-regexp\nconst reHasRegExp = /[|\\\\{}()[\\]^$+*?.-]/\nconst reReplaceRegExp = /[|\\\\{}()[\\]^$+*?.-]/g\n\nexport function escapeStringRegexp(str: string) {\n // see also: https://github.com/lodash/lodash/blob/2da024c3b4f9947a48517639de7560457cd4ec6c/escapeRegExp.js#L23\n if (reHasRegExp.test(str)) {\n return str.replace(reReplaceRegExp, '\\\\$&')\n }\n return str\n}\n","/**\n * Removes the trailing slash for a given route or page path. Preserves the\n * root page. Examples:\n * - `/foo/bar/` -> `/foo/bar`\n * - `/foo/bar` -> `/foo/bar`\n * - `/` -> `/`\n */\nexport function removeTrailingSlash(route: string) {\n return route.replace(/\\/$/, '') || '/'\n}\n","export class InvariantError extends Error {\n constructor(message: string, options?: ErrorOptions) {\n super(\n `Invariant: ${message.endsWith('.') ? message : message + '.'} This is a bug in Next.js.`,\n options\n )\n this.name = 'InvariantError'\n }\n}\n","import type { DynamicParam } from '../../../../server/app-render/app-render'\nimport type { LoaderTree } from '../../../../server/lib/app-dir-module'\nimport type { OpaqueFallbackRouteParams } from '../../../../server/request/fallback-params'\nimport type { Params } from '../../../../server/request/params'\nimport type { DynamicParamTypesShort } from '../../app-router-types'\nimport { InvariantError } from '../../invariant-error'\nimport { parseLoaderTree } from './parse-loader-tree'\nimport { getSegmentParam } from './get-segment-param'\n\n/**\n * Gets the value of a param from the params object. This correctly handles the\n * case where the param is a fallback route param and encodes the resulting\n * value.\n *\n * @param interpolatedParams - The params object.\n * @param segmentKey - The key of the segment.\n * @param fallbackRouteParams - The fallback route params.\n * @returns The value of the param.\n */\nfunction getParamValue(\n interpolatedParams: Params,\n segmentKey: string,\n fallbackRouteParams: OpaqueFallbackRouteParams | null\n) {\n let value = interpolatedParams[segmentKey]\n\n if (fallbackRouteParams?.has(segmentKey)) {\n // We know that the fallback route params has the segment key because we\n // checked that above.\n const [searchValue] = fallbackRouteParams.get(segmentKey)!\n value = searchValue\n } else if (Array.isArray(value)) {\n value = value.map((i) => encodeURIComponent(i))\n } else if (typeof value === 'string') {\n value = encodeURIComponent(value)\n }\n\n return value\n}\n\nexport function interpolateParallelRouteParams(\n loaderTree: LoaderTree,\n params: Params,\n pagePath: string,\n fallbackRouteParams: OpaqueFallbackRouteParams | null\n) {\n const interpolated = structuredClone(params)\n\n // Stack-based traversal with depth tracking\n const stack: Array<{ tree: LoaderTree; depth: number }> = [\n { tree: loaderTree, depth: 0 },\n ]\n\n // Derive value from pagePath based on depth and parameter type\n const pathSegments = pagePath.split('/').slice(1) // Remove first empty string\n\n while (stack.length > 0) {\n const { tree, depth } = stack.pop()!\n const { segment, parallelRoutes } = parseLoaderTree(tree)\n\n // Check if current segment contains a parameter\n const segmentParam = getSegmentParam(segment)\n if (\n segmentParam &&\n !interpolated.hasOwnProperty(segmentParam.param) &&\n // If the param is in the fallback route params, we don't need to\n // interpolate it because it's already marked as being unknown.\n !fallbackRouteParams?.has(segmentParam.param)\n ) {\n switch (segmentParam.type) {\n case 'catchall':\n case 'optional-catchall':\n case 'catchall-intercepted':\n // For catchall parameters, take all remaining segments from this depth\n const remainingSegments = pathSegments.slice(depth)\n\n // Process each segment to handle any dynamic params\n const processedSegments = remainingSegments\n .flatMap((pathSegment) => {\n const param = getSegmentParam(pathSegment)\n // If the segment matches a param, return the param value otherwise,\n // it's a static segment, so just return that. We don't use the\n // `getParamValue` function here because we don't want the values to\n // be encoded, that's handled on get by the `getDynamicParam`\n // function.\n return param ? interpolated[param.param] : pathSegment\n })\n .filter((s) => s !== undefined)\n\n if (processedSegments.length > 0) {\n interpolated[segmentParam.param] = processedSegments\n }\n break\n case 'dynamic':\n case 'dynamic-intercepted':\n // For regular dynamic parameters, take the segment at this depth\n if (depth < pathSegments.length) {\n const pathSegment = pathSegments[depth]\n const param = getSegmentParam(pathSegment)\n\n interpolated[segmentParam.param] = param\n ? interpolated[param.param]\n : pathSegment\n }\n break\n default:\n segmentParam.type satisfies never\n }\n }\n\n // Calculate next depth - increment if this is not a route group and not empty\n let nextDepth = depth\n const isRouteGroup = segment.startsWith('(') && segment.endsWith(')')\n if (!isRouteGroup && segment !== '') {\n nextDepth++\n }\n\n // Add all parallel routes to the stack for processing\n for (const route of Object.values(parallelRoutes)) {\n stack.push({ tree: route, depth: nextDepth })\n }\n }\n\n return interpolated\n}\n\n/**\n *\n * Shared logic on client and server for creating a dynamic param value.\n *\n * This code needs to be shared with the client so it can extract dynamic route\n * params from the URL without a server request.\n *\n * Because everything in this module is sent to the client, we should aim to\n * keep this code as simple as possible. The special case handling for catchall\n * and optional is, alas, unfortunate.\n */\nexport function getDynamicParam(\n interpolatedParams: Params,\n segmentKey: string,\n dynamicParamType: DynamicParamTypesShort,\n fallbackRouteParams: OpaqueFallbackRouteParams | null\n): DynamicParam {\n let value: string | string[] | undefined = getParamValue(\n interpolatedParams,\n segmentKey,\n fallbackRouteParams\n )\n\n // handle the case where an optional catchall does not have a value,\n // e.g. `/dashboard/[[...slug]]` when requesting `/dashboard`\n if (!value || value.length === 0) {\n if (dynamicParamType === 'oc') {\n return {\n param: segmentKey,\n value: null,\n type: dynamicParamType,\n treeSegment: [segmentKey, '', dynamicParamType],\n }\n }\n\n throw new InvariantError(\n `Missing value for segment key: \"${segmentKey}\" with dynamic param type: ${dynamicParamType}`\n )\n }\n\n return {\n param: segmentKey,\n // The value that is passed to user code.\n value,\n // The value that is rendered in the router tree.\n treeSegment: [\n segmentKey,\n Array.isArray(value) ? value.join('/') : value,\n dynamicParamType,\n ],\n type: dynamicParamType,\n }\n}\n\n/**\n * Regular expression pattern used to match route parameters.\n * Matches both single parameters and parameter groups.\n * Examples:\n * - `[[...slug]]` matches parameter group with key 'slug', repeat: true, optional: true\n * - `[...slug]` matches parameter group with key 'slug', repeat: true, optional: false\n * - `[[foo]]` matches parameter with key 'foo', repeat: false, optional: true\n * - `[bar]` matches parameter with key 'bar', repeat: false, optional: false\n */\nexport const PARAMETER_PATTERN = /^([^[]*)\\[((?:\\[[^\\]]*\\])|[^\\]]+)\\](.*)$/\n\n/**\n * Parses a given parameter from a route to a data structure that can be used\n * to generate the parametrized route.\n * Examples:\n * - `[[...slug]]` -> `{ key: 'slug', repeat: true, optional: true }`\n * - `[...slug]` -> `{ key: 'slug', repeat: true, optional: false }`\n * - `[[foo]]` -> `{ key: 'foo', repeat: false, optional: true }`\n * - `[bar]` -> `{ key: 'bar', repeat: false, optional: false }`\n * - `fizz` -> `{ key: 'fizz', repeat: false, optional: false }`\n * @param param - The parameter to parse.\n * @returns The parsed parameter as a data structure.\n */\nexport function parseParameter(param: string) {\n const match = param.match(PARAMETER_PATTERN)\n\n if (!match) {\n return parseMatchedParameter(param)\n }\n\n return parseMatchedParameter(match[2])\n}\n\n/**\n * Parses a matched parameter from the PARAMETER_PATTERN regex to a data structure that can be used\n * to generate the parametrized route.\n * Examples:\n * - `[...slug]` -> `{ key: 'slug', repeat: true, optional: true }`\n * - `...slug` -> `{ key: 'slug', repeat: true, optional: false }`\n * - `[foo]` -> `{ key: 'foo', repeat: false, optional: true }`\n * - `bar` -> `{ key: 'bar', repeat: false, optional: false }`\n * @param param - The matched parameter to parse.\n * @returns The parsed parameter as a data structure.\n */\nexport function parseMatchedParameter(param: string) {\n const optional = param.startsWith('[') && param.endsWith(']')\n if (optional) {\n param = param.slice(1, -1)\n }\n const repeat = param.startsWith('...')\n if (repeat) {\n param = param.slice(3)\n }\n return { key: param, repeat, optional }\n}\n","import {\n NEXT_INTERCEPTION_MARKER_PREFIX,\n NEXT_QUERY_PARAM_PREFIX,\n} from '../../../../lib/constants'\nimport { INTERCEPTION_ROUTE_MARKERS } from './interception-routes'\nimport { escapeStringRegexp } from '../../escape-regexp'\nimport { removeTrailingSlash } from './remove-trailing-slash'\nimport { PARAMETER_PATTERN, parseMatchedParameter } from './get-dynamic-param'\n\nexport interface Group {\n pos: number\n repeat: boolean\n optional: boolean\n}\n\nexport interface RouteRegex {\n groups: { [groupName: string]: Group }\n re: RegExp\n}\n\nexport type RegexReference = {\n names: Record<string, string>\n intercepted: Record<string, string>\n}\n\ntype GetNamedRouteRegexOptions = {\n /**\n * Whether to prefix the route keys with the NEXT_INTERCEPTION_MARKER_PREFIX\n * or NEXT_QUERY_PARAM_PREFIX. This is only relevant when creating the\n * routes-manifest during the build.\n */\n prefixRouteKeys: boolean\n\n /**\n * Whether to include the suffix in the route regex. This means that when you\n * have something like `/[...slug].json` the `.json` part will be included\n * in the regex, yielding `/(.*).json` as the regex.\n */\n includeSuffix?: boolean\n\n /**\n * Whether to include the prefix in the route regex. This means that when you\n * have something like `/[...slug].json` the `/` part will be included\n * in the regex, yielding `^/(.*).json$` as the regex.\n *\n * Note that interception markers will already be included without the need\n */\n includePrefix?: boolean\n\n /**\n * Whether to exclude the optional trailing slash from the route regex.\n */\n excludeOptionalTrailingSlash?: boolean\n\n /**\n * Whether to backtrack duplicate keys. This is only relevant when creating\n * the routes-manifest during the build.\n */\n backreferenceDuplicateKeys?: boolean\n\n /**\n * If provided, this will be used as the reference for the dynamic parameter\n * keys instead of generating them in context. This is currently only used for\n * interception routes.\n */\n reference?: RegexReference\n}\n\ntype GetRouteRegexOptions = {\n /**\n * Whether to include extra parts in the route regex. This means that when you\n * have something like `/[...slug].json` the `.json` part will be included\n * in the regex, yielding `/(.*).json` as the regex.\n */\n includeSuffix?: boolean\n\n /**\n * Whether to include the prefix in the route regex. This means that when you\n * have something like `/[...slug].json` the `/` part will be included\n * in the regex, yielding `^/(.*).json$` as the regex.\n *\n * Note that interception markers will already be included without the need\n * of adding this option.\n */\n includePrefix?: boolean\n\n /**\n * Whether to exclude the optional trailing slash from the route regex.\n */\n excludeOptionalTrailingSlash?: boolean\n}\n\nfunction getParametrizedRoute(\n route: string,\n includeSuffix: boolean,\n includePrefix: boolean\n) {\n const groups: { [groupName: string]: Group } = {}\n let groupIndex = 1\n\n const segments: string[] = []\n for (const segment of removeTrailingSlash(route).slice(1).split('/')) {\n const markerMatch = INTERCEPTION_ROUTE_MARKERS.find((m) =>\n segment.startsWith(m)\n )\n const paramMatches = segment.match(PARAMETER_PATTERN) // Check for parameters\n\n if (markerMatch && paramMatches && paramMatches[2]) {\n const { key, optional, repeat } = parseMatchedParameter(paramMatches[2])\n groups[key] = { pos: groupIndex++, repeat, optional }\n segments.push(`/${escapeStringRegexp(markerMatch)}([^/]+?)`)\n } else if (paramMatches && paramMatches[2]) {\n const { key, repeat, optional } = parseMatchedParameter(paramMatches[2])\n groups[key] = { pos: groupIndex++, repeat, optional }\n\n if (includePrefix && paramMatches[1]) {\n segments.push(`/${escapeStringRegexp(paramMatches[1])}`)\n }\n\n let s = repeat ? (optional ? '(?:/(.+?))?' : '/(.+?)') : '/([^/]+?)'\n\n // Remove the leading slash if includePrefix already added it.\n if (includePrefix && paramMatches[1]) {\n s = s.substring(1)\n }\n\n segments.push(s)\n } else {\n segments.push(`/${escapeStringRegexp(segment)}`)\n }\n\n // If there's a suffix, add it to the segments if it's enabled.\n if (includeSuffix && paramMatches && paramMatches[3]) {\n segments.push(escapeStringRegexp(paramMatches[3]))\n }\n }\n\n return {\n parameterizedRoute: segments.join(''),\n groups,\n }\n}\n\n/**\n * From a normalized route this function generates a regular expression and\n * a corresponding groups object intended to be used to store matching groups\n * from the regular expression.\n */\nexport function getRouteRegex(\n normalizedRoute: string,\n {\n includeSuffix = false,\n includePrefix = false,\n excludeOptionalTrailingSlash = false,\n }: GetRouteRegexOptions = {}\n): RouteRegex {\n const { parameterizedRoute, groups } = getParametrizedRoute(\n normalizedRoute,\n includeSuffix,\n includePrefix\n )\n\n let re = parameterizedRoute\n if (!excludeOptionalTrailingSlash) {\n re += '(?:/)?'\n }\n\n return {\n re: new RegExp(`^${re}$`),\n groups: groups,\n }\n}\n\n/**\n * Builds a function to generate a minimal routeKey using only a-z and minimal\n * number of characters.\n */\nfunction buildGetSafeRouteKey() {\n let i = 0\n\n return () => {\n let routeKey = ''\n let j = ++i\n while (j > 0) {\n routeKey += String.fromCharCode(97 + ((j - 1) % 26))\n j = Math.floor((j - 1) / 26)\n }\n return routeKey\n }\n}\n\nfunction getSafeKeyFromSegment({\n interceptionMarker,\n getSafeRouteKey,\n segment,\n routeKeys,\n keyPrefix,\n backreferenceDuplicateKeys,\n}: {\n interceptionMarker?: string\n getSafeRouteKey: () => string\n segment: string\n routeKeys: Record<string, string>\n keyPrefix?: string\n backreferenceDuplicateKeys: boolean\n}) {\n const { key, optional, repeat } = parseMatchedParameter(segment)\n\n // replace any non-word characters since they can break\n // the named regex\n let cleanedKey = key.replace(/\\W/g, '')\n\n if (keyPrefix) {\n cleanedKey = `${keyPrefix}${cleanedKey}`\n }\n let invalidKey = false\n\n // check if the key is still invalid and fallback to using a known\n // safe key\n if (cleanedKey.length === 0 || cleanedKey.length > 30) {\n invalidKey = true\n }\n if (!isNaN(parseInt(cleanedKey.slice(0, 1)))) {\n invalidKey = true\n }\n\n if (invalidKey) {\n cleanedKey = getSafeRouteKey()\n }\n\n const duplicateKey = cleanedKey in routeKeys\n\n if (keyPrefix) {\n routeKeys[cleanedKey] = `${keyPrefix}${key}`\n } else {\n routeKeys[cleanedKey] = key\n }\n\n // if the segment has an interception marker, make sure that's part of the regex pattern\n // this is to ensure that the route with the interception marker doesn't incorrectly match\n // the non-intercepted route (ie /app/(.)[username] should not match /app/[username])\n const interceptionPrefix = interceptionMarker\n ? escapeStringRegexp(interceptionMarker)\n : ''\n\n let pattern: string\n if (duplicateKey && backreferenceDuplicateKeys) {\n // Use a backreference to the key to ensure that the key is the same value\n // in each of the placeholders.\n pattern = `\\\\k<${cleanedKey}>`\n } else if (repeat) {\n pattern = `(?<${cleanedKey}>.+?)`\n } else {\n pattern = `(?<${cleanedKey}>[^/]+?)`\n }\n\n return {\n key,\n pattern: optional\n ? `(?:/${interceptionPrefix}${pattern})?`\n : `/${interceptionPrefix}${pattern}`,\n cleanedKey: cleanedKey,\n optional,\n repeat,\n }\n}\n\nfunction getNamedParametrizedRoute(\n route: string,\n prefixRouteKeys: boolean,\n includeSuffix: boolean,\n includePrefix: boolean,\n backreferenceDuplicateKeys: boolean,\n reference: RegexReference = { names: {}, intercepted: {} }\n) {\n const getSafeRouteKey = buildGetSafeRouteKey()\n const routeKeys: { [named: string]: string } = {}\n\n const segments: string[] = []\n const inverseParts: string[] = []\n\n // Ensure we don't mutate the original reference object.\n reference = structuredClone(reference)\n\n for (const segment of removeTrailingSlash(route).slice(1).split('/')) {\n const hasInterceptionMarker = INTERCEPTION_ROUTE_MARKERS.some((m) =>\n segment.startsWith(m)\n )\n\n const paramMatches = segment.match(PARAMETER_PATTERN) // Check for parameters\n\n const interceptionMarker = hasInterceptionMarker\n ? paramMatches?.[1]\n : undefined\n\n let keyPrefix: string | undefined\n if (interceptionMarker && paramMatches?.[2]) {\n keyPrefix = prefixRouteKeys ? NEXT_INTERCEPTION_MARKER_PREFIX : undefined\n reference.intercepted[paramMatches[2]] = interceptionMarker\n } else if (paramMatches?.[2] && reference.intercepted[paramMatches[2]]) {\n keyPrefix = prefixRouteKeys ? NEXT_INTERCEPTION_MARKER_PREFIX : undefined\n } else {\n keyPrefix = prefixRouteKeys ? NEXT_QUERY_PARAM_PREFIX : undefined\n }\n\n if (interceptionMarker && paramMatches && paramMatches[2]) {\n // If there's an interception marker, add it to the segments.\n const { key, pattern, cleanedKey, repeat, optional } =\n getSafeKeyFromSegment({\n getSafeRouteKey,\n interceptionMarker,\n segment: paramMatches[2],\n routeKeys,\n keyPrefix,\n backreferenceDuplicateKeys,\n })\n\n segments.push(pattern)\n inverseParts.push(\n `/${paramMatches[1]}:${reference.names[key] ?? cleanedKey}${repeat ? (optional ? '*' : '+') : ''}`\n )\n reference.names[key] ??= cleanedKey\n } else if (paramMatches && paramMatches[2]) {\n // If there's a prefix, add it to the segments if it's enabled.\n if (includePrefix && paramMatches[1]) {\n segments.push(`/${escapeStringRegexp(paramMatches[1])}`)\n inverseParts.push(`/${paramMatches[1]}`)\n }\n\n const { key, pattern, cleanedKey, repeat, optional } =\n getSafeKeyFromSegment({\n getSafeRouteKey,\n segment: paramMatches[2],\n routeKeys,\n keyPrefix,\n backreferenceDuplicateKeys,\n })\n\n // Remove the leading slash if includePrefix already added it.\n let s = pattern\n if (includePrefix && paramMatches[1]) {\n s = s.substring(1)\n }\n\n segments.push(s)\n inverseParts.push(\n `/:${reference.names[key] ?? cleanedKey}${repeat ? (optional ? '*' : '+') : ''}`\n )\n reference.names[key] ??= cleanedKey\n } else {\n segments.push(`/${escapeStringRegexp(segment)}`)\n inverseParts.push(`/${segment}`)\n }\n\n // If there's a suffix, add it to the segments if it's enabled.\n if (includeSuffix && paramMatches && paramMatches[3]) {\n segments.push(escapeStringRegexp(paramMatches[3]))\n inverseParts.push(paramMatches[3])\n }\n }\n\n return {\n namedParameterizedRoute: segments.join(''),\n routeKeys,\n pathToRegexpPattern: inverseParts.join(''),\n reference,\n }\n}\n\n/**\n * This function extends `getRouteRegex` generating also a named regexp where\n * each group is named along with a routeKeys object that indexes the assigned\n * named group with its corresponding key. When the routeKeys need to be\n * prefixed to uniquely identify internally the \"prefixRouteKey\" arg should\n * be \"true\" currently this is only the case when creating the routes-manifest\n * during the build\n */\nexport function getNamedRouteRegex(\n normalizedRoute: string,\n options: GetNamedRouteRegexOptions\n) {\n const result = getNamedParametrizedRoute(\n normalizedRoute,\n options.prefixRouteKeys,\n options.includeSuffix ?? false,\n options.includePrefix ?? false,\n options.backreferenceDuplicateKeys ?? false,\n options.reference\n )\n\n let namedRegex = result.namedParameterizedRoute\n if (!options.excludeOptionalTrailingSlash) {\n namedRegex += '(?:/)?'\n }\n\n return {\n ...getRouteRegex(normalizedRoute, options),\n namedRegex: `^${namedRegex}$`,\n routeKeys: result.routeKeys,\n pathToRegexpPattern: result.pathToRegexpPattern,\n reference: result.reference,\n }\n}\n\n/**\n * Generates a named regexp.\n * This is intended to be using for build time only.\n */\nexport function getNamedMiddlewareRegex(\n normalizedRoute: string,\n options: {\n catchAll?: boolean\n }\n) {\n const { parameterizedRoute } = getParametrizedRoute(\n normalizedRoute,\n false,\n false\n )\n const { catchAll = true } = options\n if (parameterizedRoute === '/') {\n let catchAllRegex = catchAll ? '.*' : ''\n return {\n namedRegex: `^/${catchAllRegex}$`,\n }\n }\n\n const { namedParameterizedRoute } = getNamedParametrizedRoute(\n normalizedRoute,\n false,\n false,\n false,\n false,\n undefined\n )\n let catchAllGroupedRegex = catchAll ? '(?:(/.*)?)' : ''\n return {\n namedRegex: `^${namedParameterizedRoute}${catchAllGroupedRegex}$`,\n }\n}\n","import type { HtmlProps } from './html-context.shared-runtime'\nimport type { ComponentType, JSX } from 'react'\nimport type { DomainLocale } from '../../server/config'\nimport type { Env } from '@next/env'\nimport type { IncomingMessage, ServerResponse } from 'http'\nimport type { NextRouter } from './router/router'\nimport type { ParsedUrlQuery } from 'querystring'\nimport type { PreviewData } from '../../types'\nimport type { COMPILER_NAMES } from './constants'\nimport type fs from 'fs'\n\nexport type NextComponentType<\n Context extends BaseContext = NextPageContext,\n InitialProps = {},\n Props = {},\n> = ComponentType<Props> & {\n /**\n * Used for initial page load data population. Data returned from `getInitialProps` is serialized when server rendered.\n * Make sure to return plain `Object` without using `Date`, `Map`, `Set`.\n * @param context Context of `page`\n */\n getInitialProps?(context: Context): InitialProps | Promise<InitialProps>\n}\n\nexport type DocumentType = NextComponentType<\n DocumentContext,\n DocumentInitialProps,\n DocumentProps\n>\n\nexport type AppType<P = {}> = NextComponentType<\n AppContextType,\n P,\n AppPropsType<any, P>\n>\n\nexport type AppTreeType = ComponentType<\n AppInitialProps & { [name: string]: any }\n>\n\n/**\n * Web vitals provided to _app.reportWebVitals by Core Web Vitals plugin developed by Google Chrome team.\n * https://nextjs.org/blog/next-9-4#integrated-web-vitals-reporting\n */\nexport const WEB_VITALS = ['CLS', 'FCP', 'FID', 'INP', 'LCP', 'TTFB'] as const\nexport type NextWebVitalsMetric = {\n id: string\n startTime: number\n value: number\n attribution?: { [key: string]: unknown }\n} & (\n | {\n label: 'web-vital'\n name: (typeof WEB_VITALS)[number]\n }\n | {\n label: 'custom'\n name:\n | 'Next.js-hydration'\n | 'Next.js-route-change-to-render'\n | 'Next.js-render'\n }\n)\n\nexport type Enhancer<C> = (Component: C) => C\n\nexport type ComponentsEnhancer =\n | {\n enhanceApp?: Enhancer<AppType>\n enhanceComponent?: Enhancer<NextComponentType>\n }\n | Enhancer<NextComponentType>\n\nexport type RenderPageResult = {\n html: string\n head?: Array<JSX.Element | null>\n}\n\nexport type RenderPage = (\n options?: ComponentsEnhancer\n) => DocumentInitialProps | Promise<DocumentInitialProps>\n\nexport type BaseContext = {\n res?: ServerResponse\n [k: string]: any\n}\n\nexport type NEXT_DATA = {\n props: Record<string, any>\n page: string\n query: ParsedUrlQuery\n buildId: string\n assetPrefix?: string\n nextExport?: boolean\n autoExport?: boolean\n isFallback?: boolean\n isExperimentalCompile?: boolean\n dynamicIds?: (string | number)[]\n err?: Error & {\n statusCode?: number\n source?: typeof COMPILER_NAMES.server | typeof COMPILER_NAMES.edgeServer\n }\n gsp?: boolean\n gssp?: boolean\n customServer?: boolean\n gip?: boolean\n appGip?: boolean\n locale?: string\n locales?: readonly string[]\n defaultLocale?: string\n domainLocales?: readonly DomainLocale[]\n scriptLoader?: any[]\n isPreview?: boolean\n notFoundSrcPage?: string\n}\n\n/**\n * `Next` context\n */\nexport interface NextPageContext {\n /**\n * Error object if encountered during rendering\n */\n err?: (Error & { statusCode?: number }) | null\n /**\n * `HTTP` request object.\n */\n req?: IncomingMessage\n /**\n * `HTTP` response object.\n */\n res?: ServerResponse\n /**\n * Path section of `URL`.\n */\n pathname: string\n /**\n * Query string section of `URL` parsed as an object.\n */\n query: ParsedUrlQuery\n /**\n * `String` of the actual path including query.\n */\n asPath?: string\n /**\n * The currently active locale\n */\n locale?: string\n /**\n * All configured locales\n */\n locales?: readonly string[]\n /**\n * The configured default locale\n */\n defaultLocale?: string\n /**\n * `Component` the tree of the App to use if needing to render separately\n */\n AppTree: AppTreeType\n}\n\nexport type AppContextType<Router extends NextRouter = NextRouter> = {\n Component: NextComponentType<NextPageContext>\n AppTree: AppTreeType\n ctx: NextPageContext\n router: Router\n}\n\nexport type AppInitialProps<PageProps = any> = {\n pageProps: PageProps\n}\n\nexport type AppPropsType<\n Router extends NextRouter = NextRouter,\n PageProps = {},\n> = AppInitialProps<PageProps> & {\n Component: NextComponentType<NextPageContext, any, any>\n router: Router\n __N_SSG?: boolean\n __N_SSP?: boolean\n}\n\nexport type DocumentContext = NextPageContext & {\n renderPage: RenderPage\n defaultGetInitialProps(\n ctx: DocumentContext,\n options?: { nonce?: string }\n ): Promise<DocumentInitialProps>\n}\n\nexport type DocumentInitialProps = RenderPageResult & {\n styles?: React.ReactElement[] | Iterable<React.ReactNode> | JSX.Element\n}\n\nexport type DocumentProps = DocumentInitialProps & HtmlProps\n\n/**\n * Next `API` route request\n */\nexport interface NextApiRequest extends IncomingMessage {\n /**\n * Object of `query` values from url\n */\n query: Partial<{\n [key: string]: string | string[]\n }>\n /**\n * Object of `cookies` from header\n */\n cookies: Partial<{\n [key: string]: string\n }>\n\n body: any\n\n env: Env\n\n draftMode?: boolean\n\n preview?: boolean\n /**\n * Preview data set on the request, if any\n * */\n previewData?: PreviewData\n}\n\n/**\n * Send body of response\n */\ntype Send<T> = (body: T) => void\n\n/**\n * Next `API` route response\n */\nexport type NextApiResponse<Data = any> = ServerResponse & {\n /**\n * Send data `any` data in response\n */\n send: Send<Data>\n /**\n * Send data `json` data in response\n */\n json: Send<Data>\n status: (statusCode: number) => NextApiResponse<Data>\n redirect(url: string): NextApiResponse<Data>\n redirect(status: number, url: string): NextApiResponse<Data>\n\n /**\n * Set draft mode\n */\n setDraftMode: (options: { enable: boolean }) => NextApiResponse<Data>\n\n /**\n * Set preview data for Next.js' prerender mode\n */\n setPreviewData: (\n data: object | string,\n options?: {\n /**\n * Specifies the number (in seconds) for the preview session to last for.\n * The given number will be converted to an integer by rounding down.\n * By default, no maximum age is set and the preview session finishes\n * when the client shuts down (browser is closed).\n */\n maxAge?: number\n /**\n * Specifies the path for the preview session to work under. By default,\n * the path is considered the \"default path\", i.e., any pages under \"/\".\n */\n path?: string\n }\n ) => NextApiResponse<Data>\n\n /**\n * Clear preview data for Next.js' prerender mode\n */\n clearPreviewData: (options?: { path?: string }) => NextApiResponse<Data>\n\n /**\n * Revalidate a specific page and regenerate it using On-Demand Incremental\n * Static Regeneration.\n * The path should be an actual path, not a rewritten path. E.g. for\n * \"/blog/[slug]\" this should be \"/blog/post-1\".\n * @link https://nextjs.org/docs/app/building-your-application/data-fetching/incremental-static-regeneration#on-demand-revalidation-with-revalidatepath\n */\n revalidate: (\n urlPath: string,\n opts?: {\n unstable_onlyGenerated?: boolean\n }\n ) => Promise<void>\n}\n\n/**\n * Next `API` route handler\n */\nexport type NextApiHandler<T = any> = (\n req: NextApiRequest,\n res: NextApiResponse<T>\n) => unknown | Promise<unknown>\n\n/**\n * Utils\n */\nexport function execOnce<T extends (...args: any[]) => ReturnType<T>>(\n fn: T\n): T {\n let used = false\n let result: ReturnType<T>\n\n return ((...args: any[]) => {\n if (!used) {\n used = true\n result = fn(...args)\n }\n return result\n }) as T\n}\n\n// Scheme: https://tools.ietf.org/html/rfc3986#section-3.1\n// Absolute URL: https://tools.ietf.org/html/rfc3986#section-4.3\nconst ABSOLUTE_URL_REGEX = /^[a-zA-Z][a-zA-Z\\d+\\-.]*?:/\nexport const isAbsoluteUrl = (url: string) => ABSOLUTE_URL_REGEX.test(url)\n\nexport function getLocationOrigin() {\n const { protocol, hostname, port } = window.location\n return `${protocol}//${hostname}${port ? ':' + port : ''}`\n}\n\nexport function getURL() {\n const { href } = window.location\n const origin = getLocationOrigin()\n return href.substring(origin.length)\n}\n\nexport function getDisplayName<P>(Component: ComponentType<P>) {\n return typeof Component === 'string'\n ? Component\n : Component.displayName || Component.name || 'Unknown'\n}\n\nexport function isResSent(res: ServerResponse) {\n return res.finished || res.headersSent\n}\n\nexport function normalizeRepeatedSlashes(url: string) {\n const urlParts = url.split('?')\n const urlNoQuery = urlParts[0]\n\n return (\n urlNoQuery\n // first we replace any non-encoded backslashes with forward\n // then normalize repeated forward slashes\n .replace(/\\\\/g, '/')\n .replace(/\\/\\/+/g, '/') +\n (urlParts[1] ? `?${urlParts.slice(1).join('?')}` : '')\n )\n}\n\nexport async function loadGetInitialProps<\n C extends BaseContext,\n IP = {},\n P = {},\n>(App: NextComponentType<C, IP, P>, ctx: C): Promise<IP> {\n if (process.env.NODE_ENV !== 'production') {\n if (App.prototype?.getInitialProps) {\n const message = `\"${getDisplayName(\n App\n )}.getInitialProps()\" is defined as an instance method - visit https://nextjs.org/docs/messages/get-initial-props-as-an-instance-method for more information.`\n throw new Error(message)\n }\n }\n // when called from _app `ctx` is nested in `ctx`\n const res = ctx.res || (ctx.ctx && ctx.ctx.res)\n\n if (!App.getInitialProps) {\n if (ctx.ctx && ctx.Component) {\n // @ts-ignore pageProps default\n return {\n pageProps: await loadGetInitialProps(ctx.Component, ctx.ctx),\n }\n }\n return {} as IP\n }\n\n const props = await App.getInitialProps(ctx)\n\n if (res && isResSent(res)) {\n return props\n }\n\n if (!props) {\n const message = `\"${getDisplayName(\n App\n )}.getInitialProps()\" should resolve to an object. But found \"${props}\" instead.`\n throw new Error(message)\n }\n\n if (process.env.NODE_ENV !== 'production') {\n if (Object.keys(props).length === 0 && !ctx.ctx) {\n console.warn(\n `${getDisplayName(\n App\n )} returned an empty object from \\`getInitialProps\\`. This de-optimizes and prevents automatic static optimization. https://nextjs.org/docs/messages/empty-object-getInitialProps`\n )\n }\n }\n\n return props\n}\n\nexport const SP = typeof performance !== 'undefined'\nexport const ST =\n SP &&\n (['mark', 'measure', 'getEntriesByName'] as const).every(\n (method) => typeof performance[method] === 'function'\n )\n\nexport class DecodeError extends Error {}\nexport class NormalizeError extends Error {}\nexport class PageNotFoundError extends Error {\n code: string\n\n constructor(page: string) {\n super()\n this.code = 'ENOENT'\n this.name = 'PageNotFoundError'\n this.message = `Cannot find module for page: ${page}`\n }\n}\n\nexport class MissingStaticPage extends Error {\n constructor(page: string, message: string) {\n super()\n this.message = `Failed to load static file for page: ${page} ${message}`\n }\n}\n\nexport class MiddlewareNotFoundError extends Error {\n code: string\n constructor() {\n super()\n this.code = 'ENOENT'\n this.message = `Cannot find the middleware module`\n }\n}\n\nexport interface CacheFs {\n existsSync: typeof fs.existsSync\n readFile: typeof fs.promises.readFile\n readFileSync: typeof fs.readFileSync\n writeFile(f: string, d: any): Promise<void>\n mkdir(dir: string): Promise<void | string>\n stat(f: string): Promise<{ mtime: Date }>\n}\n\nexport function stringifyError(error: Error) {\n return JSON.stringify({ message: error.message, stack: error.stack })\n}\n","import type { Token } from 'next/dist/compiled/path-to-regexp'\n\n/**\n * Route pattern normalization utilities for path-to-regexp compatibility.\n *\n * path-to-regexp 6.3.0+ introduced stricter validation that rejects certain\n * patterns commonly used in Next.js interception routes. This module provides\n * normalization functions to make Next.js route patterns compatible with the\n * updated library while preserving all functionality.\n */\n\n/**\n * Internal separator used to normalize adjacent parameter patterns.\n * This unique marker is inserted between adjacent parameters and stripped out\n * during parameter extraction to avoid conflicts with real URL content.\n */\nexport const PARAM_SEPARATOR = '_NEXTSEP_'\n\n/**\n * Detects if a route pattern needs normalization for path-to-regexp compatibility.\n */\nexport function hasAdjacentParameterIssues(route: string): boolean {\n if (typeof route !== 'string') return false\n\n // Check for interception route markers followed immediately by parameters\n // Pattern: /(.):param, /(..):param, /(...):param, /(.)(.):param etc.\n // These patterns cause \"Must have text between two parameters\" errors\n if (/\\/\\(\\.{1,3}\\):[^/\\s]+/.test(route)) {\n return true\n }\n\n // Check for basic adjacent parameters without separators\n // Pattern: :param1:param2 (but not :param* or other URL patterns)\n if (/:[a-zA-Z_][a-zA-Z0-9_]*:[a-zA-Z_][a-zA-Z0-9_]*/.test(route)) {\n return true\n }\n\n return false\n}\n\n/**\n * Normalizes route patterns that have adjacent parameters without text between them.\n * Inserts a unique separator that can be safely stripped out later.\n */\nexport function normalizeAdjacentParameters(route: string): string {\n let normalized = route\n\n // Handle interception route patterns: (.):param -> (.)_NEXTSEP_:param\n normalized = normalized.replace(\n /(\\([^)]*\\)):([^/\\s]+)/g,\n `$1${PARAM_SEPARATOR}:$2`\n )\n\n // Handle other adjacent parameter patterns: :param1:param2 -> :param1_NEXTSEP_:param2\n normalized = normalized.replace(/:([^:/\\s)]+)(?=:)/g, `:$1${PARAM_SEPARATOR}`)\n\n return normalized\n}\n\n/**\n * Normalizes tokens that have repeating modifiers (* or +) but empty prefix and suffix.\n *\n * path-to-regexp 6.3.0+ introduced validation that throws:\n * \"Can not repeat without prefix/suffix\"\n *\n * This occurs when a token has modifier: '*' or '+' with both prefix: '' and suffix: ''\n */\nexport function normalizeTokensForRegexp(tokens: Token[]): Token[] {\n return tokens.map((token) => {\n // Token union type: Token = string | TokenObject\n // Literal path segments are strings, parameters/wildcards are objects\n if (\n typeof token === 'object' &&\n token !== null &&\n // Not all token objects have 'modifier' property (e.g., simple text tokens)\n 'modifier' in token &&\n // Only repeating modifiers (* or +) cause the validation error\n // Other modifiers like '?' (optional) are fine\n (token.modifier === '*' || token.modifier === '+') &&\n // Token objects can have different shapes depending on route pattern\n 'prefix' in token &&\n 'suffix' in token &&\n // Both prefix and suffix must be empty strings\n // This is what causes the validation error in path-to-regexp\n token.prefix === '' &&\n token.suffix === ''\n ) {\n // Add minimal prefix to satisfy path-to-regexp validation\n // We use '/' as it's the most common path delimiter and won't break route matching\n // The prefix gets used in regex generation but doesn't affect parameter extraction\n return {\n ...token,\n prefix: '/',\n }\n }\n return token\n })\n}\n\n/**\n * Strips normalization separators from compiled pathname.\n * This removes separators that were inserted by normalizeAdjacentParameters\n * to satisfy path-to-regexp validation.\n *\n * Only removes separators in the specific contexts where they were inserted:\n * - After interception route markers: (.)_NEXTSEP_ -> (.)\n *\n * This targeted approach ensures we don't accidentally remove the separator\n * from legitimate user content.\n */\nexport function stripNormalizedSeparators(pathname: string): string {\n // Remove separator after interception route markers\n // Pattern: (.)_NEXTSEP_ -> (.), (..)_NEXTSEP_ -> (..), etc.\n // The separator appears after the closing paren of interception markers\n return pathname.replace(new RegExp(`\\\\)${PARAM_SEPARATOR}`, 'g'), ')')\n}\n\n/**\n * Strips normalization separators from extracted route parameters.\n * Used by both server and client code to clean up parameters after route matching.\n */\nexport function stripParameterSeparators(\n params: Record<string, any>\n): Record<string, any> {\n const cleaned: Record<string, any> = {}\n\n for (const [key, value] of Object.entries(params)) {\n if (typeof value === 'string') {\n // Remove the separator if it appears at the start of parameter values\n cleaned[key] = value.replace(new RegExp(`^${PARAM_SEPARATOR}`), '')\n } else if (Array.isArray(value)) {\n // Handle array parameters (from repeated route segments)\n cleaned[key] = value.map((item) =>\n typeof item === 'string'\n ? item.replace(new RegExp(`^${PARAM_SEPARATOR}`), '')\n : item\n )\n } else {\n cleaned[key] = value\n }\n }\n\n return cleaned\n}\n","/**\n * Client-safe utilities for route matching that don't import server-side\n * utilities to avoid bundling issues with Turbopack\n */\n\nimport type {\n Key,\n TokensToRegexpOptions,\n ParseOptions,\n TokensToFunctionOptions,\n} from 'next/dist/compiled/path-to-regexp'\nimport {\n pathToRegexp,\n compile,\n regexpToFunction,\n} from 'next/dist/compiled/path-to-regexp'\nimport {\n hasAdjacentParameterIssues,\n normalizeAdjacentParameters,\n stripParameterSeparators,\n stripNormalizedSeparators,\n} from '../../../../lib/route-pattern-normalizer'\n\n/**\n * Client-safe wrapper around pathToRegexp that handles path-to-regexp 6.3.0+ validation errors.\n * This includes both \"Can not repeat without prefix/suffix\" and \"Must have text between parameters\" errors.\n */\nexport function safePathToRegexp(\n route: string | RegExp | Array<string | RegExp>,\n keys?: Key[],\n options?: TokensToRegexpOptions & ParseOptions\n): RegExp {\n if (typeof route !== 'string') {\n return pathToRegexp(route, keys, options)\n }\n\n // Check if normalization is needed and cache the result\n const needsNormalization = hasAdjacentParameterIssues(route)\n const routeToUse = needsNormalization\n ? normalizeAdjacentParameters(route)\n : route\n\n try {\n return pathToRegexp(routeToUse, keys, options)\n } catch (error) {\n // Only try normalization if we haven't already normalized\n if (!needsNormalization) {\n try {\n const normalizedRoute = normalizeAdjacentParameters(route)\n return pathToRegexp(normalizedRoute, keys, options)\n } catch (retryError) {\n // If that doesn't work, fall back to original error\n throw error\n }\n }\n throw error\n }\n}\n\n/**\n * Client-safe wrapper around compile that handles path-to-regexp 6.3.0+ validation errors.\n * No server-side error reporting to avoid bundling issues.\n * When normalization is applied, the returned compiler function automatically strips\n * the internal separator from the output URL.\n */\nexport function safeCompile(\n route: string,\n options?: TokensToFunctionOptions & ParseOptions\n) {\n // Check if normalization is needed and cache the result\n const needsNormalization = hasAdjacentParameterIssues(route)\n const routeToUse = needsNormalization\n ? normalizeAdjacentParameters(route)\n : route\n\n try {\n const compiler = compile(routeToUse, options)\n\n // If we normalized the route, wrap the compiler to strip separators from output\n // The normalization inserts _NEXTSEP_ as a literal string in the pattern to satisfy\n // path-to-regexp validation, but we don't want it in the final compiled URL\n if (needsNormalization) {\n return (params: any) => {\n return stripNormalizedSeparators(compiler(params))\n }\n }\n\n return compiler\n } catch (error) {\n // Only try normalization if we haven't already normalized\n if (!needsNormalization) {\n try {\n const normalizedRoute = normalizeAdjacentParameters(route)\n const compiler = compile(normalizedRoute, options)\n\n // Wrap the compiler to strip separators from output\n return (params: any) => {\n return stripNormalizedSeparators(compiler(params))\n }\n } catch (retryError) {\n // If that doesn't work, fall back to original error\n throw error\n }\n }\n throw error\n }\n}\n\n/**\n * Client-safe wrapper around regexpToFunction that automatically cleans parameters.\n */\nexport function safeRegexpToFunction<\n T extends Record<string, any> = Record<string, any>,\n>(regexp: RegExp, keys?: Key[]): (pathname: string) => { params: T } | false {\n const originalMatcher = regexpToFunction<T>(regexp, keys || [])\n\n return (pathname: string) => {\n const result = originalMatcher(pathname)\n if (!result) return false\n\n // Clean parameters before returning\n return {\n ...result,\n params: stripParameterSeparators(result.params as any) as T,\n }\n }\n}\n\n/**\n * Safe wrapper for route matcher functions that automatically cleans parameters.\n * This is client-safe and doesn't import path-to-regexp.\n */\nexport function safeRouteMatcher<T extends Record<string, any>>(\n matcherFn: (pathname: string) => false | T\n): (pathname: string) => false | T {\n return (pathname: string) => {\n const result = matcherFn(pathname)\n if (!result) return false\n\n // Clean parameters before returning\n return stripParameterSeparators(result) as T\n }\n}\n","import type { Group } from './route-regex'\nimport { DecodeError } from '../../utils'\nimport type { Params } from '../../../../server/request/params'\nimport { safeRouteMatcher } from './route-match-utils'\n\nexport interface RouteMatchFn {\n (pathname: string): false | Params\n}\n\ntype RouteMatcherOptions = {\n // We only use the exec method of the RegExp object. This helps us avoid using\n // type assertions that the passed in properties are of the correct type.\n re: Pick<RegExp, 'exec'>\n groups: Record<string, Group>\n}\n\nexport function getRouteMatcher({\n re,\n groups,\n}: RouteMatcherOptions): RouteMatchFn {\n const rawMatcher = (pathname: string) => {\n const routeMatch = re.exec(pathname)\n if (!routeMatch) return false\n\n const decode = (param: string) => {\n try {\n return decodeURIComponent(param)\n } catch {\n throw new DecodeError('failed to decode param')\n }\n }\n\n const params: Params = {}\n for (const [key, group] of Object.entries(groups)) {\n const match = routeMatch[group.pos]\n if (match !== undefined) {\n if (group.repeat) {\n params[key] = match.split('/').map((entry) => decode(entry))\n } else {\n params[key] = decode(match)\n }\n }\n }\n\n return params\n }\n\n // Wrap with safe matcher to handle parameter cleaning\n return safeRouteMatcher(rawMatcher)\n}\n","import type { ParsedUrlQuery } from 'querystring'\n\nexport function searchParamsToUrlQuery(\n searchParams: URLSearchParams\n): ParsedUrlQuery {\n const query: ParsedUrlQuery = {}\n for (const [key, value] of searchParams.entries()) {\n const existing = query[key]\n if (typeof existing === 'undefined') {\n query[key] = value\n } else if (Array.isArray(existing)) {\n existing.push(value)\n } else {\n query[key] = [existing, value]\n }\n }\n return query\n}\n\nfunction stringifyUrlQueryParam(param: unknown): string {\n if (typeof param === 'string') {\n return param\n }\n\n if (\n (typeof param === 'number' && !isNaN(param)) ||\n typeof param === 'boolean'\n ) {\n return String(param)\n } else {\n return ''\n }\n}\n\nexport function urlQueryToSearchParams(query: ParsedUrlQuery): URLSearchParams {\n const searchParams = new URLSearchParams()\n for (const [key, value] of Object.entries(query)) {\n if (Array.isArray(value)) {\n for (const item of value) {\n searchParams.append(key, stringifyUrlQueryParam(item))\n }\n } else {\n searchParams.set(key, stringifyUrlQueryParam(value))\n }\n }\n return searchParams\n}\n\nexport function assign(\n target: URLSearchParams,\n ...searchParamsList: URLSearchParams[]\n): URLSearchParams {\n for (const searchParams of searchParamsList) {\n for (const key of searchParams.keys()) {\n target.delete(key)\n }\n\n for (const [key, value] of searchParams.entries()) {\n target.append(key, value)\n }\n }\n\n return target\n}\n","import type { NextApiRequestCookies } from '.'\n\n/**\n * Parse cookies from the `headers` of request\n * @param req request object\n */\n\nexport function getCookieParser(headers: {\n [key: string]: string | string[] | null | undefined\n}): () => NextApiRequestCookies {\n return function parseCookie(): NextApiRequestCookies {\n const { cookie } = headers\n\n if (!cookie) {\n return {}\n }\n\n const { parse: parseCookieFn } =\n require('next/dist/compiled/cookie') as typeof import('next/dist/compiled/cookie')\n return parseCookieFn(Array.isArray(cookie) ? cookie.join('; ') : cookie)\n }\n}\n","import type { IncomingMessage } from 'http'\nimport type { Key } from 'next/dist/compiled/path-to-regexp'\nimport type { NextParsedUrlQuery } from '../../../../server/request-meta'\nimport type { RouteHas } from '../../../../lib/load-custom-routes'\nimport type { BaseNextRequest } from '../../../../server/base-http'\n\nimport { escapeStringRegexp } from '../../escape-regexp'\nimport { parseUrl } from './parse-url'\nimport {\n INTERCEPTION_ROUTE_MARKERS,\n isInterceptionRouteAppPath,\n} from './interception-routes'\nimport { getCookieParser } from '../../../../server/api-utils/get-cookie-parser'\nimport type { Params } from '../../../../server/request/params'\nimport { safePathToRegexp, safeCompile } from './route-match-utils'\n\n/**\n * Ensure only a-zA-Z are used for param names for proper interpolating\n * with path-to-regexp\n */\nfunction getSafeParamName(paramName: string) {\n let newParamName = ''\n\n for (let i = 0; i < paramName.length; i++) {\n const charCode = paramName.charCodeAt(i)\n\n if (\n (charCode > 64 && charCode < 91) || // A-Z\n (charCode > 96 && charCode < 123) // a-z\n ) {\n newParamName += paramName[i]\n }\n }\n return newParamName\n}\n\nfunction escapeSegment(str: string, segmentName: string) {\n return str.replace(\n new RegExp(`:${escapeStringRegexp(segmentName)}`, 'g'),\n `__ESC_COLON_${segmentName}`\n )\n}\n\nfunction unescapeSegments(str: string) {\n return str.replace(/__ESC_COLON_/gi, ':')\n}\n\nexport function matchHas(\n req: BaseNextRequest | IncomingMessage,\n query: Params,\n has: RouteHas[] = [],\n missing: RouteHas[] = []\n): false | Params {\n const params: Params = {}\n\n const hasMatch = (hasItem: RouteHas) => {\n let value\n let key = hasItem.key\n\n switch (hasItem.type) {\n case 'header': {\n key = key!.toLowerCase()\n value = req.headers[key] as string\n break\n }\n case 'cookie': {\n if ('cookies' in req) {\n value = req.cookies[hasItem.key]\n } else {\n const cookies = getCookieParser(req.headers)()\n value = cookies[hasItem.key]\n }\n\n break\n }\n case 'query': {\n value = query[key!]\n break\n }\n case 'host': {\n const { host } = req?.headers || {}\n // remove port from host if present\n const hostname = host?.split(':', 1)[0].toLowerCase()\n value = hostname\n break\n }\n default: {\n break\n }\n }\n\n if (!hasItem.value && value) {\n params[getSafeParamName(key!)] = value\n return true\n } else if (value) {\n const matcher = new RegExp(`^${hasItem.value}$`)\n const matches = Array.isArray(value)\n ? value.slice(-1)[0].match(matcher)\n : value.match(matcher)\n\n if (matches) {\n if (Array.isArray(matches)) {\n if (matches.groups) {\n Object.keys(matches.groups).forEach((groupKey) => {\n params[groupKey] = matches.groups![groupKey]\n })\n } else if (hasItem.type === 'host' && matches[0]) {\n params.host = matches[0]\n }\n }\n return true\n }\n }\n return false\n }\n\n const allMatch =\n has.every((item) => hasMatch(item)) &&\n !missing.some((item) => hasMatch(item))\n\n if (allMatch) {\n return params\n }\n return false\n}\n\nexport function compileNonPath(value: string, params: Params): string {\n if (!value.includes(':')) {\n return value\n }\n\n for (const key of Object.keys(params)) {\n if (value.includes(`:${key}`)) {\n value = value\n .replace(\n new RegExp(`:${key}\\\\*`, 'g'),\n `:${key}--ESCAPED_PARAM_ASTERISKS`\n )\n .replace(\n new RegExp(`:${key}\\\\?`, 'g'),\n `:${key}--ESCAPED_PARAM_QUESTION`\n )\n .replace(new RegExp(`:${key}\\\\+`, 'g'), `:${key}--ESCAPED_PARAM_PLUS`)\n .replace(\n new RegExp(`:${key}(?!\\\\w)`, 'g'),\n `--ESCAPED_PARAM_COLON${key}`\n )\n }\n }\n value = value\n .replace(/(:|\\*|\\?|\\+|\\(|\\)|\\{|\\})/g, '\\\\$1')\n .replace(/--ESCAPED_PARAM_PLUS/g, '+')\n .replace(/--ESCAPED_PARAM_COLON/g, ':')\n .replace(/--ESCAPED_PARAM_QUESTION/g, '?')\n .replace(/--ESCAPED_PARAM_ASTERISKS/g, '*')\n\n // the value needs to start with a forward-slash to be compiled\n // correctly\n return safeCompile(`/${value}`, { validate: false })(params).slice(1)\n}\n\nexport function parseDestination(args: {\n destination: string\n params: Readonly<Params>\n query: Readonly<NextParsedUrlQuery>\n}) {\n let escaped = args.destination\n for (const param of Object.keys({ ...args.params, ...args.query })) {\n if (!param) continue\n\n escaped = escapeSegment(escaped, param)\n }\n\n const parsed = parseUrl(escaped)\n\n let pathname = parsed.pathname\n if (pathname) {\n pathname = unescapeSegments(pathname)\n }\n\n let href = parsed.href\n if (href) {\n href = unescapeSegments(href)\n }\n\n let hostname = parsed.hostname\n if (hostname) {\n hostname = unescapeSegments(hostname)\n }\n\n let hash = parsed.hash\n if (hash) {\n hash = unescapeSegments(hash)\n }\n\n let search = parsed.search\n if (search) {\n search = unescapeSegments(search)\n }\n\n let origin = parsed.origin\n if (origin) {\n origin = unescapeSegments(origin)\n }\n\n return {\n ...parsed,\n pathname,\n hostname,\n href,\n hash,\n search,\n origin,\n }\n}\n\nexport function prepareDestination(args: {\n appendParamsToQuery: boolean\n destination: string\n params: Params\n query: NextParsedUrlQuery\n}) {\n const parsedDestination = parseDestination(args)\n\n const {\n hostname: destHostname,\n query: destQuery,\n search: destSearch,\n } = parsedDestination\n\n // The following code assumes that the pathname here includes the hash if it's\n // present.\n let destPath = parsedDestination.pathname\n if (parsedDestination.hash) {\n destPath = `${destPath}${parsedDestination.hash}`\n }\n\n const destParams: (string | number)[] = []\n\n const destPathParamKeys: Key[] = []\n safePathToRegexp(destPath, destPathParamKeys)\n for (const key of destPathParamKeys) {\n destParams.push(key.name)\n }\n\n if (destHostname) {\n const destHostnameParamKeys: Key[] = []\n safePathToRegexp(destHostname, destHostnameParamKeys)\n for (const key of destHostnameParamKeys) {\n destParams.push(key.name)\n }\n }\n\n const destPathCompiler = safeCompile(\n destPath,\n // we don't validate while compiling the destination since we should\n // have already validated before we got to this point and validating\n // breaks compiling destinations with named pattern params from the source\n // e.g. /something:hello(.*) -> /another/:hello is broken with validation\n // since compile validation is meant for reversing and not for inserting\n // params from a separate path-regex into another\n { validate: false }\n )\n\n let destHostnameCompiler\n if (destHostname) {\n destHostnameCompiler = safeCompile(destHostname, { validate: false })\n }\n\n // update any params in query values\n for (const [key, strOrArray] of Object.entries(destQuery)) {\n // the value needs to start with a forward-slash to be compiled\n // correctly\n if (Array.isArray(strOrArray)) {\n destQuery[key] = strOrArray.map((value) =>\n compileNonPath(unescapeSegments(value), args.params)\n )\n } else if (typeof strOrArray === 'string') {\n destQuery[key] = compileNonPath(unescapeSegments(strOrArray), args.params)\n }\n }\n\n // add path params to query if it's not a redirect and not\n // already defined in destination query or path\n let paramKeys = Object.keys(args.params).filter(\n (name) => name !== 'nextInternalLocale'\n )\n\n if (\n args.appendParamsToQuery &&\n !paramKeys.some((key) => destParams.includes(key))\n ) {\n for (const key of paramKeys) {\n if (!(key in destQuery)) {\n destQuery[key] = args.params[key]\n }\n }\n }\n\n let newUrl\n\n // The compiler also that the interception route marker is an unnamed param, hence '0',\n // so we need to add it to the params object.\n if (isInterceptionRouteAppPath(destPath)) {\n for (const segment of destPath.split('/')) {\n const marker = INTERCEPTION_ROUTE_MARKERS.find((m) =>\n segment.startsWith(m)\n )\n if (marker) {\n if (marker === '(..)(..)') {\n args.params['0'] = '(..)'\n args.params['1'] = '(..)'\n } else {\n args.params['0'] = marker\n }\n break\n }\n }\n }\n\n try {\n newUrl = destPathCompiler(args.params)\n\n const [pathname, hash] = newUrl.split('#', 2)\n if (destHostnameCompiler) {\n parsedDestination.hostname = destHostnameCompiler(args.params)\n }\n parsedDestination.pathname = pathname\n parsedDestination.hash = `${hash ? '#' : ''}${hash || ''}`\n parsedDestination.search = destSearch\n ? compileNonPath(destSearch, args.params)\n : ''\n } catch (err: any) {\n if (err.message.match(/Expected .*? to not repeat, but got an array/)) {\n throw new Error(\n `To use a multi-match in the destination you must add \\`*\\` at the end of the param name to signify it should repeat. https://nextjs.org/docs/messages/invalid-multi-match`\n )\n }\n throw err\n }\n\n // Query merge order lowest priority to highest\n // 1. initial URL query values\n // 2. path segment values\n // 3. destination specified query values\n parsedDestination.query = {\n ...args.query,\n ...parsedDestination.query,\n }\n\n return {\n newUrl,\n destQuery,\n parsedDestination,\n }\n}\n","import type { OutgoingHttpHeaders } from 'http'\nimport {\n NEXT_INTERCEPTION_MARKER_PREFIX,\n NEXT_QUERY_PARAM_PREFIX,\n} from '../../lib/constants'\n\n/**\n * Converts a Node.js IncomingHttpHeaders object to a Headers object. Any\n * headers with multiple values will be joined with a comma and space. Any\n * headers that have an undefined value will be ignored and others will be\n * coerced to strings.\n *\n * @param nodeHeaders the headers object to convert\n * @returns the converted headers object\n */\nexport function fromNodeOutgoingHttpHeaders(\n nodeHeaders: OutgoingHttpHeaders\n): Headers {\n const headers = new Headers()\n for (let [key, value] of Object.entries(nodeHeaders)) {\n const values = Array.isArray(value) ? value : [value]\n for (let v of values) {\n if (typeof v === 'undefined') continue\n if (typeof v === 'number') {\n v = v.toString()\n }\n\n headers.append(key, v)\n }\n }\n return headers\n}\n\n/*\n Set-Cookie header field-values are sometimes comma joined in one string. This splits them without choking on commas\n that are within a single set-cookie field-value, such as in the Expires portion.\n This is uncommon, but explicitly allowed - see https://tools.ietf.org/html/rfc2616#section-4.2\n Node.js does this for every header *except* set-cookie - see https://github.com/nodejs/node/blob/d5e363b77ebaf1caf67cd7528224b651c86815c1/lib/_http_incoming.js#L128\n React Native's fetch does this for *every* header, including set-cookie.\n \n Based on: https://github.com/google/j2objc/commit/16820fdbc8f76ca0c33472810ce0cb03d20efe25\n Credits to: https://github.com/tomball for original and https://github.com/chrusart for JavaScript implementation\n*/\nexport function splitCookiesString(cookiesString: string) {\n var cookiesStrings = []\n var pos = 0\n var start\n var ch\n var lastComma\n var nextStart\n var cookiesSeparatorFound\n\n function skipWhitespace() {\n while (pos < cookiesString.length && /\\s/.test(cookiesString.charAt(pos))) {\n pos += 1\n }\n return pos < cookiesString.length\n }\n\n function notSpecialChar() {\n ch = cookiesString.charAt(pos)\n\n return ch !== '=' && ch !== ';' && ch !== ','\n }\n\n while (pos < cookiesString.length) {\n start = pos\n cookiesSeparatorFound = false\n\n while (skipWhitespace()) {\n ch = cookiesString.charAt(pos)\n if (ch === ',') {\n // ',' is a cookie separator if we have later first '=', not ';' or ','\n lastComma = pos\n pos += 1\n\n skipWhitespace()\n nextStart = pos\n\n while (pos < cookiesString.length && notSpecialChar()) {\n pos += 1\n }\n\n // currently special character\n if (pos < cookiesString.length && cookiesString.charAt(pos) === '=') {\n // we found cookies separator\n cookiesSeparatorFound = true\n // pos is inside the next cookie, so back up and return it.\n pos = nextStart\n cookiesStrings.push(cookiesString.substring(start, lastComma))\n start = pos\n } else {\n // in param ',' or param separator ';',\n // we continue from that comma\n pos = lastComma + 1\n }\n } else {\n pos += 1\n }\n }\n\n if (!cookiesSeparatorFound || pos >= cookiesString.length) {\n cookiesStrings.push(cookiesString.substring(start, cookiesString.length))\n }\n }\n\n return cookiesStrings\n}\n\n/**\n * Converts a Headers object to a Node.js OutgoingHttpHeaders object. This is\n * required to support the set-cookie header, which may have multiple values.\n *\n * @param headers the headers object to convert\n * @returns the converted headers object\n */\nexport function toNodeOutgoingHttpHeaders(\n headers: Headers\n): OutgoingHttpHeaders {\n const nodeHeaders: OutgoingHttpHeaders = {}\n const cookies: string[] = []\n if (headers) {\n for (const [key, value] of headers.entries()) {\n if (key.toLowerCase() === 'set-cookie') {\n // We may have gotten a comma joined string of cookies, or multiple\n // set-cookie headers. We need to merge them into one header array\n // to represent all the cookies.\n cookies.push(...splitCookiesString(value))\n nodeHeaders[key] = cookies.length === 1 ? cookies[0] : cookies\n } else {\n nodeHeaders[key] = value\n }\n }\n }\n return nodeHeaders\n}\n\n/**\n * Validate the correctness of a user-provided URL.\n */\nexport function validateURL(url: string | URL): string {\n try {\n return String(new URL(String(url)))\n } catch (error: any) {\n throw new Error(\n `URL is malformed \"${String(\n url\n )}\". Please use only absolute URLs - https://nextjs.org/docs/messages/middleware-relative-urls`,\n { cause: error }\n )\n }\n}\n\n/**\n * Normalizes `nxtP` and `nxtI` query param values to remove the prefix.\n * This function does not mutate the input key.\n */\nexport function normalizeNextQueryParam(key: string): null | string {\n const prefixes = [NEXT_QUERY_PARAM_PREFIX, NEXT_INTERCEPTION_MARKER_PREFIX]\n for (const prefix of prefixes) {\n if (key !== prefix && key.startsWith(prefix)) {\n return key.substring(prefix.length)\n }\n }\n return null\n}\n","/**\n * Decodes a query path parameter.\n *\n * @param value - The value to decode.\n * @returns The decoded value.\n */\nexport function decodeQueryPathParameter(value: string) {\n // When deployed to Vercel, the value may be encoded, so this attempts to\n // decode it and returns the original value if it fails.\n try {\n return decodeURIComponent(value)\n } catch {\n return value\n }\n}\n","// Format function modified from nodejs\n// Copyright Joyent, Inc. and other Node contributors.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a\n// copy of this software and associated documentation files (the\n// \"Software\"), to deal in the Software without restriction, including\n// without limitation the rights to use, copy, modify, merge, publish,\n// distribute, sublicense, and/or sell copies of the Software, and to permit\n// persons to whom the Software is furnished to do so, subject to the\n// following conditions:\n//\n// The above copyright notice and this permission notice shall be included\n// in all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS\n// OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF\n// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN\n// NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,\n// DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR\n// OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE\n// USE OR OTHER DEALINGS IN THE SOFTWARE.\n\nimport type { UrlObject } from 'url'\nimport type { ParsedUrlQuery } from 'querystring'\nimport * as querystring from './querystring'\n\nconst slashedProtocols = /https?|ftp|gopher|file/\n\nexport function formatUrl(urlObj: UrlObject) {\n let { auth, hostname } = urlObj\n let protocol = urlObj.protocol || ''\n let pathname = urlObj.pathname || ''\n let hash = urlObj.hash || ''\n let query = urlObj.query || ''\n let host: string | false = false\n\n auth = auth ? encodeURIComponent(auth).replace(/%3A/i, ':') + '@' : ''\n\n if (urlObj.host) {\n host = auth + urlObj.host\n } else if (hostname) {\n host = auth + (~hostname.indexOf(':') ? `[${hostname}]` : hostname)\n if (urlObj.port) {\n host += ':' + urlObj.port\n }\n }\n\n if (query && typeof query === 'object') {\n query = String(querystring.urlQueryToSearchParams(query as ParsedUrlQuery))\n }\n\n let search = urlObj.search || (query && `?${query}`) || ''\n\n if (protocol && !protocol.endsWith(':')) protocol += ':'\n\n if (\n urlObj.slashes ||\n ((!protocol || slashedProtocols.test(protocol)) && host !== false)\n ) {\n host = '//' + (host || '')\n if (pathname && pathname[0] !== '/') pathname = '/' + pathname\n } else if (!host) {\n host = ''\n }\n\n if (hash && hash[0] !== '#') hash = '#' + hash\n if (search && search[0] !== '?') search = '?' + search\n\n pathname = pathname.replace(/[?#]/g, encodeURIComponent)\n search = search.replace('#', '%23')\n\n return `${protocol}${host}${pathname}${search}${hash}`\n}\n\nexport const urlObjectKeys = [\n 'auth',\n 'hash',\n 'host',\n 'hostname',\n 'href',\n 'path',\n 'pathname',\n 'port',\n 'protocol',\n 'query',\n 'search',\n 'slashes',\n]\n\nexport function formatWithValidation(url: UrlObject): string {\n if (process.env.NODE_ENV === 'development') {\n if (url !== null && typeof url === 'object') {\n Object.keys(url).forEach((key) => {\n if (!urlObjectKeys.includes(key)) {\n console.warn(\n `Unknown key passed via urlObject into url.format: ${key}`\n )\n }\n })\n }\n }\n\n return formatUrl(url)\n}\n","import type { Rewrite } from '../lib/load-custom-routes'\nimport type { RouteMatchFn } from '../shared/lib/router/utils/route-matcher'\nimport type { NextConfig } from './config'\nimport type { BaseNextRequest } from './base-http'\nimport type { ParsedUrlQuery } from 'querystring'\nimport type { UrlWithParsedQuery } from 'url'\n\nimport { normalizeLocalePath } from '../shared/lib/i18n/normalize-locale-path'\nimport { getPathMatch } from '../shared/lib/router/utils/path-match'\nimport { getNamedRouteRegex } from '../shared/lib/router/utils/route-regex'\nimport { getRouteMatcher } from '../shared/lib/router/utils/route-matcher'\nimport {\n matchHas,\n prepareDestination,\n} from '../shared/lib/router/utils/prepare-destination'\nimport { removeTrailingSlash } from '../shared/lib/router/utils/remove-trailing-slash'\nimport { normalizeRscURL } from '../shared/lib/router/utils/app-paths'\nimport {\n NEXT_CACHE_REVALIDATE_TAG_TOKEN_HEADER,\n NEXT_CACHE_REVALIDATED_TAGS_HEADER,\n NEXT_INTERCEPTION_MARKER_PREFIX,\n NEXT_QUERY_PARAM_PREFIX,\n} from '../lib/constants'\nimport { normalizeNextQueryParam } from './web/utils'\nimport type { IncomingHttpHeaders, IncomingMessage } from 'http'\nimport { decodeQueryPathParameter } from './lib/decode-query-path-parameter'\nimport type { DeepReadonly } from '../shared/lib/deep-readonly'\nimport { parseReqUrl } from '../lib/url'\nimport { formatUrl } from '../shared/lib/router/utils/format-url'\n\nfunction filterInternalQuery(\n query: Record<string, undefined | string | string[]>,\n paramKeys: string[]\n) {\n // this is used to pass query information in rewrites\n // but should not be exposed in final query\n delete query['nextInternalLocale']\n\n for (const key in query) {\n const isNextQueryPrefix =\n key !== NEXT_QUERY_PARAM_PREFIX && key.startsWith(NEXT_QUERY_PARAM_PREFIX)\n\n const isNextInterceptionMarkerPrefix =\n key !== NEXT_INTERCEPTION_MARKER_PREFIX &&\n key.startsWith(NEXT_INTERCEPTION_MARKER_PREFIX)\n\n if (\n isNextQueryPrefix ||\n isNextInterceptionMarkerPrefix ||\n paramKeys.includes(key)\n ) {\n delete query[key]\n }\n }\n}\n\nexport function normalizeCdnUrl(\n req: BaseNextRequest | IncomingMessage,\n paramKeys: string[]\n) {\n // make sure to normalize req.url from CDNs to strip dynamic and rewrite\n // params from the query which are added during routing\n const _parsedUrl = parseReqUrl(req.url!)\n\n // we can't normalize if we can't parse\n if (!_parsedUrl) {\n return req.url\n }\n delete (_parsedUrl as any).search\n filterInternalQuery(_parsedUrl.query, paramKeys)\n\n req.url = formatUrl(_parsedUrl)\n}\n\nexport function interpolateDynamicPath(\n pathname: string,\n params: ParsedUrlQuery,\n defaultRouteRegex?: ReturnType<typeof getNamedRouteRegex> | undefined\n) {\n if (!defaultRouteRegex) return pathname\n\n for (const param of Object.keys(defaultRouteRegex.groups)) {\n const { optional, repeat } = defaultRouteRegex.groups[param]\n let builtParam = `[${repeat ? '...' : ''}${param}]`\n\n if (optional) {\n builtParam = `[${builtParam}]`\n }\n\n let paramValue: string\n const value = params[param]\n\n if (Array.isArray(value)) {\n paramValue = value.map((v) => v && encodeURIComponent(v)).join('/')\n } else if (value) {\n paramValue = encodeURIComponent(value)\n } else {\n paramValue = ''\n }\n\n if (paramValue || optional) {\n pathname = pathname.replaceAll(builtParam, paramValue)\n }\n }\n\n return pathname\n}\n\nexport function normalizeDynamicRouteParams(\n query: ParsedUrlQuery,\n defaultRouteRegex: ReturnType<typeof getNamedRouteRegex>,\n defaultRouteMatches: ParsedUrlQuery,\n ignoreMissingOptional: boolean\n) {\n let hasValidParams = true\n let params: ParsedUrlQuery = {}\n\n for (const key of Object.keys(defaultRouteRegex.groups)) {\n let value: string | string[] | undefined = query[key]\n\n if (typeof value === 'string') {\n value = normalizeRscURL(value)\n } else if (Array.isArray(value)) {\n value = value.map(normalizeRscURL)\n }\n\n // if the value matches the default value we can't rely\n // on the parsed params, this is used to signal if we need\n // to parse x-now-route-matches or not\n const defaultValue = defaultRouteMatches![key]\n const isOptional = defaultRouteRegex!.groups[key].optional\n\n const isDefaultValue = Array.isArray(defaultValue)\n ? defaultValue.some((defaultVal) => {\n return Array.isArray(value)\n ? value.some((val) => val.includes(defaultVal))\n : value?.includes(defaultVal)\n })\n : value?.includes(defaultValue as string)\n\n if (\n isDefaultValue ||\n (typeof value === 'undefined' && !(isOptional && ignoreMissingOptional))\n ) {\n return { params: {}, hasValidParams: false }\n }\n\n // non-provided optional values should be undefined so normalize\n // them to undefined\n if (\n isOptional &&\n (!value ||\n (Array.isArray(value) &&\n value.length === 1 &&\n // fallback optional catch-all SSG pages have\n // [[...paramName]] for the root path on Vercel\n (value[0] === 'index' || value[0] === `[[...${key}]]`)) ||\n value === 'index' ||\n value === `[[...${key}]]`)\n ) {\n value = undefined\n delete query[key]\n }\n\n // query values from the proxy aren't already split into arrays\n // so make sure to normalize catch-all values\n if (\n value &&\n typeof value === 'string' &&\n defaultRouteRegex!.groups[key].repeat\n ) {\n value = value.split('/')\n }\n\n if (value) {\n params[key] = value\n }\n }\n\n return {\n params,\n hasValidParams,\n }\n}\n\nexport function getServerUtils({\n page,\n i18n,\n basePath,\n rewrites,\n pageIsDynamic,\n trailingSlash,\n caseSensitive,\n}: {\n page: string\n i18n?: NextConfig['i18n']\n basePath: string\n rewrites: DeepReadonly<{\n fallback?: ReadonlyArray<Rewrite>\n afterFiles?: ReadonlyArray<Rewrite>\n beforeFiles?: ReadonlyArray<Rewrite>\n }>\n pageIsDynamic: boolean\n trailingSlash?: boolean\n caseSensitive: boolean\n}) {\n let defaultRouteRegex: ReturnType<typeof getNamedRouteRegex> | undefined\n let dynamicRouteMatcher: RouteMatchFn | undefined\n let defaultRouteMatches: ParsedUrlQuery | undefined\n\n if (pageIsDynamic) {\n defaultRouteRegex = getNamedRouteRegex(page, {\n prefixRouteKeys: false,\n })\n dynamicRouteMatcher = getRouteMatcher(defaultRouteRegex)\n defaultRouteMatches = dynamicRouteMatcher(page) as ParsedUrlQuery\n }\n\n function handleRewrites(\n req: BaseNextRequest | IncomingMessage,\n parsedUrl: DeepReadonly<UrlWithParsedQuery>\n ) {\n // Here we deep clone the parsedUrl to avoid mutating the original. We also\n // cast this to a mutable type so we can mutate it within this scope.\n const rewrittenParsedUrl = structuredClone(parsedUrl) as UrlWithParsedQuery\n const rewriteParams: Record<string, string> = {}\n let fsPathname = rewrittenParsedUrl.pathname\n\n const matchesPage = () => {\n const fsPathnameNoSlash = removeTrailingSlash(fsPathname || '')\n return (\n fsPathnameNoSlash === removeTrailingSlash(page) ||\n dynamicRouteMatcher?.(fsPathnameNoSlash)\n )\n }\n\n const checkRewrite = (rewrite: DeepReadonly<Rewrite>): boolean => {\n const matcher = getPathMatch(\n rewrite.source + (trailingSlash ? '(/)?' : ''),\n {\n removeUnnamedParams: true,\n strict: true,\n sensitive: !!caseSensitive,\n }\n )\n\n if (!rewrittenParsedUrl.pathname) return false\n\n let params = matcher(rewrittenParsedUrl.pathname)\n\n if ((rewrite.has || rewrite.missing) && params) {\n const hasParams = matchHas(\n req,\n rewrittenParsedUrl.query,\n rewrite.has as Rewrite['has'],\n rewrite.missing as Rewrite['missing']\n )\n\n if (hasParams) {\n Object.assign(params, hasParams)\n } else {\n params = false\n }\n }\n\n if (params) {\n const { parsedDestination, destQuery } = prepareDestination({\n appendParamsToQuery: true,\n destination: rewrite.destination,\n params: params,\n query: rewrittenParsedUrl.query,\n })\n\n // if the rewrite destination is external break rewrite chain\n if (parsedDestination.protocol) {\n return true\n }\n\n Object.assign(rewriteParams, destQuery, params)\n Object.assign(rewrittenParsedUrl.query, parsedDestination.query)\n delete (parsedDestination as any).query\n\n Object.assign(rewrittenParsedUrl, parsedDestination)\n\n fsPathname = rewrittenParsedUrl.pathname\n if (!fsPathname) return false\n\n if (basePath) {\n fsPathname = fsPathname.replace(new RegExp(`^${basePath}`), '') || '/'\n }\n\n if (i18n) {\n const result = normalizeLocalePath(fsPathname, i18n.locales)\n fsPathname = result.pathname\n rewrittenParsedUrl.query.nextInternalLocale =\n result.detectedLocale || params.nextInternalLocale\n }\n\n if (fsPathname === page) {\n return true\n }\n\n if (pageIsDynamic && dynamicRouteMatcher) {\n const dynamicParams = dynamicRouteMatcher(fsPathname)\n if (dynamicParams) {\n rewrittenParsedUrl.query = {\n ...rewrittenParsedUrl.query,\n ...dynamicParams,\n }\n return true\n }\n }\n }\n\n return false\n }\n\n for (const rewrite of rewrites.beforeFiles || []) {\n checkRewrite(rewrite)\n }\n\n if (fsPathname !== page) {\n let finished = false\n\n for (const rewrite of rewrites.afterFiles || []) {\n finished = checkRewrite(rewrite)\n if (finished) break\n }\n\n if (!finished && !matchesPage()) {\n for (const rewrite of rewrites.fallback || []) {\n finished = checkRewrite(rewrite)\n if (finished) break\n }\n }\n }\n\n return { rewriteParams, rewrittenParsedUrl }\n }\n\n function getParamsFromRouteMatches(routeMatchesHeader: string) {\n // If we don't have a default route regex, we can't get params from route\n // matches\n if (!defaultRouteRegex) return null\n\n const { groups, routeKeys } = defaultRouteRegex\n\n const matcher = getRouteMatcher({\n re: {\n // Simulate a RegExp match from the \\`req.url\\` input\n exec: (str: string) => {\n // Normalize all the prefixed query params.\n const obj: Record<string, string> = Object.fromEntries(\n new URLSearchParams(str)\n )\n for (const [key, value] of Object.entries(obj)) {\n const normalizedKey = normalizeNextQueryParam(key)\n if (!normalizedKey) continue\n\n obj[normalizedKey] = value\n delete obj[key]\n }\n\n // Use all the named route keys.\n const result = {} as RegExpExecArray\n for (const keyName of Object.keys(routeKeys)) {\n const paramName = routeKeys[keyName]\n\n // If this param name is not a valid parameter name, then skip it.\n if (!paramName) continue\n\n const group = groups[paramName]\n const value = obj[keyName]\n\n // When we're missing a required param, we can't match the route.\n if (!group.optional && !value) return null\n\n result[group.pos] = value\n }\n\n return result\n },\n },\n groups,\n })\n\n const routeMatches = matcher(routeMatchesHeader)\n if (!routeMatches) return null\n\n return routeMatches\n }\n\n function normalizeQueryParams(\n query: Record<string, string | string[] | undefined>,\n routeParamKeys: Set<string>\n ) {\n // this is used to pass query information in rewrites\n // but should not be exposed in final query\n delete query['nextInternalLocale']\n\n for (const [key, value] of Object.entries(query)) {\n const normalizedKey = normalizeNextQueryParam(key)\n if (!normalizedKey) continue\n\n // Remove the prefixed key from the query params because we want\n // to consume it for the dynamic route matcher.\n delete query[key]\n routeParamKeys.add(normalizedKey)\n\n if (typeof value === 'undefined') continue\n\n query[normalizedKey] = Array.isArray(value)\n ? value.map((v) => decodeQueryPathParameter(v))\n : decodeQueryPathParameter(value)\n }\n }\n\n return {\n handleRewrites,\n defaultRouteRegex,\n dynamicRouteMatcher,\n defaultRouteMatches,\n normalizeQueryParams,\n getParamsFromRouteMatches,\n /**\n * Normalize dynamic route params.\n *\n * @param query - The query params to normalize.\n * @param ignoreMissingOptional - Whether to ignore missing optional params.\n * @returns The normalized params and whether they are valid.\n */\n normalizeDynamicRouteParams: (\n query: ParsedUrlQuery,\n ignoreMissingOptional: boolean\n ) => {\n if (!defaultRouteRegex || !defaultRouteMatches) {\n return { params: {}, hasValidParams: false }\n }\n\n return normalizeDynamicRouteParams(\n query,\n defaultRouteRegex,\n defaultRouteMatches,\n ignoreMissingOptional\n )\n },\n\n normalizeCdnUrl: (\n req: BaseNextRequest | IncomingMessage,\n paramKeys: string[]\n ) => normalizeCdnUrl(req, paramKeys),\n\n interpolateDynamicPath: (\n pathname: string,\n params: Record<string, undefined | string | string[]>\n ) => interpolateDynamicPath(pathname, params, defaultRouteRegex),\n\n filterInternalQuery: (query: ParsedUrlQuery, paramKeys: string[]) =>\n filterInternalQuery(query, paramKeys),\n }\n}\n\nexport function getPreviouslyRevalidatedTags(\n headers: IncomingHttpHeaders,\n previewModeId: string | undefined\n): string[] {\n return typeof headers[NEXT_CACHE_REVALIDATED_TAGS_HEADER] === 'string' &&\n headers[NEXT_CACHE_REVALIDATE_TAG_TOKEN_HEADER] === previewModeId\n ? headers[NEXT_CACHE_REVALIDATED_TAGS_HEADER].split(',')\n : []\n}\n","import type { DomainLocale } from '../../../server/config-shared'\n\nexport function detectDomainLocale(\n domainItems?: readonly DomainLocale[],\n hostname?: string,\n detectedLocale?: string\n) {\n if (!domainItems) return\n\n if (detectedLocale) {\n detectedLocale = detectedLocale.toLowerCase()\n }\n\n for (const item of domainItems) {\n // remove port if present\n const domainHostname = item.domain?.split(':', 1)[0].toLowerCase()\n if (\n hostname === domainHostname ||\n detectedLocale === item.defaultLocale.toLowerCase() ||\n item.locales?.some((locale) => locale.toLowerCase() === detectedLocale)\n ) {\n return item\n }\n }\n}\n","import type { OutgoingHttpHeaders } from 'http'\n\n/**\n * Takes an object with a hostname property (like a parsed URL) and some\n * headers that may contain Host and returns the preferred hostname.\n * @param parsed An object containing a hostname property.\n * @param headers A dictionary with headers containing a `host`.\n */\nexport function getHostname(\n parsed: { hostname?: string | null },\n headers?: OutgoingHttpHeaders\n): string | undefined {\n // Get the hostname from the headers if it exists, otherwise use the parsed\n // hostname.\n let hostname: string\n if (headers?.host && !Array.isArray(headers.host)) {\n hostname = headers.host.toString().split(':', 1)[0]\n } else if (parsed.hostname) {\n hostname = parsed.hostname\n } else return\n\n return hostname.toLowerCase()\n}\n","import { pathHasPrefix } from '../router/utils/path-has-prefix'\n\n/**\n * strip _next/data/<build-id>/ prefix and .json suffix\n */\nexport function normalizeDataPath(pathname: string) {\n if (!pathHasPrefix(pathname || '/', '/_next/data')) {\n return pathname\n }\n pathname = pathname\n .replace(/\\/_next\\/data\\/[^/]{1,}/, '')\n .replace(/\\.json$/, '')\n\n if (pathname === '/index') {\n return '/'\n }\n return pathname\n}\n","import type { IncomingMessage } from 'http'\nimport type { ParsedUrlQuery } from 'querystring'\nimport type { UrlWithParsedQuery } from 'url'\nimport type { BaseNextRequest } from './base-http'\nimport type { CloneableBody } from './body-streams'\nimport type { RouteMatch } from './route-matches/route-match'\nimport type { NEXT_RSC_UNION_QUERY } from '../client/components/app-router-headers'\nimport type {\n ResponseCacheEntry,\n ServerComponentsHmrCache,\n} from './response-cache'\nimport type { PagesDevOverlayBridgeType } from '../next-devtools/userspace/pages/pages-dev-overlay-setup'\nimport type { OpaqueFallbackRouteParams } from './request/fallback-params'\nimport type { IncrementalCache } from './lib/incremental-cache'\n\n// FIXME: (wyattjoh) this is a temporary solution to allow us to pass data between bundled modules\nexport const NEXT_REQUEST_META = Symbol.for('NextInternalRequestMeta')\n\nexport type NextIncomingMessage = (BaseNextRequest | IncomingMessage) & {\n [NEXT_REQUEST_META]?: RequestMeta\n}\n\n/**\n * The callback function to call when a response cache entry was generated or\n * looked up in the cache. When it returns true, the server assumes that the\n * handler has already responded to the request and will not do so itself.\n */\nexport type OnCacheEntryHandler = (\n /**\n * The response cache entry that was generated or looked up in the cache.\n */\n cacheEntry: ResponseCacheEntry,\n\n /**\n * The request metadata.\n */\n requestMeta: {\n /**\n * The URL that was used to make the request.\n */\n url: string | undefined\n }\n) => Promise<boolean | void> | boolean | void\n\nexport interface RequestMeta {\n /**\n * The query that was used to make the request.\n */\n initQuery?: ParsedUrlQuery\n\n /**\n * The URL that was used to make the request.\n */\n initURL?: string\n\n /**\n * The protocol that was used to make the request.\n */\n initProtocol?: string\n\n /**\n * The body that was read from the request. This is used to allow the body to\n * be read multiple times.\n */\n clonableBody?: CloneableBody\n\n /**\n * True when the request matched a locale domain that was configured in the\n * next.config.js file.\n */\n isLocaleDomain?: boolean\n\n /**\n * True when the request had locale information stripped from the pathname\n * part of the URL.\n */\n didStripLocale?: boolean\n\n /**\n * If the request had it's URL rewritten, this is the URL it was rewritten to.\n */\n rewroteURL?: string\n\n /**\n * The cookies that were added by middleware and were added to the response.\n */\n middlewareCookie?: string[]\n\n /**\n * The match on the request for a given route.\n */\n match?: RouteMatch\n\n /**\n * The incremental cache to use for the request.\n */\n incrementalCache?: IncrementalCache\n\n /**\n * The server components HMR cache, only for dev.\n */\n serverComponentsHmrCache?: ServerComponentsHmrCache\n\n /**\n * Equals the segment path that was used for the prefetch RSC request.\n */\n segmentPrefetchRSCRequest?: string\n\n /**\n * True when the request is for the prefetch flight data.\n */\n isPrefetchRSCRequest?: true\n\n /**\n * True when the request is for the flight data.\n */\n isRSCRequest?: true\n\n /**\n * A search param set by the Next.js client when performing RSC requests.\n * Because some CDNs do not vary their cache entries on our custom headers,\n * this search param represents a hash of the header values. For any cached\n * RSC request, we should verify that the hash matches before responding.\n * Otherwise this can lead to cache poisoning.\n * TODO: Consider not using custom request headers at all, and instead encode\n * everything into the search param.\n */\n cacheBustingSearchParam?: string\n\n /**\n * True when the request is for the `/_next/data` route using the pages\n * router.\n */\n isNextDataReq?: true\n\n /**\n * Postponed state to use for resumption. If present it's assumed that the\n * request is for a page that has postponed (there are no guarantees that the\n * page actually has postponed though as it would incur an additional cache\n * lookup).\n */\n postponed?: string\n\n /**\n * If provided, this will be called when a response cache entry was generated\n * or looked up in the cache.\n *\n * @deprecated Use `onCacheEntryV2` instead.\n */\n onCacheEntry?: OnCacheEntryHandler\n\n /**\n * If provided, this will be called when a response cache entry was generated\n * or looked up in the cache.\n */\n onCacheEntryV2?: OnCacheEntryHandler\n\n /**\n * The previous revalidate before rendering 404 page for notFound: true\n */\n notFoundRevalidate?: number | false\n\n /**\n * In development, the original source page that returned a 404.\n */\n developmentNotFoundSourcePage?: string\n\n /**\n * The path we routed to and should be invoked\n */\n invokePath?: string\n\n /**\n * The specific page output we should be matching\n */\n invokeOutput?: string\n\n /**\n * The status we are invoking the request with from routing\n */\n invokeStatus?: number\n\n /**\n * The routing error we are invoking with\n */\n invokeError?: Error\n\n /**\n * The query parsed for the invocation\n */\n invokeQuery?: Record<string, undefined | string | string[]>\n\n /**\n * Whether the request is a middleware invocation\n */\n middlewareInvoke?: boolean\n\n /**\n * Whether the request should render the fallback shell or not.\n */\n renderFallbackShell?: boolean\n\n /**\n * Whether the request is for the custom error page.\n */\n customErrorRender?: true\n\n /**\n * Whether to bubble up the NoFallbackError to the caller when a 404 is\n * returned.\n */\n bubbleNoFallback?: true\n\n /**\n * True when the request had locale information inferred from the default\n * locale.\n */\n localeInferredFromDefault?: true\n\n /**\n * The locale that was inferred or explicitly set for the request.\n */\n locale?: string\n\n /**\n * The default locale that was inferred or explicitly set for the request.\n */\n defaultLocale?: string\n\n /**\n * The relative project dir the server is running in from project root\n */\n relativeProjectDir?: string\n\n /**\n * The dist directory the server is currently using\n */\n distDir?: string\n\n /**\n * The query after resolving routes\n */\n query?: ParsedUrlQuery\n\n /**\n * The params after resolving routes\n */\n params?: ParsedUrlQuery\n\n /**\n * ErrorOverlay component to use in development for pages router\n */\n PagesErrorDebug?: PagesDevOverlayBridgeType\n\n /**\n * Whether server is in minimal mode (this will be replaced with more\n * specific flags in future)\n */\n minimalMode?: boolean\n\n /**\n * DEV only: The fallback params that should be used when validating prerenders during dev\n */\n devValidatingFallbackParams?: OpaqueFallbackRouteParams\n\n /**\n * DEV only: Request timings in process.hrtime.bigint()\n */\n devRequestTimingStart?: bigint\n devRequestTimingMiddlewareStart?: bigint\n devRequestTimingMiddlewareEnd?: bigint\n devRequestTimingInternalsEnd?: bigint\n}\n\n/**\n * Gets the request metadata. If no key is provided, the entire metadata object\n * is returned.\n *\n * @param req the request to get the metadata from\n * @param key the key to get from the metadata (optional)\n * @returns the value for the key or the entire metadata object\n */\nexport function getRequestMeta(\n req: NextIncomingMessage,\n key?: undefined\n): RequestMeta\nexport function getRequestMeta<K extends keyof RequestMeta>(\n req: NextIncomingMessage,\n key: K\n): RequestMeta[K]\nexport function getRequestMeta<K extends keyof RequestMeta>(\n req: NextIncomingMessage,\n key?: K\n): RequestMeta | RequestMeta[K] {\n const meta = req[NEXT_REQUEST_META] || {}\n return typeof key === 'string' ? meta[key] : meta\n}\n\n/**\n * Sets the request metadata.\n *\n * @param req the request to set the metadata on\n * @param meta the metadata to set\n * @returns the mutated request metadata\n */\nexport function setRequestMeta(req: NextIncomingMessage, meta: RequestMeta) {\n req[NEXT_REQUEST_META] = meta\n return meta\n}\n\n/**\n * Adds a value to the request metadata.\n *\n * @param request the request to mutate\n * @param key the key to set\n * @param value the value to set\n * @returns the mutated request metadata\n */\nexport function addRequestMeta<K extends keyof RequestMeta>(\n request: NextIncomingMessage,\n key: K,\n value: RequestMeta[K]\n) {\n const meta = getRequestMeta(request)\n meta[key] = value\n return setRequestMeta(request, meta)\n}\n\n/**\n * Removes a key from the request metadata.\n *\n * @param request the request to mutate\n * @param key the key to remove\n * @returns the mutated request metadata\n */\nexport function removeRequestMeta<K extends keyof RequestMeta>(\n request: NextIncomingMessage,\n key: K\n) {\n const meta = getRequestMeta(request)\n delete meta[key]\n return setRequestMeta(request, meta)\n}\n\ntype NextQueryMetadata = {\n /**\n * The `_rsc` query parameter used for cache busting to ensure that the RSC\n * requests do not get cached by the browser explicitly.\n */\n [NEXT_RSC_UNION_QUERY]?: string\n}\n\nexport type NextParsedUrlQuery = ParsedUrlQuery & NextQueryMetadata\n\nexport interface NextUrlWithParsedQuery extends UrlWithParsedQuery {\n query: NextParsedUrlQuery\n}\n","import { ensureLeadingSlash } from './ensure-leading-slash'\nimport { isDynamicRoute } from '../router/utils'\nimport { NormalizeError } from '../utils'\n\n/**\n * Takes a page and transforms it into its file counterpart ensuring that the\n * output is normalized. Note this function is not idempotent because a page\n * `/index` can be referencing `/index/index.js` and `/index/index` could be\n * referencing `/index/index/index.js`. Examples:\n * - `/` -> `/index`\n * - `/index/foo` -> `/index/index/foo`\n * - `/index` -> `/index/index`\n */\nexport function normalizePagePath(page: string): string {\n const normalized =\n /^\\/index(\\/|$)/.test(page) && !isDynamicRoute(page)\n ? `/index${page}`\n : page === '/'\n ? '/index'\n : ensureLeadingSlash(page)\n\n if (process.env.NEXT_RUNTIME !== 'edge') {\n const { posix } = require('path') as typeof import('path')\n const resolvedPage = posix.normalize(normalized)\n if (resolvedPage !== normalized) {\n throw new NormalizeError(\n `Requested and resolved page mismatch: ${normalized} ${resolvedPage}`\n )\n }\n }\n\n return normalized\n}\n","import type { PageExtensions } from '../../build/page-extensions-type'\nimport { normalizePathSep } from '../../shared/lib/page-path/normalize-path-sep'\nimport { normalizeAppPath } from '../../shared/lib/router/utils/app-paths'\nimport { isAppRouteRoute } from '../is-app-route-route'\n\nexport const STATIC_METADATA_IMAGES = {\n icon: {\n filename: 'icon',\n extensions: ['ico', 'jpg', 'jpeg', 'png', 'svg'],\n },\n apple: {\n filename: 'apple-icon',\n extensions: ['jpg', 'jpeg', 'png'],\n },\n favicon: {\n filename: 'favicon',\n extensions: ['ico'],\n },\n openGraph: {\n filename: 'opengraph-image',\n extensions: ['jpg', 'jpeg', 'png', 'gif'],\n },\n twitter: {\n filename: 'twitter-image',\n extensions: ['jpg', 'jpeg', 'png', 'gif'],\n },\n} as const\n\n// Match routes that are metadata routes, e.g. /sitemap.xml, /favicon.<ext>, /<icon>.<ext>, etc.\n// TODO-METADATA: support more metadata routes with more extensions\nexport const DEFAULT_METADATA_ROUTE_EXTENSIONS = ['js', 'jsx', 'ts', 'tsx']\n\n// Match the file extension with the dynamic multi-routes extensions\n// e.g. ([xml, js], null) -> can match `/sitemap.xml/route`, `sitemap.js/route`\n// e.g. ([png], [ts]) -> can match `/opengraph-image.png`, `/opengraph-image.ts`\nexport const getExtensionRegexString = (\n staticExtensions: readonly string[],\n dynamicExtensions: readonly string[] | null\n) => {\n let result: string\n // If there's no possible multi dynamic routes, will not match any <name>[].<ext> files\n if (!dynamicExtensions || dynamicExtensions.length === 0) {\n result = `(\\\\.(?:${staticExtensions.join('|')}))`\n } else {\n result = `(?:\\\\.(${staticExtensions.join('|')})|(\\\\.(${dynamicExtensions.join('|')})))`\n }\n return result\n}\n\n/**\n * Matches the static metadata files, e.g. /robots.txt, /sitemap.xml, /favicon.ico, etc.\n * @param appDirRelativePath the relative file path to app/\n * @returns if the path is a static metadata file route\n */\nexport function isStaticMetadataFile(appDirRelativePath: string) {\n return isMetadataRouteFile(appDirRelativePath, [], true)\n}\n\n// Pre-compiled static regexes for common cases\nconst FAVICON_REGEX = /^[\\\\/]favicon\\.ico$/\nconst ROBOTS_TXT_REGEX = /^[\\\\/]robots\\.txt$/\nconst MANIFEST_JSON_REGEX = /^[\\\\/]manifest\\.json$/\nconst MANIFEST_WEBMANIFEST_REGEX = /^[\\\\/]manifest\\.webmanifest$/\nconst SITEMAP_XML_REGEX = /[\\\\/]sitemap\\.xml$/\n\n// Cache for compiled regex patterns based on parameters\nconst compiledRegexCache = new Map<string, RegExp[]>()\n\n// Fast path checks for common metadata files\nfunction fastPathCheck(normalizedPath: string): boolean | null {\n // Check favicon.ico first (most common)\n if (FAVICON_REGEX.test(normalizedPath)) return true\n\n // Check other common static files\n if (ROBOTS_TXT_REGEX.test(normalizedPath)) return true\n if (MANIFEST_JSON_REGEX.test(normalizedPath)) return true\n if (MANIFEST_WEBMANIFEST_REGEX.test(normalizedPath)) return true\n if (SITEMAP_XML_REGEX.test(normalizedPath)) return true\n\n // Quick negative check - if it doesn't contain any metadata keywords, skip\n if (\n !normalizedPath.includes('robots') &&\n !normalizedPath.includes('manifest') &&\n !normalizedPath.includes('sitemap') &&\n !normalizedPath.includes('icon') &&\n !normalizedPath.includes('apple-icon') &&\n !normalizedPath.includes('opengraph-image') &&\n !normalizedPath.includes('twitter-image') &&\n !normalizedPath.includes('favicon')\n ) {\n return false\n }\n\n return null // Continue with full regex matching\n}\n\nfunction getCompiledRegexes(\n pageExtensions: PageExtensions,\n strictlyMatchExtensions: boolean\n): RegExp[] {\n // Create cache key\n const cacheKey = `${pageExtensions.join(',')}|${strictlyMatchExtensions}`\n\n const cached = compiledRegexCache.get(cacheKey)\n if (cached) {\n return cached\n }\n\n // Pre-compute common strings\n const trailingMatcher = strictlyMatchExtensions ? '$' : '?$'\n const variantsMatcher = '\\\\d?'\n const groupSuffix = strictlyMatchExtensions ? '' : '(-\\\\w{6})?'\n const suffixMatcher = variantsMatcher + groupSuffix\n\n // Pre-compute extension arrays to avoid repeated concatenation\n const robotsExts =\n pageExtensions.length > 0 ? [...pageExtensions, 'txt'] : ['txt']\n const manifestExts =\n pageExtensions.length > 0\n ? [...pageExtensions, 'webmanifest', 'json']\n : ['webmanifest', 'json']\n\n const regexes = [\n new RegExp(\n `^[\\\\\\\\/]robots${getExtensionRegexString(robotsExts, null)}${trailingMatcher}`\n ),\n new RegExp(\n `^[\\\\\\\\/]manifest${getExtensionRegexString(manifestExts, null)}${trailingMatcher}`\n ),\n // FAVICON_REGEX removed - already handled in fastPathCheck\n new RegExp(\n `[\\\\\\\\/]sitemap${getExtensionRegexString(['xml'], pageExtensions)}${trailingMatcher}`\n ),\n new RegExp(\n `[\\\\\\\\/]icon${suffixMatcher}${getExtensionRegexString(\n STATIC_METADATA_IMAGES.icon.extensions,\n pageExtensions\n )}${trailingMatcher}`\n ),\n new RegExp(\n `[\\\\\\\\/]apple-icon${suffixMatcher}${getExtensionRegexString(\n STATIC_METADATA_IMAGES.apple.extensions,\n pageExtensions\n )}${trailingMatcher}`\n ),\n new RegExp(\n `[\\\\\\\\/]opengraph-image${suffixMatcher}${getExtensionRegexString(\n STATIC_METADATA_IMAGES.openGraph.extensions,\n pageExtensions\n )}${trailingMatcher}`\n ),\n new RegExp(\n `[\\\\\\\\/]twitter-image${suffixMatcher}${getExtensionRegexString(\n STATIC_METADATA_IMAGES.twitter.extensions,\n pageExtensions\n )}${trailingMatcher}`\n ),\n ]\n\n compiledRegexCache.set(cacheKey, regexes)\n return regexes\n}\n\n/**\n * Determine if the file is a metadata route file entry\n * @param appDirRelativePath the relative file path to app/\n * @param pageExtensions the js extensions, such as ['js', 'jsx', 'ts', 'tsx']\n * @param strictlyMatchExtensions if it's true, match the file with page extension, otherwise match the file with default corresponding extension\n * @returns if the file is a metadata route file\n */\nexport function isMetadataRouteFile(\n appDirRelativePath: string,\n pageExtensions: PageExtensions,\n strictlyMatchExtensions: boolean\n): boolean {\n // Early exit for empty or obviously non-metadata paths\n if (!appDirRelativePath || appDirRelativePath.length < 2) {\n return false\n }\n\n const normalizedPath = normalizePathSep(appDirRelativePath)\n\n // Fast path check for common cases\n const fastResult = fastPathCheck(normalizedPath)\n if (fastResult !== null) {\n return fastResult\n }\n\n // Get compiled regexes from cache\n const regexes = getCompiledRegexes(pageExtensions, strictlyMatchExtensions)\n\n // Use for loop instead of .some() for better performance\n for (let i = 0; i < regexes.length; i++) {\n if (regexes[i].test(normalizedPath)) {\n return true\n }\n }\n\n return false\n}\n\n// Check if the route is a static metadata route, with /route suffix\n// e.g. /favicon.ico/route, /icon.png/route, etc.\n// But skip the text routes like robots.txt since they might also be dynamic.\n// Checking route path is not enough to determine if text routes is dynamic.\nexport function isStaticMetadataRoute(route: string) {\n // extract ext with regex\n const pathname = route.replace(/\\/route$/, '')\n\n const matched =\n isAppRouteRoute(route) &&\n isMetadataRouteFile(pathname, [], true) &&\n // These routes can either be built by static or dynamic entrypoints,\n // so we assume they're dynamic\n pathname !== '/robots.txt' &&\n pathname !== '/manifest.webmanifest' &&\n !pathname.endsWith('/sitemap.xml')\n\n return matched\n}\n\n/**\n * Determine if a page or pathname is a metadata page.\n *\n * The input is a page or pathname, which can be with or without page suffix /foo/page or /foo.\n * But it will not contain the /route suffix.\n *\n * .e.g\n * /robots -> true\n * /sitemap -> true\n * /foo -> false\n */\nexport function isMetadataPage(page: string) {\n const matched = !isAppRouteRoute(page) && isMetadataRouteFile(page, [], false)\n\n return matched\n}\n\n/*\n * Determine if a Next.js route is a metadata route.\n * `route` will has a route suffix.\n *\n * e.g.\n * /app/robots/route -> true\n * /robots/route -> true\n * /sitemap/[__metadata_id__]/route -> true\n * /app/sitemap/page -> false\n * /icon-a102f4/route -> true\n */\nexport function isMetadataRoute(route: string): boolean {\n let page = normalizeAppPath(route)\n .replace(/^\\/?app\\//, '')\n // Remove the dynamic route id\n .replace('/[__metadata_id__]', '')\n // Remove the /route suffix\n .replace(/\\/route$/, '')\n\n if (page[0] !== '/') page = '/' + page\n\n const matched = isAppRouteRoute(route) && isMetadataRouteFile(page, [], false)\n\n return matched\n}\n","/**\n * A `Promise.withResolvers` implementation that exposes the `resolve` and\n * `reject` functions on a `Promise`.\n *\n * @see https://tc39.es/proposal-promise-with-resolvers/\n */\nexport class DetachedPromise<T = any> {\n public readonly resolve: (value: T | PromiseLike<T>) => void\n public readonly reject: (reason: any) => void\n public readonly promise: Promise<T>\n\n constructor() {\n let resolve: (value: T | PromiseLike<T>) => void\n let reject: (reason: any) => void\n\n // Create the promise and assign the resolvers to the object.\n this.promise = new Promise<T>((res, rej) => {\n resolve = res\n reject = rej\n })\n\n // We know that resolvers is defined because the Promise constructor runs\n // synchronously.\n this.resolve = resolve!\n this.reject = reject!\n }\n}\n","import type { SchedulerFn } from './scheduler'\n\nimport { DetachedPromise } from './detached-promise'\n\ntype CacheKeyFn<K, C extends string | number | null> = (\n key: K\n) => PromiseLike<C> | C\n\ntype BatcherOptions<K, C extends string | number | null> = {\n cacheKeyFn?: CacheKeyFn<K, C>\n schedulerFn?: SchedulerFn<void>\n}\n\ntype WorkFnContext<V, K> = {\n resolve: (value: V | PromiseLike<V>) => void\n key: K\n}\n\ntype WorkFn<V, K> = (context: WorkFnContext<V, K>) => Promise<V>\n\n/**\n * A wrapper for a function that will only allow one call to the function to\n * execute at a time.\n */\nexport class Batcher<K, V, C extends string | number | null> {\n private readonly pending = new Map<C, Promise<V>>()\n\n protected constructor(\n private readonly cacheKeyFn?: CacheKeyFn<K, C>,\n /**\n * A function that will be called to schedule the wrapped function to be\n * executed. This defaults to a function that will execute the function\n * immediately.\n */\n private readonly schedulerFn: SchedulerFn<void> = (fn) => fn()\n ) {}\n\n /**\n * Creates a new instance of PendingWrapper. If the key extends a string or\n * number, the key will be used as the cache key. If the key is an object, a\n * cache key function must be provided.\n */\n public static create<K extends string | number | null, V>(\n options?: BatcherOptions<K, K>\n ): Batcher<K, V, K>\n public static create<K, V, C extends string | number | null>(\n options: BatcherOptions<K, C> &\n Required<Pick<BatcherOptions<K, C>, 'cacheKeyFn'>>\n ): Batcher<K, V, C>\n public static create<K, V, C extends string | number | null>(\n options?: BatcherOptions<K, C>\n ): Batcher<K, V, C> {\n return new Batcher<K, V, C>(options?.cacheKeyFn, options?.schedulerFn)\n }\n\n /**\n * Wraps a function in a promise that will be resolved or rejected only once\n * for a given key. This will allow multiple calls to the function to be\n * made, but only one will be executed at a time. The result of the first\n * call will be returned to all callers.\n *\n * @param key the key to use for the cache\n * @param fn the function to wrap\n * @returns a promise that resolves to the result of the function\n */\n public async batch(key: K, fn: WorkFn<V, K>): Promise<V> {\n const cacheKey = (this.cacheKeyFn ? await this.cacheKeyFn(key) : key) as C\n if (cacheKey === null) {\n return fn({ resolve: (value) => Promise.resolve(value), key })\n }\n\n const pending = this.pending.get(cacheKey)\n if (pending) return pending\n\n const { promise, resolve, reject } = new DetachedPromise<V>()\n this.pending.set(cacheKey, promise)\n\n this.schedulerFn(async () => {\n try {\n const result = await fn({ resolve, key })\n\n // Resolving a promise multiple times is a no-op, so we can safely\n // resolve all pending promises with the same result.\n resolve(result)\n } catch (err) {\n reject(err)\n } finally {\n this.pending.delete(cacheKey)\n }\n })\n\n return promise\n }\n}\n","export type ScheduledFn<T = void> = () => T | PromiseLike<T>\nexport type SchedulerFn<T = void> = (cb: ScheduledFn<T>) => void\n\n/**\n * Schedules a function to be called on the next tick after the other promises\n * have been resolved.\n *\n * @param cb the function to schedule\n */\nexport const scheduleOnNextTick = (cb: ScheduledFn<void>) => {\n // We use Promise.resolve().then() here so that the operation is scheduled at\n // the end of the promise job queue, we then add it to the next process tick\n // to ensure it's evaluated afterwards.\n //\n // This was inspired by the implementation of the DataLoader interface: https://github.com/graphql/dataloader/blob/d336bd15282664e0be4b4a657cb796f09bafbc6b/src/index.js#L213-L255\n //\n Promise.resolve().then(() => {\n if (process.env.NEXT_RUNTIME === 'edge') {\n setTimeout(cb, 0)\n } else {\n process.nextTick(cb)\n }\n })\n}\n\n/**\n * Schedules a function to be called using `setImmediate` or `setTimeout` if\n * `setImmediate` is not available (like in the Edge runtime).\n *\n * @param cb the function to schedule\n */\nexport const scheduleImmediate = (cb: ScheduledFn<void>): void => {\n if (process.env.NEXT_RUNTIME === 'edge') {\n setTimeout(cb, 0)\n } else {\n setImmediate(cb)\n }\n}\n\n/**\n * returns a promise than resolves in a future task. There is no guarantee that the task it resolves in\n * will be the next task but if you await it you can at least be sure that the current task is over and\n * most usefully that the entire microtask queue of the current task has been emptied.\n */\nexport function atLeastOneTask() {\n return new Promise<void>((resolve) => scheduleImmediate(resolve))\n}\n\n/**\n * This utility function is extracted to make it easier to find places where we are doing\n * specific timing tricks to try to schedule work after React has rendered. This is especially\n * important at the moment because Next.js uses the edge builds of React which use setTimeout to\n * schedule work when you might expect that something like setImmediate would do the trick.\n *\n * Long term we should switch to the node versions of React rendering when possible and then\n * update this to use setImmediate rather than setTimeout\n */\nexport function waitAtLeastOneReactRenderTask(): Promise<void> {\n if (process.env.NEXT_RUNTIME === 'edge') {\n return new Promise((r) => setTimeout(r, 0))\n } else {\n return new Promise((r) => setImmediate(r))\n }\n}\n","import type { OutgoingHttpHeaders } from 'http'\nimport type RenderResult from '../render-result'\nimport type { CacheControl, Revalidate } from '../lib/cache-control'\nimport type { RouteKind } from '../route-kind'\n\nexport interface ResponseCacheBase {\n get(\n key: string | null,\n responseGenerator: ResponseGenerator,\n context: {\n isOnDemandRevalidate?: boolean\n isPrefetch?: boolean\n incrementalCache: IncrementalCache\n /**\n * This is a hint to the cache to help it determine what kind of route\n * this is so it knows where to look up the cache entry from. If not\n * provided it will test the filesystem to check.\n */\n routeKind: RouteKind\n\n /**\n * True if this is a fallback request.\n */\n isFallback?: boolean\n\n /**\n * True if the route is enabled for PPR.\n */\n isRoutePPREnabled?: boolean\n }\n ): Promise<ResponseCacheEntry | null>\n}\n\n// The server components HMR cache might store other data as well in the future,\n// at which point this should be refactored to a discriminated union type.\nexport interface ServerComponentsHmrCache {\n get(key: string): CachedFetchData | undefined\n set(key: string, data: CachedFetchData): void\n}\n\nexport type CachedFetchData = {\n headers: Record<string, string>\n body: string\n url: string\n status?: number\n}\n\nexport const enum CachedRouteKind {\n APP_PAGE = 'APP_PAGE',\n APP_ROUTE = 'APP_ROUTE',\n PAGES = 'PAGES',\n FETCH = 'FETCH',\n REDIRECT = 'REDIRECT',\n IMAGE = 'IMAGE',\n}\n\nexport interface CachedFetchValue {\n kind: CachedRouteKind.FETCH\n data: CachedFetchData\n // tags are only present with file-system-cache\n // fetch cache stores tags outside of cache entry\n tags?: string[]\n revalidate: number\n}\n\nexport interface CachedRedirectValue {\n kind: CachedRouteKind.REDIRECT\n props: Object\n}\n\nexport interface CachedAppPageValue {\n kind: CachedRouteKind.APP_PAGE\n // this needs to be a RenderResult so since renderResponse\n // expects that type instead of a string\n html: RenderResult\n rscData: Buffer | undefined\n status: number | undefined\n postponed: string | undefined\n headers: OutgoingHttpHeaders | undefined\n segmentData: Map<string, Buffer> | undefined\n}\n\nexport interface CachedPageValue {\n kind: CachedRouteKind.PAGES\n // this needs to be a RenderResult so since renderResponse\n // expects that type instead of a string\n html: RenderResult\n pageData: Object\n status: number | undefined\n headers: OutgoingHttpHeaders | undefined\n}\n\nexport interface CachedRouteValue {\n kind: CachedRouteKind.APP_ROUTE\n // this needs to be a RenderResult so since renderResponse\n // expects that type instead of a string\n body: Buffer\n status: number\n headers: OutgoingHttpHeaders\n}\n\nexport interface CachedImageValue {\n kind: CachedRouteKind.IMAGE\n etag: string\n upstreamEtag: string\n buffer: Buffer\n extension: string\n isMiss?: boolean\n isStale?: boolean\n}\n\nexport interface IncrementalCachedAppPageValue {\n kind: CachedRouteKind.APP_PAGE\n // this needs to be a string since the cache expects to store\n // the string value\n html: string\n rscData: Buffer | undefined\n headers: OutgoingHttpHeaders | undefined\n postponed: string | undefined\n status: number | undefined\n segmentData: Map<string, Buffer> | undefined\n}\n\nexport interface IncrementalCachedPageValue {\n kind: CachedRouteKind.PAGES\n // this needs to be a string since the cache expects to store\n // the string value\n html: string\n pageData: Object\n headers: OutgoingHttpHeaders | undefined\n status: number | undefined\n}\n\nexport interface IncrementalResponseCacheEntry {\n cacheControl?: CacheControl\n /**\n * timestamp in milliseconds to revalidate after\n */\n revalidateAfter?: Revalidate\n /**\n * `-1` here dictates a blocking revalidate should be used\n */\n isStale?: boolean | -1\n isMiss?: boolean\n value: Exclude<IncrementalCacheValue, CachedFetchValue> | null\n}\n\nexport interface IncrementalFetchCacheEntry {\n /**\n * `-1` here dictates a blocking revalidate should be used\n */\n isStale?: boolean | -1\n value: CachedFetchValue\n}\n\nexport type IncrementalCacheEntry =\n | IncrementalResponseCacheEntry\n | IncrementalFetchCacheEntry\n\nexport type IncrementalCacheValue =\n | CachedRedirectValue\n | IncrementalCachedPageValue\n | IncrementalCachedAppPageValue\n | CachedImageValue\n | CachedFetchValue\n | CachedRouteValue\n\nexport type ResponseCacheValue =\n | CachedRedirectValue\n | CachedPageValue\n | CachedAppPageValue\n | CachedImageValue\n | CachedRouteValue\n\nexport type ResponseCacheEntry = {\n cacheControl?: CacheControl\n value: ResponseCacheValue | null\n isStale?: boolean | -1\n isMiss?: boolean\n}\n\n/**\n * @param hasResolved whether the responseGenerator has resolved it's promise\n * @param previousCacheEntry the previous cache entry if it exists or the current\n */\nexport type ResponseGenerator = (state: {\n hasResolved: boolean\n previousCacheEntry?: IncrementalResponseCacheEntry | null\n isRevalidating?: boolean\n span?: any\n\n /**\n * When true, this indicates that the response generator is being called in a\n * context where the response must be generated statically.\n *\n * CRITICAL: This should only currently be used when revalidating due to a\n * dynamic RSC request.\n */\n forceStaticRender?: boolean\n}) => Promise<ResponseCacheEntry | null>\n\nexport const enum IncrementalCacheKind {\n APP_PAGE = 'APP_PAGE',\n APP_ROUTE = 'APP_ROUTE',\n PAGES = 'PAGES',\n FETCH = 'FETCH',\n IMAGE = 'IMAGE',\n}\n\nexport interface GetIncrementalFetchCacheContext {\n kind: IncrementalCacheKind.FETCH\n revalidate?: Revalidate\n fetchUrl?: string\n fetchIdx?: number\n tags?: string[]\n softTags?: string[]\n}\n\nexport interface GetIncrementalResponseCacheContext {\n kind: Exclude<IncrementalCacheKind, IncrementalCacheKind.FETCH>\n\n /**\n * True if the route is enabled for PPR.\n */\n isRoutePPREnabled?: boolean\n\n /**\n * True if this is a fallback request.\n */\n isFallback: boolean\n}\n\nexport interface SetIncrementalFetchCacheContext {\n fetchCache: true\n fetchUrl?: string\n fetchIdx?: number\n tags?: string[]\n isImplicitBuildTimeCache?: boolean\n}\n\nexport interface SetIncrementalResponseCacheContext {\n fetchCache?: false\n cacheControl?: CacheControl\n\n /**\n * True if the route is enabled for PPR.\n */\n isRoutePPREnabled?: boolean\n\n /**\n * True if this is a fallback request.\n */\n isFallback?: boolean\n}\n\nexport interface IncrementalResponseCache {\n get(\n cacheKey: string,\n ctx: GetIncrementalResponseCacheContext\n ): Promise<IncrementalResponseCacheEntry | null>\n set(\n key: string,\n data: Exclude<IncrementalCacheValue, CachedFetchValue> | null,\n ctx: SetIncrementalResponseCacheContext\n ): Promise<void>\n}\n\nexport interface IncrementalCache extends IncrementalResponseCache {\n get(\n cacheKey: string,\n ctx: GetIncrementalFetchCacheContext\n ): Promise<IncrementalFetchCacheEntry | null>\n get(\n cacheKey: string,\n ctx: GetIncrementalResponseCacheContext\n ): Promise<IncrementalResponseCacheEntry | null>\n set(\n key: string,\n data: CachedFetchValue | null,\n ctx: SetIncrementalFetchCacheContext\n ): Promise<void>\n set(\n key: string,\n data: Exclude<IncrementalCacheValue, CachedFetchValue> | null,\n ctx: SetIncrementalResponseCacheContext\n ): Promise<void>\n revalidateTag(\n tags: string | string[],\n durations?: { expire?: number }\n ): Promise<void>\n}\n","import type { ReactDOMServerReadableStream } from 'react-dom/server'\nimport { getTracer } from '../lib/trace/tracer'\nimport { AppRenderSpan } from '../lib/trace/constants'\nimport { DetachedPromise } from '../../lib/detached-promise'\nimport { scheduleImmediate, atLeastOneTask } from '../../lib/scheduler'\nimport { ENCODED_TAGS } from './encoded-tags'\nimport {\n indexOfUint8Array,\n isEquivalentUint8Arrays,\n removeFromUint8Array,\n} from './uint8array-helpers'\nimport { MISSING_ROOT_TAGS_ERROR } from '../../shared/lib/errors/constants'\nimport { insertBuildIdComment } from '../../shared/lib/segment-cache/output-export-prefetch-encoding'\nimport {\n RSC_HEADER,\n NEXT_ROUTER_PREFETCH_HEADER,\n NEXT_ROUTER_SEGMENT_PREFETCH_HEADER,\n NEXT_RSC_UNION_QUERY,\n} from '../../client/components/app-router-headers'\nimport { computeCacheBustingSearchParam } from '../../shared/lib/router/utils/cache-busting-search-param'\n\nfunction voidCatch() {\n // this catcher is designed to be used with pipeTo where we expect the underlying\n // pipe implementation to forward errors but we don't want the pipeTo promise to reject\n // and be unhandled\n}\n\n// We can share the same encoder instance everywhere\n// Notably we cannot do the same for TextDecoder because it is stateful\n// when handling streaming data\nconst encoder = new TextEncoder()\n\nexport function chainStreams<T>(\n ...streams: ReadableStream<T>[]\n): ReadableStream<T> {\n // If we have no streams, return an empty stream. This behavior is\n // intentional as we're now providing the `RenderResult.EMPTY` value.\n if (streams.length === 0) {\n return new ReadableStream<T>({\n start(controller) {\n controller.close()\n },\n })\n }\n\n // If we only have 1 stream we fast path it by returning just this stream\n if (streams.length === 1) {\n return streams[0]\n }\n\n const { readable, writable } = new TransformStream()\n\n // We always initiate pipeTo immediately. We know we have at least 2 streams\n // so we need to avoid closing the writable when this one finishes.\n let promise = streams[0].pipeTo(writable, { preventClose: true })\n\n let i = 1\n for (; i < streams.length - 1; i++) {\n const nextStream = streams[i]\n promise = promise.then(() =>\n nextStream.pipeTo(writable, { preventClose: true })\n )\n }\n\n // We can omit the length check because we halted before the last stream and there\n // is at least two streams so the lastStream here will always be defined\n const lastStream = streams[i]\n promise = promise.then(() => lastStream.pipeTo(writable))\n\n // Catch any errors from the streams and ignore them, they will be handled\n // by whatever is consuming the readable stream.\n promise.catch(voidCatch)\n\n return readable\n}\n\nexport function streamFromString(str: string): ReadableStream<Uint8Array> {\n return new ReadableStream({\n start(controller) {\n controller.enqueue(encoder.encode(str))\n controller.close()\n },\n })\n}\n\nexport function streamFromBuffer(chunk: Buffer): ReadableStream<Uint8Array> {\n return new ReadableStream({\n start(controller) {\n controller.enqueue(chunk)\n controller.close()\n },\n })\n}\n\nexport async function streamToBuffer(\n stream: ReadableStream<Uint8Array>\n): Promise<Buffer> {\n const reader = stream.getReader()\n const chunks: Uint8Array[] = []\n\n while (true) {\n const { done, value } = await reader.read()\n if (done) {\n break\n }\n\n chunks.push(value)\n }\n\n return Buffer.concat(chunks)\n}\n\nexport async function streamToString(\n stream: ReadableStream<Uint8Array>,\n signal?: AbortSignal\n): Promise<string> {\n const decoder = new TextDecoder('utf-8', { fatal: true })\n let string = ''\n\n for await (const chunk of stream) {\n if (signal?.aborted) {\n return string\n }\n\n string += decoder.decode(chunk, { stream: true })\n }\n\n string += decoder.decode()\n\n return string\n}\n\nexport type BufferedTransformOptions = {\n /**\n * Flush synchronously once the buffer reaches this many bytes.\n */\n readonly maxBufferByteLength?: number\n}\n\nexport function createBufferedTransformStream(\n options: BufferedTransformOptions = {}\n): TransformStream<Uint8Array, Uint8Array> {\n const { maxBufferByteLength = Infinity } = options\n\n let bufferedChunks: Array<Uint8Array> = []\n let bufferByteLength: number = 0\n let pending: DetachedPromise<void> | undefined\n\n const flush = (controller: TransformStreamDefaultController) => {\n try {\n if (bufferedChunks.length === 0) {\n return\n }\n\n const chunk = new Uint8Array(bufferByteLength)\n let copiedBytes = 0\n\n for (let i = 0; i < bufferedChunks.length; i++) {\n const bufferedChunk = bufferedChunks[i]\n chunk.set(bufferedChunk, copiedBytes)\n copiedBytes += bufferedChunk.byteLength\n }\n // We just wrote all the buffered chunks so we need to reset the bufferedChunks array\n // and our bufferByteLength to prepare for the next round of buffered chunks\n bufferedChunks.length = 0\n bufferByteLength = 0\n controller.enqueue(chunk)\n } catch {\n // If an error occurs while enqueuing, it can't be due to this\n // transformer. It's most likely caused by the controller having been\n // errored (for example, if the stream was cancelled).\n }\n }\n\n const scheduleFlush = (controller: TransformStreamDefaultController) => {\n if (pending) {\n return\n }\n\n const detached = new DetachedPromise<void>()\n pending = detached\n\n scheduleImmediate(() => {\n try {\n flush(controller)\n } finally {\n pending = undefined\n detached.resolve()\n }\n })\n }\n\n return new TransformStream({\n transform(chunk, controller) {\n // Combine the previous buffer with the new chunk.\n bufferedChunks.push(chunk)\n bufferByteLength += chunk.byteLength\n\n if (bufferByteLength >= maxBufferByteLength) {\n flush(controller)\n } else {\n scheduleFlush(controller)\n }\n },\n flush() {\n return pending?.promise\n },\n })\n}\n\nfunction createPrefetchCommentStream(\n isBuildTimePrerendering: boolean,\n buildId: string\n): TransformStream<Uint8Array, Uint8Array> {\n // Insert an extra comment at the beginning of the HTML document. This must\n // come after the DOCTYPE, which is inserted by React.\n //\n // The first chunk sent by React will contain the doctype. After that, we can\n // pass through the rest of the chunks as-is.\n let didTransformFirstChunk = false\n return new TransformStream({\n transform(chunk, controller) {\n if (isBuildTimePrerendering && !didTransformFirstChunk) {\n didTransformFirstChunk = true\n const decoder = new TextDecoder('utf-8', { fatal: true })\n const chunkStr = decoder.decode(chunk, {\n stream: true,\n })\n const updatedChunkStr = insertBuildIdComment(chunkStr, buildId)\n controller.enqueue(encoder.encode(updatedChunkStr))\n return\n }\n controller.enqueue(chunk)\n },\n })\n}\n\nexport function renderToInitialFizzStream({\n ReactDOMServer,\n element,\n streamOptions,\n}: {\n ReactDOMServer: {\n renderToReadableStream: typeof import('react-dom/server').renderToReadableStream\n }\n element: React.ReactElement\n streamOptions?: Parameters<typeof ReactDOMServer.renderToReadableStream>[1]\n}): Promise<ReactDOMServerReadableStream> {\n return getTracer().trace(AppRenderSpan.renderToReadableStream, async () =>\n ReactDOMServer.renderToReadableStream(element, streamOptions)\n )\n}\n\nfunction createMetadataTransformStream(\n insert: () => Promise<string> | string\n): TransformStream<Uint8Array, Uint8Array> {\n let chunkIndex = -1\n let isMarkRemoved = false\n\n return new TransformStream({\n async transform(chunk, controller) {\n let iconMarkIndex = -1\n let closedHeadIndex = -1\n chunkIndex++\n\n if (isMarkRemoved) {\n controller.enqueue(chunk)\n return\n }\n let iconMarkLength = 0\n // Only search for the closed head tag once\n if (iconMarkIndex === -1) {\n iconMarkIndex = indexOfUint8Array(chunk, ENCODED_TAGS.META.ICON_MARK)\n if (iconMarkIndex === -1) {\n controller.enqueue(chunk)\n return\n } else {\n // When we found the `<meta name=\"«nxt-icon»\"` tag prefix, we will remove it from the chunk.\n // Its close tag could either be `/>` or `>`, checking the next char to ensure we cover both cases.\n iconMarkLength = ENCODED_TAGS.META.ICON_MARK.length\n // Check if next char is /, this is for xml mode.\n if (chunk[iconMarkIndex + iconMarkLength] === 47) {\n iconMarkLength += 2\n } else {\n // The last char is `>`\n iconMarkLength++\n }\n }\n }\n\n // Check if icon mark is inside <head> tag in the first chunk.\n if (chunkIndex === 0) {\n closedHeadIndex = indexOfUint8Array(chunk, ENCODED_TAGS.CLOSED.HEAD)\n if (iconMarkIndex !== -1) {\n // The mark icon is located in the 1st chunk before the head tag.\n // We do not need to insert the script tag in this case because it's in the head.\n // Just remove the icon mark from the chunk.\n if (iconMarkIndex < closedHeadIndex) {\n const replaced = new Uint8Array(chunk.length - iconMarkLength)\n\n // Remove the icon mark from the chunk.\n replaced.set(chunk.subarray(0, iconMarkIndex))\n replaced.set(\n chunk.subarray(iconMarkIndex + iconMarkLength),\n iconMarkIndex\n )\n chunk = replaced\n } else {\n // The icon mark is after the head tag, replace and insert the script tag at that position.\n const insertion = await insert()\n const encodedInsertion = encoder.encode(insertion)\n const insertionLength = encodedInsertion.length\n const replaced = new Uint8Array(\n chunk.length - iconMarkLength + insertionLength\n )\n replaced.set(chunk.subarray(0, iconMarkIndex))\n replaced.set(encodedInsertion, iconMarkIndex)\n replaced.set(\n chunk.subarray(iconMarkIndex + iconMarkLength),\n iconMarkIndex + insertionLength\n )\n chunk = replaced\n }\n isMarkRemoved = true\n }\n // If there's no icon mark located, it will be handled later when if present in the following chunks.\n } else {\n // When it's appeared in the following chunks, we'll need to\n // remove the mark and then insert the script tag at that position.\n const insertion = await insert()\n const encodedInsertion = encoder.encode(insertion)\n const insertionLength = encodedInsertion.length\n // Replace the icon mark with the hoist script or empty string.\n const replaced = new Uint8Array(\n chunk.length - iconMarkLength + insertionLength\n )\n // Set the first part of the chunk, before the icon mark.\n replaced.set(chunk.subarray(0, iconMarkIndex))\n // Set the insertion after the icon mark.\n replaced.set(encodedInsertion, iconMarkIndex)\n\n // Set the rest of the chunk after the icon mark.\n replaced.set(\n chunk.subarray(iconMarkIndex + iconMarkLength),\n iconMarkIndex + insertionLength\n )\n chunk = replaced\n isMarkRemoved = true\n }\n controller.enqueue(chunk)\n },\n })\n}\n\nfunction createHeadInsertionTransformStream(\n insert: () => Promise<string>\n): TransformStream<Uint8Array, Uint8Array> {\n let inserted = false\n\n // We need to track if this transform saw any bytes because if it didn't\n // we won't want to insert any server HTML at all\n let hasBytes = false\n\n return new TransformStream({\n async transform(chunk, controller) {\n hasBytes = true\n\n const insertion = await insert()\n if (inserted) {\n if (insertion) {\n const encodedInsertion = encoder.encode(insertion)\n controller.enqueue(encodedInsertion)\n }\n controller.enqueue(chunk)\n } else {\n // TODO (@Ethan-Arrowood): Replace the generic `indexOfUint8Array` method with something finely tuned for the subset of things actually being checked for.\n const index = indexOfUint8Array(chunk, ENCODED_TAGS.CLOSED.HEAD)\n // In fully static rendering or non PPR rendering cases:\n // `/head>` will always be found in the chunk in first chunk rendering.\n if (index !== -1) {\n if (insertion) {\n const encodedInsertion = encoder.encode(insertion)\n // Get the total count of the bytes in the chunk and the insertion\n // e.g.\n // chunk = <head><meta charset=\"utf-8\"></head>\n // insertion = <script>...</script>\n // output = <head><meta charset=\"utf-8\"> [ <script>...</script> ] </head>\n const insertedHeadContent = new Uint8Array(\n chunk.length + encodedInsertion.length\n )\n // Append the first part of the chunk, before the head tag\n insertedHeadContent.set(chunk.slice(0, index))\n // Append the server inserted content\n insertedHeadContent.set(encodedInsertion, index)\n // Append the rest of the chunk\n insertedHeadContent.set(\n chunk.slice(index),\n index + encodedInsertion.length\n )\n controller.enqueue(insertedHeadContent)\n } else {\n controller.enqueue(chunk)\n }\n inserted = true\n } else {\n // This will happens in PPR rendering during next start, when the page is partially rendered.\n // When the page resumes, the head tag will be found in the middle of the chunk.\n // Where we just need to append the insertion and chunk to the current stream.\n // e.g.\n // PPR-static: <head>...</head><body> [ resume content ] </body>\n // PPR-resume: [ insertion ] [ rest content ]\n if (insertion) {\n controller.enqueue(encoder.encode(insertion))\n }\n controller.enqueue(chunk)\n inserted = true\n }\n }\n },\n async flush(controller) {\n // Check before closing if there's anything remaining to insert.\n if (hasBytes) {\n const insertion = await insert()\n if (insertion) {\n controller.enqueue(encoder.encode(insertion))\n }\n }\n },\n })\n}\n\nfunction createClientResumeScriptInsertionTransformStream(): TransformStream<\n Uint8Array,\n Uint8Array\n> {\n const segmentPath = '/_full'\n const cacheBustingHeader = computeCacheBustingSearchParam(\n '1', // headers[NEXT_ROUTER_PREFETCH_HEADER]\n '/_full', // headers[NEXT_ROUTER_SEGMENT_PREFETCH_HEADER]\n undefined, // headers[NEXT_ROUTER_STATE_TREE_HEADER]\n undefined // headers[NEXT_URL]\n )\n const searchStr = `${NEXT_RSC_UNION_QUERY}=${cacheBustingHeader}`\n const NEXT_CLIENT_RESUME_SCRIPT = `<script>__NEXT_CLIENT_RESUME=fetch(location.pathname+'?${searchStr}',{credentials:'same-origin',headers:{'${RSC_HEADER}': '1','${NEXT_ROUTER_PREFETCH_HEADER}': '1','${NEXT_ROUTER_SEGMENT_PREFETCH_HEADER}': '${segmentPath}'}})</script>`\n\n let didAlreadyInsert = false\n return new TransformStream({\n transform(chunk, controller) {\n if (didAlreadyInsert) {\n // Already inserted the script into the head. Pass through.\n controller.enqueue(chunk)\n return\n }\n // TODO (@Ethan-Arrowood): Replace the generic `indexOfUint8Array` method with something finely tuned for the subset of things actually being checked for.\n const headClosingTagIndex = indexOfUint8Array(\n chunk,\n ENCODED_TAGS.CLOSED.HEAD\n )\n\n if (headClosingTagIndex === -1) {\n // In fully static rendering or non PPR rendering cases:\n // `/head>` will always be found in the chunk in first chunk rendering.\n controller.enqueue(chunk)\n return\n }\n\n const encodedInsertion = encoder.encode(NEXT_CLIENT_RESUME_SCRIPT)\n // Get the total count of the bytes in the chunk and the insertion\n // e.g.\n // chunk = <head><meta charset=\"utf-8\"></head>\n // insertion = <script>...</script>\n // output = <head><meta charset=\"utf-8\"> [ <script>...</script> ] </head>\n const insertedHeadContent = new Uint8Array(\n chunk.length + encodedInsertion.length\n )\n // Append the first part of the chunk, before the head tag\n insertedHeadContent.set(chunk.slice(0, headClosingTagIndex))\n // Append the server inserted content\n insertedHeadContent.set(encodedInsertion, headClosingTagIndex)\n // Append the rest of the chunk\n insertedHeadContent.set(\n chunk.slice(headClosingTagIndex),\n headClosingTagIndex + encodedInsertion.length\n )\n\n controller.enqueue(insertedHeadContent)\n didAlreadyInsert = true\n },\n })\n}\n\n// Suffix after main body content - scripts before </body>,\n// but wait for the major chunks to be enqueued.\nfunction createDeferredSuffixStream(\n suffix: string\n): TransformStream<Uint8Array, Uint8Array> {\n let flushed = false\n let pending: DetachedPromise<void> | undefined\n\n const flush = (controller: TransformStreamDefaultController) => {\n const detached = new DetachedPromise<void>()\n pending = detached\n\n scheduleImmediate(() => {\n try {\n controller.enqueue(encoder.encode(suffix))\n } catch {\n // If an error occurs while enqueuing it can't be due to this\n // transformers fault. It's likely due to the controller being\n // errored due to the stream being cancelled.\n } finally {\n pending = undefined\n detached.resolve()\n }\n })\n }\n\n return new TransformStream({\n transform(chunk, controller) {\n controller.enqueue(chunk)\n\n // If we've already flushed, we're done.\n if (flushed) return\n\n // Schedule the flush to happen.\n flushed = true\n flush(controller)\n },\n flush(controller) {\n if (pending) return pending.promise\n if (flushed) return\n\n // Flush now.\n controller.enqueue(encoder.encode(suffix))\n },\n })\n}\n\nfunction createFlightDataInjectionTransformStream(\n stream: ReadableStream<Uint8Array>,\n delayDataUntilFirstHtmlChunk: boolean\n): TransformStream<Uint8Array, Uint8Array> {\n let htmlStreamFinished = false\n\n let pull: Promise<void> | null = null\n let donePulling = false\n\n function startOrContinuePulling(\n controller: TransformStreamDefaultController\n ) {\n if (!pull) {\n pull = startPulling(controller)\n }\n return pull\n }\n\n async function startPulling(controller: TransformStreamDefaultController) {\n const reader = stream.getReader()\n\n if (delayDataUntilFirstHtmlChunk) {\n // NOTE: streaming flush\n // We are buffering here for the inlined data stream because the\n // \"shell\" stream might be chunkenized again by the underlying stream\n // implementation, e.g. with a specific high-water mark. To ensure it's\n // the safe timing to pipe the data stream, this extra tick is\n // necessary.\n\n // We don't start reading until we've left the current Task to ensure\n // that it's inserted after flushing the shell. Note that this implementation\n // might get stale if impl details of Fizz change in the future.\n await atLeastOneTask()\n }\n\n try {\n while (true) {\n const { done, value } = await reader.read()\n if (done) {\n donePulling = true\n return\n }\n\n // We want to prioritize HTML over RSC data.\n // The SSR render is based on the same RSC stream, so when we get a new RSC chunk,\n // we're likely to produce an HTML chunk as well, so give it a chance to flush first.\n if (!delayDataUntilFirstHtmlChunk && !htmlStreamFinished) {\n await atLeastOneTask()\n }\n controller.enqueue(value)\n }\n } catch (err) {\n controller.error(err)\n }\n }\n\n return new TransformStream({\n start(controller) {\n if (!delayDataUntilFirstHtmlChunk) {\n startOrContinuePulling(controller)\n }\n },\n transform(chunk, controller) {\n controller.enqueue(chunk)\n\n // Start the streaming if it hasn't already been started yet.\n if (delayDataUntilFirstHtmlChunk) {\n startOrContinuePulling(controller)\n }\n },\n flush(controller) {\n htmlStreamFinished = true\n if (donePulling) {\n return\n }\n return startOrContinuePulling(controller)\n },\n })\n}\n\nconst CLOSE_TAG = '</body></html>'\n\n/**\n * This transform stream moves the suffix to the end of the stream, so results\n * like `</body></html><script>...</script>` will be transformed to\n * `<script>...</script></body></html>`.\n */\nfunction createMoveSuffixStream(): TransformStream<Uint8Array, Uint8Array> {\n let foundSuffix = false\n\n return new TransformStream({\n transform(chunk, controller) {\n if (foundSuffix) {\n return controller.enqueue(chunk)\n }\n\n const index = indexOfUint8Array(chunk, ENCODED_TAGS.CLOSED.BODY_AND_HTML)\n if (index > -1) {\n foundSuffix = true\n\n // If the whole chunk is the suffix, then don't write anything, it will\n // be written in the flush.\n if (chunk.length === ENCODED_TAGS.CLOSED.BODY_AND_HTML.length) {\n return\n }\n\n // Write out the part before the suffix.\n const before = chunk.slice(0, index)\n controller.enqueue(before)\n\n // In the case where the suffix is in the middle of the chunk, we need\n // to split the chunk into two parts.\n if (chunk.length > ENCODED_TAGS.CLOSED.BODY_AND_HTML.length + index) {\n // Write out the part after the suffix.\n const after = chunk.slice(\n index + ENCODED_TAGS.CLOSED.BODY_AND_HTML.length\n )\n controller.enqueue(after)\n }\n } else {\n controller.enqueue(chunk)\n }\n },\n flush(controller) {\n // Even if we didn't find the suffix, the HTML is not valid if we don't\n // add it, so insert it at the end.\n controller.enqueue(ENCODED_TAGS.CLOSED.BODY_AND_HTML)\n },\n })\n}\n\nfunction createStripDocumentClosingTagsTransform(): TransformStream<\n Uint8Array,\n Uint8Array\n> {\n return new TransformStream({\n transform(chunk, controller) {\n // We rely on the assumption that chunks will never break across a code unit.\n // This is reasonable because we currently concat all of React's output from a single\n // flush into one chunk before streaming it forward which means the chunk will represent\n // a single coherent utf-8 string. This is not safe to use if we change our streaming to no\n // longer do this large buffered chunk\n if (\n isEquivalentUint8Arrays(chunk, ENCODED_TAGS.CLOSED.BODY_AND_HTML) ||\n isEquivalentUint8Arrays(chunk, ENCODED_TAGS.CLOSED.BODY) ||\n isEquivalentUint8Arrays(chunk, ENCODED_TAGS.CLOSED.HTML)\n ) {\n // the entire chunk is the closing tags; return without enqueueing anything.\n return\n }\n\n // We assume these tags will go at together at the end of the document and that\n // they won't appear anywhere else in the document. This is not really a safe assumption\n // but until we revamp our streaming infra this is a performant way to string the tags\n chunk = removeFromUint8Array(chunk, ENCODED_TAGS.CLOSED.BODY)\n chunk = removeFromUint8Array(chunk, ENCODED_TAGS.CLOSED.HTML)\n\n controller.enqueue(chunk)\n },\n })\n}\n\n/*\n * Checks if the root layout is missing the html or body tags\n * and if so, it will inject a script tag to throw an error in the browser, showing the user\n * the error message in the error overlay.\n */\nexport function createRootLayoutValidatorStream(): TransformStream<\n Uint8Array,\n Uint8Array\n> {\n let foundHtml = false\n let foundBody = false\n return new TransformStream({\n async transform(chunk, controller) {\n // Peek into the streamed chunk to see if the tags are present.\n if (\n !foundHtml &&\n indexOfUint8Array(chunk, ENCODED_TAGS.OPENING.HTML) > -1\n ) {\n foundHtml = true\n }\n\n if (\n !foundBody &&\n indexOfUint8Array(chunk, ENCODED_TAGS.OPENING.BODY) > -1\n ) {\n foundBody = true\n }\n\n controller.enqueue(chunk)\n },\n flush(controller) {\n const missingTags: ('html' | 'body')[] = []\n if (!foundHtml) missingTags.push('html')\n if (!foundBody) missingTags.push('body')\n\n if (!missingTags.length) return\n\n controller.enqueue(\n encoder.encode(\n `<html id=\"__next_error__\">\n <template\n data-next-error-message=\"Missing ${missingTags\n .map((c) => `<${c}>`)\n .join(\n missingTags.length > 1 ? ' and ' : ''\n )} tags in the root layout.\\nRead more at https://nextjs.org/docs/messages/missing-root-layout-tags\"\n data-next-error-digest=\"${MISSING_ROOT_TAGS_ERROR}\"\n data-next-error-stack=\"\"\n ></template>\n `\n )\n )\n },\n })\n}\n\nfunction chainTransformers<T>(\n readable: ReadableStream<T>,\n transformers: ReadonlyArray<TransformStream<T, T> | null>\n): ReadableStream<T> {\n let stream = readable\n for (const transformer of transformers) {\n if (!transformer) continue\n\n stream = stream.pipeThrough(transformer)\n }\n return stream\n}\n\nexport type ContinueStreamOptions = {\n inlinedDataStream: ReadableStream<Uint8Array> | undefined\n isStaticGeneration: boolean\n isBuildTimePrerendering: boolean\n buildId: string\n getServerInsertedHTML: () => Promise<string>\n getServerInsertedMetadata: () => Promise<string>\n validateRootLayout?: boolean\n /**\n * Suffix to inject after the buffered data, but before the close tags.\n */\n suffix?: string | undefined\n}\n\nexport async function continueFizzStream(\n renderStream: ReactDOMServerReadableStream,\n {\n suffix,\n inlinedDataStream,\n isStaticGeneration,\n isBuildTimePrerendering,\n buildId,\n getServerInsertedHTML,\n getServerInsertedMetadata,\n validateRootLayout,\n }: ContinueStreamOptions\n): Promise<ReadableStream<Uint8Array>> {\n // Suffix itself might contain close tags at the end, so we need to split it.\n const suffixUnclosed = suffix ? suffix.split(CLOSE_TAG, 1)[0] : null\n\n // If we're generating static HTML we need to wait for it to resolve before continuing.\n if (isStaticGeneration) {\n await renderStream.allReady\n }\n\n return chainTransformers(renderStream, [\n // Buffer everything to avoid flushing too frequently\n createBufferedTransformStream(),\n\n // Add build id comment to start of the HTML document (in export mode)\n createPrefetchCommentStream(isBuildTimePrerendering, buildId),\n\n // Transform metadata\n createMetadataTransformStream(getServerInsertedMetadata),\n\n // Insert suffix content\n suffixUnclosed != null && suffixUnclosed.length > 0\n ? createDeferredSuffixStream(suffixUnclosed)\n : null,\n\n // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n inlinedDataStream\n ? createFlightDataInjectionTransformStream(inlinedDataStream, true)\n : null,\n\n // Validate the root layout for missing html or body tags\n validateRootLayout ? createRootLayoutValidatorStream() : null,\n\n // Close tags should always be deferred to the end\n createMoveSuffixStream(),\n\n // Special head insertions\n // TODO-APP: Insert server side html to end of head in app layout rendering, to avoid\n // hydration errors. Remove this once it's ready to be handled by react itself.\n createHeadInsertionTransformStream(getServerInsertedHTML),\n ])\n}\n\ntype ContinueDynamicPrerenderOptions = {\n getServerInsertedHTML: () => Promise<string>\n getServerInsertedMetadata: () => Promise<string>\n}\n\nexport async function continueDynamicPrerender(\n prerenderStream: ReadableStream<Uint8Array>,\n {\n getServerInsertedHTML,\n getServerInsertedMetadata,\n }: ContinueDynamicPrerenderOptions\n) {\n return (\n prerenderStream\n // Buffer everything to avoid flushing too frequently\n .pipeThrough(createBufferedTransformStream())\n .pipeThrough(createStripDocumentClosingTagsTransform())\n // Insert generated tags to head\n .pipeThrough(createHeadInsertionTransformStream(getServerInsertedHTML))\n // Transform metadata\n .pipeThrough(createMetadataTransformStream(getServerInsertedMetadata))\n )\n}\n\ntype ContinueStaticPrerenderOptions = {\n inlinedDataStream: ReadableStream<Uint8Array>\n getServerInsertedHTML: () => Promise<string>\n getServerInsertedMetadata: () => Promise<string>\n isBuildTimePrerendering: boolean\n buildId: string\n}\n\nexport async function continueStaticPrerender(\n prerenderStream: ReadableStream<Uint8Array>,\n {\n inlinedDataStream,\n getServerInsertedHTML,\n getServerInsertedMetadata,\n isBuildTimePrerendering,\n buildId,\n }: ContinueStaticPrerenderOptions\n) {\n return (\n prerenderStream\n // Buffer everything to avoid flushing too frequently\n .pipeThrough(createBufferedTransformStream())\n // Add build id comment to start of the HTML document (in export mode)\n .pipeThrough(\n createPrefetchCommentStream(isBuildTimePrerendering, buildId)\n )\n // Insert generated tags to head\n .pipeThrough(createHeadInsertionTransformStream(getServerInsertedHTML))\n // Transform metadata\n .pipeThrough(createMetadataTransformStream(getServerInsertedMetadata))\n // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n .pipeThrough(\n createFlightDataInjectionTransformStream(inlinedDataStream, true)\n )\n // Close tags should always be deferred to the end\n .pipeThrough(createMoveSuffixStream())\n )\n}\n\nexport async function continueStaticFallbackPrerender(\n prerenderStream: ReadableStream<Uint8Array>,\n {\n inlinedDataStream,\n getServerInsertedHTML,\n getServerInsertedMetadata,\n isBuildTimePrerendering,\n buildId,\n }: ContinueStaticPrerenderOptions\n) {\n // Same as `continueStaticPrerender`, but also inserts an additional script\n // to instruct the client to start fetching the hydration data as early\n // as possible.\n return (\n prerenderStream\n // Buffer everything to avoid flushing too frequently\n .pipeThrough(createBufferedTransformStream())\n // Add build id comment to start of the HTML document (in export mode)\n .pipeThrough(\n createPrefetchCommentStream(isBuildTimePrerendering, buildId)\n )\n // Insert generated tags to head\n .pipeThrough(createHeadInsertionTransformStream(getServerInsertedHTML))\n // Insert the client resume script into the head\n .pipeThrough(createClientResumeScriptInsertionTransformStream())\n // Transform metadata\n .pipeThrough(createMetadataTransformStream(getServerInsertedMetadata))\n // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n .pipeThrough(\n createFlightDataInjectionTransformStream(inlinedDataStream, true)\n )\n // Close tags should always be deferred to the end\n .pipeThrough(createMoveSuffixStream())\n )\n}\n\ntype ContinueResumeOptions = {\n inlinedDataStream: ReadableStream<Uint8Array>\n getServerInsertedHTML: () => Promise<string>\n getServerInsertedMetadata: () => Promise<string>\n delayDataUntilFirstHtmlChunk: boolean\n}\n\nexport async function continueDynamicHTMLResume(\n renderStream: ReadableStream<Uint8Array>,\n {\n delayDataUntilFirstHtmlChunk,\n inlinedDataStream,\n getServerInsertedHTML,\n getServerInsertedMetadata,\n }: ContinueResumeOptions\n) {\n return (\n renderStream\n // Buffer everything to avoid flushing too frequently\n .pipeThrough(createBufferedTransformStream())\n // Insert generated tags to head\n .pipeThrough(createHeadInsertionTransformStream(getServerInsertedHTML))\n // Transform metadata\n .pipeThrough(createMetadataTransformStream(getServerInsertedMetadata))\n // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n .pipeThrough(\n createFlightDataInjectionTransformStream(\n inlinedDataStream,\n delayDataUntilFirstHtmlChunk\n )\n )\n // Close tags should always be deferred to the end\n .pipeThrough(createMoveSuffixStream())\n )\n}\n\nexport function createDocumentClosingStream(): ReadableStream<Uint8Array> {\n return streamFromString(CLOSE_TAG)\n}\n","export const ENCODED_TAGS = {\n // opening tags do not have the closing `>` since they can contain other attributes such as `<body className=''>`\n OPENING: {\n // <html\n HTML: new Uint8Array([60, 104, 116, 109, 108]),\n // <body\n BODY: new Uint8Array([60, 98, 111, 100, 121]),\n },\n CLOSED: {\n // </head>\n HEAD: new Uint8Array([60, 47, 104, 101, 97, 100, 62]),\n // </body>\n BODY: new Uint8Array([60, 47, 98, 111, 100, 121, 62]),\n // </html>\n HTML: new Uint8Array([60, 47, 104, 116, 109, 108, 62]),\n // </body></html>\n BODY_AND_HTML: new Uint8Array([\n 60, 47, 98, 111, 100, 121, 62, 60, 47, 104, 116, 109, 108, 62,\n ]),\n },\n META: {\n // Only the match the prefix cause the suffix can be different wether it's xml compatible or not \">\" or \"/>\"\n // <meta name=\"«nxt-icon»\"\n // This is a special mark that will be replaced by the icon insertion script tag.\n ICON_MARK: new Uint8Array([\n 60, 109, 101, 116, 97, 32, 110, 97, 109, 101, 61, 34, 194, 171, 110, 120,\n 116, 45, 105, 99, 111, 110, 194, 187, 34,\n ]),\n },\n} as const\n","import { parsePath } from './parse-path'\n\n/**\n * Adds the provided prefix to the given path. It first ensures that the path\n * is indeed starting with a slash.\n */\nexport function addPathPrefix(path: string, prefix?: string) {\n if (!path.startsWith('/') || !prefix) {\n return path\n }\n\n const { pathname, query, hash } = parsePath(path)\n return `${prefix}${pathname}${query}${hash}`\n}\n","import { parsePath } from './parse-path'\n\n/**\n * Similarly to `addPathPrefix`, this function adds a suffix at the end on the\n * provided path. It also works only for paths ensuring the argument starts\n * with a slash.\n */\nexport function addPathSuffix(path: string, suffix?: string) {\n if (!path.startsWith('/') || !suffix) {\n return path\n }\n\n const { pathname, query, hash } = parsePath(path)\n return `${pathname}${suffix}${query}${hash}`\n}\n","import type { OutgoingHttpHeaders } from 'http'\nimport type { DomainLocale, I18NConfig } from '../config-shared'\nimport type { I18NProvider } from '../lib/i18n-provider'\n\nimport { detectDomainLocale } from '../../shared/lib/i18n/detect-domain-locale'\nimport { formatNextPathnameInfo } from '../../shared/lib/router/utils/format-next-pathname-info'\nimport { getHostname } from '../../shared/lib/get-hostname'\nimport { getNextPathnameInfo } from '../../shared/lib/router/utils/get-next-pathname-info'\n\ninterface Options {\n base?: string | URL\n headers?: OutgoingHttpHeaders\n forceLocale?: boolean\n nextConfig?: {\n basePath?: string\n i18n?: I18NConfig | null\n trailingSlash?: boolean\n }\n i18nProvider?: I18NProvider\n}\n\nconst REGEX_LOCALHOST_HOSTNAME =\n /(?!^https?:\\/\\/)(127(?:\\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}|\\[::1\\]|localhost)/\n\nfunction parseURL(url: string | URL, base?: string | URL) {\n return new URL(\n String(url).replace(REGEX_LOCALHOST_HOSTNAME, 'localhost'),\n base && String(base).replace(REGEX_LOCALHOST_HOSTNAME, 'localhost')\n )\n}\n\nconst Internal = Symbol('NextURLInternal')\n\nexport class NextURL {\n private [Internal]: {\n basePath: string\n buildId?: string\n flightSearchParameters?: Record<string, string>\n defaultLocale?: string\n domainLocale?: DomainLocale\n locale?: string\n options: Options\n trailingSlash?: boolean\n url: URL\n }\n\n constructor(input: string | URL, base?: string | URL, opts?: Options)\n constructor(input: string | URL, opts?: Options)\n constructor(\n input: string | URL,\n baseOrOpts?: string | URL | Options,\n opts?: Options\n ) {\n let base: undefined | string | URL\n let options: Options\n\n if (\n (typeof baseOrOpts === 'object' && 'pathname' in baseOrOpts) ||\n typeof baseOrOpts === 'string'\n ) {\n base = baseOrOpts\n options = opts || {}\n } else {\n options = opts || baseOrOpts || {}\n }\n\n this[Internal] = {\n url: parseURL(input, base ?? options.base),\n options: options,\n basePath: '',\n }\n\n this.analyze()\n }\n\n private analyze() {\n const info = getNextPathnameInfo(this[Internal].url.pathname, {\n nextConfig: this[Internal].options.nextConfig,\n parseData: !process.env.__NEXT_NO_MIDDLEWARE_URL_NORMALIZE,\n i18nProvider: this[Internal].options.i18nProvider,\n })\n\n const hostname = getHostname(\n this[Internal].url,\n this[Internal].options.headers\n )\n this[Internal].domainLocale = this[Internal].options.i18nProvider\n ? this[Internal].options.i18nProvider.detectDomainLocale(hostname)\n : detectDomainLocale(\n this[Internal].options.nextConfig?.i18n?.domains,\n hostname\n )\n\n const defaultLocale =\n this[Internal].domainLocale?.defaultLocale ||\n this[Internal].options.nextConfig?.i18n?.defaultLocale\n\n this[Internal].url.pathname = info.pathname\n this[Internal].defaultLocale = defaultLocale\n this[Internal].basePath = info.basePath ?? ''\n this[Internal].buildId = info.buildId\n this[Internal].locale = info.locale ?? defaultLocale\n this[Internal].trailingSlash = info.trailingSlash\n }\n\n private formatPathname() {\n return formatNextPathnameInfo({\n basePath: this[Internal].basePath,\n buildId: this[Internal].buildId,\n defaultLocale: !this[Internal].options.forceLocale\n ? this[Internal].defaultLocale\n : undefined,\n locale: this[Internal].locale,\n pathname: this[Internal].url.pathname,\n trailingSlash: this[Internal].trailingSlash,\n })\n }\n\n private formatSearch() {\n return this[Internal].url.search\n }\n\n public get buildId() {\n return this[Internal].buildId\n }\n\n public set buildId(buildId: string | undefined) {\n this[Internal].buildId = buildId\n }\n\n public get locale() {\n return this[Internal].locale ?? ''\n }\n\n public set locale(locale: string) {\n if (\n !this[Internal].locale ||\n !this[Internal].options.nextConfig?.i18n?.locales.includes(locale)\n ) {\n throw new TypeError(\n `The NextURL configuration includes no locale \"${locale}\"`\n )\n }\n\n this[Internal].locale = locale\n }\n\n get defaultLocale() {\n return this[Internal].defaultLocale\n }\n\n get domainLocale() {\n return this[Internal].domainLocale\n }\n\n get searchParams() {\n return this[Internal].url.searchParams\n }\n\n get host() {\n return this[Internal].url.host\n }\n\n set host(value: string) {\n this[Internal].url.host = value\n }\n\n get hostname() {\n return this[Internal].url.hostname\n }\n\n set hostname(value: string) {\n this[Internal].url.hostname = value\n }\n\n get port() {\n return this[Internal].url.port\n }\n\n set port(value: string) {\n this[Internal].url.port = value\n }\n\n get protocol() {\n return this[Internal].url.protocol\n }\n\n set protocol(value: string) {\n this[Internal].url.protocol = value\n }\n\n get href() {\n const pathname = this.formatPathname()\n const search = this.formatSearch()\n return `${this.protocol}//${this.host}${pathname}${search}${this.hash}`\n }\n\n set href(url: string) {\n this[Internal].url = parseURL(url)\n this.analyze()\n }\n\n get origin() {\n return this[Internal].url.origin\n }\n\n get pathname() {\n return this[Internal].url.pathname\n }\n\n set pathname(value: string) {\n this[Internal].url.pathname = value\n }\n\n get hash() {\n return this[Internal].url.hash\n }\n\n set hash(value: string) {\n this[Internal].url.hash = value\n }\n\n get search() {\n return this[Internal].url.search\n }\n\n set search(value: string) {\n this[Internal].url.search = value\n }\n\n get password() {\n return this[Internal].url.password\n }\n\n set password(value: string) {\n this[Internal].url.password = value\n }\n\n get username() {\n return this[Internal].url.username\n }\n\n set username(value: string) {\n this[Internal].url.username = value\n }\n\n get basePath() {\n return this[Internal].basePath\n }\n\n set basePath(value: string) {\n this[Internal].basePath = value.startsWith('/') ? value : `/${value}`\n }\n\n toString() {\n return this.href\n }\n\n toJSON() {\n return this.href\n }\n\n [Symbol.for('edge-runtime.inspect.custom')]() {\n return {\n href: this.href,\n origin: this.origin,\n protocol: this.protocol,\n username: this.username,\n password: this.password,\n host: this.host,\n hostname: this.hostname,\n port: this.port,\n pathname: this.pathname,\n search: this.search,\n searchParams: this.searchParams,\n hash: this.hash,\n }\n }\n\n clone() {\n return new NextURL(String(this), this[Internal].options)\n }\n}\n","import { normalizeLocalePath } from '../../i18n/normalize-locale-path'\nimport { removePathPrefix } from './remove-path-prefix'\nimport { pathHasPrefix } from './path-has-prefix'\nimport type { I18NProvider } from '../../../../server/lib/i18n-provider'\n\nexport interface NextPathnameInfo {\n /**\n * The base path in case the pathname included it.\n */\n basePath?: string\n /**\n * The buildId for when the parsed URL is a data URL. Parsing it can be\n * disabled with the `parseData` option.\n */\n buildId?: string\n /**\n * If there was a locale in the pathname, this will hold its value.\n */\n locale?: string\n /**\n * The processed pathname without a base path, locale, or data URL elements\n * when parsing it is enabled.\n */\n pathname: string\n /**\n * A boolean telling if the pathname had a trailingSlash. This can be only\n * true if trailingSlash is enabled.\n */\n trailingSlash?: boolean\n}\n\ninterface Options {\n /**\n * When passed to true, this function will also parse Nextjs data URLs.\n */\n parseData?: boolean\n /**\n * A partial of the Next.js configuration to parse the URL.\n */\n nextConfig?: {\n basePath?: string\n i18n?: { locales?: readonly string[] } | null\n trailingSlash?: boolean\n }\n\n /**\n * If provided, this normalizer will be used to detect the locale instead of\n * the default locale detection.\n */\n i18nProvider?: I18NProvider\n}\n\nexport function getNextPathnameInfo(\n pathname: string,\n options: Options\n): NextPathnameInfo {\n const { basePath, i18n, trailingSlash } = options.nextConfig ?? {}\n const info: NextPathnameInfo = {\n pathname,\n trailingSlash: pathname !== '/' ? pathname.endsWith('/') : trailingSlash,\n }\n\n if (basePath && pathHasPrefix(info.pathname, basePath)) {\n info.pathname = removePathPrefix(info.pathname, basePath)\n info.basePath = basePath\n }\n let pathnameNoDataPrefix = info.pathname\n\n if (\n info.pathname.startsWith('/_next/data/') &&\n info.pathname.endsWith('.json')\n ) {\n const paths = info.pathname\n .replace(/^\\/_next\\/data\\//, '')\n .replace(/\\.json$/, '')\n .split('/')\n\n const buildId = paths[0]\n info.buildId = buildId\n pathnameNoDataPrefix =\n paths[1] !== 'index' ? `/${paths.slice(1).join('/')}` : '/'\n\n // update pathname with normalized if enabled although\n // we use normalized to populate locale info still\n if (options.parseData === true) {\n info.pathname = pathnameNoDataPrefix\n }\n }\n\n // If provided, use the locale route normalizer to detect the locale instead\n // of the function below.\n if (i18n) {\n let result = options.i18nProvider\n ? options.i18nProvider.analyze(info.pathname)\n : normalizeLocalePath(info.pathname, i18n.locales)\n\n info.locale = result.detectedLocale\n info.pathname = result.pathname ?? info.pathname\n\n if (!result.detectedLocale && info.buildId) {\n result = options.i18nProvider\n ? options.i18nProvider.analyze(pathnameNoDataPrefix)\n : normalizeLocalePath(pathnameNoDataPrefix, i18n.locales)\n\n if (result.detectedLocale) {\n info.locale = result.detectedLocale\n }\n }\n }\n return info\n}\n","import type { NextPathnameInfo } from './get-next-pathname-info'\nimport { removeTrailingSlash } from './remove-trailing-slash'\nimport { addPathPrefix } from './add-path-prefix'\nimport { addPathSuffix } from './add-path-suffix'\nimport { addLocale } from './add-locale'\n\ninterface ExtendedInfo extends NextPathnameInfo {\n defaultLocale?: string\n ignorePrefix?: boolean\n}\n\nexport function formatNextPathnameInfo(info: ExtendedInfo) {\n let pathname = addLocale(\n info.pathname,\n info.locale,\n info.buildId ? undefined : info.defaultLocale,\n info.ignorePrefix\n )\n\n if (info.buildId || !info.trailingSlash) {\n pathname = removeTrailingSlash(pathname)\n }\n\n if (info.buildId) {\n pathname = addPathSuffix(\n addPathPrefix(pathname, `/_next/data/${info.buildId}`),\n info.pathname === '/' ? 'index.json' : '.json'\n )\n }\n\n pathname = addPathPrefix(pathname, info.basePath)\n return !info.buildId && info.trailingSlash\n ? !pathname.endsWith('/')\n ? addPathSuffix(pathname, '/')\n : pathname\n : removeTrailingSlash(pathname)\n}\n","import { addPathPrefix } from './add-path-prefix'\nimport { pathHasPrefix } from './path-has-prefix'\n\n/**\n * For a given path and a locale, if the locale is given, it will prefix the\n * locale. The path shouldn't be an API path. If a default locale is given the\n * prefix will be omitted if the locale is already the default locale.\n */\nexport function addLocale(\n path: string,\n locale?: string | false,\n defaultLocale?: string,\n ignorePrefix?: boolean\n) {\n // If no locale was given or the locale is the default locale, we don't need\n // to prefix the path.\n if (!locale || locale === defaultLocale) return path\n\n const lower = path.toLowerCase()\n\n // If the path is an API path or the path already has the locale prefix, we\n // don't need to prefix the path.\n if (!ignorePrefix) {\n if (pathHasPrefix(lower, '/api')) return path\n if (pathHasPrefix(lower, `/${locale.toLowerCase()}`)) return path\n }\n\n // Add the locale prefix to the path.\n return addPathPrefix(path, `/${locale}`)\n}\n","import type { I18NConfig } from '../../config-shared'\nimport { NextURL } from '../next-url'\nimport { toNodeOutgoingHttpHeaders, validateURL } from '../utils'\nimport { RemovedUAError, RemovedPageError } from '../error'\nimport { RequestCookies } from './cookies'\n\nexport const INTERNALS = Symbol('internal request')\n\n/**\n * This class extends the [Web `Request` API](https://developer.mozilla.org/docs/Web/API/Request) with additional convenience methods.\n *\n * Read more: [Next.js Docs: `NextRequest`](https://nextjs.org/docs/app/api-reference/functions/next-request)\n */\nexport class NextRequest extends Request {\n /** @internal */\n [INTERNALS]: {\n cookies: RequestCookies\n url: string\n nextUrl: NextURL\n }\n\n constructor(input: URL | RequestInfo, init: RequestInit = {}) {\n const url =\n typeof input !== 'string' && 'url' in input ? input.url : String(input)\n\n validateURL(url)\n\n // node Request instance requires duplex option when a body\n // is present or it errors, we don't handle this for\n // Request being passed in since it would have already\n // errored if this wasn't configured\n if (process.env.NEXT_RUNTIME !== 'edge') {\n if (init.body && init.duplex !== 'half') {\n init.duplex = 'half'\n }\n }\n\n if (input instanceof Request) super(input, init)\n else super(url, init)\n\n const nextUrl = new NextURL(url, {\n headers: toNodeOutgoingHttpHeaders(this.headers),\n nextConfig: init.nextConfig,\n })\n this[INTERNALS] = {\n cookies: new RequestCookies(this.headers),\n nextUrl,\n url: process.env.__NEXT_NO_MIDDLEWARE_URL_NORMALIZE\n ? url\n : nextUrl.toString(),\n }\n }\n\n [Symbol.for('edge-runtime.inspect.custom')]() {\n return {\n cookies: this.cookies,\n nextUrl: this.nextUrl,\n url: this.url,\n // rest of props come from Request\n bodyUsed: this.bodyUsed,\n cache: this.cache,\n credentials: this.credentials,\n destination: this.destination,\n headers: Object.fromEntries(this.headers),\n integrity: this.integrity,\n keepalive: this.keepalive,\n method: this.method,\n mode: this.mode,\n redirect: this.redirect,\n referrer: this.referrer,\n referrerPolicy: this.referrerPolicy,\n signal: this.signal,\n }\n }\n\n public get cookies() {\n return this[INTERNALS].cookies\n }\n\n public get nextUrl() {\n return this[INTERNALS].nextUrl\n }\n\n /**\n * @deprecated\n * `page` has been deprecated in favour of `URLPattern`.\n * Read more: https://nextjs.org/docs/messages/middleware-request-page\n */\n public get page() {\n throw new RemovedPageError()\n }\n\n /**\n * @deprecated\n * `ua` has been removed in favour of \\`userAgent\\` function.\n * Read more: https://nextjs.org/docs/messages/middleware-parse-user-agent\n */\n public get ua() {\n throw new RemovedUAError()\n }\n\n public get url() {\n return this[INTERNALS].url\n }\n}\n\nexport interface RequestInit extends globalThis.RequestInit {\n nextConfig?: {\n basePath?: string\n i18n?: I18NConfig | null\n trailingSlash?: boolean\n }\n signal?: AbortSignal\n // see https://github.com/whatwg/fetch/pull/1457\n duplex?: 'half'\n}\n","import type { BaseNextRequest } from '../../../base-http'\nimport type { NodeNextRequest } from '../../../base-http/node'\nimport type { WebNextRequest } from '../../../base-http/web'\nimport type { Writable } from 'node:stream'\n\nimport { getRequestMeta } from '../../../request-meta'\nimport { fromNodeOutgoingHttpHeaders } from '../../utils'\nimport { NextRequest } from '../request'\nimport { isNodeNextRequest, isWebNextRequest } from '../../../base-http/helpers'\n\nexport const ResponseAbortedName = 'ResponseAborted'\nexport class ResponseAborted extends Error {\n public readonly name = ResponseAbortedName\n}\n\n/**\n * Creates an AbortController tied to the closing of a ServerResponse (or other\n * appropriate Writable).\n *\n * If the `close` event is fired before the `finish` event, then we'll send the\n * `abort` signal.\n */\nexport function createAbortController(response: Writable): AbortController {\n const controller = new AbortController()\n\n // If `finish` fires first, then `res.end()` has been called and the close is\n // just us finishing the stream on our side. If `close` fires first, then we\n // know the client disconnected before we finished.\n response.once('close', () => {\n if (response.writableFinished) return\n\n controller.abort(new ResponseAborted())\n })\n\n return controller\n}\n\n/**\n * Creates an AbortSignal tied to the closing of a ServerResponse (or other\n * appropriate Writable).\n *\n * This cannot be done with the request (IncomingMessage or Readable) because\n * the `abort` event will not fire if to data has been fully read (because that\n * will \"close\" the readable stream and nothing fires after that).\n */\nexport function signalFromNodeResponse(response: Writable): AbortSignal {\n const { errored, destroyed } = response\n if (errored || destroyed) {\n return AbortSignal.abort(errored ?? new ResponseAborted())\n }\n\n const { signal } = createAbortController(response)\n return signal\n}\n\nexport class NextRequestAdapter {\n public static fromBaseNextRequest(\n request: BaseNextRequest,\n signal: AbortSignal\n ): NextRequest {\n if (\n // The type check here ensures that `req` is correctly typed, and the\n // environment variable check provides dead code elimination.\n process.env.NEXT_RUNTIME === 'edge' &&\n isWebNextRequest(request)\n ) {\n return NextRequestAdapter.fromWebNextRequest(request)\n } else if (\n // The type check here ensures that `req` is correctly typed, and the\n // environment variable check provides dead code elimination.\n process.env.NEXT_RUNTIME !== 'edge' &&\n isNodeNextRequest(request)\n ) {\n return NextRequestAdapter.fromNodeNextRequest(request, signal)\n } else {\n throw new Error('Invariant: Unsupported NextRequest type')\n }\n }\n\n public static fromNodeNextRequest(\n request: NodeNextRequest,\n signal: AbortSignal\n ): NextRequest {\n // HEAD and GET requests can not have a body.\n let body: BodyInit | null = null\n if (request.method !== 'GET' && request.method !== 'HEAD' && request.body) {\n // @ts-expect-error - this is handled by undici, when streams/web land use it instead\n body = request.body\n }\n\n let url: URL\n if (request.url.startsWith('http')) {\n url = new URL(request.url)\n } else {\n // Grab the full URL from the request metadata.\n const base = getRequestMeta(request, 'initURL')\n if (!base || !base.startsWith('http')) {\n // Because the URL construction relies on the fact that the URL provided\n // is absolute, we need to provide a base URL. We can't use the request\n // URL because it's relative, so we use a dummy URL instead.\n url = new URL(request.url, 'http://n')\n } else {\n url = new URL(request.url, base)\n }\n }\n\n return new NextRequest(url, {\n method: request.method,\n headers: fromNodeOutgoingHttpHeaders(request.headers),\n duplex: 'half',\n signal,\n // geo\n // ip\n // nextConfig\n\n // body can not be passed if request was aborted\n // or we get a Request body was disturbed error\n ...(signal.aborted\n ? {}\n : {\n body,\n }),\n })\n }\n\n public static fromWebNextRequest(request: WebNextRequest): NextRequest {\n // HEAD and GET requests can not have a body.\n let body: ReadableStream | null = null\n if (request.method !== 'GET' && request.method !== 'HEAD') {\n body = request.body\n }\n\n return new NextRequest(request.url, {\n method: request.method,\n headers: fromNodeOutgoingHttpHeaders(request.headers),\n duplex: 'half',\n signal: request.request.signal,\n // geo\n // ip\n // nextConfig\n\n // body can not be passed if request was aborted\n // or we get a Request body was disturbed error\n ...(request.request.signal.aborted\n ? {}\n : {\n body,\n }),\n })\n }\n}\n","import type { AppPageModule } from './route-modules/app-page/module'\n\n// Combined load times for loading client components\nlet clientComponentLoadStart = 0\nlet clientComponentLoadTimes = 0\nlet clientComponentLoadCount = 0\n\nexport function wrapClientComponentLoader(\n ComponentMod: AppPageModule\n): AppPageModule['__next_app__'] {\n if (!('performance' in globalThis)) {\n return ComponentMod.__next_app__\n }\n\n return {\n require: (...args) => {\n const startTime = performance.now()\n\n if (clientComponentLoadStart === 0) {\n clientComponentLoadStart = startTime\n }\n\n try {\n clientComponentLoadCount += 1\n return ComponentMod.__next_app__.require(...args)\n } finally {\n clientComponentLoadTimes += performance.now() - startTime\n }\n },\n loadChunk: (...args) => {\n const startTime = performance.now()\n const result = ComponentMod.__next_app__.loadChunk(...args)\n // Avoid wrapping `loadChunk`'s result in an extra promise in case something like React depends on its identity.\n // We only need to know when it's settled.\n result.finally(() => {\n clientComponentLoadTimes += performance.now() - startTime\n })\n return result\n },\n }\n}\n\nexport function getClientComponentLoaderMetrics(\n options: { reset?: boolean } = {}\n) {\n const metrics =\n clientComponentLoadStart === 0\n ? undefined\n : {\n clientComponentLoadStart,\n clientComponentLoadTimes,\n clientComponentLoadCount,\n }\n\n if (options.reset) {\n clientComponentLoadStart = 0\n clientComponentLoadTimes = 0\n clientComponentLoadCount = 0\n }\n\n return metrics\n}\n","import type { ServerResponse } from 'node:http'\n\nimport {\n ResponseAbortedName,\n createAbortController,\n} from './web/spec-extension/adapters/next-request'\nimport { DetachedPromise } from '../lib/detached-promise'\nimport { getTracer } from './lib/trace/tracer'\nimport { NextNodeServerSpan } from './lib/trace/constants'\nimport { getClientComponentLoaderMetrics } from './client-component-renderer-logger'\n\nexport function isAbortError(e: any): e is Error & { name: 'AbortError' } {\n return e?.name === 'AbortError' || e?.name === ResponseAbortedName\n}\n\nfunction createWriterFromResponse(\n res: ServerResponse,\n waitUntilForEnd?: Promise<unknown>\n): WritableStream<Uint8Array> {\n let started = false\n\n // Create a promise that will resolve once the response has drained. See\n // https://nodejs.org/api/stream.html#stream_event_drain\n let drained = new DetachedPromise<void>()\n function onDrain() {\n drained.resolve()\n }\n res.on('drain', onDrain)\n\n // If the finish event fires, it means we shouldn't block and wait for the\n // drain event.\n res.once('close', () => {\n res.off('drain', onDrain)\n drained.resolve()\n })\n\n // Create a promise that will resolve once the response has finished. See\n // https://nodejs.org/api/http.html#event-finish_1\n const finished = new DetachedPromise<void>()\n res.once('finish', () => {\n finished.resolve()\n })\n\n // Create a writable stream that will write to the response.\n return new WritableStream<Uint8Array>({\n write: async (chunk) => {\n // You'd think we'd want to use `start` instead of placing this in `write`\n // but this ensures that we don't actually flush the headers until we've\n // started writing chunks.\n if (!started) {\n started = true\n\n if (\n 'performance' in globalThis &&\n process.env.NEXT_OTEL_PERFORMANCE_PREFIX\n ) {\n const metrics = getClientComponentLoaderMetrics()\n if (metrics) {\n performance.measure(\n `${process.env.NEXT_OTEL_PERFORMANCE_PREFIX}:next-client-component-loading`,\n {\n start: metrics.clientComponentLoadStart,\n end:\n metrics.clientComponentLoadStart +\n metrics.clientComponentLoadTimes,\n }\n )\n }\n }\n\n res.flushHeaders()\n getTracer().trace(\n NextNodeServerSpan.startResponse,\n {\n spanName: 'start response',\n },\n () => undefined\n )\n }\n\n try {\n const ok = res.write(chunk)\n\n // Added by the `compression` middleware, this is a function that will\n // flush the partially-compressed response to the client.\n if ('flush' in res && typeof res.flush === 'function') {\n res.flush()\n }\n\n // If the write returns false, it means there's some backpressure, so\n // wait until it's streamed before continuing.\n if (!ok) {\n await drained.promise\n\n // Reset the drained promise so that we can wait for the next drain event.\n drained = new DetachedPromise<void>()\n }\n } catch (err) {\n res.end()\n throw new Error('failed to write chunk to response', { cause: err })\n }\n },\n abort: (err) => {\n if (res.writableFinished) return\n\n res.destroy(err)\n },\n close: async () => {\n // if a waitUntil promise was passed, wait for it to resolve before\n // ending the response.\n if (waitUntilForEnd) {\n await waitUntilForEnd\n }\n\n if (res.writableFinished) return\n\n res.end()\n return finished.promise\n },\n })\n}\n\nexport async function pipeToNodeResponse(\n readable: ReadableStream<Uint8Array>,\n res: ServerResponse,\n waitUntilForEnd?: Promise<unknown>\n) {\n try {\n // If the response has already errored, then just return now.\n const { errored, destroyed } = res\n if (errored || destroyed) return\n\n // Create a new AbortController so that we can abort the readable if the\n // client disconnects.\n const controller = createAbortController(res)\n\n const writer = createWriterFromResponse(res, waitUntilForEnd)\n\n await readable.pipeTo(writer, { signal: controller.signal })\n } catch (err: any) {\n // If this isn't related to an abort error, re-throw it.\n if (isAbortError(err)) return\n\n throw new Error('failed to pipe response', { cause: err })\n }\n}\n","import type { OutgoingHttpHeaders, ServerResponse } from 'http'\nimport type { CacheControl } from './lib/cache-control'\nimport type { FetchMetrics } from './base-http'\n\nimport {\n chainStreams,\n streamFromBuffer,\n streamFromString,\n streamToString,\n} from './stream-utils/node-web-streams-helper'\nimport { isAbortError, pipeToNodeResponse } from './pipe-readable'\nimport type { RenderResumeDataCache } from './resume-data-cache/resume-data-cache'\nimport { InvariantError } from '../shared/lib/invariant-error'\nimport type {\n HTML_CONTENT_TYPE_HEADER,\n JSON_CONTENT_TYPE_HEADER,\n TEXT_PLAIN_CONTENT_TYPE_HEADER,\n} from '../lib/constants'\nimport type { RSC_CONTENT_TYPE_HEADER } from '../client/components/app-router-headers'\n\ntype ContentTypeOption =\n | typeof RSC_CONTENT_TYPE_HEADER // For App Page RSC responses\n | typeof HTML_CONTENT_TYPE_HEADER // For App Page, Pages HTML responses\n | typeof JSON_CONTENT_TYPE_HEADER // For API routes, Next.js data requests\n | typeof TEXT_PLAIN_CONTENT_TYPE_HEADER // For simplified errors\n\nexport type AppPageRenderResultMetadata = {\n flightData?: Buffer\n cacheControl?: CacheControl\n staticBailoutInfo?: {\n stack?: string\n description?: string\n }\n\n /**\n * The postponed state if the render had postponed and needs to be resumed.\n */\n postponed?: string\n\n /**\n * The headers to set on the response that were added by the render.\n */\n headers?: OutgoingHttpHeaders\n statusCode?: number\n fetchTags?: string\n fetchMetrics?: FetchMetrics\n\n segmentData?: Map<string, Buffer>\n\n /**\n * In development, the resume data cache is warmed up before the render. This\n * is attached to the metadata so that it can be used during the render. When\n * prerendering, the filled resume data cache is also attached to the metadata\n * so that it can be used when prerendering matching fallback shells.\n */\n renderResumeDataCache?: RenderResumeDataCache\n}\n\nexport type PagesRenderResultMetadata = {\n pageData?: any\n cacheControl?: CacheControl\n assetQueryString?: string\n isNotFound?: boolean\n isRedirect?: boolean\n}\n\nexport type StaticRenderResultMetadata = {}\n\nexport type RenderResultMetadata = AppPageRenderResultMetadata &\n PagesRenderResultMetadata &\n StaticRenderResultMetadata\n\nexport type RenderResultResponse =\n | ReadableStream<Uint8Array>[]\n | ReadableStream<Uint8Array>\n | string\n | Buffer\n | null\n\nexport type RenderResultOptions<\n Metadata extends RenderResultMetadata = RenderResultMetadata,\n> = {\n contentType: ContentTypeOption | null\n waitUntil?: Promise<unknown>\n metadata: Metadata\n}\n\nexport default class RenderResult<\n Metadata extends RenderResultMetadata = RenderResultMetadata,\n> {\n /**\n * The detected content type for the response. This is used to set the\n * `Content-Type` header.\n */\n public readonly contentType: ContentTypeOption | null\n\n /**\n * The metadata for the response. This is used to set the revalidation times\n * and other metadata.\n */\n public readonly metadata: Readonly<Metadata>\n\n /**\n * The response itself. This can be a string, a stream, or null. If it's a\n * string, then it's a static response. If it's a stream, then it's a\n * dynamic response. If it's null, then the response was not found or was\n * already sent.\n */\n private response: RenderResultResponse\n\n /**\n * A render result that represents an empty response. This is used to\n * represent a response that was not found or was already sent.\n */\n public static readonly EMPTY = new RenderResult<StaticRenderResultMetadata>(\n null,\n { metadata: {}, contentType: null }\n )\n\n /**\n * Creates a new RenderResult instance from a static response.\n *\n * @param value the static response value\n * @param contentType the content type of the response\n * @returns a new RenderResult instance\n */\n public static fromStatic(\n value: string | Buffer,\n contentType: ContentTypeOption\n ) {\n return new RenderResult<StaticRenderResultMetadata>(value, {\n metadata: {},\n contentType,\n })\n }\n\n private readonly waitUntil?: Promise<unknown>\n\n constructor(\n response: RenderResultResponse,\n { contentType, waitUntil, metadata }: RenderResultOptions<Metadata>\n ) {\n this.response = response\n this.contentType = contentType\n this.metadata = metadata\n this.waitUntil = waitUntil\n }\n\n public assignMetadata(metadata: Metadata) {\n Object.assign(this.metadata, metadata)\n }\n\n /**\n * Returns true if the response is null. It can be null if the response was\n * not found or was already sent.\n */\n public get isNull(): boolean {\n return this.response === null\n }\n\n /**\n * Returns false if the response is a string. It can be a string if the page\n * was prerendered. If it's not, then it was generated dynamically.\n */\n public get isDynamic(): boolean {\n return typeof this.response !== 'string'\n }\n\n /**\n * Returns the response if it is a string. If the page was dynamic, this will\n * return a promise if the `stream` option is true, or it will throw an error.\n *\n * @param stream Whether or not to return a promise if the response is dynamic\n * @returns The response as a string\n */\n public toUnchunkedString(stream?: false): string\n public toUnchunkedString(stream: true): Promise<string>\n public toUnchunkedString(stream = false): Promise<string> | string {\n if (this.response === null) {\n // If the response is null, return an empty string. This behavior is\n // intentional as we're now providing the `RenderResult.EMPTY` value.\n return ''\n }\n\n if (typeof this.response !== 'string') {\n if (!stream) {\n throw new InvariantError(\n 'dynamic responses cannot be unchunked. This is a bug in Next.js'\n )\n }\n\n return streamToString(this.readable)\n }\n\n return this.response\n }\n\n /**\n * Returns a readable stream of the response.\n */\n private get readable(): ReadableStream<Uint8Array> {\n if (this.response === null) {\n // If the response is null, return an empty stream. This behavior is\n // intentional as we're now providing the `RenderResult.EMPTY` value.\n return new ReadableStream<Uint8Array>({\n start(controller) {\n controller.close()\n },\n })\n }\n\n if (typeof this.response === 'string') {\n return streamFromString(this.response)\n }\n\n if (Buffer.isBuffer(this.response)) {\n return streamFromBuffer(this.response)\n }\n\n // If the response is an array of streams, then chain them together.\n if (Array.isArray(this.response)) {\n return chainStreams(...this.response)\n }\n\n return this.response\n }\n\n /**\n * Coerces the response to an array of streams. This will convert the response\n * to an array of streams if it is not already one.\n *\n * @returns An array of streams\n */\n private coerce(): ReadableStream<Uint8Array>[] {\n if (this.response === null) {\n // If the response is null, return an empty stream. This behavior is\n // intentional as we're now providing the `RenderResult.EMPTY` value.\n return []\n }\n\n if (typeof this.response === 'string') {\n return [streamFromString(this.response)]\n } else if (Array.isArray(this.response)) {\n return this.response\n } else if (Buffer.isBuffer(this.response)) {\n return [streamFromBuffer(this.response)]\n } else {\n return [this.response]\n }\n }\n\n /**\n * Unshifts a new stream to the response. This will convert the response to an\n * array of streams if it is not already one and will add the new stream to\n * the start of the array. When this response is piped, all of the streams\n * will be piped one after the other.\n *\n * @param readable The new stream to unshift\n */\n public unshift(readable: ReadableStream<Uint8Array>): void {\n // Coerce the response to an array of streams.\n this.response = this.coerce()\n\n // Add the new stream to the start of the array.\n this.response.unshift(readable)\n }\n\n /**\n * Chains a new stream to the response. This will convert the response to an\n * array of streams if it is not already one and will add the new stream to\n * the end. When this response is piped, all of the streams will be piped\n * one after the other.\n *\n * @param readable The new stream to chain\n */\n public push(readable: ReadableStream<Uint8Array>): void {\n // Coerce the response to an array of streams.\n this.response = this.coerce()\n\n // Add the new stream to the end of the array.\n this.response.push(readable)\n }\n\n /**\n * Pipes the response to a writable stream. This will close/cancel the\n * writable stream if an error is encountered. If this doesn't throw, then\n * the writable stream will be closed or aborted.\n *\n * @param writable Writable stream to pipe the response to\n */\n public async pipeTo(writable: WritableStream<Uint8Array>): Promise<void> {\n try {\n await this.readable.pipeTo(writable, {\n // We want to close the writable stream ourselves so that we can wait\n // for the waitUntil promise to resolve before closing it. If an error\n // is encountered, we'll abort the writable stream if we swallowed the\n // error.\n preventClose: true,\n })\n\n // If there is a waitUntil promise, wait for it to resolve before\n // closing the writable stream.\n if (this.waitUntil) await this.waitUntil\n\n // Close the writable stream.\n await writable.close()\n } catch (err) {\n // If this is an abort error, we should abort the writable stream (as we\n // took ownership of it when we started piping). We don't need to re-throw\n // because we handled the error.\n if (isAbortError(err)) {\n // Abort the writable stream if an error is encountered.\n await writable.abort(err)\n\n return\n }\n\n // We're not aborting the writer here as when this method throws it's not\n // clear as to how so the caller should assume it's their responsibility\n // to clean up the writer.\n throw err\n }\n }\n\n /**\n * Pipes the response to a node response. This will close/cancel the node\n * response if an error is encountered.\n *\n * @param res\n */\n public async pipeToNodeResponse(res: ServerResponse) {\n await pipeToNodeResponse(this.readable, res, this.waitUntil)\n }\n}\n","export const enum RouteKind {\n /**\n * `PAGES` represents all the React pages that are under `pages/`.\n */\n PAGES = 'PAGES',\n /**\n * `PAGES_API` represents all the API routes under `pages/api/`.\n */\n PAGES_API = 'PAGES_API',\n /**\n * `APP_PAGE` represents all the React pages that are under `app/` with the\n * filename of `page.{j,t}s{,x}`.\n */\n APP_PAGE = 'APP_PAGE',\n /**\n * `APP_ROUTE` represents all the API routes and metadata routes that are under `app/` with the\n * filename of `route.{j,t}s{,x}`.\n */\n APP_ROUTE = 'APP_ROUTE',\n\n /**\n * `IMAGE` represents all the images that are generated by `next/image`.\n */\n IMAGE = 'IMAGE',\n}\n","import {\n CachedRouteKind,\n IncrementalCacheKind,\n type CachedAppPageValue,\n type CachedPageValue,\n type IncrementalResponseCacheEntry,\n type ResponseCacheEntry,\n} from './types'\n\nimport RenderResult from '../render-result'\nimport { RouteKind } from '../route-kind'\nimport { HTML_CONTENT_TYPE_HEADER } from '../../lib/constants'\n\nexport async function fromResponseCacheEntry(\n cacheEntry: ResponseCacheEntry\n): Promise<IncrementalResponseCacheEntry> {\n return {\n ...cacheEntry,\n value:\n cacheEntry.value?.kind === CachedRouteKind.PAGES\n ? {\n kind: CachedRouteKind.PAGES,\n html: await cacheEntry.value.html.toUnchunkedString(true),\n pageData: cacheEntry.value.pageData,\n headers: cacheEntry.value.headers,\n status: cacheEntry.value.status,\n }\n : cacheEntry.value?.kind === CachedRouteKind.APP_PAGE\n ? {\n kind: CachedRouteKind.APP_PAGE,\n html: await cacheEntry.value.html.toUnchunkedString(true),\n postponed: cacheEntry.value.postponed,\n rscData: cacheEntry.value.rscData,\n headers: cacheEntry.value.headers,\n status: cacheEntry.value.status,\n segmentData: cacheEntry.value.segmentData,\n }\n : cacheEntry.value,\n }\n}\n\nexport async function toResponseCacheEntry(\n response: IncrementalResponseCacheEntry | null\n): Promise<ResponseCacheEntry | null> {\n if (!response) return null\n\n return {\n isMiss: response.isMiss,\n isStale: response.isStale,\n cacheControl: response.cacheControl,\n value:\n response.value?.kind === CachedRouteKind.PAGES\n ? ({\n kind: CachedRouteKind.PAGES,\n html: RenderResult.fromStatic(\n response.value.html,\n HTML_CONTENT_TYPE_HEADER\n ),\n pageData: response.value.pageData,\n headers: response.value.headers,\n status: response.value.status,\n } satisfies CachedPageValue)\n : response.value?.kind === CachedRouteKind.APP_PAGE\n ? ({\n kind: CachedRouteKind.APP_PAGE,\n html: RenderResult.fromStatic(\n response.value.html,\n HTML_CONTENT_TYPE_HEADER\n ),\n rscData: response.value.rscData,\n headers: response.value.headers,\n status: response.value.status,\n postponed: response.value.postponed,\n segmentData: response.value.segmentData,\n } satisfies CachedAppPageValue)\n : response.value,\n }\n}\n\nexport function routeKindToIncrementalCacheKind(\n routeKind: RouteKind\n): Exclude<IncrementalCacheKind, IncrementalCacheKind.FETCH> {\n switch (routeKind) {\n case RouteKind.PAGES:\n return IncrementalCacheKind.PAGES\n case RouteKind.APP_PAGE:\n return IncrementalCacheKind.APP_PAGE\n case RouteKind.IMAGE:\n return IncrementalCacheKind.IMAGE\n case RouteKind.APP_ROUTE:\n return IncrementalCacheKind.APP_ROUTE\n case RouteKind.PAGES_API:\n // Pages Router API routes are not cached in the incremental cache.\n throw new Error(`Unexpected route kind ${routeKind}`)\n default:\n return routeKind satisfies never\n }\n}\n","import type {\n ResponseCacheEntry,\n ResponseGenerator,\n ResponseCacheBase,\n IncrementalResponseCacheEntry,\n IncrementalResponseCache,\n} from './types'\n\nimport { Batcher } from '../../lib/batcher'\nimport { scheduleOnNextTick } from '../../lib/scheduler'\nimport {\n fromResponseCacheEntry,\n routeKindToIncrementalCacheKind,\n toResponseCacheEntry,\n} from './utils'\nimport type { RouteKind } from '../route-kind'\n\nexport * from './types'\n\nexport default class ResponseCache implements ResponseCacheBase {\n private readonly getBatcher = Batcher.create<\n { key: string; isOnDemandRevalidate: boolean },\n IncrementalResponseCacheEntry | null,\n string\n >({\n // Ensure on-demand revalidate doesn't block normal requests, it should be\n // safe to run an on-demand revalidate for the same key as a normal request.\n cacheKeyFn: ({ key, isOnDemandRevalidate }) =>\n `${key}-${isOnDemandRevalidate ? '1' : '0'}`,\n // We wait to do any async work until after we've added our promise to\n // `pendingResponses` to ensure that any any other calls will reuse the\n // same promise until we've fully finished our work.\n schedulerFn: scheduleOnNextTick,\n })\n\n private readonly revalidateBatcher = Batcher.create<\n string,\n IncrementalResponseCacheEntry | null\n >({\n // We wait to do any async work until after we've added our promise to\n // `pendingResponses` to ensure that any any other calls will reuse the\n // same promise until we've fully finished our work.\n schedulerFn: scheduleOnNextTick,\n })\n\n private previousCacheItem?: {\n key: string\n entry: IncrementalResponseCacheEntry | null\n expiresAt: number\n }\n\n // we don't use minimal_mode name here as this.minimal_mode is\n // statically replace for server runtimes but we need it to\n // be dynamic here\n private minimal_mode?: boolean\n\n constructor(minimal_mode: boolean) {\n this.minimal_mode = minimal_mode\n }\n\n /**\n * Gets the response cache entry for the given key.\n *\n * @param key - The key to get the response cache entry for.\n * @param responseGenerator - The response generator to use to generate the response cache entry.\n * @param context - The context for the get request.\n * @returns The response cache entry.\n */\n public async get(\n key: string | null,\n responseGenerator: ResponseGenerator,\n context: {\n routeKind: RouteKind\n isOnDemandRevalidate?: boolean\n isPrefetch?: boolean\n incrementalCache: IncrementalResponseCache\n isRoutePPREnabled?: boolean\n isFallback?: boolean\n waitUntil?: (prom: Promise<any>) => void\n }\n ): Promise<ResponseCacheEntry | null> {\n // If there is no key for the cache, we can't possibly look this up in the\n // cache so just return the result of the response generator.\n if (!key) {\n return responseGenerator({\n hasResolved: false,\n previousCacheEntry: null,\n })\n }\n\n // Check minimal mode cache before doing any other work\n if (\n this.minimal_mode &&\n this.previousCacheItem?.key === key &&\n this.previousCacheItem.expiresAt > Date.now()\n ) {\n return toResponseCacheEntry(this.previousCacheItem.entry)\n }\n\n const {\n incrementalCache,\n isOnDemandRevalidate = false,\n isFallback = false,\n isRoutePPREnabled = false,\n isPrefetch = false,\n waitUntil,\n routeKind,\n } = context\n\n const response = await this.getBatcher.batch(\n { key, isOnDemandRevalidate },\n ({ resolve }) => {\n const promise = this.handleGet(\n key,\n responseGenerator,\n {\n incrementalCache,\n isOnDemandRevalidate,\n isFallback,\n isRoutePPREnabled,\n isPrefetch,\n routeKind,\n },\n resolve\n )\n\n // We need to ensure background revalidates are passed to waitUntil.\n if (waitUntil) waitUntil(promise)\n\n return promise\n }\n )\n\n return toResponseCacheEntry(response)\n }\n\n /**\n * Handles the get request for the response cache.\n *\n * @param key - The key to get the response cache entry for.\n * @param responseGenerator - The response generator to use to generate the response cache entry.\n * @param context - The context for the get request.\n * @param resolve - The resolve function to use to resolve the response cache entry.\n * @returns The response cache entry.\n */\n private async handleGet(\n key: string,\n responseGenerator: ResponseGenerator,\n context: {\n incrementalCache: IncrementalResponseCache\n isOnDemandRevalidate: boolean\n isFallback: boolean\n isRoutePPREnabled: boolean\n isPrefetch: boolean\n routeKind: RouteKind\n },\n resolve: (value: IncrementalResponseCacheEntry | null) => void\n ): Promise<IncrementalResponseCacheEntry | null> {\n let previousIncrementalCacheEntry: IncrementalResponseCacheEntry | null =\n null\n let resolved = false\n\n try {\n // Get the previous cache entry if not in minimal mode\n previousIncrementalCacheEntry = !this.minimal_mode\n ? await context.incrementalCache.get(key, {\n kind: routeKindToIncrementalCacheKind(context.routeKind),\n isRoutePPREnabled: context.isRoutePPREnabled,\n isFallback: context.isFallback,\n })\n : null\n\n if (previousIncrementalCacheEntry && !context.isOnDemandRevalidate) {\n resolve(previousIncrementalCacheEntry)\n resolved = true\n\n if (!previousIncrementalCacheEntry.isStale || context.isPrefetch) {\n // The cached value is still valid, so we don't need to update it yet.\n return previousIncrementalCacheEntry\n }\n }\n\n // Revalidate the cache entry\n const incrementalResponseCacheEntry = await this.revalidate(\n key,\n context.incrementalCache,\n context.isRoutePPREnabled,\n context.isFallback,\n responseGenerator,\n previousIncrementalCacheEntry,\n previousIncrementalCacheEntry !== null && !context.isOnDemandRevalidate\n )\n\n // Handle null response\n if (!incrementalResponseCacheEntry) {\n // Unset the previous cache item if it was set so we don't use it again.\n if (this.minimal_mode) this.previousCacheItem = undefined\n return null\n }\n\n // Resolve for on-demand revalidation or if not already resolved\n if (context.isOnDemandRevalidate && !resolved) {\n return incrementalResponseCacheEntry\n }\n\n return incrementalResponseCacheEntry\n } catch (err) {\n // If we've already resolved the cache entry, we can't reject as we\n // already resolved the cache entry so log the error here.\n if (resolved) {\n console.error(err)\n return null\n }\n\n throw err\n }\n }\n\n /**\n * Revalidates the cache entry for the given key.\n *\n * @param key - The key to revalidate the cache entry for.\n * @param incrementalCache - The incremental cache to use to revalidate the cache entry.\n * @param isRoutePPREnabled - Whether the route is PPR enabled.\n * @param isFallback - Whether the route is a fallback.\n * @param responseGenerator - The response generator to use to generate the response cache entry.\n * @param previousIncrementalCacheEntry - The previous cache entry to use to revalidate the cache entry.\n * @param hasResolved - Whether the response has been resolved.\n * @returns The revalidated cache entry.\n */\n public async revalidate(\n key: string,\n incrementalCache: IncrementalResponseCache,\n isRoutePPREnabled: boolean,\n isFallback: boolean,\n responseGenerator: ResponseGenerator,\n previousIncrementalCacheEntry: IncrementalResponseCacheEntry | null,\n hasResolved: boolean,\n waitUntil?: (prom: Promise<any>) => void\n ) {\n return this.revalidateBatcher.batch(key, () => {\n const promise = this.handleRevalidate(\n key,\n incrementalCache,\n isRoutePPREnabled,\n isFallback,\n responseGenerator,\n previousIncrementalCacheEntry,\n hasResolved\n )\n\n // We need to ensure background revalidates are passed to waitUntil.\n if (waitUntil) waitUntil(promise)\n\n return promise\n })\n }\n\n private async handleRevalidate(\n key: string,\n incrementalCache: IncrementalResponseCache,\n isRoutePPREnabled: boolean,\n isFallback: boolean,\n responseGenerator: ResponseGenerator,\n previousIncrementalCacheEntry: IncrementalResponseCacheEntry | null,\n hasResolved: boolean\n ) {\n try {\n // Generate the response cache entry using the response generator.\n const responseCacheEntry = await responseGenerator({\n hasResolved,\n previousCacheEntry: previousIncrementalCacheEntry,\n isRevalidating: true,\n })\n if (!responseCacheEntry) {\n return null\n }\n\n // Convert the response cache entry to an incremental response cache entry.\n const incrementalResponseCacheEntry = await fromResponseCacheEntry({\n ...responseCacheEntry,\n isMiss: !previousIncrementalCacheEntry,\n })\n\n // We want to persist the result only if it has a cache control value\n // defined.\n if (incrementalResponseCacheEntry.cacheControl) {\n if (this.minimal_mode) {\n this.previousCacheItem = {\n key,\n entry: incrementalResponseCacheEntry,\n expiresAt: Date.now() + 1000,\n }\n } else {\n await incrementalCache.set(key, incrementalResponseCacheEntry.value, {\n cacheControl: incrementalResponseCacheEntry.cacheControl,\n isRoutePPREnabled,\n isFallback,\n })\n }\n }\n\n return incrementalResponseCacheEntry\n } catch (err) {\n // When a path is erroring we automatically re-set the existing cache\n // with new revalidate and expire times to prevent non-stop retrying.\n if (previousIncrementalCacheEntry?.cacheControl) {\n const revalidate = Math.min(\n Math.max(\n previousIncrementalCacheEntry.cacheControl.revalidate || 3,\n 3\n ),\n 30\n )\n const expire =\n previousIncrementalCacheEntry.cacheControl.expire === undefined\n ? undefined\n : Math.max(\n revalidate + 3,\n previousIncrementalCacheEntry.cacheControl.expire\n )\n\n await incrementalCache.set(key, previousIncrementalCacheEntry.value, {\n cacheControl: { revalidate: revalidate, expire: expire },\n isRoutePPREnabled,\n isFallback,\n })\n }\n\n // We haven't resolved yet, so let's throw to indicate an error.\n throw err\n }\n }\n}\n","import path from '../shared/lib/isomorphic/path'\nimport type { CacheFs } from '../shared/lib/utils'\n\n/**\n * A task to be written.\n */\ntype Task = [\n /**\n * The directory to create.\n */\n directory: string,\n\n /**\n * The promise to create the directory.\n */\n mkdir: Promise<unknown>,\n\n /**\n * The promises to write the files that are dependent on the directory being\n * created.\n */\n writeFile: Promise<unknown>[],\n]\n/**\n * MultiFileWriter is a utility for writing multiple files in parallel that\n * guarantees that all files will be written after their containing directory\n * is created, and that the directory will only be created once.\n */\nexport class MultiFileWriter {\n /**\n * The tasks to be written.\n */\n private readonly tasks: Task[] = []\n\n constructor(\n /**\n * The file system methods to use.\n */\n private readonly fs: Pick<CacheFs, 'mkdir' | 'writeFile'>\n ) {}\n\n /**\n * Finds or creates a task for a directory.\n *\n * @param directory - The directory to find or create a task for.\n * @returns The task for the directory.\n */\n private findOrCreateTask(directory: string): Task {\n // See if this directory already has a task to create it.\n for (const task of this.tasks) {\n if (task[0] === directory) {\n return task\n }\n }\n\n const promise = this.fs.mkdir(directory)\n\n // Attach a catch handler so that it doesn't throw an unhandled promise\n // rejection warning.\n promise.catch(() => {})\n\n // Otherwise, create a new task for this directory.\n const task: Task = [directory, promise, []]\n this.tasks.push(task)\n\n return task\n }\n\n /**\n * Appends a file to the writer to be written after its containing directory\n * is created. The file writer should be awaited after all the files have been\n * appended. Any async operation that occurs between appending and awaiting\n * may cause an unhandled promise rejection warning and potentially crash the\n * process.\n *\n * @param filePath - The path to the file to write.\n * @param data - The data to write to the file.\n */\n public append(filePath: string, data: Buffer | string): void {\n // Find or create a task for the directory that contains the file.\n const task = this.findOrCreateTask(path.dirname(filePath))\n\n const promise = task[1].then(() => this.fs.writeFile(filePath, data))\n\n // Attach a catch handler so that it doesn't throw an unhandled promise\n // rejection warning.\n promise.catch(() => {})\n\n // Add the file write to the task AFTER the directory promise has resolved.\n task[2].push(promise)\n }\n\n /**\n * Returns a promise that resolves when all the files have been written.\n */\n public wait(): Promise<unknown> {\n return Promise.all(this.tasks.flatMap((task) => task[2]))\n }\n}\n","import type { RouteMetadata } from '../../../export/routes/types'\nimport type { CacheHandler, CacheHandlerContext, CacheHandlerValue } from '.'\nimport type { CacheFs } from '../../../shared/lib/utils'\nimport type { TagManifestEntry } from './tags-manifest.external'\nimport {\n CachedRouteKind,\n IncrementalCacheKind,\n type CachedFetchValue,\n type IncrementalCacheValue,\n type SetIncrementalFetchCacheContext,\n type SetIncrementalResponseCacheContext,\n} from '../../response-cache'\n\nimport type { LRUCache } from '../lru-cache'\nimport path from '../../../shared/lib/isomorphic/path'\nimport {\n NEXT_CACHE_TAGS_HEADER,\n NEXT_DATA_SUFFIX,\n NEXT_META_SUFFIX,\n RSC_PREFETCH_SUFFIX,\n RSC_SEGMENT_SUFFIX,\n RSC_SEGMENTS_DIR_SUFFIX,\n RSC_SUFFIX,\n} from '../../../lib/constants'\nimport { areTagsExpired, tagsManifest } from './tags-manifest.external'\nimport { MultiFileWriter } from '../../../lib/multi-file-writer'\nimport { getMemoryCache } from './memory-cache.external'\n\ntype FileSystemCacheContext = Omit<\n CacheHandlerContext,\n 'fs' | 'serverDistDir'\n> & {\n fs: CacheFs\n serverDistDir: string\n}\n\nexport default class FileSystemCache implements CacheHandler {\n private fs: FileSystemCacheContext['fs']\n private flushToDisk?: FileSystemCacheContext['flushToDisk']\n private serverDistDir: FileSystemCacheContext['serverDistDir']\n private revalidatedTags: string[]\n private static debug: boolean = !!process.env.NEXT_PRIVATE_DEBUG_CACHE\n private static memoryCache: LRUCache<CacheHandlerValue> | undefined\n\n constructor(ctx: FileSystemCacheContext) {\n this.fs = ctx.fs\n this.flushToDisk = ctx.flushToDisk\n this.serverDistDir = ctx.serverDistDir\n this.revalidatedTags = ctx.revalidatedTags\n\n if (ctx.maxMemoryCacheSize) {\n if (!FileSystemCache.memoryCache) {\n if (FileSystemCache.debug) {\n console.log('FileSystemCache: using memory store for fetch cache')\n }\n\n FileSystemCache.memoryCache = getMemoryCache(ctx.maxMemoryCacheSize)\n } else if (FileSystemCache.debug) {\n console.log('FileSystemCache: memory store already initialized')\n }\n } else if (FileSystemCache.debug) {\n console.log('FileSystemCache: not using memory store for fetch cache')\n }\n }\n\n public resetRequestCache(): void {}\n\n public async revalidateTag(\n tags: string | string[],\n durations?: { expire?: number }\n ) {\n tags = typeof tags === 'string' ? [tags] : tags\n\n if (FileSystemCache.debug) {\n console.log('FileSystemCache: revalidateTag', tags, durations)\n }\n\n if (tags.length === 0) {\n return\n }\n\n const now = Date.now()\n\n for (const tag of tags) {\n const existingEntry = tagsManifest.get(tag) || {}\n\n if (durations) {\n // Use provided durations directly\n const updates: TagManifestEntry = { ...existingEntry }\n\n // mark as stale immediately\n updates.stale = now\n\n if (durations.expire !== undefined) {\n updates.expired = now + durations.expire * 1000 // Convert seconds to ms\n }\n\n tagsManifest.set(tag, updates)\n } else {\n // Update expired field for immediate expiration (default behavior when no durations provided)\n tagsManifest.set(tag, { ...existingEntry, expired: now })\n }\n }\n }\n\n public async get(...args: Parameters<CacheHandler['get']>) {\n const [key, ctx] = args\n const { kind } = ctx\n\n let data = FileSystemCache.memoryCache?.get(key)\n\n if (FileSystemCache.debug) {\n if (kind === IncrementalCacheKind.FETCH) {\n console.log('FileSystemCache: get', key, ctx.tags, kind, !!data)\n } else {\n console.log('FileSystemCache: get', key, kind, !!data)\n }\n }\n\n // let's check the disk for seed data\n if (!data && process.env.NEXT_RUNTIME !== 'edge') {\n try {\n if (kind === IncrementalCacheKind.APP_ROUTE) {\n const filePath = this.getFilePath(\n `${key}.body`,\n IncrementalCacheKind.APP_ROUTE\n )\n const fileData = await this.fs.readFile(filePath)\n const { mtime } = await this.fs.stat(filePath)\n\n const meta = JSON.parse(\n await this.fs.readFile(\n filePath.replace(/\\.body$/, NEXT_META_SUFFIX),\n 'utf8'\n )\n )\n\n data = {\n lastModified: mtime.getTime(),\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n body: fileData,\n headers: meta.headers,\n status: meta.status,\n },\n }\n } else {\n const filePath = this.getFilePath(\n kind === IncrementalCacheKind.FETCH ? key : `${key}.html`,\n kind\n )\n\n const fileData = await this.fs.readFile(filePath, 'utf8')\n const { mtime } = await this.fs.stat(filePath)\n\n if (kind === IncrementalCacheKind.FETCH) {\n const { tags, fetchIdx, fetchUrl } = ctx\n\n if (!this.flushToDisk) return null\n\n const lastModified = mtime.getTime()\n const parsedData: CachedFetchValue = JSON.parse(fileData)\n data = {\n lastModified,\n value: parsedData,\n }\n\n if (data.value?.kind === CachedRouteKind.FETCH) {\n const storedTags = data.value?.tags\n\n // update stored tags if a new one is being added\n // TODO: remove this when we can send the tags\n // via header on GET same as SET\n if (!tags?.every((tag) => storedTags?.includes(tag))) {\n if (FileSystemCache.debug) {\n console.log(\n 'FileSystemCache: tags vs storedTags mismatch',\n tags,\n storedTags\n )\n }\n await this.set(key, data.value, {\n fetchCache: true,\n tags,\n fetchIdx,\n fetchUrl,\n })\n }\n }\n } else if (kind === IncrementalCacheKind.APP_PAGE) {\n // We try to load the metadata file, but if it fails, we don't\n // error. We also don't load it if this is a fallback.\n let meta: RouteMetadata | undefined\n try {\n meta = JSON.parse(\n await this.fs.readFile(\n filePath.replace(/\\.html$/, NEXT_META_SUFFIX),\n 'utf8'\n )\n )\n } catch {}\n\n let maybeSegmentData: Map<string, Buffer> | undefined\n if (meta?.segmentPaths) {\n // Collect all the segment data for this page.\n // TODO: To optimize file system reads, we should consider creating\n // separate cache entries for each segment, rather than storing them\n // all on the page's entry. Though the behavior is\n // identical regardless.\n const segmentData: Map<string, Buffer> = new Map()\n maybeSegmentData = segmentData\n const segmentsDir = key + RSC_SEGMENTS_DIR_SUFFIX\n await Promise.all(\n meta.segmentPaths.map(async (segmentPath: string) => {\n const segmentDataFilePath = this.getFilePath(\n segmentsDir + segmentPath + RSC_SEGMENT_SUFFIX,\n IncrementalCacheKind.APP_PAGE\n )\n try {\n segmentData.set(\n segmentPath,\n await this.fs.readFile(segmentDataFilePath)\n )\n } catch {\n // This shouldn't happen, but if for some reason we fail to\n // load a segment from the filesystem, treat it the same as if\n // the segment is dynamic and does not have a prefetch.\n }\n })\n )\n }\n\n let rscData: Buffer | undefined\n if (!ctx.isFallback) {\n rscData = await this.fs.readFile(\n this.getFilePath(\n `${key}${ctx.isRoutePPREnabled ? RSC_PREFETCH_SUFFIX : RSC_SUFFIX}`,\n IncrementalCacheKind.APP_PAGE\n )\n )\n }\n\n data = {\n lastModified: mtime.getTime(),\n value: {\n kind: CachedRouteKind.APP_PAGE,\n html: fileData,\n rscData,\n postponed: meta?.postponed,\n headers: meta?.headers,\n status: meta?.status,\n segmentData: maybeSegmentData,\n },\n }\n } else if (kind === IncrementalCacheKind.PAGES) {\n let meta: RouteMetadata | undefined\n let pageData: string | object = {}\n\n if (!ctx.isFallback) {\n pageData = JSON.parse(\n await this.fs.readFile(\n this.getFilePath(\n `${key}${NEXT_DATA_SUFFIX}`,\n IncrementalCacheKind.PAGES\n ),\n 'utf8'\n )\n )\n }\n\n data = {\n lastModified: mtime.getTime(),\n value: {\n kind: CachedRouteKind.PAGES,\n html: fileData,\n pageData,\n headers: meta?.headers,\n status: meta?.status,\n },\n }\n } else {\n throw new Error(\n `Invariant: Unexpected route kind ${kind} in file system cache.`\n )\n }\n }\n\n if (data) {\n FileSystemCache.memoryCache?.set(key, data)\n }\n } catch {\n return null\n }\n }\n\n if (\n data?.value?.kind === CachedRouteKind.APP_PAGE ||\n data?.value?.kind === CachedRouteKind.APP_ROUTE ||\n data?.value?.kind === CachedRouteKind.PAGES\n ) {\n const tagsHeader = data.value.headers?.[NEXT_CACHE_TAGS_HEADER]\n if (typeof tagsHeader === 'string') {\n const cacheTags = tagsHeader.split(',')\n\n // we trigger a blocking validation if an ISR page\n // had a tag revalidated, if we want to be a background\n // revalidation instead we return data.lastModified = -1\n if (\n cacheTags.length > 0 &&\n areTagsExpired(cacheTags, data.lastModified)\n ) {\n if (FileSystemCache.debug) {\n console.log('FileSystemCache: expired tags', cacheTags)\n }\n\n return null\n }\n }\n } else if (data?.value?.kind === CachedRouteKind.FETCH) {\n const combinedTags =\n ctx.kind === IncrementalCacheKind.FETCH\n ? [...(ctx.tags || []), ...(ctx.softTags || [])]\n : []\n\n // When revalidate tag is called we don't return stale data so it's\n // updated right away.\n if (combinedTags.some((tag) => this.revalidatedTags.includes(tag))) {\n if (FileSystemCache.debug) {\n console.log('FileSystemCache: was revalidated', combinedTags)\n }\n\n return null\n }\n\n if (areTagsExpired(combinedTags, data.lastModified)) {\n if (FileSystemCache.debug) {\n console.log('FileSystemCache: expired tags', combinedTags)\n }\n\n return null\n }\n }\n\n return data ?? null\n }\n\n public async set(\n key: string,\n data: IncrementalCacheValue | null,\n ctx: SetIncrementalFetchCacheContext | SetIncrementalResponseCacheContext\n ) {\n FileSystemCache.memoryCache?.set(key, {\n value: data,\n lastModified: Date.now(),\n })\n\n if (FileSystemCache.debug) {\n console.log('FileSystemCache: set', key)\n }\n\n if (!this.flushToDisk || !data) return\n\n // Create a new writer that will prepare to write all the files to disk\n // after their containing directory is created.\n const writer = new MultiFileWriter(this.fs)\n\n if (data.kind === CachedRouteKind.APP_ROUTE) {\n const filePath = this.getFilePath(\n `${key}.body`,\n IncrementalCacheKind.APP_ROUTE\n )\n\n writer.append(filePath, data.body)\n\n const meta: RouteMetadata = {\n headers: data.headers,\n status: data.status,\n postponed: undefined,\n segmentPaths: undefined,\n }\n\n writer.append(\n filePath.replace(/\\.body$/, NEXT_META_SUFFIX),\n JSON.stringify(meta, null, 2)\n )\n } else if (\n data.kind === CachedRouteKind.PAGES ||\n data.kind === CachedRouteKind.APP_PAGE\n ) {\n const isAppPath = data.kind === CachedRouteKind.APP_PAGE\n const htmlPath = this.getFilePath(\n `${key}.html`,\n isAppPath ? IncrementalCacheKind.APP_PAGE : IncrementalCacheKind.PAGES\n )\n\n writer.append(htmlPath, data.html)\n\n // Fallbacks don't generate a data file.\n if (!ctx.fetchCache && !ctx.isFallback) {\n writer.append(\n this.getFilePath(\n `${key}${\n isAppPath\n ? ctx.isRoutePPREnabled\n ? RSC_PREFETCH_SUFFIX\n : RSC_SUFFIX\n : NEXT_DATA_SUFFIX\n }`,\n isAppPath\n ? IncrementalCacheKind.APP_PAGE\n : IncrementalCacheKind.PAGES\n ),\n isAppPath ? data.rscData! : JSON.stringify(data.pageData)\n )\n }\n\n if (data?.kind === CachedRouteKind.APP_PAGE) {\n let segmentPaths: string[] | undefined\n if (data.segmentData) {\n segmentPaths = []\n const segmentsDir = htmlPath.replace(\n /\\.html$/,\n RSC_SEGMENTS_DIR_SUFFIX\n )\n\n for (const [segmentPath, buffer] of data.segmentData) {\n segmentPaths.push(segmentPath)\n const segmentDataFilePath =\n segmentsDir + segmentPath + RSC_SEGMENT_SUFFIX\n writer.append(segmentDataFilePath, buffer)\n }\n }\n\n const meta: RouteMetadata = {\n headers: data.headers,\n status: data.status,\n postponed: data.postponed,\n segmentPaths,\n }\n\n writer.append(\n htmlPath.replace(/\\.html$/, NEXT_META_SUFFIX),\n JSON.stringify(meta)\n )\n }\n } else if (data.kind === CachedRouteKind.FETCH) {\n const filePath = this.getFilePath(key, IncrementalCacheKind.FETCH)\n writer.append(\n filePath,\n JSON.stringify({\n ...data,\n tags: ctx.fetchCache ? ctx.tags : [],\n })\n )\n }\n\n // Wait for all FS operations to complete.\n await writer.wait()\n }\n\n private getFilePath(pathname: string, kind: IncrementalCacheKind): string {\n switch (kind) {\n case IncrementalCacheKind.FETCH:\n // we store in .next/cache/fetch-cache so it can be persisted\n // across deploys\n return path.join(\n this.serverDistDir,\n '..',\n 'cache',\n 'fetch-cache',\n pathname\n )\n case IncrementalCacheKind.PAGES:\n return path.join(this.serverDistDir, 'pages', pathname)\n case IncrementalCacheKind.IMAGE:\n case IncrementalCacheKind.APP_PAGE:\n case IncrementalCacheKind.APP_ROUTE:\n return path.join(this.serverDistDir, 'app', pathname)\n default:\n throw new Error(`Unexpected file path kind: ${kind}`)\n }\n }\n}\n","/**\n * This transforms a URL pathname into a route. It removes any trailing slashes\n * and the `/index` suffix.\n *\n * @param pathname - The URL path that needs to be optimized.\n * @returns - The route\n *\n * @example\n * // returns '/example'\n * toRoute('/example/index/');\n *\n * @example\n * // returns '/example'\n * toRoute('/example/');\n *\n * @example\n * // returns '/'\n * toRoute('/index/');\n *\n * @example\n * // returns '/'\n * toRoute('/');\n */\nexport function toRoute(pathname: string): string {\n return pathname.replace(/(?:\\/index)?\\/?$/, '') || '/'\n}\n","import type { CacheFs } from '../../../shared/lib/utils'\nimport type { PrerenderManifest } from '../../../build'\nimport {\n type IncrementalCacheValue,\n type IncrementalCacheEntry,\n type IncrementalCache as IncrementalCacheType,\n IncrementalCacheKind,\n CachedRouteKind,\n type IncrementalResponseCacheEntry,\n type IncrementalFetchCacheEntry,\n type GetIncrementalFetchCacheContext,\n type GetIncrementalResponseCacheContext,\n type CachedFetchValue,\n type SetIncrementalFetchCacheContext,\n type SetIncrementalResponseCacheContext,\n} from '../../response-cache'\nimport type { DeepReadonly } from '../../../shared/lib/deep-readonly'\nimport FileSystemCache from './file-system-cache'\nimport { normalizePagePath } from '../../../shared/lib/page-path/normalize-page-path'\n\nimport {\n CACHE_ONE_YEAR,\n NEXT_CACHE_TAGS_HEADER,\n PRERENDER_REVALIDATE_HEADER,\n} from '../../../lib/constants'\nimport { toRoute } from '../to-route'\nimport { SharedCacheControls } from './shared-cache-controls.external'\nimport {\n getPrerenderResumeDataCache,\n getRenderResumeDataCache,\n workUnitAsyncStorage,\n} from '../../app-render/work-unit-async-storage.external'\nimport { InvariantError } from '../../../shared/lib/invariant-error'\nimport type { Revalidate } from '../cache-control'\nimport { getPreviouslyRevalidatedTags } from '../../server-utils'\nimport { workAsyncStorage } from '../../app-render/work-async-storage.external'\nimport { DetachedPromise } from '../../../lib/detached-promise'\nimport { areTagsExpired, areTagsStale } from './tags-manifest.external'\n\nexport interface CacheHandlerContext {\n fs?: CacheFs\n dev?: boolean\n flushToDisk?: boolean\n serverDistDir?: string\n maxMemoryCacheSize?: number\n fetchCacheKeyPrefix?: string\n prerenderManifest?: PrerenderManifest\n revalidatedTags: string[]\n _requestHeaders: IncrementalCache['requestHeaders']\n}\n\nexport interface CacheHandlerValue {\n lastModified: number\n age?: number\n cacheState?: string\n value: IncrementalCacheValue | null\n}\n\nexport class CacheHandler {\n // eslint-disable-next-line\n constructor(_ctx: CacheHandlerContext) {}\n\n public async get(\n _cacheKey: string,\n _ctx: GetIncrementalFetchCacheContext | GetIncrementalResponseCacheContext\n ): Promise<CacheHandlerValue | null> {\n return {} as any\n }\n\n public async set(\n _cacheKey: string,\n _data: IncrementalCacheValue | null,\n _ctx: SetIncrementalFetchCacheContext | SetIncrementalResponseCacheContext\n ): Promise<void> {}\n\n public async revalidateTag(\n _tags: string | string[],\n _durations?: { expire?: number }\n ): Promise<void> {}\n\n public resetRequestCache(): void {}\n}\n\nexport class IncrementalCache implements IncrementalCacheType {\n readonly dev?: boolean\n readonly disableForTestmode?: boolean\n readonly cacheHandler?: CacheHandler\n readonly hasCustomCacheHandler: boolean\n readonly prerenderManifest: DeepReadonly<PrerenderManifest>\n readonly requestHeaders: Record<string, undefined | string | string[]>\n readonly allowedRevalidateHeaderKeys?: string[]\n readonly minimalMode?: boolean\n readonly fetchCacheKeyPrefix?: string\n readonly isOnDemandRevalidate?: boolean\n readonly revalidatedTags?: readonly string[]\n\n private static readonly debug: boolean =\n !!process.env.NEXT_PRIVATE_DEBUG_CACHE\n private readonly locks = new Map<string, Promise<void>>()\n\n /**\n * The cache controls for routes. This will source the values from the\n * prerender manifest until the in-memory cache is updated with new values.\n */\n private readonly cacheControls: SharedCacheControls\n\n constructor({\n fs,\n dev,\n flushToDisk,\n minimalMode,\n serverDistDir,\n requestHeaders,\n maxMemoryCacheSize,\n getPrerenderManifest,\n fetchCacheKeyPrefix,\n CurCacheHandler,\n allowedRevalidateHeaderKeys,\n }: {\n fs?: CacheFs\n dev: boolean\n minimalMode?: boolean\n serverDistDir?: string\n flushToDisk?: boolean\n allowedRevalidateHeaderKeys?: string[]\n requestHeaders: IncrementalCache['requestHeaders']\n maxMemoryCacheSize?: number\n getPrerenderManifest: () => DeepReadonly<PrerenderManifest>\n fetchCacheKeyPrefix?: string\n CurCacheHandler?: typeof CacheHandler\n }) {\n this.hasCustomCacheHandler = Boolean(CurCacheHandler)\n\n const cacheHandlersSymbol = Symbol.for('@next/cache-handlers')\n const _globalThis: typeof globalThis & {\n [cacheHandlersSymbol]?: {\n FetchCache?: typeof CacheHandler\n }\n } = globalThis\n\n if (!CurCacheHandler) {\n // if we have a global cache handler available leverage it\n const globalCacheHandler = _globalThis[cacheHandlersSymbol]\n\n if (globalCacheHandler?.FetchCache) {\n CurCacheHandler = globalCacheHandler.FetchCache\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: using global FetchCache cache handler')\n }\n } else {\n if (fs && serverDistDir) {\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: using filesystem cache handler')\n }\n CurCacheHandler = FileSystemCache\n }\n }\n } else if (IncrementalCache.debug) {\n console.log(\n 'IncrementalCache: using custom cache handler',\n CurCacheHandler.name\n )\n }\n\n if (process.env.__NEXT_TEST_MAX_ISR_CACHE) {\n // Allow cache size to be overridden for testing purposes\n maxMemoryCacheSize = parseInt(process.env.__NEXT_TEST_MAX_ISR_CACHE, 10)\n }\n this.dev = dev\n this.disableForTestmode = process.env.NEXT_PRIVATE_TEST_PROXY === 'true'\n // this is a hack to avoid Webpack knowing this is equal to this.minimalMode\n // because we replace this.minimalMode to true in production bundles.\n const minimalModeKey = 'minimalMode'\n this[minimalModeKey] = minimalMode\n this.requestHeaders = requestHeaders\n this.allowedRevalidateHeaderKeys = allowedRevalidateHeaderKeys\n this.prerenderManifest = getPrerenderManifest()\n this.cacheControls = new SharedCacheControls(this.prerenderManifest)\n this.fetchCacheKeyPrefix = fetchCacheKeyPrefix\n let revalidatedTags: string[] = []\n\n if (\n requestHeaders[PRERENDER_REVALIDATE_HEADER] ===\n this.prerenderManifest?.preview?.previewModeId\n ) {\n this.isOnDemandRevalidate = true\n }\n\n if (minimalMode) {\n revalidatedTags = this.revalidatedTags = getPreviouslyRevalidatedTags(\n requestHeaders,\n this.prerenderManifest?.preview?.previewModeId\n )\n }\n\n if (CurCacheHandler) {\n this.cacheHandler = new CurCacheHandler({\n dev,\n fs,\n flushToDisk,\n serverDistDir,\n revalidatedTags,\n maxMemoryCacheSize,\n _requestHeaders: requestHeaders,\n fetchCacheKeyPrefix,\n })\n }\n }\n\n private calculateRevalidate(\n pathname: string,\n fromTime: number,\n dev: boolean,\n isFallback: boolean | undefined\n ): Revalidate {\n // in development we don't have a prerender-manifest\n // and default to always revalidating to allow easier debugging\n if (dev)\n return Math.floor(performance.timeOrigin + performance.now() - 1000)\n\n const cacheControl = this.cacheControls.get(toRoute(pathname))\n\n // if an entry isn't present in routes we fallback to a default\n // of revalidating after 1 second unless it's a fallback request.\n const initialRevalidateSeconds = cacheControl\n ? cacheControl.revalidate\n : isFallback\n ? false\n : 1\n\n const revalidateAfter =\n typeof initialRevalidateSeconds === 'number'\n ? initialRevalidateSeconds * 1000 + fromTime\n : initialRevalidateSeconds\n\n return revalidateAfter\n }\n\n _getPathname(pathname: string, fetchCache?: boolean) {\n return fetchCache ? pathname : normalizePagePath(pathname)\n }\n\n resetRequestCache() {\n this.cacheHandler?.resetRequestCache?.()\n }\n\n async lock(cacheKey: string): Promise<() => Promise<void> | void> {\n // Wait for any existing lock on this cache key to be released\n // This implements a simple queue-based locking mechanism\n while (true) {\n const lock = this.locks.get(cacheKey)\n\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: lock get', cacheKey, !!lock)\n }\n\n // If no lock exists, we can proceed to acquire it\n if (!lock) break\n\n // Wait for the existing lock to be released before trying again\n await lock\n }\n\n // Create a new detached promise that will represent this lock\n // The resolve function (unlock) will be returned to the caller\n const { resolve, promise } = new DetachedPromise<void>()\n\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: successfully locked', cacheKey)\n }\n\n // Store the lock promise in the locks map\n this.locks.set(cacheKey, promise)\n\n return () => {\n // Resolve the promise to release the lock.\n resolve()\n\n // Remove the lock from the map once it's released so that future gets\n // can acquire the lock.\n this.locks.delete(cacheKey)\n }\n }\n\n async revalidateTag(\n tags: string | string[],\n durations?: { expire?: number }\n ): Promise<void> {\n return this.cacheHandler?.revalidateTag(tags, durations)\n }\n\n // x-ref: https://github.com/facebook/react/blob/2655c9354d8e1c54ba888444220f63e836925caa/packages/react/src/ReactFetch.js#L23\n async generateCacheKey(\n url: string,\n init: RequestInit | Request = {}\n ): Promise<string> {\n // this should be bumped anytime a fix is made to cache entries\n // that should bust the cache\n const MAIN_KEY_PREFIX = 'v3'\n\n const bodyChunks: string[] = []\n\n const encoder = new TextEncoder()\n const decoder = new TextDecoder()\n\n if (init.body) {\n // handle Uint8Array body\n if (init.body instanceof Uint8Array) {\n bodyChunks.push(decoder.decode(init.body))\n ;(init as any)._ogBody = init.body\n } // handle ReadableStream body\n else if (typeof (init.body as any).getReader === 'function') {\n const readableBody = init.body as ReadableStream<Uint8Array | string>\n\n const chunks: Uint8Array[] = []\n\n try {\n await readableBody.pipeTo(\n new WritableStream({\n write(chunk) {\n if (typeof chunk === 'string') {\n chunks.push(encoder.encode(chunk))\n bodyChunks.push(chunk)\n } else {\n chunks.push(chunk)\n bodyChunks.push(decoder.decode(chunk, { stream: true }))\n }\n },\n })\n )\n\n // Flush the decoder.\n bodyChunks.push(decoder.decode())\n\n // Create a new buffer with all the chunks.\n const length = chunks.reduce((total, arr) => total + arr.length, 0)\n const arrayBuffer = new Uint8Array(length)\n\n // Push each of the chunks into the new array buffer.\n let offset = 0\n for (const chunk of chunks) {\n arrayBuffer.set(chunk, offset)\n offset += chunk.length\n }\n\n ;(init as any)._ogBody = arrayBuffer\n } catch (err) {\n console.error('Problem reading body', err)\n }\n } // handle FormData or URLSearchParams bodies\n else if (typeof (init.body as any).keys === 'function') {\n const formData = init.body as FormData\n ;(init as any)._ogBody = init.body\n for (const key of new Set([...formData.keys()])) {\n const values = formData.getAll(key)\n bodyChunks.push(\n `${key}=${(\n await Promise.all(\n values.map(async (val) => {\n if (typeof val === 'string') {\n return val\n } else {\n return await val.text()\n }\n })\n )\n ).join(',')}`\n )\n }\n // handle blob body\n } else if (typeof (init.body as any).arrayBuffer === 'function') {\n const blob = init.body as Blob\n const arrayBuffer = await blob.arrayBuffer()\n bodyChunks.push(await blob.text())\n ;(init as any)._ogBody = new Blob([arrayBuffer], { type: blob.type })\n } else if (typeof init.body === 'string') {\n bodyChunks.push(init.body)\n ;(init as any)._ogBody = init.body\n }\n }\n\n const headers =\n typeof (init.headers || {}).keys === 'function'\n ? Object.fromEntries(init.headers as Headers)\n : Object.assign({}, init.headers)\n\n // w3c trace context headers can break request caching and deduplication\n // so we remove them from the cache key\n if ('traceparent' in headers) delete headers['traceparent']\n if ('tracestate' in headers) delete headers['tracestate']\n\n const cacheString = JSON.stringify([\n MAIN_KEY_PREFIX,\n this.fetchCacheKeyPrefix || '',\n url,\n init.method,\n headers,\n init.mode,\n init.redirect,\n init.credentials,\n init.referrer,\n init.referrerPolicy,\n init.integrity,\n init.cache,\n bodyChunks,\n ])\n\n if (process.env.NEXT_RUNTIME === 'edge') {\n function bufferToHex(buffer: ArrayBuffer): string {\n return Array.prototype.map\n .call(new Uint8Array(buffer), (b) => b.toString(16).padStart(2, '0'))\n .join('')\n }\n const buffer = encoder.encode(cacheString)\n return bufferToHex(await crypto.subtle.digest('SHA-256', buffer))\n } else {\n const crypto = require('crypto') as typeof import('crypto')\n return crypto.createHash('sha256').update(cacheString).digest('hex')\n }\n }\n\n async get(\n cacheKey: string,\n ctx: GetIncrementalFetchCacheContext\n ): Promise<IncrementalFetchCacheEntry | null>\n async get(\n cacheKey: string,\n ctx: GetIncrementalResponseCacheContext\n ): Promise<IncrementalResponseCacheEntry | null>\n async get(\n cacheKey: string,\n ctx: GetIncrementalFetchCacheContext | GetIncrementalResponseCacheContext\n ): Promise<IncrementalCacheEntry | null> {\n // Unlike other caches if we have a resume data cache, we use it even if\n // testmode would normally disable it or if requestHeaders say 'no-cache'.\n if (ctx.kind === IncrementalCacheKind.FETCH) {\n const workUnitStore = workUnitAsyncStorage.getStore()\n const resumeDataCache = workUnitStore\n ? getRenderResumeDataCache(workUnitStore)\n : null\n if (resumeDataCache) {\n const memoryCacheData = resumeDataCache.fetch.get(cacheKey)\n if (memoryCacheData?.kind === CachedRouteKind.FETCH) {\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: rdc:hit', cacheKey)\n }\n\n return { isStale: false, value: memoryCacheData }\n } else if (IncrementalCache.debug) {\n console.log('IncrementalCache: rdc:miss', cacheKey)\n }\n } else {\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: rdc:no-resume-data')\n }\n }\n }\n\n // we don't leverage the prerender cache in dev mode\n // so that getStaticProps is always called for easier debugging\n if (\n this.disableForTestmode ||\n (this.dev &&\n (ctx.kind !== IncrementalCacheKind.FETCH ||\n this.requestHeaders['cache-control'] === 'no-cache'))\n ) {\n return null\n }\n\n cacheKey = this._getPathname(\n cacheKey,\n ctx.kind === IncrementalCacheKind.FETCH\n )\n\n const cacheData = await this.cacheHandler?.get(cacheKey, ctx)\n\n if (ctx.kind === IncrementalCacheKind.FETCH) {\n if (!cacheData) {\n return null\n }\n\n if (cacheData.value?.kind !== CachedRouteKind.FETCH) {\n throw new InvariantError(\n `Expected cached value for cache key ${JSON.stringify(cacheKey)} to be a \"FETCH\" kind, got ${JSON.stringify(cacheData.value?.kind)} instead.`\n )\n }\n\n const workStore = workAsyncStorage.getStore()\n const combinedTags = [...(ctx.tags || []), ...(ctx.softTags || [])]\n // if a tag was revalidated we don't return stale data\n if (\n combinedTags.some(\n (tag) =>\n this.revalidatedTags?.includes(tag) ||\n workStore?.pendingRevalidatedTags?.some((item) => item.tag === tag)\n )\n ) {\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: expired tag', cacheKey)\n }\n\n return null\n }\n\n // As we're able to get the cache entry for this fetch, and the prerender\n // resume data cache (RDC) is available, it must have been populated by a\n // previous fetch, but was not yet present in the in-memory cache. This\n // could be the case when performing multiple renders in parallel during\n // build time where we de-duplicate the fetch calls.\n //\n // We add it to the RDC so that the next fetch call will be able to use it\n // and it won't have to reach into the fetch cache implementation.\n const workUnitStore = workUnitAsyncStorage.getStore()\n if (workUnitStore) {\n const prerenderResumeDataCache =\n getPrerenderResumeDataCache(workUnitStore)\n if (prerenderResumeDataCache) {\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: rdc:set', cacheKey)\n }\n\n prerenderResumeDataCache.fetch.set(cacheKey, cacheData.value)\n }\n }\n\n const revalidate = ctx.revalidate || cacheData.value.revalidate\n const age =\n (performance.timeOrigin +\n performance.now() -\n (cacheData.lastModified || 0)) /\n 1000\n\n let isStale = age > revalidate\n const data = cacheData.value.data\n\n if (areTagsExpired(combinedTags, cacheData.lastModified)) {\n return null\n } else if (areTagsStale(combinedTags, cacheData.lastModified)) {\n isStale = true\n }\n\n return {\n isStale,\n value: { kind: CachedRouteKind.FETCH, data, revalidate },\n }\n } else if (cacheData?.value?.kind === CachedRouteKind.FETCH) {\n throw new InvariantError(\n `Expected cached value for cache key ${JSON.stringify(cacheKey)} not to be a ${JSON.stringify(ctx.kind)} kind, got \"FETCH\" instead.`\n )\n }\n\n let entry: IncrementalResponseCacheEntry | null = null\n const cacheControl = this.cacheControls.get(toRoute(cacheKey))\n\n let isStale: boolean | -1 | undefined\n let revalidateAfter: Revalidate\n\n if (cacheData?.lastModified === -1) {\n isStale = -1\n revalidateAfter = -1 * CACHE_ONE_YEAR\n } else {\n const now = performance.timeOrigin + performance.now()\n const lastModified = cacheData?.lastModified || now\n\n revalidateAfter = this.calculateRevalidate(\n cacheKey,\n lastModified,\n this.dev ?? false,\n ctx.isFallback\n )\n\n isStale =\n revalidateAfter !== false && revalidateAfter < now ? true : undefined\n\n // If the stale time couldn't be determined based on the revalidation\n // time, we check if the tags are expired or stale.\n if (\n isStale === undefined &&\n (cacheData?.value?.kind === CachedRouteKind.APP_PAGE ||\n cacheData?.value?.kind === CachedRouteKind.APP_ROUTE)\n ) {\n const tagsHeader = cacheData.value.headers?.[NEXT_CACHE_TAGS_HEADER]\n\n if (typeof tagsHeader === 'string') {\n const cacheTags = tagsHeader.split(',')\n\n if (cacheTags.length > 0) {\n if (areTagsExpired(cacheTags, lastModified)) {\n isStale = -1\n } else if (areTagsStale(cacheTags, lastModified)) {\n isStale = true\n }\n }\n }\n }\n }\n\n if (cacheData) {\n entry = {\n isStale,\n cacheControl,\n revalidateAfter,\n value: cacheData.value,\n }\n }\n\n if (\n !cacheData &&\n this.prerenderManifest.notFoundRoutes.includes(cacheKey)\n ) {\n // for the first hit after starting the server the cache\n // may not have a way to save notFound: true so if\n // the prerender-manifest marks this as notFound then we\n // return that entry and trigger a cache set to give it a\n // chance to update in-memory entries\n entry = {\n isStale,\n value: null,\n cacheControl,\n revalidateAfter,\n }\n this.set(cacheKey, entry.value, { ...ctx, cacheControl })\n }\n return entry\n }\n\n async set(\n pathname: string,\n data: CachedFetchValue | null,\n ctx: SetIncrementalFetchCacheContext\n ): Promise<void>\n async set(\n pathname: string,\n data: Exclude<IncrementalCacheValue, CachedFetchValue> | null,\n ctx: SetIncrementalResponseCacheContext\n ): Promise<void>\n async set(\n pathname: string,\n data: IncrementalCacheValue | null,\n ctx: SetIncrementalFetchCacheContext | SetIncrementalResponseCacheContext\n ): Promise<void> {\n // Even if we otherwise disable caching for testMode or if no fetchCache is\n // configured we still always stash results in the resume data cache if one\n // exists. This is because this is a transient in memory cache that\n // populates caches ahead of a dynamic render in dev mode to allow the RSC\n // debug info to have the right environment associated to it.\n if (data?.kind === CachedRouteKind.FETCH) {\n const workUnitStore = workUnitAsyncStorage.getStore()\n const prerenderResumeDataCache = workUnitStore\n ? getPrerenderResumeDataCache(workUnitStore)\n : null\n if (prerenderResumeDataCache) {\n if (IncrementalCache.debug) {\n console.log('IncrementalCache: rdc:set', pathname)\n }\n\n prerenderResumeDataCache.fetch.set(pathname, data)\n }\n }\n\n if (this.disableForTestmode || (this.dev && !ctx.fetchCache)) return\n\n pathname = this._getPathname(pathname, ctx.fetchCache)\n\n // FetchCache has upper limit of 2MB per-entry currently\n const itemSize = JSON.stringify(data).length\n if (\n ctx.fetchCache &&\n itemSize > 2 * 1024 * 1024 &&\n // We ignore the size limit when custom cache handler is being used, as it\n // might not have this limit\n !this.hasCustomCacheHandler &&\n // We also ignore the size limit when it's an implicit build-time-only\n // caching that the user isn't even aware of.\n !ctx.isImplicitBuildTimeCache\n ) {\n const warningText = `Failed to set Next.js data cache for ${ctx.fetchUrl || pathname}, items over 2MB can not be cached (${itemSize} bytes)`\n\n if (this.dev) {\n throw new Error(warningText)\n }\n console.warn(warningText)\n return\n }\n\n try {\n if (!ctx.fetchCache && ctx.cacheControl) {\n this.cacheControls.set(toRoute(pathname), ctx.cacheControl)\n }\n\n await this.cacheHandler?.set(pathname, data, ctx)\n } catch (error) {\n console.warn('Failed to update prerender cache for', pathname, error)\n }\n }\n}\n","/**\n * Node in the doubly-linked list used for LRU tracking.\n * Each node represents a cache entry with bidirectional pointers.\n */\nclass LRUNode<T> {\n public readonly key: string\n public data: T\n public size: number\n public prev: LRUNode<T> | SentinelNode<T> | null = null\n public next: LRUNode<T> | SentinelNode<T> | null = null\n\n constructor(key: string, data: T, size: number) {\n this.key = key\n this.data = data\n this.size = size\n }\n}\n\n/**\n * Sentinel node used for head/tail boundaries.\n * These nodes don't contain actual cache data but simplify list operations.\n */\nclass SentinelNode<T> {\n public prev: LRUNode<T> | SentinelNode<T> | null = null\n public next: LRUNode<T> | SentinelNode<T> | null = null\n}\n\n/**\n * LRU (Least Recently Used) Cache implementation using a doubly-linked list\n * and hash map for O(1) operations.\n *\n * Algorithm:\n * - Uses a doubly-linked list to maintain access order (most recent at head)\n * - Hash map provides O(1) key-to-node lookup\n * - Sentinel head/tail nodes simplify edge case handling\n * - Size-based eviction supports custom size calculation functions\n *\n * Data Structure Layout:\n * HEAD <-> [most recent] <-> ... <-> [least recent] <-> TAIL\n *\n * Operations:\n * - get(): Move accessed node to head (mark as most recent)\n * - set(): Add new node at head, evict from tail if over capacity\n * - Eviction: Remove least recent node (tail.prev) when size exceeds limit\n */\nexport class LRUCache<T> {\n private readonly cache: Map<string, LRUNode<T>> = new Map()\n private readonly head: SentinelNode<T>\n private readonly tail: SentinelNode<T>\n private totalSize: number = 0\n private readonly maxSize: number\n private readonly calculateSize: ((value: T) => number) | undefined\n\n constructor(maxSize: number, calculateSize?: (value: T) => number) {\n this.maxSize = maxSize\n this.calculateSize = calculateSize\n\n // Create sentinel nodes to simplify doubly-linked list operations\n // HEAD <-> TAIL (empty list)\n this.head = new SentinelNode<T>()\n this.tail = new SentinelNode<T>()\n this.head.next = this.tail\n this.tail.prev = this.head\n }\n\n /**\n * Adds a node immediately after the head (marks as most recently used).\n * Used when inserting new items or when an item is accessed.\n * PRECONDITION: node must be disconnected (prev/next should be null)\n */\n private addToHead(node: LRUNode<T>): void {\n node.prev = this.head\n node.next = this.head.next\n // head.next is always non-null (points to tail or another node)\n this.head.next!.prev = node\n this.head.next = node\n }\n\n /**\n * Removes a node from its current position in the doubly-linked list.\n * Updates the prev/next pointers of adjacent nodes to maintain list integrity.\n * PRECONDITION: node must be connected (prev/next are non-null)\n */\n private removeNode(node: LRUNode<T>): void {\n // Connected nodes always have non-null prev/next\n node.prev!.next = node.next\n node.next!.prev = node.prev\n }\n\n /**\n * Moves an existing node to the head position (marks as most recently used).\n * This is the core LRU operation - accessed items become most recent.\n */\n private moveToHead(node: LRUNode<T>): void {\n this.removeNode(node)\n this.addToHead(node)\n }\n\n /**\n * Removes and returns the least recently used node (the one before tail).\n * This is called during eviction when the cache exceeds capacity.\n * PRECONDITION: cache is not empty (ensured by caller)\n */\n private removeTail(): LRUNode<T> {\n const lastNode = this.tail.prev as LRUNode<T>\n // tail.prev is always non-null and always LRUNode when cache is not empty\n this.removeNode(lastNode)\n return lastNode\n }\n\n /**\n * Sets a key-value pair in the cache.\n * If the key exists, updates the value and moves to head.\n * If new, adds at head and evicts from tail if necessary.\n *\n * Time Complexity:\n * - O(1) for uniform item sizes\n * - O(k) where k is the number of items evicted (can be O(N) for variable sizes)\n */\n public set(key: string, value: T): void {\n const size = this.calculateSize?.(value) ?? 1\n if (size > this.maxSize) {\n console.warn('Single item size exceeds maxSize')\n return\n }\n\n const existing = this.cache.get(key)\n if (existing) {\n // Update existing node: adjust size and move to head (most recent)\n existing.data = value\n this.totalSize = this.totalSize - existing.size + size\n existing.size = size\n this.moveToHead(existing)\n } else {\n // Add new node at head (most recent position)\n const newNode = new LRUNode(key, value, size)\n this.cache.set(key, newNode)\n this.addToHead(newNode)\n this.totalSize += size\n }\n\n // Evict least recently used items until under capacity\n while (this.totalSize > this.maxSize && this.cache.size > 0) {\n const tail = this.removeTail()\n this.cache.delete(tail.key)\n this.totalSize -= tail.size\n }\n }\n\n /**\n * Checks if a key exists in the cache.\n * This is a pure query operation - does NOT update LRU order.\n *\n * Time Complexity: O(1)\n */\n public has(key: string): boolean {\n return this.cache.has(key)\n }\n\n /**\n * Retrieves a value by key and marks it as most recently used.\n * Moving to head maintains the LRU property for future evictions.\n *\n * Time Complexity: O(1)\n */\n public get(key: string): T | undefined {\n const node = this.cache.get(key)\n if (!node) return undefined\n\n // Mark as most recently used by moving to head\n this.moveToHead(node)\n\n return node.data\n }\n\n /**\n * Returns an iterator over the cache entries. The order is outputted in the\n * order of most recently used to least recently used.\n */\n public *[Symbol.iterator](): IterableIterator<[string, T]> {\n let current = this.head.next\n while (current && current !== this.tail) {\n // Between head and tail, current is always LRUNode\n const node = current as LRUNode<T>\n yield [node.key, node.data]\n current = current.next\n }\n }\n\n /**\n * Removes a specific key from the cache.\n * Updates both the hash map and doubly-linked list.\n *\n * Time Complexity: O(1)\n */\n public remove(key: string): void {\n const node = this.cache.get(key)\n if (!node) return\n\n this.removeNode(node)\n this.cache.delete(key)\n this.totalSize -= node.size\n }\n\n /**\n * Returns the number of items in the cache.\n */\n public get size(): number {\n return this.cache.size\n }\n\n /**\n * Returns the current total size of all cached items.\n * This uses the custom size calculation if provided.\n */\n public get currentSize(): number {\n return this.totalSize\n }\n}\n","/**\n * This is the default \"use cache\" handler it defaults to an in-memory store.\n * In-memory caches are fragile and should not use stale-while-revalidate\n * semantics on the caches because it's not worth warming up an entry that's\n * likely going to get evicted before we get to use it anyway. However, we also\n * don't want to reuse a stale entry for too long so stale entries should be\n * considered expired/missing in such cache handlers.\n */\n\nimport { LRUCache } from '../lru-cache'\nimport type { CacheEntry, CacheHandler } from './types'\nimport {\n areTagsExpired,\n areTagsStale,\n tagsManifest,\n type TagManifestEntry,\n} from '../incremental-cache/tags-manifest.external'\n\ntype PrivateCacheEntry = {\n entry: CacheEntry\n\n // For the default cache we store errored cache\n // entries and allow them to be used up to 3 times\n // after that we want to dispose it and try for fresh\n\n // If an entry is errored we return no entry\n // three times so that we retry hitting origin (MISS)\n // and then if it still fails to set after the third we\n // return the errored content and use expiration of\n // Math.min(30, entry.expiration)\n isErrored: boolean\n errorRetryCount: number\n\n // compute size on set since we need to read size\n // of the ReadableStream for LRU evicting\n size: number\n}\n\nexport function createDefaultCacheHandler(maxSize: number): CacheHandler {\n // If the max size is 0, return a cache handler that doesn't cache anything,\n // this avoids an unnecessary LRUCache instance and potential memory\n // allocation.\n if (maxSize === 0) {\n return {\n get: () => Promise.resolve(undefined),\n set: () => Promise.resolve(),\n refreshTags: () => Promise.resolve(),\n getExpiration: () => Promise.resolve(0),\n updateTags: () => Promise.resolve(),\n }\n }\n\n const memoryCache = new LRUCache<PrivateCacheEntry>(\n maxSize,\n (entry) => entry.size\n )\n const pendingSets = new Map<string, Promise<void>>()\n\n const debug = process.env.NEXT_PRIVATE_DEBUG_CACHE\n ? console.debug.bind(console, 'DefaultCacheHandler:')\n : undefined\n\n return {\n async get(cacheKey) {\n const pendingPromise = pendingSets.get(cacheKey)\n\n if (pendingPromise) {\n debug?.('get', cacheKey, 'pending')\n await pendingPromise\n }\n\n const privateEntry = memoryCache.get(cacheKey)\n\n if (!privateEntry) {\n debug?.('get', cacheKey, 'not found')\n return undefined\n }\n\n const entry = privateEntry.entry\n if (\n performance.timeOrigin + performance.now() >\n entry.timestamp + entry.revalidate * 1000\n ) {\n // In-memory caches should expire after revalidate time because it is\n // unlikely that a new entry will be able to be used before it is dropped\n // from the cache.\n debug?.('get', cacheKey, 'expired')\n\n return undefined\n }\n\n let revalidate = entry.revalidate\n\n if (areTagsExpired(entry.tags, entry.timestamp)) {\n debug?.('get', cacheKey, 'had expired tag')\n return undefined\n }\n\n if (areTagsStale(entry.tags, entry.timestamp)) {\n debug?.('get', cacheKey, 'had stale tag')\n revalidate = -1\n }\n\n const [returnStream, newSaved] = entry.value.tee()\n entry.value = newSaved\n\n debug?.('get', cacheKey, 'found', {\n tags: entry.tags,\n timestamp: entry.timestamp,\n expire: entry.expire,\n revalidate,\n })\n\n return {\n ...entry,\n revalidate,\n value: returnStream,\n }\n },\n\n async set(cacheKey, pendingEntry) {\n debug?.('set', cacheKey, 'start')\n\n let resolvePending: () => void = () => {}\n const pendingPromise = new Promise<void>((resolve) => {\n resolvePending = resolve\n })\n pendingSets.set(cacheKey, pendingPromise)\n\n const entry = await pendingEntry\n\n let size = 0\n\n try {\n const [value, clonedValue] = entry.value.tee()\n entry.value = value\n const reader = clonedValue.getReader()\n\n for (let chunk; !(chunk = await reader.read()).done; ) {\n size += Buffer.from(chunk.value).byteLength\n }\n\n memoryCache.set(cacheKey, {\n entry,\n isErrored: false,\n errorRetryCount: 0,\n size,\n })\n\n debug?.('set', cacheKey, 'done')\n } catch (err) {\n // TODO: store partial buffer with error after we retry 3 times\n debug?.('set', cacheKey, 'failed', err)\n } finally {\n resolvePending()\n pendingSets.delete(cacheKey)\n }\n },\n\n async refreshTags() {\n // Nothing to do for an in-memory cache handler.\n },\n\n async getExpiration(tags) {\n const expirations = tags.map((tag) => {\n const entry = tagsManifest.get(tag)\n if (!entry) return 0\n // Return the most recent timestamp (either expired or stale)\n return entry.expired || 0\n })\n\n const expiration = Math.max(...expirations, 0)\n\n debug?.('getExpiration', { tags, expiration })\n\n return expiration\n },\n\n async updateTags(tags, durations) {\n const now = Math.round(performance.timeOrigin + performance.now())\n debug?.('updateTags', { tags, timestamp: now })\n\n for (const tag of tags) {\n // TODO: update file-system-cache?\n const existingEntry = tagsManifest.get(tag) || {}\n\n if (durations) {\n // Use provided durations directly\n const updates: TagManifestEntry = { ...existingEntry }\n\n // mark as stale immediately\n updates.stale = now\n\n if (durations.expire !== undefined) {\n updates.expired = now + durations.expire * 1000 // Convert seconds to ms\n }\n\n tagsManifest.set(tag, updates)\n } else {\n // Update expired field for immediate expiration (default behavior when no durations provided)\n tagsManifest.set(tag, { ...existingEntry, expired: now })\n }\n }\n },\n }\n}\n","import { createDefaultCacheHandler } from '../lib/cache-handlers/default'\nimport type { CacheHandler } from '../lib/cache-handlers/types'\n\nconst debug = process.env.NEXT_PRIVATE_DEBUG_CACHE\n ? (message: string, ...args: any[]) => {\n console.log(`use-cache: ${message}`, ...args)\n }\n : undefined\n\nconst handlersSymbol = Symbol.for('@next/cache-handlers')\nconst handlersMapSymbol = Symbol.for('@next/cache-handlers-map')\nconst handlersSetSymbol = Symbol.for('@next/cache-handlers-set')\n\n/**\n * The reference to the cache handlers. We store the cache handlers on the\n * global object so that we can access the same instance across different\n * boundaries (such as different copies of the same module).\n */\nconst reference: typeof globalThis & {\n [handlersSymbol]?: {\n RemoteCache?: CacheHandler\n DefaultCache?: CacheHandler\n }\n [handlersMapSymbol]?: Map<string, CacheHandler>\n [handlersSetSymbol]?: Set<CacheHandler>\n} = globalThis\n\n/**\n * Initialize the cache handlers.\n * @param cacheMaxMemorySize - The maximum memory size of the cache in bytes, if\n * not provided, the default memory size will be used.\n * @returns `true` if the cache handlers were initialized, `false` if they were already initialized.\n */\nexport function initializeCacheHandlers(cacheMaxMemorySize: number): boolean {\n // If the cache handlers have already been initialized, don't do it again.\n if (reference[handlersMapSymbol]) {\n debug?.('cache handlers already initialized')\n return false\n }\n\n debug?.('initializing cache handlers')\n reference[handlersMapSymbol] = new Map<string, CacheHandler>()\n\n // Initialize the cache from the symbol contents first.\n if (reference[handlersSymbol]) {\n let fallback: CacheHandler\n if (reference[handlersSymbol].DefaultCache) {\n debug?.('setting \"default\" cache handler from symbol')\n fallback = reference[handlersSymbol].DefaultCache\n } else {\n debug?.('setting \"default\" cache handler from default')\n fallback = createDefaultCacheHandler(cacheMaxMemorySize)\n }\n\n reference[handlersMapSymbol].set('default', fallback)\n\n if (reference[handlersSymbol].RemoteCache) {\n debug?.('setting \"remote\" cache handler from symbol')\n reference[handlersMapSymbol].set(\n 'remote',\n reference[handlersSymbol].RemoteCache\n )\n } else {\n debug?.('setting \"remote\" cache handler from default')\n reference[handlersMapSymbol].set('remote', fallback)\n }\n } else {\n const handler = createDefaultCacheHandler(cacheMaxMemorySize)\n\n debug?.('setting \"default\" cache handler from default')\n reference[handlersMapSymbol].set('default', handler)\n debug?.('setting \"remote\" cache handler from default')\n reference[handlersMapSymbol].set('remote', handler)\n }\n\n // Create a set of the cache handlers.\n reference[handlersSetSymbol] = new Set(reference[handlersMapSymbol].values())\n\n return true\n}\n\n/**\n * Get a cache handler by kind.\n * @param kind - The kind of cache handler to get.\n * @returns The cache handler, or `undefined` if it does not exist.\n * @throws If the cache handlers are not initialized.\n */\nexport function getCacheHandler(kind: string): CacheHandler | undefined {\n // This should never be called before initializeCacheHandlers.\n if (!reference[handlersMapSymbol]) {\n throw new Error('Cache handlers not initialized')\n }\n\n return reference[handlersMapSymbol].get(kind)\n}\n\n/**\n * Get a set iterator over the cache handlers.\n * @returns An iterator over the cache handlers, or `undefined` if they are not\n * initialized.\n */\nexport function getCacheHandlers(): SetIterator<CacheHandler> | undefined {\n if (!reference[handlersSetSymbol]) {\n return undefined\n }\n\n return reference[handlersSetSymbol].values()\n}\n\n/**\n * Get a map iterator over the cache handlers (keyed by kind).\n * @returns An iterator over the cache handler entries, or `undefined` if they\n * are not initialized.\n * @throws If the cache handlers are not initialized.\n */\nexport function getCacheHandlerEntries():\n | MapIterator<[string, CacheHandler]>\n | undefined {\n if (!reference[handlersMapSymbol]) {\n return undefined\n }\n\n return reference[handlersMapSymbol].entries()\n}\n\n/**\n * Set a cache handler by kind.\n * @param kind - The kind of cache handler to set.\n * @param cacheHandler - The cache handler to set.\n */\nexport function setCacheHandler(\n kind: string,\n cacheHandler: CacheHandler\n): void {\n // This should never be called before initializeCacheHandlers.\n if (!reference[handlersMapSymbol] || !reference[handlersSetSymbol]) {\n throw new Error('Cache handlers not initialized')\n }\n\n debug?.('setting cache handler for \"%s\"', kind)\n reference[handlersMapSymbol].set(kind, cacheHandler)\n reference[handlersSetSymbol].add(cacheHandler)\n}\n","/**\n * Interop between \"export default\" and \"module.exports\".\n */\nexport function interopDefault(mod: any) {\n return mod.default || mod\n}\n","import type { IncomingMessage, ServerResponse } from 'node:http'\nimport type { NextConfigComplete } from '../../config-shared'\nimport type { UrlWithParsedQuery } from 'node:url'\nimport type { ServerCacheStatus } from '../../../next-devtools/dev-overlay/cache-indicator'\n\nexport type RevalidateFn = (config: {\n urlPath: string\n revalidateHeaders: { [key: string]: string | string[] }\n opts: { unstable_onlyGenerated?: boolean }\n}) => Promise<void>\n\n// The RouterServerContext contains instance specific\n// information that isn't available/relevant when\n// deployed in serverless environments, the key is\n// the relative project dir this allows separate contexts\n// when running multiple next instances in same process\nexport type RouterServerContext = Record<\n string,\n {\n // hostname the server is started with\n hostname?: string\n // revalidate function to bypass going through network\n // to invoke revalidate request (uses mocked req/res)\n revalidate?: RevalidateFn\n // function to render the 404 page\n render404?: (\n req: IncomingMessage,\n res: ServerResponse,\n parsedUrl?: UrlWithParsedQuery,\n setHeaders?: boolean\n ) => Promise<void>\n // exposing nextConfig for dev mode specifically\n nextConfig?: NextConfigComplete\n // whether running in custom server mode\n isCustomServer?: boolean\n // whether test proxy is enabled\n experimentalTestProxy?: boolean\n // allow dev server to log with original stack\n logErrorWithOriginalStack?: (err: unknown, type: string) => void\n // allow setting ISR status in dev\n setIsrStatus?: (key: string, value: boolean | undefined) => void\n setReactDebugChannel?: (\n debugChannel: { readable: ReadableStream<Uint8Array> },\n htmlRequestId: string,\n requestId: string\n ) => void\n setCacheStatus?: (\n status: ServerCacheStatus,\n htmlRequestId: string,\n requestId: string\n ) => void\n }\n>\n\nexport const RouterServerContextSymbol = Symbol.for(\n '@next/router-server-methods'\n)\n\nexport const routerServerGlobal = globalThis as typeof globalThis & {\n [RouterServerContextSymbol]?: RouterServerContext\n}\n","import { NEXT_URL } from '../client/components/app-router-headers'\nimport {\n extractInterceptionRouteInformation,\n isInterceptionRouteAppPath,\n} from '../shared/lib/router/utils/interception-routes'\nimport type { Rewrite } from './load-custom-routes'\nimport type { DeepReadonly } from '../shared/lib/deep-readonly'\nimport { getNamedRouteRegex } from '../shared/lib/router/utils/route-regex'\n\nexport function generateInterceptionRoutesRewrites(\n appPaths: string[],\n basePath = ''\n): Rewrite[] {\n const rewrites: Rewrite[] = []\n\n for (const appPath of appPaths) {\n if (isInterceptionRouteAppPath(appPath)) {\n const { interceptingRoute, interceptedRoute } =\n extractInterceptionRouteInformation(appPath)\n\n const destination = getNamedRouteRegex(basePath + appPath, {\n prefixRouteKeys: true,\n })\n\n const header = getNamedRouteRegex(interceptingRoute, {\n prefixRouteKeys: true,\n reference: destination.reference,\n })\n\n const source = getNamedRouteRegex(basePath + interceptedRoute, {\n prefixRouteKeys: true,\n reference: header.reference,\n })\n\n const headerRegex = header.namedRegex\n // Strip ^ and $ anchors since matchHas() will add them automatically\n .replace(/^\\^/, '')\n .replace(/\\$$/, '')\n // Replace matching the `/` with matching any route segment.\n .replace(/^\\/\\(\\?:\\/\\)\\?$/, '/.*')\n // Replace the optional trailing with slash capture group with one that\n // will match any descendants.\n .replace(/\\(\\?:\\/\\)\\?$/, '(?:/.*)?')\n\n rewrites.push({\n source: source.pathToRegexpPattern,\n destination: destination.pathToRegexpPattern,\n has: [\n {\n type: 'header',\n key: NEXT_URL,\n value: headerRegex,\n },\n ],\n internal: true,\n regex: source.namedRegex,\n })\n }\n }\n\n return rewrites\n}\n\nexport function isInterceptionRouteRewrite(route: DeepReadonly<Rewrite>) {\n // When we generate interception rewrites in the above implementation, we always do so with only a single `has` condition.\n return route.has?.[0]?.key === NEXT_URL\n}\n","export const RSC_HEADER = 'rsc' as const\nexport const ACTION_HEADER = 'next-action' as const\n// TODO: Instead of sending the full router state, we only need to send the\n// segment path. Saves bytes. Then we could also use this field for segment\n// prefetches, which also need to specify a particular segment.\nexport const NEXT_ROUTER_STATE_TREE_HEADER = 'next-router-state-tree' as const\nexport const NEXT_ROUTER_PREFETCH_HEADER = 'next-router-prefetch' as const\n// This contains the path to the segment being prefetched.\n// TODO: If we change next-router-state-tree to be a segment path, we can use\n// that instead. Then next-router-prefetch and next-router-segment-prefetch can\n// be merged into a single enum.\nexport const NEXT_ROUTER_SEGMENT_PREFETCH_HEADER =\n 'next-router-segment-prefetch' as const\nexport const NEXT_HMR_REFRESH_HEADER = 'next-hmr-refresh' as const\nexport const NEXT_HMR_REFRESH_HASH_COOKIE = '__next_hmr_refresh_hash__' as const\nexport const NEXT_URL = 'next-url' as const\nexport const RSC_CONTENT_TYPE_HEADER = 'text/x-component' as const\n\nexport const FLIGHT_HEADERS = [\n RSC_HEADER,\n NEXT_ROUTER_STATE_TREE_HEADER,\n NEXT_ROUTER_PREFETCH_HEADER,\n NEXT_HMR_REFRESH_HEADER,\n NEXT_ROUTER_SEGMENT_PREFETCH_HEADER,\n] as const\n\nexport const NEXT_RSC_UNION_QUERY = '_rsc' as const\n\nexport const NEXT_ROUTER_STALE_TIME_HEADER = 'x-nextjs-stale-time' as const\nexport const NEXT_DID_POSTPONE_HEADER = 'x-nextjs-postponed' as const\nexport const NEXT_REWRITTEN_PATH_HEADER = 'x-nextjs-rewritten-path' as const\nexport const NEXT_REWRITTEN_QUERY_HEADER = 'x-nextjs-rewritten-query' as const\nexport const NEXT_IS_PRERENDER_HEADER = 'x-nextjs-prerender' as const\nexport const NEXT_ACTION_NOT_FOUND_HEADER = 'x-nextjs-action-not-found' as const\nexport const NEXT_REQUEST_ID_HEADER = 'x-nextjs-request-id' as const\nexport const NEXT_HTML_REQUEST_ID_HEADER = 'x-nextjs-html-request-id' as const\n","import type { IncomingMessage, ServerResponse } from 'node:http'\nimport type {\n InstrumentationOnRequestError,\n RequestErrorContext,\n} from '../instrumentation/types'\nimport type { ParsedUrlQuery } from 'node:querystring'\nimport type { UrlWithParsedQuery } from 'node:url'\nimport type {\n PrerenderManifest,\n RequiredServerFilesManifest,\n} from '../../build'\nimport type { DevRoutesManifest } from '../lib/router-utils/setup-dev-bundler'\nimport type { RouteDefinition } from '../route-definitions/route-definition'\nimport type { DeepReadonly } from '../../shared/lib/deep-readonly'\nimport {\n BUILD_ID_FILE,\n BUILD_MANIFEST,\n CLIENT_REFERENCE_MANIFEST,\n DYNAMIC_CSS_MANIFEST,\n NEXT_FONT_MANIFEST,\n PRERENDER_MANIFEST,\n REACT_LOADABLE_MANIFEST,\n ROUTES_MANIFEST,\n SERVER_FILES_MANIFEST,\n SERVER_REFERENCE_MANIFEST,\n SUBRESOURCE_INTEGRITY_MANIFEST,\n} from '../../shared/lib/constants'\nimport { parseReqUrl } from '../../lib/url'\nimport {\n normalizeLocalePath,\n type PathLocale,\n} from '../../shared/lib/i18n/normalize-locale-path'\nimport { isDynamicRoute } from '../../shared/lib/router/utils'\nimport { removePathPrefix } from '../../shared/lib/router/utils/remove-path-prefix'\nimport { getServerUtils } from '../server-utils'\nimport { detectDomainLocale } from '../../shared/lib/i18n/detect-domain-locale'\nimport { getHostname } from '../../shared/lib/get-hostname'\nimport { checkIsOnDemandRevalidate } from '../api-utils'\nimport type { PreviewData } from '../../types'\nimport type { BuildManifest } from '../get-page-files'\nimport type { ReactLoadableManifest } from '../load-components'\nimport type { NextFontManifest } from '../../build/webpack/plugins/next-font-manifest-plugin'\nimport { normalizeDataPath } from '../../shared/lib/page-path/normalize-data-path'\nimport { pathHasPrefix } from '../../shared/lib/router/utils/path-has-prefix'\nimport { addRequestMeta, getRequestMeta } from '../request-meta'\nimport { normalizePagePath } from '../../shared/lib/page-path/normalize-page-path'\nimport { isStaticMetadataRoute } from '../../lib/metadata/is-metadata-route'\nimport { IncrementalCache } from '../lib/incremental-cache'\nimport { initializeCacheHandlers, setCacheHandler } from '../use-cache/handlers'\nimport { interopDefault } from '../app-render/interop-default'\nimport { RouteKind } from '../route-kind'\nimport type { BaseNextRequest } from '../base-http'\nimport type { I18NConfig, NextConfigComplete } from '../config-shared'\nimport ResponseCache, { type ResponseGenerator } from '../response-cache'\nimport { normalizeAppPath } from '../../shared/lib/router/utils/app-paths'\nimport {\n RouterServerContextSymbol,\n routerServerGlobal,\n type RouterServerContext,\n} from '../lib/router-utils/router-server-context'\nimport { decodePathParams } from '../lib/router-utils/decode-path-params'\nimport { removeTrailingSlash } from '../../shared/lib/router/utils/remove-trailing-slash'\nimport { isInterceptionRouteRewrite } from '../../lib/generate-interception-routes-rewrites'\n\n/**\n * RouteModuleOptions is the options that are passed to the route module, other\n * route modules should extend this class to add specific options for their\n * route.\n */\nexport interface RouteModuleOptions<\n D extends RouteDefinition = RouteDefinition,\n U = unknown,\n> {\n readonly definition: Readonly<D>\n readonly userland: Readonly<U>\n readonly distDir: string\n readonly relativeProjectDir: string\n}\n\n/**\n * RouteHandlerContext is the base context for a route handler.\n */\nexport interface RouteModuleHandleContext {\n /**\n * Any matched parameters for the request. This is only defined for dynamic\n * routes.\n */\n params: Record<string, string | string[] | undefined> | undefined\n}\n\nconst dynamicImportEsmDefault = (id: string) =>\n import(/* webpackIgnore: true */ /* turbopackIgnore: true */ id).then(\n (mod) => mod.default || mod\n )\n\n/**\n * RouteModule is the base class for all route modules. This class should be\n * extended by all route modules.\n */\nexport abstract class RouteModule<\n D extends RouteDefinition = RouteDefinition,\n U = unknown,\n> {\n /**\n * The userland module. This is the module that is exported from the user's\n * code. This is marked as readonly to ensure that the module is not mutated\n * because the module (when compiled) only provides getters.\n */\n public readonly userland: Readonly<U>\n\n /**\n * The definition of the route.\n */\n public readonly definition: Readonly<D>\n\n /**\n * The shared modules that are exposed and required for the route module.\n */\n public static readonly sharedModules: any\n\n public isDev: boolean\n public distDir: string\n public relativeProjectDir: string\n public incrementCache?: IncrementalCache\n public responseCache?: ResponseCache\n\n constructor({\n userland,\n definition,\n distDir,\n relativeProjectDir,\n }: RouteModuleOptions<D, U>) {\n this.userland = userland\n this.definition = definition\n this.isDev = process.env.NODE_ENV === 'development'\n this.distDir = distDir\n this.relativeProjectDir = relativeProjectDir\n }\n\n public async instrumentationOnRequestError(\n req: IncomingMessage | BaseNextRequest,\n ...args: Parameters<InstrumentationOnRequestError>\n ) {\n if (process.env.NEXT_RUNTIME === 'edge') {\n const { getEdgeInstrumentationModule } = await import('../web/globals')\n const instrumentation = await getEdgeInstrumentationModule()\n\n if (instrumentation) {\n await instrumentation.onRequestError?.(...args)\n }\n } else {\n const { join } = require('node:path') as typeof import('node:path')\n const absoluteProjectDir = join(\n /* turbopackIgnore: true */\n process.cwd(),\n getRequestMeta(req, 'relativeProjectDir') || this.relativeProjectDir\n )\n\n const { instrumentationOnRequestError } = await import(\n '../lib/router-utils/instrumentation-globals.external.js'\n )\n\n return instrumentationOnRequestError(\n absoluteProjectDir,\n this.distDir,\n ...args\n )\n }\n }\n\n private loadManifests(\n srcPage: string,\n projectDir?: string\n ): {\n buildId: string\n buildManifest: BuildManifest\n fallbackBuildManifest: BuildManifest\n routesManifest: DeepReadonly<DevRoutesManifest>\n nextFontManifest: DeepReadonly<NextFontManifest>\n prerenderManifest: DeepReadonly<PrerenderManifest>\n serverFilesManifest: RequiredServerFilesManifest\n reactLoadableManifest: DeepReadonly<ReactLoadableManifest>\n subresourceIntegrityManifest: any\n clientReferenceManifest: any\n serverActionsManifest: any\n dynamicCssManifest: any\n interceptionRoutePatterns: RegExp[]\n } {\n if (process.env.NEXT_RUNTIME === 'edge') {\n const { getEdgePreviewProps } =\n require('../web/get-edge-preview-props') as typeof import('../web/get-edge-preview-props')\n\n const maybeJSONParse = (str?: string) =>\n str ? JSON.parse(str) : undefined\n\n return {\n buildId: process.env.__NEXT_BUILD_ID || '',\n buildManifest: self.__BUILD_MANIFEST as any,\n fallbackBuildManifest: {} as any,\n reactLoadableManifest: maybeJSONParse(self.__REACT_LOADABLE_MANIFEST),\n nextFontManifest: maybeJSONParse(self.__NEXT_FONT_MANIFEST),\n prerenderManifest: {\n routes: {},\n dynamicRoutes: {},\n notFoundRoutes: [],\n version: 4,\n preview: getEdgePreviewProps(),\n },\n routesManifest: {\n version: 4,\n caseSensitive: Boolean(process.env.__NEXT_CASE_SENSITIVE_ROUTES),\n basePath: process.env.__NEXT_BASE_PATH || '',\n rewrites: (process.env.__NEXT_REWRITES as any) || {\n beforeFiles: [],\n afterFiles: [],\n fallback: [],\n },\n redirects: [],\n headers: [],\n i18n:\n (process.env.__NEXT_I18N_CONFIG as any as I18NConfig) || undefined,\n skipProxyUrlNormalize: Boolean(\n process.env.__NEXT_NO_MIDDLEWARE_URL_NORMALIZE\n ),\n },\n serverFilesManifest: {\n config: (globalThis as any).nextConfig || {},\n } as any,\n clientReferenceManifest: self.__RSC_MANIFEST?.[srcPage],\n serverActionsManifest: maybeJSONParse(self.__RSC_SERVER_MANIFEST),\n subresourceIntegrityManifest: maybeJSONParse(\n self.__SUBRESOURCE_INTEGRITY_MANIFEST\n ),\n dynamicCssManifest: maybeJSONParse(self.__DYNAMIC_CSS_MANIFEST),\n interceptionRoutePatterns: (\n maybeJSONParse(self.__INTERCEPTION_ROUTE_REWRITE_MANIFEST) ?? []\n ).map((rewrite: any) => new RegExp(rewrite.regex)),\n }\n } else {\n if (!projectDir) {\n throw new Error('Invariant: projectDir is required for node runtime')\n }\n const { loadManifestFromRelativePath } =\n require('../load-manifest.external') as typeof import('../load-manifest.external')\n const normalizedPagePath = normalizePagePath(srcPage)\n\n const router =\n this.definition.kind === RouteKind.PAGES ||\n this.definition.kind === RouteKind.PAGES_API\n ? 'pages'\n : 'app'\n\n const [\n routesManifest,\n prerenderManifest,\n buildManifest,\n fallbackBuildManifest,\n reactLoadableManifest,\n nextFontManifest,\n clientReferenceManifest,\n serverActionsManifest,\n subresourceIntegrityManifest,\n serverFilesManifest,\n buildId,\n dynamicCssManifest,\n ] = [\n loadManifestFromRelativePath<DevRoutesManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: ROUTES_MANIFEST,\n shouldCache: !this.isDev,\n }),\n loadManifestFromRelativePath<PrerenderManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: PRERENDER_MANIFEST,\n shouldCache: !this.isDev,\n }),\n loadManifestFromRelativePath<BuildManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: BUILD_MANIFEST,\n shouldCache: !this.isDev,\n }),\n srcPage === '/_error'\n ? loadManifestFromRelativePath<BuildManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: `fallback-${BUILD_MANIFEST}`,\n shouldCache: !this.isDev,\n handleMissing: true,\n })\n : ({} as BuildManifest),\n loadManifestFromRelativePath<ReactLoadableManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: process.env.TURBOPACK\n ? `server/${router === 'app' ? 'app' : 'pages'}${normalizedPagePath}/${REACT_LOADABLE_MANIFEST}`\n : REACT_LOADABLE_MANIFEST,\n handleMissing: true,\n shouldCache: !this.isDev,\n }),\n loadManifestFromRelativePath<NextFontManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: `server/${NEXT_FONT_MANIFEST}.json`,\n shouldCache: !this.isDev,\n }),\n router === 'app' && !isStaticMetadataRoute(srcPage)\n ? loadManifestFromRelativePath({\n distDir: this.distDir,\n projectDir,\n useEval: true,\n handleMissing: true,\n manifest: `server/app${srcPage.replace(/%5F/g, '_') + '_' + CLIENT_REFERENCE_MANIFEST}.js`,\n shouldCache: !this.isDev,\n })\n : undefined,\n router === 'app'\n ? loadManifestFromRelativePath<any>({\n distDir: this.distDir,\n projectDir,\n manifest: `server/${SERVER_REFERENCE_MANIFEST}.json`,\n handleMissing: true,\n shouldCache: !this.isDev,\n })\n : {},\n loadManifestFromRelativePath<Record<string, string>>({\n projectDir,\n distDir: this.distDir,\n manifest: `server/${SUBRESOURCE_INTEGRITY_MANIFEST}.json`,\n handleMissing: true,\n shouldCache: !this.isDev,\n }),\n this.isDev\n ? ({} as any)\n : loadManifestFromRelativePath<RequiredServerFilesManifest>({\n projectDir,\n distDir: this.distDir,\n manifest: SERVER_FILES_MANIFEST,\n }),\n this.isDev\n ? 'development'\n : loadManifestFromRelativePath<any>({\n projectDir,\n distDir: this.distDir,\n manifest: BUILD_ID_FILE,\n skipParse: true,\n }),\n loadManifestFromRelativePath<any>({\n projectDir,\n distDir: this.distDir,\n manifest: DYNAMIC_CSS_MANIFEST,\n handleMissing: true,\n }),\n ]\n\n return {\n buildId,\n buildManifest,\n fallbackBuildManifest,\n routesManifest,\n nextFontManifest,\n prerenderManifest,\n serverFilesManifest,\n reactLoadableManifest,\n clientReferenceManifest: (clientReferenceManifest as any)\n ?.__RSC_MANIFEST?.[srcPage.replace(/%5F/g, '_')],\n serverActionsManifest,\n subresourceIntegrityManifest,\n dynamicCssManifest,\n interceptionRoutePatterns: routesManifest.rewrites.beforeFiles\n .filter(isInterceptionRouteRewrite)\n .map((rewrite) => new RegExp(rewrite.regex)),\n }\n }\n }\n\n public async loadCustomCacheHandlers(\n req: IncomingMessage | BaseNextRequest,\n nextConfig: NextConfigComplete\n ) {\n if (process.env.NEXT_RUNTIME !== 'edge') {\n const { cacheMaxMemorySize, cacheHandlers } = nextConfig\n if (!cacheHandlers) return\n\n // If we've already initialized the cache handlers interface, don't do it\n // again.\n if (!initializeCacheHandlers(cacheMaxMemorySize)) return\n\n for (const [kind, handler] of Object.entries(cacheHandlers)) {\n if (!handler) continue\n\n const { formatDynamicImportPath } =\n require('../../lib/format-dynamic-import-path') as typeof import('../../lib/format-dynamic-import-path')\n\n const { join } = require('node:path') as typeof import('node:path')\n const absoluteProjectDir = join(\n /* turbopackIgnore: true */\n process.cwd(),\n getRequestMeta(req, 'relativeProjectDir') || this.relativeProjectDir\n )\n\n setCacheHandler(\n kind,\n interopDefault(\n await dynamicImportEsmDefault(\n formatDynamicImportPath(\n `${absoluteProjectDir}/${this.distDir}`,\n handler\n )\n )\n )\n )\n }\n }\n }\n\n public async getIncrementalCache(\n req: IncomingMessage | BaseNextRequest,\n nextConfig: NextConfigComplete,\n prerenderManifest: DeepReadonly<PrerenderManifest>,\n isMinimalMode: boolean\n ): Promise<IncrementalCache> {\n if (process.env.NEXT_RUNTIME === 'edge') {\n return (globalThis as any).__incrementalCache\n } else {\n let CacheHandler: any\n const { cacheHandler } = nextConfig\n\n if (cacheHandler) {\n const { formatDynamicImportPath } =\n require('../../lib/format-dynamic-import-path') as typeof import('../../lib/format-dynamic-import-path')\n\n CacheHandler = interopDefault(\n await dynamicImportEsmDefault(\n formatDynamicImportPath(this.distDir, cacheHandler)\n )\n )\n }\n const { join } = require('node:path') as typeof import('node:path')\n const projectDir = join(\n /* turbopackIgnore: true */\n process.cwd(),\n getRequestMeta(req, 'relativeProjectDir') || this.relativeProjectDir\n )\n\n await this.loadCustomCacheHandlers(req, nextConfig)\n\n // incremental-cache is request specific\n // although can have shared caches in module scope\n // per-cache handler\n const incrementalCache = new IncrementalCache({\n fs: (\n require('../lib/node-fs-methods') as typeof import('../lib/node-fs-methods')\n ).nodeFs,\n dev: this.isDev,\n requestHeaders: req.headers,\n allowedRevalidateHeaderKeys:\n nextConfig.experimental.allowedRevalidateHeaderKeys,\n minimalMode: isMinimalMode,\n serverDistDir: `${projectDir}/${this.distDir}/server`,\n fetchCacheKeyPrefix: nextConfig.experimental.fetchCacheKeyPrefix,\n maxMemoryCacheSize: nextConfig.cacheMaxMemorySize,\n flushToDisk: !isMinimalMode && nextConfig.experimental.isrFlushToDisk,\n getPrerenderManifest: () => prerenderManifest,\n CurCacheHandler: CacheHandler,\n })\n\n // we need to expose this on globalThis as the app-render\n // workStore grabs the incrementalCache from there\n ;(globalThis as any).__incrementalCache = incrementalCache\n return incrementalCache\n }\n }\n\n public async onRequestError(\n req: IncomingMessage | BaseNextRequest,\n err: unknown,\n errorContext: RequestErrorContext,\n routerServerContext?: RouterServerContext[string]\n ) {\n if (routerServerContext?.logErrorWithOriginalStack) {\n routerServerContext.logErrorWithOriginalStack(err, 'app-dir')\n } else {\n console.error(err)\n }\n await this.instrumentationOnRequestError(\n req,\n err,\n {\n path: req.url || '/',\n headers: req.headers,\n method: req.method || 'GET',\n },\n errorContext\n )\n }\n\n public async prepare(\n req: IncomingMessage | BaseNextRequest,\n res: ServerResponse | null,\n {\n srcPage,\n multiZoneDraftMode,\n }: {\n srcPage: string\n multiZoneDraftMode?: boolean\n }\n ): Promise<\n | {\n buildId: string\n locale?: string\n locales?: readonly string[]\n defaultLocale?: string\n query: ParsedUrlQuery\n originalQuery: ParsedUrlQuery\n originalPathname: string\n params?: ParsedUrlQuery\n parsedUrl: UrlWithParsedQuery\n previewData: PreviewData\n pageIsDynamic: boolean\n isDraftMode: boolean\n resolvedPathname: string\n encodedResolvedPathname: string\n isNextDataRequest: boolean\n buildManifest: DeepReadonly<BuildManifest>\n fallbackBuildManifest: DeepReadonly<BuildManifest>\n nextFontManifest: DeepReadonly<NextFontManifest>\n serverFilesManifest: DeepReadonly<RequiredServerFilesManifest>\n reactLoadableManifest: DeepReadonly<ReactLoadableManifest>\n routesManifest: DeepReadonly<DevRoutesManifest>\n prerenderManifest: DeepReadonly<PrerenderManifest>\n // we can't pull in the client reference type or it causes issues with\n // our pre-compiled types\n clientReferenceManifest?: any\n serverActionsManifest?: any\n dynamicCssManifest?: any\n subresourceIntegrityManifest?: DeepReadonly<Record<string, string>>\n isOnDemandRevalidate: boolean\n revalidateOnlyGenerated: boolean\n nextConfig: NextConfigComplete\n routerServerContext?: RouterServerContext[string]\n interceptionRoutePatterns?: any\n }\n | undefined\n > {\n let absoluteProjectDir: string | undefined\n\n // edge runtime handles loading instrumentation at the edge adapter level\n if (process.env.NEXT_RUNTIME !== 'edge') {\n const { join, relative } =\n require('node:path') as typeof import('node:path')\n\n absoluteProjectDir = join(\n /* turbopackIgnore: true */\n process.cwd(),\n getRequestMeta(req, 'relativeProjectDir') || this.relativeProjectDir\n )\n\n const absoluteDistDir = getRequestMeta(req, 'distDir')\n\n if (absoluteDistDir) {\n this.distDir = relative(absoluteProjectDir, absoluteDistDir)\n }\n const { ensureInstrumentationRegistered } = await import(\n '../lib/router-utils/instrumentation-globals.external.js'\n )\n // ensure instrumentation is registered and pass\n // onRequestError below\n ensureInstrumentationRegistered(absoluteProjectDir, this.distDir)\n }\n const manifests = await this.loadManifests(srcPage, absoluteProjectDir)\n const { routesManifest, prerenderManifest, serverFilesManifest } = manifests\n\n const { basePath, i18n, rewrites } = routesManifest\n\n if (basePath) {\n req.url = removePathPrefix(req.url || '/', basePath)\n }\n\n const parsedUrl = parseReqUrl(req.url || '/')\n // if we couldn't parse the URL we can't continue\n if (!parsedUrl) {\n return\n }\n let isNextDataRequest = false\n\n if (pathHasPrefix(parsedUrl.pathname || '/', '/_next/data')) {\n isNextDataRequest = true\n parsedUrl.pathname = normalizeDataPath(parsedUrl.pathname || '/')\n }\n let originalPathname = parsedUrl.pathname || '/'\n const originalQuery = { ...parsedUrl.query }\n const pageIsDynamic = isDynamicRoute(srcPage)\n\n let localeResult: PathLocale | undefined\n let detectedLocale: string | undefined\n\n if (i18n) {\n localeResult = normalizeLocalePath(\n parsedUrl.pathname || '/',\n i18n.locales\n )\n\n if (localeResult.detectedLocale) {\n req.url = `${localeResult.pathname}${parsedUrl.search}`\n originalPathname = localeResult.pathname\n\n if (!detectedLocale) {\n detectedLocale = localeResult.detectedLocale\n }\n }\n }\n\n // Normalize the page path for route matching. The srcPage contains the\n // internal page path (e.g., /app/[slug]/page), but route matchers expect\n // the pathname format (e.g., /app/[slug]).\n const normalizedSrcPage = normalizeAppPath(srcPage)\n\n const serverUtils = getServerUtils({\n page: normalizedSrcPage,\n i18n,\n basePath,\n rewrites,\n pageIsDynamic,\n trailingSlash: process.env.__NEXT_TRAILING_SLASH as any as boolean,\n caseSensitive: Boolean(routesManifest.caseSensitive),\n })\n\n const domainLocale = detectDomainLocale(\n i18n?.domains,\n getHostname(parsedUrl, req.headers),\n detectedLocale\n )\n addRequestMeta(req, 'isLocaleDomain', Boolean(domainLocale))\n\n const defaultLocale = domainLocale?.defaultLocale || i18n?.defaultLocale\n\n // Ensure parsedUrl.pathname includes locale before processing\n // rewrites or they won't match correctly.\n if (defaultLocale && !detectedLocale) {\n parsedUrl.pathname = `/${defaultLocale}${parsedUrl.pathname === '/' ? '' : parsedUrl.pathname}`\n }\n const locale =\n getRequestMeta(req, 'locale') || detectedLocale || defaultLocale\n\n // we apply rewrites against cloned URL so that we don't\n // modify the original with the rewrite destination\n const { rewriteParams, rewrittenParsedUrl } = serverUtils.handleRewrites(\n req,\n parsedUrl\n )\n const rewriteParamKeys = Object.keys(rewriteParams)\n Object.assign(parsedUrl.query, rewrittenParsedUrl.query)\n\n // after processing rewrites we want to remove locale\n // from parsedUrl pathname\n if (i18n) {\n parsedUrl.pathname = normalizeLocalePath(\n parsedUrl.pathname || '/',\n i18n.locales\n ).pathname\n\n rewrittenParsedUrl.pathname = normalizeLocalePath(\n rewrittenParsedUrl.pathname || '/',\n i18n.locales\n ).pathname\n }\n\n let params: Record<string, undefined | string | string[]> | undefined =\n getRequestMeta(req, 'params')\n\n // attempt parsing from pathname\n if (!params && serverUtils.dynamicRouteMatcher) {\n const paramsMatch = serverUtils.dynamicRouteMatcher(\n normalizeDataPath(\n rewrittenParsedUrl?.pathname || parsedUrl.pathname || '/'\n )\n )\n const paramsResult = serverUtils.normalizeDynamicRouteParams(\n paramsMatch || {},\n true\n )\n\n if (paramsResult.hasValidParams) {\n params = paramsResult.params\n }\n }\n\n // Local \"next start\" expects the routing parsed query values\n // to not be present in the URL although when deployed proxies\n // will add query values from resolving the routes to pass to function.\n\n // TODO: do we want to change expectations for \"next start\"\n // to include these query values in the URL which affects asPath\n // but would match deployed behavior, e.g. a rewrite from middleware\n // that adds a query param would be in asPath as query but locally\n // it won't be in the asPath but still available in the query object\n const query = getRequestMeta(req, 'query') || {\n ...parsedUrl.query,\n }\n\n const routeParamKeys = new Set<string>()\n const combinedParamKeys = []\n\n // We don't include rewriteParamKeys in the combinedParamKeys\n // for app router since the searchParams is populated from the\n // URL so we don't want to strip the rewrite params from the URL\n // so that searchParams can include them.\n if (\n this.definition.kind === RouteKind.PAGES ||\n this.definition.kind === RouteKind.PAGES_API\n ) {\n for (const key of [\n ...rewriteParamKeys,\n ...Object.keys(serverUtils.defaultRouteMatches || {}),\n ]) {\n // We only want to filter rewrite param keys from the URL\n // if they are matches from the URL e.g. the key/value matches\n // before and after applying the rewrites /:path for /hello and\n // { path: 'hello' } but not for { path: 'another' } and /hello\n // TODO: we should prefix rewrite param keys the same as we do\n // for dynamic routes so we can identify them properly\n const originalValue = Array.isArray(originalQuery[key])\n ? originalQuery[key].join('')\n : originalQuery[key]\n\n const queryValue = Array.isArray(query[key])\n ? query[key].join('')\n : query[key]\n\n if (!(key in originalQuery) || originalValue === queryValue) {\n combinedParamKeys.push(key)\n }\n }\n }\n\n serverUtils.normalizeCdnUrl(req, combinedParamKeys)\n serverUtils.normalizeQueryParams(query, routeParamKeys)\n serverUtils.filterInternalQuery(originalQuery, combinedParamKeys)\n\n if (pageIsDynamic) {\n const queryResult = serverUtils.normalizeDynamicRouteParams(query, true)\n\n const paramsResult = serverUtils.normalizeDynamicRouteParams(\n params || {},\n true\n )\n\n let paramsToInterpolate: ParsedUrlQuery\n\n if (\n // if both query and params are valid but one\n // provided more information rely on that one\n query &&\n params &&\n paramsResult.hasValidParams &&\n queryResult.hasValidParams &&\n Object.keys(paramsResult.params).length <\n Object.keys(queryResult.params).length\n ) {\n paramsToInterpolate = queryResult.params\n params = Object.assign(queryResult.params)\n } else {\n paramsToInterpolate =\n paramsResult.hasValidParams && params\n ? params\n : queryResult.hasValidParams\n ? query\n : {}\n }\n\n req.url = serverUtils.interpolateDynamicPath(\n req.url || '/',\n paramsToInterpolate\n )\n parsedUrl.pathname = serverUtils.interpolateDynamicPath(\n parsedUrl.pathname || '/',\n paramsToInterpolate\n )\n originalPathname = serverUtils.interpolateDynamicPath(\n originalPathname,\n paramsToInterpolate\n )\n\n // try pulling from query if valid\n if (!params) {\n if (queryResult.hasValidParams) {\n params = Object.assign({}, queryResult.params)\n\n // If we pulled from query remove it so it's\n // only in params\n for (const key in serverUtils.defaultRouteMatches) {\n delete query[key]\n }\n } else {\n // use final params from URL matching\n const paramsMatch = serverUtils.dynamicRouteMatcher?.(\n normalizeDataPath(\n localeResult?.pathname || parsedUrl.pathname || '/'\n )\n )\n // we don't normalize these as they are allowed to be\n // the literal slug matches here e.g. /blog/[slug]\n // actually being requested\n if (paramsMatch) {\n params = Object.assign({}, paramsMatch)\n }\n }\n }\n }\n\n // Remove any normalized params from the query if they\n // weren't present as non-prefixed query key e.g.\n // ?search=1&nxtPsearch=hello we don't delete search\n for (const key of routeParamKeys) {\n if (!(key in originalQuery)) {\n delete query[key]\n }\n }\n\n const { isOnDemandRevalidate, revalidateOnlyGenerated } =\n checkIsOnDemandRevalidate(req, prerenderManifest.preview)\n\n let isDraftMode = false\n let previewData: PreviewData\n\n // preview data relies on non-edge utils\n if (process.env.NEXT_RUNTIME !== 'edge' && res) {\n const { tryGetPreviewData } =\n require('../api-utils/node/try-get-preview-data') as typeof import('../api-utils/node/try-get-preview-data')\n\n previewData = tryGetPreviewData(\n req,\n res,\n prerenderManifest.preview,\n Boolean(multiZoneDraftMode)\n )\n isDraftMode = previewData !== false\n }\n\n const relativeProjectDir =\n getRequestMeta(req, 'relativeProjectDir') || this.relativeProjectDir\n\n const routerServerContext =\n routerServerGlobal[RouterServerContextSymbol]?.[relativeProjectDir]\n const nextConfig =\n routerServerContext?.nextConfig || serverFilesManifest.config\n\n let resolvedPathname = normalizedSrcPage\n if (isDynamicRoute(resolvedPathname) && params) {\n resolvedPathname = serverUtils.interpolateDynamicPath(\n resolvedPathname,\n params\n )\n }\n\n if (resolvedPathname === '/index') {\n resolvedPathname = '/'\n }\n const encodedResolvedPathname = resolvedPathname\n\n // we decode for cache key/manifest usage encoded is\n // for URL building\n try {\n resolvedPathname = decodePathParams(resolvedPathname)\n } catch (_) {}\n\n resolvedPathname = removeTrailingSlash(resolvedPathname)\n\n return {\n query,\n originalQuery,\n originalPathname,\n params,\n parsedUrl,\n locale,\n isNextDataRequest,\n locales: i18n?.locales,\n defaultLocale,\n isDraftMode,\n previewData,\n pageIsDynamic,\n resolvedPathname,\n encodedResolvedPathname,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n ...manifests,\n serverActionsManifest: manifests.serverActionsManifest,\n clientReferenceManifest: manifests.clientReferenceManifest,\n nextConfig,\n routerServerContext,\n }\n }\n\n public getResponseCache(req: IncomingMessage | BaseNextRequest) {\n if (!this.responseCache) {\n const minimalMode =\n (Boolean(process.env.MINIMAL_MODE) ||\n getRequestMeta(req, 'minimalMode')) ??\n false\n this.responseCache = new ResponseCache(minimalMode)\n }\n return this.responseCache\n }\n\n public async handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind,\n isFallback,\n prerenderManifest,\n isRoutePPREnabled,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil,\n isMinimalMode,\n }: {\n req: IncomingMessage | BaseNextRequest\n nextConfig: NextConfigComplete\n cacheKey: string | null\n routeKind: RouteKind\n isFallback?: boolean\n prerenderManifest: DeepReadonly<PrerenderManifest>\n isRoutePPREnabled?: boolean\n isOnDemandRevalidate?: boolean\n revalidateOnlyGenerated?: boolean\n responseGenerator: ResponseGenerator\n waitUntil?: (prom: Promise<any>) => void\n isMinimalMode: boolean\n }) {\n const responseCache = this.getResponseCache(req)\n const cacheEntry = await responseCache.get(cacheKey, responseGenerator, {\n routeKind,\n isFallback,\n isRoutePPREnabled,\n isOnDemandRevalidate,\n isPrefetch: req.headers.purpose === 'prefetch',\n incrementalCache: await this.getIncrementalCache(\n req,\n nextConfig,\n prerenderManifest,\n isMinimalMode\n ),\n waitUntil,\n })\n\n if (!cacheEntry) {\n if (\n cacheKey &&\n // revalidate only generated can bail even if cacheKey is provided\n !(isOnDemandRevalidate && revalidateOnlyGenerated)\n ) {\n // A cache entry might not be generated if a response is written\n // in `getInitialProps` or `getServerSideProps`, but those shouldn't\n // have a cache key. If we do have a cache key but we don't end up\n // with a cache entry, then either Next.js or the application has a\n // bug that needs fixing.\n throw new Error('invariant: cache entry required but not generated')\n }\n }\n return cacheEntry\n }\n}\n","export function isAppRouteRoute(route: string): boolean {\n return route.endsWith('/route')\n}\n","/**\n * For a given page path, this function ensures that there is no backslash\n * escaping slashes in the path. Example:\n * - `foo\\/bar\\/baz` -> `foo/bar/baz`\n */\nexport function normalizePathSep(path: string): string {\n return path.replace(/\\\\/g, '/')\n}\n","import type { Key } from 'next/dist/compiled/path-to-regexp'\nimport { regexpToFunction } from 'next/dist/compiled/path-to-regexp'\nimport { pathToRegexp } from 'next/dist/compiled/path-to-regexp'\n\ninterface Options {\n /**\n * A transformer function that will be applied to the regexp generated\n * from the provided path and path-to-regexp.\n */\n regexModifier?: (regex: string) => string\n /**\n * When true the function will remove all unnamed parameters\n * from the matched parameters.\n */\n removeUnnamedParams?: boolean\n /**\n * When true the regexp won't allow an optional trailing delimiter\n * to match.\n */\n strict?: boolean\n\n /**\n * When true the matcher will be case-sensitive, defaults to false\n */\n sensitive?: boolean\n}\n\nexport type PatchMatcher = (\n pathname: string,\n params?: Record<string, any>\n) => Record<string, any> | false\n\n/**\n * Generates a path matcher function for a given path and options based on\n * path-to-regexp. By default the match will be case insensitive, non strict\n * and delimited by `/`.\n */\nexport function getPathMatch(path: string, options?: Options): PatchMatcher {\n const keys: Key[] = []\n const regexp = pathToRegexp(path, keys, {\n delimiter: '/',\n sensitive:\n typeof options?.sensitive === 'boolean' ? options.sensitive : false,\n strict: options?.strict,\n })\n\n const matcher = regexpToFunction<Record<string, any>>(\n options?.regexModifier\n ? new RegExp(options.regexModifier(regexp.source), regexp.flags)\n : regexp,\n keys\n )\n\n /**\n * A matcher function that will check if a given pathname matches the path\n * given in the builder function. When the path does not match it will return\n * `false` but if it does it will return an object with the matched params\n * merged with the params provided in the second argument.\n */\n return (pathname, params) => {\n // If no pathname is provided it's not a match.\n if (typeof pathname !== 'string') return false\n\n const match = matcher(pathname)\n\n // If the path did not match `false` will be returned.\n if (!match) return false\n\n /**\n * If unnamed params are not allowed they must be removed from\n * the matched parameters. path-to-regexp uses \"string\" for named and\n * \"number\" for unnamed parameters.\n */\n if (options?.removeUnnamedParams) {\n for (const key of keys) {\n if (typeof key.name === 'number') {\n delete match.params[key.name]\n }\n }\n }\n\n return { ...params, ...match.params }\n }\n}\n","import type { ParsedUrlQuery } from 'querystring'\n\nimport { searchParamsToUrlQuery } from './querystring'\nimport { parseRelativeUrl } from './parse-relative-url'\n\nexport interface ParsedUrl {\n hash: string\n hostname?: string | null\n href: string\n pathname: string\n port?: string | null\n protocol?: string | null\n query: ParsedUrlQuery\n origin?: string | null\n search: string\n slashes: boolean | undefined\n}\n\nexport function parseUrl(url: string): ParsedUrl {\n if (url.startsWith('/')) {\n return parseRelativeUrl(url)\n }\n\n const parsedURL = new URL(url)\n return {\n hash: parsedURL.hash,\n hostname: parsedURL.hostname,\n href: parsedURL.href,\n pathname: parsedURL.pathname,\n port: parsedURL.port,\n protocol: parsedURL.protocol,\n query: searchParamsToUrlQuery(parsedURL.searchParams),\n search: parsedURL.search,\n origin: parsedURL.origin,\n slashes:\n parsedURL.href.slice(\n parsedURL.protocol.length,\n parsedURL.protocol.length + 2\n ) === '//',\n }\n}\n","import type { ParsedUrlQuery } from 'querystring'\nimport { getLocationOrigin } from '../../utils'\nimport { searchParamsToUrlQuery } from './querystring'\n\nexport interface ParsedRelativeUrl {\n hash: string\n href: string\n pathname: string\n query: ParsedUrlQuery\n search: string\n slashes: undefined\n}\n\n/**\n * Parses path-relative urls (e.g. `/hello/world?foo=bar`). If url isn't path-relative\n * (e.g. `./hello`) then at least base must be.\n * Absolute urls are rejected with one exception, in the browser, absolute urls that are on\n * the current origin will be parsed as relative\n */\nexport function parseRelativeUrl(\n url: string,\n base?: string,\n parseQuery?: true\n): ParsedRelativeUrl\nexport function parseRelativeUrl(\n url: string,\n base: string | undefined,\n parseQuery: false\n): Omit<ParsedRelativeUrl, 'query'>\nexport function parseRelativeUrl(\n url: string,\n base?: string,\n parseQuery = true\n): ParsedRelativeUrl | Omit<ParsedRelativeUrl, 'query'> {\n const globalBase = new URL(\n typeof window === 'undefined' ? 'http://n' : getLocationOrigin()\n )\n\n const resolvedBase = base\n ? new URL(base, globalBase)\n : url.startsWith('.')\n ? new URL(\n typeof window === 'undefined' ? 'http://n' : window.location.href\n )\n : globalBase\n\n const { pathname, searchParams, search, hash, href, origin } = new URL(\n url,\n resolvedBase\n )\n\n if (origin !== globalBase.origin) {\n throw new Error(`invariant: invalid relative URL, router received ${url}`)\n }\n\n return {\n pathname,\n query: parseQuery ? searchParamsToUrlQuery(searchParams) : undefined,\n search,\n hash,\n href: href.slice(origin.length),\n // We don't know for relative URLs at this point since we set a custom, internal\n // base that isn't surfaced to users.\n slashes: undefined,\n }\n}\n","import escapePathDelimiters from '../../../shared/lib/router/utils/escape-path-delimiters'\nimport { DecodeError } from '../../../shared/lib/utils'\n\n/**\n * We only encode path delimiters for path segments from\n * getStaticPaths so we need to attempt decoding the URL\n * to match against and only escape the path delimiters\n * this allows non-ascii values to be handled e.g.\n * Japanese characters.\n * */\nfunction decodePathParams(pathname: string): string {\n // TODO: investigate adding this handling for non-SSG\n // pages so non-ascii names also work there.\n return pathname\n .split('/')\n .map((seg) => {\n try {\n seg = escapePathDelimiters(decodeURIComponent(seg), true)\n } catch (_) {\n // An improperly encoded URL was provided\n throw new DecodeError('Failed to decode path param(s).')\n }\n return seg\n })\n .join('/')\n}\n\nexport { decodePathParams }\n","// escape delimiters used by path-to-regexp\nexport default function escapePathDelimiters(\n segment: string,\n escapeEncoded?: boolean\n): string {\n return segment.replace(\n new RegExp(`([/#?]${escapeEncoded ? '|%(2f|23|3f|5c)' : ''})`, 'gi'),\n (char: string) => encodeURIComponent(char)\n )\n}\n","import { isPlainObject } from '../shared/lib/is-plain-object'\nimport safeStringify from 'next/dist/compiled/safe-stable-stringify'\n\n// We allow some additional attached properties for Next.js errors\nexport interface NextError extends Error {\n type?: string\n page?: string\n code?: string | number\n cancelled?: boolean\n digest?: number\n}\n\n/**\n * Checks whether the given value is a NextError.\n * This can be used to print a more detailed error message with properties like `code` & `digest`.\n */\nexport default function isError(err: unknown): err is NextError {\n return (\n typeof err === 'object' && err !== null && 'name' in err && 'message' in err\n )\n}\n\nexport function getProperError(err: unknown): Error {\n if (isError(err)) {\n return err\n }\n\n if (process.env.NODE_ENV === 'development') {\n // provide better error for case where `throw undefined`\n // is called in development\n if (typeof err === 'undefined') {\n return new Error(\n 'An undefined error was thrown, ' +\n 'see here for more info: https://nextjs.org/docs/messages/threw-undefined'\n )\n }\n\n if (err === null) {\n return new Error(\n 'A null error was thrown, ' +\n 'see here for more info: https://nextjs.org/docs/messages/threw-undefined'\n )\n }\n }\n\n return new Error(isPlainObject(err) ? safeStringify(err) : err + '')\n}\n","import type { IncomingMessage } from 'http'\n\nimport { parse } from 'next/dist/compiled/content-type'\nimport isError from '../../../lib/is-error'\nimport type { SizeLimit } from '../../../types'\nimport { ApiError } from '../index'\n\n/**\n * Parse `JSON` and handles invalid `JSON` strings\n * @param str `JSON` string\n */\nfunction parseJson(str: string): object {\n if (str.length === 0) {\n // special-case empty json body, as it's a common client-side mistake\n return {}\n }\n\n try {\n return JSON.parse(str)\n } catch (e) {\n throw new ApiError(400, 'Invalid JSON')\n }\n}\n\n/**\n * Parse incoming message like `json` or `urlencoded`\n * @param req request object\n */\nexport async function parseBody(\n req: IncomingMessage,\n limit: SizeLimit\n): Promise<any> {\n let contentType\n try {\n contentType = parse(req.headers['content-type'] || 'text/plain')\n } catch {\n contentType = parse('text/plain')\n }\n const { type, parameters } = contentType\n const encoding = parameters.charset || 'utf-8'\n\n let buffer\n\n try {\n const getRawBody =\n require('next/dist/compiled/raw-body') as typeof import('next/dist/compiled/raw-body')\n buffer = await getRawBody(req, { encoding, limit })\n } catch (e) {\n if (isError(e) && e.type === 'entity.too.large') {\n throw new ApiError(413, `Body exceeded ${limit} limit`)\n } else {\n throw new ApiError(400, 'Invalid body')\n }\n }\n\n const body = buffer.toString()\n\n if (type === 'application/json' || type === 'application/ld+json') {\n return parseJson(body)\n } else if (type === 'application/x-www-form-urlencoded') {\n const qs = require('querystring') as typeof import('querystring')\n return qs.decode(body)\n } else {\n return body\n }\n}\n","import type { IncomingMessage, ServerResponse } from 'http'\nimport type { NextApiRequest, NextApiResponse } from '../../../shared/lib/utils'\nimport type { PageConfig, ResponseLimit } from '../../../types'\nimport type { __ApiPreviewProps } from '../.'\nimport type { CookieSerializeOptions } from 'next/dist/compiled/cookie'\n\nimport bytes from 'next/dist/compiled/bytes'\nimport { generateETag } from '../../lib/etag'\nimport { sendEtagResponse } from '../../send-payload'\nimport { Stream } from 'stream'\nimport isError from '../../../lib/is-error'\nimport { isResSent } from '../../../shared/lib/utils'\nimport { interopDefault } from '../../../lib/interop-default'\nimport {\n setLazyProp,\n sendStatusCode,\n redirect,\n clearPreviewData,\n sendError,\n ApiError,\n COOKIE_NAME_PRERENDER_BYPASS,\n COOKIE_NAME_PRERENDER_DATA,\n RESPONSE_LIMIT_DEFAULT,\n} from './../index'\nimport { getCookieParser } from './../get-cookie-parser'\nimport {\n JSON_CONTENT_TYPE_HEADER,\n PRERENDER_REVALIDATE_HEADER,\n PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER,\n} from '../../../lib/constants'\nimport { tryGetPreviewData } from './try-get-preview-data'\nimport { parseBody } from './parse-body'\nimport type { RevalidateFn } from '../../lib/router-utils/router-server-context'\nimport type { InstrumentationOnRequestError } from '../../instrumentation/types'\n\ntype ApiContext = __ApiPreviewProps & {\n trustHostHeader?: boolean\n allowedRevalidateHeaderKeys?: string[]\n hostname?: string\n multiZoneDraftMode?: boolean\n dev: boolean\n internalRevalidate?: RevalidateFn\n}\n\nfunction getMaxContentLength(responseLimit?: ResponseLimit) {\n if (responseLimit && typeof responseLimit !== 'boolean') {\n return bytes.parse(responseLimit)\n }\n return RESPONSE_LIMIT_DEFAULT\n}\n\n/**\n * Send `any` body to response\n * @param req request object\n * @param res response object\n * @param body of response\n */\nfunction sendData(req: NextApiRequest, res: NextApiResponse, body: any): void {\n if (body === null || body === undefined) {\n res.end()\n return\n }\n\n // strip irrelevant headers/body\n if (res.statusCode === 204 || res.statusCode === 304) {\n res.removeHeader('Content-Type')\n res.removeHeader('Content-Length')\n res.removeHeader('Transfer-Encoding')\n\n if (process.env.NODE_ENV === 'development' && body) {\n console.warn(\n `A body was attempted to be set with a 204 statusCode for ${req.url}, this is invalid and the body was ignored.\\n` +\n `See more info here https://nextjs.org/docs/messages/invalid-api-status-body`\n )\n }\n res.end()\n return\n }\n\n const contentType = res.getHeader('Content-Type')\n\n if (body instanceof Stream) {\n if (!contentType) {\n res.setHeader('Content-Type', 'application/octet-stream')\n }\n body.pipe(res)\n return\n }\n\n const isJSONLike = ['object', 'number', 'boolean'].includes(typeof body)\n const stringifiedBody = isJSONLike ? JSON.stringify(body) : body\n const etag = generateETag(stringifiedBody)\n if (sendEtagResponse(req, res, etag)) {\n return\n }\n\n if (Buffer.isBuffer(body)) {\n if (!contentType) {\n res.setHeader('Content-Type', 'application/octet-stream')\n }\n res.setHeader('Content-Length', body.length)\n res.end(body)\n return\n }\n\n if (isJSONLike) {\n res.setHeader('Content-Type', JSON_CONTENT_TYPE_HEADER)\n }\n\n res.setHeader('Content-Length', Buffer.byteLength(stringifiedBody))\n res.end(stringifiedBody)\n}\n\n/**\n * Send `JSON` object\n * @param res response object\n * @param jsonBody of data\n */\nfunction sendJson(res: NextApiResponse, jsonBody: any): void {\n // Set header to application/json\n res.setHeader('Content-Type', JSON_CONTENT_TYPE_HEADER)\n\n // Use send to handle request\n res.send(JSON.stringify(jsonBody))\n}\n\nfunction isValidData(str: any): str is string {\n return typeof str === 'string' && str.length >= 16\n}\n\nfunction setDraftMode<T>(\n res: NextApiResponse<T>,\n options: {\n enable: boolean\n previewModeId?: string\n }\n): NextApiResponse<T> {\n if (!isValidData(options.previewModeId)) {\n throw new Error('invariant: invalid previewModeId')\n }\n const expires = options.enable ? undefined : new Date(0)\n // To delete a cookie, set `expires` to a date in the past:\n // https://tools.ietf.org/html/rfc6265#section-4.1.1\n // `Max-Age: 0` is not valid, thus ignored, and the cookie is persisted.\n const { serialize } =\n require('next/dist/compiled/cookie') as typeof import('next/dist/compiled/cookie')\n const previous = res.getHeader('Set-Cookie')\n res.setHeader(`Set-Cookie`, [\n ...(typeof previous === 'string'\n ? [previous]\n : Array.isArray(previous)\n ? previous\n : []),\n serialize(COOKIE_NAME_PRERENDER_BYPASS, options.previewModeId, {\n httpOnly: true,\n sameSite: process.env.NODE_ENV !== 'development' ? 'none' : 'lax',\n secure: process.env.NODE_ENV !== 'development',\n path: '/',\n expires,\n }),\n ])\n return res\n}\n\nfunction setPreviewData<T>(\n res: NextApiResponse<T>,\n data: object | string, // TODO: strict runtime type checking\n options: {\n maxAge?: number\n path?: string\n } & __ApiPreviewProps\n): NextApiResponse<T> {\n if (!isValidData(options.previewModeId)) {\n throw new Error('invariant: invalid previewModeId')\n }\n if (!isValidData(options.previewModeEncryptionKey)) {\n throw new Error('invariant: invalid previewModeEncryptionKey')\n }\n if (!isValidData(options.previewModeSigningKey)) {\n throw new Error('invariant: invalid previewModeSigningKey')\n }\n\n const jsonwebtoken =\n require('next/dist/compiled/jsonwebtoken') as typeof import('next/dist/compiled/jsonwebtoken')\n const { encryptWithSecret } =\n require('../../crypto-utils') as typeof import('../../crypto-utils')\n const payload = jsonwebtoken.sign(\n {\n data: encryptWithSecret(\n Buffer.from(options.previewModeEncryptionKey),\n JSON.stringify(data)\n ),\n },\n options.previewModeSigningKey,\n {\n algorithm: 'HS256',\n ...(options.maxAge !== undefined\n ? { expiresIn: options.maxAge }\n : undefined),\n }\n )\n\n // limit preview mode cookie to 2KB since we shouldn't store too much\n // data here and browsers drop cookies over 4KB\n if (payload.length > 2048) {\n throw new Error(\n `Preview data is limited to 2KB currently, reduce how much data you are storing as preview data to continue`\n )\n }\n\n const { serialize } =\n require('next/dist/compiled/cookie') as typeof import('next/dist/compiled/cookie')\n const previous = res.getHeader('Set-Cookie')\n res.setHeader(`Set-Cookie`, [\n ...(typeof previous === 'string'\n ? [previous]\n : Array.isArray(previous)\n ? previous\n : []),\n serialize(COOKIE_NAME_PRERENDER_BYPASS, options.previewModeId, {\n httpOnly: true,\n sameSite: process.env.NODE_ENV !== 'development' ? 'none' : 'lax',\n secure: process.env.NODE_ENV !== 'development',\n path: '/',\n ...(options.maxAge !== undefined\n ? ({ maxAge: options.maxAge } as CookieSerializeOptions)\n : undefined),\n ...(options.path !== undefined\n ? ({ path: options.path } as CookieSerializeOptions)\n : undefined),\n }),\n serialize(COOKIE_NAME_PRERENDER_DATA, payload, {\n httpOnly: true,\n sameSite: process.env.NODE_ENV !== 'development' ? 'none' : 'lax',\n secure: process.env.NODE_ENV !== 'development',\n path: '/',\n ...(options.maxAge !== undefined\n ? ({ maxAge: options.maxAge } as CookieSerializeOptions)\n : undefined),\n ...(options.path !== undefined\n ? ({ path: options.path } as CookieSerializeOptions)\n : undefined),\n }),\n ])\n return res\n}\n\nasync function revalidate(\n urlPath: string,\n opts: {\n unstable_onlyGenerated?: boolean\n },\n req: IncomingMessage,\n context: ApiContext\n) {\n if (typeof urlPath !== 'string' || !urlPath.startsWith('/')) {\n throw new Error(\n `Invalid urlPath provided to revalidate(), must be a path e.g. /blog/post-1, received ${urlPath}`\n )\n }\n const revalidateHeaders: HeadersInit = {\n [PRERENDER_REVALIDATE_HEADER]: context.previewModeId,\n ...(opts.unstable_onlyGenerated\n ? {\n [PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER]: '1',\n }\n : {}),\n }\n const allowedRevalidateHeaderKeys = [\n ...(context.allowedRevalidateHeaderKeys || []),\n ]\n\n if (context.trustHostHeader || context.dev) {\n allowedRevalidateHeaderKeys.push('cookie')\n }\n\n if (context.trustHostHeader) {\n allowedRevalidateHeaderKeys.push('x-vercel-protection-bypass')\n }\n\n for (const key of Object.keys(req.headers)) {\n if (allowedRevalidateHeaderKeys.includes(key)) {\n revalidateHeaders[key] = req.headers[key] as string\n }\n }\n\n const internalRevalidate = context.internalRevalidate\n\n try {\n // We use the revalidate in router-server if available.\n // If we are operating without router-server (serverless)\n // we must go through network layer with fetch request\n if (internalRevalidate) {\n return await internalRevalidate({\n urlPath,\n revalidateHeaders,\n opts,\n })\n }\n\n if (context.trustHostHeader) {\n const res = await fetch(`https://${req.headers.host}${urlPath}`, {\n method: 'HEAD',\n headers: revalidateHeaders,\n })\n // we use the cache header to determine successful revalidate as\n // a non-200 status code can be returned from a successful revalidate\n // e.g. notFound: true returns 404 status code but is successful\n const cacheHeader =\n res.headers.get('x-vercel-cache') || res.headers.get('x-nextjs-cache')\n\n if (\n cacheHeader?.toUpperCase() !== 'REVALIDATED' &&\n res.status !== 200 &&\n !(res.status === 404 && opts.unstable_onlyGenerated)\n ) {\n throw new Error(`Invalid response ${res.status}`)\n }\n } else {\n throw new Error(\n `Invariant: missing internal router-server-methods this is an internal bug`\n )\n }\n } catch (err: unknown) {\n throw new Error(\n `Failed to revalidate ${urlPath}: ${isError(err) ? err.message : err}`\n )\n }\n}\n\nexport async function apiResolver(\n req: IncomingMessage,\n res: ServerResponse,\n query: any,\n resolverModule: any,\n apiContext: ApiContext,\n propagateError: boolean,\n dev?: boolean,\n page?: string,\n onError?: InstrumentationOnRequestError\n): Promise<void> {\n const apiReq = req as NextApiRequest\n const apiRes = res as NextApiResponse\n\n try {\n if (!resolverModule) {\n res.statusCode = 404\n res.end('Not Found')\n return\n }\n const config: PageConfig = resolverModule.config || {}\n const bodyParser = config.api?.bodyParser !== false\n const responseLimit = config.api?.responseLimit ?? true\n const externalResolver = config.api?.externalResolver || false\n\n // Parsing of cookies\n setLazyProp({ req: apiReq }, 'cookies', getCookieParser(req.headers))\n // Parsing query string\n apiReq.query = query\n // Parsing preview data\n setLazyProp({ req: apiReq }, 'previewData', () =>\n tryGetPreviewData(req, res, apiContext, !!apiContext.multiZoneDraftMode)\n )\n // Checking if preview mode is enabled\n setLazyProp({ req: apiReq }, 'preview', () =>\n apiReq.previewData !== false ? true : undefined\n )\n // Set draftMode to the same value as preview\n setLazyProp({ req: apiReq }, 'draftMode', () => apiReq.preview)\n\n // Parsing of body\n if (bodyParser && !apiReq.body) {\n apiReq.body = await parseBody(\n apiReq,\n config.api && config.api.bodyParser && config.api.bodyParser.sizeLimit\n ? config.api.bodyParser.sizeLimit\n : '1mb'\n )\n }\n\n let contentLength = 0\n const maxContentLength = getMaxContentLength(responseLimit)\n const writeData = apiRes.write\n const endResponse = apiRes.end\n apiRes.write = (...args: any[2]) => {\n contentLength += Buffer.byteLength(args[0] || '')\n return writeData.apply(apiRes, args)\n }\n apiRes.end = (...args: any[2]) => {\n if (args.length && typeof args[0] !== 'function') {\n contentLength += Buffer.byteLength(args[0] || '')\n }\n\n if (responseLimit && contentLength >= maxContentLength) {\n console.warn(\n `API response for ${req.url} exceeds ${bytes.format(\n maxContentLength\n )}. API Routes are meant to respond quickly. https://nextjs.org/docs/messages/api-routes-response-size-limit`\n )\n }\n\n return endResponse.apply(apiRes, args)\n }\n apiRes.status = (statusCode) => sendStatusCode(apiRes, statusCode)\n apiRes.send = (data) => sendData(apiReq, apiRes, data)\n apiRes.json = (data) => sendJson(apiRes, data)\n apiRes.redirect = (statusOrUrl: number | string, url?: string) =>\n redirect(apiRes, statusOrUrl, url)\n apiRes.setDraftMode = (options = { enable: true }) =>\n setDraftMode(apiRes, Object.assign({}, apiContext, options))\n apiRes.setPreviewData = (data, options = {}) =>\n setPreviewData(apiRes, data, Object.assign({}, apiContext, options))\n apiRes.clearPreviewData = (options = {}) =>\n clearPreviewData(apiRes, options)\n apiRes.revalidate = (\n urlPath: string,\n opts?: {\n unstable_onlyGenerated?: boolean\n }\n ) => revalidate(urlPath, opts || {}, req, apiContext)\n\n const resolver = interopDefault(resolverModule)\n let wasPiped = false\n\n if (process.env.NODE_ENV !== 'production') {\n // listen for pipe event and don't show resolve warning\n res.once('pipe', () => (wasPiped = true))\n }\n\n const apiRouteResult = await resolver(req, res)\n\n if (process.env.NODE_ENV !== 'production') {\n if (typeof apiRouteResult !== 'undefined') {\n if (apiRouteResult instanceof Response) {\n throw new Error(\n 'API route returned a Response object in the Node.js runtime, this is not supported. Please use `runtime: \"edge\"` instead: https://nextjs.org/docs/api-routes/edge-api-routes'\n )\n }\n console.warn(\n `API handler should not return a value, received ${typeof apiRouteResult}.`\n )\n }\n\n if (!externalResolver && !isResSent(res) && !wasPiped) {\n console.warn(\n `API resolved without sending a response for ${req.url}, this may result in stalled requests.`\n )\n }\n }\n } catch (err) {\n await onError?.(\n err,\n {\n method: req.method || 'GET',\n headers: req.headers,\n path: req.url || '/',\n },\n {\n routerKind: 'Pages Router',\n routePath: page || '',\n routeType: 'route',\n revalidateReason: undefined,\n }\n )\n\n if (err instanceof ApiError) {\n sendError(apiRes, err.statusCode, err.message)\n } else {\n if (dev) {\n if (isError(err)) {\n err.page = page\n }\n throw err\n }\n\n console.error(err)\n if (propagateError) {\n throw err\n }\n sendError(apiRes, 500, 'Internal Server Error')\n }\n }\n}\n","/**\n * FNV-1a Hash implementation\n * @author Travis Webb (tjwebb) <me@traviswebb.com>\n *\n * Ported from https://github.com/tjwebb/fnv-plus/blob/master/index.js\n *\n * Simplified, optimized and add modified for 52 bit, which provides a larger hash space\n * and still making use of Javascript's 53-bit integer space.\n */\nexport const fnv1a52 = (str: string) => {\n const len = str.length\n let i = 0,\n t0 = 0,\n v0 = 0x2325,\n t1 = 0,\n v1 = 0x8422,\n t2 = 0,\n v2 = 0x9ce4,\n t3 = 0,\n v3 = 0xcbf2\n\n while (i < len) {\n v0 ^= str.charCodeAt(i++)\n t0 = v0 * 435\n t1 = v1 * 435\n t2 = v2 * 435\n t3 = v3 * 435\n t2 += v0 << 8\n t3 += v1 << 8\n t1 += t0 >>> 16\n v0 = t0 & 65535\n t2 += t1 >>> 16\n v1 = t1 & 65535\n v3 = (t3 + (t2 >>> 16)) & 65535\n v2 = t2 & 65535\n }\n\n return (\n (v3 & 15) * 281474976710656 +\n v2 * 4294967296 +\n v1 * 65536 +\n (v0 ^ (v3 >> 4))\n )\n}\n\nexport const generateETag = (payload: string, weak = false) => {\n const prefix = weak ? 'W/\"' : '\"'\n return (\n prefix + fnv1a52(payload).toString(36) + payload.length.toString(36) + '\"'\n )\n}\n","import type { IncomingMessage, ServerResponse } from 'http'\nimport type RenderResult from './render-result'\nimport type { CacheControl } from './lib/cache-control'\n\nimport { isResSent } from '../shared/lib/utils'\nimport { generateETag } from './lib/etag'\nimport fresh from 'next/dist/compiled/fresh'\nimport { getCacheControlHeader } from './lib/cache-control'\nimport { HTML_CONTENT_TYPE_HEADER } from '../lib/constants'\n\nexport function sendEtagResponse(\n req: IncomingMessage,\n res: ServerResponse,\n etag: string | undefined\n): boolean {\n if (etag) {\n /**\n * The server generating a 304 response MUST generate any of the\n * following header fields that would have been sent in a 200 (OK)\n * response to the same request: Cache-Control, Content-Location, Date,\n * ETag, Expires, and Vary. https://tools.ietf.org/html/rfc7232#section-4.1\n */\n res.setHeader('ETag', etag)\n }\n\n if (fresh(req.headers, { etag })) {\n res.statusCode = 304\n res.end()\n return true\n }\n\n return false\n}\n\nexport async function sendRenderResult({\n req,\n res,\n result,\n generateEtags,\n poweredByHeader,\n cacheControl,\n}: {\n req: IncomingMessage\n res: ServerResponse\n result: RenderResult\n generateEtags: boolean\n poweredByHeader: boolean\n cacheControl: CacheControl | undefined\n}): Promise<void> {\n if (isResSent(res)) {\n return\n }\n\n if (poweredByHeader && result.contentType === HTML_CONTENT_TYPE_HEADER) {\n res.setHeader('X-Powered-By', 'Next.js')\n }\n\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheControl && !res.getHeader('Cache-Control')) {\n res.setHeader('Cache-Control', getCacheControlHeader(cacheControl))\n }\n\n const payload = result.isDynamic ? null : result.toUnchunkedString()\n\n if (generateEtags && payload !== null) {\n const etag = generateETag(payload)\n if (sendEtagResponse(req, res, etag)) {\n return\n }\n }\n\n if (!res.getHeader('Content-Type') && result.contentType) {\n res.setHeader('Content-Type', result.contentType)\n }\n\n if (payload) {\n res.setHeader('Content-Length', Buffer.byteLength(payload))\n }\n\n if (req.method === 'HEAD') {\n res.end(null)\n return\n }\n\n if (payload !== null) {\n res.end(payload)\n return\n }\n\n // Pipe the render result to the response after we get a writer for it.\n await result.pipeToNodeResponse(res)\n}\n","export function interopDefault(mod: any) {\n return mod.default || mod\n}\n","import type { IncomingMessage, ServerResponse } from 'http'\nimport type { PagesAPIRouteDefinition } from '../../route-definitions/pages-api-route-definition'\nimport type { PageConfig } from '../../../types'\nimport type { ParsedUrlQuery } from 'querystring'\nimport { wrapApiHandler, type __ApiPreviewProps } from '../../api-utils'\nimport type { RouteModuleOptions } from '../route-module'\n\nimport { RouteModule, type RouteModuleHandleContext } from '../route-module'\nimport { apiResolver } from '../../api-utils/node/api-resolver'\nimport type { RevalidateFn } from '../../lib/router-utils/router-server-context'\n\ntype PagesAPIHandleFn = (\n req: IncomingMessage,\n res: ServerResponse\n) => Promise<void>\n\n/**\n * The PagesAPIModule is the type of the module exported by the bundled Pages\n * API module.\n */\nexport type PagesAPIModule = typeof import('../../../build/templates/pages-api')\n\ntype PagesAPIUserlandModule = {\n /**\n * The exported handler method.\n */\n readonly default: PagesAPIHandleFn\n\n /**\n * The exported page config.\n */\n readonly config?: PageConfig\n}\n\ntype PagesAPIRouteHandlerContext = RouteModuleHandleContext & {\n /**\n * The incoming server request in non-edge runtime.\n */\n req?: IncomingMessage\n\n /**\n * The outgoing server response in non-edge runtime.\n */\n res?: ServerResponse\n\n /**\n * The hostname for the request.\n */\n hostname?: string\n\n /**\n * Keys allowed in the revalidate call.\n */\n allowedRevalidateHeaderKeys?: string[]\n\n /**\n * Whether to trust the host header.\n */\n trustHostHeader?: boolean\n\n /**\n * The query for the request.\n */\n query: ParsedUrlQuery\n\n /**\n * The preview props used by the `preview` API.\n */\n previewProps: __ApiPreviewProps\n\n /**\n * True if the server is in development mode.\n */\n dev: boolean\n\n /**\n * Whether errors should be left uncaught to handle\n * higher up\n */\n propagateError: boolean\n\n /**\n * The page that's being rendered.\n */\n page: string\n\n /**\n * The error handler for the request.\n */\n onError?: Parameters<typeof apiResolver>[8]\n\n /**\n * whether multi-zone flag is enabled for draft mode\n */\n multiZoneDraftMode?: boolean\n\n /**\n * Internal revalidate function to avoid revalidating\n * over the network\n */\n internalRevalidate?: RevalidateFn\n}\n\nexport type PagesAPIRouteModuleOptions = RouteModuleOptions<\n PagesAPIRouteDefinition,\n PagesAPIUserlandModule\n>\n\nexport class PagesAPIRouteModule extends RouteModule<\n PagesAPIRouteDefinition,\n PagesAPIUserlandModule\n> {\n private apiResolverWrapped: typeof apiResolver\n\n constructor(options: PagesAPIRouteModuleOptions) {\n super(options)\n\n if (typeof options.userland.default !== 'function') {\n throw new Error(\n `Page ${options.definition.page} does not export a default function.`\n )\n }\n\n this.apiResolverWrapped = wrapApiHandler(\n options.definition.page,\n apiResolver\n )\n }\n\n /**\n *\n * @param req the incoming server request\n * @param res the outgoing server response\n * @param context the context for the render\n */\n public async render(\n req: IncomingMessage,\n res: ServerResponse,\n context: PagesAPIRouteHandlerContext\n ): Promise<void> {\n const { apiResolverWrapped } = this\n await apiResolverWrapped(\n req,\n res,\n context.query,\n this.userland,\n {\n ...context.previewProps,\n trustHostHeader: context.trustHostHeader,\n allowedRevalidateHeaderKeys: context.allowedRevalidateHeaderKeys,\n hostname: context.hostname,\n multiZoneDraftMode: context.multiZoneDraftMode,\n dev: context.dev,\n internalRevalidate: context.internalRevalidate,\n },\n context.propagateError,\n context.dev,\n context.page,\n context.onError\n )\n }\n}\n\nexport default PagesAPIRouteModule\n"],"names":["Object","Date","Boolean","encodeURIComponent","Map","decodeURIComponent","p","Number","Symbol","Array","n","r","JSON","e","i","Math","u","isNaN","parseFloat","parseInt","__dirname","__nccwpck_require__","TypeError","String","s","a","isFinite","NaN","o","v","x","RegExp","t","Int8Array","RangeError","Error","arguments","c","Set","HTML_CONTENT_TYPE_HEADER","JSON_CONTENT_TYPE_HEADER","NEXT_QUERY_PARAM_PREFIX","NEXT_INTERCEPTION_MARKER_PREFIX","PRERENDER_REVALIDATE_HEADER","PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER","RSC_PREFETCH_SUFFIX","RSC_SEGMENTS_DIR_SUFFIX","RSC_SEGMENT_SUFFIX","RSC_SUFFIX","NEXT_DATA_SUFFIX","NEXT_META_SUFFIX","NEXT_CACHE_TAGS_HEADER","NEXT_CACHE_REVALIDATED_TAGS_HEADER","NEXT_CACHE_REVALIDATE_TAG_TOKEN_HEADER","CACHE_ONE_YEAR","WEBPACK_LAYERS_NAMES","shared","reactServerComponents","serverSideRendering","actionBrowser","apiNode","apiEdge","middleware","instrument","edgeAsset","appPagesBrowser","pagesDirBrowser","pagesDirEdge","pagesDirNode","GROUP","builtinReact","serverOnly","neutralTarget","clientOnly","bundled","appPages","formatDynamicImportPath","dir","filePath","absoluteFilePath","path","pathToFileURL","toString","wrapApiHandler","page","handler","args","getTracer","setRootSpanAttribute","trace","NodeSpan","spanName","sendStatusCode","res","statusCode","redirect","statusOrUrl","url","writeHead","Location","write","end","checkIsOnDemandRevalidate","req","previewProps","headers","HeadersAdapter","isOnDemandRevalidate","previewModeId","get","revalidateOnlyGenerated","has","COOKIE_NAME_PRERENDER_BYPASS","COOKIE_NAME_PRERENDER_DATA","RESPONSE_LIMIT_DEFAULT","SYMBOL_PREVIEW_DATA","SYMBOL_CLEARED_COOKIES","clearPreviewData","options","serialize","require","previous","getHeader","setHeader","isArray","expires","httpOnly","sameSite","secure","process","undefined","defineProperty","value","enumerable","ApiError","constructor","message","sendError","statusMessage","setLazyProp","prop","getter","opts","configurable","optsReset","writable","set","tryGetPreviewData","multiZoneDraftMode","cookies","encryptedPreviewData","RequestCookies","tokenPreviewData","data","jsonwebtoken","verify","previewModeSigningKey","decryptWithSecret","decryptedPreviewData","Buffer","from","previewModeEncryptionKey","parse","CIPHER_ALGORITHM","encryptWithSecret","secret","iv","crypto","salt","key","cipher","encrypted","concat","update","final","tag","getAuthTag","encryptedData","buffer","slice","CIPHER_SALT_LENGTH","decipher","setAuthTag","nodeFs","existsSync","fs","readFile","readFileSync","writeFile","f","d","mkdir","recursive","stat","NextNodeServerSpan","ReflectAdapter","target","receiver","Reflect","bind","deleteProperty","ReadonlyHeadersError","callable","Headers","Proxy","lowercased","toLowerCase","original","keys","find","seal","merge","join","append","name","existing","push","delete","forEach","callbackfn","thisArg","entries","call","values","iterator","module","COMPILER_NAMES","client","server","edgeServer","BUILD_MANIFEST","parseReqUrl","parsedUrl","parseUrl","parsed","URL","query","searchParams","getAll","length","hash","search","pathname","href","host","hostname","auth","protocol","slashes","port","features","typescript","cache","WeakMap","normalizeLocalePath","locales","detectedLocale","lowercasedLocales","map","locale","segments","split","segment","index","indexOf","ensureLeadingSlash","startsWith","normalizeAppPath","route","reduce","endsWith","normalizeRscURL","replace","INTERCEPTION_ROUTE_MARKERS","isInterceptionRouteAppPath","m","TEST_ROUTE","TEST_STRICT_ROUTE","isDynamicRoute","strict","extractInterceptionRouteInformation","interceptingRoute","marker","interceptedRoute","splitInterceptingRoute","test","parsePath","hashIndex","queryIndex","hasQuery","substring","pathHasPrefix","prefix","removePathPrefix","withoutPrefix","reHasRegExp","reReplaceRegExp","escapeStringRegexp","str","removeTrailingSlash","InvariantError","PARAMETER_PATTERN","parseMatchedParameter","param","optional","repeat","getSafeKeyFromSegment","interceptionMarker","getSafeRouteKey","routeKeys","keyPrefix","backreferenceDuplicateKeys","pattern","cleanedKey","invalidKey","duplicateKey","interceptionPrefix","SP","performance","every","method","DecodeError","NormalizeError","PARAM_SEPARATOR","hasAdjacentParameterIssues","normalizeAdjacentParameters","normalized","stripNormalizedSeparators","safePathToRegexp","pathToRegexp","needsNormalization","routeToUse","error","normalizedRoute","retryError","safeCompile","compiler","compile","params","getRouteMatcher","re","groups","matcherFn","routeMatch","exec","decode","group","match","pos","entry","result","cleaned","item","searchParamsToUrlQuery","stringifyUrlQueryParam","getCookieParser","cookie","parseCookieFn","unescapeSegments","compileNonPath","includes","validate","normalizeNextQueryParam","decodeQueryPathParameter","slashedProtocols","filterInternalQuery","paramKeys","isNextQueryPrefix","isNextInterceptionMarkerPrefix","detectDomainLocale","domainItems","domain","defaultLocale","some","getHostname","normalizeDataPath","NEXT_REQUEST_META","for","getRequestMeta","meta","normalizePagePath","posix","resolvedPage","normalize","STATIC_METADATA_IMAGES","icon","filename","extensions","apple","openGraph","twitter","getExtensionRegexString","staticExtensions","dynamicExtensions","FAVICON_REGEX","ROBOTS_TXT_REGEX","MANIFEST_JSON_REGEX","MANIFEST_WEBMANIFEST_REGEX","SITEMAP_XML_REGEX","compiledRegexCache","DetachedPromise","resolve","reject","promise","Promise","rej","Batcher","cacheKeyFn","schedulerFn","fn","pending","create","batch","cacheKey","err","scheduleOnNextTick","cb","then","nextTick","CachedRouteKind","IncrementalCacheKind","voidCatch","Uint8Array","encoder","TextEncoder","streamFromString","ReadableStream","start","controller","enqueue","encode","close","streamFromBuffer","chunk","streamToString","stream","signal","decoder","TextDecoder","fatal","string","aborted","addPathPrefix","addPathSuffix","suffix","REGEX_LOCALHOST_HOSTNAME","parseURL","base","Internal","NextURL","input","baseOrOpts","basePath","analyze","info","getNextPathnameInfo","i18n","trailingSlash","nextConfig","pathnameNoDataPrefix","paths","buildId","parseData","i18nProvider","env","__NEXT_NO_MIDDLEWARE_URL_NORMALIZE","domainLocale","domains","formatPathname","addLocale","ignorePrefix","lower","forceLocale","formatSearch","origin","password","username","toJSON","clone","Request","ResponseAbortedName","ResponseAborted","clientComponentLoadStart","clientComponentLoadTimes","clientComponentLoadCount","isAbortError","pipeToNodeResponse","readable","waitUntilForEnd","errored","destroyed","createAbortController","response","AbortController","once","writableFinished","abort","writer","createWriterFromResponse","started","drained","onDrain","on","off","finished","WritableStream","globalThis","NEXT_OTEL_PERFORMANCE_PREFIX","metrics","getClientComponentLoaderMetrics","reset","measure","flushHeaders","ok","flush","cause","destroy","pipeTo","RenderResult","EMPTY","metadata","contentType","fromStatic","waitUntil","assignMetadata","assign","isNull","isDynamic","toUnchunkedString","isBuffer","chainStreams","streams","TransformStream","preventClose","nextStream","lastStream","catch","coerce","unshift","RouteKind","fromResponseCacheEntry","cacheEntry","kind","html","pageData","status","postponed","rscData","segmentData","toResponseCacheEntry","isMiss","isStale","cacheControl","ResponseCache","minimal_mode","getBatcher","revalidateBatcher","responseGenerator","context","hasResolved","previousCacheEntry","previousCacheItem","expiresAt","now","incrementalCache","isFallback","isRoutePPREnabled","isPrefetch","routeKind","handleGet","previousIncrementalCacheEntry","resolved","routeKindToIncrementalCacheKind","incrementalResponseCacheEntry","revalidate","console","handleRevalidate","responseCacheEntry","isRevalidating","min","max","expire","MultiFileWriter","tasks","findOrCreateTask","directory","task","wait","all","flatMap","FileSystemCache","debug","NEXT_PRIVATE_DEBUG_CACHE","ctx","flushToDisk","serverDistDir","revalidatedTags","maxMemoryCacheSize","memoryCache","log","getMemoryCache","resetRequestCache","revalidateTag","tags","durations","existingEntry","tagsManifest","updates","stale","expired","getFilePath","fileData","mtime","lastModified","getTime","body","fetchIdx","fetchUrl","parsedData","storedTags","fetchCache","maybeSegmentData","segmentPaths","segmentsDir","segmentPath","segmentDataFilePath","tagsHeader","cacheTags","areTagsExpired","combinedTags","softTags","stringify","isAppPath","htmlPath","toRoute","IncrementalCache","dev","minimalMode","requestHeaders","getPrerenderManifest","fetchCacheKeyPrefix","CurCacheHandler","allowedRevalidateHeaderKeys","locks","hasCustomCacheHandler","cacheHandlersSymbol","_globalThis","globalCacheHandler","FetchCache","__NEXT_TEST_MAX_ISR_CACHE","disableForTestmode","NEXT_PRIVATE_TEST_PROXY","prerenderManifest","cacheControls","SharedCacheControls","preview","getPreviouslyRevalidatedTags","cacheHandler","_requestHeaders","calculateRevalidate","fromTime","floor","timeOrigin","initialRevalidateSeconds","_getPathname","lock","generateCacheKey","init","bodyChunks","_ogBody","getReader","readableBody","chunks","total","arr","arrayBuffer","offset","formData","val","text","blob","Blob","type","fromEntries","cacheString","mode","credentials","referrer","referrerPolicy","integrity","createHash","digest","cacheData","revalidateAfter","workUnitStore","workUnitAsyncStorage","resumeDataCache","getRenderResumeDataCache","memoryCacheData","fetch","workStore","workAsyncStorage","pendingRevalidatedTags","prerenderResumeDataCache","getPrerenderResumeDataCache","age","areTagsStale","notFoundRoutes","itemSize","isImplicitBuildTimeCache","warningText","warn","LRUNode","size","prev","next","SentinelNode","LRUCache","maxSize","calculateSize","totalSize","head","tail","addToHead","node","removeNode","moveToHead","removeTail","lastNode","newNode","current","remove","currentSize","createDefaultCacheHandler","refreshTags","getExpiration","updateTags","pendingSets","pendingPromise","privateEntry","timestamp","returnStream","newSaved","tee","pendingEntry","resolvePending","clonedValue","reader","read","done","byteLength","isErrored","errorRetryCount","expiration","round","handlersSymbol","handlersMapSymbol","handlersSetSymbol","reference","interopDefault","mod","default","RouterServerContextSymbol","routerServerGlobal","isInterceptionRouteRewrite","dynamicImportEsmDefault","id","RouteModule","userland","definition","distDir","relativeProjectDir","isDev","instrumentationOnRequestError","absoluteProjectDir","cwd","loadManifests","srcPage","projectDir","loadManifestFromRelativePath","normalizedPagePath","router","routesManifest","buildManifest","fallbackBuildManifest","reactLoadableManifest","nextFontManifest","clientReferenceManifest","serverActionsManifest","subresourceIntegrityManifest","serverFilesManifest","dynamicCssManifest","manifest","shouldCache","handleMissing","isStaticMetadataRoute","isAppRouteRoute","isMetadataRouteFile","appDirRelativePath","pageExtensions","strictlyMatchExtensions","normalizedPath","fastResult","regexes","getCompiledRegexes","cached","trailingMatcher","suffixMatcher","variantsMatcher","robotsExts","manifestExts","useEval","skipParse","__RSC_MANIFEST","interceptionRoutePatterns","rewrites","beforeFiles","filter","rewrite","regex","loadCustomCacheHandlers","cacheMaxMemorySize","cacheHandlers","initializeCacheHandlers","fallback","DefaultCache","RemoteCache","add","getIncrementalCache","isMinimalMode","CacheHandler","experimental","isrFlushToDisk","__incrementalCache","onRequestError","errorContext","routerServerContext","logErrorWithOriginalStack","prepare","localeResult","previewData","relative","absoluteDistDir","ensureInstrumentationRegistered","manifests","isNextDataRequest","originalPathname","originalQuery","pageIsDynamic","normalizedSrcPage","serverUtils","getServerUtils","caseSensitive","defaultRouteRegex","dynamicRouteMatcher","defaultRouteMatches","getNamedRouteRegex","getNamedParametrizedRoute","prefixRouteKeys","includeSuffix","includePrefix","names","intercepted","routeKey","j","fromCharCode","inverseParts","structuredClone","hasInterceptionMarker","paramMatches","namedParameterizedRoute","pathToRegexpPattern","namedRegex","excludeOptionalTrailingSlash","getRouteRegex","parameterizedRoute","getParametrizedRoute","groupIndex","markerMatch","handleRewrites","rewrittenParsedUrl","rewriteParams","fsPathname","checkRewrite","matcher","getPathMatch","regexp","delimiter","sensitive","regexpToFunction","regexModifier","source","flags","removeUnnamedParams","missing","hasParams","matchHas","hasMatch","hasItem","getSafeParamName","paramName","newParamName","charCode","charCodeAt","matches","groupKey","parsedDestination","destQuery","prepareDestination","destHostnameCompiler","newUrl","parseDestination","escaped","destination","parseRelativeUrl","parseQuery","globalBase","resolvedBase","parsedURL","destHostname","destSearch","destPath","destParams","destPathParamKeys","destHostnameParamKeys","destPathCompiler","strOrArray","appendParamsToQuery","nextInternalLocale","dynamicParams","afterFiles","matchesPage","fsPathnameNoSlash","normalizeQueryParams","routeParamKeys","normalizedKey","getParamsFromRouteMatches","routeMatchesHeader","routeMatches","obj","URLSearchParams","keyName","normalizeDynamicRouteParams","ignoreMissingOptional","hasValidParams","defaultValue","isOptional","isDefaultValue","defaultVal","normalizeCdnUrl","_parsedUrl","formatUrl","urlObj","querystring","interpolateDynamicPath","paramValue","builtParam","replaceAll","__NEXT_TRAILING_SLASH","addRequestMeta","request","rewriteParamKeys","paramsMatch","paramsResult","combinedParamKeys","originalValue","queryValue","paramsToInterpolate","queryResult","isDraftMode","config","resolvedPathname","encodedResolvedPathname","seg","char","_","getResponseCache","responseCache","MINIMAL_MODE","handleResponse","purpose","isError","parseBody","limit","parameters","encoding","charset","getRawBody","parseJson","qs","isValidData","urlPath","revalidateHeaders","unstable_onlyGenerated","trustHostHeader","internalRevalidate","cacheHeader","toUpperCase","apiResolver","resolverModule","apiContext","propagateError","onError","bodyParser","api","responseLimit","externalResolver","apiReq","sizeLimit","contentLength","maxContentLength","bytes","writeData","apiRes","endResponse","apply","send","sendData","removeHeader","Stream","pipe","isJSONLike","stringifiedBody","etag","generateETag","payload","weak","fnv1a52","len","t0","v0","t1","v1","t2","v2","t3","v3","fresh","json","setDraftMode","enable","setPreviewData","sign","algorithm","maxAge","expiresIn","resolver","routerKind","routePath","routeType","revalidateReason","PagesAPIRouteModule","apiResolverWrapped","render"],"mappings":"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","ignoreList":[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33,34,35,36,37,38,39,40,41,42,43,44,45,46,47,48,49,50,51,52,53,54,55,56,57,58,59,60,61,62,63,64,65,66,67,68,69,70,71,72,73,74,75,76,77,78,79,80,81,82,83,84,85,86,87,88,89,90,91,92,93,94,95,96,97,98,99,100,101]}