dev3000 0.0.126 → 0.0.128

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 (349) hide show
  1. package/dist/cdp-monitor.d.ts.map +1 -1
  2. package/dist/cdp-monitor.js +18 -0
  3. package/dist/cdp-monitor.js.map +1 -1
  4. package/dist/dev-environment.d.ts +0 -4
  5. package/dist/dev-environment.d.ts.map +1 -1
  6. package/dist/dev-environment.js +1 -236
  7. package/dist/dev-environment.js.map +1 -1
  8. package/dist/screencast-manager.d.ts +2 -1
  9. package/dist/screencast-manager.d.ts.map +1 -1
  10. package/dist/screencast-manager.js +85 -36
  11. package/dist/screencast-manager.js.map +1 -1
  12. package/dist/utils/version-check.d.ts +3 -0
  13. package/dist/utils/version-check.d.ts.map +1 -1
  14. package/dist/utils/version-check.js +13 -1
  15. package/dist/utils/version-check.js.map +1 -1
  16. package/mcp-server/.next/BUILD_ID +1 -1
  17. package/mcp-server/.next/app-path-routes-manifest.json +2 -0
  18. package/mcp-server/.next/build/chunks/[turbopack]_runtime.js +32 -7
  19. package/mcp-server/.next/build/chunks/[turbopack]_runtime.js.map +5 -5
  20. package/mcp-server/.next/build/postcss.js +1 -1
  21. package/mcp-server/.next/build/webpack-loaders.js +1 -1
  22. package/mcp-server/.next/build-manifest.json +7 -7
  23. package/mcp-server/.next/fallback-build-manifest.json +2 -2
  24. package/mcp-server/.next/next-minimal-server.js.nft.json +1 -1
  25. package/mcp-server/.next/next-server.js.nft.json +1 -1
  26. package/mcp-server/.next/prerender-manifest.json +3 -6
  27. package/mcp-server/.next/required-server-files.js +164 -0
  28. package/mcp-server/.next/required-server-files.json +39 -192
  29. package/mcp-server/.next/routes-manifest.json +13 -1
  30. package/mcp-server/.next/server/app/_global-error/page/build-manifest.json +5 -5
  31. package/mcp-server/.next/server/app/_global-error/page.js +8 -8
  32. package/mcp-server/.next/server/app/_global-error/page.js.nft.json +1 -1
  33. package/mcp-server/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  34. package/mcp-server/.next/server/app/_global-error.html +2 -2
  35. package/mcp-server/.next/server/app/_global-error.rsc +8 -8
  36. package/mcp-server/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
  37. package/mcp-server/.next/server/app/_global-error.segments/_full.segment.rsc +8 -8
  38. package/mcp-server/.next/server/app/_global-error.segments/_head.segment.rsc +4 -6
  39. package/mcp-server/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
  40. package/mcp-server/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  41. package/mcp-server/.next/server/app/_not-found/page/build-manifest.json +5 -5
  42. package/mcp-server/.next/server/app/_not-found/page.js +10 -10
  43. package/mcp-server/.next/server/app/_not-found/page.js.nft.json +1 -1
  44. package/mcp-server/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  45. package/mcp-server/.next/server/app/_not-found.html +1 -1
  46. package/mcp-server/.next/server/app/_not-found.rsc +9 -9
  47. package/mcp-server/.next/server/app/_not-found.segments/_full.segment.rsc +9 -9
  48. package/mcp-server/.next/server/app/_not-found.segments/_head.segment.rsc +4 -6
  49. package/mcp-server/.next/server/app/_not-found.segments/_index.segment.rsc +4 -4
  50. package/mcp-server/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  51. package/mcp-server/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  52. package/mcp-server/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  53. package/mcp-server/.next/server/app/api/jank/[session]/route.js +8 -8
  54. package/mcp-server/.next/server/app/api/jank/[session]/route.js.nft.json +1 -1
  55. package/mcp-server/.next/server/app/api/logs/append/route.js +4 -4
  56. package/mcp-server/.next/server/app/api/logs/append/route.js.nft.json +1 -1
  57. package/mcp-server/.next/server/app/api/logs/head/route.js +4 -4
  58. package/mcp-server/.next/server/app/api/logs/head/route.js.nft.json +1 -1
  59. package/mcp-server/.next/server/app/api/logs/list/route.js +4 -4
  60. package/mcp-server/.next/server/app/api/logs/list/route.js.nft.json +1 -1
  61. package/mcp-server/.next/server/app/api/logs/rotate/route.js +6 -6
  62. package/mcp-server/.next/server/app/api/logs/rotate/route.js.nft.json +1 -1
  63. package/mcp-server/.next/server/app/api/logs/stream/route.js +4 -4
  64. package/mcp-server/.next/server/app/api/logs/stream/route.js.nft.json +1 -1
  65. package/mcp-server/.next/server/app/api/logs/tail/route.js +4 -4
  66. package/mcp-server/.next/server/app/api/logs/tail/route.js.nft.json +1 -1
  67. package/mcp-server/.next/server/app/api/orchestrator/route.js +6 -6
  68. package/mcp-server/.next/server/app/api/orchestrator/route.js.nft.json +1 -1
  69. package/mcp-server/.next/server/app/api/screenshots/[filename]/route.js +6 -6
  70. package/mcp-server/.next/server/app/api/screenshots/[filename]/route.js.nft.json +1 -1
  71. package/mcp-server/.next/server/app/api/screenshots/capture/route/app-paths-manifest.json +3 -0
  72. package/mcp-server/.next/server/app/api/screenshots/capture/route/build-manifest.json +11 -0
  73. package/mcp-server/.next/server/app/api/screenshots/capture/route/server-reference-manifest.json +4 -0
  74. package/mcp-server/.next/server/app/api/screenshots/capture/route.js +9 -0
  75. package/mcp-server/.next/server/app/api/screenshots/capture/route.js.map +5 -0
  76. package/mcp-server/.next/server/app/api/screenshots/capture/route.js.nft.json +1 -0
  77. package/mcp-server/.next/server/app/api/screenshots/capture/route_client-reference-manifest.js +2 -0
  78. package/mcp-server/.next/server/app/api/screenshots/clear/route/app-paths-manifest.json +3 -0
  79. package/mcp-server/.next/server/app/api/screenshots/clear/route/build-manifest.json +11 -0
  80. package/mcp-server/.next/server/app/api/screenshots/clear/route/server-reference-manifest.json +4 -0
  81. package/mcp-server/.next/server/app/api/screenshots/clear/route.js +8 -0
  82. package/mcp-server/.next/server/app/api/screenshots/clear/route.js.map +5 -0
  83. package/mcp-server/.next/server/app/api/screenshots/clear/route.js.nft.json +1 -0
  84. package/mcp-server/.next/server/app/api/screenshots/clear/route_client-reference-manifest.js +2 -0
  85. package/mcp-server/.next/server/app/api/screenshots/list/route.js +6 -6
  86. package/mcp-server/.next/server/app/api/screenshots/list/route.js.nft.json +1 -1
  87. package/mcp-server/.next/server/app/api/teams/route.js +6 -6
  88. package/mcp-server/.next/server/app/api/teams/route.js.nft.json +1 -1
  89. package/mcp-server/.next/server/app/api/tools/route.js +6 -6
  90. package/mcp-server/.next/server/app/api/tools/route.js.nft.json +1 -1
  91. package/mcp-server/.next/server/app/index.html +1 -1
  92. package/mcp-server/.next/server/app/index.rsc +11 -11
  93. package/mcp-server/.next/server/app/index.segments/__PAGE__.segment.rsc +4 -4
  94. package/mcp-server/.next/server/app/index.segments/_full.segment.rsc +11 -11
  95. package/mcp-server/.next/server/app/index.segments/_head.segment.rsc +4 -6
  96. package/mcp-server/.next/server/app/index.segments/_index.segment.rsc +4 -4
  97. package/mcp-server/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  98. package/mcp-server/.next/server/app/logs/page/build-manifest.json +5 -5
  99. package/mcp-server/.next/server/app/logs/page.js +13 -13
  100. package/mcp-server/.next/server/app/logs/page.js.nft.json +1 -1
  101. package/mcp-server/.next/server/app/logs/page_client-reference-manifest.js +1 -1
  102. package/mcp-server/.next/server/app/mcp/route.js +8 -7
  103. package/mcp-server/.next/server/app/mcp/route.js.nft.json +1 -1
  104. package/mcp-server/.next/server/app/page/build-manifest.json +5 -5
  105. package/mcp-server/.next/server/app/page.js +12 -12
  106. package/mcp-server/.next/server/app/page.js.nft.json +1 -1
  107. package/mcp-server/.next/server/app/page_client-reference-manifest.js +1 -1
  108. package/mcp-server/.next/server/app/video/[session]/page/build-manifest.json +5 -5
  109. package/mcp-server/.next/server/app/video/[session]/page.js +12 -12
  110. package/mcp-server/.next/server/app/video/[session]/page.js.nft.json +1 -1
  111. package/mcp-server/.next/server/app/video/[session]/page_client-reference-manifest.js +1 -1
  112. package/mcp-server/.next/server/app-paths-manifest.json +2 -0
  113. package/mcp-server/.next/server/chunks/250ae__next-internal_server_app_api_screenshots_capture_route_actions_4034f26c.js +3 -0
  114. package/mcp-server/.next/server/chunks/250ae__next-internal_server_app_api_screenshots_clear_route_actions_e26206f4.js +3 -0
  115. package/mcp-server/.next/server/chunks/{[root-of-the-server]__86eb7852._.js → [externals]__eb460e97._.js} +2 -2
  116. package/mcp-server/.next/server/chunks/{[root-of-the-server]__2a398dc7._.js → [externals]_next_dist_2a398dc7._.js} +1 -1
  117. package/mcp-server/.next/server/chunks/{[root-of-the-server]__880af90b._.js → [root-of-the-server]__141a5bc7._.js} +6 -6
  118. package/mcp-server/.next/server/chunks/[root-of-the-server]__141a5bc7._.js.map +1 -0
  119. package/mcp-server/.next/server/chunks/[root-of-the-server]__1ca296d3._.js +3 -0
  120. package/mcp-server/.next/server/chunks/[root-of-the-server]__1ca296d3._.js.map +1 -0
  121. package/mcp-server/.next/server/chunks/[root-of-the-server]__21bdfd19._.js +3 -0
  122. package/mcp-server/.next/server/chunks/[root-of-the-server]__21bdfd19._.js.map +1 -0
  123. package/mcp-server/.next/server/chunks/[root-of-the-server]__31a16876._.js +3 -0
  124. package/mcp-server/.next/server/chunks/[root-of-the-server]__31a16876._.js.map +1 -0
  125. package/mcp-server/.next/server/chunks/[root-of-the-server]__340a77dc._.js +3 -0
  126. package/mcp-server/.next/server/chunks/{[root-of-the-server]__9a45c8f9._.js.map → [root-of-the-server]__340a77dc._.js.map} +1 -1
  127. package/mcp-server/.next/server/chunks/[root-of-the-server]__4aa77621._.js +7 -0
  128. package/mcp-server/.next/server/chunks/[root-of-the-server]__4aa77621._.js.map +1 -0
  129. package/mcp-server/.next/server/chunks/[root-of-the-server]__52809b10._.js +3 -0
  130. package/mcp-server/.next/server/chunks/[root-of-the-server]__52809b10._.js.map +1 -0
  131. package/mcp-server/.next/server/chunks/{[root-of-the-server]__72f849fd._.js → [root-of-the-server]__532c5da6._.js} +2 -2
  132. package/mcp-server/.next/server/chunks/[root-of-the-server]__714e8bcf._.js +3 -0
  133. package/mcp-server/.next/server/chunks/{[root-of-the-server]__e1a64519._.js.map → [root-of-the-server]__714e8bcf._.js.map} +1 -1
  134. package/mcp-server/.next/server/chunks/[root-of-the-server]__81270bcf._.js +3 -0
  135. package/mcp-server/.next/server/chunks/[root-of-the-server]__81270bcf._.js.map +1 -0
  136. package/mcp-server/.next/server/chunks/[root-of-the-server]__8589759c._.js +4 -0
  137. package/mcp-server/.next/server/chunks/[root-of-the-server]__8589759c._.js.map +1 -0
  138. package/mcp-server/.next/server/chunks/[root-of-the-server]__90514e85._.js +4 -0
  139. package/mcp-server/.next/server/chunks/[root-of-the-server]__90514e85._.js.map +1 -0
  140. package/mcp-server/.next/server/chunks/[root-of-the-server]__90569352._.js +3 -0
  141. package/mcp-server/.next/server/chunks/[root-of-the-server]__90569352._.js.map +1 -0
  142. package/mcp-server/.next/server/chunks/[root-of-the-server]__945b2b7b._.js +11 -0
  143. package/mcp-server/.next/server/chunks/[root-of-the-server]__945b2b7b._.js.map +1 -0
  144. package/mcp-server/.next/server/chunks/[root-of-the-server]__ad4d66b0._.js +3 -0
  145. package/mcp-server/.next/server/chunks/[root-of-the-server]__ad4d66b0._.js.map +1 -0
  146. package/mcp-server/.next/server/chunks/[root-of-the-server]__b4ecebbe._.js +3 -0
  147. package/mcp-server/.next/server/chunks/[root-of-the-server]__b4ecebbe._.js.map +1 -0
  148. package/mcp-server/.next/server/chunks/[root-of-the-server]__e7efb7fe._.js +3 -0
  149. package/mcp-server/.next/server/chunks/[root-of-the-server]__e7efb7fe._.js.map +1 -0
  150. package/mcp-server/.next/server/chunks/[root-of-the-server]__fa4b0e38._.js +4 -0
  151. package/mcp-server/.next/server/chunks/[root-of-the-server]__fa4b0e38._.js.map +1 -0
  152. package/mcp-server/.next/server/chunks/[root-of-the-server]__fd2bf649._.js +3 -0
  153. package/mcp-server/.next/server/chunks/[root-of-the-server]__fd2bf649._.js.map +1 -0
  154. package/mcp-server/.next/server/chunks/[turbopack]_runtime.js +32 -7
  155. package/mcp-server/.next/server/chunks/[turbopack]_runtime.js.map +5 -5
  156. package/mcp-server/.next/server/chunks/{8b111_next_70882466._.js → c80b1_next_d479b5fa._.js} +3 -3
  157. package/mcp-server/.next/server/chunks/c80b1_next_d479b5fa._.js.map +1 -0
  158. package/mcp-server/.next/server/chunks/c80b1_next_dist_579c473d._.js +6 -0
  159. package/mcp-server/.next/server/chunks/c80b1_next_dist_579c473d._.js.map +1 -0
  160. package/mcp-server/.next/server/chunks/c80b1_next_dist_esm_build_templates_app-route_ea10d5ad.js +3 -0
  161. package/mcp-server/.next/server/chunks/c80b1_next_dist_esm_build_templates_app-route_ea10d5ad.js.map +1 -0
  162. package/mcp-server/.next/server/chunks/c80b1_next_f225a77d._.js +3 -0
  163. package/mcp-server/.next/server/chunks/c80b1_next_f225a77d._.js.map +1 -0
  164. package/mcp-server/.next/server/chunks/{mcp-server_50ca1d40._.js → mcp-server_70405c2f._.js} +1 -1
  165. package/mcp-server/.next/server/chunks/mcp-server_app_mcp_tools_ts_faf6d7df._.js +216 -0
  166. package/mcp-server/.next/server/chunks/mcp-server_app_mcp_tools_ts_faf6d7df._.js.map +1 -0
  167. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__1d6b73d5._.js +3 -0
  168. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__baf72617._.js.map → [root-of-the-server]__1d6b73d5._.js.map} +1 -1
  169. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__27ae22d6._.js +3 -0
  170. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__ad363fb6._.js.map → [root-of-the-server]__27ae22d6._.js.map} +1 -1
  171. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__324715a4._.js +3 -0
  172. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__d9257d07._.js.map → [root-of-the-server]__324715a4._.js.map} +1 -1
  173. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__3c6c75a6._.js +3 -0
  174. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__0aa14b12._.js.map → [root-of-the-server]__3c6c75a6._.js.map} +1 -1
  175. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__5ba89445._.js → [root-of-the-server]__50b48a29._.js} +2 -2
  176. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__5ba89445._.js.map → [root-of-the-server]__50b48a29._.js.map} +1 -1
  177. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__64e0f342._.js +3 -0
  178. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__0e5de3ed._.js.map → [root-of-the-server]__64e0f342._.js.map} +1 -1
  179. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__75b45b88._.js +3 -0
  180. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__75b45b88._.js.map +1 -0
  181. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__90e175f7._.js +3 -0
  182. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__23b471c0._.js.map → [root-of-the-server]__90e175f7._.js.map} +1 -1
  183. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__ab72cb3d._.js +3 -0
  184. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__f9ee1284._.js.map → [root-of-the-server]__ab72cb3d._.js.map} +1 -1
  185. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__c73c0147._.js → [root-of-the-server]__bbed00c8._.js} +2 -2
  186. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__c73c0147._.js.map → [root-of-the-server]__bbed00c8._.js.map} +1 -1
  187. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__bc51e8b7._.js +3 -0
  188. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__016aaaae._.js.map → [root-of-the-server]__bc51e8b7._.js.map} +1 -1
  189. package/mcp-server/.next/server/chunks/ssr/[turbopack]_runtime.js +32 -7
  190. package/mcp-server/.next/server/chunks/ssr/[turbopack]_runtime.js.map +5 -5
  191. package/mcp-server/.next/server/chunks/ssr/_262bbdcd._.js +4 -0
  192. package/mcp-server/.next/server/chunks/ssr/_262bbdcd._.js.map +1 -0
  193. package/mcp-server/.next/server/chunks/ssr/{_5ba67898._.js → _9a178862._.js} +4 -4
  194. package/mcp-server/.next/server/chunks/ssr/_9a178862._.js.map +1 -0
  195. package/mcp-server/.next/server/chunks/ssr/_aabc0f14._.js +8 -0
  196. package/mcp-server/.next/server/chunks/ssr/_aabc0f14._.js.map +1 -0
  197. package/mcp-server/.next/server/chunks/ssr/_be1b41b5._.js +4 -0
  198. package/mcp-server/.next/server/chunks/ssr/_be1b41b5._.js.map +1 -0
  199. package/mcp-server/.next/server/chunks/ssr/_e92c871d._.js +4 -0
  200. package/mcp-server/.next/server/chunks/ssr/_e92c871d._.js.map +1 -0
  201. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_0d37e039._.js +3 -0
  202. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_0d37e039._.js.map +1 -0
  203. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_5f2de86d._.js +4 -0
  204. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_5f2de86d._.js.map +1 -0
  205. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_81d07c6e._.js +10 -0
  206. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_81d07c6e._.js.map +1 -0
  207. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_889a708f._.js +6 -0
  208. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_889a708f._.js.map +1 -0
  209. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_69dfdf5e._.js → c80b1_next_dist_client_components_43abb007._.js} +2 -2
  210. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_69dfdf5e._.js.map → c80b1_next_dist_client_components_43abb007._.js.map} +1 -1
  211. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_builtin_forbidden_5a705cc6.js → c80b1_next_dist_client_components_builtin_forbidden_462fb25e.js} +2 -2
  212. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_builtin_forbidden_5a705cc6.js.map → c80b1_next_dist_client_components_builtin_forbidden_462fb25e.js.map} +1 -1
  213. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_client_components_builtin_global-error_f3bf1365.js +3 -0
  214. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_builtin_global-error_d996306b.js.map → c80b1_next_dist_client_components_builtin_global-error_f3bf1365.js.map} +1 -1
  215. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_builtin_unauthorized_0df11997.js → c80b1_next_dist_client_components_builtin_unauthorized_9a1b3d4d.js} +2 -2
  216. package/mcp-server/.next/server/chunks/ssr/{8b111_next_dist_client_components_builtin_unauthorized_0df11997.js.map → c80b1_next_dist_client_components_builtin_unauthorized_9a1b3d4d.js.map} +1 -1
  217. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_esm_build_templates_app-page_9b0ce51c.js +4 -0
  218. package/mcp-server/.next/server/chunks/ssr/c80b1_next_dist_esm_build_templates_app-page_9b0ce51c.js.map +1 -0
  219. package/mcp-server/.next/server/chunks/ssr/mcp-server_app_layout_tsx_afa41767._.js +1 -1
  220. package/mcp-server/.next/server/chunks/ssr/mcp-server_app_page_tsx_9fc46577._.js +1 -1
  221. package/mcp-server/.next/server/chunks/ssr/mcp-server_components_dark-mode-toggle_tsx_f31dd15d._.js +1 -1
  222. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_98754805._.js +5 -0
  223. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_98754805._.js.map +1 -0
  224. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_b801224a._.js +3 -0
  225. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_b801224a._.js.map +1 -0
  226. package/mcp-server/.next/server/functions-config-manifest.json +1 -11
  227. package/mcp-server/.next/server/instrumentation.js +1 -1
  228. package/mcp-server/.next/server/instrumentation.js.nft.json +1 -1
  229. package/mcp-server/.next/server/middleware-build-manifest.js +5 -5
  230. package/mcp-server/.next/server/pages/404.html +1 -1
  231. package/mcp-server/.next/server/pages/500.html +2 -2
  232. package/mcp-server/.next/server/server-reference-manifest.js +1 -1
  233. package/mcp-server/.next/server/server-reference-manifest.json +1 -1
  234. package/mcp-server/.next/static/1tSGEmFktuD3B97MIF49Q/_clientMiddlewareManifest.json +1 -0
  235. package/mcp-server/.next/static/chunks/0ceacd9ff62ffa24.js +1 -0
  236. package/mcp-server/.next/static/chunks/{5171d9a831cc2de4.js → 41c5312e59752fb5.js} +1 -1
  237. package/mcp-server/.next/static/chunks/47219b9a153e0530.js +3 -0
  238. package/mcp-server/.next/static/chunks/4b70aaeeb4b78390.js +1 -0
  239. package/mcp-server/.next/static/chunks/59cdeaf92a780e96.css +1 -0
  240. package/mcp-server/.next/static/chunks/5c8ff2f81b2fec4d.js +3 -0
  241. package/mcp-server/.next/static/chunks/6bd8e9b9ad938cba.js +1 -0
  242. package/mcp-server/.next/static/chunks/{3d612a0a5e49885d.js → 86092b19e32d6ddb.js} +1 -1
  243. package/mcp-server/.next/static/chunks/a6dad97d9634a72d.js.map +1 -0
  244. package/mcp-server/.next/static/chunks/a782bd48b8755eeb.js +1 -0
  245. package/mcp-server/.next/static/chunks/{95b89db5d1d54841.js → ba2f63419c181083.js} +1 -1
  246. package/mcp-server/.next/static/chunks/f09e07f5359ffb6b.js +4 -0
  247. package/mcp-server/.next/static/chunks/f5ae99caea655ac1.js +2 -0
  248. package/mcp-server/.next/static/chunks/turbopack-2c2bdfdb92058782.js +4 -0
  249. package/mcp-server/app/api/screenshots/capture/route.ts +137 -0
  250. package/mcp-server/app/api/screenshots/clear/route.ts +44 -0
  251. package/mcp-server/app/mcp/route.ts +80 -45
  252. package/mcp-server/app/mcp/tools.ts +6 -2
  253. package/mcp-server/package.json +1 -1
  254. package/package.json +2 -2
  255. package/mcp-server/.next/server/chunks/8b111_next_1353f498._.js +0 -3
  256. package/mcp-server/.next/server/chunks/8b111_next_1353f498._.js.map +0 -1
  257. package/mcp-server/.next/server/chunks/8b111_next_70882466._.js.map +0 -1
  258. package/mcp-server/.next/server/chunks/8b111_next_dist_b45da2c0._.js +0 -6
  259. package/mcp-server/.next/server/chunks/8b111_next_dist_b45da2c0._.js.map +0 -1
  260. package/mcp-server/.next/server/chunks/8b111_next_dist_esm_build_templates_app-route_61845054.js +0 -3
  261. package/mcp-server/.next/server/chunks/8b111_next_dist_esm_build_templates_app-route_61845054.js.map +0 -1
  262. package/mcp-server/.next/server/chunks/[root-of-the-server]__11cde0db._.js +0 -3
  263. package/mcp-server/.next/server/chunks/[root-of-the-server]__11cde0db._.js.map +0 -1
  264. package/mcp-server/.next/server/chunks/[root-of-the-server]__3ac957e6._.js +0 -3
  265. package/mcp-server/.next/server/chunks/[root-of-the-server]__45cf400e._.js +0 -7
  266. package/mcp-server/.next/server/chunks/[root-of-the-server]__45cf400e._.js.map +0 -1
  267. package/mcp-server/.next/server/chunks/[root-of-the-server]__5e1331cc._.js +0 -3
  268. package/mcp-server/.next/server/chunks/[root-of-the-server]__5e1331cc._.js.map +0 -1
  269. package/mcp-server/.next/server/chunks/[root-of-the-server]__7a6a57a4._.js +0 -3
  270. package/mcp-server/.next/server/chunks/[root-of-the-server]__7a6a57a4._.js.map +0 -1
  271. package/mcp-server/.next/server/chunks/[root-of-the-server]__8173a02b._.js +0 -3
  272. package/mcp-server/.next/server/chunks/[root-of-the-server]__8173a02b._.js.map +0 -1
  273. package/mcp-server/.next/server/chunks/[root-of-the-server]__880af90b._.js.map +0 -1
  274. package/mcp-server/.next/server/chunks/[root-of-the-server]__92444e87._.js +0 -3
  275. package/mcp-server/.next/server/chunks/[root-of-the-server]__92444e87._.js.map +0 -1
  276. package/mcp-server/.next/server/chunks/[root-of-the-server]__97925d45._.js +0 -3
  277. package/mcp-server/.next/server/chunks/[root-of-the-server]__97925d45._.js.map +0 -1
  278. package/mcp-server/.next/server/chunks/[root-of-the-server]__9a45c8f9._.js +0 -3
  279. package/mcp-server/.next/server/chunks/[root-of-the-server]__9be3321c._.js +0 -4
  280. package/mcp-server/.next/server/chunks/[root-of-the-server]__9be3321c._.js.map +0 -1
  281. package/mcp-server/.next/server/chunks/[root-of-the-server]__ae49815f._.js +0 -217
  282. package/mcp-server/.next/server/chunks/[root-of-the-server]__ae49815f._.js.map +0 -1
  283. package/mcp-server/.next/server/chunks/[root-of-the-server]__d4d47e5f._.js +0 -28
  284. package/mcp-server/.next/server/chunks/[root-of-the-server]__d4d47e5f._.js.map +0 -1
  285. package/mcp-server/.next/server/chunks/[root-of-the-server]__e1a64519._.js +0 -3
  286. package/mcp-server/.next/server/chunks/[root-of-the-server]__f2de2bac._.js +0 -3
  287. package/mcp-server/.next/server/chunks/[root-of-the-server]__f2de2bac._.js.map +0 -1
  288. package/mcp-server/.next/server/chunks/[root-of-the-server]__f449fffa._.js +0 -11
  289. package/mcp-server/.next/server/chunks/[root-of-the-server]__f449fffa._.js.map +0 -1
  290. package/mcp-server/.next/server/chunks/[root-of-the-server]__f9975293._.js +0 -3
  291. package/mcp-server/.next/server/chunks/[root-of-the-server]__f9975293._.js.map +0 -1
  292. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_2d5fda8a._.js +0 -6
  293. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_2d5fda8a._.js.map +0 -1
  294. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_416feb3b._.js +0 -6
  295. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_416feb3b._.js.map +0 -1
  296. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_a0631e8f._.js +0 -3
  297. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_a0631e8f._.js.map +0 -1
  298. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_bc5bff92._.js +0 -4
  299. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_bc5bff92._.js.map +0 -1
  300. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_client_components_builtin_global-error_d996306b.js +0 -3
  301. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_esm_build_templates_app-page_4117d230.js +0 -4
  302. package/mcp-server/.next/server/chunks/ssr/8b111_next_dist_esm_build_templates_app-page_4117d230.js.map +0 -1
  303. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__016aaaae._.js +0 -3
  304. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__0aa14b12._.js +0 -3
  305. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__0e5de3ed._.js +0 -3
  306. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__23b471c0._.js +0 -3
  307. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__ad363fb6._.js +0 -3
  308. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__baf72617._.js +0 -3
  309. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__bf7cd8c6._.js +0 -3
  310. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__d9257d07._.js +0 -3
  311. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__f9ee1284._.js +0 -3
  312. package/mcp-server/.next/server/chunks/ssr/_2eb35278._.js +0 -4
  313. package/mcp-server/.next/server/chunks/ssr/_2eb35278._.js.map +0 -1
  314. package/mcp-server/.next/server/chunks/ssr/_3b1c49b6._.js +0 -4
  315. package/mcp-server/.next/server/chunks/ssr/_3b1c49b6._.js.map +0 -1
  316. package/mcp-server/.next/server/chunks/ssr/_5ba67898._.js.map +0 -1
  317. package/mcp-server/.next/server/chunks/ssr/_af685f91._.js +0 -8
  318. package/mcp-server/.next/server/chunks/ssr/_af685f91._.js.map +0 -1
  319. package/mcp-server/.next/server/chunks/ssr/_ba028667._.js +0 -4
  320. package/mcp-server/.next/server/chunks/ssr/_ba028667._.js.map +0 -1
  321. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_3bd414fc._.js +0 -5
  322. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_3bd414fc._.js.map +0 -1
  323. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_9d64b6f5._.js +0 -3
  324. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_9d64b6f5._.js.map +0 -1
  325. package/mcp-server/.next/server/middleware.js +0 -5
  326. package/mcp-server/.next/server/middleware.js.nft.json +0 -1
  327. package/mcp-server/.next/static/chunks/37739dbbbff41860.js +0 -2
  328. package/mcp-server/.next/static/chunks/45ba9786ab8c2e44.js +0 -1
  329. package/mcp-server/.next/static/chunks/9af9038936981171.js +0 -3
  330. package/mcp-server/.next/static/chunks/9d9ea52745b7cee8.css +0 -1
  331. package/mcp-server/.next/static/chunks/a3771e169e1ff356.js +0 -1
  332. package/mcp-server/.next/static/chunks/a92901311ade94f3.js +0 -4
  333. package/mcp-server/.next/static/chunks/b3811fb9af254076.js +0 -1
  334. package/mcp-server/.next/static/chunks/eb96b27d3b73ef3b.js +0 -3
  335. package/mcp-server/.next/static/chunks/f9a2399752a0a1fa.js +0 -1
  336. package/mcp-server/.next/static/chunks/turbopack-39686e05867003be.js +0 -3
  337. package/mcp-server/.next/static/lSzvvkjD4ab_1CtchfQYo/_clientMiddlewareManifest.json +0 -6
  338. /package/mcp-server/.next/build/chunks/{[turbopack-node]_transforms_postcss_ts_80bff36f._.js → [turbopack-node]_transforms_postcss_ts_7988927e._.js} +0 -0
  339. /package/mcp-server/.next/build/chunks/{[turbopack-node]_transforms_postcss_ts_80bff36f._.js.map → [turbopack-node]_transforms_postcss_ts_7988927e._.js.map} +0 -0
  340. /package/mcp-server/.next/build/chunks/{[turbopack-node]_transforms_webpack-loaders_ts_c84aa21a._.js → [turbopack-node]_transforms_webpack-loaders_ts_1efa112f._.js} +0 -0
  341. /package/mcp-server/.next/build/chunks/{[turbopack-node]_transforms_webpack-loaders_ts_c84aa21a._.js.map → [turbopack-node]_transforms_webpack-loaders_ts_1efa112f._.js.map} +0 -0
  342. /package/mcp-server/.next/server/chunks/{[root-of-the-server]__2a398dc7._.js.map → 250ae__next-internal_server_app_api_screenshots_capture_route_actions_4034f26c.js.map} +0 -0
  343. /package/mcp-server/.next/server/chunks/{[root-of-the-server]__3ac957e6._.js.map → 250ae__next-internal_server_app_api_screenshots_clear_route_actions_e26206f4.js.map} +0 -0
  344. /package/mcp-server/.next/server/chunks/{[root-of-the-server]__72f849fd._.js.map → [externals]__eb460e97._.js.map} +0 -0
  345. /package/mcp-server/.next/server/chunks/{[root-of-the-server]__86eb7852._.js.map → [externals]_next_dist_2a398dc7._.js.map} +0 -0
  346. /package/mcp-server/.next/server/chunks/{ssr/[root-of-the-server]__bf7cd8c6._.js.map → [root-of-the-server]__532c5da6._.js.map} +0 -0
  347. /package/mcp-server/.next/server/chunks/{mcp-server_50ca1d40._.js.map → mcp-server_70405c2f._.js.map} +0 -0
  348. /package/mcp-server/.next/static/{lSzvvkjD4ab_1CtchfQYo → 1tSGEmFktuD3B97MIF49Q}/_buildManifest.js +0 -0
  349. /package/mcp-server/.next/static/{lSzvvkjD4ab_1CtchfQYo → 1tSGEmFktuD3B97MIF49Q}/_ssgManifest.js +0 -0
@@ -1,3 +0,0 @@
1
- module.exports=[8133,e=>{"use strict";var t=e.i(7479),a=e.i(3797),n=e.i(66154),r=e.i(36096),i=e.i(54296),o=e.i(23249),s=e.i(33185),l=e.i(84521),d=e.i(67707),c=e.i(86157),u=e.i(87608),h=e.i(48432),p=e.i(77430),f=e.i(45577),g=e.i(92366),m=e.i(97691),R=e.i(93695);e.i(24496);var w=e.i(91349),x=e.i(22734),v=e.i(76494),y=e.i(46786),S=e.i(14747),C=e.i(73169),N=e.i(60801);async function A(e,t){try{let a=(0,S.join)(e,`${t}-metadata.json`);if(!(0,x.existsSync)(a))return null;let n=JSON.parse((0,x.readFileSync)(a,"utf-8"));if(!n.layoutShifts||0===n.layoutShifts.length)return null;return{shifts:n.layoutShifts,totalCLS:n.totalCLS||0,grade:n.clsGrade||"unknown",cssViewport:n.cssViewport}}catch(e){return console.error("Failed to fetch real CLS data:",e),null}}async function E(e,{params:t}){let{session:a}=await t,n=process.env.SCREENSHOT_DIR||(0,S.join)((0,y.tmpdir)(),"dev3000-mcp-deps","public","screenshots"),r=await A(n,a);if(r&&0===r.shifts.length)return v.NextResponse.json({clsMarkers:[],source:"performance-observer",actualCLS:0,grade:"good",message:"No layout shifts detected by PerformanceObserver"});if(!(0,x.existsSync)(n))return v.NextResponse.json({clsMarkers:[]});let i=(0,x.readdirSync)(n).filter(e=>e.startsWith(a)&&e.includes("-jank-")&&e.endsWith(".png")).sort((e,t)=>parseInt(e.match(/-(\d+)ms\.png$/)?.[1]||"0",10)-parseInt(t.match(/-(\d+)ms\.png$/)?.[1]||"0",10));if(i.length<2)return v.NextResponse.json({clsMarkers:[]});let o=[],s=[];for(let e=1;e<i.length;e++){let t=(0,S.join)(n,i[e-1]),a=(0,S.join)(n,i[e]);try{let n=N.PNG.sync.read((0,x.readFileSync)(t)),r=N.PNG.sync.read((0,x.readFileSync)(a));if(n.width!==r.width||n.height!==r.height)continue;let l=new N.PNG({width:n.width,height:n.height}),d=(0,C.default)(n.data,r.data,l.data,n.width,n.height,{threshold:.1}),c=n.width*n.height,u=d/c*100;if(u<.05)continue;let h=Array(n.height).fill(0);for(let e=0;e<n.height;e++)for(let t=0;t<n.width;t++){let a=(n.width*e+t)*4;(l.data[a]>0||l.data[a+1]>0||l.data[a+2]>0)&&h[e]++}let p=[],f=-1,g=0;for(let e=0;e<n.height;e++){let t=h[e]/n.width*100;t>10?-1===f?(f=e,g=t):g=Math.max(g,t):-1!==f&&(p.push({startY:f,endY:e-1,intensity:g}),f=-1,g=0)}if(-1!==f&&p.push({startY:f,endY:n.height-1,intensity:g}),(p=p.filter(e=>e.endY-e.startY>=5&&e.intensity>20)).length>0){let t=n.width,a=n.height,r=0,d=0;for(let e of p)for(let i=e.startY;i<=e.endY;i++)for(let e=0;e<n.width;e++){let o=(n.width*i+e)*4;(l.data[o]>0||l.data[o+1]>0||l.data[o+2]>0)&&(t=Math.min(t,e),a=Math.min(a,i),r=Math.max(r,e),d=Math.max(d,i))}if(s.push({comparison:`${i[e-1]} vs ${i[e]}`,diffPercentage:Number.parseFloat(u.toFixed(2)),shiftRegions:p.length,isValid:!0}),t<r&&a<d){let s=i[e].match(/-(\d+)ms\.png$/),l=s?parseInt(s[1],10):0,c={x:Math.max(0,t-10),y:Math.max(0,a-10),width:Math.min(n.width,r-t+20),height:Math.min(n.height,d-a+20)},u=c.width*c.height,h=n.width*n.height,p=u/h*100,f=u<.5*h?c:null;console.log("[JANK API] Pixel-diff bounding box:",{boundingBox:c,areaPercentage:`${p.toFixed(2)}%`,rejected:!f,reason:f?"accepted":"too large (>50% of screen)"}),o.push({timestamp:l,boundingBox:f})}}else s.push({comparison:`${i[e-1]} vs ${i[e]}`,diffPercentage:Number.parseFloat(u.toFixed(2)),shiftRegions:0,isValid:!1})}catch{}}let l=1920,d=1080;if(i.length>0)try{let e=N.PNG.sync.read((0,x.readFileSync)((0,S.join)(n,i[0])));l=e.width,d=e.height}catch{}if(r){let e=r.shifts.map(e=>{let t=null,a=1/0;for(let n of o){let r=Math.abs(e.timestamp-n.timestamp);r<50&&r<a&&(t=n,a=r)}if(!t)return null;let n=e.sources?.[0],i=t.boundingBox;if(n?.actualRect&&r?.cssViewport){let e=n.actualRect,t=r.cssViewport.width,a=r.cssViewport.height;console.log("[JANK API] actualRect (CSS pixels):",e),console.log("[JANK API] CSS viewport:",{width:t,height:a}),console.log("[JANK API] Screenshot dimensions:",{width:l,height:d});let o=l/t,s=d/a;console.log("[JANK API] Calculated scale:",{x:o.toFixed(3),y:s.toFixed(3)}),console.log("[JANK API] Bounding box (screenshot pixels):",i={x:Math.round(e.x*o),y:Math.round(e.y*s),width:Math.round(e.width*o),height:Math.round(e.height*s)})}else console.log("[JANK API] No actualRect or cssViewport available, cannot determine bounding box");return{...t,boundingBox:i,clsScore:e.score,element:n?.node||"unknown"}}).filter(Boolean);return v.NextResponse.json({clsMarkers:e,realLayoutShifts:r.shifts,debug:s,source:"performance-observer-validated",actualCLS:r.totalCLS,grade:r.grade,note:`Real CLS: ${r.totalCLS.toFixed(4)} (${r.grade}). Filtered ${o.length-e.length} false positives from pixel-diff.`})}return v.NextResponse.json({clsMarkers:o,debug:s,source:"pixel-diff-fallback",note:"PerformanceObserver data not available, using pixel-diff analysis (may include false positives)"})}e.s(["GET",()=>E],57300);var b=e.i(57300);let P=new t.AppRouteRouteModule({definition:{kind:a.RouteKind.APP_ROUTE,page:"/api/jank/[session]/route",pathname:"/api/jank/[session]",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/mcp-server/app/api/jank/[session]/route.ts",nextConfigOutput:"",userland:b}),{workAsyncStorage:M,workUnitAsyncStorage:I,serverHooks:T}=P;function k(){return(0,n.patchFetch)({workAsyncStorage:M,workUnitAsyncStorage:I})}async function O(e,t,n){P.isDev&&(0,r.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let x="/api/jank/[session]/route";x=x.replace(/\/index$/,"")||"/";let v=await P.prepare(e,t,{srcPage:x,multiZoneDraftMode:!1});if(!v)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:y,params:S,nextConfig:C,parsedUrl:N,isDraftMode:A,prerenderManifest:E,routerServerContext:b,isOnDemandRevalidate:M,revalidateOnlyGenerated:I,resolvedPathname:T,clientReferenceManifest:k,serverActionsManifest:O}=v,j=(0,l.normalizeAppPath)(x),F=!!(E.dynamicRoutes[j]||E.routes[T]),$=async()=>((null==b?void 0:b.render404)?await b.render404(e,t,N,!1):t.end("This page could not be found"),null);if(F&&!A){let e=!!E.routes[T],t=E.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(C.experimental.adapterPath)return await $();throw new R.NoFallbackError}}let _=null;!F||P.isDev||A||(_="/index"===(_=T)?"/":_);let H=!0===P.isDev||!F,U=F&&!H;O&&k&&(0,o.setReferenceManifestsSingleton)({page:x,clientReferenceManifest:k,serverActionsManifest:O,serverModuleMap:(0,s.createServerModuleMap)({serverActionsManifest:O})});let K=e.method||"GET",q=(0,i.getTracer)(),D=q.getActiveScopeSpan(),L={params:S,prerenderManifest:E,renderOpts:{experimental:{authInterrupts:!!C.experimental.authInterrupts},cacheComponents:!!C.cacheComponents,supportsDynamicResponse:H,incrementalCache:(0,r.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:C.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,n)=>P.onRequestError(e,t,n,b)},sharedContext:{buildId:y}},V=new d.NodeNextRequest(e),B=new d.NodeNextResponse(t),G=c.NextRequestAdapter.fromNodeNextRequest(V,(0,c.signalFromNodeResponse)(t));try{let o=async e=>P.handle(G,L).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=q.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==u.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=a.get("next.route");if(n){let t=`${K} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${K} ${x}`)}),s=!!(0,r.getRequestMeta)(e,"minimalMode"),l=async r=>{var i,l;let d=async({previousCacheEntry:a})=>{try{if(!s&&M&&I&&!a)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await o(r);e.fetchMetrics=L.renderOpts.fetchMetrics;let l=L.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let d=L.renderOpts.collectedTags;if(!F)return await (0,p.sendResponse)(V,B,i,L.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(i.headers);d&&(t[m.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==L.renderOpts.collectedRevalidate&&!(L.renderOpts.collectedRevalidate>=m.INFINITE_CACHE)&&L.renderOpts.collectedRevalidate,n=void 0===L.renderOpts.collectedExpire||L.renderOpts.collectedExpire>=m.INFINITE_CACHE?void 0:L.renderOpts.collectedExpire;return{value:{kind:w.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:n}}}}catch(t){throw(null==a?void 0:a.isStale)&&await P.onRequestError(e,t,{routerKind:"App Router",routePath:x,routeType:"route",revalidateReason:(0,h.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:M})},b),t}},c=await P.handleResponse({req:e,nextConfig:C,cacheKey:_,routeKind:a.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:E,isRoutePPREnabled:!1,isOnDemandRevalidate:M,revalidateOnlyGenerated:I,responseGenerator:d,waitUntil:n.waitUntil,isMinimalMode:s});if(!F)return null;if((null==c||null==(i=c.value)?void 0:i.kind)!==w.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(l=c.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});s||t.setHeader("x-nextjs-cache",M?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let u=(0,f.fromNodeOutgoingHttpHeaders)(c.value.headers);return s&&F||u.delete(m.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||u.get("Cache-Control")||u.set("Cache-Control",(0,g.getCacheControlHeader)(c.cacheControl)),await (0,p.sendResponse)(V,B,new Response(c.value.body,{headers:u,status:c.value.status||200})),null};D?await l(D):await q.withPropagatedContext(e.headers,()=>q.trace(u.BaseServerSpan.handleRequest,{spanName:`${K} ${x}`,kind:i.SpanKind.SERVER,attributes:{"http.method":K,"http.target":e.url}},l))}catch(t){if(t instanceof R.NoFallbackError||await P.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,h.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:M})}),F)throw t;return await (0,p.sendResponse)(V,B,new Response(null,{status:500})),null}}e.s(["handler",()=>O,"patchFetch",()=>k,"routeModule",()=>P,"serverHooks",()=>T,"workAsyncStorage",()=>M,"workUnitAsyncStorage",()=>I],8133)}];
2
-
3
- //# sourceMappingURL=8b111_next_dist_esm_build_templates_app-route_61845054.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../mcp-server/app/api/jank/%5Bsession%5D/route.ts","../../../../node_modules/.pnpm/next%4016.0.7_%40opentelemetry%2Bapi%401.9.0_babel-plugin-react-compiler%401.0.0_react-dom%4019.3.0_a20848594014cb183ab624f2be88a203/node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import { existsSync, readdirSync, readFileSync } from \"fs\"\nimport { type NextRequest, NextResponse } from \"next/server\"\nimport { tmpdir } from \"os\"\nimport { join } from \"path\"\nimport pixelmatch from \"pixelmatch\"\nimport { PNG } from \"pngjs\"\n\n/**\n * Fetch real CLS data from screencast metadata\n * ScreencastManager now injects a PerformanceObserver to capture real layout shifts\n */\nasync function getRealCLSData(\n screenshotDir: string,\n session: string\n): Promise<{\n shifts: Array<{ score: number; timestamp: number; sources?: unknown[] }>\n totalCLS: number\n grade: string\n cssViewport?: { width: number; height: number; devicePixelRatio: number }\n} | null> {\n try {\n const metadataPath = join(screenshotDir, `${session}-metadata.json`)\n if (!existsSync(metadataPath)) {\n return null\n }\n\n const metadata = JSON.parse(readFileSync(metadataPath, \"utf-8\"))\n if (!metadata.layoutShifts || metadata.layoutShifts.length === 0) {\n return null\n }\n\n return {\n shifts: metadata.layoutShifts,\n totalCLS: metadata.totalCLS || 0,\n grade: metadata.clsGrade || \"unknown\",\n cssViewport: metadata.cssViewport\n }\n } catch (error) {\n console.error(\"Failed to fetch real CLS data:\", error)\n return null\n }\n}\n\nexport async function GET(_request: NextRequest, { params }: { params: Promise<{ session: string }> }) {\n const { session } = await params\n const screenshotDir = process.env.SCREENSHOT_DIR || join(tmpdir(), \"dev3000-mcp-deps\", \"public\", \"screenshots\")\n\n // Try to get real CLS data from screencast metadata\n const realCLS = await getRealCLSData(screenshotDir, session)\n\n if (realCLS && realCLS.shifts.length === 0) {\n // No layout shifts detected by PerformanceObserver\n return NextResponse.json({\n clsMarkers: [],\n source: \"performance-observer\",\n actualCLS: 0,\n grade: \"good\",\n message: \"No layout shifts detected by PerformanceObserver\"\n })\n }\n\n if (!existsSync(screenshotDir)) {\n return NextResponse.json({ clsMarkers: [] })\n }\n\n // Find files for this session\n const files = readdirSync(screenshotDir)\n const sessionFiles = files\n .filter((f) => f.startsWith(session) && f.includes(\"-jank-\") && f.endsWith(\".png\"))\n .sort((a, b) => {\n const aTime = parseInt(a.match(/-(\\d+)ms\\.png$/)?.[1] || \"0\", 10)\n const bTime = parseInt(b.match(/-(\\d+)ms\\.png$/)?.[1] || \"0\", 10)\n return aTime - bTime\n })\n\n if (sessionFiles.length < 2) {\n return NextResponse.json({ clsMarkers: [] })\n }\n\n const clsMarkers: Array<{\n timestamp: number\n boundingBox: { x: number; y: number; width: number; height: number } | null\n }> = []\n\n const debugInfo: Array<{\n comparison: string\n diffPercentage: number\n shiftRegions?: number\n isValid: boolean\n }> = []\n\n // Compare consecutive frames\n for (let i = 1; i < sessionFiles.length; i++) {\n const prevFile = join(screenshotDir, sessionFiles[i - 1])\n const currFile = join(screenshotDir, sessionFiles[i])\n\n try {\n const prevPng = PNG.sync.read(readFileSync(prevFile))\n const currPng = PNG.sync.read(readFileSync(currFile))\n\n if (prevPng.width !== currPng.width || prevPng.height !== currPng.height) {\n continue\n }\n\n const diff = new PNG({ width: prevPng.width, height: prevPng.height })\n const numDiffPixels = pixelmatch(prevPng.data, currPng.data, diff.data, prevPng.width, prevPng.height, {\n threshold: 0.1\n })\n\n const totalPixels = prevPng.width * prevPng.height\n const diffPercentage = (numDiffPixels / totalPixels) * 100\n\n // Skip if almost no changes (< 0.05% = likely just anti-aliasing)\n if (diffPercentage < 0.05) {\n continue\n }\n\n // Detect LAYOUT SHIFTS by looking for horizontal bands of changes\n // (content moving down/up will create horizontal bands of differences)\n const rowChangeCounts = new Array(prevPng.height).fill(0)\n\n for (let y = 0; y < prevPng.height; y++) {\n for (let x = 0; x < prevPng.width; x++) {\n const idx = (prevPng.width * y + x) * 4\n if (diff.data[idx] > 0 || diff.data[idx + 1] > 0 || diff.data[idx + 2] > 0) {\n rowChangeCounts[y]++\n }\n }\n }\n\n // Find regions with significant row changes (indicating vertical shifts)\n let shiftRegions: Array<{ startY: number; endY: number; intensity: number }> = []\n let currentRegionStart = -1\n let currentRegionIntensity = 0\n\n for (let y = 0; y < prevPng.height; y++) {\n const rowChangePercentage = (rowChangeCounts[y] / prevPng.width) * 100\n\n // If this row has significant changes (>10% of pixels in the row changed)\n if (rowChangePercentage > 10) {\n if (currentRegionStart === -1) {\n currentRegionStart = y\n currentRegionIntensity = rowChangePercentage\n } else {\n currentRegionIntensity = Math.max(currentRegionIntensity, rowChangePercentage)\n }\n } else if (currentRegionStart !== -1) {\n // End of a shift region\n shiftRegions.push({\n startY: currentRegionStart,\n endY: y - 1,\n intensity: currentRegionIntensity\n })\n currentRegionStart = -1\n currentRegionIntensity = 0\n }\n }\n\n // Close final region if needed\n if (currentRegionStart !== -1) {\n shiftRegions.push({\n startY: currentRegionStart,\n endY: prevPng.height - 1,\n intensity: currentRegionIntensity\n })\n }\n\n // Filter shift regions: must be at least 5px tall and have high intensity\n shiftRegions = shiftRegions.filter((region) => {\n const height = region.endY - region.startY\n return height >= 5 && region.intensity > 20\n })\n\n // If we found layout shift regions, calculate bounding box\n if (shiftRegions.length > 0) {\n let minX = prevPng.width\n let minY = prevPng.height\n let maxX = 0\n let maxY = 0\n\n for (const region of shiftRegions) {\n for (let y = region.startY; y <= region.endY; y++) {\n for (let x = 0; x < prevPng.width; x++) {\n const idx = (prevPng.width * y + x) * 4\n if (diff.data[idx] > 0 || diff.data[idx + 1] > 0 || diff.data[idx + 2] > 0) {\n minX = Math.min(minX, x)\n minY = Math.min(minY, y)\n maxX = Math.max(maxX, x)\n maxY = Math.max(maxY, y)\n }\n }\n }\n }\n\n // Collect debug info\n debugInfo.push({\n comparison: `${sessionFiles[i - 1]} vs ${sessionFiles[i]}`,\n diffPercentage: Number.parseFloat(diffPercentage.toFixed(2)),\n shiftRegions: shiftRegions.length,\n isValid: true\n })\n\n if (minX < maxX && minY < maxY) {\n const timeMatch = sessionFiles[i].match(/-(\\d+)ms\\.png$/)\n const timeSinceStart = timeMatch ? parseInt(timeMatch[1], 10) : 0\n\n // Add padding to bounding box (10px)\n const padding = 10\n const boundingBox = {\n x: Math.max(0, minX - padding),\n y: Math.max(0, minY - padding),\n width: Math.min(prevPng.width, maxX - minX + padding * 2),\n height: Math.min(prevPng.height, maxY - minY + padding * 2)\n }\n\n // Only include bounding box if it's reasonable (< 50% of screen)\n // If it's too large, the detection is likely inaccurate\n const boxArea = boundingBox.width * boundingBox.height\n const screenArea = prevPng.width * prevPng.height\n const areaPercentage = (boxArea / screenArea) * 100\n const boundingBoxToUse = boxArea < screenArea * 0.5 ? boundingBox : null\n\n console.log(\"[JANK API] Pixel-diff bounding box:\", {\n boundingBox,\n areaPercentage: `${areaPercentage.toFixed(2)}%`,\n rejected: !boundingBoxToUse,\n reason: !boundingBoxToUse ? \"too large (>50% of screen)\" : \"accepted\"\n })\n\n clsMarkers.push({ timestamp: timeSinceStart, boundingBox: boundingBoxToUse })\n }\n } else {\n // No shift regions found - likely just content changes (images loading)\n debugInfo.push({\n comparison: `${sessionFiles[i - 1]} vs ${sessionFiles[i]}`,\n diffPercentage: Number.parseFloat(diffPercentage.toFixed(2)),\n shiftRegions: 0,\n isValid: false\n })\n }\n } catch {\n // Skip frames that can't be compared\n }\n }\n\n // Get screenshot dimensions to calculate coordinate scaling\n let screenshotWidth = 1920 // default\n let screenshotHeight = 1080 // default\n if (sessionFiles.length > 0) {\n try {\n const firstScreenshot = PNG.sync.read(readFileSync(join(screenshotDir, sessionFiles[0])))\n screenshotWidth = firstScreenshot.width\n screenshotHeight = firstScreenshot.height\n } catch {\n // Use defaults\n }\n }\n\n // If we have real CLS data, cross-reference with pixel-diff to filter false positives\n if (realCLS) {\n // Match each real CLS shift to the closest pixel-diff marker\n // This avoids duplicate markers for the same shift\n const filteredMarkers = realCLS.shifts\n .map((shift) => {\n // Find closest pixel-diff marker within 50ms\n let closestMarker = null\n let closestDistance = Infinity\n\n for (const marker of clsMarkers) {\n const distance = Math.abs(shift.timestamp - marker.timestamp)\n if (distance < 50 && distance < closestDistance) {\n closestMarker = marker\n closestDistance = distance\n }\n }\n\n if (!closestMarker) return null\n\n // Try to use real CLS bounding box if available\n const source = shift.sources?.[0] as {\n node?: string\n previousRect?: { x: number; y: number; width: number; height: number }\n currentRect?: { x: number; y: number; width: number; height: number }\n actualRect?: { x: number; y: number; width: number; height: number }\n }\n let boundingBox = closestMarker.boundingBox\n\n // Prefer actualRect (queried via querySelector) - it's in CSS pixels relative to viewport\n // Convert to screenshot pixels using CSS viewport dimensions\n if (source?.actualRect && realCLS?.cssViewport) {\n const cssRect = source.actualRect\n const cssViewportWidth = realCLS.cssViewport.width\n const cssViewportHeight = realCLS.cssViewport.height\n\n console.log(\"[JANK API] actualRect (CSS pixels):\", cssRect)\n console.log(\"[JANK API] CSS viewport:\", { width: cssViewportWidth, height: cssViewportHeight })\n console.log(\"[JANK API] Screenshot dimensions:\", { width: screenshotWidth, height: screenshotHeight })\n\n // Calculate scale factor: screenshot pixels / CSS pixels\n const scaleX = screenshotWidth / cssViewportWidth\n const scaleY = screenshotHeight / cssViewportHeight\n\n console.log(\"[JANK API] Calculated scale:\", { x: scaleX.toFixed(3), y: scaleY.toFixed(3) })\n\n // Convert CSS pixels to screenshot pixels\n boundingBox = {\n x: Math.round(cssRect.x * scaleX),\n y: Math.round(cssRect.y * scaleY),\n width: Math.round(cssRect.width * scaleX),\n height: Math.round(cssRect.height * scaleY)\n }\n\n console.log(\"[JANK API] Bounding box (screenshot pixels):\", boundingBox)\n } else {\n console.log(\"[JANK API] No actualRect or cssViewport available, cannot determine bounding box\")\n }\n\n return {\n ...closestMarker,\n boundingBox,\n clsScore: shift.score,\n element: source?.node || \"unknown\"\n }\n })\n .filter(Boolean)\n\n return NextResponse.json({\n clsMarkers: filteredMarkers,\n realLayoutShifts: realCLS.shifts,\n debug: debugInfo,\n source: \"performance-observer-validated\",\n actualCLS: realCLS.totalCLS,\n grade: realCLS.grade,\n note: `Real CLS: ${realCLS.totalCLS.toFixed(4)} (${realCLS.grade}). Filtered ${clsMarkers.length - filteredMarkers.length} false positives from pixel-diff.`\n })\n }\n\n return NextResponse.json({\n clsMarkers,\n debug: debugInfo,\n source: \"pixel-diff-fallback\",\n note: \"PerformanceObserver data not available, using pixel-diff analysis (may include false positives)\"\n })\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setReferenceManifestsSingleton } from \"next/dist/esm/server/app-render/encryption-utils\";\nimport { createServerModuleMap } from \"next/dist/esm/server/app-render/action-utils\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/jank/[session]/route\",\n pathname: \"/api/jank/[session]\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/mcp-server/app/api/jank/[session]/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/jank/[session]/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setReferenceManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest,\n serverModuleMap: createServerModuleMap({\n serverActionsManifest\n })\n });\n }\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil,\n isMinimalMode\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!isMinimalMode) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(isMinimalMode && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${srcPage}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n"],"names":[],"mappings":"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","ignoreList":[1]}
@@ -1,3 +0,0 @@
1
- module.exports=[18622,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,t,r)=>{t.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},93695,(e,t,r)=>{t.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},24286,e=>{"use strict";function t(e){let t=e.match(/^(.+?)-(\d{4}-\d{2}-\d{2}T[\d-]+Z)\.log$/);if(t)return t[1];let r=e.match(/^(.+)-d3k\.log$/);return r?r[1]:null}function r(e,r){let n=t(e);return!!n&&n.includes(r)}e.s(["extractProjectNameFromLogFilename",()=>t,"logFilenameMatchesProject",()=>r])},9202,e=>{"use strict";var t=e.i(7479),r=e.i(3797),n=e.i(66154),a=e.i(36096),o=e.i(54296),s=e.i(23249),i=e.i(33185),l=e.i(84521),d=e.i(67707),u=e.i(86157),c=e.i(87608),p=e.i(48432),h=e.i(77430),m=e.i(45577),g=e.i(92366),x=e.i(97691),R=e.i(93695);e.i(24496);var v=e.i(91349),f=e.i(24286),E=e.i(22734),w=e.i(14747);async function C(e){try{let e=process.env.LOG_FILE_PATH||"/var/log/dev3000/dev3000.log";if(!(0,E.existsSync)(e))return Response.json({error:"Current log file not found"},{status:404});let t=(0,w.dirname)(e),r=(0,w.basename)(e),n=(0,f.extractProjectNameFromLogFilename)(r)||"unknown",a=[];try{let e=(0,E.readdirSync)(t).filter(e=>(0,f.logFilenameMatchesProject)(e,n)).map(e=>{let n=(0,w.join)(t,e),a=(0,E.statSync)(n),o=e.match(/(\d{4}-\d{2}-\d{2}T[\d-]+Z)/),s=o?o[1].replace(/-/g,":"):"";return{name:e,path:n,timestamp:s,size:a.size,mtime:a.mtime,isCurrent:e===r}}).sort((e,t)=>t.mtime.getTime()-e.mtime.getTime()).map(e=>({...e,mtime:e.mtime.toISOString()}));a.push(...e)}catch(e){console.warn("Could not read log directory:",e)}return Response.json({files:a,currentFile:e,projectName:n})}catch(t){let e={error:t instanceof Error?t.message:"Unknown error"};return Response.json(e,{status:500})}}e.s(["GET",()=>C],15e3);var y=e.i(15e3);let A=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/logs/list/route",pathname:"/api/logs/list",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/mcp-server/app/api/logs/list/route.ts",nextConfigOutput:"",userland:y}),{workAsyncStorage:T,workUnitAsyncStorage:b,serverHooks:P}=A;function N(){return(0,n.patchFetch)({workAsyncStorage:T,workUnitAsyncStorage:b})}async function S(e,t,n){A.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let f="/api/logs/list/route";f=f.replace(/\/index$/,"")||"/";let E=await A.prepare(e,t,{srcPage:f,multiZoneDraftMode:!1});if(!E)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:w,params:C,nextConfig:y,parsedUrl:T,isDraftMode:b,prerenderManifest:P,routerServerContext:N,isOnDemandRevalidate:S,revalidateOnlyGenerated:j,resolvedPathname:O,clientReferenceManifest:k,serverActionsManifest:_}=E,q=(0,l.normalizeAppPath)(f),H=!!(P.dynamicRoutes[q]||P.routes[O]),M=async()=>((null==N?void 0:N.render404)?await N.render404(e,t,T,!1):t.end("This page could not be found"),null);if(H&&!b){let e=!!P.routes[O],t=P.dynamicRoutes[q];if(t&&!1===t.fallback&&!e){if(y.experimental.adapterPath)return await M();throw new R.NoFallbackError}}let I=null;!H||A.isDev||b||(I="/index"===(I=O)?"/":I);let U=!0===A.isDev||!H,F=H&&!U;_&&k&&(0,s.setReferenceManifestsSingleton)({page:f,clientReferenceManifest:k,serverActionsManifest:_,serverModuleMap:(0,i.createServerModuleMap)({serverActionsManifest:_})});let D=e.method||"GET",$=(0,o.getTracer)(),L=$.getActiveScopeSpan(),K={params:C,prerenderManifest:P,renderOpts:{experimental:{authInterrupts:!!y.experimental.authInterrupts},cacheComponents:!!y.cacheComponents,supportsDynamicResponse:U,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:y.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n)=>A.onRequestError(e,t,n,N)},sharedContext:{buildId:w}},B=new d.NodeNextRequest(e),G=new d.NodeNextResponse(t),z=u.NextRequestAdapter.fromNodeNextRequest(B,(0,u.signalFromNodeResponse)(t));try{let s=async e=>A.handle(z,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=$.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==c.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=r.get("next.route");if(n){let t=`${D} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${D} ${f}`)}),i=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var o,l;let d=async({previousCacheEntry:r})=>{try{if(!i&&S&&j&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await s(a);e.fetchMetrics=K.renderOpts.fetchMetrics;let l=K.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let d=K.renderOpts.collectedTags;if(!H)return await (0,h.sendResponse)(B,G,o,K.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(o.headers);d&&(t[x.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=x.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,n=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=x.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:v.CachedRouteKind.APP_ROUTE,status:o.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await A.onRequestError(e,t,{routerKind:"App Router",routePath:f,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:F,isOnDemandRevalidate:S})},N),t}},u=await A.handleResponse({req:e,nextConfig:y,cacheKey:I,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:P,isRoutePPREnabled:!1,isOnDemandRevalidate:S,revalidateOnlyGenerated:j,responseGenerator:d,waitUntil:n.waitUntil,isMinimalMode:i});if(!H)return null;if((null==u||null==(o=u.value)?void 0:o.kind)!==v.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(l=u.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",S?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),b&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,m.fromNodeOutgoingHttpHeaders)(u.value.headers);return i&&H||c.delete(x.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,g.getCacheControlHeader)(u.cacheControl)),await (0,h.sendResponse)(B,G,new Response(u.value.body,{headers:c,status:u.value.status||200})),null};L?await l(L):await $.withPropagatedContext(e.headers,()=>$.trace(c.BaseServerSpan.handleRequest,{spanName:`${D} ${f}`,kind:o.SpanKind.SERVER,attributes:{"http.method":D,"http.target":e.url}},l))}catch(t){if(t instanceof R.NoFallbackError||await A.onRequestError(e,t,{routerKind:"App Router",routePath:q,routeType:"route",revalidateReason:(0,p.getRevalidateReason)({isStaticGeneration:F,isOnDemandRevalidate:S})}),H)throw t;return await (0,h.sendResponse)(B,G,new Response(null,{status:500})),null}}e.s(["handler",()=>S,"patchFetch",()=>N,"routeModule",()=>A,"serverHooks",()=>P,"workAsyncStorage",()=>T,"workUnitAsyncStorage",()=>b],9202)}];
2
-
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__11cde0db._.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["../../../../src/utils/log-filename.ts","../../../../mcp-server/app/api/logs/list/route.ts","../../../../node_modules/.pnpm/next%4016.0.7_%40opentelemetry%2Bapi%401.9.0_babel-plugin-react-compiler%401.0.0_react-dom%4019.3.0_a20848594014cb183ab624f2be88a203/node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["/**\n * Utilities for working with dev3000 log filenames\n *\n * Log files follow the pattern: <project-name>-<timestamp>.log\n * where timestamp is ISO 8601 with special chars replaced by hyphens\n * Example: tailwindui-studio-2025-10-27T17-57-15-014Z.log\n */\n\n/**\n * Extract the project name from a log filename\n *\n * @param filename - The log filename (e.g., \"tailwindui-studio-2025-10-27T17-57-15-014Z.log\")\n * @returns The project name (e.g., \"tailwindui-studio\") or null if invalid format\n */\nexport function extractProjectNameFromLogFilename(filename: string): string | null {\n // Pattern matches: <project-name>-YYYY-MM-DDTHH-MM-SS-SSSZ.log\n // The timestamp always starts with YYYY-MM-DD which is a reliable anchor\n const timestampMatch = filename.match(/^(.+?)-(\\d{4}-\\d{2}-\\d{2}T[\\d-]+Z)\\.log$/)\n if (timestampMatch) {\n return timestampMatch[1]\n }\n\n // Also handle current log file pattern: <project-name>-d3k.log\n const d3kMatch = filename.match(/^(.+)-d3k\\.log$/)\n if (d3kMatch) {\n return d3kMatch[1]\n }\n\n return null\n}\n\n/**\n * Check if a log filename matches a given project name\n *\n * @param filename - The log filename to check\n * @param projectName - The project name to match (supports partial matching)\n * @returns true if the filename belongs to this project\n */\nexport function logFilenameMatchesProject(filename: string, projectName: string): boolean {\n const extractedName = extractProjectNameFromLogFilename(filename)\n if (!extractedName) {\n return false\n }\n\n // Support partial matching (e.g., \"studio\" matches \"tailwindui-studio\")\n return extractedName.includes(projectName)\n}\n\n/**\n * Extract the timestamp from a log filename\n *\n * @param filename - The log filename\n * @returns ISO 8601 timestamp string or null if invalid format\n */\nexport function extractTimestampFromLogFilename(filename: string): string | null {\n const match = filename.match(/^.+?-(\\d{4}-\\d{2}-\\d{2}T[\\d-]+Z)\\.log$/)\n if (match) {\n // Convert back to proper ISO format (replace hyphens with colons and dots)\n const timestamp = match[1]\n // Format: 2025-10-27T17-57-15-014Z -> 2025-10-27T17:57:15.014Z\n const isoTimestamp = timestamp.replace(/T(\\d{2})-(\\d{2})-(\\d{2})-(\\d{3})Z/, \"T$1:$2:$3.$4Z\")\n return isoTimestamp\n }\n return null\n}\n","import { extractProjectNameFromLogFilename, logFilenameMatchesProject } from \"@dev3000/src/utils/log-filename\"\nimport { existsSync, readdirSync, statSync } from \"fs\"\nimport type { NextRequest } from \"next/server\"\nimport { basename, dirname, join } from \"path\"\nimport type { LogFile, LogListError, LogListResponse } from \"@/types\"\n\nexport async function GET(_request: NextRequest): Promise<Response> {\n try {\n const currentLogPath = process.env.LOG_FILE_PATH || \"/var/log/dev3000/dev3000.log\"\n\n if (!existsSync(currentLogPath)) {\n const errorResponse: LogListError = { error: \"Current log file not found\" }\n return Response.json(errorResponse, { status: 404 })\n }\n\n // Get the directory containing the current log\n const logDir = dirname(currentLogPath)\n const currentLogName = basename(currentLogPath)\n\n // Extract project name from current log filename using shared utility\n const projectName = extractProjectNameFromLogFilename(currentLogName) || \"unknown\"\n\n // Find all log files for this project\n const files: LogFile[] = []\n\n try {\n const dirContents = readdirSync(logDir)\n const logFiles = dirContents\n .filter((file) => logFilenameMatchesProject(file, projectName))\n .map((file) => {\n const filePath = join(logDir, file)\n const stats = statSync(filePath)\n\n // Extract timestamp from filename\n const timestampMatch = file.match(/(\\d{4}-\\d{2}-\\d{2}T[\\d-]+Z)/)\n const timestamp = timestampMatch ? timestampMatch[1].replace(/-/g, \":\") : \"\"\n\n return {\n name: file,\n path: filePath,\n timestamp,\n size: stats.size,\n mtime: stats.mtime,\n isCurrent: file === currentLogName\n }\n })\n .sort((a, b) => b.mtime.getTime() - a.mtime.getTime()) // Most recent first\n .map((file) => ({\n ...file,\n mtime: file.mtime.toISOString() // Convert to string after sorting\n }))\n\n files.push(...logFiles)\n } catch (error) {\n console.warn(\"Could not read log directory:\", error)\n }\n\n const response: LogListResponse = {\n files,\n currentFile: currentLogPath,\n projectName\n }\n\n return Response.json(response)\n } catch (error) {\n const errorResponse: LogListError = {\n error: error instanceof Error ? error.message : \"Unknown error\"\n }\n return Response.json(errorResponse, { status: 500 })\n }\n}\n","import { AppRouteRouteModule } from \"next/dist/esm/server/route-modules/app-route/module.compiled\";\nimport { RouteKind } from \"next/dist/esm/server/route-kind\";\nimport { patchFetch as _patchFetch } from \"next/dist/esm/server/lib/patch-fetch\";\nimport { addRequestMeta, getRequestMeta } from \"next/dist/esm/server/request-meta\";\nimport { getTracer, SpanKind } from \"next/dist/esm/server/lib/trace/tracer\";\nimport { setReferenceManifestsSingleton } from \"next/dist/esm/server/app-render/encryption-utils\";\nimport { createServerModuleMap } from \"next/dist/esm/server/app-render/action-utils\";\nimport { normalizeAppPath } from \"next/dist/esm/shared/lib/router/utils/app-paths\";\nimport { NodeNextRequest, NodeNextResponse } from \"next/dist/esm/server/base-http/node\";\nimport { NextRequestAdapter, signalFromNodeResponse } from \"next/dist/esm/server/web/spec-extension/adapters/next-request\";\nimport { BaseServerSpan } from \"next/dist/esm/server/lib/trace/constants\";\nimport { getRevalidateReason } from \"next/dist/esm/server/instrumentation/utils\";\nimport { sendResponse } from \"next/dist/esm/server/send-response\";\nimport { fromNodeOutgoingHttpHeaders, toNodeOutgoingHttpHeaders } from \"next/dist/esm/server/web/utils\";\nimport { getCacheControlHeader } from \"next/dist/esm/server/lib/cache-control\";\nimport { INFINITE_CACHE, NEXT_CACHE_TAGS_HEADER } from \"next/dist/esm/lib/constants\";\nimport { NoFallbackError } from \"next/dist/esm/shared/lib/no-fallback-error.external\";\nimport { CachedRouteKind } from \"next/dist/esm/server/response-cache\";\nimport * as userland from \"INNER_APP_ROUTE\";\n// We inject the nextConfigOutput here so that we can use them in the route\n// module.\nconst nextConfigOutput = \"\"\nconst routeModule = new AppRouteRouteModule({\n definition: {\n kind: RouteKind.APP_ROUTE,\n page: \"/api/logs/list/route\",\n pathname: \"/api/logs/list\",\n filename: \"route\",\n bundlePath: \"\"\n },\n distDir: process.env.__NEXT_RELATIVE_DIST_DIR || '',\n relativeProjectDir: process.env.__NEXT_RELATIVE_PROJECT_DIR || '',\n resolvedPagePath: \"[project]/mcp-server/app/api/logs/list/route.ts\",\n nextConfigOutput,\n userland\n});\n// Pull out the exports that we need to expose from the module. This should\n// be eliminated when we've moved the other routes to the new format. These\n// are used to hook into the route.\nconst { workAsyncStorage, workUnitAsyncStorage, serverHooks } = routeModule;\nfunction patchFetch() {\n return _patchFetch({\n workAsyncStorage,\n workUnitAsyncStorage\n });\n}\nexport { routeModule, workAsyncStorage, workUnitAsyncStorage, serverHooks, patchFetch, };\nexport async function handler(req, res, ctx) {\n if (routeModule.isDev) {\n addRequestMeta(req, 'devRequestTimingInternalsEnd', process.hrtime.bigint());\n }\n let srcPage = \"/api/logs/list/route\";\n // turbopack doesn't normalize `/index` in the page name\n // so we need to to process dynamic routes properly\n // TODO: fix turbopack providing differing value from webpack\n if (process.env.TURBOPACK) {\n srcPage = srcPage.replace(/\\/index$/, '') || '/';\n } else if (srcPage === '/index') {\n // we always normalize /index specifically\n srcPage = '/';\n }\n const multiZoneDraftMode = process.env.__NEXT_MULTI_ZONE_DRAFT_MODE;\n const prepareResult = await routeModule.prepare(req, res, {\n srcPage,\n multiZoneDraftMode\n });\n if (!prepareResult) {\n res.statusCode = 400;\n res.end('Bad Request');\n ctx.waitUntil == null ? void 0 : ctx.waitUntil.call(ctx, Promise.resolve());\n return null;\n }\n const { buildId, params, nextConfig, parsedUrl, isDraftMode, prerenderManifest, routerServerContext, isOnDemandRevalidate, revalidateOnlyGenerated, resolvedPathname, clientReferenceManifest, serverActionsManifest } = prepareResult;\n const normalizedSrcPage = normalizeAppPath(srcPage);\n let isIsr = Boolean(prerenderManifest.dynamicRoutes[normalizedSrcPage] || prerenderManifest.routes[resolvedPathname]);\n const render404 = async ()=>{\n // TODO: should route-module itself handle rendering the 404\n if (routerServerContext == null ? void 0 : routerServerContext.render404) {\n await routerServerContext.render404(req, res, parsedUrl, false);\n } else {\n res.end('This page could not be found');\n }\n return null;\n };\n if (isIsr && !isDraftMode) {\n const isPrerendered = Boolean(prerenderManifest.routes[resolvedPathname]);\n const prerenderInfo = prerenderManifest.dynamicRoutes[normalizedSrcPage];\n if (prerenderInfo) {\n if (prerenderInfo.fallback === false && !isPrerendered) {\n if (nextConfig.experimental.adapterPath) {\n return await render404();\n }\n throw new NoFallbackError();\n }\n }\n }\n let cacheKey = null;\n if (isIsr && !routeModule.isDev && !isDraftMode) {\n cacheKey = resolvedPathname;\n // ensure /index and / is normalized to one key\n cacheKey = cacheKey === '/index' ? '/' : cacheKey;\n }\n const supportsDynamicResponse = // If we're in development, we always support dynamic HTML\n routeModule.isDev === true || // If this is not SSG or does not have static paths, then it supports\n // dynamic HTML.\n !isIsr;\n // This is a revalidation request if the request is for a static\n // page and it is not being resumed from a postponed render and\n // it is not a dynamic RSC request then it is a revalidation\n // request.\n const isStaticGeneration = isIsr && !supportsDynamicResponse;\n // Before rendering (which initializes component tree modules), we have to\n // set the reference manifests to our global store so Server Action's\n // encryption util can access to them at the top level of the page module.\n if (serverActionsManifest && clientReferenceManifest) {\n setReferenceManifestsSingleton({\n page: srcPage,\n clientReferenceManifest,\n serverActionsManifest,\n serverModuleMap: createServerModuleMap({\n serverActionsManifest\n })\n });\n }\n const method = req.method || 'GET';\n const tracer = getTracer();\n const activeSpan = tracer.getActiveScopeSpan();\n const context = {\n params,\n prerenderManifest,\n renderOpts: {\n experimental: {\n authInterrupts: Boolean(nextConfig.experimental.authInterrupts)\n },\n cacheComponents: Boolean(nextConfig.cacheComponents),\n supportsDynamicResponse,\n incrementalCache: getRequestMeta(req, 'incrementalCache'),\n cacheLifeProfiles: nextConfig.cacheLife,\n waitUntil: ctx.waitUntil,\n onClose: (cb)=>{\n res.on('close', cb);\n },\n onAfterTaskError: undefined,\n onInstrumentationRequestError: (error, _request, errorContext)=>routeModule.onRequestError(req, error, errorContext, routerServerContext)\n },\n sharedContext: {\n buildId\n }\n };\n const nodeNextReq = new NodeNextRequest(req);\n const nodeNextRes = new NodeNextResponse(res);\n const nextReq = NextRequestAdapter.fromNodeNextRequest(nodeNextReq, signalFromNodeResponse(res));\n try {\n const invokeRouteModule = async (span)=>{\n return routeModule.handle(nextReq, context).finally(()=>{\n if (!span) return;\n span.setAttributes({\n 'http.status_code': res.statusCode,\n 'next.rsc': false\n });\n const rootSpanAttributes = tracer.getRootSpanAttributes();\n // We were unable to get attributes, probably OTEL is not enabled\n if (!rootSpanAttributes) {\n return;\n }\n if (rootSpanAttributes.get('next.span_type') !== BaseServerSpan.handleRequest) {\n console.warn(`Unexpected root span type '${rootSpanAttributes.get('next.span_type')}'. Please report this Next.js issue https://github.com/vercel/next.js`);\n return;\n }\n const route = rootSpanAttributes.get('next.route');\n if (route) {\n const name = `${method} ${route}`;\n span.setAttributes({\n 'next.route': route,\n 'http.route': route,\n 'next.span_name': name\n });\n span.updateName(name);\n } else {\n span.updateName(`${method} ${srcPage}`);\n }\n });\n };\n const isMinimalMode = Boolean(process.env.MINIMAL_MODE || getRequestMeta(req, 'minimalMode'));\n const handleResponse = async (currentSpan)=>{\n var _cacheEntry_value;\n const responseGenerator = async ({ previousCacheEntry })=>{\n try {\n if (!isMinimalMode && isOnDemandRevalidate && revalidateOnlyGenerated && !previousCacheEntry) {\n res.statusCode = 404;\n // on-demand revalidate always sets this header\n res.setHeader('x-nextjs-cache', 'REVALIDATED');\n res.end('This page could not be found');\n return null;\n }\n const response = await invokeRouteModule(currentSpan);\n req.fetchMetrics = context.renderOpts.fetchMetrics;\n let pendingWaitUntil = context.renderOpts.pendingWaitUntil;\n // Attempt using provided waitUntil if available\n // if it's not we fallback to sendResponse's handling\n if (pendingWaitUntil) {\n if (ctx.waitUntil) {\n ctx.waitUntil(pendingWaitUntil);\n pendingWaitUntil = undefined;\n }\n }\n const cacheTags = context.renderOpts.collectedTags;\n // If the request is for a static response, we can cache it so long\n // as it's not edge.\n if (isIsr) {\n const blob = await response.blob();\n // Copy the headers from the response.\n const headers = toNodeOutgoingHttpHeaders(response.headers);\n if (cacheTags) {\n headers[NEXT_CACHE_TAGS_HEADER] = cacheTags;\n }\n if (!headers['content-type'] && blob.type) {\n headers['content-type'] = blob.type;\n }\n const revalidate = typeof context.renderOpts.collectedRevalidate === 'undefined' || context.renderOpts.collectedRevalidate >= INFINITE_CACHE ? false : context.renderOpts.collectedRevalidate;\n const expire = typeof context.renderOpts.collectedExpire === 'undefined' || context.renderOpts.collectedExpire >= INFINITE_CACHE ? undefined : context.renderOpts.collectedExpire;\n // Create the cache entry for the response.\n const cacheEntry = {\n value: {\n kind: CachedRouteKind.APP_ROUTE,\n status: response.status,\n body: Buffer.from(await blob.arrayBuffer()),\n headers\n },\n cacheControl: {\n revalidate,\n expire\n }\n };\n return cacheEntry;\n } else {\n // send response without caching if not ISR\n await sendResponse(nodeNextReq, nodeNextRes, response, context.renderOpts.pendingWaitUntil);\n return null;\n }\n } catch (err) {\n // if this is a background revalidate we need to report\n // the request error here as it won't be bubbled\n if (previousCacheEntry == null ? void 0 : previousCacheEntry.isStale) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: srcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n }, routerServerContext);\n }\n throw err;\n }\n };\n const cacheEntry = await routeModule.handleResponse({\n req,\n nextConfig,\n cacheKey,\n routeKind: RouteKind.APP_ROUTE,\n isFallback: false,\n prerenderManifest,\n isRoutePPREnabled: false,\n isOnDemandRevalidate,\n revalidateOnlyGenerated,\n responseGenerator,\n waitUntil: ctx.waitUntil,\n isMinimalMode\n });\n // we don't create a cacheEntry for ISR\n if (!isIsr) {\n return null;\n }\n if ((cacheEntry == null ? void 0 : (_cacheEntry_value = cacheEntry.value) == null ? void 0 : _cacheEntry_value.kind) !== CachedRouteKind.APP_ROUTE) {\n var _cacheEntry_value1;\n throw Object.defineProperty(new Error(`Invariant: app-route received invalid cache entry ${cacheEntry == null ? void 0 : (_cacheEntry_value1 = cacheEntry.value) == null ? void 0 : _cacheEntry_value1.kind}`), \"__NEXT_ERROR_CODE\", {\n value: \"E701\",\n enumerable: false,\n configurable: true\n });\n }\n if (!isMinimalMode) {\n res.setHeader('x-nextjs-cache', isOnDemandRevalidate ? 'REVALIDATED' : cacheEntry.isMiss ? 'MISS' : cacheEntry.isStale ? 'STALE' : 'HIT');\n }\n // Draft mode should never be cached\n if (isDraftMode) {\n res.setHeader('Cache-Control', 'private, no-cache, no-store, max-age=0, must-revalidate');\n }\n const headers = fromNodeOutgoingHttpHeaders(cacheEntry.value.headers);\n if (!(isMinimalMode && isIsr)) {\n headers.delete(NEXT_CACHE_TAGS_HEADER);\n }\n // If cache control is already set on the response we don't\n // override it to allow users to customize it via next.config\n if (cacheEntry.cacheControl && !res.getHeader('Cache-Control') && !headers.get('Cache-Control')) {\n headers.set('Cache-Control', getCacheControlHeader(cacheEntry.cacheControl));\n }\n await sendResponse(nodeNextReq, nodeNextRes, // @ts-expect-error - Argument of type 'Buffer<ArrayBufferLike>' is not assignable to parameter of type 'BodyInit | null | undefined'.\n new Response(cacheEntry.value.body, {\n headers,\n status: cacheEntry.value.status || 200\n }));\n return null;\n };\n // TODO: activeSpan code path is for when wrapped by\n // next-server can be removed when this is no longer used\n if (activeSpan) {\n await handleResponse(activeSpan);\n } else {\n await tracer.withPropagatedContext(req.headers, ()=>tracer.trace(BaseServerSpan.handleRequest, {\n spanName: `${method} ${srcPage}`,\n kind: SpanKind.SERVER,\n attributes: {\n 'http.method': method,\n 'http.target': req.url\n }\n }, handleResponse));\n }\n } catch (err) {\n if (!(err instanceof NoFallbackError)) {\n await routeModule.onRequestError(req, err, {\n routerKind: 'App Router',\n routePath: normalizedSrcPage,\n routeType: 'route',\n revalidateReason: getRevalidateReason({\n isStaticGeneration,\n isOnDemandRevalidate\n })\n });\n }\n // rethrow so that we can handle serving error page\n // If this is during static generation, throw the error again.\n if (isIsr) throw err;\n // Otherwise, send a 500 response.\n await sendResponse(nodeNextReq, nodeNextRes, new Response(null, {\n status: 500\n }));\n return null;\n }\n}\n\n//# sourceMappingURL=app-route.js.map\n"],"names":[],"mappings":"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","ignoreList":[2]}
@@ -1,3 +0,0 @@
1
- module.exports=[93695,(e,r,t)=>{r.exports=e.x("next/dist/shared/lib/no-fallback-error.external.js",()=>require("next/dist/shared/lib/no-fallback-error.external.js"))},18622,(e,r,t)=>{r.exports=e.x("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-page-turbo.runtime.prod.js"))},56704,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/work-async-storage.external.js",()=>require("next/dist/server/app-render/work-async-storage.external.js"))},32319,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/work-unit-async-storage.external.js",()=>require("next/dist/server/app-render/work-unit-async-storage.external.js"))},24725,(e,r,t)=>{r.exports=e.x("next/dist/server/app-render/after-task-async-storage.external.js",()=>require("next/dist/server/app-render/after-task-async-storage.external.js"))},24361,(e,r,t)=>{r.exports=e.x("util",()=>require("util"))},14747,(e,r,t)=>{r.exports=e.x("path",()=>require("path"))},22734,(e,r,t)=>{r.exports=e.x("fs",()=>require("fs"))},46786,(e,r,t)=>{r.exports=e.x("os",()=>require("os"))}];
2
-
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__3ac957e6._.js.map
@@ -1,7 +0,0 @@
1
- module.exports=[61724,(e,t,r)=>{t.exports=e.x("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js",()=>require("next/dist/compiled/next-server/app-route-turbo.runtime.prod.js"))},7479,(e,t,r)=>{t.exports=e.r(61724)},67173,e=>{"use strict";function t(e){return Symbol.for(e)}var r,n,a,o,i,s,l,u,c,d,p,f,h,g=new function e(t){var r=this;r._currentContext=t?new Map(t):new Map,r.getValue=function(e){return r._currentContext.get(e)},r.setValue=function(t,n){var a=new e(r._currentContext);return a._currentContext.set(t,n),a},r.deleteValue=function(t){var n=new e(r._currentContext);return n._currentContext.delete(t),n}},v=function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,a,o=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)i.push(n.value)}catch(e){a={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(a)throw a.error}}return i},y=function(e,t,r){if(r||2==arguments.length)for(var n,a=0,o=t.length;a<o;a++)!n&&a in t||(n||(n=Array.prototype.slice.call(t,0,a)),n[a]=t[a]);return e.concat(n||Array.prototype.slice.call(t))},m=function(){function e(){}return e.prototype.active=function(){return g},e.prototype.with=function(e,t,r){for(var n=[],a=3;a<arguments.length;a++)n[a-3]=arguments[a];return t.call.apply(t,y([r],v(n),!1))},e.prototype.bind=function(e,t){return t},e.prototype.enable=function(){return this},e.prototype.disable=function(){return this},e}(),_="object"==typeof globalThis?globalThis:e.g,b="1.9.0",S=/^(\d+)\.(\d+)\.(\d+)(-(.+))?$/,E=function(e){var t=new Set([e]),r=new Set,n=e.match(S);if(!n)return function(){return!1};var a={major:+n[1],minor:+n[2],patch:+n[3],prerelease:n[4]};if(null!=a.prerelease)return function(t){return t===e};function o(e){return r.add(e),!1}return function(e){if(t.has(e))return!0;if(r.has(e))return!1;var n=e.match(S);if(!n)return o(e);var i={major:+n[1],minor:+n[2],patch:+n[3],prerelease:n[4]};if(null!=i.prerelease||a.major!==i.major)return o(e);if(0===a.major)return a.minor===i.minor&&a.patch<=i.patch?(t.add(e),!0):o(e);return a.minor<=i.minor?(t.add(e),!0):o(e)}}(b),R=Symbol.for("opentelemetry.js.api."+b.split(".")[0]);function O(e,t,r,n){void 0===n&&(n=!1);var a,o=_[R]=null!=(a=_[R])?a:{version:b};if(!n&&o[e]){var i=Error("@opentelemetry/api: Attempted duplicate registration of API: "+e);return r.error(i.stack||i.message),!1}if(o.version!==b){var i=Error("@opentelemetry/api: Registration of version v"+o.version+" for "+e+" does not match previously registered API v"+b);return r.error(i.stack||i.message),!1}return o[e]=t,r.debug("@opentelemetry/api: Registered a global for "+e+" v"+b+"."),!0}function w(e){var t,r,n=null==(t=_[R])?void 0:t.version;if(n&&E(n))return null==(r=_[R])?void 0:r[e]}function T(e,t){t.debug("@opentelemetry/api: Unregistering a global for "+e+" v"+b+".");var r=_[R];r&&delete r[e]}var x=function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,a,o=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)i.push(n.value)}catch(e){a={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(a)throw a.error}}return i},P=function(e,t,r){if(r||2==arguments.length)for(var n,a=0,o=t.length;a<o;a++)!n&&a in t||(n||(n=Array.prototype.slice.call(t,0,a)),n[a]=t[a]);return e.concat(n||Array.prototype.slice.call(t))},N=function(){function e(e){this._namespace=e.namespace||"DiagComponentLogger"}return e.prototype.debug=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return C("debug",this._namespace,e)},e.prototype.error=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return C("error",this._namespace,e)},e.prototype.info=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return C("info",this._namespace,e)},e.prototype.warn=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return C("warn",this._namespace,e)},e.prototype.verbose=function(){for(var e=[],t=0;t<arguments.length;t++)e[t]=arguments[t];return C("verbose",this._namespace,e)},e}();function C(e,t,r){var n=w("diag");if(n)return r.unshift(t),n[e].apply(n,P([],x(r),!1))}(l=r||(r={}))[l.NONE=0]="NONE",l[l.ERROR=30]="ERROR",l[l.WARN=50]="WARN",l[l.INFO=60]="INFO",l[l.DEBUG=70]="DEBUG",l[l.VERBOSE=80]="VERBOSE",l[l.ALL=9999]="ALL";var A=function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,a,o=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)i.push(n.value)}catch(e){a={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(a)throw a.error}}return i},I=function(e,t,r){if(r||2==arguments.length)for(var n,a=0,o=t.length;a<o;a++)!n&&a in t||(n||(n=Array.prototype.slice.call(t,0,a)),n[a]=t[a]);return e.concat(n||Array.prototype.slice.call(t))},M=function(){function e(){function e(e){return function(){for(var t=[],r=0;r<arguments.length;r++)t[r]=arguments[r];var n=w("diag");if(n)return n[e].apply(n,I([],A(t),!1))}}var t=this;t.setLogger=function(e,n){if(void 0===n&&(n={logLevel:r.INFO}),e===t){var a,o,i,s=Error("Cannot use diag as the logger for itself. Please use a DiagLogger implementation like ConsoleDiagLogger or a custom implementation");return t.error(null!=(a=s.stack)?a:s.message),!1}"number"==typeof n&&(n={logLevel:n});var l=w("diag"),u=function(e,t){function n(r,n){var a=t[r];return"function"==typeof a&&e>=n?a.bind(t):function(){}}return e<r.NONE?e=r.NONE:e>r.ALL&&(e=r.ALL),t=t||{},{error:n("error",r.ERROR),warn:n("warn",r.WARN),info:n("info",r.INFO),debug:n("debug",r.DEBUG),verbose:n("verbose",r.VERBOSE)}}(null!=(o=n.logLevel)?o:r.INFO,e);if(l&&!n.suppressOverrideMessage){var c=null!=(i=Error().stack)?i:"<failed to generate stacktrace>";l.warn("Current logger will be overwritten from "+c),u.warn("Current logger will overwrite one already registered from "+c)}return O("diag",u,t,!0)},t.disable=function(){T("diag",t)},t.createComponentLogger=function(e){return new N(e)},t.verbose=e("verbose"),t.debug=e("debug"),t.info=e("info"),t.warn=e("warn"),t.error=e("error")}return e.instance=function(){return this._instance||(this._instance=new e),this._instance},e}(),L=function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,a,o=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)i.push(n.value)}catch(e){a={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(a)throw a.error}}return i},D=function(e,t,r){if(r||2==arguments.length)for(var n,a=0,o=t.length;a<o;a++)!n&&a in t||(n||(n=Array.prototype.slice.call(t,0,a)),n[a]=t[a]);return e.concat(n||Array.prototype.slice.call(t))},j="context",B=new m,V=function(){function e(){}return e.getInstance=function(){return this._instance||(this._instance=new e),this._instance},e.prototype.setGlobalContextManager=function(e){return O(j,e,M.instance())},e.prototype.active=function(){return this._getContextManager().active()},e.prototype.with=function(e,t,r){for(var n,a=[],o=3;o<arguments.length;o++)a[o-3]=arguments[o];return(n=this._getContextManager()).with.apply(n,D([e,t,r],L(a),!1))},e.prototype.bind=function(e,t){return this._getContextManager().bind(e,t)},e.prototype._getContextManager=function(){return w(j)||B},e.prototype.disable=function(){this._getContextManager().disable(),T(j,M.instance())},e}(),k=V.getInstance(),U=M.instance(),$=(u=function(e,t){return(u=Object.setPrototypeOf||({__proto__:[]})instanceof Array&&function(e,t){e.__proto__=t}||function(e,t){for(var r in t)Object.prototype.hasOwnProperty.call(t,r)&&(e[r]=t[r])})(e,t)},function(e,t){if("function"!=typeof t&&null!==t)throw TypeError("Class extends value "+String(t)+" is not a constructor or null");function r(){this.constructor=e}u(e,t),e.prototype=null===t?Object.create(t):(r.prototype=t.prototype,new r)}),G=function(){function e(){}return e.prototype.createGauge=function(e,t){return ee},e.prototype.createHistogram=function(e,t){return et},e.prototype.createCounter=function(e,t){return Z},e.prototype.createUpDownCounter=function(e,t){return er},e.prototype.createObservableGauge=function(e,t){return ea},e.prototype.createObservableCounter=function(e,t){return en},e.prototype.createObservableUpDownCounter=function(e,t){return eo},e.prototype.addBatchObservableCallback=function(e,t){},e.prototype.removeBatchObservableCallback=function(e){},e}(),H=function(){},F=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t.prototype.add=function(e,t){},t}(H),q=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t.prototype.add=function(e,t){},t}(H),X=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t.prototype.record=function(e,t){},t}(H),W=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t.prototype.record=function(e,t){},t}(H),K=function(){function e(){}return e.prototype.addCallback=function(e){},e.prototype.removeCallback=function(e){},e}(),z=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t}(K),Y=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t}(K),J=function(e){function t(){return null!==e&&e.apply(this,arguments)||this}return $(t,e),t}(K),Q=new G,Z=new F,ee=new X,et=new W,er=new q,en=new z,ea=new Y,eo=new J;function ei(){return Q}var es=new(function(){function e(){}return e.prototype.getMeter=function(e,t,r){return Q},e}()),el="metrics",eu=(function(){function e(){}return e.getInstance=function(){return this._instance||(this._instance=new e),this._instance},e.prototype.setGlobalMeterProvider=function(e){return O(el,e,M.instance())},e.prototype.getMeterProvider=function(){return w(el)||es},e.prototype.getMeter=function(e,t,r){return this.getMeterProvider().getMeter(e,t,r)},e.prototype.disable=function(){T(el,M.instance())},e})().getInstance(),ec=function(){function e(){}return e.prototype.inject=function(e,t){},e.prototype.extract=function(e,t){return e},e.prototype.fields=function(){return[]},e}(),ed={get:function(e,t){if(null!=e)return e[t]},keys:function(e){return null==e?[]:Object.keys(e)}},ep={set:function(e,t,r){null!=e&&(e[t]=r)}},ef=t("OpenTelemetry Baggage Key");function eh(e){return e.getValue(ef)||void 0}function eg(){return eh(V.getInstance().active())}function ev(e,t){return e.setValue(ef,t)}function ey(e){return e.deleteValue(ef)}var em=function(e,t){var r="function"==typeof Symbol&&e[Symbol.iterator];if(!r)return e;var n,a,o=r.call(e),i=[];try{for(;(void 0===t||t-- >0)&&!(n=o.next()).done;)i.push(n.value)}catch(e){a={error:e}}finally{try{n&&!n.done&&(r=o.return)&&r.call(o)}finally{if(a)throw a.error}}return i},e_=function(e){var t="function"==typeof Symbol&&Symbol.iterator,r=t&&e[t],n=0;if(r)return r.call(e);if(e&&"number"==typeof e.length)return{next:function(){return e&&n>=e.length&&(e=void 0),{value:e&&e[n++],done:!e}}};throw TypeError(t?"Object is not iterable.":"Symbol.iterator is not defined.")},eb=function(){function e(e){this._entries=e?new Map(e):new Map}return e.prototype.getEntry=function(e){var t=this._entries.get(e);if(t)return Object.assign({},t)},e.prototype.getAllEntries=function(){return Array.from(this._entries.entries()).map(function(e){var t=em(e,2);return[t[0],t[1]]})},e.prototype.setEntry=function(t,r){var n=new e(this._entries);return n._entries.set(t,r),n},e.prototype.removeEntry=function(t){var r=new e(this._entries);return r._entries.delete(t),r},e.prototype.removeEntries=function(){for(var t,r,n=[],a=0;a<arguments.length;a++)n[a]=arguments[a];var o=new e(this._entries);try{for(var i=e_(n),s=i.next();!s.done;s=i.next()){var l=s.value;o._entries.delete(l)}}catch(e){t={error:e}}finally{try{s&&!s.done&&(r=i.return)&&r.call(i)}finally{if(t)throw t.error}}return o},e.prototype.clear=function(){return new e},e}(),eS=Symbol("BaggageEntryMetadata"),eE=M.instance();function eR(e){return void 0===e&&(e={}),new eb(new Map(Object.entries(e)))}function eO(e){return"string"!=typeof e&&(eE.error("Cannot create baggage metadata from unknown type: "+typeof e),e=""),{__TYPE__:eS,toString:function(){return e}}}var ew="propagation",eT=new ec,ex=(function(){function e(){this.createBaggage=eR,this.getBaggage=eh,this.getActiveBaggage=eg,this.setBaggage=ev,this.deleteBaggage=ey}return e.getInstance=function(){return this._instance||(this._instance=new e),this._instance},e.prototype.setGlobalPropagator=function(e){return O(ew,e,M.instance())},e.prototype.inject=function(e,t,r){return void 0===r&&(r=ep),this._getGlobalPropagator().inject(e,t,r)},e.prototype.extract=function(e,t,r){return void 0===r&&(r=ed),this._getGlobalPropagator().extract(e,t,r)},e.prototype.fields=function(){return this._getGlobalPropagator().fields()},e.prototype.disable=function(){T(ew,M.instance())},e.prototype._getGlobalPropagator=function(){return w(ew)||eT},e})().getInstance();(c=n||(n={}))[c.NONE=0]="NONE",c[c.SAMPLED=1]="SAMPLED";var eP="0000000000000000",eN="00000000000000000000000000000000",eC={traceId:eN,spanId:eP,traceFlags:n.NONE},eA=function(){function e(e){void 0===e&&(e=eC),this._spanContext=e}return e.prototype.spanContext=function(){return this._spanContext},e.prototype.setAttribute=function(e,t){return this},e.prototype.setAttributes=function(e){return this},e.prototype.addEvent=function(e,t){return this},e.prototype.addLink=function(e){return this},e.prototype.addLinks=function(e){return this},e.prototype.setStatus=function(e){return this},e.prototype.updateName=function(e){return this},e.prototype.end=function(e){},e.prototype.isRecording=function(){return!1},e.prototype.recordException=function(e,t){},e}(),eI=t("OpenTelemetry Context Key SPAN");function eM(e){return e.getValue(eI)||void 0}function eL(){return eM(V.getInstance().active())}function eD(e,t){return e.setValue(eI,t)}function ej(e){return e.deleteValue(eI)}function eB(e,t){return eD(e,new eA(t))}function eV(e){var t;return null==(t=eM(e))?void 0:t.spanContext()}var ek=/^([0-9a-f]{32})$/i,eU=/^[0-9a-f]{16}$/i;function e$(e){return ek.test(e)&&e!==eN}function eG(e){return eU.test(e)&&e!==eP}function eH(e){return e$(e.traceId)&&eG(e.spanId)}function eF(e){return new eA(e)}var eq=V.getInstance(),eX=function(){function e(){}return e.prototype.startSpan=function(e,t,r){if(void 0===r&&(r=eq.active()),null==t?void 0:t.root)return new eA;var n,a=r&&eV(r);return"object"==typeof(n=a)&&"string"==typeof n.spanId&&"string"==typeof n.traceId&&"number"==typeof n.traceFlags&&eH(a)?new eA(a):new eA},e.prototype.startActiveSpan=function(e,t,r,n){if(!(arguments.length<2)){2==arguments.length?i=t:3==arguments.length?(a=t,i=r):(a=t,o=r,i=n);var a,o,i,s=null!=o?o:eq.active(),l=this.startSpan(e,a,s),u=eD(s,l);return eq.with(u,i,void 0,l)}},e}(),eW=new eX,eK=function(){function e(e,t,r,n){this._provider=e,this.name=t,this.version=r,this.options=n}return e.prototype.startSpan=function(e,t,r){return this._getTracer().startSpan(e,t,r)},e.prototype.startActiveSpan=function(e,t,r,n){var a=this._getTracer();return Reflect.apply(a.startActiveSpan,a,arguments)},e.prototype._getTracer=function(){if(this._delegate)return this._delegate;var e=this._provider.getDelegateTracer(this.name,this.version,this.options);return e?(this._delegate=e,this._delegate):eW},e}(),ez=new(function(){function e(){}return e.prototype.getTracer=function(e,t,r){return new eX},e}()),eY=function(){function e(){}return e.prototype.getTracer=function(e,t,r){var n;return null!=(n=this.getDelegateTracer(e,t,r))?n:new eK(this,e,t,r)},e.prototype.getDelegate=function(){var e;return null!=(e=this._delegate)?e:ez},e.prototype.setDelegate=function(e){this._delegate=e},e.prototype.getDelegateTracer=function(e,t,r){var n;return null==(n=this._delegate)?void 0:n.getTracer(e,t,r)},e}(),eJ="trace",eQ=(function(){function e(){this._proxyTracerProvider=new eY,this.wrapSpanContext=eF,this.isSpanContextValid=eH,this.deleteSpan=ej,this.getSpan=eM,this.getActiveSpan=eL,this.getSpanContext=eV,this.setSpan=eD,this.setSpanContext=eB}return e.getInstance=function(){return this._instance||(this._instance=new e),this._instance},e.prototype.setGlobalTracerProvider=function(e){var t=O(eJ,this._proxyTracerProvider,M.instance());return t&&this._proxyTracerProvider.setDelegate(e),t},e.prototype.getTracerProvider=function(){return w(eJ)||this._proxyTracerProvider},e.prototype.getTracer=function(e,t){return this.getTracerProvider().getTracer(e,t)},e.prototype.disable=function(){T(eJ,M.instance()),this._proxyTracerProvider=new eY},e})().getInstance();let eZ={context:k,diag:U,metrics:eu,propagation:ex,trace:eQ};e.s(["default",0,eZ],40787),e.i(40787);var e0=[{n:"error",c:"error"},{n:"warn",c:"warn"},{n:"info",c:"info"},{n:"debug",c:"debug"},{n:"verbose",c:"trace"}],e1=function(){for(var e=0;e<e0.length;e++)this[e0[e].n]=function(e){return function(){for(var t=[],r=0;r<arguments.length;r++)t[r]=arguments[r];if(console){var n=console[e];if("function"!=typeof n&&(n=console.log),"function"==typeof n)return n.apply(console,t)}}}(e0[e].c)};(d=a||(a={}))[d.INT=0]="INT",d[d.DOUBLE=1]="DOUBLE",(p=o||(o={}))[p.NOT_RECORD=0]="NOT_RECORD",p[p.RECORD=1]="RECORD",p[p.RECORD_AND_SAMPLED=2]="RECORD_AND_SAMPLED",(f=i||(i={}))[f.INTERNAL=0]="INTERNAL",f[f.SERVER=1]="SERVER",f[f.CLIENT=2]="CLIENT",f[f.PRODUCER=3]="PRODUCER",f[f.CONSUMER=4]="CONSUMER",(h=s||(s={}))[h.UNSET=0]="UNSET",h[h.OK=1]="OK",h[h.ERROR=2]="ERROR";var e2="[_0-9a-z-*/]",e4=RegExp("^(?:[a-z]"+e2+"{0,255}|"+("[a-z0-9]"+e2+"{0,240}@[a-z]")+e2+"{0,13})$"),e9=/^[ -~]{0,255}[!-~]$/,e6=/,|=/,e3=function(){function e(e){this._internalState=new Map,e&&this._parse(e)}return e.prototype.set=function(e,t){var r=this._clone();return r._internalState.has(e)&&r._internalState.delete(e),r._internalState.set(e,t),r},e.prototype.unset=function(e){var t=this._clone();return t._internalState.delete(e),t},e.prototype.get=function(e){return this._internalState.get(e)},e.prototype.serialize=function(){var e=this;return this._keys().reduce(function(t,r){return t.push(r+"="+e.get(r)),t},[]).join(",")},e.prototype._parse=function(e){!(e.length>512)&&(this._internalState=e.split(",").reverse().reduce(function(e,t){var r=t.trim(),n=r.indexOf("=");if(-1!==n){var a=r.slice(0,n),o=r.slice(n+1,t.length);e4.test(a)&&e9.test(o)&&!e6.test(o)&&e.set(a,o)}return e},new Map),this._internalState.size>32&&(this._internalState=new Map(Array.from(this._internalState.entries()).reverse().slice(0,32))))},e.prototype._keys=function(){return Array.from(this._internalState.keys()).reverse()},e.prototype._clone=function(){var t=new e;return t._internalState=new Map(this._internalState),t},e}();function e7(e){return new e3(e)}e.s(["DiagConsoleLogger",()=>e1,"DiagLogLevel",()=>r,"INVALID_SPANID",()=>eP,"INVALID_SPAN_CONTEXT",()=>eC,"INVALID_TRACEID",()=>eN,"ProxyTracer",()=>eK,"ProxyTracerProvider",()=>eY,"ROOT_CONTEXT",()=>g,"SamplingDecision",()=>o,"SpanKind",()=>i,"SpanStatusCode",()=>s,"TraceFlags",()=>n,"ValueType",()=>a,"baggageEntryMetadataFromString",()=>eO,"context",()=>k,"createContextKey",()=>t,"createNoopMeter",()=>ei,"createTraceState",()=>e7,"default",0,eZ,"defaultTextMapGetter",()=>ed,"defaultTextMapSetter",()=>ep,"diag",()=>U,"isSpanContextValid",()=>eH,"isValidSpanId",()=>eG,"isValidTraceId",()=>e$,"metrics",()=>eu,"propagation",()=>ex,"trace",()=>eQ],67173)},44928,(e,t,r)=>{(()=>{"use strict";let r,n,a,o,i;var s,l,u,c,d,p,f,h,g,v,y,m,_,b,S,E,R={491:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ContextAPI=void 0;let n=r(223),a=r(172),o=r(930),i="context",s=new n.NoopContextManager;class l{constructor(){}static getInstance(){return this._instance||(this._instance=new l),this._instance}setGlobalContextManager(e){return(0,a.registerGlobal)(i,e,o.DiagAPI.instance())}active(){return this._getContextManager().active()}with(e,t,r,...n){return this._getContextManager().with(e,t,r,...n)}bind(e,t){return this._getContextManager().bind(e,t)}_getContextManager(){return(0,a.getGlobal)(i)||s}disable(){this._getContextManager().disable(),(0,a.unregisterGlobal)(i,o.DiagAPI.instance())}}t.ContextAPI=l},930:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DiagAPI=void 0;let n=r(56),a=r(912),o=r(957),i=r(172);class s{constructor(){function e(e){return function(...t){let r=(0,i.getGlobal)("diag");if(r)return r[e](...t)}}const t=this;t.setLogger=(e,r={logLevel:o.DiagLogLevel.INFO})=>{var n,s,l;if(e===t){let e=Error("Cannot use diag as the logger for itself. Please use a DiagLogger implementation like ConsoleDiagLogger or a custom implementation");return t.error(null!=(n=e.stack)?n:e.message),!1}"number"==typeof r&&(r={logLevel:r});let u=(0,i.getGlobal)("diag"),c=(0,a.createLogLevelDiagLogger)(null!=(s=r.logLevel)?s:o.DiagLogLevel.INFO,e);if(u&&!r.suppressOverrideMessage){let e=null!=(l=Error().stack)?l:"<failed to generate stacktrace>";u.warn(`Current logger will be overwritten from ${e}`),c.warn(`Current logger will overwrite one already registered from ${e}`)}return(0,i.registerGlobal)("diag",c,t,!0)},t.disable=()=>{(0,i.unregisterGlobal)("diag",t)},t.createComponentLogger=e=>new n.DiagComponentLogger(e),t.verbose=e("verbose"),t.debug=e("debug"),t.info=e("info"),t.warn=e("warn"),t.error=e("error")}static instance(){return this._instance||(this._instance=new s),this._instance}}t.DiagAPI=s},653:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.MetricsAPI=void 0;let n=r(660),a=r(172),o=r(930),i="metrics";class s{constructor(){}static getInstance(){return this._instance||(this._instance=new s),this._instance}setGlobalMeterProvider(e){return(0,a.registerGlobal)(i,e,o.DiagAPI.instance())}getMeterProvider(){return(0,a.getGlobal)(i)||n.NOOP_METER_PROVIDER}getMeter(e,t,r){return this.getMeterProvider().getMeter(e,t,r)}disable(){(0,a.unregisterGlobal)(i,o.DiagAPI.instance())}}t.MetricsAPI=s},181:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.PropagationAPI=void 0;let n=r(172),a=r(874),o=r(194),i=r(277),s=r(369),l=r(930),u="propagation",c=new a.NoopTextMapPropagator;class d{constructor(){this.createBaggage=s.createBaggage,this.getBaggage=i.getBaggage,this.getActiveBaggage=i.getActiveBaggage,this.setBaggage=i.setBaggage,this.deleteBaggage=i.deleteBaggage}static getInstance(){return this._instance||(this._instance=new d),this._instance}setGlobalPropagator(e){return(0,n.registerGlobal)(u,e,l.DiagAPI.instance())}inject(e,t,r=o.defaultTextMapSetter){return this._getGlobalPropagator().inject(e,t,r)}extract(e,t,r=o.defaultTextMapGetter){return this._getGlobalPropagator().extract(e,t,r)}fields(){return this._getGlobalPropagator().fields()}disable(){(0,n.unregisterGlobal)(u,l.DiagAPI.instance())}_getGlobalPropagator(){return(0,n.getGlobal)(u)||c}}t.PropagationAPI=d},997:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.TraceAPI=void 0;let n=r(172),a=r(846),o=r(139),i=r(607),s=r(930),l="trace";class u{constructor(){this._proxyTracerProvider=new a.ProxyTracerProvider,this.wrapSpanContext=o.wrapSpanContext,this.isSpanContextValid=o.isSpanContextValid,this.deleteSpan=i.deleteSpan,this.getSpan=i.getSpan,this.getActiveSpan=i.getActiveSpan,this.getSpanContext=i.getSpanContext,this.setSpan=i.setSpan,this.setSpanContext=i.setSpanContext}static getInstance(){return this._instance||(this._instance=new u),this._instance}setGlobalTracerProvider(e){let t=(0,n.registerGlobal)(l,this._proxyTracerProvider,s.DiagAPI.instance());return t&&this._proxyTracerProvider.setDelegate(e),t}getTracerProvider(){return(0,n.getGlobal)(l)||this._proxyTracerProvider}getTracer(e,t){return this.getTracerProvider().getTracer(e,t)}disable(){(0,n.unregisterGlobal)(l,s.DiagAPI.instance()),this._proxyTracerProvider=new a.ProxyTracerProvider}}t.TraceAPI=u},277:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.deleteBaggage=t.setBaggage=t.getActiveBaggage=t.getBaggage=void 0;let n=r(491),a=(0,r(780).createContextKey)("OpenTelemetry Baggage Key");function o(e){return e.getValue(a)||void 0}t.getBaggage=o,t.getActiveBaggage=function(){return o(n.ContextAPI.getInstance().active())},t.setBaggage=function(e,t){return e.setValue(a,t)},t.deleteBaggage=function(e){return e.deleteValue(a)}},993:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.BaggageImpl=void 0;class r{constructor(e){this._entries=e?new Map(e):new Map}getEntry(e){let t=this._entries.get(e);if(t)return Object.assign({},t)}getAllEntries(){return Array.from(this._entries.entries()).map(([e,t])=>[e,t])}setEntry(e,t){let n=new r(this._entries);return n._entries.set(e,t),n}removeEntry(e){let t=new r(this._entries);return t._entries.delete(e),t}removeEntries(...e){let t=new r(this._entries);for(let r of e)t._entries.delete(r);return t}clear(){return new r}}t.BaggageImpl=r},830:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.baggageEntryMetadataSymbol=void 0,t.baggageEntryMetadataSymbol=Symbol("BaggageEntryMetadata")},369:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.baggageEntryMetadataFromString=t.createBaggage=void 0;let n=r(930),a=r(993),o=r(830),i=n.DiagAPI.instance();t.createBaggage=function(e={}){return new a.BaggageImpl(new Map(Object.entries(e)))},t.baggageEntryMetadataFromString=function(e){return"string"!=typeof e&&(i.error(`Cannot create baggage metadata from unknown type: ${typeof e}`),e=""),{__TYPE__:o.baggageEntryMetadataSymbol,toString:()=>e}}},67:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.context=void 0,t.context=r(491).ContextAPI.getInstance()},223:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.NoopContextManager=void 0;let n=r(780);t.NoopContextManager=class{active(){return n.ROOT_CONTEXT}with(e,t,r,...n){return t.call(r,...n)}bind(e,t){return t}enable(){return this}disable(){return this}}},780:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ROOT_CONTEXT=t.createContextKey=void 0,t.createContextKey=function(e){return Symbol.for(e)};class r{constructor(e){const t=this;t._currentContext=e?new Map(e):new Map,t.getValue=e=>t._currentContext.get(e),t.setValue=(e,n)=>{let a=new r(t._currentContext);return a._currentContext.set(e,n),a},t.deleteValue=e=>{let n=new r(t._currentContext);return n._currentContext.delete(e),n}}}t.ROOT_CONTEXT=new r},506:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.diag=void 0,t.diag=r(930).DiagAPI.instance()},56:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DiagComponentLogger=void 0;let n=r(172);function a(e,t,r){let a=(0,n.getGlobal)("diag");if(a)return r.unshift(t),a[e](...r)}t.DiagComponentLogger=class{constructor(e){this._namespace=e.namespace||"DiagComponentLogger"}debug(...e){return a("debug",this._namespace,e)}error(...e){return a("error",this._namespace,e)}info(...e){return a("info",this._namespace,e)}warn(...e){return a("warn",this._namespace,e)}verbose(...e){return a("verbose",this._namespace,e)}}},972:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.DiagConsoleLogger=void 0;let r=[{n:"error",c:"error"},{n:"warn",c:"warn"},{n:"info",c:"info"},{n:"debug",c:"debug"},{n:"verbose",c:"trace"}];t.DiagConsoleLogger=class{constructor(){for(let e=0;e<r.length;e++)this[r[e].n]=function(e){return function(...t){if(console){let r=console[e];if("function"!=typeof r&&(r=console.log),"function"==typeof r)return r.apply(console,t)}}}(r[e].c)}}},912:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.createLogLevelDiagLogger=void 0;let n=r(957);t.createLogLevelDiagLogger=function(e,t){function r(r,n){let a=t[r];return"function"==typeof a&&e>=n?a.bind(t):function(){}}return e<n.DiagLogLevel.NONE?e=n.DiagLogLevel.NONE:e>n.DiagLogLevel.ALL&&(e=n.DiagLogLevel.ALL),t=t||{},{error:r("error",n.DiagLogLevel.ERROR),warn:r("warn",n.DiagLogLevel.WARN),info:r("info",n.DiagLogLevel.INFO),debug:r("debug",n.DiagLogLevel.DEBUG),verbose:r("verbose",n.DiagLogLevel.VERBOSE)}}},957:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.DiagLogLevel=void 0,(r=t.DiagLogLevel||(t.DiagLogLevel={}))[r.NONE=0]="NONE",r[r.ERROR=30]="ERROR",r[r.WARN=50]="WARN",r[r.INFO=60]="INFO",r[r.DEBUG=70]="DEBUG",r[r.VERBOSE=80]="VERBOSE",r[r.ALL=9999]="ALL"},172:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.unregisterGlobal=t.getGlobal=t.registerGlobal=void 0;let n=r(200),a=r(521),o=r(130),i=a.VERSION.split(".")[0],s=Symbol.for(`opentelemetry.js.api.${i}`),l=n._globalThis;t.registerGlobal=function(e,t,r,n=!1){var o;let i=l[s]=null!=(o=l[s])?o:{version:a.VERSION};if(!n&&i[e]){let t=Error(`@opentelemetry/api: Attempted duplicate registration of API: ${e}`);return r.error(t.stack||t.message),!1}if(i.version!==a.VERSION){let t=Error(`@opentelemetry/api: Registration of version v${i.version} for ${e} does not match previously registered API v${a.VERSION}`);return r.error(t.stack||t.message),!1}return i[e]=t,r.debug(`@opentelemetry/api: Registered a global for ${e} v${a.VERSION}.`),!0},t.getGlobal=function(e){var t,r;let n=null==(t=l[s])?void 0:t.version;if(n&&(0,o.isCompatible)(n))return null==(r=l[s])?void 0:r[e]},t.unregisterGlobal=function(e,t){t.debug(`@opentelemetry/api: Unregistering a global for ${e} v${a.VERSION}.`);let r=l[s];r&&delete r[e]}},130:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.isCompatible=t._makeCompatibilityCheck=void 0;let n=r(521),a=/^(\d+)\.(\d+)\.(\d+)(-(.+))?$/;function o(e){let t=new Set([e]),r=new Set,n=e.match(a);if(!n)return()=>!1;let o={major:+n[1],minor:+n[2],patch:+n[3],prerelease:n[4]};if(null!=o.prerelease)return function(t){return t===e};function i(e){return r.add(e),!1}return function(e){if(t.has(e))return!0;if(r.has(e))return!1;let n=e.match(a);if(!n)return i(e);let s={major:+n[1],minor:+n[2],patch:+n[3],prerelease:n[4]};if(null!=s.prerelease||o.major!==s.major)return i(e);if(0===o.major)return o.minor===s.minor&&o.patch<=s.patch?(t.add(e),!0):i(e);return o.minor<=s.minor?(t.add(e),!0):i(e)}}t._makeCompatibilityCheck=o,t.isCompatible=o(n.VERSION)},886:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.metrics=void 0,t.metrics=r(653).MetricsAPI.getInstance()},901:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.ValueType=void 0,(r=t.ValueType||(t.ValueType={}))[r.INT=0]="INT",r[r.DOUBLE=1]="DOUBLE"},102:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.createNoopMeter=t.NOOP_OBSERVABLE_UP_DOWN_COUNTER_METRIC=t.NOOP_OBSERVABLE_GAUGE_METRIC=t.NOOP_OBSERVABLE_COUNTER_METRIC=t.NOOP_UP_DOWN_COUNTER_METRIC=t.NOOP_HISTOGRAM_METRIC=t.NOOP_COUNTER_METRIC=t.NOOP_METER=t.NoopObservableUpDownCounterMetric=t.NoopObservableGaugeMetric=t.NoopObservableCounterMetric=t.NoopObservableMetric=t.NoopHistogramMetric=t.NoopUpDownCounterMetric=t.NoopCounterMetric=t.NoopMetric=t.NoopMeter=void 0;class r{constructor(){}createHistogram(e,r){return t.NOOP_HISTOGRAM_METRIC}createCounter(e,r){return t.NOOP_COUNTER_METRIC}createUpDownCounter(e,r){return t.NOOP_UP_DOWN_COUNTER_METRIC}createObservableGauge(e,r){return t.NOOP_OBSERVABLE_GAUGE_METRIC}createObservableCounter(e,r){return t.NOOP_OBSERVABLE_COUNTER_METRIC}createObservableUpDownCounter(e,r){return t.NOOP_OBSERVABLE_UP_DOWN_COUNTER_METRIC}addBatchObservableCallback(e,t){}removeBatchObservableCallback(e){}}t.NoopMeter=r;class n{}t.NoopMetric=n;class a extends n{add(e,t){}}t.NoopCounterMetric=a;class o extends n{add(e,t){}}t.NoopUpDownCounterMetric=o;class i extends n{record(e,t){}}t.NoopHistogramMetric=i;class s{addCallback(e){}removeCallback(e){}}t.NoopObservableMetric=s;class l extends s{}t.NoopObservableCounterMetric=l;class u extends s{}t.NoopObservableGaugeMetric=u;class c extends s{}t.NoopObservableUpDownCounterMetric=c,t.NOOP_METER=new r,t.NOOP_COUNTER_METRIC=new a,t.NOOP_HISTOGRAM_METRIC=new i,t.NOOP_UP_DOWN_COUNTER_METRIC=new o,t.NOOP_OBSERVABLE_COUNTER_METRIC=new l,t.NOOP_OBSERVABLE_GAUGE_METRIC=new u,t.NOOP_OBSERVABLE_UP_DOWN_COUNTER_METRIC=new c,t.createNoopMeter=function(){return t.NOOP_METER}},660:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.NOOP_METER_PROVIDER=t.NoopMeterProvider=void 0;let n=r(102);class a{getMeter(e,t,r){return n.NOOP_METER}}t.NoopMeterProvider=a,t.NOOP_METER_PROVIDER=new a},200:function(e,t,r){var n=this&&this.__createBinding||(Object.create?function(e,t,r,n){void 0===n&&(n=r),Object.defineProperty(e,n,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,n){void 0===n&&(n=r),e[n]=t[r]}),a=this&&this.__exportStar||function(e,t){for(var r in e)"default"===r||Object.prototype.hasOwnProperty.call(t,r)||n(t,e,r)};Object.defineProperty(t,"__esModule",{value:!0}),a(r(46),t)},651:(t,r)=>{Object.defineProperty(r,"__esModule",{value:!0}),r._globalThis=void 0,r._globalThis="object"==typeof globalThis?globalThis:e.g},46:function(e,t,r){var n=this&&this.__createBinding||(Object.create?function(e,t,r,n){void 0===n&&(n=r),Object.defineProperty(e,n,{enumerable:!0,get:function(){return t[r]}})}:function(e,t,r,n){void 0===n&&(n=r),e[n]=t[r]}),a=this&&this.__exportStar||function(e,t){for(var r in e)"default"===r||Object.prototype.hasOwnProperty.call(t,r)||n(t,e,r)};Object.defineProperty(t,"__esModule",{value:!0}),a(r(651),t)},939:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.propagation=void 0,t.propagation=r(181).PropagationAPI.getInstance()},874:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.NoopTextMapPropagator=void 0,t.NoopTextMapPropagator=class{inject(e,t){}extract(e,t){return e}fields(){return[]}}},194:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.defaultTextMapSetter=t.defaultTextMapGetter=void 0,t.defaultTextMapGetter={get(e,t){if(null!=e)return e[t]},keys:e=>null==e?[]:Object.keys(e)},t.defaultTextMapSetter={set(e,t,r){null!=e&&(e[t]=r)}}},845:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.trace=void 0,t.trace=r(997).TraceAPI.getInstance()},403:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.NonRecordingSpan=void 0;let n=r(476);t.NonRecordingSpan=class{constructor(e=n.INVALID_SPAN_CONTEXT){this._spanContext=e}spanContext(){return this._spanContext}setAttribute(e,t){return this}setAttributes(e){return this}addEvent(e,t){return this}setStatus(e){return this}updateName(e){return this}end(e){}isRecording(){return!1}recordException(e,t){}}},614:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.NoopTracer=void 0;let n=r(491),a=r(607),o=r(403),i=r(139),s=n.ContextAPI.getInstance();t.NoopTracer=class{startSpan(e,t,r=s.active()){var n;if(null==t?void 0:t.root)return new o.NonRecordingSpan;let l=r&&(0,a.getSpanContext)(r);return"object"==typeof(n=l)&&"string"==typeof n.spanId&&"string"==typeof n.traceId&&"number"==typeof n.traceFlags&&(0,i.isSpanContextValid)(l)?new o.NonRecordingSpan(l):new o.NonRecordingSpan}startActiveSpan(e,t,r,n){let o,i,l;if(arguments.length<2)return;2==arguments.length?l=t:3==arguments.length?(o=t,l=r):(o=t,i=r,l=n);let u=null!=i?i:s.active(),c=this.startSpan(e,o,u),d=(0,a.setSpan)(u,c);return s.with(d,l,void 0,c)}}},124:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.NoopTracerProvider=void 0;let n=r(614);t.NoopTracerProvider=class{getTracer(e,t,r){return new n.NoopTracer}}},125:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ProxyTracer=void 0;let n=new(r(614)).NoopTracer;t.ProxyTracer=class{constructor(e,t,r,n){this._provider=e,this.name=t,this.version=r,this.options=n}startSpan(e,t,r){return this._getTracer().startSpan(e,t,r)}startActiveSpan(e,t,r,n){let a=this._getTracer();return Reflect.apply(a.startActiveSpan,a,arguments)}_getTracer(){if(this._delegate)return this._delegate;let e=this._provider.getDelegateTracer(this.name,this.version,this.options);return e?(this._delegate=e,this._delegate):n}}},846:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.ProxyTracerProvider=void 0;let n=r(125),a=new(r(124)).NoopTracerProvider;t.ProxyTracerProvider=class{getTracer(e,t,r){var a;return null!=(a=this.getDelegateTracer(e,t,r))?a:new n.ProxyTracer(this,e,t,r)}getDelegate(){var e;return null!=(e=this._delegate)?e:a}setDelegate(e){this._delegate=e}getDelegateTracer(e,t,r){var n;return null==(n=this._delegate)?void 0:n.getTracer(e,t,r)}}},996:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.SamplingDecision=void 0,(r=t.SamplingDecision||(t.SamplingDecision={}))[r.NOT_RECORD=0]="NOT_RECORD",r[r.RECORD=1]="RECORD",r[r.RECORD_AND_SAMPLED=2]="RECORD_AND_SAMPLED"},607:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.getSpanContext=t.setSpanContext=t.deleteSpan=t.setSpan=t.getActiveSpan=t.getSpan=void 0;let n=r(780),a=r(403),o=r(491),i=(0,n.createContextKey)("OpenTelemetry Context Key SPAN");function s(e){return e.getValue(i)||void 0}function l(e,t){return e.setValue(i,t)}t.getSpan=s,t.getActiveSpan=function(){return s(o.ContextAPI.getInstance().active())},t.setSpan=l,t.deleteSpan=function(e){return e.deleteValue(i)},t.setSpanContext=function(e,t){return l(e,new a.NonRecordingSpan(t))},t.getSpanContext=function(e){var t;return null==(t=s(e))?void 0:t.spanContext()}},325:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.TraceStateImpl=void 0;let n=r(564);class a{constructor(e){this._internalState=new Map,e&&this._parse(e)}set(e,t){let r=this._clone();return r._internalState.has(e)&&r._internalState.delete(e),r._internalState.set(e,t),r}unset(e){let t=this._clone();return t._internalState.delete(e),t}get(e){return this._internalState.get(e)}serialize(){return this._keys().reduce((e,t)=>(e.push(t+"="+this.get(t)),e),[]).join(",")}_parse(e){!(e.length>512)&&(this._internalState=e.split(",").reverse().reduce((e,t)=>{let r=t.trim(),a=r.indexOf("=");if(-1!==a){let o=r.slice(0,a),i=r.slice(a+1,t.length);(0,n.validateKey)(o)&&(0,n.validateValue)(i)&&e.set(o,i)}return e},new Map),this._internalState.size>32&&(this._internalState=new Map(Array.from(this._internalState.entries()).reverse().slice(0,32))))}_keys(){return Array.from(this._internalState.keys()).reverse()}_clone(){let e=new a;return e._internalState=new Map(this._internalState),e}}t.TraceStateImpl=a},564:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.validateValue=t.validateKey=void 0;let r="[_0-9a-z-*/]",n=`[a-z]${r}{0,255}`,a=`[a-z0-9]${r}{0,240}@[a-z]${r}{0,13}`,o=RegExp(`^(?:${n}|${a})$`),i=/^[ -~]{0,255}[!-~]$/,s=/,|=/;t.validateKey=function(e){return o.test(e)},t.validateValue=function(e){return i.test(e)&&!s.test(e)}},98:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.createTraceState=void 0;let n=r(325);t.createTraceState=function(e){return new n.TraceStateImpl(e)}},476:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.INVALID_SPAN_CONTEXT=t.INVALID_TRACEID=t.INVALID_SPANID=void 0;let n=r(475);t.INVALID_SPANID="0000000000000000",t.INVALID_TRACEID="00000000000000000000000000000000",t.INVALID_SPAN_CONTEXT={traceId:t.INVALID_TRACEID,spanId:t.INVALID_SPANID,traceFlags:n.TraceFlags.NONE}},357:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.SpanKind=void 0,(r=t.SpanKind||(t.SpanKind={}))[r.INTERNAL=0]="INTERNAL",r[r.SERVER=1]="SERVER",r[r.CLIENT=2]="CLIENT",r[r.PRODUCER=3]="PRODUCER",r[r.CONSUMER=4]="CONSUMER"},139:(e,t,r)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.wrapSpanContext=t.isSpanContextValid=t.isValidSpanId=t.isValidTraceId=void 0;let n=r(476),a=r(403),o=/^([0-9a-f]{32})$/i,i=/^[0-9a-f]{16}$/i;function s(e){return o.test(e)&&e!==n.INVALID_TRACEID}function l(e){return i.test(e)&&e!==n.INVALID_SPANID}t.isValidTraceId=s,t.isValidSpanId=l,t.isSpanContextValid=function(e){return s(e.traceId)&&l(e.spanId)},t.wrapSpanContext=function(e){return new a.NonRecordingSpan(e)}},847:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.SpanStatusCode=void 0,(r=t.SpanStatusCode||(t.SpanStatusCode={}))[r.UNSET=0]="UNSET",r[r.OK=1]="OK",r[r.ERROR=2]="ERROR"},475:(e,t)=>{var r;Object.defineProperty(t,"__esModule",{value:!0}),t.TraceFlags=void 0,(r=t.TraceFlags||(t.TraceFlags={}))[r.NONE=0]="NONE",r[r.SAMPLED=1]="SAMPLED"},521:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.VERSION=void 0,t.VERSION="1.6.0"}},O={};function w(e){var t=O[e];if(void 0!==t)return t.exports;var r=O[e]={exports:{}},n=!0;try{R[e].call(r.exports,r,r.exports,w),n=!1}finally{n&&delete O[e]}return r.exports}w.ab="/ROOT/node_modules/.pnpm/next@16.0.7_@opentelemetry+api@1.9.0_babel-plugin-react-compiler@1.0.0_react-dom@19.3.0_a20848594014cb183ab624f2be88a203/node_modules/next/dist/compiled/@opentelemetry/api/";var T={};Object.defineProperty(T,"__esModule",{value:!0}),T.trace=T.propagation=T.metrics=T.diag=T.context=T.INVALID_SPAN_CONTEXT=T.INVALID_TRACEID=T.INVALID_SPANID=T.isValidSpanId=T.isValidTraceId=T.isSpanContextValid=T.createTraceState=T.TraceFlags=T.SpanStatusCode=T.SpanKind=T.SamplingDecision=T.ProxyTracerProvider=T.ProxyTracer=T.defaultTextMapSetter=T.defaultTextMapGetter=T.ValueType=T.createNoopMeter=T.DiagLogLevel=T.DiagConsoleLogger=T.ROOT_CONTEXT=T.createContextKey=T.baggageEntryMetadataFromString=void 0,s=w(369),Object.defineProperty(T,"baggageEntryMetadataFromString",{enumerable:!0,get:function(){return s.baggageEntryMetadataFromString}}),l=w(780),Object.defineProperty(T,"createContextKey",{enumerable:!0,get:function(){return l.createContextKey}}),Object.defineProperty(T,"ROOT_CONTEXT",{enumerable:!0,get:function(){return l.ROOT_CONTEXT}}),u=w(972),Object.defineProperty(T,"DiagConsoleLogger",{enumerable:!0,get:function(){return u.DiagConsoleLogger}}),c=w(957),Object.defineProperty(T,"DiagLogLevel",{enumerable:!0,get:function(){return c.DiagLogLevel}}),d=w(102),Object.defineProperty(T,"createNoopMeter",{enumerable:!0,get:function(){return d.createNoopMeter}}),p=w(901),Object.defineProperty(T,"ValueType",{enumerable:!0,get:function(){return p.ValueType}}),f=w(194),Object.defineProperty(T,"defaultTextMapGetter",{enumerable:!0,get:function(){return f.defaultTextMapGetter}}),Object.defineProperty(T,"defaultTextMapSetter",{enumerable:!0,get:function(){return f.defaultTextMapSetter}}),h=w(125),Object.defineProperty(T,"ProxyTracer",{enumerable:!0,get:function(){return h.ProxyTracer}}),g=w(846),Object.defineProperty(T,"ProxyTracerProvider",{enumerable:!0,get:function(){return g.ProxyTracerProvider}}),v=w(996),Object.defineProperty(T,"SamplingDecision",{enumerable:!0,get:function(){return v.SamplingDecision}}),y=w(357),Object.defineProperty(T,"SpanKind",{enumerable:!0,get:function(){return y.SpanKind}}),m=w(847),Object.defineProperty(T,"SpanStatusCode",{enumerable:!0,get:function(){return m.SpanStatusCode}}),_=w(475),Object.defineProperty(T,"TraceFlags",{enumerable:!0,get:function(){return _.TraceFlags}}),b=w(98),Object.defineProperty(T,"createTraceState",{enumerable:!0,get:function(){return b.createTraceState}}),S=w(139),Object.defineProperty(T,"isSpanContextValid",{enumerable:!0,get:function(){return S.isSpanContextValid}}),Object.defineProperty(T,"isValidTraceId",{enumerable:!0,get:function(){return S.isValidTraceId}}),Object.defineProperty(T,"isValidSpanId",{enumerable:!0,get:function(){return S.isValidSpanId}}),E=w(476),Object.defineProperty(T,"INVALID_SPANID",{enumerable:!0,get:function(){return E.INVALID_SPANID}}),Object.defineProperty(T,"INVALID_TRACEID",{enumerable:!0,get:function(){return E.INVALID_TRACEID}}),Object.defineProperty(T,"INVALID_SPAN_CONTEXT",{enumerable:!0,get:function(){return E.INVALID_SPAN_CONTEXT}}),r=w(67),Object.defineProperty(T,"context",{enumerable:!0,get:function(){return r.context}}),n=w(506),Object.defineProperty(T,"diag",{enumerable:!0,get:function(){return n.diag}}),a=w(886),Object.defineProperty(T,"metrics",{enumerable:!0,get:function(){return a.metrics}}),o=w(939),Object.defineProperty(T,"propagation",{enumerable:!0,get:function(){return o.propagation}}),i=w(845),Object.defineProperty(T,"trace",{enumerable:!0,get:function(){return i.trace}}),T.default={context:r.context,diag:n.diag,metrics:a.metrics,propagation:o.propagation,trace:i.trace},t.exports=T})()},41640,(e,t,r)=>{"use strict";t.exports=e.r(18622)},23292,(e,t,r)=>{"use strict";t.exports=e.r(41640).vendored["react-rsc"].React},45408,(e,t,r)=>{"use strict";var n=Object.defineProperty,a=Object.getOwnPropertyDescriptor,o=Object.getOwnPropertyNames,i=Object.prototype.hasOwnProperty,s={},l={RequestCookies:()=>g,ResponseCookies:()=>v,parseCookie:()=>d,parseSetCookie:()=>p,stringifyCookie:()=>c};for(var u in l)n(s,u,{get:l[u],enumerable:!0});function c(e){var t;let r=["path"in e&&e.path&&`Path=${e.path}`,"expires"in e&&(e.expires||0===e.expires)&&`Expires=${("number"==typeof e.expires?new Date(e.expires):e.expires).toUTCString()}`,"maxAge"in e&&"number"==typeof e.maxAge&&`Max-Age=${e.maxAge}`,"domain"in e&&e.domain&&`Domain=${e.domain}`,"secure"in e&&e.secure&&"Secure","httpOnly"in e&&e.httpOnly&&"HttpOnly","sameSite"in e&&e.sameSite&&`SameSite=${e.sameSite}`,"partitioned"in e&&e.partitioned&&"Partitioned","priority"in e&&e.priority&&`Priority=${e.priority}`].filter(Boolean),n=`${e.name}=${encodeURIComponent(null!=(t=e.value)?t:"")}`;return 0===r.length?n:`${n}; ${r.join("; ")}`}function d(e){let t=new Map;for(let r of e.split(/; */)){if(!r)continue;let e=r.indexOf("=");if(-1===e){t.set(r,"true");continue}let[n,a]=[r.slice(0,e),r.slice(e+1)];try{t.set(n,decodeURIComponent(null!=a?a:"true"))}catch{}}return t}function p(e){if(!e)return;let[[t,r],...n]=d(e),{domain:a,expires:o,httponly:i,maxage:s,path:l,samesite:u,secure:c,partitioned:p,priority:g}=Object.fromEntries(n.map(([e,t])=>[e.toLowerCase().replace(/-/g,""),t]));{var v,y,m={name:t,value:decodeURIComponent(r),domain:a,...o&&{expires:new Date(o)},...i&&{httpOnly:!0},..."string"==typeof s&&{maxAge:Number(s)},path:l,...u&&{sameSite:f.includes(v=(v=u).toLowerCase())?v:void 0},...c&&{secure:!0},...g&&{priority:h.includes(y=(y=g).toLowerCase())?y:void 0},...p&&{partitioned:!0}};let e={};for(let t in m)m[t]&&(e[t]=m[t]);return e}}t.exports=((e,t,r,s)=>{if(t&&"object"==typeof t||"function"==typeof t)for(let l of o(t))i.call(e,l)||l===r||n(e,l,{get:()=>t[l],enumerable:!(s=a(t,l))||s.enumerable});return e})(n({},"__esModule",{value:!0}),s);var f=["strict","lax","none"],h=["low","medium","high"],g=class{constructor(e){this._parsed=new Map,this._headers=e;const t=e.get("cookie");if(t)for(const[e,r]of d(t))this._parsed.set(e,{name:e,value:r})}[Symbol.iterator](){return this._parsed[Symbol.iterator]()}get size(){return this._parsed.size}get(...e){let t="string"==typeof e[0]?e[0]:e[0].name;return this._parsed.get(t)}getAll(...e){var t;let r=Array.from(this._parsed);if(!e.length)return r.map(([e,t])=>t);let n="string"==typeof e[0]?e[0]:null==(t=e[0])?void 0:t.name;return r.filter(([e])=>e===n).map(([e,t])=>t)}has(e){return this._parsed.has(e)}set(...e){let[t,r]=1===e.length?[e[0].name,e[0].value]:e,n=this._parsed;return n.set(t,{name:t,value:r}),this._headers.set("cookie",Array.from(n).map(([e,t])=>c(t)).join("; ")),this}delete(e){let t=this._parsed,r=Array.isArray(e)?e.map(e=>t.delete(e)):t.delete(e);return this._headers.set("cookie",Array.from(t).map(([e,t])=>c(t)).join("; ")),r}clear(){return this.delete(Array.from(this._parsed.keys())),this}[Symbol.for("edge-runtime.inspect.custom")](){return`RequestCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`}toString(){return[...this._parsed.values()].map(e=>`${e.name}=${encodeURIComponent(e.value)}`).join("; ")}},v=class{constructor(e){var t,r,n;this._parsed=new Map,this._headers=e;const a=null!=(n=null!=(r=null==(t=e.getSetCookie)?void 0:t.call(e))?r:e.get("set-cookie"))?n:[];for(const e of Array.isArray(a)?a:function(e){if(!e)return[];var t,r,n,a,o,i=[],s=0;function l(){for(;s<e.length&&/\s/.test(e.charAt(s));)s+=1;return s<e.length}for(;s<e.length;){for(t=s,o=!1;l();)if(","===(r=e.charAt(s))){for(n=s,s+=1,l(),a=s;s<e.length&&"="!==(r=e.charAt(s))&&";"!==r&&","!==r;)s+=1;s<e.length&&"="===e.charAt(s)?(o=!0,s=a,i.push(e.substring(t,n)),t=s):s=n+1}else s+=1;(!o||s>=e.length)&&i.push(e.substring(t,e.length))}return i}(a)){const t=p(e);t&&this._parsed.set(t.name,t)}}get(...e){let t="string"==typeof e[0]?e[0]:e[0].name;return this._parsed.get(t)}getAll(...e){var t;let r=Array.from(this._parsed.values());if(!e.length)return r;let n="string"==typeof e[0]?e[0]:null==(t=e[0])?void 0:t.name;return r.filter(e=>e.name===n)}has(e){return this._parsed.has(e)}set(...e){let[t,r,n]=1===e.length?[e[0].name,e[0].value,e[0]]:e,a=this._parsed;return a.set(t,function(e={name:"",value:""}){return"number"==typeof e.expires&&(e.expires=new Date(e.expires)),e.maxAge&&(e.expires=new Date(Date.now()+1e3*e.maxAge)),(null===e.path||void 0===e.path)&&(e.path="/"),e}({name:t,value:r,...n})),function(e,t){for(let[,r]of(t.delete("set-cookie"),e)){let e=c(r);t.append("set-cookie",e)}}(a,this._headers),this}delete(...e){let[t,r]="string"==typeof e[0]?[e[0]]:[e[0].name,e[0]];return this.set({...r,name:t,value:"",expires:new Date(0)})}[Symbol.for("edge-runtime.inspect.custom")](){return`ResponseCookies ${JSON.stringify(Object.fromEntries(this._parsed))}`}toString(){return[...this._parsed.values()].map(c).join("; ")}}},90677,(e,t,r)=>{(()=>{"use strict";"undefined"!=typeof __nccwpck_require__&&(__nccwpck_require__.ab="/ROOT/node_modules/.pnpm/next@16.0.7_@opentelemetry+api@1.9.0_babel-plugin-react-compiler@1.0.0_react-dom@19.3.0_a20848594014cb183ab624f2be88a203/node_modules/next/dist/compiled/cookie/");var e,r,n,a,o={};o.parse=function(t,r){if("string"!=typeof t)throw TypeError("argument str must be a string");for(var a={},o=t.split(n),i=(r||{}).decode||e,s=0;s<o.length;s++){var l=o[s],u=l.indexOf("=");if(!(u<0)){var c=l.substr(0,u).trim(),d=l.substr(++u,l.length).trim();'"'==d[0]&&(d=d.slice(1,-1)),void 0==a[c]&&(a[c]=function(e,t){try{return t(e)}catch(t){return e}}(d,i))}}return a},o.serialize=function(e,t,n){var o=n||{},i=o.encode||r;if("function"!=typeof i)throw TypeError("option encode is invalid");if(!a.test(e))throw TypeError("argument name is invalid");var s=i(t);if(s&&!a.test(s))throw TypeError("argument val is invalid");var l=e+"="+s;if(null!=o.maxAge){var u=o.maxAge-0;if(isNaN(u)||!isFinite(u))throw TypeError("option maxAge is invalid");l+="; Max-Age="+Math.floor(u)}if(o.domain){if(!a.test(o.domain))throw TypeError("option domain is invalid");l+="; Domain="+o.domain}if(o.path){if(!a.test(o.path))throw TypeError("option path is invalid");l+="; Path="+o.path}if(o.expires){if("function"!=typeof o.expires.toUTCString)throw TypeError("option expires is invalid");l+="; Expires="+o.expires.toUTCString()}if(o.httpOnly&&(l+="; HttpOnly"),o.secure&&(l+="; Secure"),o.sameSite)switch("string"==typeof o.sameSite?o.sameSite.toLowerCase():o.sameSite){case!0:case"strict":l+="; SameSite=Strict";break;case"lax":l+="; SameSite=Lax";break;case"none":l+="; SameSite=None";break;default:throw TypeError("option sameSite is invalid")}return l},e=decodeURIComponent,r=encodeURIComponent,n=/; */,a=/^[\u0009\u0020-\u007e\u0080-\u00ff]+$/,t.exports=o})()},3797,87608,54296,97691,91349,36096,45577,86157,24496,66154,84521,23249,33185,67707,48432,77430,92366,e=>{"use strict";let t,r,n;var a,o,i,s,l,u,c,d,p,f,h,g,v,y,m,_,b,S,E=((b={}).PAGES="PAGES",b.PAGES_API="PAGES_API",b.APP_PAGE="APP_PAGE",b.APP_ROUTE="APP_ROUTE",b.IMAGE="IMAGE",b);e.s(["RouteKind",()=>E],3797);var R=((a=R||{}).handleRequest="BaseServer.handleRequest",a.run="BaseServer.run",a.pipe="BaseServer.pipe",a.getStaticHTML="BaseServer.getStaticHTML",a.render="BaseServer.render",a.renderToResponseWithComponents="BaseServer.renderToResponseWithComponents",a.renderToResponse="BaseServer.renderToResponse",a.renderToHTML="BaseServer.renderToHTML",a.renderError="BaseServer.renderError",a.renderErrorToResponse="BaseServer.renderErrorToResponse",a.renderErrorToHTML="BaseServer.renderErrorToHTML",a.render404="BaseServer.render404",a),O=((o=O||{}).loadDefaultErrorComponents="LoadComponents.loadDefaultErrorComponents",o.loadComponents="LoadComponents.loadComponents",o),w=((i=w||{}).getRequestHandler="NextServer.getRequestHandler",i.getRequestHandlerWithMetadata="NextServer.getRequestHandlerWithMetadata",i.getServer="NextServer.getServer",i.getServerRequestHandler="NextServer.getServerRequestHandler",i.createServer="createServer.createServer",i),T=((s=T||{}).compression="NextNodeServer.compression",s.getBuildId="NextNodeServer.getBuildId",s.createComponentTree="NextNodeServer.createComponentTree",s.clientComponentLoading="NextNodeServer.clientComponentLoading",s.getLayoutOrPageModule="NextNodeServer.getLayoutOrPageModule",s.generateStaticRoutes="NextNodeServer.generateStaticRoutes",s.generateFsStaticRoutes="NextNodeServer.generateFsStaticRoutes",s.generatePublicRoutes="NextNodeServer.generatePublicRoutes",s.generateImageRoutes="NextNodeServer.generateImageRoutes.route",s.sendRenderResult="NextNodeServer.sendRenderResult",s.proxyRequest="NextNodeServer.proxyRequest",s.runApi="NextNodeServer.runApi",s.render="NextNodeServer.render",s.renderHTML="NextNodeServer.renderHTML",s.imageOptimizer="NextNodeServer.imageOptimizer",s.getPagePath="NextNodeServer.getPagePath",s.getRoutesManifest="NextNodeServer.getRoutesManifest",s.findPageComponents="NextNodeServer.findPageComponents",s.getFontManifest="NextNodeServer.getFontManifest",s.getServerComponentManifest="NextNodeServer.getServerComponentManifest",s.getRequestHandler="NextNodeServer.getRequestHandler",s.renderToHTML="NextNodeServer.renderToHTML",s.renderError="NextNodeServer.renderError",s.renderErrorToHTML="NextNodeServer.renderErrorToHTML",s.render404="NextNodeServer.render404",s.startResponse="NextNodeServer.startResponse",s.route="route",s.onProxyReq="onProxyReq",s.apiResolver="apiResolver",s.internalFetch="internalFetch",s),x=((l=x||{}).startServer="startServer.startServer",l),P=((u=P||{}).getServerSideProps="Render.getServerSideProps",u.getStaticProps="Render.getStaticProps",u.renderToString="Render.renderToString",u.renderDocument="Render.renderDocument",u.createBodyResult="Render.createBodyResult",u),N=((c=N||{}).renderToString="AppRender.renderToString",c.renderToReadableStream="AppRender.renderToReadableStream",c.getBodyResult="AppRender.getBodyResult",c.fetch="AppRender.fetch",c),C=((d=C||{}).executeRoute="Router.executeRoute",d),A=((p=A||{}).runHandler="Node.runHandler",p),I=((f=I||{}).runHandler="AppRouteRouteHandlers.runHandler",f),M=((h=M||{}).generateMetadata="ResolveMetadata.generateMetadata",h.generateViewport="ResolveMetadata.generateViewport",h),L=((g=L||{}).execute="Middleware.execute",g);let D=new Set(["Middleware.execute","BaseServer.handleRequest","Render.getServerSideProps","Render.getStaticProps","AppRender.fetch","AppRender.getBodyResult","Render.renderDocument","Node.runHandler","AppRouteRouteHandlers.runHandler","ResolveMetadata.generateMetadata","ResolveMetadata.generateViewport","NextNodeServer.createComponentTree","NextNodeServer.findPageComponents","NextNodeServer.getLayoutOrPageModule","NextNodeServer.startResponse","NextNodeServer.clientComponentLoading"]),j=new Set(["NextNodeServer.findPageComponents","NextNodeServer.createComponentTree","NextNodeServer.clientComponentLoading"]);e.s(["AppRenderSpan",()=>N,"BaseServerSpan",()=>R,"LogSpanAllowList",0,j,"NextNodeServerSpan",()=>T,"NextVanillaSpanAllowlist",0,D,"NodeSpan",()=>A],87608);let B=process.env.NEXT_OTEL_PERFORMANCE_PREFIX;try{t=e.r(67173)}catch(r){t=e.r(44928)}let{context:V,propagation:k,trace:U,SpanStatusCode:$,SpanKind:G,ROOT_CONTEXT:H}=t;class F extends Error{constructor(e,t){super(),this.bubble=e,this.result=t}}let q=(e,t)=>{"object"==typeof t&&null!==t&&t instanceof F&&t.bubble?e.setAttribute("next.bubble",!0):(t&&(e.recordException(t),e.setAttribute("error.type",t.name)),e.setStatus({code:$.ERROR,message:null==t?void 0:t.message})),e.end()},X=new Map,W=t.createContextKey("next.rootSpanId"),K=0,z={set(e,t,r){e.push({key:t,value:r})}},Y=(n=new class e{getTracerInstance(){return U.getTracer("next.js","0.0.1")}getContext(){return V}getTracePropagationData(){let e=V.active(),t=[];return k.inject(e,t,z),t}getActiveScopeSpan(){return U.getSpan(null==V?void 0:V.active())}withPropagatedContext(e,t,r){let n=V.active();if(U.getSpanContext(n))return t();let a=k.extract(n,e,r);return V.with(a,t)}trace(...e){let[t,r,n]=e,{fn:a,options:o}="function"==typeof r?{fn:r,options:{}}:{fn:n,options:{...r}},i=o.spanName??t;if(!D.has(t)&&"1"!==process.env.NEXT_OTEL_VERBOSE||o.hideSpan)return a();let s=this.getSpanContext((null==o?void 0:o.parentSpan)??this.getActiveScopeSpan());s||(s=(null==V?void 0:V.active())??H);let l=s.getValue(W),u="number"!=typeof l||!X.has(l),c=K++;return o.attributes={"next.span_name":i,"next.span_type":t,...o.attributes},V.with(s.setValue(W,c),()=>this.getTracerInstance().startActiveSpan(i,o,e=>{let r;B&&t&&j.has(t)&&(r="performance"in globalThis&&"measure"in performance?globalThis.performance.now():void 0);let n=!1,i=()=>{!n&&(n=!0,X.delete(c),r&&performance.measure(`${B}:next-${(t.split(".").pop()||"").replace(/[A-Z]/g,e=>"-"+e.toLowerCase())}`,{start:r,end:performance.now()}))};if(u&&X.set(c,new Map(Object.entries(o.attributes??{}))),a.length>1)try{return a(e,t=>q(e,t))}catch(t){throw q(e,t),t}finally{i()}try{let t=a(e);if(null!==t&&"object"==typeof t&&"then"in t&&"function"==typeof t.then)return t.then(t=>(e.end(),t)).catch(t=>{throw q(e,t),t}).finally(i);return e.end(),i(),t}catch(t){throw q(e,t),i(),t}}))}wrap(...e){let t=this,[r,n,a]=3===e.length?e:[e[0],{},e[1]];return D.has(r)||"1"===process.env.NEXT_OTEL_VERBOSE?function(){let e=n;"function"==typeof e&&"function"==typeof a&&(e=e.apply(this,arguments));let o=arguments.length-1,i=arguments[o];if("function"!=typeof i)return t.trace(r,e,()=>a.apply(this,arguments));{let n=t.getContext().bind(V.active(),i);return t.trace(r,e,(e,t)=>(arguments[o]=function(e){return null==t||t(e),n.apply(this,arguments)},a.apply(this,arguments)))}}:a}startSpan(...e){let[t,r]=e,n=this.getSpanContext((null==r?void 0:r.parentSpan)??this.getActiveScopeSpan());return this.getTracerInstance().startSpan(t,r,n)}getSpanContext(e){return e?U.setSpan(V.active(),e):void 0}getRootSpanAttributes(){let e=V.active().getValue(W);return X.get(e)}setRootSpanAttribute(e,t){let r=V.active().getValue(W),n=X.get(r);n&&!n.has(e)&&n.set(e,t)}},()=>n);e.s(["SpanKind",()=>G,"getTracer",()=>Y],54296);let J={shared:"shared",reactServerComponents:"rsc",serverSideRendering:"ssr",actionBrowser:"action-browser",apiNode:"api-node",apiEdge:"api-edge",middleware:"middleware",instrument:"instrument",edgeAsset:"edge-asset",appPagesBrowser:"app-pages-browser",pagesDirBrowser:"pages-dir-browser",pagesDirEdge:"pages-dir-edge",pagesDirNode:"pages-dir-node"};J.reactServerComponents,J.actionBrowser,J.reactServerComponents,J.actionBrowser,J.instrument,J.middleware,J.apiNode,J.apiEdge,J.serverSideRendering,J.appPagesBrowser,J.reactServerComponents,J.actionBrowser,J.serverSideRendering,J.appPagesBrowser,J.shared,J.instrument,J.middleware,J.reactServerComponents,J.serverSideRendering,J.appPagesBrowser,J.actionBrowser,e.s(["CACHE_ONE_YEAR",0,31536e3,"HTML_CONTENT_TYPE_HEADER",0,"text/html; charset=utf-8","INFINITE_CACHE",0,0xfffffffe,"NEXT_CACHE_TAGS_HEADER",0,"x-next-cache-tags","NEXT_CACHE_TAG_MAX_ITEMS",0,128,"NEXT_CACHE_TAG_MAX_LENGTH",0,256,"NEXT_INTERCEPTION_MARKER_PREFIX",0,"nxtI","NEXT_QUERY_PARAM_PREFIX",0,"nxtP","PRERENDER_REVALIDATE_HEADER",0,"x-prerender-revalidate","PRERENDER_REVALIDATE_ONLY_GENERATED_HEADER",0,"x-prerender-revalidate-if-generated"],97691);var Q=e.i(23292);class Z extends Error{constructor(e){super(`Dynamic server usage: ${e}`),this.description=e,this.digest="DYNAMIC_SERVER_USAGE"}}class ee extends Error{constructor(...e){super(...e),this.code="NEXT_STATIC_GEN_BAILOUT"}}var et=e.i(32319),er=e.i(56704);class en extends Error{constructor(e,t){super(`During prerendering, ${t} rejects when the prerender is complete. Typically these errors are handled by React but if you move ${t} to a different context by using \`setTimeout\`, \`after\`, or similar functions you may observe this error and you should handle it in that context. This occurred at route "${e}".`),this.route=e,this.expression=t,this.digest="HANGING_PROMISE_REJECTION"}}let ea=new WeakMap;function eo(e,t,r){if(e.aborted)return Promise.reject(new en(t,r));{let n=new Promise((n,a)=>{let o=a.bind(null,new en(t,r)),i=ea.get(e);if(i)i.push(o);else{let t=[o];ea.set(e,t),e.addEventListener("abort",()=>{for(let e=0;e<t.length;e++)t[e]()},{once:!0})}});return n.catch(ei),n}}function ei(){}class es extends Error{constructor(e,t){super(`Invariant: ${e.endsWith(".")?e:e+"."} This is a bug in Next.js.`,t),this.name="InvariantError"}}let el="function"==typeof Q.default.unstable_postpone;function eu(e,t,r){if(t)switch(t.type){case"cache":case"unstable-cache":case"private-cache":return}if(!e.forceDynamic&&!e.forceStatic){if(e.dynamicShouldError)throw Object.defineProperty(new ee(`Route ${e.route} with \`dynamic = "error"\` couldn't be rendered statically because it used \`${r}\`. See more info here: https://nextjs.org/docs/app/building-your-application/rendering/static-and-dynamic#dynamic-rendering`),"__NEXT_ERROR_CODE",{value:"E553",enumerable:!1,configurable:!0});if(t)switch(t.type){case"prerender-ppr":var n,a,o;return n=e.route,a=r,o=t.dynamicTracking,void(function(){if(!el)throw Object.defineProperty(Error("Invariant: React.unstable_postpone is not defined. This suggests the wrong version of React was loaded. This is a bug in Next.js"),"__NEXT_ERROR_CODE",{value:"E224",enumerable:!1,configurable:!0})}(),o&&o.dynamicAccesses.push({stack:o.isDebugDynamicAccesses?Error().stack:void 0,expression:a}),Q.default.unstable_postpone(ec(n,a)));case"prerender-legacy":t.revalidate=0;let i=Object.defineProperty(new Z(`Route ${e.route} couldn't be rendered statically because it used ${r}. See more info here: https://nextjs.org/docs/messages/dynamic-server-error`),"__NEXT_ERROR_CODE",{value:"E550",enumerable:!1,configurable:!0});throw e.dynamicUsageDescription=r,e.dynamicUsageStack=i.stack,i}}}function ec(e,t){return`Route ${e} needs to bail out of prerendering at this point because it used ${t}. React throws this special object to indicate where. It should not be caught by your own try/catch. Learn more: https://nextjs.org/docs/messages/ppr-caught-error`}if(!1===((v=ec("%%%","^^^")).includes("needs to bail out of prerendering at this point because it used")&&v.includes("Learn more: https://nextjs.org/docs/messages/ppr-caught-error")))throw Object.defineProperty(Error("Invariant: isDynamicPostpone misidentified a postpone reason. This is a bug in Next.js"),"__NEXT_ERROR_CODE",{value:"E296",enumerable:!1,configurable:!0});RegExp(`\\n\\s+at Suspense \\(<anonymous>\\)(?:(?!\\n\\s+at (?:body|div|main|section|article|aside|header|footer|nav|form|p|span|h1|h2|h3|h4|h5|h6) \\(<anonymous>\\))[\\s\\S])*?\\n\\s+at __next_root_layout_boundary__ \\([^\\n]*\\)`),RegExp(`\\n\\s+at __next_metadata_boundary__[\\n\\s]`),RegExp(`\\n\\s+at __next_viewport_boundary__[\\n\\s]`),RegExp(`\\n\\s+at __next_outlet_boundary__[\\n\\s]`);let ed=()=>{};function ep(e){if(!e.body)return[e,e];let[t,n]=e.body.tee(),a=new Response(t,{status:e.status,statusText:e.statusText,headers:e.headers});Object.defineProperty(a,"url",{value:e.url,configurable:!0,enumerable:!0,writable:!1}),r&&a.body&&r.register(a,new WeakRef(a.body));let o=new Response(n,{status:e.status,statusText:e.statusText,headers:e.headers});return Object.defineProperty(o,"url",{value:e.url,configurable:!0,enumerable:!0,writable:!1}),[a,o]}globalThis.FinalizationRegistry&&(r=new FinalizationRegistry(e=>{let t=e.deref();t&&!t.locked&&t.cancel("Response object has been garbage collected").then(ed)}));let ef=new Set(["traceparent","tracestate"]);class eh{constructor(){let e,t;this.promise=new Promise((r,n)=>{e=r,t=n}),this.resolve=e,this.reject=t}}var eg=((y={}).APP_PAGE="APP_PAGE",y.APP_ROUTE="APP_ROUTE",y.PAGES="PAGES",y.FETCH="FETCH",y.REDIRECT="REDIRECT",y.IMAGE="IMAGE",y),ev=((m={}).APP_PAGE="APP_PAGE",m.APP_ROUTE="APP_ROUTE",m.PAGES="PAGES",m.FETCH="FETCH",m.IMAGE="IMAGE",m);function ey(){}e.s(["CachedRouteKind",()=>eg,"IncrementalCacheKind",()=>ev],91349),new Uint8Array([60,104,116,109,108]),new Uint8Array([60,98,111,100,121]),new Uint8Array([60,47,104,101,97,100,62]),new Uint8Array([60,47,98,111,100,121,62]),new Uint8Array([60,47,104,116,109,108,62]),new Uint8Array([60,47,98,111,100,121,62,60,47,104,116,109,108,62]),new Uint8Array([60,109,101,116,97,32,110,97,109,101,61,34,194,171,110,120,116,45,105,99,111,110,194,187,34]);let em=new TextEncoder;function e_(e){return new ReadableStream({start(t){t.enqueue(em.encode(e)),t.close()}})}function eb(e){return new ReadableStream({start(t){t.enqueue(e),t.close()}})}async function eS(e,t){let r=new TextDecoder("utf-8",{fatal:!0}),n="";for await(let a of e){if(null==t?void 0:t.aborted)return n;n+=r.decode(a,{stream:!0})}return n+r.decode()}let eE=Symbol.for("NextInternalRequestMeta");function eR(e,t){let r=e[eE]||{};return"string"==typeof t?r[t]:r}function eO(e,t,r){let n=eR(e);return n[t]=r,e[eE]=n,n}function ew(e){let t=new Headers;for(let[r,n]of Object.entries(e))for(let e of Array.isArray(n)?n:[n])void 0!==e&&("number"==typeof e&&(e=e.toString()),t.append(r,e));return t}function eT(e){var t,r,n,a,o,i=[],s=0;function l(){for(;s<e.length&&/\s/.test(e.charAt(s));)s+=1;return s<e.length}for(;s<e.length;){for(t=s,o=!1;l();)if(","===(r=e.charAt(s))){for(n=s,s+=1,l(),a=s;s<e.length&&"="!==(r=e.charAt(s))&&";"!==r&&","!==r;)s+=1;s<e.length&&"="===e.charAt(s)?(o=!0,s=a,i.push(e.substring(t,n)),t=s):s=n+1}else s+=1;(!o||s>=e.length)&&i.push(e.substring(t,e.length))}return i}function ex(e){let t={},r=[];if(e)for(let[n,a]of e.entries())"set-cookie"===n.toLowerCase()?(r.push(...eT(a)),t[n]=1===r.length?r[0]:r):t[n]=a;return t}function eP(e){try{return String(new URL(String(e)))}catch(t){throw Object.defineProperty(Error(`URL is malformed "${String(e)}". Please use only absolute URLs - https://nextjs.org/docs/messages/middleware-relative-urls`,{cause:t}),"__NEXT_ERROR_CODE",{value:"E61",enumerable:!1,configurable:!0})}}function eN(e){return e.replace(/\/$/,"")||"/"}function eC(e){let t=e.indexOf("#"),r=e.indexOf("?"),n=r>-1&&(t<0||r<t);return n||t>-1?{pathname:e.substring(0,n?r:t),query:n?e.substring(r,t>-1?t:void 0):"",hash:t>-1?e.slice(t):""}:{pathname:e,query:"",hash:""}}function eA(e,t){if(!e.startsWith("/")||!t)return e;let{pathname:r,query:n,hash:a}=eC(e);return`${t}${r}${n}${a}`}function eI(e,t){if(!e.startsWith("/")||!t)return e;let{pathname:r,query:n,hash:a}=eC(e);return`${r}${t}${n}${a}`}function eM(e,t){if("string"!=typeof e)return!1;let{pathname:r}=eC(e);return r===t||r.startsWith(t+"/")}e.s(["NEXT_REQUEST_META",0,eE,"addRequestMeta",()=>eO,"getRequestMeta",()=>eR],36096),e.s(["fromNodeOutgoingHttpHeaders",()=>ew,"splitCookiesString",()=>eT,"toNodeOutgoingHttpHeaders",()=>ex,"validateURL",()=>eP],45577);let eL=new WeakMap;function eD(e,t){let r;if(!t)return{pathname:e};let n=eL.get(t);n||(n=t.map(e=>e.toLowerCase()),eL.set(t,n));let a=e.split("/",2);if(!a[1])return{pathname:e};let o=a[1].toLowerCase(),i=n.indexOf(o);return i<0?{pathname:e}:(r=t[i],{pathname:e=e.slice(r.length+1)||"/",detectedLocale:r})}let ej=/(?!^https?:\/\/)(127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}|\[::1\]|localhost)/;function eB(e,t){return new URL(String(e).replace(ej,"localhost"),t&&String(t).replace(ej,"localhost"))}let eV=Symbol("NextURLInternal");class ek{constructor(e,t,r){let n,a;"object"==typeof t&&"pathname"in t||"string"==typeof t?(n=t,a=r||{}):a=r||t||{},this[eV]={url:eB(e,n??a.base),options:a,basePath:""},this.analyze()}analyze(){var e,t,r,n,a;let o=function(e,t){let{basePath:r,i18n:n,trailingSlash:a}=t.nextConfig??{},o={pathname:e,trailingSlash:"/"!==e?e.endsWith("/"):a};r&&eM(o.pathname,r)&&(o.pathname=function(e,t){if(!eM(e,t))return e;let r=e.slice(t.length);return r.startsWith("/")?r:`/${r}`}(o.pathname,r),o.basePath=r);let i=o.pathname;if(o.pathname.startsWith("/_next/data/")&&o.pathname.endsWith(".json")){let e=o.pathname.replace(/^\/_next\/data\//,"").replace(/\.json$/,"").split("/");o.buildId=e[0],i="index"!==e[1]?`/${e.slice(1).join("/")}`:"/",!0===t.parseData&&(o.pathname=i)}if(n){let e=t.i18nProvider?t.i18nProvider.analyze(o.pathname):eD(o.pathname,n.locales);o.locale=e.detectedLocale,o.pathname=e.pathname??o.pathname,!e.detectedLocale&&o.buildId&&(e=t.i18nProvider?t.i18nProvider.analyze(i):eD(i,n.locales)).detectedLocale&&(o.locale=e.detectedLocale)}return o}(this[eV].url.pathname,{nextConfig:this[eV].options.nextConfig,parseData:!0,i18nProvider:this[eV].options.i18nProvider}),i=function(e,t){let r;if(t?.host&&!Array.isArray(t.host))r=t.host.toString().split(":",1)[0];else{if(!e.hostname)return;r=e.hostname}return r.toLowerCase()}(this[eV].url,this[eV].options.headers);this[eV].domainLocale=this[eV].options.i18nProvider?this[eV].options.i18nProvider.detectDomainLocale(i):function(e,t,r){if(e){for(let n of(r&&(r=r.toLowerCase()),e))if(t===n.domain?.split(":",1)[0].toLowerCase()||r===n.defaultLocale.toLowerCase()||n.locales?.some(e=>e.toLowerCase()===r))return n}}(null==(t=this[eV].options.nextConfig)||null==(e=t.i18n)?void 0:e.domains,i);let s=(null==(r=this[eV].domainLocale)?void 0:r.defaultLocale)||(null==(a=this[eV].options.nextConfig)||null==(n=a.i18n)?void 0:n.defaultLocale);this[eV].url.pathname=o.pathname,this[eV].defaultLocale=s,this[eV].basePath=o.basePath??"",this[eV].buildId=o.buildId,this[eV].locale=o.locale??s,this[eV].trailingSlash=o.trailingSlash}formatPathname(){var e;let t;return t=function(e,t,r,n){if(!t||t===r)return e;let a=e.toLowerCase();return!n&&(eM(a,"/api")||eM(a,`/${t.toLowerCase()}`))?e:eA(e,`/${t}`)}((e={basePath:this[eV].basePath,buildId:this[eV].buildId,defaultLocale:this[eV].options.forceLocale?void 0:this[eV].defaultLocale,locale:this[eV].locale,pathname:this[eV].url.pathname,trailingSlash:this[eV].trailingSlash}).pathname,e.locale,e.buildId?void 0:e.defaultLocale,e.ignorePrefix),(e.buildId||!e.trailingSlash)&&(t=eN(t)),e.buildId&&(t=eI(eA(t,`/_next/data/${e.buildId}`),"/"===e.pathname?"index.json":".json")),t=eA(t,e.basePath),!e.buildId&&e.trailingSlash?t.endsWith("/")?t:eI(t,"/"):eN(t)}formatSearch(){return this[eV].url.search}get buildId(){return this[eV].buildId}set buildId(e){this[eV].buildId=e}get locale(){return this[eV].locale??""}set locale(e){var t,r;if(!this[eV].locale||!(null==(r=this[eV].options.nextConfig)||null==(t=r.i18n)?void 0:t.locales.includes(e)))throw Object.defineProperty(TypeError(`The NextURL configuration includes no locale "${e}"`),"__NEXT_ERROR_CODE",{value:"E597",enumerable:!1,configurable:!0});this[eV].locale=e}get defaultLocale(){return this[eV].defaultLocale}get domainLocale(){return this[eV].domainLocale}get searchParams(){return this[eV].url.searchParams}get host(){return this[eV].url.host}set host(e){this[eV].url.host=e}get hostname(){return this[eV].url.hostname}set hostname(e){this[eV].url.hostname=e}get port(){return this[eV].url.port}set port(e){this[eV].url.port=e}get protocol(){return this[eV].url.protocol}set protocol(e){this[eV].url.protocol=e}get href(){let e=this.formatPathname(),t=this.formatSearch();return`${this.protocol}//${this.host}${e}${t}${this.hash}`}set href(e){this[eV].url=eB(e),this.analyze()}get origin(){return this[eV].url.origin}get pathname(){return this[eV].url.pathname}set pathname(e){this[eV].url.pathname=e}get hash(){return this[eV].url.hash}set hash(e){this[eV].url.hash=e}get search(){return this[eV].url.search}set search(e){this[eV].url.search=e}get password(){return this[eV].url.password}set password(e){this[eV].url.password=e}get username(){return this[eV].url.username}set username(e){this[eV].url.username=e}get basePath(){return this[eV].basePath}set basePath(e){this[eV].basePath=e.startsWith("/")?e:`/${e}`}toString(){return this.href}toJSON(){return this.href}[Symbol.for("edge-runtime.inspect.custom")](){return{href:this.href,origin:this.origin,protocol:this.protocol,username:this.username,password:this.password,host:this.host,hostname:this.hostname,port:this.port,pathname:this.pathname,search:this.search,searchParams:this.searchParams,hash:this.hash}}clone(){return new ek(String(this),this[eV].options)}}class eU extends Error{constructor(){super(`The request.page has been deprecated in favour of \`URLPattern\`.
2
- Read more: https://nextjs.org/docs/messages/middleware-request-page
3
- `)}}class e$ extends Error{constructor(){super(`The request.ua has been removed in favour of \`userAgent\` function.
4
- Read more: https://nextjs.org/docs/messages/middleware-parse-user-agent
5
- `)}}var eG=e.i(45408);let eH=Symbol("internal request");class eF extends Request{constructor(e,t={}){const r="string"!=typeof e&&"url"in e?e.url:String(e);eP(r),t.body&&"half"!==t.duplex&&(t.duplex="half"),e instanceof Request?super(e,t):super(r,t);const n=new ek(r,{headers:ex(this.headers),nextConfig:t.nextConfig});this[eH]={cookies:new eG.RequestCookies(this.headers),nextUrl:n,url:n.toString()}}[Symbol.for("edge-runtime.inspect.custom")](){return{cookies:this.cookies,nextUrl:this.nextUrl,url:this.url,bodyUsed:this.bodyUsed,cache:this.cache,credentials:this.credentials,destination:this.destination,headers:Object.fromEntries(this.headers),integrity:this.integrity,keepalive:this.keepalive,method:this.method,mode:this.mode,redirect:this.redirect,referrer:this.referrer,referrerPolicy:this.referrerPolicy,signal:this.signal}}get cookies(){return this[eH].cookies}get nextUrl(){return this[eH].nextUrl}get page(){throw new eU}get ua(){throw new e$}get url(){return this[eH].url}}let eq="ResponseAborted";class eX extends Error{constructor(...e){super(...e),this.name=eq}}function eW(e){let t=new AbortController;return e.once("close",()=>{e.writableFinished||t.abort(new eX)}),t}function eK(e){let{errored:t,destroyed:r}=e;if(t||r)return AbortSignal.abort(t??new eX);let{signal:n}=eW(e);return n}class ez{static fromBaseNextRequest(e,t){return ez.fromNodeNextRequest(e,t)}static fromNodeNextRequest(e,t){let r,n=null;if("GET"!==e.method&&"HEAD"!==e.method&&e.body&&(n=e.body),e.url.startsWith("http"))r=new URL(e.url);else{let t=eR(e,"initURL");r=t&&t.startsWith("http")?new URL(e.url,t):new URL(e.url,"http://n")}return new eF(r,{method:e.method,headers:ew(e.headers),duplex:"half",signal:t,...t.aborted?{}:{body:n}})}static fromWebNextRequest(e){let t=null;return"GET"!==e.method&&"HEAD"!==e.method&&(t=e.body),new eF(e.url,{method:e.method,headers:ew(e.headers),duplex:"half",signal:e.request.signal,...e.request.signal.aborted?{}:{body:t}})}}e.s(["NextRequestAdapter",()=>ez,"ResponseAbortedName",0,eq,"createAbortController",()=>eW,"signalFromNodeResponse",()=>eK],86157);let eY=0,eJ=0,eQ=0;function eZ(e){return(null==e?void 0:e.name)==="AbortError"||(null==e?void 0:e.name)===eq}async function e0(e,t,r){try{let{errored:n,destroyed:a}=t;if(n||a)return;let o=eW(t),i=function(e,t){let r=!1,n=new eh;function a(){n.resolve()}e.on("drain",a),e.once("close",()=>{e.off("drain",a),n.resolve()});let o=new eh;return e.once("finish",()=>{o.resolve()}),new WritableStream({write:async t=>{if(!r){if(r=!0,"performance"in globalThis&&process.env.NEXT_OTEL_PERFORMANCE_PREFIX){let e=function(e={}){let t=0===eY?void 0:{clientComponentLoadStart:eY,clientComponentLoadTimes:eJ,clientComponentLoadCount:eQ};return e.reset&&(eY=0,eJ=0,eQ=0),t}();e&&performance.measure(`${process.env.NEXT_OTEL_PERFORMANCE_PREFIX}:next-client-component-loading`,{start:e.clientComponentLoadStart,end:e.clientComponentLoadStart+e.clientComponentLoadTimes})}e.flushHeaders(),Y().trace(T.startResponse,{spanName:"start response"},()=>void 0)}try{let r=e.write(t);"flush"in e&&"function"==typeof e.flush&&e.flush(),r||(await n.promise,n=new eh)}catch(t){throw e.end(),Object.defineProperty(Error("failed to write chunk to response",{cause:t}),"__NEXT_ERROR_CODE",{value:"E321",enumerable:!1,configurable:!0})}},abort:t=>{e.writableFinished||e.destroy(t)},close:async()=>{if(t&&await t,!e.writableFinished)return e.end(),o.promise}})}(t,r);await e.pipeTo(i,{signal:o.signal})}catch(e){if(eZ(e))return;throw Object.defineProperty(Error("failed to pipe response",{cause:e}),"__NEXT_ERROR_CODE",{value:"E180",enumerable:!1,configurable:!0})}}class e1{static #e=this.EMPTY=new e1(null,{metadata:{},contentType:null});static fromStatic(e,t){return new e1(e,{metadata:{},contentType:t})}constructor(e,{contentType:t,waitUntil:r,metadata:n}){this.response=e,this.contentType=t,this.metadata=n,this.waitUntil=r}assignMetadata(e){Object.assign(this.metadata,e)}get isNull(){return null===this.response}get isDynamic(){return"string"!=typeof this.response}toUnchunkedString(e=!1){if(null===this.response)return"";if("string"!=typeof this.response){if(!e)throw Object.defineProperty(new es("dynamic responses cannot be unchunked. This is a bug in Next.js"),"__NEXT_ERROR_CODE",{value:"E732",enumerable:!1,configurable:!0});return eS(this.readable)}return this.response}get readable(){return null===this.response?new ReadableStream({start(e){e.close()}}):"string"==typeof this.response?e_(this.response):Buffer.isBuffer(this.response)?eb(this.response):Array.isArray(this.response)?function(...e){if(0===e.length)return new ReadableStream({start(e){e.close()}});if(1===e.length)return e[0];let{readable:t,writable:r}=new TransformStream,n=e[0].pipeTo(r,{preventClose:!0}),a=1;for(;a<e.length-1;a++){let t=e[a];n=n.then(()=>t.pipeTo(r,{preventClose:!0}))}let o=e[a];return(n=n.then(()=>o.pipeTo(r))).catch(ey),t}(...this.response):this.response}coerce(){return null===this.response?[]:"string"==typeof this.response?[e_(this.response)]:Array.isArray(this.response)?this.response:Buffer.isBuffer(this.response)?[eb(this.response)]:[this.response]}unshift(e){this.response=this.coerce(),this.response.unshift(e)}push(e){this.response=this.coerce(),this.response.push(e)}async pipeTo(e){try{await this.readable.pipeTo(e,{preventClose:!0}),this.waitUntil&&await this.waitUntil,await e.close()}catch(t){if(eZ(t))return void await e.abort(t);throw t}}async pipeToNodeResponse(e){await e0(this.readable,e,this.waitUntil)}}e.s([],24496);let e2=Symbol.for("next-patch");function e4(e,t){e.shouldTrackFetchMetrics&&(e.fetchMetrics??=[],e.fetchMetrics.push({...t,end:performance.timeOrigin+performance.now(),idx:e.nextFetchId||0}))}async function e9(e,t,r,n,a,o){let i=await e.arrayBuffer(),s={headers:Object.fromEntries(e.headers.entries()),body:Buffer.from(i).toString("base64"),status:e.status,url:e.url};return r&&await n.set(t,{kind:eg.FETCH,data:s,revalidate:a},r),await o(),new Response(i,{headers:e.headers,status:e.status,statusText:e.statusText})}async function e6(e,t,r,n,a,o,i,s,l){let[u,c]=ep(t),d=u.arrayBuffer().then(async e=>{let t=Buffer.from(e),s={headers:Object.fromEntries(u.headers.entries()),body:t.toString("base64"),status:u.status,url:u.url};null==o||o.set(r,s),n&&await a.set(r,{kind:eg.FETCH,data:s,revalidate:i},n)}).catch(e=>console.warn("Failed to set fetch cache",s,e)).finally(l),p=`cache-set-${r}`;return e.pendingRevalidates??={},p in e.pendingRevalidates&&await e.pendingRevalidates[p],e.pendingRevalidates[p]=d.finally(()=>{var t;(null==(t=e.pendingRevalidates)?void 0:t[p])&&delete e.pendingRevalidates[p]}),c}function e3(e){var t;let r;if(!0===globalThis[e2])return;let n=(t=globalThis.fetch,r=Q.cache(e=>[]),function(e,n){let a,o;if(n&&n.signal)return t(e,n);if("string"!=typeof e||n){let r,i="string"==typeof e||e instanceof URL?new Request(e,n):e;if("GET"!==i.method&&"HEAD"!==i.method||i.keepalive)return t(e,n);r=Array.from(i.headers.entries()).filter(([e])=>!ef.has(e.toLowerCase())),o=JSON.stringify([i.method,r,i.mode,i.redirect,i.credentials,i.referrer,i.referrerPolicy,i.integrity]),a=i.url}else o='["GET",[],null,"follow",null,null,null,null]',a=e;let i=r(a);for(let e=0,t=i.length;e<t;e+=1){let[t,r]=i[e];if(t===o)return r.then(()=>{let t=i[e][2];if(!t)throw Object.defineProperty(new es("No cached response"),"__NEXT_ERROR_CODE",{value:"E579",enumerable:!1,configurable:!0});let[r,n]=ep(t);return i[e][2]=n,r})}let s=t(e,n),l=[o,s,null];return i.push(l),s.then(e=>{let[t,r]=ep(e);return l[2]=r,t})});globalThis.fetch=function(e,{workAsyncStorage:t,workUnitAsyncStorage:r}){let n=async function(n,a){var o,i;let s;try{(s=new URL(n instanceof Request?n.url:n)).username="",s.password=""}catch{s=void 0}let l=(null==s?void 0:s.href)??"",u=(null==a||null==(o=a.method)?void 0:o.toUpperCase())||"GET",c=(null==a||null==(i=a.next)?void 0:i.internal)===!0,d="1"===process.env.NEXT_OTEL_FETCH_DISABLED,p=c?void 0:performance.timeOrigin+performance.now(),f=t.getStore(),h=r.getStore(),g=h?(0,et.getCacheSignal)(h):null;g&&g.beginRead();let v=Y().trace(c?T.internalFetch:N.fetch,{hideSpan:d,kind:G.CLIENT,spanName:["fetch",u,l].filter(Boolean).join(" "),attributes:{"http.url":l,"http.method":u,"net.peer.name":null==s?void 0:s.hostname,"net.peer.port":(null==s?void 0:s.port)||void 0}},async()=>{var t;let r,o,i,s,u,d;if(c||!f||f.isDraftMode)return e(n,a);let v=n&&"object"==typeof n&&"string"==typeof n.method,y=e=>(null==a?void 0:a[e])||(v?n[e]:null),m=e=>{var t,r,o;return void 0!==(null==a||null==(t=a.next)?void 0:t[e])?null==a||null==(r=a.next)?void 0:r[e]:v?null==(o=n.next)?void 0:o[e]:void 0},_=m("revalidate"),b=_,S=function(e,t){let r=[],n=[];for(let a=0;a<e.length;a++){let o=e[a];if("string"!=typeof o?n.push({tag:o,reason:"invalid type, must be a string"}):o.length>256?n.push({tag:o,reason:"exceeded max length of 256"}):r.push(o),r.length>128){console.warn(`Warning: exceeded max tag count for ${t}, dropped tags:`,e.slice(a).join(", "));break}}if(n.length>0)for(let{tag:e,reason:r}of(console.warn(`Warning: invalid tags passed to ${t}: `),n))console.log(`tag: "${e}" ${r}`);return r}(m("tags")||[],`fetch ${n.toString()}`);if(h)switch(h.type){case"prerender":case"prerender-runtime":case"prerender-client":case"prerender-ppr":case"prerender-legacy":case"cache":case"private-cache":r=h}if(r&&Array.isArray(S)){let e=r.tags??(r.tags=[]);for(let t of S)e.includes(t)||e.push(t)}let E=null==h?void 0:h.implicitTags,R=f.fetchCache;h&&"unstable-cache"===h.type&&(R="force-no-store");let O=!!f.isUnstableNoStore,w=y("cache"),T="";"string"==typeof w&&void 0!==b&&("force-cache"===w&&0===b||"no-store"===w&&(b>0||!1===b))&&(o=`Specified "cache: ${w}" and "revalidate: ${b}", only one should be specified.`,w=void 0,b=void 0);let x="no-cache"===w||"no-store"===w||"force-no-store"===R||"only-no-store"===R,P=!R&&!w&&!b&&f.forceDynamic;"force-cache"===w&&void 0===b?b=!1:(x||P)&&(b=0),("no-cache"===w||"no-store"===w)&&(T=`cache: ${w}`),d=function(e,t){try{let r;if(!1===e)r=0xfffffffe;else if("number"==typeof e&&!isNaN(e)&&e>-1)r=e;else if(void 0!==e)throw Object.defineProperty(Error(`Invalid revalidate value "${e}" on "${t}", must be a non-negative number or false`),"__NEXT_ERROR_CODE",{value:"E179",enumerable:!1,configurable:!0});return r}catch(e){if(e instanceof Error&&e.message.includes("Invalid revalidate"))throw e;return}}(b,f.route);let N=y("headers"),C="function"==typeof(null==N?void 0:N.get)?N:new Headers(N||{}),A=C.get("authorization")||C.get("cookie"),I=!["get","head"].includes((null==(t=y("method"))?void 0:t.toLowerCase())||"get"),M=void 0==R&&(void 0==w||"default"===w)&&void 0==b,L=!!((A||I)&&(null==r?void 0:r.revalidate)===0),D=!1;if(!L&&M&&(f.isBuildTimePrerendering?D=!0:L=!0),M&&void 0!==h)switch(h.type){case"prerender":case"prerender-runtime":case"prerender-client":return g&&(g.endRead(),g=null),eo(h.renderSignal,f.route,"fetch()")}switch(R){case"force-no-store":T="fetchCache = force-no-store";break;case"only-no-store":if("force-cache"===w||void 0!==d&&d>0)throw Object.defineProperty(Error(`cache: 'force-cache' used on fetch for ${l} with 'export const fetchCache = 'only-no-store'`),"__NEXT_ERROR_CODE",{value:"E448",enumerable:!1,configurable:!0});T="fetchCache = only-no-store";break;case"only-cache":if("no-store"===w)throw Object.defineProperty(Error(`cache: 'no-store' used on fetch for ${l} with 'export const fetchCache = 'only-cache'`),"__NEXT_ERROR_CODE",{value:"E521",enumerable:!1,configurable:!0});break;case"force-cache":(void 0===b||0===b)&&(T="fetchCache = force-cache",d=0xfffffffe)}if(void 0===d?"default-cache"!==R||O?"default-no-store"===R?(d=0,T="fetchCache = default-no-store"):O?(d=0,T="noStore call"):L?(d=0,T="auto no cache"):(T="auto cache",d=r?r.revalidate:0xfffffffe):(d=0xfffffffe,T="fetchCache = default-cache"):T||(T=`revalidate: ${d}`),!(f.forceStatic&&0===d)&&!L&&r&&d<r.revalidate){if(0===d){if(h)switch(h.type){case"prerender":case"prerender-client":case"prerender-runtime":return g&&(g.endRead(),g=null),eo(h.renderSignal,f.route,"fetch()")}eu(f,h,`revalidate: 0 fetch ${n} ${f.route}`)}r&&_===d&&(r.revalidate=d)}let j="number"==typeof d&&d>0,{incrementalCache:B}=f,V=!1;if(h)switch(h.type){case"request":case"cache":case"private-cache":V=h.isHmrRefresh??!1,s=h.serverComponentsHmrCache}if(B&&(j||s))try{i=await B.generateCacheKey(l,v?n:a)}catch(e){console.error("Failed to generate cache key for",n)}let k=f.nextFetchId??1;f.nextFetchId=k+1;let U=()=>{},$=async(t,r)=>{let u=["cache","credentials","headers","integrity","keepalive","method","mode","redirect","referrer","referrerPolicy","window","duplex",...t?[]:["signal"]];if(v){let e=n,t={body:e._ogBody||e.body};for(let r of u)t[r]=e[r];n=new Request(e.url,t)}else if(a){let{_ogBody:e,body:r,signal:n,...o}=a;a={...o,body:e||r,signal:t?void 0:n}}let c={...a,next:{...null==a?void 0:a.next,fetchType:"origin",fetchIdx:k}};return e(n,c).then(async e=>{if(!t&&p&&e4(f,{start:p,url:l,cacheReason:r||T,cacheStatus:0===d||r?"skip":"miss",cacheWarning:o,status:e.status,method:c.method||"GET"}),200===e.status&&B&&i&&(j||s)){let t=d>=0xfffffffe?31536e3:d,r=j?{fetchCache:!0,fetchUrl:l,fetchIdx:k,tags:S,isImplicitBuildTimeCache:D}:void 0;switch(null==h?void 0:h.type){case"prerender":case"prerender-client":case"prerender-runtime":return e9(e,i,r,B,t,U);case"request":case"prerender-ppr":case"prerender-legacy":case"cache":case"private-cache":case"unstable-cache":case void 0:return e6(f,e,i,r,B,s,t,n,U)}}return await U(),e}).catch(e=>{throw U(),e})},G=!1,H=!1;if(i&&B){let e;if(V&&s&&(e=s.get(i),H=!0),j&&!e){U=await B.lock(i);let t=f.isOnDemandRevalidate?null:await B.get(i,{kind:ev.FETCH,revalidate:d,fetchUrl:l,fetchIdx:k,tags:S,softTags:null==E?void 0:E.tags});if(M&&h)switch(h.type){case"prerender":case"prerender-client":case"prerender-runtime":await (e7||(e7=new Promise(e=>{setTimeout(()=>{e7=null,e()},0)})),e7)}if(t?await U():u="cache-control: no-cache (hard refresh)",(null==t?void 0:t.value)&&t.value.kind===eg.FETCH)if(f.isStaticGeneration&&t.isStale)G=!0;else{if(t.isStale&&(f.pendingRevalidates??={},!f.pendingRevalidates[i])){let e=$(!0).then(async e=>({body:await e.arrayBuffer(),headers:e.headers,status:e.status,statusText:e.statusText})).finally(()=>{f.pendingRevalidates??={},delete f.pendingRevalidates[i||""]});e.catch(console.error),f.pendingRevalidates[i]=e}e=t.value.data}}if(e){p&&e4(f,{start:p,url:l,cacheReason:T,cacheStatus:H?"hmr":"hit",cacheWarning:o,status:e.status||200,method:(null==a?void 0:a.method)||"GET"});let t=new Response(Buffer.from(e.body,"base64"),{headers:e.headers,status:e.status});return Object.defineProperty(t,"url",{value:e.url}),t}}if(f.isStaticGeneration&&a&&"object"==typeof a){let{cache:e}=a;if("no-store"===e){if(h)switch(h.type){case"prerender":case"prerender-client":case"prerender-runtime":return g&&(g.endRead(),g=null),eo(h.renderSignal,f.route,"fetch()")}eu(f,h,`no-store fetch ${n} ${f.route}`)}let t="next"in a,{next:o={}}=a;if("number"==typeof o.revalidate&&r&&o.revalidate<r.revalidate){if(0===o.revalidate){if(h)switch(h.type){case"prerender":case"prerender-client":case"prerender-runtime":return eo(h.renderSignal,f.route,"fetch()")}eu(f,h,`revalidate: 0 fetch ${n} ${f.route}`)}f.forceStatic&&0===o.revalidate||(r.revalidate=o.revalidate)}t&&delete a.next}if(!i||!G)return $(!1,u);{let e=i;f.pendingRevalidates??={};let t=f.pendingRevalidates[e];if(t){let e=await t;return new Response(e.body,{headers:e.headers,status:e.status,statusText:e.statusText})}let r=$(!0,u).then(ep);return(t=r.then(async e=>{let t=e[0];return{body:await t.arrayBuffer(),headers:t.headers,status:t.status,statusText:t.statusText}}).finally(()=>{var t;(null==(t=f.pendingRevalidates)?void 0:t[e])&&delete f.pendingRevalidates[e]})).catch(()=>{}),f.pendingRevalidates[e]=t,r.then(e=>e[1])}});if(g)try{return await v}finally{g&&g.endRead()}return v};return n.__nextPatched=!0,n.__nextGetStaticStore=()=>t,n._nextOriginalFetch=e,globalThis[e2]=!0,Object.defineProperty(n,"name",{value:"fetch",writable:!1}),n}(n,e)}let e7=null;function e8(e){var t;return(t=e.split("/").reduce((e,t,r,n)=>t?"("===t[0]&&t.endsWith(")")||"@"===t[0]||("page"===t||"route"===t)&&r===n.length-1?e:`${e}/${t}`:e,"")).startsWith("/")?t:`/${t}`}e.s(["patchFetch",()=>e3],66154),e.s(["normalizeAppPath",()=>e8],84521);let e5=Symbol.for("next.server.action-manifests");function te({page:e,clientReferenceManifest:t,serverActionsManifest:r,serverModuleMap:n}){var a;let o=null==(a=globalThis[e5])?void 0:a.clientReferenceManifestsPerPage;globalThis[e5]={clientReferenceManifestsPerPage:{...o,[e8(e)]:t},serverActionsManifest:r,serverModuleMap:n}}function tt({serverActionsManifest:e}){return new Proxy({},{get:(t,r)=>{var n,a,o;let i,s=null==(a=e.node)||null==(n=a[r])?void 0:n.workers;if(!s)return;let l=er.workAsyncStorage.getStore();if(!(i=l?s[eM(o=l.page,"app")?o:"app"+o]:Object.values(s).at(0)))return;let{moduleId:u,async:c}=i;return{id:u,name:r,chunks:[],async:c}}})}e.s(["setReferenceManifestsSingleton",()=>te],23249),e.s(["createServerModuleMap",()=>tt],33185);class tr{static get(e,t,r){let n=Reflect.get(e,t,r);return"function"==typeof n?n.bind(e):n}static set(e,t,r,n){return Reflect.set(e,t,r,n)}static has(e,t){return Reflect.has(e,t)}static deleteProperty(e,t){return Reflect.deleteProperty(e,t)}}class tn extends Error{constructor(){super("Headers cannot be modified. Read more: https://nextjs.org/docs/app/api-reference/functions/headers")}static callable(){throw new tn}}class ta extends Headers{constructor(e){super(),this.headers=new Proxy(e,{get(t,r,n){if("symbol"==typeof r)return tr.get(t,r,n);let a=r.toLowerCase(),o=Object.keys(e).find(e=>e.toLowerCase()===a);if(void 0!==o)return tr.get(t,o,n)},set(t,r,n,a){if("symbol"==typeof r)return tr.set(t,r,n,a);let o=r.toLowerCase(),i=Object.keys(e).find(e=>e.toLowerCase()===o);return tr.set(t,i??r,n,a)},has(t,r){if("symbol"==typeof r)return tr.has(t,r);let n=r.toLowerCase(),a=Object.keys(e).find(e=>e.toLowerCase()===n);return void 0!==a&&tr.has(t,a)},deleteProperty(t,r){if("symbol"==typeof r)return tr.deleteProperty(t,r);let n=r.toLowerCase(),a=Object.keys(e).find(e=>e.toLowerCase()===n);return void 0===a||tr.deleteProperty(t,a)}})}static seal(e){return new Proxy(e,{get(e,t,r){switch(t){case"append":case"delete":case"set":return tn.callable;default:return tr.get(e,t,r)}}})}merge(e){return Array.isArray(e)?e.join(", "):e}static from(e){return e instanceof Headers?e:new ta(e)}append(e,t){let r=this.headers[e];"string"==typeof r?this.headers[e]=[r,t]:Array.isArray(r)?r.push(t):this.headers[e]=t}delete(e){delete this.headers[e]}get(e){let t=this.headers[e];return void 0!==t?this.merge(t):null}has(e){return void 0!==this.headers[e]}set(e,t){this.headers[e]=t}forEach(e,t){for(let[r,n]of this.entries())e.call(t,n,r,this)}*entries(){for(let e of Object.keys(this.headers)){let t=e.toLowerCase(),r=this.get(t);yield[t,r]}}*keys(){for(let e of Object.keys(this.headers)){let t=e.toLowerCase();yield t}}*values(){for(let e of Object.keys(this.headers)){let t=this.get(e);yield t}}[Symbol.iterator](){return this.entries()}}Symbol("__next_preview_data");let to=Symbol("__prerender_bypass");var ti=((_={})[_.SeeOther=303]="SeeOther",_[_.TemporaryRedirect=307]="TemporaryRedirect",_[_.PermanentRedirect=308]="PermanentRedirect",_);class ts{constructor(e,t,r){this.method=e,this.url=t,this.body=r}get cookies(){var t;return this._cookies?this._cookies:this._cookies=(t=this.headers,function(){let{cookie:r}=t;if(!r)return{};let{parse:n}=e.r(90677);return n(Array.isArray(r)?r.join("; "):r)})()}}class tl{constructor(e){this.destination=e}redirect(e,t){return this.setHeader("Location",e),this.statusCode=t,t===ti.PermanentRedirect&&this.setHeader("Refresh",`0;url=${e}`),this}}class tu extends ts{static #e=S=eE;constructor(e){var t;super(e.method.toUpperCase(),e.url,e),this._req=e,this.headers=this._req.headers,this.fetchMetrics=null==(t=this._req)?void 0:t.fetchMetrics,this[S]=this._req[eE]||{},this.streaming=!1}get originalRequest(){return this._req[eE]=this[eE],this._req.url=this.url,this._req.cookies=this.cookies,this._req}set originalRequest(e){this._req=e}stream(){if(this.streaming)throw Object.defineProperty(Error("Invariant: NodeNextRequest.stream() can only be called once"),"__NEXT_ERROR_CODE",{value:"E467",enumerable:!1,configurable:!0});return this.streaming=!0,new ReadableStream({start:e=>{this._req.on("data",t=>{e.enqueue(new Uint8Array(t))}),this._req.on("end",()=>{e.close()}),this._req.on("error",t=>{e.error(t)})}})}}class tc extends tl{get originalResponse(){return to in this&&(this._res[to]=this[to]),this._res}constructor(e){super(e),this._res=e,this.textBody=void 0}get sent(){return this._res.finished||this._res.headersSent}get statusCode(){return this._res.statusCode}set statusCode(e){this._res.statusCode=e}get statusMessage(){return this._res.statusMessage}set statusMessage(e){this._res.statusMessage=e}setHeader(e,t){return this._res.setHeader(e,t),this}removeHeader(e){return this._res.removeHeader(e),this}getHeaderValues(e){let t=this._res.getHeader(e);if(void 0!==t)return(Array.isArray(t)?t:[t]).map(e=>e.toString())}hasHeader(e){return this._res.hasHeader(e)}getHeader(e){let t=this.getHeaderValues(e);return Array.isArray(t)?t.join(","):void 0}getHeaders(){return this._res.getHeaders()}appendHeader(e,t){let r=this.getHeaderValues(e)??[];return r.includes(t)||this._res.setHeader(e,[...r,t]),this}body(e){return this.textBody=e,this}send(){this._res.end(this.textBody)}onClose(e){this.originalResponse.on("close",e)}}function td(e){return e.isOnDemandRevalidate?"on-demand":e.isStaticGeneration?"stale":void 0}async function tp(e,t,r,n){{var a;t.statusCode=r.status,t.statusMessage=r.statusText;let o=["set-cookie","www-authenticate","proxy-authenticate","vary"];null==(a=r.headers)||a.forEach((e,r)=>{if("x-middleware-set-cookie"!==r.toLowerCase())if("set-cookie"===r.toLowerCase())for(let n of eT(e))t.appendHeader(r,n);else{let n=void 0!==t.getHeader(r);(o.includes(r.toLowerCase())||!n)&&t.appendHeader(r,e)}});let{originalResponse:i}=t;r.body&&"HEAD"!==e.method?await e0(r.body,i,n):i.end()}}function tf({revalidate:e,expire:t}){let r="number"==typeof e&&void 0!==t&&e<t?`, stale-while-revalidate=${t-e}`:"";return 0===e?"private, no-cache, no-store, max-age=0, must-revalidate":"number"==typeof e?`s-maxage=${e}${r}`:`s-maxage=31536000${r}`}e.s(["NodeNextRequest",()=>tu,"NodeNextResponse",()=>tc],67707),e.s(["getRevalidateReason",()=>td],48432),e.s(["sendResponse",()=>tp],77430),e.s(["getCacheControlHeader",()=>tf],92366)}];
6
-
7
- //# sourceMappingURL=%5Broot-of-the-server%5D__45cf400e._.js.map