vinext 0.0.53 → 0.0.55

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (276) hide show
  1. package/README.md +1 -0
  2. package/dist/build/inline-css.d.ts +7 -0
  3. package/dist/build/inline-css.js +50 -0
  4. package/dist/build/inline-css.js.map +1 -0
  5. package/dist/build/prerender.js +2 -1
  6. package/dist/build/prerender.js.map +1 -1
  7. package/dist/check.js +19 -3
  8. package/dist/check.js.map +1 -1
  9. package/dist/client/navigation-runtime.d.ts +3 -1
  10. package/dist/client/navigation-runtime.js +1 -1
  11. package/dist/client/navigation-runtime.js.map +1 -1
  12. package/dist/client/window-next.d.ts +7 -0
  13. package/dist/client/window-next.js.map +1 -1
  14. package/dist/config/next-config.d.ts +97 -2
  15. package/dist/config/next-config.js +155 -6
  16. package/dist/config/next-config.js.map +1 -1
  17. package/dist/config/tsconfig-paths.d.ts +12 -3
  18. package/dist/config/tsconfig-paths.js +55 -24
  19. package/dist/config/tsconfig-paths.js.map +1 -1
  20. package/dist/deploy.js +13 -0
  21. package/dist/deploy.js.map +1 -1
  22. package/dist/entries/app-browser-entry.d.ts +11 -1
  23. package/dist/entries/app-browser-entry.js +16 -6
  24. package/dist/entries/app-browser-entry.js.map +1 -1
  25. package/dist/entries/app-rsc-entry.d.ts +9 -1
  26. package/dist/entries/app-rsc-entry.js +30 -5
  27. package/dist/entries/app-rsc-entry.js.map +1 -1
  28. package/dist/entries/app-rsc-manifest.d.ts +21 -1
  29. package/dist/entries/app-rsc-manifest.js +28 -9
  30. package/dist/entries/app-rsc-manifest.js.map +1 -1
  31. package/dist/entries/pages-client-entry.d.ts +4 -1
  32. package/dist/entries/pages-client-entry.js +18 -2
  33. package/dist/entries/pages-client-entry.js.map +1 -1
  34. package/dist/entries/pages-server-entry.js +123 -8
  35. package/dist/entries/pages-server-entry.js.map +1 -1
  36. package/dist/entries/runtime-entry-module.d.ts +1 -10
  37. package/dist/entries/runtime-entry-module.js +2 -12
  38. package/dist/entries/runtime-entry-module.js.map +1 -1
  39. package/dist/index.js +144 -44
  40. package/dist/index.js.map +1 -1
  41. package/dist/plugins/import-meta-url.d.ts +16 -0
  42. package/dist/plugins/import-meta-url.js +193 -0
  43. package/dist/plugins/import-meta-url.js.map +1 -0
  44. package/dist/plugins/remove-console.d.ts +16 -0
  45. package/dist/plugins/remove-console.js +176 -0
  46. package/dist/plugins/remove-console.js.map +1 -0
  47. package/dist/routing/app-route-graph.d.ts +24 -1
  48. package/dist/routing/app-route-graph.js +52 -4
  49. package/dist/routing/app-route-graph.js.map +1 -1
  50. package/dist/routing/app-router.d.ts +2 -2
  51. package/dist/routing/app-router.js +2 -2
  52. package/dist/routing/app-router.js.map +1 -1
  53. package/dist/routing/file-matcher.d.ts +21 -1
  54. package/dist/routing/file-matcher.js +39 -1
  55. package/dist/routing/file-matcher.js.map +1 -1
  56. package/dist/routing/pages-router.d.ts +1 -1
  57. package/dist/routing/pages-router.js +10 -3
  58. package/dist/routing/pages-router.js.map +1 -1
  59. package/dist/server/api-handler.js +1 -1
  60. package/dist/server/app-browser-action-result.d.ts +9 -16
  61. package/dist/server/app-browser-action-result.js +25 -14
  62. package/dist/server/app-browser-action-result.js.map +1 -1
  63. package/dist/server/app-browser-entry.js +195 -60
  64. package/dist/server/app-browser-entry.js.map +1 -1
  65. package/dist/server/app-browser-mpa-navigation.d.ts +16 -0
  66. package/dist/server/app-browser-mpa-navigation.js +36 -0
  67. package/dist/server/app-browser-mpa-navigation.js.map +1 -0
  68. package/dist/server/app-browser-navigation-controller.d.ts +2 -0
  69. package/dist/server/app-browser-navigation-controller.js +4 -0
  70. package/dist/server/app-browser-navigation-controller.js.map +1 -1
  71. package/dist/server/app-browser-popstate.d.ts +3 -1
  72. package/dist/server/app-browser-popstate.js +15 -1
  73. package/dist/server/app-browser-popstate.js.map +1 -1
  74. package/dist/server/app-browser-state.js +2 -1
  75. package/dist/server/app-browser-state.js.map +1 -1
  76. package/dist/server/app-elements-wire.d.ts +13 -4
  77. package/dist/server/app-elements-wire.js +10 -1
  78. package/dist/server/app-elements-wire.js.map +1 -1
  79. package/dist/server/app-elements.d.ts +2 -2
  80. package/dist/server/app-elements.js +2 -2
  81. package/dist/server/app-elements.js.map +1 -1
  82. package/dist/server/app-fallback-renderer.d.ts +15 -5
  83. package/dist/server/app-fallback-renderer.js +10 -4
  84. package/dist/server/app-fallback-renderer.js.map +1 -1
  85. package/dist/server/app-inline-css-client.d.ts +7 -0
  86. package/dist/server/app-inline-css-client.js +37 -0
  87. package/dist/server/app-inline-css-client.js.map +1 -0
  88. package/dist/server/app-layout-param-observation.d.ts +30 -0
  89. package/dist/server/app-layout-param-observation.js +130 -0
  90. package/dist/server/app-layout-param-observation.js.map +1 -0
  91. package/dist/server/app-page-boundary-render.js +2 -2
  92. package/dist/server/app-page-boundary-render.js.map +1 -1
  93. package/dist/server/app-page-boundary.d.ts +21 -1
  94. package/dist/server/app-page-boundary.js +28 -3
  95. package/dist/server/app-page-boundary.js.map +1 -1
  96. package/dist/server/app-page-cache.d.ts +7 -3
  97. package/dist/server/app-page-cache.js +7 -7
  98. package/dist/server/app-page-cache.js.map +1 -1
  99. package/dist/server/app-page-dispatch.d.ts +10 -1
  100. package/dist/server/app-page-dispatch.js +126 -79
  101. package/dist/server/app-page-dispatch.js.map +1 -1
  102. package/dist/server/app-page-element-builder.js +12 -28
  103. package/dist/server/app-page-element-builder.js.map +1 -1
  104. package/dist/server/app-page-params.d.ts +2 -1
  105. package/dist/server/app-page-params.js +14 -1
  106. package/dist/server/app-page-params.js.map +1 -1
  107. package/dist/server/app-page-probe.d.ts +12 -1
  108. package/dist/server/app-page-probe.js +116 -1
  109. package/dist/server/app-page-probe.js.map +1 -1
  110. package/dist/server/app-page-render-identity.d.ts +22 -0
  111. package/dist/server/app-page-render-identity.js +42 -0
  112. package/dist/server/app-page-render-identity.js.map +1 -0
  113. package/dist/server/app-page-render.d.ts +8 -1
  114. package/dist/server/app-page-render.js +4 -1
  115. package/dist/server/app-page-render.js.map +1 -1
  116. package/dist/server/app-page-request.d.ts +6 -3
  117. package/dist/server/app-page-request.js +5 -2
  118. package/dist/server/app-page-request.js.map +1 -1
  119. package/dist/server/app-page-response.js +2 -2
  120. package/dist/server/app-page-response.js.map +1 -1
  121. package/dist/server/app-page-route-wiring.d.ts +15 -0
  122. package/dist/server/app-page-route-wiring.js +7 -5
  123. package/dist/server/app-page-route-wiring.js.map +1 -1
  124. package/dist/server/app-page-stream.d.ts +11 -0
  125. package/dist/server/app-page-stream.js +1 -0
  126. package/dist/server/app-page-stream.js.map +1 -1
  127. package/dist/server/app-route-handler-response.js +37 -5
  128. package/dist/server/app-route-handler-response.js.map +1 -1
  129. package/dist/server/app-rsc-cache-busting.d.ts +3 -2
  130. package/dist/server/app-rsc-cache-busting.js +9 -7
  131. package/dist/server/app-rsc-cache-busting.js.map +1 -1
  132. package/dist/server/app-rsc-handler.d.ts +14 -3
  133. package/dist/server/app-rsc-handler.js +56 -6
  134. package/dist/server/app-rsc-handler.js.map +1 -1
  135. package/dist/server/app-rsc-request-normalization.d.ts +2 -1
  136. package/dist/server/app-rsc-request-normalization.js +3 -2
  137. package/dist/server/app-rsc-request-normalization.js.map +1 -1
  138. package/dist/server/app-segment-config.d.ts +1 -1
  139. package/dist/server/app-segment-config.js +4 -1
  140. package/dist/server/app-segment-config.js.map +1 -1
  141. package/dist/server/app-server-action-execution.d.ts +26 -3
  142. package/dist/server/app-server-action-execution.js +240 -29
  143. package/dist/server/app-server-action-execution.js.map +1 -1
  144. package/dist/server/app-ssr-entry.d.ts +6 -0
  145. package/dist/server/app-ssr-entry.js +22 -7
  146. package/dist/server/app-ssr-entry.js.map +1 -1
  147. package/dist/server/app-ssr-error-meta.js +3 -3
  148. package/dist/server/app-ssr-error-meta.js.map +1 -1
  149. package/dist/server/app-ssr-stream.d.ts +2 -1
  150. package/dist/server/app-ssr-stream.js +176 -31
  151. package/dist/server/app-ssr-stream.js.map +1 -1
  152. package/dist/server/artifact-compatibility.d.ts +2 -1
  153. package/dist/server/artifact-compatibility.js +10 -1
  154. package/dist/server/artifact-compatibility.js.map +1 -1
  155. package/dist/server/client-reuse-manifest.d.ts +9 -4
  156. package/dist/server/client-reuse-manifest.js +2 -1
  157. package/dist/server/client-reuse-manifest.js.map +1 -1
  158. package/dist/server/client-trace-metadata.d.ts +31 -0
  159. package/dist/server/client-trace-metadata.js +83 -0
  160. package/dist/server/client-trace-metadata.js.map +1 -0
  161. package/dist/server/cookie-utils.d.ts +13 -0
  162. package/dist/server/cookie-utils.js +20 -0
  163. package/dist/server/cookie-utils.js.map +1 -0
  164. package/dist/server/dev-server.d.ts +8 -1
  165. package/dist/server/dev-server.js +83 -12
  166. package/dist/server/dev-server.js.map +1 -1
  167. package/dist/server/document-initial-head.d.ts +7 -0
  168. package/dist/server/document-initial-head.js +35 -0
  169. package/dist/server/document-initial-head.js.map +1 -0
  170. package/dist/server/html.d.ts +2 -1
  171. package/dist/server/html.js +6 -1
  172. package/dist/server/html.js.map +1 -1
  173. package/dist/server/isr-cache.d.ts +7 -5
  174. package/dist/server/isr-cache.js +17 -6
  175. package/dist/server/isr-cache.js.map +1 -1
  176. package/dist/server/middleware-runtime.js +1 -2
  177. package/dist/server/middleware-runtime.js.map +1 -1
  178. package/dist/server/pages-document-initial-props.d.ts +89 -0
  179. package/dist/server/pages-document-initial-props.js +140 -0
  180. package/dist/server/pages-document-initial-props.js.map +1 -0
  181. package/dist/server/pages-node-compat.js +1 -1
  182. package/dist/server/pages-page-data.js +3 -0
  183. package/dist/server/pages-page-data.js.map +1 -1
  184. package/dist/server/pages-page-method.d.ts +48 -0
  185. package/dist/server/pages-page-method.js +19 -0
  186. package/dist/server/pages-page-method.js.map +1 -0
  187. package/dist/server/pages-page-response.d.ts +20 -0
  188. package/dist/server/pages-page-response.js +37 -7
  189. package/dist/server/pages-page-response.js.map +1 -1
  190. package/dist/server/pages-serializable-props.d.ts +25 -0
  191. package/dist/server/pages-serializable-props.js +69 -0
  192. package/dist/server/pages-serializable-props.js.map +1 -0
  193. package/dist/server/prod-server.js +16 -6
  194. package/dist/server/prod-server.js.map +1 -1
  195. package/dist/server/server-action-not-found.js +3 -2
  196. package/dist/server/server-action-not-found.js.map +1 -1
  197. package/dist/server/skip-cache-proof.d.ts +23 -2
  198. package/dist/server/skip-cache-proof.js +81 -12
  199. package/dist/server/skip-cache-proof.js.map +1 -1
  200. package/dist/server/static-file-cache.js +2 -1
  201. package/dist/server/static-file-cache.js.map +1 -1
  202. package/dist/server/static-layout-client-reuse-proof.d.ts +16 -0
  203. package/dist/server/static-layout-client-reuse-proof.js +35 -0
  204. package/dist/server/static-layout-client-reuse-proof.js.map +1 -0
  205. package/dist/shims/app-router-scroll-state.d.ts +4 -2
  206. package/dist/shims/app-router-scroll-state.js +16 -3
  207. package/dist/shims/app-router-scroll-state.js.map +1 -1
  208. package/dist/shims/app-router-scroll.d.ts +16 -2
  209. package/dist/shims/app-router-scroll.js +18 -3
  210. package/dist/shims/app-router-scroll.js.map +1 -1
  211. package/dist/shims/cache.d.ts +27 -1
  212. package/dist/shims/cache.js +108 -6
  213. package/dist/shims/cache.js.map +1 -1
  214. package/dist/shims/document.d.ts +6 -0
  215. package/dist/shims/document.js +7 -8
  216. package/dist/shims/document.js.map +1 -1
  217. package/dist/shims/error-boundary.d.ts +4 -4
  218. package/dist/shims/error-boundary.js +27 -28
  219. package/dist/shims/error-boundary.js.map +1 -1
  220. package/dist/shims/error.js +3 -0
  221. package/dist/shims/error.js.map +1 -1
  222. package/dist/shims/fetch-cache.d.ts +3 -1
  223. package/dist/shims/fetch-cache.js +16 -5
  224. package/dist/shims/fetch-cache.js.map +1 -1
  225. package/dist/shims/hash-scroll.d.ts +4 -1
  226. package/dist/shims/hash-scroll.js +13 -1
  227. package/dist/shims/hash-scroll.js.map +1 -1
  228. package/dist/shims/head-state.d.ts +1 -0
  229. package/dist/shims/head-state.js +18 -3
  230. package/dist/shims/head-state.js.map +1 -1
  231. package/dist/shims/head.d.ts +35 -1
  232. package/dist/shims/head.js +113 -14
  233. package/dist/shims/head.js.map +1 -1
  234. package/dist/shims/headers.d.ts +7 -0
  235. package/dist/shims/headers.js +9 -1
  236. package/dist/shims/headers.js.map +1 -1
  237. package/dist/shims/internal/app-route-detection.d.ts +37 -0
  238. package/dist/shims/internal/app-route-detection.js +69 -0
  239. package/dist/shims/internal/app-route-detection.js.map +1 -0
  240. package/dist/shims/internal/pages-data-fetch-dedup.d.ts +56 -0
  241. package/dist/shims/internal/pages-data-fetch-dedup.js +70 -0
  242. package/dist/shims/internal/pages-data-fetch-dedup.js.map +1 -0
  243. package/dist/shims/link.d.ts +18 -2
  244. package/dist/shims/link.js +98 -8
  245. package/dist/shims/link.js.map +1 -1
  246. package/dist/shims/metadata.d.ts +7 -6
  247. package/dist/shims/metadata.js +9 -5
  248. package/dist/shims/metadata.js.map +1 -1
  249. package/dist/shims/navigation.d.ts +40 -3
  250. package/dist/shims/navigation.js +124 -25
  251. package/dist/shims/navigation.js.map +1 -1
  252. package/dist/shims/router.d.ts +5 -0
  253. package/dist/shims/router.js +51 -21
  254. package/dist/shims/router.js.map +1 -1
  255. package/dist/shims/script.d.ts +11 -1
  256. package/dist/shims/script.js +75 -6
  257. package/dist/shims/script.js.map +1 -1
  258. package/dist/shims/thenable-params.d.ts +5 -2
  259. package/dist/shims/thenable-params.js +25 -1
  260. package/dist/shims/thenable-params.js.map +1 -1
  261. package/dist/shims/unified-request-context.js +3 -0
  262. package/dist/shims/unified-request-context.js.map +1 -1
  263. package/dist/utils/client-build-manifest.d.ts +15 -0
  264. package/dist/utils/client-build-manifest.js +54 -0
  265. package/dist/utils/client-build-manifest.js.map +1 -0
  266. package/dist/utils/hash.js +1 -1
  267. package/dist/utils/hash.js.map +1 -1
  268. package/dist/utils/lazy-chunks.d.ts +1 -1
  269. package/dist/utils/lazy-chunks.js.map +1 -1
  270. package/dist/utils/path.d.ts +13 -0
  271. package/dist/utils/path.js +16 -0
  272. package/dist/utils/path.js.map +1 -0
  273. package/dist/utils/vite-version.d.ts +11 -0
  274. package/dist/utils/vite-version.js +36 -0
  275. package/dist/utils/vite-version.js.map +1 -0
  276. package/package.json +2 -2
@@ -10,10 +10,17 @@ import React, { Children, isValidElement, useEffect, useRef } from "react";
10
10
  * document.head projection and applies it with DOM manipulation.
11
11
  */
12
12
  let _ssrHeadChildren = [];
13
+ let _documentInitialHead = [];
14
+ /** @internal — exposed for unit tests of the client head projection. */
13
15
  const _clientHeadChildren = /* @__PURE__ */ new Map();
14
16
  let _getSSRHeadChildren = () => _ssrHeadChildren;
15
17
  let _resetSSRHeadImpl = () => {
16
18
  _ssrHeadChildren = [];
19
+ _documentInitialHead = [];
20
+ };
21
+ let _getDocumentInitialHead = () => _documentInitialHead;
22
+ let _setDocumentInitialHead = (head) => {
23
+ _documentInitialHead = head;
17
24
  };
18
25
  /**
19
26
  * Register ALS-backed state accessors. Called by head-state.ts on import.
@@ -22,14 +29,52 @@ let _resetSSRHeadImpl = () => {
22
29
  function _registerHeadStateAccessors(accessors) {
23
30
  _getSSRHeadChildren = accessors.getSSRHeadChildren;
24
31
  _resetSSRHeadImpl = accessors.resetSSRHead;
32
+ if (accessors.getDocumentInitialHead) _getDocumentInitialHead = accessors.getDocumentInitialHead;
33
+ if (accessors.setDocumentInitialHead) _setDocumentInitialHead = accessors.setDocumentInitialHead;
25
34
  }
26
35
  /** Reset the SSR head collector. Call before render. */
27
36
  function resetSSRHead() {
28
37
  _resetSSRHeadImpl();
29
38
  }
39
+ /**
40
+ * Register head tags returned by a user `_document.getInitialProps()` call.
41
+ * Mirrors Next.js: `_document` may extend the head array passed to its render,
42
+ * and those tags are merged into the final `<head>` output. We treat them the
43
+ * same as `next/head` children — they go through the same dedupe pipeline so
44
+ * later tags (by key or meta-type) win, matching Next.js semantics.
45
+ *
46
+ * Pass an empty array (or simply don't call this) to skip the merge.
47
+ */
48
+ function setDocumentInitialHead(head) {
49
+ _setDocumentInitialHead(head);
50
+ }
51
+ /**
52
+ * Default head tags emitted alongside every Pages Router render — charset
53
+ * first, then viewport. Mirrors Next.js's `defaultHead()` in
54
+ * `packages/next/src/shared/lib/head.tsx`, which seeds the head array used
55
+ * by `HeadManagerContext` before any user `<Head>` reduces over it.
56
+ *
57
+ * The canonical Next.js order is `<meta charset>` then `<meta viewport>`
58
+ * then user tags, all with `data-next-head=""`. See assertion in
59
+ * `test/e2e/next-head/index.test.ts`.
60
+ */
61
+ function defaultHead() {
62
+ return [React.createElement("meta", {
63
+ charSet: "utf-8",
64
+ key: "charset"
65
+ }), React.createElement("meta", {
66
+ name: "viewport",
67
+ content: "width=device-width",
68
+ key: "viewport"
69
+ })];
70
+ }
30
71
  /** Get collected head HTML. Call after render. */
31
72
  function getSSRHeadHTML() {
32
- return reduceHeadChildren(_getSSRHeadChildren()).map((child) => headChildToHTML(child.type, child.props)).filter(Boolean).join("\n ");
73
+ return reduceHeadChildren([
74
+ ...defaultHead(),
75
+ ..._getSSRHeadChildren(),
76
+ ..._getDocumentInitialHead()
77
+ ]).map((child) => headChildToHTML(child.type, child.props)).filter(Boolean).join("\n ");
33
78
  }
34
79
  /**
35
80
  * Tags allowed inside <head>. Anything else is silently dropped.
@@ -138,6 +183,28 @@ function isSafeAttrName(name) {
138
183
  return true;
139
184
  }
140
185
  /**
186
+ * Map React JSX attribute names to their HTML serialised form for the small
187
+ * set of head-relevant attributes where the two differ. React's own renderer
188
+ * normalises these automatically, but we serialise tags by hand so they reach
189
+ * the final HTML in the canonical lowercase / kebab-case shape that browsers
190
+ * (and Next.js's `test/e2e/next-head/index.test.ts`) expect.
191
+ */
192
+ const JSX_TO_HTML_ATTR_MAP = {
193
+ charSet: "charset",
194
+ httpEquiv: "http-equiv",
195
+ acceptCharset: "accept-charset",
196
+ itemProp: "itemprop",
197
+ itemType: "itemtype",
198
+ itemID: "itemid",
199
+ itemRef: "itemref",
200
+ itemScope: "itemscope",
201
+ crossOrigin: "crossorigin",
202
+ referrerPolicy: "referrerpolicy"
203
+ };
204
+ function jsxAttrToHtml(name) {
205
+ return JSX_TO_HTML_ATTR_MAP[name] ?? name;
206
+ }
207
+ /**
141
208
  * Convert props + tag to an HTML string for SSR head injection.
142
209
  * Callers must only pass tags that have already been validated against
143
210
  * ALLOWED_HEAD_TAGS (e.g. via reduceHeadChildren / collectHeadElements).
@@ -153,10 +220,10 @@ function headChildToHTML(tag, props) {
153
220
  else if (key === "className") attrs.push(`class="${escapeAttr(String(value))}"`);
154
221
  else if (typeof value === "string") {
155
222
  if (!isSafeAttrName(key)) continue;
156
- attrs.push(`${key}="${escapeAttr(value)}"`);
223
+ attrs.push(`${jsxAttrToHtml(key)}="${escapeAttr(value)}"`);
157
224
  } else if (typeof value === "boolean" && value) {
158
225
  if (!isSafeAttrName(key)) continue;
159
- attrs.push(key);
226
+ attrs.push(jsxAttrToHtml(key));
160
227
  }
161
228
  const attrStr = attrs.length ? " " + attrs.join(" ") : "";
162
229
  if (SELF_CLOSING_HEAD_TAGS.has(tag)) return `<${tag}${attrStr} data-next-head="" />`;
@@ -197,22 +264,54 @@ function _applyHeadPropsToElement(domEl, props) {
197
264
  else if (key === "className") domEl.setAttribute("class", String(value));
198
265
  else if (typeof value === "boolean" && value) {
199
266
  if (!isSafeAttrName(key)) continue;
200
- domEl.setAttribute(key, "");
267
+ domEl.setAttribute(jsxAttrToHtml(key), "");
201
268
  } else if (typeof value === "string") {
202
269
  if (!isSafeAttrName(key)) continue;
203
- domEl.setAttribute(key, value);
270
+ domEl.setAttribute(jsxAttrToHtml(key), value);
204
271
  }
205
272
  }
206
- function syncClientHead() {
207
- document.querySelectorAll("[data-next-head]").forEach((el) => el.remove());
208
- for (const child of reduceHeadChildren([..._clientHeadChildren.values()])) {
273
+ /**
274
+ * Reconcile the document <head> against the desired projection.
275
+ *
276
+ * Mirrors Next.js's client `head-manager.ts` `updateElements()`: rather than
277
+ * wiping every [data-next-head] node and re-appending (which reorders the
278
+ * SSR-emitted tags to the end of <head> and causes flicker on each update),
279
+ * we diff the desired tags against the existing ones with isEqualNode(). Tags
280
+ * that already match are left untouched in their original DOM position, only
281
+ * genuinely new tags are inserted, and stale tags are removed.
282
+ *
283
+ * The desired list seeds defaultHead() (charset + viewport) ahead of user
284
+ * tags — matching the SSR path in getSSRHeadHTML() and Next.js's
285
+ * reduceComponents(), which always concatenates defaultHead() on both server
286
+ * and client. Without it the first <Head> mount after hydration would drop the
287
+ * server-rendered defaults. Users can still override via key="charset" /
288
+ * key="viewport" through the dedupe pipeline.
289
+ *
290
+ * @internal — exported for unit tests; called from the Head client effect.
291
+ */
292
+ function _syncClientHead() {
293
+ const headEl = document.head;
294
+ if (!headEl) return;
295
+ const oldTags = new Set(headEl.querySelectorAll("[data-next-head]"));
296
+ const charsetEl = headEl.querySelector("meta[charset]");
297
+ if (charsetEl) oldTags.add(charsetEl);
298
+ const newTags = [];
299
+ for (const child of reduceHeadChildren([...defaultHead(), ..._clientHeadChildren.values()])) {
209
300
  if (typeof child.type !== "string") continue;
210
301
  const domEl = document.createElement(child.type);
211
- const props = child.props;
212
- _applyHeadPropsToElement(domEl, props);
302
+ _applyHeadPropsToElement(domEl, child.props);
213
303
  domEl.setAttribute("data-next-head", "");
214
- document.head.appendChild(domEl);
304
+ let isNew = true;
305
+ for (const oldTag of oldTags) if (oldTag.isEqualNode(domEl)) {
306
+ oldTags.delete(oldTag);
307
+ isNew = false;
308
+ break;
309
+ }
310
+ if (isNew) newTags.push(domEl);
215
311
  }
312
+ for (const oldTag of oldTags) oldTag.parentNode?.removeChild(oldTag);
313
+ for (const newTag of newTags) if (newTag.tagName.toLowerCase() === "meta" && newTag.getAttribute("charset") !== null) headEl.prepend(newTag);
314
+ else headEl.appendChild(newTag);
216
315
  }
217
316
  function Head({ children }) {
218
317
  const headInstanceIdRef = useRef(null);
@@ -224,15 +323,15 @@ function Head({ children }) {
224
323
  useEffect(() => {
225
324
  const instanceId = headInstanceIdRef.current;
226
325
  _clientHeadChildren.set(instanceId, children);
227
- syncClientHead();
326
+ _syncClientHead();
228
327
  return () => {
229
328
  _clientHeadChildren.delete(instanceId);
230
- syncClientHead();
329
+ _syncClientHead();
231
330
  };
232
331
  }, [children]);
233
332
  return null;
234
333
  }
235
334
  //#endregion
236
- export { _applyHeadPropsToElement, _registerHeadStateAccessors, Head as default, escapeAttr, escapeInlineContent, getSSRHeadHTML, isSafeAttrName, reduceHeadChildren, resetSSRHead };
335
+ export { _applyHeadPropsToElement, _clientHeadChildren, _registerHeadStateAccessors, _syncClientHead, Head as default, escapeAttr, escapeInlineContent, getSSRHeadHTML, isSafeAttrName, reduceHeadChildren, resetSSRHead, setDocumentInitialHead };
237
336
 
238
337
  //# sourceMappingURL=head.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"head.js","names":[],"sources":["../../src/shims/head.ts"],"sourcesContent":["/**\n * next/head shim\n *\n * In the Pages Router, <Head> manages document <head> elements.\n * - On the server: collects elements into a module-level array that the\n * dev-server reads after render and injects into the HTML <head>.\n * - On the client: reduces all mounted <Head> instances into one deduped\n * document.head projection and applies it with DOM manipulation.\n */\nimport React, { useEffect, useRef, Children, isValidElement } from \"react\";\n\ntype HeadProps = {\n children?: React.ReactNode;\n};\n\n// --- SSR head collection ---\n// State uses a registration pattern so this module can be bundled for the\n// browser. The ALS-backed implementation lives in head-state.ts (server-only).\n\nlet _ssrHeadChildren: React.ReactNode[] = [];\nconst _clientHeadChildren = new Map<symbol, React.ReactNode>();\n\nlet _getSSRHeadChildren = (): React.ReactNode[] => _ssrHeadChildren;\nlet _resetSSRHeadImpl = (): void => {\n _ssrHeadChildren = [];\n};\n\n/**\n * Register ALS-backed state accessors. Called by head-state.ts on import.\n * @internal\n */\nexport function _registerHeadStateAccessors(accessors: {\n getSSRHeadChildren: () => React.ReactNode[];\n resetSSRHead: () => void;\n}): void {\n _getSSRHeadChildren = accessors.getSSRHeadChildren;\n _resetSSRHeadImpl = accessors.resetSSRHead;\n}\n\n/** Reset the SSR head collector. Call before render. */\nexport function resetSSRHead(): void {\n _resetSSRHeadImpl();\n}\n\n/** Get collected head HTML. Call after render. */\nexport function getSSRHeadHTML(): string {\n return reduceHeadChildren(_getSSRHeadChildren())\n .map((child) => headChildToHTML(child.type as string, child.props as Record<string, unknown>))\n .filter(Boolean)\n .join(\"\\n \");\n}\n\n/**\n * Tags allowed inside <head>. Anything else is silently dropped.\n * This prevents injection of dangerous elements like <iframe>, <object>, etc.\n */\nconst ALLOWED_HEAD_TAGS = new Set([\"title\", \"meta\", \"link\", \"style\", \"script\", \"base\", \"noscript\"]);\nconst ALLOWED_HEAD_TAGS_LIST = Array.from(ALLOWED_HEAD_TAGS).join(\", \");\nconst META_TYPES = [\"name\", \"httpEquiv\", \"charSet\", \"itemProp\"] as const;\n\n/** Self-closing tags: no inner content, emit as <tag ... /> */\nconst SELF_CLOSING_HEAD_TAGS = new Set([\"meta\", \"link\", \"base\"]);\n\n/** Tags whose content is raw text — closing-tag sequences must be escaped during SSR. */\nconst RAW_CONTENT_TAGS = new Set([\"script\", \"style\"]);\n\ntype HeadDOMElement = Pick<HTMLElement, \"innerHTML\" | \"setAttribute\" | \"textContent\">;\n\nfunction warnDisallowedHeadTag(tag: string): void {\n if (process.env.NODE_ENV !== \"production\") {\n console.warn(\n `[vinext] <Head> ignoring disallowed tag <${tag}>. ` +\n `Only ${ALLOWED_HEAD_TAGS_LIST} are allowed.`,\n );\n }\n}\n\nfunction collectHeadElements(\n list: React.ReactElement[],\n child: React.ReactNode,\n): React.ReactElement[] {\n if (\n child == null ||\n typeof child === \"boolean\" ||\n typeof child === \"string\" ||\n typeof child === \"number\"\n ) {\n return list;\n }\n if (!isValidElement(child)) {\n return list;\n }\n if (child.type === React.Fragment) {\n return Children.toArray((child.props as { children?: React.ReactNode }).children).reduce(\n collectHeadElements,\n list,\n );\n }\n if (typeof child.type !== \"string\") {\n return list;\n }\n if (!ALLOWED_HEAD_TAGS.has(child.type)) {\n warnDisallowedHeadTag(child.type);\n return list;\n }\n return list.concat(child);\n}\n\nfunction normalizeHeadKey(key: React.Key | null): string | null {\n if (key == null || typeof key === \"number\") return null;\n const normalizedKey = String(key);\n const separatorIndex = normalizedKey.indexOf(\"$\");\n return separatorIndex > 0 ? normalizedKey.slice(separatorIndex + 1) : null;\n}\n\nfunction createUniqueHeadFilter(): (child: React.ReactElement) => boolean {\n const keys = new Set<string>();\n const tags = new Set<string>();\n const metaTypes = new Set<string>();\n const metaCategories = new Map<string, Set<string>>();\n\n return (child) => {\n let isUnique = true;\n const normalizedKey = normalizeHeadKey(child.key);\n const hasKey = normalizedKey !== null;\n if (normalizedKey) {\n if (keys.has(normalizedKey)) {\n isUnique = false;\n } else {\n keys.add(normalizedKey);\n }\n }\n\n switch (child.type) {\n case \"title\":\n case \"base\":\n if (tags.has(child.type)) {\n isUnique = false;\n } else {\n tags.add(child.type);\n }\n break;\n case \"meta\": {\n const props = child.props as Record<string, unknown>;\n for (const metaType of META_TYPES) {\n if (!Object.prototype.hasOwnProperty.call(props, metaType)) continue;\n if (metaType === \"charSet\") {\n if (metaTypes.has(metaType)) {\n isUnique = false;\n } else {\n metaTypes.add(metaType);\n }\n continue;\n }\n\n const category = props[metaType];\n if (typeof category !== \"string\") continue;\n\n let categories = metaCategories.get(metaType);\n if (!categories) {\n categories = new Set<string>();\n metaCategories.set(metaType, categories);\n }\n\n if ((metaType !== \"name\" || !hasKey) && categories.has(category)) {\n isUnique = false;\n } else {\n categories.add(category);\n }\n }\n break;\n }\n default:\n break;\n }\n\n return isUnique;\n };\n}\n\nexport function reduceHeadChildren(headChildren: React.ReactNode[]): React.ReactElement[] {\n return headChildren\n .reduce<React.ReactNode[]>(\n (flattenedChildren, child) => flattenedChildren.concat(Children.toArray(child)),\n [],\n )\n .reduce(collectHeadElements, [])\n .reverse()\n .filter(createUniqueHeadFilter())\n .reverse();\n}\n\n/**\n * Validate an HTML attribute name. Rejects names that could break out of\n * the attribute context during SSR serialization, or that represent inline\n * event handlers (on*). Only allows alphanumeric characters, hyphens, and\n * common data-attribute patterns.\n */\nconst SAFE_ATTR_NAME_RE = /^[a-zA-Z][a-zA-Z0-9\\-:.]*$/;\n\nexport function isSafeAttrName(name: string): boolean {\n if (!SAFE_ATTR_NAME_RE.test(name)) return false;\n // Block inline event handlers (onclick, onerror, etc.)\n if (name.length > 2 && name[0] === \"o\" && name[1] === \"n\" && name[2] >= \"A\" && name[2] <= \"z\")\n return false;\n return true;\n}\n\n/**\n * Convert props + tag to an HTML string for SSR head injection.\n * Callers must only pass tags that have already been validated against\n * ALLOWED_HEAD_TAGS (e.g. via reduceHeadChildren / collectHeadElements).\n */\nfunction headChildToHTML(tag: string, props: Record<string, unknown>): string {\n const attrs: string[] = [];\n let innerHTML = \"\";\n\n // dangerouslySetInnerHTML takes precedence over children, regardless of\n // prop iteration order. Check it first to match Next.js semantics.\n const rawHtml = getDangerouslySetInnerHTML(props.dangerouslySetInnerHTML);\n if (rawHtml != null) {\n // Intentionally raw — developer explicitly opted in.\n // SECURITY NOTE: This injects raw HTML. Developers must never pass\n // unsanitized user input here — it is a stored XSS vector.\n innerHTML = rawHtml;\n } else if (typeof props.children === \"string\") {\n innerHTML = escapeHTML(props.children);\n } else if (Array.isArray(props.children)) {\n innerHTML = escapeHTML(props.children.join(\"\"));\n }\n\n for (const [key, value] of Object.entries(props)) {\n if (key === \"children\" || key === \"dangerouslySetInnerHTML\") {\n continue;\n } else if (key === \"className\") {\n attrs.push(`class=\"${escapeAttr(String(value))}\"`);\n } else if (typeof value === \"string\") {\n if (!isSafeAttrName(key)) continue;\n attrs.push(`${key}=\"${escapeAttr(value)}\"`);\n } else if (typeof value === \"boolean\" && value) {\n if (!isSafeAttrName(key)) continue;\n attrs.push(key);\n }\n }\n\n const attrStr = attrs.length ? \" \" + attrs.join(\" \") : \"\";\n\n if (SELF_CLOSING_HEAD_TAGS.has(tag)) {\n return `<${tag}${attrStr} data-next-head=\"\" />`;\n }\n\n // For raw-content tags (script, style), escape closing-tag sequences so the\n // HTML parser doesn't prematurely terminate the element.\n if (RAW_CONTENT_TAGS.has(tag) && innerHTML) {\n innerHTML = escapeInlineContent(innerHTML, tag);\n }\n\n return `<${tag}${attrStr} data-next-head=\"\">${innerHTML}</${tag}>`;\n}\n\nfunction escapeHTML(s: string): string {\n return s.replace(/&/g, \"&amp;\").replace(/</g, \"&lt;\").replace(/>/g, \"&gt;\");\n}\n\nexport function escapeAttr(s: string): string {\n return s\n .replace(/&/g, \"&amp;\")\n .replace(/\"/g, \"&quot;\")\n .replace(/</g, \"&lt;\")\n .replace(/>/g, \"&gt;\");\n}\n\n/**\n * Escape content that will be placed inside a raw <script> or <style> tag\n * during SSR. The HTML parser treats `</script>` (or `</style>`) as the end\n * of the block regardless of JavaScript string context, so any occurrence\n * of `</` followed by the tag name must be escaped.\n *\n * We replace `</script` and `</style` (case-insensitive) with `<\\/script`\n * and `<\\/style` respectively. The `<\\/` form is harmless in JS/CSS string\n * context but prevents the HTML parser from seeing a closing tag.\n */\nexport function escapeInlineContent(content: string, tag: string): string {\n // Build a pattern like `<\\/script` or `<\\/style`, case-insensitive.\n // `tag` is always a literal developer-controlled value (\"script\" or \"style\")\n // guarded by the RAW_CONTENT_TAGS.has(tag) check at all call sites — never user input.\n const pattern = new RegExp(`<\\\\/(${tag})`, \"gi\");\n return content.replace(pattern, \"<\\\\/$1\");\n}\n\nfunction getDangerouslySetInnerHTML(value: unknown): string | undefined {\n if (typeof value !== \"object\" || value === null) return undefined;\n\n const html = Reflect.get(value, \"__html\");\n return typeof html === \"string\" ? html : undefined;\n}\n\nexport function _applyHeadPropsToElement(\n domEl: HeadDOMElement,\n props: Record<string, unknown>,\n): void {\n const rawHtml = getDangerouslySetInnerHTML(props.dangerouslySetInnerHTML);\n\n if (rawHtml != null) {\n domEl.innerHTML = rawHtml;\n } else if (typeof props.children === \"string\") {\n domEl.textContent = props.children;\n } else if (Array.isArray(props.children)) {\n domEl.textContent = props.children.join(\"\");\n }\n\n for (const [key, value] of Object.entries(props)) {\n if (key === \"children\" || key === \"dangerouslySetInnerHTML\") {\n continue;\n } else if (key === \"className\") {\n domEl.setAttribute(\"class\", String(value));\n } else if (typeof value === \"boolean\" && value) {\n if (!isSafeAttrName(key)) continue;\n domEl.setAttribute(key, \"\");\n } else if (typeof value === \"string\") {\n if (!isSafeAttrName(key)) continue;\n domEl.setAttribute(key, value);\n }\n }\n}\n\nfunction syncClientHead(): void {\n document.querySelectorAll(\"[data-next-head]\").forEach((el) => el.remove());\n\n for (const child of reduceHeadChildren([..._clientHeadChildren.values()])) {\n if (typeof child.type !== \"string\") continue;\n\n const domEl = document.createElement(child.type);\n const props = child.props as Record<string, unknown>;\n _applyHeadPropsToElement(domEl, props);\n\n domEl.setAttribute(\"data-next-head\", \"\");\n document.head.appendChild(domEl);\n }\n}\n\n// --- Component ---\n\nfunction Head({ children }: HeadProps): null {\n const headInstanceIdRef = useRef<symbol | null>(null);\n if (headInstanceIdRef.current === null) {\n headInstanceIdRef.current = Symbol(\"vinext-head\");\n }\n\n // SSR path: collect elements for later injection\n if (typeof window === \"undefined\") {\n _getSSRHeadChildren().push(children);\n return null;\n }\n\n // Client path: update the shared head projection after hydration.\n // oxlint-disable-next-line react-hooks/rules-of-hooks\n useEffect(() => {\n const instanceId = headInstanceIdRef.current!;\n _clientHeadChildren.set(instanceId, children);\n syncClientHead();\n\n return () => {\n _clientHeadChildren.delete(instanceId);\n syncClientHead();\n };\n }, [children]);\n\n return null;\n}\n\nexport default Head;\n"],"mappings":"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"}
1
+ {"version":3,"file":"head.js","names":[],"sources":["../../src/shims/head.ts"],"sourcesContent":["/**\n * next/head shim\n *\n * In the Pages Router, <Head> manages document <head> elements.\n * - On the server: collects elements into a module-level array that the\n * dev-server reads after render and injects into the HTML <head>.\n * - On the client: reduces all mounted <Head> instances into one deduped\n * document.head projection and applies it with DOM manipulation.\n */\nimport React, { useEffect, useRef, Children, isValidElement } from \"react\";\n\ntype HeadProps = {\n children?: React.ReactNode;\n};\n\n// --- SSR head collection ---\n// State uses a registration pattern so this module can be bundled for the\n// browser. The ALS-backed implementation lives in head-state.ts (server-only).\n\nlet _ssrHeadChildren: React.ReactNode[] = [];\nlet _documentInitialHead: React.ReactNode[] = [];\n/** @internal — exposed for unit tests of the client head projection. */\nexport const _clientHeadChildren = new Map<symbol, React.ReactNode>();\n\nlet _getSSRHeadChildren = (): React.ReactNode[] => _ssrHeadChildren;\nlet _resetSSRHeadImpl = (): void => {\n _ssrHeadChildren = [];\n _documentInitialHead = [];\n};\nlet _getDocumentInitialHead = (): React.ReactNode[] => _documentInitialHead;\nlet _setDocumentInitialHead = (head: React.ReactNode[]): void => {\n _documentInitialHead = head;\n};\n\n/**\n * Register ALS-backed state accessors. Called by head-state.ts on import.\n * @internal\n */\nexport function _registerHeadStateAccessors(accessors: {\n getSSRHeadChildren: () => React.ReactNode[];\n resetSSRHead: () => void;\n getDocumentInitialHead?: () => React.ReactNode[];\n setDocumentInitialHead?: (head: React.ReactNode[]) => void;\n}): void {\n _getSSRHeadChildren = accessors.getSSRHeadChildren;\n _resetSSRHeadImpl = accessors.resetSSRHead;\n if (accessors.getDocumentInitialHead) {\n _getDocumentInitialHead = accessors.getDocumentInitialHead;\n }\n if (accessors.setDocumentInitialHead) {\n _setDocumentInitialHead = accessors.setDocumentInitialHead;\n }\n}\n\n/** Reset the SSR head collector. Call before render. */\nexport function resetSSRHead(): void {\n _resetSSRHeadImpl();\n}\n\n/**\n * Register head tags returned by a user `_document.getInitialProps()` call.\n * Mirrors Next.js: `_document` may extend the head array passed to its render,\n * and those tags are merged into the final `<head>` output. We treat them the\n * same as `next/head` children — they go through the same dedupe pipeline so\n * later tags (by key or meta-type) win, matching Next.js semantics.\n *\n * Pass an empty array (or simply don't call this) to skip the merge.\n */\nexport function setDocumentInitialHead(head: React.ReactNode[]): void {\n _setDocumentInitialHead(head);\n}\n\n/**\n * Default head tags emitted alongside every Pages Router render — charset\n * first, then viewport. Mirrors Next.js's `defaultHead()` in\n * `packages/next/src/shared/lib/head.tsx`, which seeds the head array used\n * by `HeadManagerContext` before any user `<Head>` reduces over it.\n *\n * The canonical Next.js order is `<meta charset>` then `<meta viewport>`\n * then user tags, all with `data-next-head=\"\"`. See assertion in\n * `test/e2e/next-head/index.test.ts`.\n */\nfunction defaultHead(): React.ReactElement[] {\n return [\n React.createElement(\"meta\", { charSet: \"utf-8\", key: \"charset\" }),\n React.createElement(\"meta\", {\n name: \"viewport\",\n content: \"width=device-width\",\n key: \"viewport\",\n }),\n ];\n}\n\n/** Get collected head HTML. Call after render. */\nexport function getSSRHeadHTML(): string {\n // Order mirrors Next.js's `_document.tsx`: defaultHead seeds the head array,\n // user `next/head` tags reduce over it, and then `_document.getInitialProps`\n // may extend the array. The final `_document` render emits `{head}` (which\n // contains the defaults + user tags + initial-props tags) ahead of any\n // children declared inside `_document`'s own `<Head>`. Because the user\n // children inside `_document`'s `<Head>` are tracked via React tree render\n // (not next/head), they don't appear in this collector — so emitting\n // `defaultHead + user + initialProps` here matches Next.js's serialised\n // output up to that boundary.\n return reduceHeadChildren([\n ...defaultHead(),\n ..._getSSRHeadChildren(),\n ..._getDocumentInitialHead(),\n ])\n .map((child) => headChildToHTML(child.type as string, child.props as Record<string, unknown>))\n .filter(Boolean)\n .join(\"\\n \");\n}\n\n/**\n * Tags allowed inside <head>. Anything else is silently dropped.\n * This prevents injection of dangerous elements like <iframe>, <object>, etc.\n */\nconst ALLOWED_HEAD_TAGS = new Set([\"title\", \"meta\", \"link\", \"style\", \"script\", \"base\", \"noscript\"]);\nconst ALLOWED_HEAD_TAGS_LIST = Array.from(ALLOWED_HEAD_TAGS).join(\", \");\nconst META_TYPES = [\"name\", \"httpEquiv\", \"charSet\", \"itemProp\"] as const;\n\n/** Self-closing tags: no inner content, emit as <tag ... /> */\nconst SELF_CLOSING_HEAD_TAGS = new Set([\"meta\", \"link\", \"base\"]);\n\n/** Tags whose content is raw text — closing-tag sequences must be escaped during SSR. */\nconst RAW_CONTENT_TAGS = new Set([\"script\", \"style\"]);\n\ntype HeadDOMElement = Pick<HTMLElement, \"innerHTML\" | \"setAttribute\" | \"textContent\">;\n\nfunction warnDisallowedHeadTag(tag: string): void {\n if (process.env.NODE_ENV !== \"production\") {\n console.warn(\n `[vinext] <Head> ignoring disallowed tag <${tag}>. ` +\n `Only ${ALLOWED_HEAD_TAGS_LIST} are allowed.`,\n );\n }\n}\n\nfunction collectHeadElements(\n list: React.ReactElement[],\n child: React.ReactNode,\n): React.ReactElement[] {\n if (\n child == null ||\n typeof child === \"boolean\" ||\n typeof child === \"string\" ||\n typeof child === \"number\"\n ) {\n return list;\n }\n if (!isValidElement(child)) {\n return list;\n }\n if (child.type === React.Fragment) {\n return Children.toArray((child.props as { children?: React.ReactNode }).children).reduce(\n collectHeadElements,\n list,\n );\n }\n if (typeof child.type !== \"string\") {\n return list;\n }\n if (!ALLOWED_HEAD_TAGS.has(child.type)) {\n warnDisallowedHeadTag(child.type);\n return list;\n }\n return list.concat(child);\n}\n\nfunction normalizeHeadKey(key: React.Key | null): string | null {\n if (key == null || typeof key === \"number\") return null;\n const normalizedKey = String(key);\n const separatorIndex = normalizedKey.indexOf(\"$\");\n return separatorIndex > 0 ? normalizedKey.slice(separatorIndex + 1) : null;\n}\n\nfunction createUniqueHeadFilter(): (child: React.ReactElement) => boolean {\n const keys = new Set<string>();\n const tags = new Set<string>();\n const metaTypes = new Set<string>();\n const metaCategories = new Map<string, Set<string>>();\n\n return (child) => {\n let isUnique = true;\n const normalizedKey = normalizeHeadKey(child.key);\n const hasKey = normalizedKey !== null;\n if (normalizedKey) {\n if (keys.has(normalizedKey)) {\n isUnique = false;\n } else {\n keys.add(normalizedKey);\n }\n }\n\n switch (child.type) {\n case \"title\":\n case \"base\":\n if (tags.has(child.type)) {\n isUnique = false;\n } else {\n tags.add(child.type);\n }\n break;\n case \"meta\": {\n const props = child.props as Record<string, unknown>;\n for (const metaType of META_TYPES) {\n if (!Object.prototype.hasOwnProperty.call(props, metaType)) continue;\n if (metaType === \"charSet\") {\n if (metaTypes.has(metaType)) {\n isUnique = false;\n } else {\n metaTypes.add(metaType);\n }\n continue;\n }\n\n const category = props[metaType];\n if (typeof category !== \"string\") continue;\n\n let categories = metaCategories.get(metaType);\n if (!categories) {\n categories = new Set<string>();\n metaCategories.set(metaType, categories);\n }\n\n if ((metaType !== \"name\" || !hasKey) && categories.has(category)) {\n isUnique = false;\n } else {\n categories.add(category);\n }\n }\n break;\n }\n default:\n break;\n }\n\n return isUnique;\n };\n}\n\nexport function reduceHeadChildren(headChildren: React.ReactNode[]): React.ReactElement[] {\n return headChildren\n .reduce<React.ReactNode[]>(\n (flattenedChildren, child) => flattenedChildren.concat(Children.toArray(child)),\n [],\n )\n .reduce(collectHeadElements, [])\n .reverse()\n .filter(createUniqueHeadFilter())\n .reverse();\n}\n\n/**\n * Validate an HTML attribute name. Rejects names that could break out of\n * the attribute context during SSR serialization, or that represent inline\n * event handlers (on*). Only allows alphanumeric characters, hyphens, and\n * common data-attribute patterns.\n */\nconst SAFE_ATTR_NAME_RE = /^[a-zA-Z][a-zA-Z0-9\\-:.]*$/;\n\nexport function isSafeAttrName(name: string): boolean {\n if (!SAFE_ATTR_NAME_RE.test(name)) return false;\n // Block inline event handlers (onclick, onerror, etc.)\n if (name.length > 2 && name[0] === \"o\" && name[1] === \"n\" && name[2] >= \"A\" && name[2] <= \"z\")\n return false;\n return true;\n}\n\n/**\n * Map React JSX attribute names to their HTML serialised form for the small\n * set of head-relevant attributes where the two differ. React's own renderer\n * normalises these automatically, but we serialise tags by hand so they reach\n * the final HTML in the canonical lowercase / kebab-case shape that browsers\n * (and Next.js's `test/e2e/next-head/index.test.ts`) expect.\n */\nconst JSX_TO_HTML_ATTR_MAP: Record<string, string> = {\n charSet: \"charset\",\n httpEquiv: \"http-equiv\",\n acceptCharset: \"accept-charset\",\n itemProp: \"itemprop\",\n itemType: \"itemtype\",\n itemID: \"itemid\",\n itemRef: \"itemref\",\n itemScope: \"itemscope\",\n crossOrigin: \"crossorigin\",\n referrerPolicy: \"referrerpolicy\",\n};\n\nfunction jsxAttrToHtml(name: string): string {\n return JSX_TO_HTML_ATTR_MAP[name] ?? name;\n}\n\n/**\n * Convert props + tag to an HTML string for SSR head injection.\n * Callers must only pass tags that have already been validated against\n * ALLOWED_HEAD_TAGS (e.g. via reduceHeadChildren / collectHeadElements).\n */\nfunction headChildToHTML(tag: string, props: Record<string, unknown>): string {\n const attrs: string[] = [];\n let innerHTML = \"\";\n\n // dangerouslySetInnerHTML takes precedence over children, regardless of\n // prop iteration order. Check it first to match Next.js semantics.\n const rawHtml = getDangerouslySetInnerHTML(props.dangerouslySetInnerHTML);\n if (rawHtml != null) {\n // Intentionally raw — developer explicitly opted in.\n // SECURITY NOTE: This injects raw HTML. Developers must never pass\n // unsanitized user input here — it is a stored XSS vector.\n innerHTML = rawHtml;\n } else if (typeof props.children === \"string\") {\n innerHTML = escapeHTML(props.children);\n } else if (Array.isArray(props.children)) {\n innerHTML = escapeHTML(props.children.join(\"\"));\n }\n\n for (const [key, value] of Object.entries(props)) {\n if (key === \"children\" || key === \"dangerouslySetInnerHTML\") {\n continue;\n } else if (key === \"className\") {\n attrs.push(`class=\"${escapeAttr(String(value))}\"`);\n } else if (typeof value === \"string\") {\n if (!isSafeAttrName(key)) continue;\n attrs.push(`${jsxAttrToHtml(key)}=\"${escapeAttr(value)}\"`);\n } else if (typeof value === \"boolean\" && value) {\n if (!isSafeAttrName(key)) continue;\n attrs.push(jsxAttrToHtml(key));\n }\n }\n\n const attrStr = attrs.length ? \" \" + attrs.join(\" \") : \"\";\n\n if (SELF_CLOSING_HEAD_TAGS.has(tag)) {\n return `<${tag}${attrStr} data-next-head=\"\" />`;\n }\n\n // For raw-content tags (script, style), escape closing-tag sequences so the\n // HTML parser doesn't prematurely terminate the element.\n if (RAW_CONTENT_TAGS.has(tag) && innerHTML) {\n innerHTML = escapeInlineContent(innerHTML, tag);\n }\n\n return `<${tag}${attrStr} data-next-head=\"\">${innerHTML}</${tag}>`;\n}\n\nfunction escapeHTML(s: string): string {\n return s.replace(/&/g, \"&amp;\").replace(/</g, \"&lt;\").replace(/>/g, \"&gt;\");\n}\n\nexport function escapeAttr(s: string): string {\n return s\n .replace(/&/g, \"&amp;\")\n .replace(/\"/g, \"&quot;\")\n .replace(/</g, \"&lt;\")\n .replace(/>/g, \"&gt;\");\n}\n\n/**\n * Escape content that will be placed inside a raw <script> or <style> tag\n * during SSR. The HTML parser treats `</script>` (or `</style>`) as the end\n * of the block regardless of JavaScript string context, so any occurrence\n * of `</` followed by the tag name must be escaped.\n *\n * We replace `</script` and `</style` (case-insensitive) with `<\\/script`\n * and `<\\/style` respectively. The `<\\/` form is harmless in JS/CSS string\n * context but prevents the HTML parser from seeing a closing tag.\n */\nexport function escapeInlineContent(content: string, tag: string): string {\n // Build a pattern like `<\\/script` or `<\\/style`, case-insensitive.\n // `tag` is always a literal developer-controlled value (\"script\" or \"style\")\n // guarded by the RAW_CONTENT_TAGS.has(tag) check at all call sites — never user input.\n const pattern = new RegExp(`<\\\\/(${tag})`, \"gi\");\n return content.replace(pattern, \"<\\\\/$1\");\n}\n\nfunction getDangerouslySetInnerHTML(value: unknown): string | undefined {\n if (typeof value !== \"object\" || value === null) return undefined;\n\n const html = Reflect.get(value, \"__html\");\n return typeof html === \"string\" ? html : undefined;\n}\n\nexport function _applyHeadPropsToElement(\n domEl: HeadDOMElement,\n props: Record<string, unknown>,\n): void {\n const rawHtml = getDangerouslySetInnerHTML(props.dangerouslySetInnerHTML);\n\n if (rawHtml != null) {\n domEl.innerHTML = rawHtml;\n } else if (typeof props.children === \"string\") {\n domEl.textContent = props.children;\n } else if (Array.isArray(props.children)) {\n domEl.textContent = props.children.join(\"\");\n }\n\n for (const [key, value] of Object.entries(props)) {\n if (key === \"children\" || key === \"dangerouslySetInnerHTML\") {\n continue;\n } else if (key === \"className\") {\n domEl.setAttribute(\"class\", String(value));\n } else if (typeof value === \"boolean\" && value) {\n if (!isSafeAttrName(key)) continue;\n // Map JSX attribute names (charSet, httpEquiv, ...) to the HTML form\n // (charset, http-equiv, ...) so the client-side mutation matches the\n // SSR output. `setAttribute` is case-insensitive for HTML elements, so\n // `charSet` would land as `charset` by coincidence, but `httpEquiv`\n // would lowercase to `httpequiv` rather than `http-equiv` and produce\n // a hydration mismatch. The shared mapping in jsxAttrToHtml keeps both\n // paths in lockstep.\n domEl.setAttribute(jsxAttrToHtml(key), \"\");\n } else if (typeof value === \"string\") {\n if (!isSafeAttrName(key)) continue;\n domEl.setAttribute(jsxAttrToHtml(key), value);\n }\n }\n}\n\n/**\n * Reconcile the document <head> against the desired projection.\n *\n * Mirrors Next.js's client `head-manager.ts` `updateElements()`: rather than\n * wiping every [data-next-head] node and re-appending (which reorders the\n * SSR-emitted tags to the end of <head> and causes flicker on each update),\n * we diff the desired tags against the existing ones with isEqualNode(). Tags\n * that already match are left untouched in their original DOM position, only\n * genuinely new tags are inserted, and stale tags are removed.\n *\n * The desired list seeds defaultHead() (charset + viewport) ahead of user\n * tags — matching the SSR path in getSSRHeadHTML() and Next.js's\n * reduceComponents(), which always concatenates defaultHead() on both server\n * and client. Without it the first <Head> mount after hydration would drop the\n * server-rendered defaults. Users can still override via key=\"charset\" /\n * key=\"viewport\" through the dedupe pipeline.\n *\n * @internal — exported for unit tests; called from the Head client effect.\n */\nexport function _syncClientHead(): void {\n const headEl = document.head;\n if (!headEl) return;\n\n // Existing vinext-managed tags. Also fold in any <meta charset> even if it\n // somehow lost the marker, so we never end up with a duplicate charset.\n const oldTags = new Set<Element>(headEl.querySelectorAll(\"[data-next-head]\"));\n const charsetEl = headEl.querySelector(\"meta[charset]\");\n if (charsetEl) oldTags.add(charsetEl);\n\n const newTags: Element[] = [];\n for (const child of reduceHeadChildren([...defaultHead(), ..._clientHeadChildren.values()])) {\n if (typeof child.type !== \"string\") continue;\n\n const domEl = document.createElement(child.type);\n _applyHeadPropsToElement(domEl, child.props as Record<string, unknown>);\n domEl.setAttribute(\"data-next-head\", \"\");\n\n // Reuse an identical node already in <head> so its DOM position (and thus\n // the head ordering produced by SSR) is preserved.\n //\n // Note: Next.js routes <title> through document.title rather than\n // updateElements(), so a title node never moves. We reconcile <title> like\n // any other tag — on hydration with an unchanged title it is reused in\n // place via isEqualNode (the common case), and only on a client-side title\n // *change* does the old node get removed and the new one appended. The\n // position of <title> in <head> is not observable, so this is cosmetic.\n let isNew = true;\n for (const oldTag of oldTags) {\n if (oldTag.isEqualNode(domEl)) {\n oldTags.delete(oldTag);\n isNew = false;\n break;\n }\n }\n if (isNew) newTags.push(domEl);\n }\n\n // Remove tags that are no longer desired.\n for (const oldTag of oldTags) {\n oldTag.parentNode?.removeChild(oldTag);\n }\n\n // Insert genuinely new tags. Keep <meta charset> first in <head> so the\n // declared encoding stays at the top.\n //\n // This deliberately diverges from Next.js's literal head-manager.ts, which\n // does `if (charset) headEl.prepend(newTag)` with NO `else` and then\n // unconditionally `headEl.appendChild(newTag)` — moving a newly-created\n // charset node twice and landing it last. We use a proper if/else so a new\n // charset is prepended and only prepended. Don't \"fix\" this back to match\n // Next.js's sequence. (This branch only runs on client-only navigation; on\n // SSR hydration the charset is reused in place via isEqualNode above.)\n for (const newTag of newTags) {\n if (newTag.tagName.toLowerCase() === \"meta\" && newTag.getAttribute(\"charset\") !== null) {\n headEl.prepend(newTag);\n } else {\n headEl.appendChild(newTag);\n }\n }\n}\n\n// --- Component ---\n\nfunction Head({ children }: HeadProps): null {\n const headInstanceIdRef = useRef<symbol | null>(null);\n if (headInstanceIdRef.current === null) {\n headInstanceIdRef.current = Symbol(\"vinext-head\");\n }\n\n // SSR path: collect elements for later injection\n if (typeof window === \"undefined\") {\n _getSSRHeadChildren().push(children);\n return null;\n }\n\n // Client path: update the shared head projection after hydration.\n // oxlint-disable-next-line react-hooks/rules-of-hooks\n useEffect(() => {\n const instanceId = headInstanceIdRef.current!;\n _clientHeadChildren.set(instanceId, children);\n _syncClientHead();\n\n return () => {\n _clientHeadChildren.delete(instanceId);\n _syncClientHead();\n };\n }, [children]);\n\n return null;\n}\n\nexport default Head;\n"],"mappings":"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"}
@@ -166,6 +166,13 @@ type DraftModeResult = {
166
166
  * - `isEnabled`: true if the bypass cookie is present in the request
167
167
  * - `enable()`: sets the bypass cookie (for Route Handlers)
168
168
  * - `disable()`: clears the bypass cookie
169
+ *
170
+ * Unlike `headers()` / `cookies()`, calling `draftMode()` itself is allowed
171
+ * inside `"use cache"` and `unstable_cache()` scopes — reads of `isEnabled`
172
+ * are non-dynamic and supported in cached functions. Only the mutating
173
+ * `enable()` / `disable()` methods throw when invoked inside a cache scope.
174
+ * Ported from Next.js: packages/next/src/server/request/draft-mode.ts
175
+ * (`getDraftModeProviderForCacheScope` + `trackDynamicDraftMode`).
169
176
  */
170
177
  declare function draftMode(): Promise<DraftModeResult>;
171
178
  declare class RequestCookies {
@@ -545,10 +545,16 @@ function requireActiveDraftModeContext(state, expectedContext, expression) {
545
545
  * - `isEnabled`: true if the bypass cookie is present in the request
546
546
  * - `enable()`: sets the bypass cookie (for Route Handlers)
547
547
  * - `disable()`: clears the bypass cookie
548
+ *
549
+ * Unlike `headers()` / `cookies()`, calling `draftMode()` itself is allowed
550
+ * inside `"use cache"` and `unstable_cache()` scopes — reads of `isEnabled`
551
+ * are non-dynamic and supported in cached functions. Only the mutating
552
+ * `enable()` / `disable()` methods throw when invoked inside a cache scope.
553
+ * Ported from Next.js: packages/next/src/server/request/draft-mode.ts
554
+ * (`getDraftModeProviderForCacheScope` + `trackDynamicDraftMode`).
548
555
  */
549
556
  async function draftMode() {
550
557
  markRenderRequestApiUsage("draftMode");
551
- throwIfInsideCacheScope("draftMode()");
552
558
  const state = _getState();
553
559
  const context = state.headersContext;
554
560
  if (!context) throw createDraftModeScopeError("draftMode()");
@@ -559,12 +565,14 @@ async function draftMode() {
559
565
  return context.cookies.get(DRAFT_MODE_COOKIE) === secret;
560
566
  },
561
567
  enable() {
568
+ throwIfInsideCacheScope("draftMode().enable()");
562
569
  const activeContext = requireActiveDraftModeContext(state, context, "draftMode().enable()");
563
570
  markDynamicUsage();
564
571
  activeContext.cookies.set(DRAFT_MODE_COOKIE, secret);
565
572
  state.draftModeCookieHeader = `${DRAFT_MODE_COOKIE}=${secret}; ${draftModeCookieAttributes()}`;
566
573
  },
567
574
  disable() {
575
+ throwIfInsideCacheScope("draftMode().disable()");
568
576
  const activeContext = requireActiveDraftModeContext(state, context, "draftMode().disable()");
569
577
  markDynamicUsage();
570
578
  activeContext.cookies.delete(DRAFT_MODE_COOKIE);
@@ -1 +1 @@
1
- {"version":3,"file":"headers.js","names":[],"sources":["../../src/shims/headers.ts"],"sourcesContent":["/**\n * next/headers shim\n *\n * Provides cookies() and headers() functions for App Router Server Components.\n * These read from a request context set by the RSC handler before rendering.\n *\n * In Next.js 15+, cookies() and headers() return Promises (async).\n * We support both the sync (legacy) and async patterns.\n */\n\nimport { MIDDLEWARE_SET_COOKIE_HEADER } from \"../server/headers.js\";\nimport { buildRequestHeadersFromMiddlewareResponse } from \"../server/middleware-request-headers.js\";\nimport { getOrCreateAls } from \"./internal/als-registry.js\";\nimport {\n serializeSetCookie,\n validateCookieAttributeValue,\n validateCookieName,\n} from \"./internal/cookie-serialize.js\";\nimport { parseCookieHeader } from \"./internal/parse-cookie-header.js\";\nimport {\n isInsideUnifiedScope,\n getRequestContext,\n runWithUnifiedStateMutation,\n} from \"./unified-request-context.js\";\nimport type { RenderRequestApiKind } from \"../server/cache-proof.js\";\n\n// ---------------------------------------------------------------------------\n// Request context\n// ---------------------------------------------------------------------------\n\nexport type HeadersContext = {\n headers: Headers;\n cookies: Map<string, string>;\n accessError?: Error;\n forceStatic?: boolean;\n mutableCookies?: RequestCookies;\n readonlyCookies?: RequestCookies;\n readonlyHeaders?: Headers;\n draftModeSecret?: string;\n};\n\ntype HeadersContextFromRequestOptions = {\n draftModeSecret?: string;\n};\n\nexport type HeadersAccessPhase = \"render\" | \"action\" | \"route-handler\";\n\nexport type VinextHeadersShimState = {\n headersContext: HeadersContext | null;\n dynamicUsageDetected: boolean;\n renderRequestApiUsage: Set<RenderRequestApiKind>;\n /** Error recorded by throwIfInsideCacheScope for dev diagnostics, persists even if caught by user code. */\n invalidDynamicUsageError: unknown;\n pendingSetCookies: string[];\n draftModeCookieHeader: string | null;\n phase: HeadersAccessPhase;\n};\n\n// NOTE:\n// - This shim can be loaded under multiple module specifiers in Vite's\n// multi-environment setup (RSC/SSR). Store the AsyncLocalStorage on\n// globalThis so `connection()` (next/server) and `consumeDynamicUsage()`\n// (next/headers) always share it.\n// - We use AsyncLocalStorage so concurrent requests don't stomp each other's\n// headers/cookies/dynamic-usage state.\nconst _FALLBACK_KEY = Symbol.for(\"vinext.nextHeadersShim.fallback\");\nconst _g = globalThis as unknown as Record<PropertyKey, unknown>;\nconst _als = getOrCreateAls<VinextHeadersShimState>(\"vinext.nextHeadersShim.als\");\n\nconst _fallbackState = (_g[_FALLBACK_KEY] ??= {\n headersContext: null,\n dynamicUsageDetected: false,\n renderRequestApiUsage: new Set<RenderRequestApiKind>(),\n invalidDynamicUsageError: null,\n pendingSetCookies: [],\n draftModeCookieHeader: null,\n phase: \"render\",\n} satisfies VinextHeadersShimState) as VinextHeadersShimState;\nconst EXPIRED_COOKIE_DATE = new Date(0).toUTCString();\n\nfunction splitMiddlewareSetCookieHeader(value: string): string[] {\n const cookies: string[] = [];\n let start = 0;\n let inExpires = false;\n let expiresCommaSeen = false;\n\n for (let i = 0; i < value.length; i++) {\n if (value.slice(i, i + 8).toLowerCase() === \"expires=\") {\n inExpires = true;\n expiresCommaSeen = false;\n i += 7;\n continue;\n }\n\n const ch = value[i];\n if (inExpires && ch === \";\") {\n inExpires = false;\n expiresCommaSeen = false;\n continue;\n }\n\n if (ch !== \",\") continue;\n if (inExpires && !expiresCommaSeen) {\n expiresCommaSeen = true;\n continue;\n }\n\n const cookie = value.slice(start, i).trim();\n if (cookie) cookies.push(cookie);\n start = i + 1;\n inExpires = false;\n expiresCommaSeen = false;\n }\n\n const cookie = value.slice(start).trim();\n if (cookie) cookies.push(cookie);\n return cookies;\n}\n\nfunction setCookieNameValue(setCookie: string): { name: string; value: string } | null {\n const equalsIndex = setCookie.indexOf(\"=\");\n if (equalsIndex <= 0) return null;\n\n const name = setCookie.slice(0, equalsIndex).trim();\n const valueEnd = setCookie.indexOf(\";\", equalsIndex + 1);\n const encodedValue = setCookie.slice(equalsIndex + 1, valueEnd === -1 ? undefined : valueEnd);\n let value: string;\n try {\n value = decodeURIComponent(encodedValue);\n } catch {\n value = encodedValue;\n }\n\n return { name, value };\n}\n\nfunction rebuildCookiesFromHeader(ctx: HeadersContext, cookieHeader: string | null): void {\n ctx.cookies.clear();\n if (cookieHeader === null) return;\n\n const nextCookies = parseCookieHeader(cookieHeader);\n for (const [name, value] of nextCookies) {\n ctx.cookies.set(name, value);\n }\n}\n\nfunction mergeMiddlewareSetCookies(ctx: HeadersContext, rawHeader: string | null): boolean {\n if (rawHeader === null) return false;\n\n let merged = false;\n for (const setCookie of splitMiddlewareSetCookieHeader(rawHeader)) {\n const entry = setCookieNameValue(setCookie);\n if (!entry) continue;\n ctx.cookies.set(entry.name, entry.value);\n merged = true;\n }\n\n return merged;\n}\n\nfunction _getState(): VinextHeadersShimState {\n if (isInsideUnifiedScope()) {\n return getRequestContext();\n }\n return _als.getStore() ?? _fallbackState;\n}\n\n/**\n * Dynamic usage flag — set when a component calls connection(), cookies(),\n * headers(), or noStore() during rendering. When true, ISR caching is\n * bypassed and the response gets Cache-Control: no-store.\n */\n// (stored on _state)\n\n/**\n * Mark the current render as requiring dynamic (uncached) rendering.\n * Called by connection(), cookies(), headers(), and noStore().\n */\nexport function markDynamicUsage(): void {\n const state = _getState();\n if (state.headersContext?.forceStatic) {\n return;\n }\n state.dynamicUsageDetected = true;\n}\n\nexport function markRenderRequestApiUsage(kind: RenderRequestApiKind): void {\n _getState().renderRequestApiUsage.add(kind);\n}\n\nexport function peekRenderRequestApiUsage(): RenderRequestApiKind[] {\n return [..._getState().renderRequestApiUsage].sort();\n}\n\nexport function consumeRenderRequestApiUsage(): RenderRequestApiKind[] {\n const state = _getState();\n const observed = [...state.renderRequestApiUsage].sort();\n state.renderRequestApiUsage = new Set<RenderRequestApiKind>();\n return observed;\n}\n\n// ---------------------------------------------------------------------------\n// Cache scope detection — checks whether we're inside \"use cache\" or\n// unstable_cache() by reading ALS instances stored on globalThis via Symbols.\n// This avoids circular imports between headers.ts, cache.ts, and cache-runtime.ts.\n// The ALS instances are registered by cache-runtime.ts and cache.ts respectively.\n// ---------------------------------------------------------------------------\n\n/** Symbol used by cache-runtime.ts to store the \"use cache\" ALS on globalThis */\nconst _USE_CACHE_ALS_KEY = Symbol.for(\"vinext.cacheRuntime.contextAls\");\n/** Symbol used by cache.ts to store the unstable_cache ALS on globalThis */\nconst _UNSTABLE_CACHE_ALS_KEY = Symbol.for(\"vinext.unstableCache.als\");\n\ntype UseCacheGuardContext = {\n variant?: unknown;\n};\n\ntype CacheScopeStorage = {\n getStore: () => unknown;\n};\n\nfunction _getGlobalCacheScopeStorage(key: symbol): CacheScopeStorage | null {\n const value = Reflect.get(globalThis, key);\n if (!value || typeof value !== \"object\") return null;\n\n const getStore = Reflect.get(value, \"getStore\");\n if (typeof getStore !== \"function\") return null;\n\n return {\n getStore: () => getStore.call(value),\n };\n}\n\nfunction _getUseCacheGuardContext(): UseCacheGuardContext | null {\n const store = _getGlobalCacheScopeStorage(_USE_CACHE_ALS_KEY)?.getStore();\n if (!store || typeof store !== \"object\") return null;\n return store;\n}\n\nfunction _isInsidePublicUseCache(): boolean {\n const ctx = _getUseCacheGuardContext();\n // Next.js models \"use cache: private\" as a private-cache work unit that\n // carries request headers and cookies. Only public \"use cache\" scopes freeze\n // request APIs into persisted cache entries and must reject these reads.\n // https://github.com/vercel/next.js/blob/canary/packages/next/src/server/app-render/work-unit-async-storage.external.ts\n return ctx !== null && ctx.variant !== \"private\";\n}\n\nfunction _isInsideUnstableCache(): boolean {\n return _getGlobalCacheScopeStorage(_UNSTABLE_CACHE_ALS_KEY)?.getStore() === true;\n}\n\n/**\n * Throw if the current execution is inside a \"use cache\" or unstable_cache()\n * scope. Called by dynamic request APIs (headers, cookies, connection) to\n * prevent request-specific data from being frozen into cached results.\n *\n * @param apiName - The name of the API being called (e.g. \"connection()\")\n */\nexport function throwIfInsideCacheScope(apiName: string): void {\n if (_isInsidePublicUseCache()) {\n const error = new Error(\n `\\`${apiName}\\` cannot be called inside \"use cache\". ` +\n `If you need this data inside a cached function, call \\`${apiName}\\` ` +\n \"outside and pass the required data as an argument.\",\n );\n // Record the error on the request context so it survives user try/catch\n // and can be forwarded to the dev overlay on client-side navigations.\n // Ported from Next.js: workStore.invalidDynamicUsageError assignment in\n // packages/next/src/server/app-render/app-render.tsx\n // https://github.com/vercel/next.js/commit/f5e54c06726b571a042fce67417e40a29f6b8689\n try {\n const ctx = getRequestContext();\n if (ctx) ctx.invalidDynamicUsageError = error;\n } catch {\n // Ignore — best-effort recording for dev diagnostics\n }\n throw error;\n }\n if (_isInsideUnstableCache()) {\n const error = new Error(\n `\\`${apiName}\\` cannot be called inside a function cached with \\`unstable_cache()\\`. ` +\n `If you need this data inside a cached function, call \\`${apiName}\\` ` +\n \"outside and pass the required data as an argument.\",\n );\n try {\n const ctx = getRequestContext();\n if (ctx) ctx.invalidDynamicUsageError = error;\n } catch {\n // Ignore\n }\n throw error;\n }\n}\n\n/**\n * Check, consume, and return any invalid dynamic usage error recorded during\n * the render (e.g. cookies() called inside \"use cache\"). This error persists\n * even if the throw was caught by user-code try/catch, so it can surface on\n * client-side navigations where the static shell validation is skipped.\n * Ported from Next.js: workStore.invalidDynamicUsageError in\n * packages/next/src/server/app-render/app-render.tsx\n * https://github.com/vercel/next.js/commit/f5e54c06726b571a042fce67417e40a29f6b8689\n */\nexport function consumeInvalidDynamicUsageError(): unknown {\n const state = _getState();\n const err = state.invalidDynamicUsageError;\n state.invalidDynamicUsageError = null;\n return err;\n}\n\n/**\n * Check and reset the dynamic usage flag.\n * Called by the server after rendering to decide on caching.\n */\nexport function consumeDynamicUsage(): boolean {\n const state = _getState();\n const used = state.dynamicUsageDetected;\n state.dynamicUsageDetected = false;\n return used;\n}\n\nfunction _setStatePhase(\n state: VinextHeadersShimState,\n phase: HeadersAccessPhase,\n): HeadersAccessPhase {\n const previous = state.phase;\n state.phase = phase;\n return previous;\n}\n\nfunction _areCookiesMutableInCurrentPhase(): boolean {\n const phase = _getState().phase;\n return phase === \"action\" || phase === \"route-handler\";\n}\n\nexport function setHeadersAccessPhase(phase: HeadersAccessPhase): HeadersAccessPhase {\n return _setStatePhase(_getState(), phase);\n}\n\nexport function getHeadersAccessPhase(): HeadersAccessPhase {\n return _getState().phase;\n}\n\n/**\n * Set the headers/cookies context for the current RSC render.\n * Called by the framework's RSC entry before rendering each request.\n *\n * @deprecated Prefer runWithHeadersContext() which uses als.run() for\n * proper per-request isolation. This function mutates the ALS store\n * in-place and is only safe for cleanup (ctx=null) within an existing\n * als.run() scope.\n */\n/**\n * Returns the current live HeadersContext from ALS (or the fallback).\n * Used after applyMiddlewareRequestHeaders() to build a post-middleware\n * request context for afterFiles/fallback rewrite has/missing evaluation.\n */\nexport function getHeadersContext(): HeadersContext | null {\n return _getState().headersContext;\n}\n\nexport function setHeadersContext(ctx: HeadersContext | null): void {\n const state = _getState();\n if (ctx !== null) {\n state.headersContext = ctx;\n state.dynamicUsageDetected = false;\n state.renderRequestApiUsage = new Set();\n state.pendingSetCookies = [];\n state.draftModeCookieHeader = null;\n state.phase = \"render\";\n } else {\n state.headersContext = null;\n state.phase = \"render\";\n }\n}\n\n/**\n * Run a function with headers context, ensuring the context propagates\n * through all async operations (including RSC streaming).\n *\n * Uses AsyncLocalStorage.run() to guarantee per-request isolation.\n * The ALS store propagates through all async continuations including\n * ReadableStream consumption, setTimeout callbacks, and Promise chains,\n * so RSC streaming works correctly — components that render when the\n * stream is consumed still see the correct request's context.\n */\nexport function runWithHeadersContext<T>(ctx: HeadersContext, fn: () => Promise<T>): Promise<T>;\nexport function runWithHeadersContext<T>(\n ctx: HeadersContext,\n fn: () => T | Promise<T>,\n): T | Promise<T>;\nexport function runWithHeadersContext<T>(\n ctx: HeadersContext,\n fn: () => T | Promise<T>,\n): T | Promise<T> {\n if (isInsideUnifiedScope()) {\n return runWithUnifiedStateMutation((uCtx) => {\n uCtx.headersContext = ctx;\n uCtx.dynamicUsageDetected = false;\n uCtx.renderRequestApiUsage = new Set();\n uCtx.pendingSetCookies = [];\n uCtx.draftModeCookieHeader = null;\n uCtx.phase = \"render\";\n }, fn);\n }\n\n const state: VinextHeadersShimState = {\n headersContext: ctx,\n dynamicUsageDetected: false,\n renderRequestApiUsage: new Set(),\n invalidDynamicUsageError: null,\n pendingSetCookies: [],\n draftModeCookieHeader: null,\n phase: \"render\",\n };\n\n return _als.run(state, fn);\n}\n\n/**\n * Apply middleware-forwarded request headers to the current headers context.\n *\n * When Next.js middleware calls `NextResponse.next()` or `NextResponse.rewrite()`\n * with `{ request: { headers } }`, the modified headers are encoded on the\n * middleware response. This function decodes that protocol and applies the\n * resulting request header set to the live `HeadersContext`. When an override\n * list is present, omitted headers are deleted as part of the rebuild.\n *\n * Cached `readonlyHeaders` and `readonlyCookies` snapshots on the\n * HeadersContext must be invalidated whenever this function rebuilds the\n * underlying `headers`/`cookies`. Otherwise a middleware that reads\n * `headers()` (or `cookies()`) before returning a request-header override —\n * for example `@clerk/nextjs`, whose `clerkClient()` reads `headers()` via\n * `buildRequestLike()` during middleware execution — primes a sealed snapshot\n * built from the *pre*-override request, and any subsequent `headers()` call\n * from a Server Component would return that stale snapshot instead of the\n * middleware-modified view.\n */\nexport function applyMiddlewareRequestHeaders(middlewareResponseHeaders: Headers): void {\n const state = _getState();\n if (!state.headersContext) return;\n\n const ctx = state.headersContext;\n const previousCookieHeader = ctx.headers.get(\"cookie\");\n const middlewareSetCookieHeader = middlewareResponseHeaders.get(MIDDLEWARE_SET_COOKIE_HEADER);\n const nextHeaders = buildRequestHeadersFromMiddlewareResponse(\n ctx.headers,\n middlewareResponseHeaders,\n );\n\n if (!nextHeaders && middlewareSetCookieHeader === null) return;\n\n if (nextHeaders) {\n ctx.headers = nextHeaders;\n // Invalidate any sealed snapshot of the pre-override headers. A middleware\n // that read `headers()` before returning the override (e.g. clerkMiddleware)\n // would otherwise leak the pre-override view into the Server Component.\n ctx.readonlyHeaders = undefined;\n const nextCookieHeader = nextHeaders.get(\"cookie\");\n if (previousCookieHeader !== nextCookieHeader) {\n rebuildCookiesFromHeader(ctx, nextCookieHeader);\n ctx.readonlyCookies = undefined;\n ctx.mutableCookies = undefined;\n }\n }\n\n if (mergeMiddlewareSetCookies(ctx, middlewareSetCookieHeader)) {\n ctx.readonlyCookies = undefined;\n ctx.mutableCookies = undefined;\n }\n}\n\n/** Methods on `Headers` that mutate state. Hoisted to module scope — static. */\nconst _HEADERS_MUTATING_METHODS = new Set([\"set\", \"delete\", \"append\"]);\n\nclass 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 static callable(): never {\n throw new ReadonlyHeadersError();\n }\n}\n\n// Keep this error message in sync with server.ts. The two RequestCookies\n// adapters are separate until the next/headers and NextRequest cookie paths\n// share one implementation.\nclass ReadonlyRequestCookiesError extends Error {\n constructor() {\n super(\n \"Cookies can only be modified in a Server Action or Route Handler. Read more: https://nextjs.org/docs/app/api-reference/functions/cookies#options\",\n );\n }\n\n static callable(): never {\n throw new ReadonlyRequestCookiesError();\n }\n}\n\nfunction _decorateRequestApiPromise<T extends object>(\n promise: Promise<T>,\n target: T,\n): Promise<T> & T {\n return new Proxy(promise as Promise<T> & T, {\n get(promiseTarget, prop) {\n if (prop in promiseTarget) {\n const value = Reflect.get(promiseTarget, prop, promiseTarget);\n return typeof value === \"function\" ? value.bind(promiseTarget) : value;\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n has(promiseTarget, prop) {\n return prop in promiseTarget || prop in target;\n },\n ownKeys(promiseTarget) {\n return Array.from(new Set([...Reflect.ownKeys(promiseTarget), ...Reflect.ownKeys(target)]));\n },\n getOwnPropertyDescriptor(promiseTarget, prop) {\n return (\n Reflect.getOwnPropertyDescriptor(promiseTarget, prop) ??\n Reflect.getOwnPropertyDescriptor(target, prop)\n );\n },\n });\n}\n\n// React.use() tracks thenables by identity, so request APIs must reuse the\n// same decorated promise for the same underlying request view.\nconst _decoratedHeadersPromises = new WeakMap<Headers, Promise<Headers> & Headers>();\nconst _decoratedCookiesPromises = new WeakMap<\n RequestCookies,\n Promise<RequestCookies> & RequestCookies\n>();\n\nfunction _getOrCreateDecoratedRequestApiPromise<T extends object>(\n cache: WeakMap<T, Promise<T> & T>,\n target: T,\n): Promise<T> & T {\n const cached = cache.get(target);\n if (cached) return cached;\n\n const promise = _decorateRequestApiPromise(Promise.resolve(target), target);\n cache.set(target, promise);\n return promise;\n}\n\nfunction _decorateRejectedRequestApiPromise<T extends object>(error: unknown): Promise<T> & T {\n const normalizedError = error instanceof Error ? error : new Error(String(error));\n const promise = Promise.reject(normalizedError) as Promise<T>;\n // Mark the rejection as handled so legacy sync access does not trigger\n // spurious unhandled rejection noise before callers await/catch it.\n promise.catch(() => {});\n\n const throwingTarget = new Proxy({} as T, {\n get(_target, prop) {\n if (prop === \"then\" || prop === \"catch\" || prop === \"finally\") {\n return undefined;\n }\n throw normalizedError;\n },\n });\n\n return _decorateRequestApiPromise(promise, throwingTarget);\n}\n\nfunction _sealHeaders(headers: Headers): Headers {\n return new Proxy(headers, {\n get(target, prop) {\n if (typeof prop === \"string\" && _HEADERS_MUTATING_METHODS.has(prop)) {\n throw new ReadonlyHeadersError();\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n }) as Headers;\n}\n\nfunction _wrapMutableCookies(cookies: RequestCookies): RequestCookies {\n return new Proxy(cookies, {\n get(target, prop) {\n if (prop === \"set\" || prop === \"delete\") {\n return (...args: unknown[]) => {\n if (!_areCookiesMutableInCurrentPhase()) {\n throw new ReadonlyRequestCookiesError();\n }\n\n return (Reflect.get(target, prop, target) as (...callArgs: unknown[]) => unknown).apply(\n target,\n args,\n );\n };\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n }) as RequestCookies;\n}\n\nfunction _sealCookies(cookies: RequestCookies): RequestCookies {\n return new Proxy(cookies, {\n get(target, prop) {\n if (prop === \"set\" || prop === \"delete\") {\n throw new ReadonlyRequestCookiesError();\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n }) as RequestCookies;\n}\n\nfunction _getMutableCookies(ctx: HeadersContext): RequestCookies {\n if (!ctx.mutableCookies) {\n ctx.mutableCookies = _wrapMutableCookies(new RequestCookies(ctx.cookies));\n }\n\n return ctx.mutableCookies;\n}\n\nfunction _getReadonlyCookies(ctx: HeadersContext): RequestCookies {\n if (!ctx.readonlyCookies) {\n // Keep a separate readonly wrapper so render-path reads avoid the\n // mutable phase-checking proxy while still reflecting the shared cookie map.\n ctx.readonlyCookies = _sealCookies(new RequestCookies(ctx.cookies));\n }\n\n return ctx.readonlyCookies;\n}\n\nfunction _getReadonlyHeaders(ctx: HeadersContext): Headers {\n if (!ctx.readonlyHeaders) {\n ctx.readonlyHeaders = _sealHeaders(ctx.headers);\n }\n\n return ctx.readonlyHeaders;\n}\n\n/**\n * Create a HeadersContext from a standard Request object.\n *\n * Performance note: In Workerd (Cloudflare Workers), `new Headers(request.headers)`\n * copies the entire header map across the V8/C++ boundary, which shows up as\n * ~815 ms self-time in production profiles when requests carry many headers.\n * We defer this copy with a lazy proxy:\n *\n * - Reads (`get`, `has`, `entries`, …) are forwarded directly to the original\n * immutable `request.headers` — zero copy cost on the hot path.\n * - The first mutating call (`set`, `delete`, `append`) materialises\n * `new Headers(request.headers)` once, then applies the mutation to the copy.\n * All subsequent operations go to the copy.\n *\n * This means the ~815 ms copy only occurs when middleware actually rewrites\n * request headers via `NextResponse.next({ request: { headers } })`, which is\n * uncommon. Pure read requests (the vast majority) pay zero copy cost.\n *\n * Cookie parsing is also deferred: the `cookie` header string is not split\n * until the first call to `cookies()` or `draftMode()`.\n */\nexport function headersContextFromRequest(\n request: Request,\n options?: HeadersContextFromRequestOptions,\n): HeadersContext {\n // ---------------------------------------------------------------------------\n // Lazy mutable Headers proxy\n // ---------------------------------------------------------------------------\n // `_mutable` holds the materialised copy once a write is needed.\n let _mutable: Headers | null = null;\n\n const headersProxy = new Proxy(request.headers, {\n get(target, prop: string | symbol) {\n // Route to the materialised copy if it exists.\n const src = _mutable ?? target;\n\n // Intercept mutating methods: materialise on first write.\n if (typeof prop === \"string\" && _HEADERS_MUTATING_METHODS.has(prop)) {\n return (...args: unknown[]) => {\n if (!_mutable) {\n _mutable = new Headers(target);\n }\n return (_mutable[prop as \"set\" | \"delete\" | \"append\"] as (...a: unknown[]) => unknown)(\n ...args,\n );\n };\n }\n\n // Non-mutating method or property: bind to current source.\n const value = Reflect.get(src, prop, src);\n return typeof value === \"function\" ? value.bind(src) : value;\n },\n }) as Headers;\n\n // ---------------------------------------------------------------------------\n // Lazy cookie map\n // ---------------------------------------------------------------------------\n // Parsing cookies requires splitting on `;` and `=`, which is cheap but\n // still unnecessary overhead if `cookies()` is never called for this request.\n let _cookies: Map<string, string> | null = null;\n\n function getCookies(): Map<string, string> {\n if (_cookies) return _cookies;\n // Read from the proxy so middleware-modified cookie headers are respected.\n const cookieHeader = headersProxy.get(\"cookie\") || \"\";\n _cookies = parseCookieHeader(cookieHeader);\n return _cookies;\n }\n\n // Expose cookies as a lazy getter that memoises on first access.\n const ctx = {\n headers: headersProxy,\n get cookies(): Map<string, string> {\n return getCookies();\n },\n draftModeSecret: options?.draftModeSecret,\n } satisfies HeadersContext;\n\n return ctx;\n}\n\n// ---------------------------------------------------------------------------\n// Public API\n// ---------------------------------------------------------------------------\n\n/**\n * Read-only Headers instance from the incoming request.\n * Returns a Promise in Next.js 15+ style (but resolves synchronously since\n * the context is already available).\n */\nexport function headers(): Promise<Headers> & Headers {\n markRenderRequestApiUsage(\"headers\");\n try {\n throwIfInsideCacheScope(\"headers()\");\n } catch (error) {\n return _decorateRejectedRequestApiPromise<Headers>(error);\n }\n\n const state = _getState();\n if (!state.headersContext) {\n return _decorateRejectedRequestApiPromise<Headers>(\n new Error(\n \"headers() can only be called from a Server Component, Route Handler, \" +\n \"or Server Action. Make sure you're not calling it from a Client Component.\",\n ),\n );\n }\n\n if (state.headersContext.accessError) {\n return _decorateRejectedRequestApiPromise<Headers>(state.headersContext.accessError);\n }\n\n markDynamicUsage();\n const readonlyHeaders = _getReadonlyHeaders(state.headersContext);\n return _getOrCreateDecoratedRequestApiPromise(_decoratedHeadersPromises, readonlyHeaders);\n}\n\n/**\n * Cookie jar from the incoming request.\n * Returns a ReadonlyRequestCookies-like object.\n */\nexport function cookies(): Promise<RequestCookies> & RequestCookies {\n markRenderRequestApiUsage(\"cookies\");\n try {\n throwIfInsideCacheScope(\"cookies()\");\n } catch (error) {\n return _decorateRejectedRequestApiPromise<RequestCookies>(error);\n }\n\n const state = _getState();\n if (!state.headersContext) {\n return _decorateRejectedRequestApiPromise<RequestCookies>(\n new Error(\n \"cookies() can only be called from a Server Component, Route Handler, or Server Action.\",\n ),\n );\n }\n\n if (state.headersContext.accessError) {\n return _decorateRejectedRequestApiPromise<RequestCookies>(state.headersContext.accessError);\n }\n\n markDynamicUsage();\n const cookieStore = _areCookiesMutableInCurrentPhase()\n ? _getMutableCookies(state.headersContext)\n : _getReadonlyCookies(state.headersContext);\n\n return _getOrCreateDecoratedRequestApiPromise(_decoratedCookiesPromises, cookieStore);\n}\n\n// ---------------------------------------------------------------------------\n// Writable cookie accumulator for Route Handlers / Server Actions\n// ---------------------------------------------------------------------------\n\n/** Accumulated Set-Cookie headers from cookies().set() / .delete() calls */\n// (stored on _state)\n\n/**\n * Get and clear all pending Set-Cookie headers generated by cookies().set()/delete().\n * Called by the framework after rendering to attach headers to the response.\n */\nexport function getAndClearPendingCookies(): string[] {\n const state = _getState();\n const cookies = state.pendingSetCookies;\n state.pendingSetCookies = [];\n return cookies;\n}\n\n// Draft mode cookie name (matches Next.js convention)\nconst DRAFT_MODE_COOKIE = \"__prerender_bypass\";\nconst DRAFT_MODE_EXPIRED_DATE = new Date(0).toUTCString();\n\n// Store for Set-Cookie headers generated by draftMode().enable()/disable()\n// (stored on _state)\n\n/**\n * Get any Set-Cookie header generated by draftMode().enable()/disable().\n * Called by the framework after rendering to attach the header to the response.\n */\nexport function getDraftModeCookieHeader(): string | null {\n const state = _getState();\n const header = state.draftModeCookieHeader;\n state.draftModeCookieHeader = null;\n return header;\n}\n\nfunction validateDraftModeSecret(secret: string): string {\n if (secret.length === 0) {\n throw new Error(\"[vinext] draft mode secret must be a non-empty string.\");\n }\n return secret;\n}\n\nfunction createDraftModeSecret(): string {\n const crypto = globalThis.crypto;\n if (crypto && typeof crypto.randomUUID === \"function\") {\n return crypto.randomUUID();\n }\n\n throw new Error(\n \"[vinext] draft mode secret is not initialized. \" +\n \"This should be initialized by the server entry before handling requests.\",\n );\n}\n\nfunction ensureContextDraftModeSecret(ctx: HeadersContext): string {\n if (ctx.draftModeSecret !== undefined) {\n return validateDraftModeSecret(ctx.draftModeSecret);\n }\n\n const secret = createDraftModeSecret();\n ctx.draftModeSecret = secret;\n return secret;\n}\n\nexport function isDraftModeRequest(request: Request, draftModeSecret: string): boolean {\n const cookieHeader = request.headers.get(\"cookie\");\n if (!cookieHeader) return false;\n return (\n parseCookieHeader(cookieHeader).get(DRAFT_MODE_COOKIE) ===\n validateDraftModeSecret(draftModeSecret)\n );\n}\n\ntype DraftModeResult = {\n readonly isEnabled: boolean;\n enable(): void;\n disable(): void;\n};\n\nfunction draftModeCookieAttributes(): string {\n if (typeof process !== \"undefined\" && process.env?.NODE_ENV === \"development\") {\n return \"Path=/; HttpOnly; SameSite=Lax\";\n }\n return \"Path=/; HttpOnly; SameSite=None; Secure\";\n}\n\nfunction createDraftModeScopeError(expression: string): Error {\n return new Error(\n `${expression} can only be called from a Server Component, Route Handler, or Server Action.`,\n );\n}\n\nfunction requireActiveDraftModeContext(\n state: VinextHeadersShimState,\n expectedContext: HeadersContext,\n expression: string,\n): HeadersContext {\n const currentContext = state.headersContext;\n if (currentContext !== expectedContext) {\n throw createDraftModeScopeError(expression);\n }\n if (currentContext.accessError) {\n throw currentContext.accessError;\n }\n return currentContext;\n}\n\n/**\n * Draft mode — check/toggle via a `__prerender_bypass` cookie.\n *\n * - `isEnabled`: true if the bypass cookie is present in the request\n * - `enable()`: sets the bypass cookie (for Route Handlers)\n * - `disable()`: clears the bypass cookie\n */\nexport async function draftMode(): Promise<DraftModeResult> {\n markRenderRequestApiUsage(\"draftMode\");\n throwIfInsideCacheScope(\"draftMode()\");\n\n const state = _getState();\n const context = state.headersContext;\n if (!context) {\n throw createDraftModeScopeError(\"draftMode()\");\n }\n if (context.accessError) {\n throw context.accessError;\n }\n // Reading `draftMode()` itself is not dynamic — `isEnabled` is a plain\n // getter and merely calling `draftMode()` does not require bailing out\n // of static prerendering. Only `enable()`/`disable()` mutate state and\n // must be tracked as dynamic, mirroring Next.js's `trackDynamicDraftMode`\n // (see .nextjs-ref/packages/next/src/server/request/draft-mode.ts:152-165).\n const secret = ensureContextDraftModeSecret(context);\n\n return {\n get isEnabled(): boolean {\n return context.cookies.get(DRAFT_MODE_COOKIE) === secret;\n },\n enable(): void {\n const activeContext = requireActiveDraftModeContext(state, context, \"draftMode().enable()\");\n markDynamicUsage();\n activeContext.cookies.set(DRAFT_MODE_COOKIE, secret);\n state.draftModeCookieHeader = `${DRAFT_MODE_COOKIE}=${secret}; ${draftModeCookieAttributes()}`;\n },\n disable(): void {\n const activeContext = requireActiveDraftModeContext(state, context, \"draftMode().disable()\");\n markDynamicUsage();\n activeContext.cookies.delete(DRAFT_MODE_COOKIE);\n state.draftModeCookieHeader = `${DRAFT_MODE_COOKIE}=; ${draftModeCookieAttributes()}; Expires=${DRAFT_MODE_EXPIRED_DATE}`;\n },\n };\n}\n\n// ---------------------------------------------------------------------------\n// RequestCookies implementation\n// ---------------------------------------------------------------------------\n\nclass RequestCookies {\n private _cookies: Map<string, string>;\n\n constructor(cookies: Map<string, string>) {\n this._cookies = cookies;\n }\n\n get(name: string): { name: string; value: string } | undefined {\n const value = this._cookies.get(name);\n if (value === undefined) return undefined;\n return { name, value };\n }\n\n getAll(nameOrOptions?: string | { name: string }): Array<{ name: string; value: string }> {\n const name = typeof nameOrOptions === \"string\" ? nameOrOptions : nameOrOptions?.name;\n const result: Array<{ name: string; value: string }> = [];\n for (const [cookieName, value] of this._cookies) {\n if (name === undefined || cookieName === name) {\n result.push({ name: cookieName, value });\n }\n }\n return result;\n }\n\n has(name: string): boolean {\n return this._cookies.has(name);\n }\n\n /**\n * Set a cookie. In Route Handlers and Server Actions, this produces\n * a Set-Cookie header on the response.\n */\n set(\n nameOrOptions:\n | string\n | {\n name: string;\n value: string;\n path?: string;\n domain?: string;\n maxAge?: number;\n expires?: Date;\n httpOnly?: boolean;\n secure?: boolean;\n sameSite?: \"Strict\" | \"Lax\" | \"None\";\n },\n value?: string,\n options?: {\n path?: string;\n domain?: string;\n maxAge?: number;\n expires?: Date;\n httpOnly?: boolean;\n secure?: boolean;\n sameSite?: \"Strict\" | \"Lax\" | \"None\";\n },\n ): this {\n let cookieName: string;\n let cookieValue: string;\n let opts: typeof options;\n\n if (typeof nameOrOptions === \"string\") {\n cookieName = nameOrOptions;\n cookieValue = value ?? \"\";\n opts = options;\n } else {\n cookieName = nameOrOptions.name;\n cookieValue = nameOrOptions.value;\n opts = nameOrOptions;\n }\n\n validateCookieName(cookieName);\n\n // Update the local cookie map\n this._cookies.set(cookieName, cookieValue);\n\n _getState().pendingSetCookies.push(serializeSetCookie(cookieName, cookieValue, opts));\n return this;\n }\n\n /**\n * Delete a cookie by emitting an expired Set-Cookie header.\n */\n delete(nameOrOptions: string | { name: string; path?: string; domain?: string }): this {\n const name = typeof nameOrOptions === \"string\" ? nameOrOptions : nameOrOptions.name;\n const path = typeof nameOrOptions === \"string\" ? \"/\" : (nameOrOptions.path ?? \"/\");\n const domain = typeof nameOrOptions === \"string\" ? undefined : nameOrOptions.domain;\n\n validateCookieName(name);\n validateCookieAttributeValue(path, \"Path\");\n if (domain) {\n validateCookieAttributeValue(domain, \"Domain\");\n }\n\n this._cookies.delete(name);\n const parts = [`${name}=`, `Path=${path}`];\n if (domain) parts.push(`Domain=${domain}`);\n parts.push(`Expires=${EXPIRED_COOKIE_DATE}`);\n _getState().pendingSetCookies.push(parts.join(\"; \"));\n return this;\n }\n\n get size(): number {\n return this._cookies.size;\n }\n\n [Symbol.iterator](): IterableIterator<[string, { name: string; value: string }]> {\n const entries = this._cookies.entries();\n const iter: IterableIterator<[string, { name: string; value: string }]> = {\n [Symbol.iterator]() {\n return iter;\n },\n next() {\n const { value, done } = entries.next();\n if (done) return { value: undefined, done: true };\n const [name, val] = value;\n return { value: [name, { name, value: val }], done: false };\n },\n };\n return iter;\n }\n\n toString(): string {\n const parts: string[] = [];\n for (const [name, value] of this._cookies) {\n parts.push(`${name}=${value}`);\n }\n return parts.join(\"; \");\n }\n}\n\n// Re-export types\nexport type { RequestCookies };\n"],"mappings":";;;;;;;;;;;;;;;;AAiEA,MAAM,gBAAgB,OAAO,IAAI,kCAAkC;AACnE,MAAM,KAAK;AACX,MAAM,OAAO,eAAuC,6BAA6B;AAEjF,MAAM,iBAAkB,GAAG,mBAAmB;CAC5C,gBAAgB;CAChB,sBAAsB;CACtB,uCAAuB,IAAI,KAA2B;CACtD,0BAA0B;CAC1B,mBAAmB,EAAE;CACrB,uBAAuB;CACvB,OAAO;CACR;AACD,MAAM,uCAAsB,IAAI,KAAK,EAAE,EAAC,aAAa;AAErD,SAAS,+BAA+B,OAAyB;CAC/D,MAAM,UAAoB,EAAE;CAC5B,IAAI,QAAQ;CACZ,IAAI,YAAY;CAChB,IAAI,mBAAmB;CAEvB,KAAK,IAAI,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;EACrC,IAAI,MAAM,MAAM,GAAG,IAAI,EAAE,CAAC,aAAa,KAAK,YAAY;GACtD,YAAY;GACZ,mBAAmB;GACnB,KAAK;GACL;;EAGF,MAAM,KAAK,MAAM;EACjB,IAAI,aAAa,OAAO,KAAK;GAC3B,YAAY;GACZ,mBAAmB;GACnB;;EAGF,IAAI,OAAO,KAAK;EAChB,IAAI,aAAa,CAAC,kBAAkB;GAClC,mBAAmB;GACnB;;EAGF,MAAM,SAAS,MAAM,MAAM,OAAO,EAAE,CAAC,MAAM;EAC3C,IAAI,QAAQ,QAAQ,KAAK,OAAO;EAChC,QAAQ,IAAI;EACZ,YAAY;EACZ,mBAAmB;;CAGrB,MAAM,SAAS,MAAM,MAAM,MAAM,CAAC,MAAM;CACxC,IAAI,QAAQ,QAAQ,KAAK,OAAO;CAChC,OAAO;;AAGT,SAAS,mBAAmB,WAA2D;CACrF,MAAM,cAAc,UAAU,QAAQ,IAAI;CAC1C,IAAI,eAAe,GAAG,OAAO;CAE7B,MAAM,OAAO,UAAU,MAAM,GAAG,YAAY,CAAC,MAAM;CACnD,MAAM,WAAW,UAAU,QAAQ,KAAK,cAAc,EAAE;CACxD,MAAM,eAAe,UAAU,MAAM,cAAc,GAAG,aAAa,KAAK,KAAA,IAAY,SAAS;CAC7F,IAAI;CACJ,IAAI;EACF,QAAQ,mBAAmB,aAAa;SAClC;EACN,QAAQ;;CAGV,OAAO;EAAE;EAAM;EAAO;;AAGxB,SAAS,yBAAyB,KAAqB,cAAmC;CACxF,IAAI,QAAQ,OAAO;CACnB,IAAI,iBAAiB,MAAM;CAE3B,MAAM,cAAc,kBAAkB,aAAa;CACnD,KAAK,MAAM,CAAC,MAAM,UAAU,aAC1B,IAAI,QAAQ,IAAI,MAAM,MAAM;;AAIhC,SAAS,0BAA0B,KAAqB,WAAmC;CACzF,IAAI,cAAc,MAAM,OAAO;CAE/B,IAAI,SAAS;CACb,KAAK,MAAM,aAAa,+BAA+B,UAAU,EAAE;EACjE,MAAM,QAAQ,mBAAmB,UAAU;EAC3C,IAAI,CAAC,OAAO;EACZ,IAAI,QAAQ,IAAI,MAAM,MAAM,MAAM,MAAM;EACxC,SAAS;;CAGX,OAAO;;AAGT,SAAS,YAAoC;CAC3C,IAAI,sBAAsB,EACxB,OAAO,mBAAmB;CAE5B,OAAO,KAAK,UAAU,IAAI;;;;;;;;;;;AAc5B,SAAgB,mBAAyB;CACvC,MAAM,QAAQ,WAAW;CACzB,IAAI,MAAM,gBAAgB,aACxB;CAEF,MAAM,uBAAuB;;AAG/B,SAAgB,0BAA0B,MAAkC;CAC1E,WAAW,CAAC,sBAAsB,IAAI,KAAK;;AAG7C,SAAgB,4BAAoD;CAClE,OAAO,CAAC,GAAG,WAAW,CAAC,sBAAsB,CAAC,MAAM;;AAGtD,SAAgB,+BAAuD;CACrE,MAAM,QAAQ,WAAW;CACzB,MAAM,WAAW,CAAC,GAAG,MAAM,sBAAsB,CAAC,MAAM;CACxD,MAAM,wCAAwB,IAAI,KAA2B;CAC7D,OAAO;;;AAWT,MAAM,qBAAqB,OAAO,IAAI,iCAAiC;;AAEvE,MAAM,0BAA0B,OAAO,IAAI,2BAA2B;AAUtE,SAAS,4BAA4B,KAAuC;CAC1E,MAAM,QAAQ,QAAQ,IAAI,YAAY,IAAI;CAC1C,IAAI,CAAC,SAAS,OAAO,UAAU,UAAU,OAAO;CAEhD,MAAM,WAAW,QAAQ,IAAI,OAAO,WAAW;CAC/C,IAAI,OAAO,aAAa,YAAY,OAAO;CAE3C,OAAO,EACL,gBAAgB,SAAS,KAAK,MAAM,EACrC;;AAGH,SAAS,2BAAwD;CAC/D,MAAM,QAAQ,4BAA4B,mBAAmB,EAAE,UAAU;CACzE,IAAI,CAAC,SAAS,OAAO,UAAU,UAAU,OAAO;CAChD,OAAO;;AAGT,SAAS,0BAAmC;CAC1C,MAAM,MAAM,0BAA0B;CAKtC,OAAO,QAAQ,QAAQ,IAAI,YAAY;;AAGzC,SAAS,yBAAkC;CACzC,OAAO,4BAA4B,wBAAwB,EAAE,UAAU,KAAK;;;;;;;;;AAU9E,SAAgB,wBAAwB,SAAuB;CAC7D,IAAI,yBAAyB,EAAE;EAC7B,MAAM,wBAAQ,IAAI,MAChB,KAAK,QAAQ,iGAC+C,QAAQ,uDAErE;EAMD,IAAI;GACF,MAAM,MAAM,mBAAmB;GAC/B,IAAI,KAAK,IAAI,2BAA2B;UAClC;EAGR,MAAM;;CAER,IAAI,wBAAwB,EAAE;EAC5B,MAAM,wBAAQ,IAAI,MAChB,KAAK,QAAQ,iIAC+C,QAAQ,uDAErE;EACD,IAAI;GACF,MAAM,MAAM,mBAAmB;GAC/B,IAAI,KAAK,IAAI,2BAA2B;UAClC;EAGR,MAAM;;;;;;;;;;;;AAaV,SAAgB,kCAA2C;CACzD,MAAM,QAAQ,WAAW;CACzB,MAAM,MAAM,MAAM;CAClB,MAAM,2BAA2B;CACjC,OAAO;;;;;;AAOT,SAAgB,sBAA+B;CAC7C,MAAM,QAAQ,WAAW;CACzB,MAAM,OAAO,MAAM;CACnB,MAAM,uBAAuB;CAC7B,OAAO;;AAGT,SAAS,eACP,OACA,OACoB;CACpB,MAAM,WAAW,MAAM;CACvB,MAAM,QAAQ;CACd,OAAO;;AAGT,SAAS,mCAA4C;CACnD,MAAM,QAAQ,WAAW,CAAC;CAC1B,OAAO,UAAU,YAAY,UAAU;;AAGzC,SAAgB,sBAAsB,OAA+C;CACnF,OAAO,eAAe,WAAW,EAAE,MAAM;;AAG3C,SAAgB,wBAA4C;CAC1D,OAAO,WAAW,CAAC;;;;;;;;;;;;;;;;AAiBrB,SAAgB,oBAA2C;CACzD,OAAO,WAAW,CAAC;;AAGrB,SAAgB,kBAAkB,KAAkC;CAClE,MAAM,QAAQ,WAAW;CACzB,IAAI,QAAQ,MAAM;EAChB,MAAM,iBAAiB;EACvB,MAAM,uBAAuB;EAC7B,MAAM,wCAAwB,IAAI,KAAK;EACvC,MAAM,oBAAoB,EAAE;EAC5B,MAAM,wBAAwB;EAC9B,MAAM,QAAQ;QACT;EACL,MAAM,iBAAiB;EACvB,MAAM,QAAQ;;;AAmBlB,SAAgB,sBACd,KACA,IACgB;CAChB,IAAI,sBAAsB,EACxB,OAAO,6BAA6B,SAAS;EAC3C,KAAK,iBAAiB;EACtB,KAAK,uBAAuB;EAC5B,KAAK,wCAAwB,IAAI,KAAK;EACtC,KAAK,oBAAoB,EAAE;EAC3B,KAAK,wBAAwB;EAC7B,KAAK,QAAQ;IACZ,GAAG;CAGR,MAAM,QAAgC;EACpC,gBAAgB;EAChB,sBAAsB;EACtB,uCAAuB,IAAI,KAAK;EAChC,0BAA0B;EAC1B,mBAAmB,EAAE;EACrB,uBAAuB;EACvB,OAAO;EACR;CAED,OAAO,KAAK,IAAI,OAAO,GAAG;;;;;;;;;;;;;;;;;;;;;AAsB5B,SAAgB,8BAA8B,2BAA0C;CACtF,MAAM,QAAQ,WAAW;CACzB,IAAI,CAAC,MAAM,gBAAgB;CAE3B,MAAM,MAAM,MAAM;CAClB,MAAM,uBAAuB,IAAI,QAAQ,IAAI,SAAS;CACtD,MAAM,4BAA4B,0BAA0B,IAAI,6BAA6B;CAC7F,MAAM,cAAc,0CAClB,IAAI,SACJ,0BACD;CAED,IAAI,CAAC,eAAe,8BAA8B,MAAM;CAExD,IAAI,aAAa;EACf,IAAI,UAAU;EAId,IAAI,kBAAkB,KAAA;EACtB,MAAM,mBAAmB,YAAY,IAAI,SAAS;EAClD,IAAI,yBAAyB,kBAAkB;GAC7C,yBAAyB,KAAK,iBAAiB;GAC/C,IAAI,kBAAkB,KAAA;GACtB,IAAI,iBAAiB,KAAA;;;CAIzB,IAAI,0BAA0B,KAAK,0BAA0B,EAAE;EAC7D,IAAI,kBAAkB,KAAA;EACtB,IAAI,iBAAiB,KAAA;;;;AAKzB,MAAM,4BAA4B,IAAI,IAAI;CAAC;CAAO;CAAU;CAAS,CAAC;AAEtE,IAAM,uBAAN,MAAM,6BAA6B,MAAM;CACvC,cAAc;EACZ,MACE,qGACD;;CAGH,OAAO,WAAkB;EACvB,MAAM,IAAI,sBAAsB;;;AAOpC,IAAM,8BAAN,MAAM,oCAAoC,MAAM;CAC9C,cAAc;EACZ,MACE,mJACD;;CAGH,OAAO,WAAkB;EACvB,MAAM,IAAI,6BAA6B;;;AAI3C,SAAS,2BACP,SACA,QACgB;CAChB,OAAO,IAAI,MAAM,SAA2B;EAC1C,IAAI,eAAe,MAAM;GACvB,IAAI,QAAQ,eAAe;IACzB,MAAM,QAAQ,QAAQ,IAAI,eAAe,MAAM,cAAc;IAC7D,OAAO,OAAO,UAAU,aAAa,MAAM,KAAK,cAAc,GAAG;;GAGnE,MAAM,QAAQ,QAAQ,IAAI,QAAQ,MAAM,OAAO;GAC/C,OAAO,OAAO,UAAU,aAAa,MAAM,KAAK,OAAO,GAAG;;EAE5D,IAAI,eAAe,MAAM;GACvB,OAAO,QAAQ,iBAAiB,QAAQ;;EAE1C,QAAQ,eAAe;GACrB,OAAO,MAAM,KAAK,IAAI,IAAI,CAAC,GAAG,QAAQ,QAAQ,cAAc,EAAE,GAAG,QAAQ,QAAQ,OAAO,CAAC,CAAC,CAAC;;EAE7F,yBAAyB,eAAe,MAAM;GAC5C,OACE,QAAQ,yBAAyB,eAAe,KAAK,IACrD,QAAQ,yBAAyB,QAAQ,KAAK;;EAGnD,CAAC;;AAKJ,MAAM,4CAA4B,IAAI,SAA8C;AACpF,MAAM,4CAA4B,IAAI,SAGnC;AAEH,SAAS,uCACP,OACA,QACgB;CAChB,MAAM,SAAS,MAAM,IAAI,OAAO;CAChC,IAAI,QAAQ,OAAO;CAEnB,MAAM,UAAU,2BAA2B,QAAQ,QAAQ,OAAO,EAAE,OAAO;CAC3E,MAAM,IAAI,QAAQ,QAAQ;CAC1B,OAAO;;AAGT,SAAS,mCAAqD,OAAgC;CAC5F,MAAM,kBAAkB,iBAAiB,QAAQ,QAAQ,IAAI,MAAM,OAAO,MAAM,CAAC;CACjF,MAAM,UAAU,QAAQ,OAAO,gBAAgB;CAG/C,QAAQ,YAAY,GAAG;CAWvB,OAAO,2BAA2B,SAAS,IAThB,MAAM,EAAE,EAAO,EACxC,IAAI,SAAS,MAAM;EACjB,IAAI,SAAS,UAAU,SAAS,WAAW,SAAS,WAClD;EAEF,MAAM;IAET,CAEwD,CAAC;;AAG5D,SAAS,aAAa,SAA2B;CAC/C,OAAO,IAAI,MAAM,SAAS,EACxB,IAAI,QAAQ,MAAM;EAChB,IAAI,OAAO,SAAS,YAAY,0BAA0B,IAAI,KAAK,EACjE,MAAM,IAAI,sBAAsB;EAGlC,MAAM,QAAQ,QAAQ,IAAI,QAAQ,MAAM,OAAO;EAC/C,OAAO,OAAO,UAAU,aAAa,MAAM,KAAK,OAAO,GAAG;IAE7D,CAAC;;AAGJ,SAAS,oBAAoB,SAAyC;CACpE,OAAO,IAAI,MAAM,SAAS,EACxB,IAAI,QAAQ,MAAM;EAChB,IAAI,SAAS,SAAS,SAAS,UAC7B,QAAQ,GAAG,SAAoB;GAC7B,IAAI,CAAC,kCAAkC,EACrC,MAAM,IAAI,6BAA6B;GAGzC,OAAQ,QAAQ,IAAI,QAAQ,MAAM,OAAO,CAAyC,MAChF,QACA,KACD;;EAIL,MAAM,QAAQ,QAAQ,IAAI,QAAQ,MAAM,OAAO;EAC/C,OAAO,OAAO,UAAU,aAAa,MAAM,KAAK,OAAO,GAAG;IAE7D,CAAC;;AAGJ,SAAS,aAAa,SAAyC;CAC7D,OAAO,IAAI,MAAM,SAAS,EACxB,IAAI,QAAQ,MAAM;EAChB,IAAI,SAAS,SAAS,SAAS,UAC7B,MAAM,IAAI,6BAA6B;EAGzC,MAAM,QAAQ,QAAQ,IAAI,QAAQ,MAAM,OAAO;EAC/C,OAAO,OAAO,UAAU,aAAa,MAAM,KAAK,OAAO,GAAG;IAE7D,CAAC;;AAGJ,SAAS,mBAAmB,KAAqC;CAC/D,IAAI,CAAC,IAAI,gBACP,IAAI,iBAAiB,oBAAoB,IAAI,eAAe,IAAI,QAAQ,CAAC;CAG3E,OAAO,IAAI;;AAGb,SAAS,oBAAoB,KAAqC;CAChE,IAAI,CAAC,IAAI,iBAGP,IAAI,kBAAkB,aAAa,IAAI,eAAe,IAAI,QAAQ,CAAC;CAGrE,OAAO,IAAI;;AAGb,SAAS,oBAAoB,KAA8B;CACzD,IAAI,CAAC,IAAI,iBACP,IAAI,kBAAkB,aAAa,IAAI,QAAQ;CAGjD,OAAO,IAAI;;;;;;;;;;;;;;;;;;;;;;;AAwBb,SAAgB,0BACd,SACA,SACgB;CAKhB,IAAI,WAA2B;CAE/B,MAAM,eAAe,IAAI,MAAM,QAAQ,SAAS,EAC9C,IAAI,QAAQ,MAAuB;EAEjC,MAAM,MAAM,YAAY;EAGxB,IAAI,OAAO,SAAS,YAAY,0BAA0B,IAAI,KAAK,EACjE,QAAQ,GAAG,SAAoB;GAC7B,IAAI,CAAC,UACH,WAAW,IAAI,QAAQ,OAAO;GAEhC,OAAQ,SAAS,MACf,GAAG,KACJ;;EAKL,MAAM,QAAQ,QAAQ,IAAI,KAAK,MAAM,IAAI;EACzC,OAAO,OAAO,UAAU,aAAa,MAAM,KAAK,IAAI,GAAG;IAE1D,CAAC;CAOF,IAAI,WAAuC;CAE3C,SAAS,aAAkC;EACzC,IAAI,UAAU,OAAO;EAGrB,WAAW,kBADU,aAAa,IAAI,SAAS,IAAI,GACT;EAC1C,OAAO;;CAYT,OAAO;EAPL,SAAS;EACT,IAAI,UAA+B;GACjC,OAAO,YAAY;;EAErB,iBAAiB,SAAS;EAGlB;;;;;;;AAYZ,SAAgB,UAAsC;CACpD,0BAA0B,UAAU;CACpC,IAAI;EACF,wBAAwB,YAAY;UAC7B,OAAO;EACd,OAAO,mCAA4C,MAAM;;CAG3D,MAAM,QAAQ,WAAW;CACzB,IAAI,CAAC,MAAM,gBACT,OAAO,mDACL,IAAI,MACF,kJAED,CACF;CAGH,IAAI,MAAM,eAAe,aACvB,OAAO,mCAA4C,MAAM,eAAe,YAAY;CAGtF,kBAAkB;CAElB,OAAO,uCAAuC,2BADtB,oBAAoB,MAAM,eACsC,CAAC;;;;;;AAO3F,SAAgB,UAAoD;CAClE,0BAA0B,UAAU;CACpC,IAAI;EACF,wBAAwB,YAAY;UAC7B,OAAO;EACd,OAAO,mCAAmD,MAAM;;CAGlE,MAAM,QAAQ,WAAW;CACzB,IAAI,CAAC,MAAM,gBACT,OAAO,mDACL,IAAI,MACF,yFACD,CACF;CAGH,IAAI,MAAM,eAAe,aACvB,OAAO,mCAAmD,MAAM,eAAe,YAAY;CAG7F,kBAAkB;CAKlB,OAAO,uCAAuC,2BAJ1B,kCAAkC,GAClD,mBAAmB,MAAM,eAAe,GACxC,oBAAoB,MAAM,eAAe,CAEwC;;;;;;;AAcvF,SAAgB,4BAAsC;CACpD,MAAM,QAAQ,WAAW;CACzB,MAAM,UAAU,MAAM;CACtB,MAAM,oBAAoB,EAAE;CAC5B,OAAO;;AAIT,MAAM,oBAAoB;AAC1B,MAAM,2CAA0B,IAAI,KAAK,EAAE,EAAC,aAAa;;;;;AASzD,SAAgB,2BAA0C;CACxD,MAAM,QAAQ,WAAW;CACzB,MAAM,SAAS,MAAM;CACrB,MAAM,wBAAwB;CAC9B,OAAO;;AAGT,SAAS,wBAAwB,QAAwB;CACvD,IAAI,OAAO,WAAW,GACpB,MAAM,IAAI,MAAM,yDAAyD;CAE3E,OAAO;;AAGT,SAAS,wBAAgC;CACvC,MAAM,SAAS,WAAW;CAC1B,IAAI,UAAU,OAAO,OAAO,eAAe,YACzC,OAAO,OAAO,YAAY;CAG5B,MAAM,IAAI,MACR,0HAED;;AAGH,SAAS,6BAA6B,KAA6B;CACjE,IAAI,IAAI,oBAAoB,KAAA,GAC1B,OAAO,wBAAwB,IAAI,gBAAgB;CAGrD,MAAM,SAAS,uBAAuB;CACtC,IAAI,kBAAkB;CACtB,OAAO;;AAGT,SAAgB,mBAAmB,SAAkB,iBAAkC;CACrF,MAAM,eAAe,QAAQ,QAAQ,IAAI,SAAS;CAClD,IAAI,CAAC,cAAc,OAAO;CAC1B,OACE,kBAAkB,aAAa,CAAC,IAAI,kBAAkB,KACtD,wBAAwB,gBAAgB;;AAU5C,SAAS,4BAAoC;CAC3C,IAAI,OAAO,YAAY,eAAe,QAAQ,KAAK,aAAa,eAC9D,OAAO;CAET,OAAO;;AAGT,SAAS,0BAA0B,YAA2B;CAC5D,uBAAO,IAAI,MACT,GAAG,WAAW,+EACf;;AAGH,SAAS,8BACP,OACA,iBACA,YACgB;CAChB,MAAM,iBAAiB,MAAM;CAC7B,IAAI,mBAAmB,iBACrB,MAAM,0BAA0B,WAAW;CAE7C,IAAI,eAAe,aACjB,MAAM,eAAe;CAEvB,OAAO;;;;;;;;;AAUT,eAAsB,YAAsC;CAC1D,0BAA0B,YAAY;CACtC,wBAAwB,cAAc;CAEtC,MAAM,QAAQ,WAAW;CACzB,MAAM,UAAU,MAAM;CACtB,IAAI,CAAC,SACH,MAAM,0BAA0B,cAAc;CAEhD,IAAI,QAAQ,aACV,MAAM,QAAQ;CAOhB,MAAM,SAAS,6BAA6B,QAAQ;CAEpD,OAAO;EACL,IAAI,YAAqB;GACvB,OAAO,QAAQ,QAAQ,IAAI,kBAAkB,KAAK;;EAEpD,SAAe;GACb,MAAM,gBAAgB,8BAA8B,OAAO,SAAS,uBAAuB;GAC3F,kBAAkB;GAClB,cAAc,QAAQ,IAAI,mBAAmB,OAAO;GACpD,MAAM,wBAAwB,GAAG,kBAAkB,GAAG,OAAO,IAAI,2BAA2B;;EAE9F,UAAgB;GACd,MAAM,gBAAgB,8BAA8B,OAAO,SAAS,wBAAwB;GAC5F,kBAAkB;GAClB,cAAc,QAAQ,OAAO,kBAAkB;GAC/C,MAAM,wBAAwB,GAAG,kBAAkB,KAAK,2BAA2B,CAAC,YAAY;;EAEnG;;AAOH,IAAM,iBAAN,MAAqB;CACnB;CAEA,YAAY,SAA8B;EACxC,KAAK,WAAW;;CAGlB,IAAI,MAA2D;EAC7D,MAAM,QAAQ,KAAK,SAAS,IAAI,KAAK;EACrC,IAAI,UAAU,KAAA,GAAW,OAAO,KAAA;EAChC,OAAO;GAAE;GAAM;GAAO;;CAGxB,OAAO,eAAmF;EACxF,MAAM,OAAO,OAAO,kBAAkB,WAAW,gBAAgB,eAAe;EAChF,MAAM,SAAiD,EAAE;EACzD,KAAK,MAAM,CAAC,YAAY,UAAU,KAAK,UACrC,IAAI,SAAS,KAAA,KAAa,eAAe,MACvC,OAAO,KAAK;GAAE,MAAM;GAAY;GAAO,CAAC;EAG5C,OAAO;;CAGT,IAAI,MAAuB;EACzB,OAAO,KAAK,SAAS,IAAI,KAAK;;;;;;CAOhC,IACE,eAaA,OACA,SASM;EACN,IAAI;EACJ,IAAI;EACJ,IAAI;EAEJ,IAAI,OAAO,kBAAkB,UAAU;GACrC,aAAa;GACb,cAAc,SAAS;GACvB,OAAO;SACF;GACL,aAAa,cAAc;GAC3B,cAAc,cAAc;GAC5B,OAAO;;EAGT,mBAAmB,WAAW;EAG9B,KAAK,SAAS,IAAI,YAAY,YAAY;EAE1C,WAAW,CAAC,kBAAkB,KAAK,mBAAmB,YAAY,aAAa,KAAK,CAAC;EACrF,OAAO;;;;;CAMT,OAAO,eAAgF;EACrF,MAAM,OAAO,OAAO,kBAAkB,WAAW,gBAAgB,cAAc;EAC/E,MAAM,OAAO,OAAO,kBAAkB,WAAW,MAAO,cAAc,QAAQ;EAC9E,MAAM,SAAS,OAAO,kBAAkB,WAAW,KAAA,IAAY,cAAc;EAE7E,mBAAmB,KAAK;EACxB,6BAA6B,MAAM,OAAO;EAC1C,IAAI,QACF,6BAA6B,QAAQ,SAAS;EAGhD,KAAK,SAAS,OAAO,KAAK;EAC1B,MAAM,QAAQ,CAAC,GAAG,KAAK,IAAI,QAAQ,OAAO;EAC1C,IAAI,QAAQ,MAAM,KAAK,UAAU,SAAS;EAC1C,MAAM,KAAK,WAAW,sBAAsB;EAC5C,WAAW,CAAC,kBAAkB,KAAK,MAAM,KAAK,KAAK,CAAC;EACpD,OAAO;;CAGT,IAAI,OAAe;EACjB,OAAO,KAAK,SAAS;;CAGvB,CAAC,OAAO,YAAyE;EAC/E,MAAM,UAAU,KAAK,SAAS,SAAS;EACvC,MAAM,OAAoE;GACxE,CAAC,OAAO,YAAY;IAClB,OAAO;;GAET,OAAO;IACL,MAAM,EAAE,OAAO,SAAS,QAAQ,MAAM;IACtC,IAAI,MAAM,OAAO;KAAE,OAAO,KAAA;KAAW,MAAM;KAAM;IACjD,MAAM,CAAC,MAAM,OAAO;IACpB,OAAO;KAAE,OAAO,CAAC,MAAM;MAAE;MAAM,OAAO;MAAK,CAAC;KAAE,MAAM;KAAO;;GAE9D;EACD,OAAO;;CAGT,WAAmB;EACjB,MAAM,QAAkB,EAAE;EAC1B,KAAK,MAAM,CAAC,MAAM,UAAU,KAAK,UAC/B,MAAM,KAAK,GAAG,KAAK,GAAG,QAAQ;EAEhC,OAAO,MAAM,KAAK,KAAK"}
1
+ {"version":3,"file":"headers.js","names":[],"sources":["../../src/shims/headers.ts"],"sourcesContent":["/**\n * next/headers shim\n *\n * Provides cookies() and headers() functions for App Router Server Components.\n * These read from a request context set by the RSC handler before rendering.\n *\n * In Next.js 15+, cookies() and headers() return Promises (async).\n * We support both the sync (legacy) and async patterns.\n */\n\nimport { MIDDLEWARE_SET_COOKIE_HEADER } from \"../server/headers.js\";\nimport { buildRequestHeadersFromMiddlewareResponse } from \"../server/middleware-request-headers.js\";\nimport { getOrCreateAls } from \"./internal/als-registry.js\";\nimport {\n serializeSetCookie,\n validateCookieAttributeValue,\n validateCookieName,\n} from \"./internal/cookie-serialize.js\";\nimport { parseCookieHeader } from \"./internal/parse-cookie-header.js\";\nimport {\n isInsideUnifiedScope,\n getRequestContext,\n runWithUnifiedStateMutation,\n} from \"./unified-request-context.js\";\nimport type { RenderRequestApiKind } from \"../server/cache-proof.js\";\n\n// ---------------------------------------------------------------------------\n// Request context\n// ---------------------------------------------------------------------------\n\nexport type HeadersContext = {\n headers: Headers;\n cookies: Map<string, string>;\n accessError?: Error;\n forceStatic?: boolean;\n mutableCookies?: RequestCookies;\n readonlyCookies?: RequestCookies;\n readonlyHeaders?: Headers;\n draftModeSecret?: string;\n};\n\ntype HeadersContextFromRequestOptions = {\n draftModeSecret?: string;\n};\n\nexport type HeadersAccessPhase = \"render\" | \"action\" | \"route-handler\";\n\nexport type VinextHeadersShimState = {\n headersContext: HeadersContext | null;\n dynamicUsageDetected: boolean;\n renderRequestApiUsage: Set<RenderRequestApiKind>;\n /** Error recorded by throwIfInsideCacheScope for dev diagnostics, persists even if caught by user code. */\n invalidDynamicUsageError: unknown;\n pendingSetCookies: string[];\n draftModeCookieHeader: string | null;\n phase: HeadersAccessPhase;\n};\n\n// NOTE:\n// - This shim can be loaded under multiple module specifiers in Vite's\n// multi-environment setup (RSC/SSR). Store the AsyncLocalStorage on\n// globalThis so `connection()` (next/server) and `consumeDynamicUsage()`\n// (next/headers) always share it.\n// - We use AsyncLocalStorage so concurrent requests don't stomp each other's\n// headers/cookies/dynamic-usage state.\nconst _FALLBACK_KEY = Symbol.for(\"vinext.nextHeadersShim.fallback\");\nconst _g = globalThis as unknown as Record<PropertyKey, unknown>;\nconst _als = getOrCreateAls<VinextHeadersShimState>(\"vinext.nextHeadersShim.als\");\n\nconst _fallbackState = (_g[_FALLBACK_KEY] ??= {\n headersContext: null,\n dynamicUsageDetected: false,\n renderRequestApiUsage: new Set<RenderRequestApiKind>(),\n invalidDynamicUsageError: null,\n pendingSetCookies: [],\n draftModeCookieHeader: null,\n phase: \"render\",\n} satisfies VinextHeadersShimState) as VinextHeadersShimState;\nconst EXPIRED_COOKIE_DATE = new Date(0).toUTCString();\n\nfunction splitMiddlewareSetCookieHeader(value: string): string[] {\n const cookies: string[] = [];\n let start = 0;\n let inExpires = false;\n let expiresCommaSeen = false;\n\n for (let i = 0; i < value.length; i++) {\n if (value.slice(i, i + 8).toLowerCase() === \"expires=\") {\n inExpires = true;\n expiresCommaSeen = false;\n i += 7;\n continue;\n }\n\n const ch = value[i];\n if (inExpires && ch === \";\") {\n inExpires = false;\n expiresCommaSeen = false;\n continue;\n }\n\n if (ch !== \",\") continue;\n if (inExpires && !expiresCommaSeen) {\n expiresCommaSeen = true;\n continue;\n }\n\n const cookie = value.slice(start, i).trim();\n if (cookie) cookies.push(cookie);\n start = i + 1;\n inExpires = false;\n expiresCommaSeen = false;\n }\n\n const cookie = value.slice(start).trim();\n if (cookie) cookies.push(cookie);\n return cookies;\n}\n\nfunction setCookieNameValue(setCookie: string): { name: string; value: string } | null {\n const equalsIndex = setCookie.indexOf(\"=\");\n if (equalsIndex <= 0) return null;\n\n const name = setCookie.slice(0, equalsIndex).trim();\n const valueEnd = setCookie.indexOf(\";\", equalsIndex + 1);\n const encodedValue = setCookie.slice(equalsIndex + 1, valueEnd === -1 ? undefined : valueEnd);\n let value: string;\n try {\n value = decodeURIComponent(encodedValue);\n } catch {\n value = encodedValue;\n }\n\n return { name, value };\n}\n\nfunction rebuildCookiesFromHeader(ctx: HeadersContext, cookieHeader: string | null): void {\n ctx.cookies.clear();\n if (cookieHeader === null) return;\n\n const nextCookies = parseCookieHeader(cookieHeader);\n for (const [name, value] of nextCookies) {\n ctx.cookies.set(name, value);\n }\n}\n\nfunction mergeMiddlewareSetCookies(ctx: HeadersContext, rawHeader: string | null): boolean {\n if (rawHeader === null) return false;\n\n let merged = false;\n for (const setCookie of splitMiddlewareSetCookieHeader(rawHeader)) {\n const entry = setCookieNameValue(setCookie);\n if (!entry) continue;\n ctx.cookies.set(entry.name, entry.value);\n merged = true;\n }\n\n return merged;\n}\n\nfunction _getState(): VinextHeadersShimState {\n if (isInsideUnifiedScope()) {\n return getRequestContext();\n }\n return _als.getStore() ?? _fallbackState;\n}\n\n/**\n * Dynamic usage flag — set when a component calls connection(), cookies(),\n * headers(), or noStore() during rendering. When true, ISR caching is\n * bypassed and the response gets Cache-Control: no-store.\n */\n// (stored on _state)\n\n/**\n * Mark the current render as requiring dynamic (uncached) rendering.\n * Called by connection(), cookies(), headers(), and noStore().\n */\nexport function markDynamicUsage(): void {\n const state = _getState();\n if (state.headersContext?.forceStatic) {\n return;\n }\n state.dynamicUsageDetected = true;\n}\n\nexport function markRenderRequestApiUsage(kind: RenderRequestApiKind): void {\n _getState().renderRequestApiUsage.add(kind);\n}\n\nexport function peekRenderRequestApiUsage(): RenderRequestApiKind[] {\n return [..._getState().renderRequestApiUsage].sort();\n}\n\nexport function consumeRenderRequestApiUsage(): RenderRequestApiKind[] {\n const state = _getState();\n const observed = [...state.renderRequestApiUsage].sort();\n state.renderRequestApiUsage = new Set<RenderRequestApiKind>();\n return observed;\n}\n\n// ---------------------------------------------------------------------------\n// Cache scope detection — checks whether we're inside \"use cache\" or\n// unstable_cache() by reading ALS instances stored on globalThis via Symbols.\n// This avoids circular imports between headers.ts, cache.ts, and cache-runtime.ts.\n// The ALS instances are registered by cache-runtime.ts and cache.ts respectively.\n// ---------------------------------------------------------------------------\n\n/** Symbol used by cache-runtime.ts to store the \"use cache\" ALS on globalThis */\nconst _USE_CACHE_ALS_KEY = Symbol.for(\"vinext.cacheRuntime.contextAls\");\n/** Symbol used by cache.ts to store the unstable_cache ALS on globalThis */\nconst _UNSTABLE_CACHE_ALS_KEY = Symbol.for(\"vinext.unstableCache.als\");\n\ntype UseCacheGuardContext = {\n variant?: unknown;\n};\n\ntype CacheScopeStorage = {\n getStore: () => unknown;\n};\n\nfunction _getGlobalCacheScopeStorage(key: symbol): CacheScopeStorage | null {\n const value = Reflect.get(globalThis, key);\n if (!value || typeof value !== \"object\") return null;\n\n const getStore = Reflect.get(value, \"getStore\");\n if (typeof getStore !== \"function\") return null;\n\n return {\n getStore: () => getStore.call(value),\n };\n}\n\nfunction _getUseCacheGuardContext(): UseCacheGuardContext | null {\n const store = _getGlobalCacheScopeStorage(_USE_CACHE_ALS_KEY)?.getStore();\n if (!store || typeof store !== \"object\") return null;\n return store;\n}\n\nfunction _isInsidePublicUseCache(): boolean {\n const ctx = _getUseCacheGuardContext();\n // Next.js models \"use cache: private\" as a private-cache work unit that\n // carries request headers and cookies. Only public \"use cache\" scopes freeze\n // request APIs into persisted cache entries and must reject these reads.\n // https://github.com/vercel/next.js/blob/canary/packages/next/src/server/app-render/work-unit-async-storage.external.ts\n return ctx !== null && ctx.variant !== \"private\";\n}\n\nfunction _isInsideUnstableCache(): boolean {\n return _getGlobalCacheScopeStorage(_UNSTABLE_CACHE_ALS_KEY)?.getStore() === true;\n}\n\n/**\n * Throw if the current execution is inside a \"use cache\" or unstable_cache()\n * scope. Called by dynamic request APIs (headers, cookies, connection) to\n * prevent request-specific data from being frozen into cached results.\n *\n * @param apiName - The name of the API being called (e.g. \"connection()\")\n */\nexport function throwIfInsideCacheScope(apiName: string): void {\n if (_isInsidePublicUseCache()) {\n const error = new Error(\n `\\`${apiName}\\` cannot be called inside \"use cache\". ` +\n `If you need this data inside a cached function, call \\`${apiName}\\` ` +\n \"outside and pass the required data as an argument.\",\n );\n // Record the error on the request context so it survives user try/catch\n // and can be forwarded to the dev overlay on client-side navigations.\n // Ported from Next.js: workStore.invalidDynamicUsageError assignment in\n // packages/next/src/server/app-render/app-render.tsx\n // https://github.com/vercel/next.js/commit/f5e54c06726b571a042fce67417e40a29f6b8689\n try {\n const ctx = getRequestContext();\n if (ctx) ctx.invalidDynamicUsageError = error;\n } catch {\n // Ignore — best-effort recording for dev diagnostics\n }\n throw error;\n }\n if (_isInsideUnstableCache()) {\n const error = new Error(\n `\\`${apiName}\\` cannot be called inside a function cached with \\`unstable_cache()\\`. ` +\n `If you need this data inside a cached function, call \\`${apiName}\\` ` +\n \"outside and pass the required data as an argument.\",\n );\n try {\n const ctx = getRequestContext();\n if (ctx) ctx.invalidDynamicUsageError = error;\n } catch {\n // Ignore\n }\n throw error;\n }\n}\n\n/**\n * Check, consume, and return any invalid dynamic usage error recorded during\n * the render (e.g. cookies() called inside \"use cache\"). This error persists\n * even if the throw was caught by user-code try/catch, so it can surface on\n * client-side navigations where the static shell validation is skipped.\n * Ported from Next.js: workStore.invalidDynamicUsageError in\n * packages/next/src/server/app-render/app-render.tsx\n * https://github.com/vercel/next.js/commit/f5e54c06726b571a042fce67417e40a29f6b8689\n */\nexport function consumeInvalidDynamicUsageError(): unknown {\n const state = _getState();\n const err = state.invalidDynamicUsageError;\n state.invalidDynamicUsageError = null;\n return err;\n}\n\n/**\n * Check and reset the dynamic usage flag.\n * Called by the server after rendering to decide on caching.\n */\nexport function consumeDynamicUsage(): boolean {\n const state = _getState();\n const used = state.dynamicUsageDetected;\n state.dynamicUsageDetected = false;\n return used;\n}\n\nfunction _setStatePhase(\n state: VinextHeadersShimState,\n phase: HeadersAccessPhase,\n): HeadersAccessPhase {\n const previous = state.phase;\n state.phase = phase;\n return previous;\n}\n\nfunction _areCookiesMutableInCurrentPhase(): boolean {\n const phase = _getState().phase;\n return phase === \"action\" || phase === \"route-handler\";\n}\n\nexport function setHeadersAccessPhase(phase: HeadersAccessPhase): HeadersAccessPhase {\n return _setStatePhase(_getState(), phase);\n}\n\nexport function getHeadersAccessPhase(): HeadersAccessPhase {\n return _getState().phase;\n}\n\n/**\n * Set the headers/cookies context for the current RSC render.\n * Called by the framework's RSC entry before rendering each request.\n *\n * @deprecated Prefer runWithHeadersContext() which uses als.run() for\n * proper per-request isolation. This function mutates the ALS store\n * in-place and is only safe for cleanup (ctx=null) within an existing\n * als.run() scope.\n */\n/**\n * Returns the current live HeadersContext from ALS (or the fallback).\n * Used after applyMiddlewareRequestHeaders() to build a post-middleware\n * request context for afterFiles/fallback rewrite has/missing evaluation.\n */\nexport function getHeadersContext(): HeadersContext | null {\n return _getState().headersContext;\n}\n\nexport function setHeadersContext(ctx: HeadersContext | null): void {\n const state = _getState();\n if (ctx !== null) {\n state.headersContext = ctx;\n state.dynamicUsageDetected = false;\n state.renderRequestApiUsage = new Set();\n state.pendingSetCookies = [];\n state.draftModeCookieHeader = null;\n state.phase = \"render\";\n } else {\n state.headersContext = null;\n state.phase = \"render\";\n }\n}\n\n/**\n * Run a function with headers context, ensuring the context propagates\n * through all async operations (including RSC streaming).\n *\n * Uses AsyncLocalStorage.run() to guarantee per-request isolation.\n * The ALS store propagates through all async continuations including\n * ReadableStream consumption, setTimeout callbacks, and Promise chains,\n * so RSC streaming works correctly — components that render when the\n * stream is consumed still see the correct request's context.\n */\nexport function runWithHeadersContext<T>(ctx: HeadersContext, fn: () => Promise<T>): Promise<T>;\nexport function runWithHeadersContext<T>(\n ctx: HeadersContext,\n fn: () => T | Promise<T>,\n): T | Promise<T>;\nexport function runWithHeadersContext<T>(\n ctx: HeadersContext,\n fn: () => T | Promise<T>,\n): T | Promise<T> {\n if (isInsideUnifiedScope()) {\n return runWithUnifiedStateMutation((uCtx) => {\n uCtx.headersContext = ctx;\n uCtx.dynamicUsageDetected = false;\n uCtx.renderRequestApiUsage = new Set();\n uCtx.pendingSetCookies = [];\n uCtx.draftModeCookieHeader = null;\n uCtx.phase = \"render\";\n }, fn);\n }\n\n const state: VinextHeadersShimState = {\n headersContext: ctx,\n dynamicUsageDetected: false,\n renderRequestApiUsage: new Set(),\n invalidDynamicUsageError: null,\n pendingSetCookies: [],\n draftModeCookieHeader: null,\n phase: \"render\",\n };\n\n return _als.run(state, fn);\n}\n\n/**\n * Apply middleware-forwarded request headers to the current headers context.\n *\n * When Next.js middleware calls `NextResponse.next()` or `NextResponse.rewrite()`\n * with `{ request: { headers } }`, the modified headers are encoded on the\n * middleware response. This function decodes that protocol and applies the\n * resulting request header set to the live `HeadersContext`. When an override\n * list is present, omitted headers are deleted as part of the rebuild.\n *\n * Cached `readonlyHeaders` and `readonlyCookies` snapshots on the\n * HeadersContext must be invalidated whenever this function rebuilds the\n * underlying `headers`/`cookies`. Otherwise a middleware that reads\n * `headers()` (or `cookies()`) before returning a request-header override —\n * for example `@clerk/nextjs`, whose `clerkClient()` reads `headers()` via\n * `buildRequestLike()` during middleware execution — primes a sealed snapshot\n * built from the *pre*-override request, and any subsequent `headers()` call\n * from a Server Component would return that stale snapshot instead of the\n * middleware-modified view.\n */\nexport function applyMiddlewareRequestHeaders(middlewareResponseHeaders: Headers): void {\n const state = _getState();\n if (!state.headersContext) return;\n\n const ctx = state.headersContext;\n const previousCookieHeader = ctx.headers.get(\"cookie\");\n const middlewareSetCookieHeader = middlewareResponseHeaders.get(MIDDLEWARE_SET_COOKIE_HEADER);\n const nextHeaders = buildRequestHeadersFromMiddlewareResponse(\n ctx.headers,\n middlewareResponseHeaders,\n );\n\n if (!nextHeaders && middlewareSetCookieHeader === null) return;\n\n if (nextHeaders) {\n ctx.headers = nextHeaders;\n // Invalidate any sealed snapshot of the pre-override headers. A middleware\n // that read `headers()` before returning the override (e.g. clerkMiddleware)\n // would otherwise leak the pre-override view into the Server Component.\n ctx.readonlyHeaders = undefined;\n const nextCookieHeader = nextHeaders.get(\"cookie\");\n if (previousCookieHeader !== nextCookieHeader) {\n rebuildCookiesFromHeader(ctx, nextCookieHeader);\n ctx.readonlyCookies = undefined;\n ctx.mutableCookies = undefined;\n }\n }\n\n if (mergeMiddlewareSetCookies(ctx, middlewareSetCookieHeader)) {\n ctx.readonlyCookies = undefined;\n ctx.mutableCookies = undefined;\n }\n}\n\n/** Methods on `Headers` that mutate state. Hoisted to module scope — static. */\nconst _HEADERS_MUTATING_METHODS = new Set([\"set\", \"delete\", \"append\"]);\n\nclass 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 static callable(): never {\n throw new ReadonlyHeadersError();\n }\n}\n\n// Keep this error message in sync with server.ts. The two RequestCookies\n// adapters are separate until the next/headers and NextRequest cookie paths\n// share one implementation.\nclass ReadonlyRequestCookiesError extends Error {\n constructor() {\n super(\n \"Cookies can only be modified in a Server Action or Route Handler. Read more: https://nextjs.org/docs/app/api-reference/functions/cookies#options\",\n );\n }\n\n static callable(): never {\n throw new ReadonlyRequestCookiesError();\n }\n}\n\nfunction _decorateRequestApiPromise<T extends object>(\n promise: Promise<T>,\n target: T,\n): Promise<T> & T {\n return new Proxy(promise as Promise<T> & T, {\n get(promiseTarget, prop) {\n if (prop in promiseTarget) {\n const value = Reflect.get(promiseTarget, prop, promiseTarget);\n return typeof value === \"function\" ? value.bind(promiseTarget) : value;\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n has(promiseTarget, prop) {\n return prop in promiseTarget || prop in target;\n },\n ownKeys(promiseTarget) {\n return Array.from(new Set([...Reflect.ownKeys(promiseTarget), ...Reflect.ownKeys(target)]));\n },\n getOwnPropertyDescriptor(promiseTarget, prop) {\n return (\n Reflect.getOwnPropertyDescriptor(promiseTarget, prop) ??\n Reflect.getOwnPropertyDescriptor(target, prop)\n );\n },\n });\n}\n\n// React.use() tracks thenables by identity, so request APIs must reuse the\n// same decorated promise for the same underlying request view.\nconst _decoratedHeadersPromises = new WeakMap<Headers, Promise<Headers> & Headers>();\nconst _decoratedCookiesPromises = new WeakMap<\n RequestCookies,\n Promise<RequestCookies> & RequestCookies\n>();\n\nfunction _getOrCreateDecoratedRequestApiPromise<T extends object>(\n cache: WeakMap<T, Promise<T> & T>,\n target: T,\n): Promise<T> & T {\n const cached = cache.get(target);\n if (cached) return cached;\n\n const promise = _decorateRequestApiPromise(Promise.resolve(target), target);\n cache.set(target, promise);\n return promise;\n}\n\nfunction _decorateRejectedRequestApiPromise<T extends object>(error: unknown): Promise<T> & T {\n const normalizedError = error instanceof Error ? error : new Error(String(error));\n const promise = Promise.reject(normalizedError) as Promise<T>;\n // Mark the rejection as handled so legacy sync access does not trigger\n // spurious unhandled rejection noise before callers await/catch it.\n promise.catch(() => {});\n\n const throwingTarget = new Proxy({} as T, {\n get(_target, prop) {\n if (prop === \"then\" || prop === \"catch\" || prop === \"finally\") {\n return undefined;\n }\n throw normalizedError;\n },\n });\n\n return _decorateRequestApiPromise(promise, throwingTarget);\n}\n\nfunction _sealHeaders(headers: Headers): Headers {\n return new Proxy(headers, {\n get(target, prop) {\n if (typeof prop === \"string\" && _HEADERS_MUTATING_METHODS.has(prop)) {\n throw new ReadonlyHeadersError();\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n }) as Headers;\n}\n\nfunction _wrapMutableCookies(cookies: RequestCookies): RequestCookies {\n return new Proxy(cookies, {\n get(target, prop) {\n if (prop === \"set\" || prop === \"delete\") {\n return (...args: unknown[]) => {\n if (!_areCookiesMutableInCurrentPhase()) {\n throw new ReadonlyRequestCookiesError();\n }\n\n return (Reflect.get(target, prop, target) as (...callArgs: unknown[]) => unknown).apply(\n target,\n args,\n );\n };\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n }) as RequestCookies;\n}\n\nfunction _sealCookies(cookies: RequestCookies): RequestCookies {\n return new Proxy(cookies, {\n get(target, prop) {\n if (prop === \"set\" || prop === \"delete\") {\n throw new ReadonlyRequestCookiesError();\n }\n\n const value = Reflect.get(target, prop, target);\n return typeof value === \"function\" ? value.bind(target) : value;\n },\n }) as RequestCookies;\n}\n\nfunction _getMutableCookies(ctx: HeadersContext): RequestCookies {\n if (!ctx.mutableCookies) {\n ctx.mutableCookies = _wrapMutableCookies(new RequestCookies(ctx.cookies));\n }\n\n return ctx.mutableCookies;\n}\n\nfunction _getReadonlyCookies(ctx: HeadersContext): RequestCookies {\n if (!ctx.readonlyCookies) {\n // Keep a separate readonly wrapper so render-path reads avoid the\n // mutable phase-checking proxy while still reflecting the shared cookie map.\n ctx.readonlyCookies = _sealCookies(new RequestCookies(ctx.cookies));\n }\n\n return ctx.readonlyCookies;\n}\n\nfunction _getReadonlyHeaders(ctx: HeadersContext): Headers {\n if (!ctx.readonlyHeaders) {\n ctx.readonlyHeaders = _sealHeaders(ctx.headers);\n }\n\n return ctx.readonlyHeaders;\n}\n\n/**\n * Create a HeadersContext from a standard Request object.\n *\n * Performance note: In Workerd (Cloudflare Workers), `new Headers(request.headers)`\n * copies the entire header map across the V8/C++ boundary, which shows up as\n * ~815 ms self-time in production profiles when requests carry many headers.\n * We defer this copy with a lazy proxy:\n *\n * - Reads (`get`, `has`, `entries`, …) are forwarded directly to the original\n * immutable `request.headers` — zero copy cost on the hot path.\n * - The first mutating call (`set`, `delete`, `append`) materialises\n * `new Headers(request.headers)` once, then applies the mutation to the copy.\n * All subsequent operations go to the copy.\n *\n * This means the ~815 ms copy only occurs when middleware actually rewrites\n * request headers via `NextResponse.next({ request: { headers } })`, which is\n * uncommon. Pure read requests (the vast majority) pay zero copy cost.\n *\n * Cookie parsing is also deferred: the `cookie` header string is not split\n * until the first call to `cookies()` or `draftMode()`.\n */\nexport function headersContextFromRequest(\n request: Request,\n options?: HeadersContextFromRequestOptions,\n): HeadersContext {\n // ---------------------------------------------------------------------------\n // Lazy mutable Headers proxy\n // ---------------------------------------------------------------------------\n // `_mutable` holds the materialised copy once a write is needed.\n let _mutable: Headers | null = null;\n\n const headersProxy = new Proxy(request.headers, {\n get(target, prop: string | symbol) {\n // Route to the materialised copy if it exists.\n const src = _mutable ?? target;\n\n // Intercept mutating methods: materialise on first write.\n if (typeof prop === \"string\" && _HEADERS_MUTATING_METHODS.has(prop)) {\n return (...args: unknown[]) => {\n if (!_mutable) {\n _mutable = new Headers(target);\n }\n return (_mutable[prop as \"set\" | \"delete\" | \"append\"] as (...a: unknown[]) => unknown)(\n ...args,\n );\n };\n }\n\n // Non-mutating method or property: bind to current source.\n const value = Reflect.get(src, prop, src);\n return typeof value === \"function\" ? value.bind(src) : value;\n },\n }) as Headers;\n\n // ---------------------------------------------------------------------------\n // Lazy cookie map\n // ---------------------------------------------------------------------------\n // Parsing cookies requires splitting on `;` and `=`, which is cheap but\n // still unnecessary overhead if `cookies()` is never called for this request.\n let _cookies: Map<string, string> | null = null;\n\n function getCookies(): Map<string, string> {\n if (_cookies) return _cookies;\n // Read from the proxy so middleware-modified cookie headers are respected.\n const cookieHeader = headersProxy.get(\"cookie\") || \"\";\n _cookies = parseCookieHeader(cookieHeader);\n return _cookies;\n }\n\n // Expose cookies as a lazy getter that memoises on first access.\n const ctx = {\n headers: headersProxy,\n get cookies(): Map<string, string> {\n return getCookies();\n },\n draftModeSecret: options?.draftModeSecret,\n } satisfies HeadersContext;\n\n return ctx;\n}\n\n// ---------------------------------------------------------------------------\n// Public API\n// ---------------------------------------------------------------------------\n\n/**\n * Read-only Headers instance from the incoming request.\n * Returns a Promise in Next.js 15+ style (but resolves synchronously since\n * the context is already available).\n */\nexport function headers(): Promise<Headers> & Headers {\n markRenderRequestApiUsage(\"headers\");\n try {\n throwIfInsideCacheScope(\"headers()\");\n } catch (error) {\n return _decorateRejectedRequestApiPromise<Headers>(error);\n }\n\n const state = _getState();\n if (!state.headersContext) {\n return _decorateRejectedRequestApiPromise<Headers>(\n new Error(\n \"headers() can only be called from a Server Component, Route Handler, \" +\n \"or Server Action. Make sure you're not calling it from a Client Component.\",\n ),\n );\n }\n\n if (state.headersContext.accessError) {\n return _decorateRejectedRequestApiPromise<Headers>(state.headersContext.accessError);\n }\n\n markDynamicUsage();\n const readonlyHeaders = _getReadonlyHeaders(state.headersContext);\n return _getOrCreateDecoratedRequestApiPromise(_decoratedHeadersPromises, readonlyHeaders);\n}\n\n/**\n * Cookie jar from the incoming request.\n * Returns a ReadonlyRequestCookies-like object.\n */\nexport function cookies(): Promise<RequestCookies> & RequestCookies {\n markRenderRequestApiUsage(\"cookies\");\n try {\n throwIfInsideCacheScope(\"cookies()\");\n } catch (error) {\n return _decorateRejectedRequestApiPromise<RequestCookies>(error);\n }\n\n const state = _getState();\n if (!state.headersContext) {\n return _decorateRejectedRequestApiPromise<RequestCookies>(\n new Error(\n \"cookies() can only be called from a Server Component, Route Handler, or Server Action.\",\n ),\n );\n }\n\n if (state.headersContext.accessError) {\n return _decorateRejectedRequestApiPromise<RequestCookies>(state.headersContext.accessError);\n }\n\n markDynamicUsage();\n const cookieStore = _areCookiesMutableInCurrentPhase()\n ? _getMutableCookies(state.headersContext)\n : _getReadonlyCookies(state.headersContext);\n\n return _getOrCreateDecoratedRequestApiPromise(_decoratedCookiesPromises, cookieStore);\n}\n\n// ---------------------------------------------------------------------------\n// Writable cookie accumulator for Route Handlers / Server Actions\n// ---------------------------------------------------------------------------\n\n/** Accumulated Set-Cookie headers from cookies().set() / .delete() calls */\n// (stored on _state)\n\n/**\n * Get and clear all pending Set-Cookie headers generated by cookies().set()/delete().\n * Called by the framework after rendering to attach headers to the response.\n */\nexport function getAndClearPendingCookies(): string[] {\n const state = _getState();\n const cookies = state.pendingSetCookies;\n state.pendingSetCookies = [];\n return cookies;\n}\n\n// Draft mode cookie name (matches Next.js convention)\nconst DRAFT_MODE_COOKIE = \"__prerender_bypass\";\nconst DRAFT_MODE_EXPIRED_DATE = new Date(0).toUTCString();\n\n// Store for Set-Cookie headers generated by draftMode().enable()/disable()\n// (stored on _state)\n\n/**\n * Get any Set-Cookie header generated by draftMode().enable()/disable().\n * Called by the framework after rendering to attach the header to the response.\n */\nexport function getDraftModeCookieHeader(): string | null {\n const state = _getState();\n const header = state.draftModeCookieHeader;\n state.draftModeCookieHeader = null;\n return header;\n}\n\nfunction validateDraftModeSecret(secret: string): string {\n if (secret.length === 0) {\n throw new Error(\"[vinext] draft mode secret must be a non-empty string.\");\n }\n return secret;\n}\n\nfunction createDraftModeSecret(): string {\n const crypto = globalThis.crypto;\n if (crypto && typeof crypto.randomUUID === \"function\") {\n return crypto.randomUUID();\n }\n\n throw new Error(\n \"[vinext] draft mode secret is not initialized. \" +\n \"This should be initialized by the server entry before handling requests.\",\n );\n}\n\nfunction ensureContextDraftModeSecret(ctx: HeadersContext): string {\n if (ctx.draftModeSecret !== undefined) {\n return validateDraftModeSecret(ctx.draftModeSecret);\n }\n\n const secret = createDraftModeSecret();\n ctx.draftModeSecret = secret;\n return secret;\n}\n\nexport function isDraftModeRequest(request: Request, draftModeSecret: string): boolean {\n const cookieHeader = request.headers.get(\"cookie\");\n if (!cookieHeader) return false;\n return (\n parseCookieHeader(cookieHeader).get(DRAFT_MODE_COOKIE) ===\n validateDraftModeSecret(draftModeSecret)\n );\n}\n\ntype DraftModeResult = {\n readonly isEnabled: boolean;\n enable(): void;\n disable(): void;\n};\n\nfunction draftModeCookieAttributes(): string {\n if (typeof process !== \"undefined\" && process.env?.NODE_ENV === \"development\") {\n return \"Path=/; HttpOnly; SameSite=Lax\";\n }\n return \"Path=/; HttpOnly; SameSite=None; Secure\";\n}\n\nfunction createDraftModeScopeError(expression: string): Error {\n return new Error(\n `${expression} can only be called from a Server Component, Route Handler, or Server Action.`,\n );\n}\n\nfunction requireActiveDraftModeContext(\n state: VinextHeadersShimState,\n expectedContext: HeadersContext,\n expression: string,\n): HeadersContext {\n const currentContext = state.headersContext;\n if (currentContext !== expectedContext) {\n throw createDraftModeScopeError(expression);\n }\n if (currentContext.accessError) {\n throw currentContext.accessError;\n }\n return currentContext;\n}\n\n/**\n * Draft mode — check/toggle via a `__prerender_bypass` cookie.\n *\n * - `isEnabled`: true if the bypass cookie is present in the request\n * - `enable()`: sets the bypass cookie (for Route Handlers)\n * - `disable()`: clears the bypass cookie\n *\n * Unlike `headers()` / `cookies()`, calling `draftMode()` itself is allowed\n * inside `\"use cache\"` and `unstable_cache()` scopes — reads of `isEnabled`\n * are non-dynamic and supported in cached functions. Only the mutating\n * `enable()` / `disable()` methods throw when invoked inside a cache scope.\n * Ported from Next.js: packages/next/src/server/request/draft-mode.ts\n * (`getDraftModeProviderForCacheScope` + `trackDynamicDraftMode`).\n */\nexport async function draftMode(): Promise<DraftModeResult> {\n markRenderRequestApiUsage(\"draftMode\");\n\n const state = _getState();\n const context = state.headersContext;\n if (!context) {\n throw createDraftModeScopeError(\"draftMode()\");\n }\n if (context.accessError) {\n throw context.accessError;\n }\n // Reading `draftMode()` itself is not dynamic — `isEnabled` is a plain\n // getter and merely calling `draftMode()` does not require bailing out\n // of static prerendering. Only `enable()`/`disable()` mutate state and\n // must be tracked as dynamic, mirroring Next.js's `trackDynamicDraftMode`\n // (see .nextjs-ref/packages/next/src/server/request/draft-mode.ts:152-165).\n const secret = ensureContextDraftModeSecret(context);\n\n return {\n get isEnabled(): boolean {\n return context.cookies.get(DRAFT_MODE_COOKIE) === secret;\n },\n enable(): void {\n // Mutating draft mode inside a cache scope would freeze a Set-Cookie\n // side-effect into the cached entry, so Next.js throws here. Match that.\n throwIfInsideCacheScope(\"draftMode().enable()\");\n const activeContext = requireActiveDraftModeContext(state, context, \"draftMode().enable()\");\n markDynamicUsage();\n activeContext.cookies.set(DRAFT_MODE_COOKIE, secret);\n state.draftModeCookieHeader = `${DRAFT_MODE_COOKIE}=${secret}; ${draftModeCookieAttributes()}`;\n },\n disable(): void {\n throwIfInsideCacheScope(\"draftMode().disable()\");\n const activeContext = requireActiveDraftModeContext(state, context, \"draftMode().disable()\");\n markDynamicUsage();\n activeContext.cookies.delete(DRAFT_MODE_COOKIE);\n state.draftModeCookieHeader = `${DRAFT_MODE_COOKIE}=; ${draftModeCookieAttributes()}; Expires=${DRAFT_MODE_EXPIRED_DATE}`;\n },\n };\n}\n\n// ---------------------------------------------------------------------------\n// RequestCookies implementation\n// ---------------------------------------------------------------------------\n\nclass RequestCookies {\n private _cookies: Map<string, string>;\n\n constructor(cookies: Map<string, string>) {\n this._cookies = cookies;\n }\n\n get(name: string): { name: string; value: string } | undefined {\n const value = this._cookies.get(name);\n if (value === undefined) return undefined;\n return { name, value };\n }\n\n getAll(nameOrOptions?: string | { name: string }): Array<{ name: string; value: string }> {\n const name = typeof nameOrOptions === \"string\" ? nameOrOptions : nameOrOptions?.name;\n const result: Array<{ name: string; value: string }> = [];\n for (const [cookieName, value] of this._cookies) {\n if (name === undefined || cookieName === name) {\n result.push({ name: cookieName, value });\n }\n }\n return result;\n }\n\n has(name: string): boolean {\n return this._cookies.has(name);\n }\n\n /**\n * Set a cookie. In Route Handlers and Server Actions, this produces\n * a Set-Cookie header on the response.\n */\n set(\n nameOrOptions:\n | string\n | {\n name: string;\n value: string;\n path?: string;\n domain?: string;\n maxAge?: number;\n expires?: Date;\n httpOnly?: boolean;\n secure?: boolean;\n sameSite?: \"Strict\" | \"Lax\" | \"None\";\n },\n value?: string,\n options?: {\n path?: string;\n domain?: string;\n maxAge?: number;\n expires?: Date;\n httpOnly?: boolean;\n secure?: boolean;\n sameSite?: \"Strict\" | \"Lax\" | \"None\";\n },\n ): this {\n let cookieName: string;\n let cookieValue: string;\n let opts: typeof options;\n\n if (typeof nameOrOptions === \"string\") {\n cookieName = nameOrOptions;\n cookieValue = value ?? \"\";\n opts = options;\n } else {\n cookieName = nameOrOptions.name;\n cookieValue = nameOrOptions.value;\n opts = nameOrOptions;\n }\n\n validateCookieName(cookieName);\n\n // Update the local cookie map\n this._cookies.set(cookieName, cookieValue);\n\n _getState().pendingSetCookies.push(serializeSetCookie(cookieName, cookieValue, opts));\n return this;\n }\n\n /**\n * Delete a cookie by emitting an expired Set-Cookie header.\n */\n delete(nameOrOptions: string | { name: string; path?: string; domain?: string }): this {\n const name = typeof nameOrOptions === \"string\" ? nameOrOptions : nameOrOptions.name;\n const path = typeof nameOrOptions === \"string\" ? \"/\" : (nameOrOptions.path ?? \"/\");\n const domain = typeof nameOrOptions === \"string\" ? undefined : nameOrOptions.domain;\n\n validateCookieName(name);\n validateCookieAttributeValue(path, \"Path\");\n if (domain) {\n validateCookieAttributeValue(domain, \"Domain\");\n }\n\n this._cookies.delete(name);\n const parts = [`${name}=`, `Path=${path}`];\n if (domain) parts.push(`Domain=${domain}`);\n parts.push(`Expires=${EXPIRED_COOKIE_DATE}`);\n _getState().pendingSetCookies.push(parts.join(\"; \"));\n return this;\n }\n\n get size(): number {\n return this._cookies.size;\n }\n\n [Symbol.iterator](): IterableIterator<[string, { name: string; value: string }]> {\n const entries = this._cookies.entries();\n const iter: IterableIterator<[string, { name: string; value: string }]> = {\n [Symbol.iterator]() {\n return iter;\n },\n next() {\n const { value, done } = entries.next();\n if (done) return { value: undefined, done: true };\n const [name, val] = value;\n return { value: [name, { name, value: val }], done: false };\n },\n };\n return iter;\n }\n\n toString(): string {\n const parts: string[] = [];\n for (const [name, value] of this._cookies) {\n parts.push(`${name}=${value}`);\n }\n return parts.join(\"; \");\n }\n}\n\n// Re-export types\nexport type { RequestCookies };\n"],"mappings":"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"}