{"version":3,"file":"pages-api.runtime.prod.js","sources":["webpack://next/webpack/runtime/create_fake_namespace_object","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/./src/lib/constants.ts","webpack://next/./src/lib/format-dynamic-import-path.ts","webpack://next/./src/server/api-utils/index.ts","webpack://next/./src/server/api-utils/node/try-get-preview-data.ts","webpack://next/./src/server/crypto-utils.ts","webpack://next/./src/server/lib/node-fs-methods.ts","webpack://next/./src/server/lib/trace/constants.ts","webpack://next/./src/server/lib/router-utils/is-postpone.ts","webpack://next/./src/server/node-environment-extensions/process-error-handlers.ts","webpack://next/./src/server/web/spec-extension/adapters/reflect.ts","webpack://next/./src/server/web/spec-extension/adapters/headers.ts","webpack://next/./src/shared/lib/isomorphic/path.js","webpack://next/./src/shared/lib/modern-browserslist-target.js","webpack://next/webpack/runtime/compat_get_default_export","webpack://next/webpack/runtime/define_property_getters","webpack://next/webpack/runtime/has_own_property","webpack://next/webpack/runtime/make_namespace_object","webpack://next/./src/server/response-cache/types.ts","webpack://next/./src/server/route-kind.ts","webpack://next/./src/lib/picocolors.ts","webpack://next/./src/shared/lib/constants.ts","webpack://next/./src/lib/url.ts","webpack://next/./src/shared/lib/i18n/normalize-locale-path.ts","webpack://next/./src/shared/lib/page-path/ensure-leading-slash.ts","webpack://next/./src/shared/lib/router/utils/app-paths.ts","webpack://next/./src/shared/lib/segment.ts","webpack://next/./src/shared/lib/router/utils/interception-routes.ts","webpack://next/./src/shared/lib/router/utils/is-dynamic.ts","webpack://next/./src/shared/lib/router/utils/parse-path.ts","webpack://next/./src/shared/lib/router/utils/path-has-prefix.ts","webpack://next/./src/shared/lib/router/utils/remove-path-prefix.ts","webpack://next/./src/shared/lib/escape-regexp.ts","webpack://next/./src/shared/lib/router/utils/remove-trailing-slash.ts","webpack://next/./src/shared/lib/invariant-error.ts","webpack://next/./src/shared/lib/router/utils/get-dynamic-param.ts","webpack://next/./src/shared/lib/router/utils/route-regex.ts","webpack://next/./src/shared/lib/utils.ts","webpack://next/./src/lib/route-pattern-normalizer.ts","webpack://next/./src/shared/lib/router/utils/route-match-utils.ts","webpack://next/./src/shared/lib/router/utils/route-matcher.ts","webpack://next/./src/shared/lib/router/utils/querystring.ts","webpack://next/./src/server/api-utils/get-cookie-parser.ts","webpack://next/./src/shared/lib/router/utils/prepare-destination.ts","webpack://next/./src/server/web/utils.ts","webpack://next/./src/server/lib/decode-query-path-parameter.ts","webpack://next/./src/shared/lib/router/utils/format-url.ts","webpack://next/./src/server/server-utils.ts","webpack://next/./src/shared/lib/i18n/detect-domain-locale.ts","webpack://next/./src/shared/lib/get-hostname.ts","webpack://next/./src/shared/lib/page-path/normalize-data-path.ts","webpack://next/./src/server/request-meta.ts","webpack://next/./src/shared/lib/page-path/normalize-page-path.ts","webpack://next/./src/lib/metadata/is-metadata-route.ts","webpack://next/./src/lib/detached-promise.ts","webpack://next/./src/lib/batcher.ts","webpack://next/./src/server/lib/lru-cache.ts","webpack://next/./src/build/output/log.ts","webpack://next/./src/lib/scheduler.ts","webpack://next/./src/server/stream-utils/node-web-streams-helper.ts","webpack://next/./src/server/stream-utils/encoded-tags.ts","webpack://next/./src/shared/lib/router/utils/add-path-prefix.ts","webpack://next/./src/shared/lib/router/utils/add-path-suffix.ts","webpack://next/./src/server/web/next-url.ts","webpack://next/./src/shared/lib/router/utils/get-next-pathname-info.ts","webpack://next/./src/shared/lib/router/utils/format-next-pathname-info.ts","webpack://next/./src/shared/lib/router/utils/add-locale.ts","webpack://next/./src/server/web/spec-extension/request.ts","webpack://next/./src/server/web/spec-extension/adapters/next-request.ts","webpack://next/./src/server/client-component-renderer-logger.ts","webpack://next/./src/server/pipe-readable.ts","webpack://next/./src/server/render-result.ts","webpack://next/./src/server/response-cache/utils.ts","webpack://next/./src/server/response-cache/index.ts","webpack://next/./src/lib/multi-file-writer.ts","webpack://next/./src/server/lib/incremental-cache/file-system-cache.ts","webpack://next/./src/server/lib/to-route.ts","webpack://next/./src/server/lib/incremental-cache/index.ts","webpack://next/./src/server/lib/cache-handlers/default.ts","webpack://next/./src/server/use-cache/handlers.ts","webpack://next/./src/server/app-render/interop-default.ts","webpack://next/./src/server/lib/router-utils/router-server-context.ts","webpack://next/./src/lib/is-interception-route-rewrite.ts","webpack://next/./src/client/components/app-router-headers.ts","webpack://next/./src/server/route-modules/route-module.ts","webpack://next/./src/lib/is-app-route-route.ts","webpack://next/./src/shared/lib/page-path/normalize-path-sep.ts","webpack://next/./src/shared/lib/router/utils/path-match.ts","webpack://next/./src/shared/lib/router/utils/parse-url.ts","webpack://next/./src/shared/lib/router/utils/parse-relative-url.ts","webpack://next/./src/server/lib/router-utils/decode-path-params.ts","webpack://next/./src/shared/lib/router/utils/escape-path-delimiters.ts","webpack://next/./src/lib/is-error.ts","webpack://next/./src/server/api-utils/node/parse-body.ts","webpack://next/./src/server/api-utils/node/api-resolver.ts","webpack://next/./src/server/lib/etag.ts","webpack://next/./src/server/send-payload.ts","webpack://next/./src/lib/interop-default.ts","webpack://next/./src/server/route-modules/pages-api/module.ts"],"sourcesContent":["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' || typeof current == 'function') && !~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};","\"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})();","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_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_NAV_DEPLOYMENT_ID_HEADER = 'x-nextjs-deployment-id'\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'\nexport const NEXT_RESUME_STATE_LENGTH_HEADER = 'x-next-resume-state-length'\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_'\nexport const NEXT_CACHE_ROOT_PARAM_TAG_ID = '_N_RP_'\n\n// in seconds\nexport const CACHE_ONE_YEAR_SECONDS = 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 = new Set([\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 = new Set([\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","const REACT_POSTPONE_TYPE: symbol = Symbol.for('react.postpone')\n\nexport function isPostpone(error: any): boolean {\n  return (\n    typeof error === 'object' &&\n    error !== null &&\n    error.$$typeof === REACT_POSTPONE_TYPE\n  )\n}\n","import { isPostpone } from '../lib/router-utils/is-postpone'\n\nlet _global = globalThis as typeof globalThis & {\n  nextInitializedProcessErrorHandlers?: boolean\n}\n\nexport function installProcessErrorHandlers(\n  shouldRemoveUncaughtErrorAndRejectionListeners: boolean\n) {\n  if (_global.nextInitializedProcessErrorHandlers) return\n  _global.nextInitializedProcessErrorHandlers = true\n  // The conventional wisdom of Node.js and other runtimes is to treat\n  // unhandled errors as fatal and exit the process.\n  //\n  // But Next.js is not a generic JS runtime — it's a specialized runtime for\n  // React Server Components.\n  //\n  // Many unhandled rejections are due to the late-awaiting pattern for\n  // prefetching data. In Next.js it's OK to call an async function without\n  // immediately awaiting it, to start the request as soon as possible\n  // without blocking unncessarily on the result. These can end up\n  // triggering an \"unhandledRejection\" if it later turns out that the\n  // data is not needed to render the page. Example:\n  //\n  //     const promise = fetchData()\n  //     const shouldShow = await checkCondition()\n  //     if (shouldShow) {\n  //       return <Component promise={promise} />\n  //     }\n  //\n  // In this example, `fetchData` is called immediately to start the request\n  // as soon as possible, but if `shouldShow` is false, then it will be\n  // discarded without unwrapping its result. If it errors, it will trigger\n  // an \"unhandledRejection\" event.\n  //\n  // Ideally, we would suppress these rejections completely without warning,\n  // because we don't consider them real errors. (TODO: Currently we do warn.)\n  //\n  // But regardless of whether we do or don't warn, we definitely shouldn't\n  // crash the entire process.\n  //\n  // Even a \"legit\" unhandled error unrelated to prefetching shouldn't\n  // prevent the rest of the page from rendering.\n  //\n  // So, we're going to intentionally override the default error handling\n  // behavior of the outer JS runtime to be more forgiving\n\n  // Remove any existing \"unhandledRejection\" and \"uncaughtException\" handlers.\n  // This is gated behind an experimental flag until we've considered the impact\n  // in various deployment environments. It's possible this may always need to\n  // be configurable.\n  if (shouldRemoveUncaughtErrorAndRejectionListeners) {\n    process.removeAllListeners('uncaughtException')\n    process.removeAllListeners('unhandledRejection')\n  }\n\n  // Install a new handler to prevent the process from crashing.\n  process.on('unhandledRejection', (reason: unknown) => {\n    if (isPostpone(reason)) {\n      // React postpones that are unhandled might end up logged here but they're\n      // not really errors. They're just part of rendering.\n      return\n    }\n    // Immediately log the error.\n    // TODO: Ideally, if we knew that this error was triggered by application\n    // code, we would suppress it entirely without logging. We can't reliably\n    // detect all of these, but when cacheComponents is enabled, we could suppress\n    // at least some of them by waiting to log the error until after all in-\n    // progress renders have completed. Then, only log errors for which there\n    // was not a corresponding \"rejectionHandled\" event.\n    console.error(reason)\n  })\n\n  process.on('rejectionHandled', () => {\n    // TODO: See note in the unhandledRejection handler above. In the future,\n    // we may use the \"rejectionHandled\" event to de-queue an error from\n    // being logged.\n  })\n\n  // Unhandled exceptions are errors triggered by non-async functions, so this\n  // is unrelated to the late-awaiting pattern. However, for similar reasons,\n  // we still shouldn't crash the process. Just log it.\n  process.on('uncaughtException', (reason: unknown) => {\n    if (isPostpone(reason)) {\n      return\n    }\n    console.error(reason)\n  })\n}\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","__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 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  revalidate?: number\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  isFallback?: 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  isFallback?: 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","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","// ISC License\n\n// Copyright (c) 2021 Alexey Raspopov, Kostiantyn Denysov, Anton Verinov\n\n// Permission to use, copy, modify, and/or distribute this software for any\n// purpose with or without fee is hereby granted, provided that the above\n// copyright notice and this permission notice appear in all copies.\n\n// THE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES\n// WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF\n// MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR\n// ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES\n// WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN\n// ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF\n// OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.\n//\n// https://github.com/alexeyraspopov/picocolors/blob/b6261487e7b81aaab2440e397a356732cad9e342/picocolors.js#L1\n\nconst { env, stdout } = globalThis?.process ?? {}\n\nconst enabled =\n  env &&\n  !env.NO_COLOR &&\n  (env.FORCE_COLOR || (stdout?.isTTY && !env.CI && env.TERM !== 'dumb'))\n\nconst replaceClose = (\n  str: string,\n  close: string,\n  replace: string,\n  index: number\n): string => {\n  const start = str.substring(0, index) + replace\n  const end = str.substring(index + close.length)\n  const nextIndex = end.indexOf(close)\n  return ~nextIndex\n    ? start + replaceClose(end, close, replace, nextIndex)\n    : start + end\n}\n\nconst formatter = (open: string, close: string, replace = open) => {\n  if (!enabled) return String\n  return (input: string) => {\n    const string = '' + input\n    const index = string.indexOf(close, open.length)\n    return ~index\n      ? open + replaceClose(string, close, replace, index) + close\n      : open + string + close\n  }\n}\n\nexport const reset = enabled ? (s: string) => `\\x1b[0m${s}\\x1b[0m` : String\nexport const bold = formatter('\\x1b[1m', '\\x1b[22m', '\\x1b[22m\\x1b[1m')\nexport const dim = formatter('\\x1b[2m', '\\x1b[22m', '\\x1b[22m\\x1b[2m')\nexport const italic = formatter('\\x1b[3m', '\\x1b[23m')\nexport const underline = formatter('\\x1b[4m', '\\x1b[24m')\nexport const inverse = formatter('\\x1b[7m', '\\x1b[27m')\nexport const hidden = formatter('\\x1b[8m', '\\x1b[28m')\nexport const strikethrough = formatter('\\x1b[9m', '\\x1b[29m')\nexport const black = formatter('\\x1b[30m', '\\x1b[39m')\nexport const red = formatter('\\x1b[31m', '\\x1b[39m')\nexport const green = formatter('\\x1b[32m', '\\x1b[39m')\nexport const yellow = formatter('\\x1b[33m', '\\x1b[39m')\nexport const blue = formatter('\\x1b[34m', '\\x1b[39m')\nexport const magenta = formatter('\\x1b[35m', '\\x1b[39m')\nexport const purple = formatter('\\x1b[38;2;173;127;168m', '\\x1b[39m')\nexport const cyan = formatter('\\x1b[36m', '\\x1b[39m')\nexport const white = formatter('\\x1b[37m', '\\x1b[39m')\nexport const gray = formatter('\\x1b[90m', '\\x1b[39m')\nexport const bgBlack = formatter('\\x1b[40m', '\\x1b[49m')\nexport const bgRed = formatter('\\x1b[41m', '\\x1b[49m')\nexport const bgGreen = formatter('\\x1b[42m', '\\x1b[49m')\nexport const bgYellow = formatter('\\x1b[43m', '\\x1b[49m')\nexport const bgBlue = formatter('\\x1b[44m', '\\x1b[49m')\nexport const bgMagenta = formatter('\\x1b[45m', '\\x1b[49m')\nexport const bgCyan = formatter('\\x1b[46m', '\\x1b[49m')\nexport const bgWhite = formatter('\\x1b[47m', '\\x1b[49m')\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_ANALYZE = 'phase-analyze'\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_ANALYZE\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 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 PREFETCH_HINTS = 'prefetch-hints.json'\nexport const ROUTES_MANIFEST = 'routes-manifest.json'\nexport const IMAGES_MANIFEST = 'images-manifest.json'\nexport const SERVER_FILES_MANIFEST = 'required-server-files'\nexport const DEV_CLIENT_PAGES_MANIFEST = '_devPagesManifest.json'\nexport const MIDDLEWARE_MANIFEST = 'middleware-manifest.json'\nexport const TURBOPACK_CLIENT_MIDDLEWARE_MANIFEST =\n  '_clientMiddlewareManifest.js'\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 * Comparator for sorting app paths so that parallel slot paths (containing\n * `/@`) come before the children/root page path. This ensures the last item\n * is always the children page, which is what `renderPageComponent` reads via\n * `appPaths[appPaths.length - 1]`.\n *\n * Without this, route group prefixes like `(group)` (char code 0x28) sort\n * before `@` (0x40), causing the children page to sort first instead of last\n * and leading to a manifest mismatch / 404 in webpack dev mode.\n */\nexport function compareAppPaths(a: string, b: string): number {\n  const aHasSlot = a.includes('/@')\n  const bHasSlot = b.includes('/@')\n  if (aHasSlot && !bHasSlot) return -1\n  if (!aHasSlot && bHasSlot) return 1\n  return a.localeCompare(b)\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__'\nexport const NOT_FOUND_SEGMENT_KEY = '/_not-found'\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 type InterceptionMarker = (typeof INTERCEPTION_ROUTE_MARKERS)[number]\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 { parseAppRoute, parseAppRouteSegment } from '../routes/app'\nimport { resolveParamValue } from './resolve-param-value'\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): Params {\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  // Parse the route from the provided page path.\n  const route = parseAppRoute(pagePath, true)\n\n  while (stack.length > 0) {\n    const { tree, depth } = stack.pop()!\n    const { segment, parallelRoutes } = parseLoaderTree(tree)\n\n    const appSegment = parseAppRouteSegment(segment)\n\n    if (\n      appSegment?.type === 'dynamic' &&\n      !interpolated.hasOwnProperty(appSegment.param.paramName) &&\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(appSegment.param.paramName)\n    ) {\n      const { paramName, paramType } = appSegment.param\n\n      const paramValue = resolveParamValue(\n        paramName,\n        paramType,\n        depth,\n        route,\n        interpolated\n      )\n\n      if (paramValue !== undefined) {\n        interpolated[paramName] = paramValue\n      } else if (paramType !== 'optional-catchall') {\n        throw new InvariantError(\n          `Could not resolve param value for segment: ${paramName}`\n        )\n      }\n    }\n\n    // Calculate next depth - increment if this is not a route group and not empty\n    let nextDepth = depth\n    if (\n      appSegment &&\n      appSegment.type !== 'route-group' &&\n      appSegment.type !== 'parallel-route'\n    ) {\n      nextDepth++\n    }\n\n    // Add all parallel routes to the stack for processing\n    for (const parallelRoute of Object.values(parallelRoutes)) {\n      stack.push({ tree: parallelRoute, 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  staticSiblings: readonly string[] | 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, staticSiblings],\n      }\n    }\n\n    throw new InvariantError(\n      `Missing value for segment key: \"${segmentKey}\" with dynamic param type: ${dynamicParamType}`\n    )\n  }\n\n  const paramCacheKey = Array.isArray(value) ? value.join('/') : value\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    // TODO: If the number of static siblings exceeds some threshold (e.g.,\n    // dozens or hundreds), consider sending a Bloom filter instead of the full\n    // array to reduce payload size. The client would then use the Bloom filter\n    // to check membership with a small false positive rate.\n    treeSegment: [segmentKey, paramCacheKey, dynamicParamType, staticSiblings],\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, type ParsedUrl } 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}): ParsedUrl {\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 { NextUrlWithParsedQuery } from './request-meta'\nimport type { ParsedUrlQuery } from 'querystring'\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<NextUrlWithParsedQuery>\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(\n      parsedUrl\n    ) as NextUrlWithParsedQuery\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, ServerResponse } 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'\nimport type { RevalidateFn } from './lib/router-utils/router-server-context'\nimport type { NextRequest } from './web/exports'\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 = (\n  | BaseNextRequest\n  | IncomingMessage\n  | NextRequest\n) & {\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 its URL rewritten, this is the pathname it was rewritten\n   * to (not a full URL, just the pathname).\n   */\n  rewrittenPathname?: string\n\n  /**\n   * The resolved pathname for the request. Dynamic route params are\n   * interpolated, the pathname is decoded, and the trailing slash is removed.\n   */\n  resolvedPathname?: 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   * The action body extracted from a server action request when the postponed\n   * state was prepended to the body by the proxy. This allows the action\n   * handler to read the action payload without re-reading the consumed stream.\n   */\n  actionBody?: Buffer\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    Optional hostname used by route handlers when constructing absolute URLs.\n    hostname: '127.0.0.1',\n   */\n  hostname?: string\n\n  /**\n   Optional internal revalidate function to avoid revalidating over the network\n   */\n  revalidate?: RevalidateFn\n\n  /**\n   Optional function to render the 404 page for pages router `notFound: true`\n   */\n  render404?: (\n    req: IncomingMessage,\n    res: ServerResponse,\n    parsedUrl?: UrlWithParsedQuery,\n    setHeaders?: boolean\n  ) => Promise<void>\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   * The fallback params for this route. In dev, used for validating prerenders.\n   * In production, used to defer params resolution during staged rendering.\n   */\n  fallbackParams?: 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   * DEV only: The duration of getStaticPaths/generateStaticParams in process.hrtime.bigint()\n   */\n  devGenerateStaticParamsDuration?: bigint\n\n  /**\n   * DEV only: Server action log info to be logged after the request log\n   */\n  devServerActionLog?: {\n    functionName: string\n    args: unknown[]\n    location: string\n    duration: number\n  }\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\n/**\n * subset of `url.parse` return value\n */\ninterface LegacyUrl {\n  auth?: string | null\n  hash: string | null\n  hostname: string | null\n  href: string\n  pathname: string | null\n  protocol: string | null\n  search: string | null\n  slashes: boolean | null\n  port: string | null\n  query: string | null | ParsedUrlQuery\n}\ninterface LegacyUrlWithParsedQuery extends LegacyUrl {\n  query: ParsedUrlQuery\n}\n\n// TODO: Remove in favor of WHATWG URLs\nexport interface NextUrlWithParsedQuery extends LegacyUrlWithParsedQuery {\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","/**\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  private readonly onEvict: ((key: string, value: T) => void) | undefined\n\n  constructor(\n    maxSize: number,\n    calculateSize?: (value: T) => number,\n    onEvict?: (key: string, value: T) => void\n  ) {\n    this.maxSize = maxSize\n    this.calculateSize = calculateSize\n    this.onEvict = onEvict\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): boolean {\n    const size = this.calculateSize?.(value) ?? 1\n    if (size <= 0) {\n      throw new Error(\n        `LRUCache: calculateSize returned ${size}, but size must be > 0. ` +\n          `Items with size 0 would never be evicted, causing unbounded cache growth.`\n      )\n    }\n    if (size > this.maxSize) {\n      console.warn('Single item size exceeds maxSize')\n      return false\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      this.onEvict?.(tail.key, tail.data)\n    }\n\n    return true\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   * Note: This is an explicit removal and does NOT trigger the `onEvict`\n   * callback. Use this for intentional deletions where eviction tracking\n   * is not needed.\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","import { bold, green, magenta, red, yellow, white } from '../../lib/picocolors'\nimport { LRUCache } from '../../server/lib/lru-cache'\n\nexport const prefixes = {\n  wait: white(bold('○')),\n  error: red(bold('⨯')),\n  warn: yellow(bold('⚠')),\n  ready: '▲', // no color\n  info: white(bold(' ')),\n  event: green(bold('✓')),\n  trace: magenta(bold('»')),\n} as const\n\nconst LOGGING_METHOD = {\n  log: 'log',\n  warn: 'warn',\n  error: 'error',\n} as const\n\nfunction prefixedLog(prefixType: keyof typeof prefixes, ...message: any[]) {\n  if ((message[0] === '' || message[0] === undefined) && message.length === 1) {\n    message.shift()\n  }\n\n  const consoleMethod: keyof typeof LOGGING_METHOD =\n    prefixType in LOGGING_METHOD\n      ? LOGGING_METHOD[prefixType as keyof typeof LOGGING_METHOD]\n      : 'log'\n\n  const prefix = prefixes[prefixType]\n  // If there's no message, don't print the prefix but a new line\n  if (message.length === 0) {\n    console[consoleMethod]('')\n  } else {\n    // Ensure if there's ANSI escape codes it's concatenated into one string.\n    // Chrome DevTool can only handle color if it's in one string.\n    if (message.length === 1 && typeof message[0] === 'string') {\n      console[consoleMethod](prefix + ' ' + message[0])\n    } else {\n      console[consoleMethod](prefix, ...message)\n    }\n  }\n}\n\nexport function bootstrap(message: string) {\n  console.log(message)\n}\n\nexport function wait(...message: any[]) {\n  prefixedLog('wait', ...message)\n}\n\nexport function error(...message: any[]) {\n  prefixedLog('error', ...message)\n}\n\nexport function warn(...message: any[]) {\n  prefixedLog('warn', ...message)\n}\n\nexport function ready(...message: any[]) {\n  prefixedLog('ready', ...message)\n}\n\nexport function info(...message: any[]) {\n  prefixedLog('info', ...message)\n}\n\nexport function event(...message: any[]) {\n  prefixedLog('event', ...message)\n}\n\nexport function trace(...message: any[]) {\n  prefixedLog('trace', ...message)\n}\n\nconst warnOnceCache = new LRUCache<string>(10_000, (value) => value.length)\nexport function warnOnce(...message: any[]) {\n  const key = message.join(' ')\n  if (!warnOnceCache.has(key)) {\n    warnOnceCache.set(key, key)\n    warn(...message)\n  }\n}\n\nconst errorOnceCache = new LRUCache<string>(10_000, (value) => value.length)\nexport function errorOnce(...message: any[]) {\n  const key = message.join(' ')\n  if (!errorOnceCache.has(key)) {\n    errorOnceCache.set(key, key)\n    error(...message)\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 { ReactDOMServerReadableStream } from 'react-dom/server'\nimport { getTracer } from '../lib/trace/tracer'\nimport { AppRenderSpan } from '../lib/trace/constants'\nimport { DetachedPromise } from '../../lib/detached-promise'\nimport {\n  scheduleImmediate,\n  atLeastOneTask,\n  waitAtLeastOneReactRenderTask,\n} 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 {\n  RSC_HEADER,\n  NEXT_ROUTER_PREFETCH_HEADER,\n  NEXT_ROUTER_SEGMENT_PREFETCH_HEADER,\n  NEXT_RSC_UNION_QUERY,\n  NEXT_INSTANT_PREFETCH_HEADER,\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\nasync function streamToChunks(\n  stream: ReadableStream<Uint8Array>\n): Promise<Array<Uint8Array>> {\n  const reader = stream.getReader()\n  const chunks: Array<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 chunks\n}\n\nfunction concatUint8Arrays(chunks: Array<Uint8Array>): Uint8Array {\n  const totalLength = chunks.reduce((sum, chunk) => sum + chunk.length, 0)\n  const result = new Uint8Array(totalLength)\n  let offset = 0\n  for (const chunk of chunks) {\n    result.set(chunk, offset)\n    offset += chunk.length\n  }\n  return result\n}\n\nexport async function streamToUint8Array(\n  stream: ReadableStream<Uint8Array>\n): Promise<Uint8Array> {\n  return concatUint8Arrays(await streamToChunks(stream))\n}\n\nexport async function streamToBuffer(\n  stream: ReadableStream<Uint8Array>\n): Promise<Buffer> {\n  return Buffer.concat(await streamToChunks(stream))\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\n// TODO this is currently unused but once we add proper output:export support, it needs to be\n// revisited. See https://github.com/vercel/next.js/pull/89478 for more details\n//\n// function 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/**\n * Creates a transform stream that injects an inline script as the first\n * element inside <head>. Used during instant navigation testing to set\n * self.__next_instant_test before any async bootstrap scripts execute.\n */\nexport function createInstantTestScriptInsertionTransformStream(\n  requestId: string | null\n): TransformStream<Uint8Array, Uint8Array> {\n  // Kick off a fetch for the static RSC payload. This is the hydration\n  // source for the locked static shell — same as the __NEXT_CLIENT_RESUME\n  // fetch used for fallback routes, but with NEXT_INSTANT_PREFETCH_HEADER\n  // so the server returns static-only data.\n  //\n  // The fetch promise is stored as self.__next_instant_test, which doubles\n  // as the feature flag (truthy = instant test mode). The client processes\n  // this as a fallback prerender payload for hydration.\n  const segmentPath = '/_full'\n  const cacheBustingHeader = computeCacheBustingSearchParam(\n    '1',\n    segmentPath,\n    undefined,\n    undefined\n  )\n  const searchStr = `${NEXT_RSC_UNION_QUERY}=${cacheBustingHeader}`\n  // In dev mode, inject self.__next_r (request ID) so that HMR WebSocket\n  // and debug channel initialization don't crash. The static shell\n  // bypasses renderToFizzStream which normally injects this via\n  // bootstrapScriptContent.\n  const requestIdScript =\n    requestId !== null ? `self.__next_r=${JSON.stringify(requestId)};` : ''\n  const INSTANT_TEST_SCRIPT = `<script>${requestIdScript}self.__next_instant_test=fetch(location.pathname+'?${searchStr}',{credentials:'same-origin',headers:{'${RSC_HEADER}':'1','${NEXT_ROUTER_PREFETCH_HEADER}':'1','${NEXT_ROUTER_SEGMENT_PREFETCH_HEADER}':'${segmentPath}','${NEXT_INSTANT_PREFETCH_HEADER}':'1'}})</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\n      // Find the opening <head tag (may have attributes like <head class=\"...\">)\n      const headOpenIndex = indexOfUint8Array(chunk, ENCODED_TAGS.OPENING.HEAD)\n\n      if (headOpenIndex === -1) {\n        controller.enqueue(chunk)\n        return\n      }\n\n      // Find the closing > of the <head ...> tag\n      const headCloseAngle = chunk.indexOf(\n        62, // '>'\n        headOpenIndex + ENCODED_TAGS.OPENING.HEAD.length\n      )\n      if (headCloseAngle === -1) {\n        controller.enqueue(chunk)\n        return\n      }\n\n      const encodedInsertion = encoder.encode(INSTANT_TEST_SCRIPT)\n      const insertionPoint = headCloseAngle + 1\n      // e.g.\n      // chunk = <!DOCTYPE html><html><head><meta charset=\"utf-8\">...\n      // insertion = <script>self.__next_instant_test=fetch(...)</script>\n      // output = <!DOCTYPE html><html><head> [ <script>...</script> ] <meta charset=\"utf-8\">...\n      const insertedHeadContent = new Uint8Array(\n        chunk.length + encodedInsertion.length\n      )\n      insertedHeadContent.set(chunk.slice(0, insertionPoint))\n      insertedHeadContent.set(encodedInsertion, insertionPoint)\n      insertedHeadContent.set(\n        chunk.slice(insertionPoint),\n        insertionPoint + encodedInsertion.length\n      )\n\n      controller.enqueue(insertedHeadContent)\n      didAlreadyInsert = true\n    },\n    flush(controller) {\n      // Append closing tags so the browser can parse the full document.\n      controller.enqueue(ENCODED_TAGS.CLOSED.BODY_AND_HTML)\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\nfunction createHtmlDataDplIdTransformStream(\n  dplId: string\n): TransformStream<Uint8Array, Uint8Array> {\n  let didTransform = false\n\n  return new TransformStream({\n    transform(chunk, controller) {\n      if (didTransform) {\n        controller.enqueue(chunk)\n        return\n      }\n\n      const htmlTagIndex = indexOfUint8Array(chunk, ENCODED_TAGS.OPENING.HTML)\n      if (htmlTagIndex === -1) {\n        controller.enqueue(chunk)\n        return\n      }\n\n      // Insert the data-dpl-id attribute right after \"<html \"\n      const insertionPoint = htmlTagIndex + ENCODED_TAGS.OPENING.HTML.length\n      const attribute = ` data-dpl-id=\"${dplId}\"`\n      const encodedAttribute = encoder.encode(attribute)\n      const modifiedChunk = new Uint8Array(\n        chunk.length + encodedAttribute.length\n      )\n\n      // Copy everything before the insertion point\n      modifiedChunk.set(chunk.subarray(0, insertionPoint))\n      // Insert the attribute\n      modifiedChunk.set(encodedAttribute, insertionPoint)\n      // Copy everything after\n      modifiedChunk.set(\n        chunk.subarray(insertionPoint),\n        insertionPoint + encodedAttribute.length\n      )\n\n      controller.enqueue(modifiedChunk)\n      didTransform = true\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  deploymentId: string | undefined\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    deploymentId,\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 (isStaticGeneration) {\n    // If we're generating static HTML we need to wait for it to resolve before continuing.\n    await renderStream.allReady\n  } else {\n    // Otherwise, we want to make sure Fizz is done with all microtasky work\n    // before we start pulling the stream and cause a flush.\n    await waitAtLeastOneReactRenderTask()\n  }\n\n  return chainTransformers(renderStream, [\n    // Buffer everything to avoid flushing too frequently\n    createBufferedTransformStream(),\n\n    // Insert data-dpl-id attribute on the html tag\n    deploymentId ? createHtmlDataDplIdTransformStream(deploymentId) : null,\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  deploymentId: string | undefined\n}\n\nexport async function continueDynamicPrerender(\n  prerenderStream: ReadableStream<Uint8Array>,\n  {\n    getServerInsertedHTML,\n    getServerInsertedMetadata,\n    deploymentId,\n  }: ContinueDynamicPrerenderOptions\n) {\n  return chainTransformers(prerenderStream, [\n    // Buffer everything to avoid flushing too frequently\n    createBufferedTransformStream(),\n    createStripDocumentClosingTagsTransform(),\n    // Insert data-dpl-id attribute on the html tag\n    deploymentId ? createHtmlDataDplIdTransformStream(deploymentId) : null,\n    // Insert generated tags to head\n    createHeadInsertionTransformStream(getServerInsertedHTML),\n    // Transform metadata\n    createMetadataTransformStream(getServerInsertedMetadata),\n  ])\n}\n\ntype ContinueStaticPrerenderOptions = {\n  inlinedDataStream: ReadableStream<Uint8Array>\n  getServerInsertedHTML: () => Promise<string>\n  getServerInsertedMetadata: () => Promise<string>\n  deploymentId: string | undefined\n}\n\nexport async function continueStaticPrerender(\n  prerenderStream: ReadableStream<Uint8Array>,\n  {\n    inlinedDataStream,\n    getServerInsertedHTML,\n    getServerInsertedMetadata,\n    deploymentId,\n  }: ContinueStaticPrerenderOptions\n) {\n  return chainTransformers(prerenderStream, [\n    // Buffer everything to avoid flushing too frequently\n    createBufferedTransformStream(),\n    // Add build id comment to start of the HTML document (in export mode)\n    // Insert data-dpl-id attribute on the html tag\n    deploymentId ? createHtmlDataDplIdTransformStream(deploymentId) : null,\n    // Insert generated tags to head\n    createHeadInsertionTransformStream(getServerInsertedHTML),\n    // Transform metadata\n    createMetadataTransformStream(getServerInsertedMetadata),\n    // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n    createFlightDataInjectionTransformStream(inlinedDataStream, true),\n    // Close tags should always be deferred to the end\n    createMoveSuffixStream(),\n  ])\n}\n\nexport async function continueStaticFallbackPrerender(\n  prerenderStream: ReadableStream<Uint8Array>,\n  {\n    inlinedDataStream,\n    getServerInsertedHTML,\n    getServerInsertedMetadata,\n    deploymentId,\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 chainTransformers(prerenderStream, [\n    // Buffer everything to avoid flushing too frequently\n    createBufferedTransformStream(),\n    // Insert data-dpl-id attribute on the html tag\n    deploymentId ? createHtmlDataDplIdTransformStream(deploymentId) : null,\n    // Insert generated tags to head\n    createHeadInsertionTransformStream(getServerInsertedHTML),\n    // Insert the client resume script into the head\n    createClientResumeScriptInsertionTransformStream(),\n    // Transform metadata\n    createMetadataTransformStream(getServerInsertedMetadata),\n    // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n    createFlightDataInjectionTransformStream(inlinedDataStream, true),\n    // Close tags should always be deferred to the end\n    createMoveSuffixStream(),\n  ])\n}\n\ntype ContinueResumeOptions = {\n  inlinedDataStream: ReadableStream<Uint8Array>\n  getServerInsertedHTML: () => Promise<string>\n  getServerInsertedMetadata: () => Promise<string>\n  delayDataUntilFirstHtmlChunk: boolean\n  deploymentId: string | undefined\n}\n\nexport async function continueDynamicHTMLResume(\n  renderStream: ReadableStream<Uint8Array>,\n  {\n    delayDataUntilFirstHtmlChunk,\n    inlinedDataStream,\n    getServerInsertedHTML,\n    getServerInsertedMetadata,\n    deploymentId,\n  }: ContinueResumeOptions\n) {\n  return chainTransformers(renderStream, [\n    // Buffer everything to avoid flushing too frequently\n    createBufferedTransformStream(),\n    // Insert data-dpl-id attribute on the html tag\n    deploymentId ? createHtmlDataDplIdTransformStream(deploymentId) : null,\n    // Insert generated tags to head\n    createHeadInsertionTransformStream(getServerInsertedHTML),\n    // Transform metadata\n    createMetadataTransformStream(getServerInsertedMetadata),\n    // Insert the inlined data (Flight data, form state, etc.) stream into the HTML\n    createFlightDataInjectionTransformStream(\n      inlinedDataStream,\n      delayDataUntilFirstHtmlChunk\n    ),\n    // Close tags should always be deferred to the end\n    createMoveSuffixStream(),\n  ])\n}\n\nexport function createDocumentClosingStream(): ReadableStream<Uint8Array> {\n  return streamFromString(CLOSE_TAG)\n}\n\n// ---------------------------------------------------------------------------\n// Runtime prefetch transform (Web streams)\n// ---------------------------------------------------------------------------\n\n/**\n * Web TransformStream that replaces the runtime prefetch sentinel in an RSC\n * payload stream: `[<sentinel>]` -> `[<isPartial>,<staleTime>]`.\n *\n * This is the web equivalent of createRuntimePrefetchNodeTransform\n * in node-stream-helpers.ts.\n */\nexport function createRuntimePrefetchTransformStream(\n  sentinel: number,\n  isPartial: boolean,\n  staleTime: number\n): TransformStream<Uint8Array, Uint8Array> {\n  const enc = new TextEncoder()\n\n  // Search for: [<sentinel>]\n  // Replace with: [<isPartial>,<staleTime>]\n  const search = enc.encode(`[${sentinel}]`)\n  const first = search[0]\n  const replace = enc.encode(`[${isPartial},${staleTime}]`)\n  const searchLen = search.length\n\n  let currentChunk: Uint8Array | null = null\n  let found = false\n\n  function processChunk(\n    controller: TransformStreamDefaultController<Uint8Array>,\n    nextChunk: null | Uint8Array\n  ) {\n    if (found) {\n      if (nextChunk) {\n        controller.enqueue(nextChunk)\n      }\n      return\n    }\n\n    if (currentChunk) {\n      // We can't search past the index that can contain a full match\n      let exclusiveUpperBound = currentChunk.length - (searchLen - 1)\n      if (nextChunk) {\n        // If we have any overflow bytes we can search up to the chunk's final byte\n        exclusiveUpperBound += Math.min(nextChunk.length, searchLen - 1)\n      }\n      if (exclusiveUpperBound < 1) {\n        // we can't match the current chunk.\n        controller.enqueue(currentChunk)\n        currentChunk = nextChunk // advance so we don't process this chunk again\n        return\n      }\n\n      let currentIndex = currentChunk.indexOf(first)\n\n      // check the current candidate match if it is within the bounds of our search space for the currentChunk\n      candidateLoop: while (\n        -1 < currentIndex &&\n        currentIndex < exclusiveUpperBound\n      ) {\n        // We already know index 0 matches because we used indexOf to find the candidateIndex so we start at index 1\n        let matchIndex = 1\n        while (matchIndex < searchLen) {\n          const candidateIndex = currentIndex + matchIndex\n          const candidateValue =\n            candidateIndex < currentChunk.length\n              ? currentChunk[candidateIndex]\n              : // if we ever hit this condition it is because there is a nextChunk we can read from\n                nextChunk![candidateIndex - currentChunk.length]\n          if (candidateValue !== search[matchIndex]) {\n            // No match, reset and continue the search from the next position\n            currentIndex = currentChunk.indexOf(first, currentIndex + 1)\n            continue candidateLoop\n          }\n          matchIndex++\n        }\n        // We found a complete match. currentIndex is our starting point to replace the value.\n        found = true\n        // enqueue everything up to the match\n        controller.enqueue(currentChunk.subarray(0, currentIndex))\n        // enqueue the replacement value\n        controller.enqueue(replace)\n        // If there are bytes in the currentChunk after the match enqueue them\n        if (currentIndex + searchLen < currentChunk.length) {\n          controller.enqueue(currentChunk.slice(currentIndex + searchLen))\n        }\n        // If we have a next chunk we enqueue it now\n        if (nextChunk) {\n          // if replacement spills over to the next chunk we first exclude the replaced bytes\n          const overflowBytes = currentIndex + searchLen - currentChunk.length\n          const truncatedChunk =\n            overflowBytes > 0 ? nextChunk!.subarray(overflowBytes) : nextChunk\n          controller.enqueue(truncatedChunk)\n        }\n        // We are now in found mode and don't need to track currentChunk anymore\n        currentChunk = null\n        return\n      }\n      // No match found in this chunk, emit it and wait for the next one\n      controller.enqueue(currentChunk)\n    }\n\n    // Advance to the next chunk\n    currentChunk = nextChunk\n  }\n\n  return new TransformStream<Uint8Array, Uint8Array>({\n    transform(chunk, controller) {\n      processChunk(controller, chunk)\n    },\n    flush(controller) {\n      processChunk(controller, null)\n    },\n  })\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    // <head\n    HEAD: new Uint8Array([60, 104, 101, 97, 100]),\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  /^(?: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  const parsed = new URL(String(url), base && String(base))\n  if (REGEX_LOCALHOST_HOSTNAME.test(parsed.hostname)) {\n    parsed.hostname = 'localhost'\n  }\n  return parsed\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'\nimport type { PrefetchHints } from '../shared/lib/app-router-types'\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   * Per-route prefetch hints computed at build time (e.g. segment inlining\n   * decisions based on gzip sizes). Written to prefetch-hints.json by the\n   * build pipeline.\n   */\n  prefetchHints?: PrefetchHints\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  mutableAssetQueryString?: 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   * Pipes the response through a transform stream. This converts the response\n   * to a single readable stream (chaining if needed) and pipes it through the\n   * provided transform.\n   *\n   * @param transform The transform stream to pipe through\n   */\n  public pipeThrough(transform: TransformStream<Uint8Array, Uint8Array>): void {\n    this.response = this.readable.pipeThrough(transform)\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","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    isFallback: response.isFallback,\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 { LRUCache } from '../lib/lru-cache'\nimport { warnOnce } from '../../build/output/log'\nimport { scheduleOnNextTick } from '../../lib/scheduler'\nimport {\n  fromResponseCacheEntry,\n  routeKindToIncrementalCacheKind,\n  toResponseCacheEntry,\n} from './utils'\nimport type { RouteKind } from '../route-kind'\n\n/**\n * Parses an environment variable as a positive integer, returning the fallback\n * if the value is missing, not a number, or not positive.\n */\nfunction parsePositiveInt(\n  envValue: string | undefined,\n  fallback: number\n): number {\n  if (!envValue) return fallback\n  const parsed = parseInt(envValue, 10)\n  return Number.isFinite(parsed) && parsed > 0 ? parsed : fallback\n}\n\n/**\n * Default TTL (in milliseconds) for minimal mode response cache entries.\n * Used for cache hit validation as a fallback for providers that don't\n * send the x-invocation-id header yet.\n *\n * 10 seconds chosen because:\n * - Long enough to dedupe rapid successive requests (e.g., page + data)\n * - Short enough to not serve stale data across unrelated requests\n *\n * Can be configured via `NEXT_PRIVATE_RESPONSE_CACHE_TTL` environment variable.\n */\nconst DEFAULT_TTL_MS = parsePositiveInt(\n  process.env.NEXT_PRIVATE_RESPONSE_CACHE_TTL,\n  10_000\n)\n\n/**\n * Default maximum number of entries in the response cache.\n * Can be configured via `NEXT_PRIVATE_RESPONSE_CACHE_MAX_SIZE` environment variable.\n */\nconst DEFAULT_MAX_SIZE = parsePositiveInt(\n  process.env.NEXT_PRIVATE_RESPONSE_CACHE_MAX_SIZE,\n  150\n)\n\n/**\n * Separator used in compound cache keys to join pathname and invocationID.\n * Using null byte (\\0) since it cannot appear in valid URL paths or UUIDs.\n */\nconst KEY_SEPARATOR = '\\0'\n\n/**\n * Sentinel value used for TTL-based cache entries (when invocationID is undefined).\n * Chosen to be a clearly reserved marker for internal cache keys.\n */\nconst TTL_SENTINEL = '__ttl_sentinel__'\n\n/**\n * Entry stored in the LRU cache.\n */\ntype CacheEntry = {\n  entry: IncrementalResponseCacheEntry | null\n  /**\n   * TTL expiration timestamp in milliseconds. Used as a fallback for\n   * cache hit validation when providers don't send x-invocation-id.\n   * Memory pressure is managed by LRU eviction rather than timers.\n   */\n  expiresAt: number\n}\n\n/**\n * Creates a compound cache key from pathname and invocationID.\n */\nfunction createCacheKey(\n  pathname: string,\n  invocationID: string | undefined\n): string {\n  return `${pathname}${KEY_SEPARATOR}${invocationID ?? TTL_SENTINEL}`\n}\n\n/**\n * Extracts the invocationID from a compound cache key.\n * Returns undefined if the key used TTL_SENTINEL.\n */\nfunction extractInvocationID(compoundKey: string): string | undefined {\n  const separatorIndex = compoundKey.lastIndexOf(KEY_SEPARATOR)\n  if (separatorIndex === -1) return undefined\n\n  const invocationID = compoundKey.slice(separatorIndex + 1)\n  return invocationID === TTL_SENTINEL ? undefined : invocationID\n}\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  /**\n   * LRU cache for minimal mode using compound keys (pathname + invocationID).\n   * This allows multiple invocations to cache the same pathname without\n   * overwriting each other's entries.\n   */\n  private readonly cache: LRUCache<CacheEntry>\n\n  /**\n   * Set of invocation IDs that have had cache entries evicted.\n   * Used to detect when the cache size may be too small.\n   * Bounded to prevent memory growth.\n   */\n  private readonly evictedInvocationIDs: Set<string> = new Set()\n\n  /**\n   * The configured max size, stored for logging.\n   */\n  private readonly maxSize: number\n\n  /**\n   * The configured TTL for cache entries in milliseconds.\n   */\n  private readonly ttl: number\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(\n    minimal_mode: boolean,\n    maxSize: number = DEFAULT_MAX_SIZE,\n    ttl: number = DEFAULT_TTL_MS\n  ) {\n    this.minimal_mode = minimal_mode\n    this.maxSize = maxSize\n    this.ttl = ttl\n\n    // Create the LRU cache with eviction tracking\n    this.cache = new LRUCache(maxSize, undefined, (compoundKey) => {\n      const invocationID = extractInvocationID(compoundKey)\n      if (invocationID) {\n        // Bound to 100 entries to prevent unbounded memory growth.\n        // FIFO eviction is acceptable here because:\n        // 1. Invocations are short-lived (single request lifecycle), so older\n        //    invocations are unlikely to still be active after 100 newer ones\n        // 2. This warning mechanism is best-effort for developer guidance—\n        //    missing occasional eviction warnings doesn't affect correctness\n        // 3. If a long-running invocation is somehow evicted and then has\n        //    another cache entry evicted, it will simply be re-added\n        if (this.evictedInvocationIDs.size >= 100) {\n          const first = this.evictedInvocationIDs.values().next().value\n          if (first) this.evictedInvocationIDs.delete(first)\n        }\n        this.evictedInvocationIDs.add(invocationID)\n      }\n    })\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      /**\n       * The invocation ID from the infrastructure. Used to scope the\n       * in-memory cache to a single revalidation request in minimal mode.\n       */\n      invocationID?: string\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 (this.minimal_mode) {\n      const cacheKey = createCacheKey(key, context.invocationID)\n      const cachedItem = this.cache.get(cacheKey)\n\n      if (cachedItem) {\n        // With invocationID: exact match found - always a hit\n        // With TTL mode: must check expiration\n        if (context.invocationID !== undefined) {\n          return toResponseCacheEntry(cachedItem.entry)\n        }\n\n        // TTL mode: check expiration\n        const now = Date.now()\n        if (cachedItem.expiresAt > now) {\n          return toResponseCacheEntry(cachedItem.entry)\n        }\n\n        // TTL expired - clean up\n        this.cache.remove(cacheKey)\n      }\n\n      // Warn if this invocation had entries evicted - indicates cache may be too small.\n      if (\n        context.invocationID &&\n        this.evictedInvocationIDs.has(context.invocationID)\n      ) {\n        warnOnce(\n          `Response cache entry was evicted for invocation ${context.invocationID}. ` +\n            `Consider increasing NEXT_PRIVATE_RESPONSE_CACHE_MAX_SIZE (current: ${this.maxSize}).`\n        )\n      }\n    }\n\n    const {\n      incrementalCache,\n      isOnDemandRevalidate = false,\n      isFallback = false,\n      isRoutePPREnabled = false,\n      isPrefetch = false,\n      waitUntil,\n      routeKind,\n      invocationID,\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            invocationID,\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      invocationID: string | undefined\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        undefined,\n        context.invocationID\n      )\n\n      // Handle null response\n      if (!incrementalResponseCacheEntry) {\n        // Remove the cache item if it was set so we don't use it again.\n        if (this.minimal_mode) {\n          const cacheKey = createCacheKey(key, context.invocationID)\n          this.cache.remove(cacheKey)\n        }\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   * @param waitUntil - Optional function to register background work.\n   * @param invocationID - The invocation ID for cache key scoping.\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    invocationID?: string\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        invocationID\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    invocationID: string | undefined\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          // Set TTL expiration for cache hit validation. Entries are validated\n          // by invocationID when available, with TTL as a fallback for providers\n          // that don't send x-invocation-id. Memory is managed by LRU eviction.\n          const cacheKey = createCacheKey(key, invocationID)\n          this.cache.set(cacheKey, {\n            entry: incrementalResponseCacheEntry,\n            expiresAt: Date.now() + this.ttl,\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_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 (\n              !ctx.isFallback &&\n              (!ctx.isRoutePPREnabled || meta?.postponed == null)\n            ) {\n              rscData = await this.fs.readFile(\n                this.getFilePath(\n                  `${key}${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        prefetchHints: 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 && !ctx.isRoutePPREnabled) {\n        writer.append(\n          this.getFilePath(\n            `${key}${isAppPath ? RSC_SUFFIX : NEXT_DATA_SUFFIX}`,\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          prefetchHints: undefined,\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_SECONDS,\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          // Check if any tags were recently revalidated before returning RDC entry.\n          // When a server action calls updateTag(), the re-render should see fresh\n          // data instead of stale RDC data.\n          const workStore = workAsyncStorage.getStore()\n          const combinedTags = [...(ctx.tags || []), ...(ctx.softTags || [])]\n          const hasRevalidatedTag = combinedTags.some(\n            (tag) =>\n              this.revalidatedTags?.includes(tag) ||\n              workStore?.pendingRevalidatedTags?.some(\n                (item) => item.tag === tag\n              )\n          )\n\n          if (hasRevalidatedTag) {\n            if (IncrementalCache.debug) {\n              console.log('IncrementalCache: rdc:revalidated-tag', cacheKey)\n            }\n            // Fall through to cacheHandler lookup\n          } else {\n            if (IncrementalCache.debug) {\n              console.log('IncrementalCache: rdc:hit', cacheKey)\n            }\n\n            return { isStale: false, value: memoryCacheData }\n          }\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 { isFallback } = ctx\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_SECONDS * 1000\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        isFallback,\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        isFallback,\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 * 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 { NextConfigRuntime } 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  headers: { [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?: NextConfigRuntime\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?: (status: ServerCacheStatus, htmlRequestId: string) => void\n    sendErrorsToBrowser?: (\n      errorsRscStream: ReadableStream<Uint8Array>,\n      htmlRequestId: string\n    ) => void\n    // indicates request handlers are already wrapped by next-server tracing\n    isWrappedByNextServer?: boolean\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 type { Rewrite } from './load-custom-routes'\nimport type { DeepReadonly } from '../shared/lib/deep-readonly'\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\n// Header for the Instant Navigation Testing API. In development and testing\n// builds, static pre-renders normally don't happen. This header tells the\n// server to perform a static pre-render anyway, allowing tests to assert on\n// the prefetched UI. Not exposed in production builds by default.\nexport const NEXT_INSTANT_PREFETCH_HEADER =\n  'next-instant-navigation-testing-prefetch' as const\n\n// Cookie for the Instant Navigation Testing API. Used for MPA navigations\n// (page reload, full page load) where we can't set request headers. When set,\n// the server renders only the static shell. Not exposed in production builds\n// by default.\nexport const NEXT_INSTANT_TEST_COOKIE =\n  'next-instant-navigation-testing' 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\n// TODO: Should this include nextjs in the name, like the others?\nexport const NEXT_ACTION_REVALIDATED_HEADER = 'x-action-revalidated' as const\n","import '../../build/adapter/setup-node-env.external'\nimport 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 {\n  addRequestMeta,\n  getRequestMeta,\n  type NextIncomingMessage,\n} 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, NextConfigRuntime } 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/is-interception-route-rewrite'\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.__NEXT_DEV_SERVER\n    this.distDir = distDir\n    this.relativeProjectDir = relativeProjectDir\n  }\n\n  private getRouterServerContext(\n    req: NextIncomingMessage\n  ): RouterServerContext[string] | undefined {\n    const hostname = getRequestMeta(req, 'hostname')\n    const revalidate = getRequestMeta(req, 'revalidate')\n    const render404 = getRequestMeta(req, 'render404')\n    const relativeProjectDir =\n      getRequestMeta(req, 'relativeProjectDir') || this.relativeProjectDir\n    const routerServerContext =\n      routerServerGlobal[RouterServerContextSymbol]?.[relativeProjectDir]\n\n    return {\n      ...routerServerContext,\n      ...(hostname !== undefined ? { hostname } : {}),\n      ...(revalidate !== undefined ? { revalidate } : {}),\n      ...(render404 !== undefined ? { render404 } : {}),\n    }\n  }\n\n  public normalizeUrl(\n    _req: IncomingMessage | BaseNextRequest,\n    _parsedUrl: UrlWithParsedQuery\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: DeepReadonly<RequiredServerFilesManifest> | undefined\n    reactLoadableManifest: DeepReadonly<ReactLoadableManifest>\n    subresourceIntegrityManifest: any\n    clientReferenceManifest: any\n    serverActionsManifest: any\n    dynamicCssManifest: any\n    interceptionRoutePatterns: RegExp[]\n  } {\n    let result\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      result = {\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        } as const,\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          onMatchHeaders: [],\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: self.__SERVER_FILES_MANIFEST,\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          ? undefined\n          : loadManifestFromRelativePath<RequiredServerFilesManifest>({\n              projectDir,\n              distDir: this.distDir,\n              shouldCache: true,\n              manifest: `${SERVER_FILES_MANIFEST}.json`,\n            }),\n        this.isDev\n          ? 'development'\n          : loadManifestFromRelativePath<any>({\n              projectDir,\n              distDir: this.distDir,\n              manifest: BUILD_ID_FILE,\n              skipParse: true,\n              shouldCache: true,\n            }),\n        loadManifestFromRelativePath<any>({\n          projectDir,\n          distDir: this.distDir,\n          manifest: DYNAMIC_CSS_MANIFEST,\n          shouldCache: !this.isDev,\n          handleMissing: true,\n        }),\n      ]\n\n      result = {\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    return result\n  }\n\n  public async loadCustomCacheHandlers(\n    req: IncomingMessage | BaseNextRequest,\n    nextConfig: NextConfigRuntime\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: NextConfigRuntime,\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    silenceLog: boolean,\n    routerServerContext?: RouterServerContext[string]\n  ) {\n    if (!silenceLog) {\n      if (routerServerContext?.logErrorWithOriginalStack) {\n        routerServerContext.logErrorWithOriginalStack(err, 'app-dir')\n      } else {\n        console.error(err)\n      }\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  /** A more lightweight version of `prepare()` for only retrieving the config on edge */\n  public getNextConfigEdge(req: NextIncomingMessage): {\n    nextConfig: NextConfigRuntime\n    deploymentId: string\n  } {\n    if (process.env.NEXT_RUNTIME !== 'edge') {\n      throw new Error(\n        'Invariant: getNextConfigEdge must only be called in edge runtime'\n      )\n    }\n\n    let serverFilesManifest = self.__SERVER_FILES_MANIFEST as any as\n      | RequiredServerFilesManifest\n      | undefined\n    const routerServerContext = this.getRouterServerContext(req)\n    const nextConfig =\n      routerServerContext?.nextConfig || serverFilesManifest?.config\n\n    if (!nextConfig) {\n      throw new Error(\"Invariant: nextConfig couldn't be loaded\")\n    }\n\n    let deploymentId\n    if (nextConfig.experimental?.runtimeServerDeploymentId) {\n      if (!process.env.NEXT_DEPLOYMENT_ID) {\n        throw new Error(\n          'process.env.NEXT_DEPLOYMENT_ID is missing but runtimeServerDeploymentId is enabled'\n        )\n      }\n      deploymentId = process.env.NEXT_DEPLOYMENT_ID\n    } else {\n      deploymentId = nextConfig.deploymentId || ''\n    }\n\n    return { nextConfig, deploymentId }\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        deploymentId: string\n        clientAssetToken: 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:\n          | DeepReadonly<RequiredServerFilesManifest>\n          | undefined\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: NextConfigRuntime\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 = this.loadManifests(srcPage, absoluteProjectDir)\n    const { routesManifest, prerenderManifest, serverFilesManifest } = manifests\n\n    const { basePath, i18n, rewrites } = routesManifest\n\n    const routerServerContext = this.getRouterServerContext(req)\n    const nextConfig =\n      routerServerContext?.nextConfig || serverFilesManifest?.config\n\n    // Injected in base-server.ts\n    const protocol = req.headers['x-forwarded-proto']?.includes('https')\n      ? 'https'\n      : 'http'\n\n    // When there are hostname and port we build an absolute URL\n    if (!getRequestMeta(req, 'initURL')) {\n      const initUrl = serverFilesManifest?.config.experimental.trustHostHeader\n        ? `${protocol}://${req.headers.host || 'localhost'}${req.url}`\n        : `${protocol}://${routerServerContext?.hostname || 'localhost'}${req.url}`\n\n      addRequestMeta(req, 'initURL', initUrl)\n      addRequestMeta(req, 'initProtocol', protocol)\n    }\n\n    if (basePath) {\n      req.url = removePathPrefix(req.url || '/', basePath)\n    }\n\n    const parsedUrl = parseReqUrl(req.url || '/')\n    addRequestMeta(req, 'initQuery', { ...parsedUrl?.query })\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    this.normalizeUrl(req, parsedUrl)\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\n    if (Boolean(domainLocale)) {\n      addRequestMeta(req, 'isLocaleDomain', Boolean(domainLocale))\n    }\n\n    const defaultLocale =\n      getRequestMeta(req, 'defaultLocale') ||\n      domainLocale?.defaultLocale ||\n      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 and the query params\n        // were nxtP prefixed rely on that one\n        query &&\n        params &&\n        paramsResult.hasValidParams &&\n        queryResult.hasValidParams &&\n        routeParamKeys.size > 0 &&\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        // handle the case where there's collision and we\n        // normalized nxtPid=123 -> id=123 but user also\n        // sends id=456 as separate key\n      } else if (\n        originalQuery[key] &&\n        query[key] &&\n        originalQuery[key] !== query[key]\n      ) {\n        query[key] = originalQuery[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    if (!nextConfig) {\n      throw new Error(\"Invariant: nextConfig couldn't be loaded\")\n    }\n\n    if (process.env.NEXT_RUNTIME !== 'edge') {\n      const { installProcessErrorHandlers } =\n        require('../node-environment-extensions/process-error-handlers') as typeof import('../node-environment-extensions/process-error-handlers')\n\n      installProcessErrorHandlers(\n        Boolean(\n          nextConfig.experimental.removeUncaughtErrorAndRejectionListeners\n        )\n      )\n    }\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\n    if (\n      res &&\n      Boolean(req.headers['x-nextjs-data']) &&\n      (!res.statusCode || res.statusCode === 200)\n    ) {\n      res.setHeader(\n        'x-nextjs-matched-path',\n        removeTrailingSlash(`${locale ? `/${locale}` : ''}${normalizedSrcPage}`)\n      )\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    addRequestMeta(req, 'resolvedPathname', resolvedPathname)\n\n    let deploymentId\n    if (nextConfig.experimental?.runtimeServerDeploymentId) {\n      if (!process.env.NEXT_DEPLOYMENT_ID) {\n        throw new Error(\n          'process.env.NEXT_DEPLOYMENT_ID is missing but runtimeServerDeploymentId is enabled'\n        )\n      }\n      deploymentId = process.env.NEXT_DEPLOYMENT_ID\n    } else {\n      deploymentId = nextConfig.deploymentId || ''\n    }\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      // loadManifest returns a readonly object, but we don't want to propagate that throughout the\n      // whole codebase (for now)\n      nextConfig:\n        nextConfig satisfies DeepReadonly<NextConfigRuntime> as NextConfigRuntime,\n      routerServerContext,\n      deploymentId,\n      clientAssetToken:\n        nextConfig.experimental.immutableAssetToken || deploymentId,\n    }\n  }\n\n  public getResponseCache(req: IncomingMessage | BaseNextRequest) {\n    if (!this.responseCache) {\n      const minimalMode = getRequestMeta(req, 'minimalMode') ?? 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: NextConfigRuntime\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      // Use x-invocation-id header to scope the in-memory cache to a single\n      // revalidation request in minimal mode.\n      invocationID: req.headers['x-invocation-id'] as string | undefined,\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  auth: string | null\n  hash: string\n  hostname: string | null\n  href: string\n  origin?: string | null\n  pathname: string\n  port: string | null\n  protocol: string | null\n  query: ParsedUrlQuery\n  search: string\n  slashes: boolean | null\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  const username = parsedURL.username\n  const password = parsedURL.password\n  const auth = username\n    ? password\n      ? `${username}:${password}`\n      : username\n    : null\n  const pathname = parsedURL.pathname\n  const search = parsedURL.search\n  return {\n    auth,\n    hash: parsedURL.hash,\n    hostname: parsedURL.hostname,\n    href: parsedURL.href,\n    pathname,\n    port: parsedURL.port,\n    protocol: parsedURL.protocol,\n    query: searchParamsToUrlQuery(parsedURL.searchParams),\n    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  auth: string | null\n  hash: string\n  host: string | null\n  hostname: string | null\n  href: string\n  pathname: string\n  port: string | null\n  protocol: string | null\n  query: ParsedUrlQuery\n  search: string\n  slashes: null\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 } = url.startsWith(\n    '/'\n  )\n    ? // 'http://localhost:3000///' would be received as '///' in Node.js' IncomingMessage\n      // See https://nodejs.org/api/http.html#messageurl\n      // Not using `origin` to support other protocols\n      new URL(`${resolvedBase.protocol}//${resolvedBase.host}${url}`)\n    : new URL(url, resolvedBase)\n\n  if (origin !== globalBase.origin) {\n    throw new Error(`invariant: invalid relative URL, router received ${url}`)\n  }\n\n  return {\n    auth: null,\n    host: null,\n    hostname: null,\n    pathname,\n    port: null,\n    protocol: null,\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: null,\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'\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?: string\n}\n\n/**\n * This is a safe stringify function that handles circular references.\n * We're using a simpler version here to avoid introducing\n * the dependency `safe-stable-stringify` into production bundle.\n *\n * This helper is used both in development and production.\n */\nfunction safeStringifyLite(obj: any) {\n  const seen = new WeakSet()\n\n  return JSON.stringify(obj, (_key, value) => {\n    // If value is an object and already seen, replace with \"[Circular]\"\n    if (typeof value === 'object' && value !== null) {\n      if (seen.has(value)) {\n        return '[Circular]'\n      }\n      seen.add(value)\n    }\n    return value\n  })\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) ? safeStringifyLite(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 headers: 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      headers[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        headers,\n        opts,\n      })\n    }\n\n    if (context.trustHostHeader) {\n      const res = await fetch(`https://${req.headers.host}${urlPath}`, {\n        method: 'HEAD',\n        headers,\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    // Ensure req.query is a writable, enumerable property by using Object.defineProperty.\n    // This addresses Express 5.x, which defines query as a getter only (read-only).\n    Object.defineProperty(apiReq, 'query', {\n      value: { ...query },\n      writable: true,\n      enumerable: true,\n      configurable: true,\n    })\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<T>(mod: { default: T } | T): T {\n  // @ts-ignore\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","a","Number","Symbol","Array","r","JSON","e","i","n","Math","isNaN","parseFloat","parseInt","__dirname","__nccwpck_require__","TypeError","u","String","s","isFinite","NaN","o","v","x","RegExp","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_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_SECONDS","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","Error","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","REACT_POSTPONE_TYPE","for","isPostpone","error","$$typeof","_global","globalThis","installProcessErrorHandlers","shouldRemoveUncaughtErrorAndRejectionListeners","nextInitializedProcessErrorHandlers","removeAllListeners","on","reason","console","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","CachedRouteKind","IncrementalCacheKind","RouteKind","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","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","getRequestMeta","meta","addRequestMeta","request","normalizePagePath","posix","resolvedPage","normalize","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","LRUNode","size","prev","next","SentinelNode","LRUCache","maxSize","calculateSize","onEvict","totalSize","head","tail","addToHead","node","removeNode","moveToHead","removeTail","lastNode","warn","newNode","current","remove","currentSize","env","stdout","enabled","NO_COLOR","FORCE_COLOR","isTTY","CI","TERM","replaceClose","close","start","nextIndex","formatter","open","input","string","bold","red","green","yellow","magenta","white","prefixes","wait","ready","info","event","LOGGING_METHOD","log","warnOnceCache","scheduleOnNextTick","cb","then","nextTick","voidCatch","Uint8Array","encoder","TextEncoder","streamFromString","ReadableStream","controller","enqueue","encode","streamFromBuffer","chunk","streamToString","stream","signal","decoder","TextDecoder","fatal","aborted","addPathPrefix","addPathSuffix","suffix","REGEX_LOCALHOST_HOSTNAME","parseURL","base","Internal","NextURL","baseOrOpts","basePath","analyze","t","getNextPathnameInfo","i18n","trailingSlash","nextConfig","pathnameNoDataPrefix","paths","buildId","parseData","i18nProvider","__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","AbortController","response","once","writableFinished","abort","writer","createWriterFromResponse","started","drained","onDrain","off","finished","WritableStream","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","pipeThrough","transform","unshift","fromResponseCacheEntry","cacheEntry","kind","html","pageData","status","postponed","rscData","segmentData","toResponseCacheEntry","isMiss","isStale","cacheControl","isFallback","parsePositiveInt","envValue","fallback","DEFAULT_TTL_MS","NEXT_PRIVATE_RESPONSE_CACHE_TTL","DEFAULT_MAX_SIZE","NEXT_PRIVATE_RESPONSE_CACHE_MAX_SIZE","TTL_SENTINEL","createCacheKey","invocationID","ResponseCache","minimal_mode","ttl","getBatcher","revalidateBatcher","evictedInvocationIDs","Set","compoundKey","extractInvocationID","separatorIndex","lastIndexOf","first","add","responseGenerator","context","hasResolved","previousCacheEntry","cachedItem","now","expiresAt","warnOnce","prefixedLog","prefixType","shift","consoleMethod","incrementalCache","isRoutePPREnabled","isPrefetch","routeKind","handleGet","previousIncrementalCacheEntry","resolved","routeKindToIncrementalCacheKind","incrementalResponseCacheEntry","revalidate","handleRevalidate","responseCacheEntry","isRevalidating","min","max","expire","MultiFileWriter","tasks","findOrCreateTask","directory","task","all","flatMap","FileSystemCache","debug","NEXT_PRIVATE_DEBUG_CACHE","ctx","flushToDisk","serverDistDir","revalidatedTags","maxMemoryCacheSize","memoryCache","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","prefetchHints","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","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","getRouterServerContext","render404","routerServerContext","normalizeUrl","_req","_parsedUrl","instrumentationOnRequestError","absoluteProjectDir","cwd","loadManifests","srcPage","projectDir","loadManifestFromRelativePath","router","routesManifest","buildManifest","fallbackBuildManifest","reactLoadableManifest","nextFontManifest","clientReferenceManifest","serverActionsManifest","subresourceIntegrityManifest","serverFilesManifest","dynamicCssManifest","manifest","shouldCache","handleMissing","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","DefaultCache","RemoteCache","getIncrementalCache","isMinimalMode","CacheHandler","experimental","isrFlushToDisk","__incrementalCache","onRequestError","errorContext","silenceLog","logErrorWithOriginalStack","getNextConfigEdge","prepare","localeResult","previewData","deploymentId","relative","absoluteDistDir","ensureInstrumentationRegistered","manifests","config","initUrl","trustHostHeader","isNextDataRequest","originalPathname","originalQuery","pageIsDynamic","normalizedSrcPage","serverUtils","getServerUtils","caseSensitive","defaultRouteRegex","dynamicRouteMatcher","defaultRouteMatches","namedRegex","getNamedParametrizedRoute","prefixRouteKeys","includeSuffix","includePrefix","names","intercepted","routeKey","j","fromCharCode","inverseParts","structuredClone","hasInterceptionMarker","paramMatches","namedParameterizedRoute","pathToRegexpPattern","excludeOptionalTrailingSlash","getRouteRegex","parameterizedRoute","getParametrizedRoute","groupIndex","markerMatch","handleRewrites","rewrittenParsedUrl","rewriteParams","fsPathname","checkRewrite","regexp","matcher","source","removeUnnamedParams","sensitive","delimiter","regexpToFunction","regexModifier","flags","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","fsPathnameNoSlash","afterFiles","normalizeQueryParams","routeParamKeys","normalizedKey","getParamsFromRouteMatches","routeMatchesHeader","routeMatches","obj","URLSearchParams","keyName","normalizeDynamicRouteParams","ignoreMissingOptional","hasValidParams","defaultValue","isOptional","isDefaultValue","defaultVal","normalizeCdnUrl","formatUrl","urlObj","querystring","interpolateDynamicPath","paramValue","builtParam","replaceAll","__NEXT_TRAILING_SLASH","rewriteParamKeys","paramsMatch","paramsResult","combinedParamKeys","originalValue","queryValue","paramsToInterpolate","queryResult","isDraftMode","removeUncaughtErrorAndRejectionListeners","resolvedPathname","encodedResolvedPathname","seg","char","_","runtimeServerDeploymentId","NEXT_DEPLOYMENT_ID","clientAssetToken","immutableAssetToken","getResponseCache","responseCache","handleResponse","purpose","isError","parseBody","limit","parameters","encoding","charset","getRawBody","parseJson","qs","isValidData","urlPath","unstable_onlyGenerated","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,102,103,104]}