dev3000 0.0.99 → 0.0.101

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 (250) hide show
  1. package/mcp-server/.next/BUILD_ID +1 -1
  2. package/mcp-server/.next/build-manifest.json +7 -7
  3. package/mcp-server/.next/fallback-build-manifest.json +2 -2
  4. package/mcp-server/.next/next-minimal-server.js.nft.json +1 -1
  5. package/mcp-server/.next/next-server.js.nft.json +1 -1
  6. package/mcp-server/.next/prerender-manifest.json +3 -3
  7. package/mcp-server/.next/server/app/_global-error/page/build-manifest.json +5 -5
  8. package/mcp-server/.next/server/app/_global-error/page.js +8 -8
  9. package/mcp-server/.next/server/app/_global-error/page.js.nft.json +1 -1
  10. package/mcp-server/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  11. package/mcp-server/.next/server/app/_global-error.html +2 -2
  12. package/mcp-server/.next/server/app/_global-error.rsc +7 -7
  13. package/mcp-server/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +2 -2
  14. package/mcp-server/.next/server/app/_global-error.segments/_full.segment.rsc +7 -7
  15. package/mcp-server/.next/server/app/_global-error.segments/_index.segment.rsc +3 -3
  16. package/mcp-server/.next/server/app/_global-error.segments/_tree.segment.rsc +3 -3
  17. package/mcp-server/.next/server/app/_not-found/page/build-manifest.json +5 -5
  18. package/mcp-server/.next/server/app/_not-found/page.js +10 -10
  19. package/mcp-server/.next/server/app/_not-found/page.js.nft.json +1 -1
  20. package/mcp-server/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  21. package/mcp-server/.next/server/app/_not-found.html +1 -1
  22. package/mcp-server/.next/server/app/_not-found.rsc +7 -7
  23. package/mcp-server/.next/server/app/_not-found.segments/_full.segment.rsc +7 -7
  24. package/mcp-server/.next/server/app/_not-found.segments/_index.segment.rsc +3 -3
  25. package/mcp-server/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  26. package/mcp-server/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  27. package/mcp-server/.next/server/app/_not-found.segments/_tree.segment.rsc +3 -3
  28. package/mcp-server/.next/server/app/api/jank/[session]/route.js +5 -5
  29. package/mcp-server/.next/server/app/api/jank/[session]/route.js.nft.json +1 -1
  30. package/mcp-server/.next/server/app/api/logs/append/route.js +4 -4
  31. package/mcp-server/.next/server/app/api/logs/append/route.js.nft.json +1 -1
  32. package/mcp-server/.next/server/app/api/logs/head/route.js +4 -4
  33. package/mcp-server/.next/server/app/api/logs/head/route.js.nft.json +1 -1
  34. package/mcp-server/.next/server/app/api/logs/list/route.js +4 -4
  35. package/mcp-server/.next/server/app/api/logs/list/route.js.nft.json +1 -1
  36. package/mcp-server/.next/server/app/api/logs/rotate/route.js +5 -5
  37. package/mcp-server/.next/server/app/api/logs/rotate/route.js.nft.json +1 -1
  38. package/mcp-server/.next/server/app/api/logs/stream/route.js +4 -4
  39. package/mcp-server/.next/server/app/api/logs/stream/route.js.nft.json +1 -1
  40. package/mcp-server/.next/server/app/api/logs/tail/route.js +4 -4
  41. package/mcp-server/.next/server/app/api/logs/tail/route.js.nft.json +1 -1
  42. package/mcp-server/.next/server/app/api/orchestrator/route.js +6 -6
  43. package/mcp-server/.next/server/app/api/orchestrator/route.js.nft.json +1 -1
  44. package/mcp-server/.next/server/app/api/screenshots/[filename]/route.js +5 -5
  45. package/mcp-server/.next/server/app/api/screenshots/[filename]/route.js.nft.json +1 -1
  46. package/mcp-server/.next/server/app/api/screenshots/list/route.js +5 -5
  47. package/mcp-server/.next/server/app/api/screenshots/list/route.js.nft.json +1 -1
  48. package/mcp-server/.next/server/app/api/tools/route.js +5 -5
  49. package/mcp-server/.next/server/app/api/tools/route.js.nft.json +1 -1
  50. package/mcp-server/.next/server/app/index.html +1 -1
  51. package/mcp-server/.next/server/app/index.rsc +9 -9
  52. package/mcp-server/.next/server/app/index.segments/__PAGE__.segment.rsc +4 -4
  53. package/mcp-server/.next/server/app/index.segments/_full.segment.rsc +9 -9
  54. package/mcp-server/.next/server/app/index.segments/_index.segment.rsc +3 -3
  55. package/mcp-server/.next/server/app/index.segments/_tree.segment.rsc +3 -3
  56. package/mcp-server/.next/server/app/logs/page/build-manifest.json +5 -5
  57. package/mcp-server/.next/server/app/logs/page.js +13 -13
  58. package/mcp-server/.next/server/app/logs/page.js.nft.json +1 -1
  59. package/mcp-server/.next/server/app/logs/page_client-reference-manifest.js +1 -1
  60. package/mcp-server/.next/server/app/mcp/route.js +5 -5
  61. package/mcp-server/.next/server/app/mcp/route.js.nft.json +1 -1
  62. package/mcp-server/.next/server/app/page/build-manifest.json +5 -5
  63. package/mcp-server/.next/server/app/page.js +12 -12
  64. package/mcp-server/.next/server/app/page.js.nft.json +1 -1
  65. package/mcp-server/.next/server/app/page_client-reference-manifest.js +1 -1
  66. package/mcp-server/.next/server/app/video/[session]/page/build-manifest.json +5 -5
  67. package/mcp-server/.next/server/app/video/[session]/page.js +12 -12
  68. package/mcp-server/.next/server/app/video/[session]/page.js.nft.json +1 -1
  69. package/mcp-server/.next/server/app/video/[session]/page_client-reference-manifest.js +1 -1
  70. package/mcp-server/.next/server/chunks/48bbd_next_dist_esm_build_templates_app-route_f218b776.js +3 -0
  71. package/mcp-server/.next/server/chunks/48bbd_next_dist_esm_build_templates_app-route_f218b776.js.map +1 -0
  72. package/mcp-server/.next/server/chunks/48bbd_next_f89e42b7._.js +17 -0
  73. package/mcp-server/.next/server/chunks/48bbd_next_f89e42b7._.js.map +1 -0
  74. package/mcp-server/.next/server/chunks/{[root-of-the-server]__6da2db92._.js → [root-of-the-server]__0691849a._.js} +3 -3
  75. package/mcp-server/.next/server/chunks/[root-of-the-server]__0691849a._.js.map +1 -0
  76. package/mcp-server/.next/server/chunks/[root-of-the-server]__104c0de1._.js +3 -0
  77. package/mcp-server/.next/server/chunks/[root-of-the-server]__104c0de1._.js.map +1 -0
  78. package/mcp-server/.next/server/chunks/{[root-of-the-server]__560d6800._.js → [root-of-the-server]__25028892._.js} +3 -3
  79. package/mcp-server/.next/server/chunks/[root-of-the-server]__25028892._.js.map +1 -0
  80. package/mcp-server/.next/server/chunks/{[root-of-the-server]__564803f8._.js → [root-of-the-server]__346502e7._.js} +2 -2
  81. package/mcp-server/.next/server/chunks/[root-of-the-server]__346502e7._.js.map +1 -0
  82. package/mcp-server/.next/server/chunks/[root-of-the-server]__55fb1929._.js +3 -0
  83. package/mcp-server/.next/server/chunks/[root-of-the-server]__55fb1929._.js.map +1 -0
  84. package/mcp-server/.next/server/chunks/[root-of-the-server]__5fb4d86e._.js +3 -0
  85. package/mcp-server/.next/server/chunks/[root-of-the-server]__5fb4d86e._.js.map +1 -0
  86. package/mcp-server/.next/server/chunks/[root-of-the-server]__623cd86e._.js +3 -0
  87. package/mcp-server/.next/server/chunks/{[root-of-the-server]__0ecb6808._.js.map → [root-of-the-server]__623cd86e._.js.map} +1 -1
  88. package/mcp-server/.next/server/chunks/[root-of-the-server]__79443649._.js +7 -0
  89. package/mcp-server/.next/server/chunks/{[root-of-the-server]__94037b23._.js.map → [root-of-the-server]__79443649._.js.map} +1 -1
  90. package/mcp-server/.next/server/chunks/[root-of-the-server]__acacc665._.js +7 -0
  91. package/mcp-server/.next/server/chunks/[root-of-the-server]__acacc665._.js.map +1 -0
  92. package/mcp-server/.next/server/chunks/[root-of-the-server]__ae49815f._.js +1 -1
  93. package/mcp-server/.next/server/chunks/[root-of-the-server]__b249526b._.js +3 -0
  94. package/mcp-server/.next/server/chunks/[root-of-the-server]__b249526b._.js.map +1 -0
  95. package/mcp-server/.next/server/chunks/[root-of-the-server]__cc8c8c79._.js +3 -0
  96. package/mcp-server/.next/server/chunks/[root-of-the-server]__cc8c8c79._.js.map +1 -0
  97. package/mcp-server/.next/server/chunks/{[root-of-the-server]__0db33344._.js → [root-of-the-server]__e07a3d2e._.js} +3 -3
  98. package/mcp-server/.next/server/chunks/[root-of-the-server]__e07a3d2e._.js.map +1 -0
  99. package/mcp-server/.next/server/chunks/[root-of-the-server]__e4f61504._.js +7 -0
  100. package/mcp-server/.next/server/chunks/{[root-of-the-server]__cc74dbef._.js.map → [root-of-the-server]__e4f61504._.js.map} +1 -1
  101. package/mcp-server/.next/server/chunks/[root-of-the-server]__f37ff204._.js +3 -0
  102. package/mcp-server/.next/server/chunks/[root-of-the-server]__f37ff204._.js.map +1 -0
  103. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_0b95b41d._.js +3 -0
  104. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_0b95b41d._.js.map +1 -0
  105. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_19ada84a._.js +3 -0
  106. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_19ada84a._.js.map +1 -0
  107. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_555486ea._.js +24 -0
  108. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_555486ea._.js.map +1 -0
  109. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_72d3c6b5._.js +6 -0
  110. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_72d3c6b5._.js.map +1 -0
  111. package/mcp-server/.next/server/chunks/ssr/{927ef_next_dist_71a74a90._.js → 48bbd_next_dist_c69079d6._.js} +3 -3
  112. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_c69079d6._.js.map +1 -0
  113. package/mcp-server/.next/server/chunks/ssr/{927ef_next_dist_client_components_builtin_forbidden_7f2836ae.js → 48bbd_next_dist_client_components_builtin_forbidden_ae4e8f76.js} +2 -2
  114. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_client_components_builtin_forbidden_ae4e8f76.js.map +1 -0
  115. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_client_components_builtin_global-error_5507dd64.js +3 -0
  116. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_client_components_builtin_global-error_5507dd64.js.map +1 -0
  117. package/mcp-server/.next/server/chunks/ssr/{927ef_next_dist_client_components_builtin_unauthorized_9c9a021e.js → 48bbd_next_dist_client_components_builtin_unauthorized_4685c00d.js} +2 -2
  118. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_client_components_builtin_unauthorized_4685c00d.js.map +1 -0
  119. package/mcp-server/.next/server/chunks/ssr/{927ef_next_dist_client_components_3f326070._.js → 48bbd_next_dist_client_components_e32e553b._.js} +2 -2
  120. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_client_components_e32e553b._.js.map +1 -0
  121. package/mcp-server/.next/server/chunks/ssr/{_6a5662d5._.js → 48bbd_next_dist_esm_build_templates_app-page_0cbe2e1c.js} +3 -3
  122. package/mcp-server/.next/server/chunks/ssr/48bbd_next_dist_esm_build_templates_app-page_0cbe2e1c.js.map +1 -0
  123. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__2abfd016._.js → [root-of-the-server]__1e3e0e71._.js} +2 -2
  124. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__1e3e0e71._.js.map +1 -0
  125. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__3d2bec74._.js → [root-of-the-server]__2be641ed._.js} +2 -2
  126. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__2be641ed._.js.map +1 -0
  127. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__1c5ac5f3._.js → [root-of-the-server]__40be2e56._.js} +2 -2
  128. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__40be2e56._.js.map +1 -0
  129. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__4d783780._.js +3 -0
  130. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__0f57b0cb._.js → [root-of-the-server]__4f72b426._.js} +2 -2
  131. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__4f72b426._.js.map +1 -0
  132. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__ab133e42._.js → [root-of-the-server]__69b5bb4b._.js} +2 -2
  133. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__69b5bb4b._.js.map +1 -0
  134. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__92e495f0._.js +3 -0
  135. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__92e495f0._.js.map +1 -0
  136. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__a9c9cefa._.js +3 -0
  137. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__fba25701._.js.map → [root-of-the-server]__a9c9cefa._.js.map} +1 -1
  138. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__c7a0da5e._.js +3 -0
  139. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__c7a0da5e._.js.map +1 -0
  140. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__d6cfe4e2._.js → [root-of-the-server]__cb190a6f._.js} +2 -2
  141. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__cb190a6f._.js.map +1 -0
  142. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__f3bcd2aa._.js +3 -0
  143. package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__83f4a70b._.js.map → [root-of-the-server]__f3bcd2aa._.js.map} +1 -1
  144. package/mcp-server/.next/server/chunks/ssr/_0b465ed0._.js +8 -0
  145. package/mcp-server/.next/server/chunks/ssr/_0b465ed0._.js.map +1 -0
  146. package/mcp-server/.next/server/chunks/ssr/{927ef_next_dist_esm_build_templates_app-page_8574fd57.js → _46c41f8e._.js} +3 -3
  147. package/mcp-server/.next/server/chunks/ssr/_46c41f8e._.js.map +1 -0
  148. package/mcp-server/.next/server/chunks/ssr/_514a7b30._.js +8 -0
  149. package/mcp-server/.next/server/chunks/ssr/_514a7b30._.js.map +1 -0
  150. package/mcp-server/.next/server/chunks/ssr/{_2490ff37._.js → _97233da7._.js} +3 -3
  151. package/mcp-server/.next/server/chunks/ssr/{_0866a270._.js.map → _97233da7._.js.map} +1 -1
  152. package/mcp-server/.next/server/chunks/ssr/{_0866a270._.js → _dcda9934._.js} +3 -3
  153. package/mcp-server/.next/server/chunks/ssr/_dcda9934._.js.map +1 -0
  154. package/mcp-server/.next/server/chunks/ssr/mcp-server_app_layout_tsx_afa41767._.js +1 -1
  155. package/mcp-server/.next/server/chunks/ssr/mcp-server_app_page_tsx_9fc46577._.js +1 -1
  156. package/mcp-server/.next/server/chunks/ssr/mcp-server_components_dark-mode-toggle_tsx_f31dd15d._.js +1 -1
  157. package/mcp-server/.next/server/chunks/ssr/mcp-server_components_dark-mode-toggle_tsx_f31dd15d._.js.map +1 -1
  158. package/mcp-server/.next/server/chunks/ssr/{node_modules__pnpm_e1c4d2de._.js → node_modules__pnpm_d25cd5a0._.js} +4 -4
  159. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_d25cd5a0._.js.map +1 -0
  160. package/mcp-server/.next/server/middleware-build-manifest.js +5 -5
  161. package/mcp-server/.next/server/server-reference-manifest.js +1 -1
  162. package/mcp-server/.next/server/server-reference-manifest.json +1 -1
  163. package/mcp-server/.next/static/chunks/0813054680c4b8d9.js +1 -0
  164. package/mcp-server/.next/static/chunks/0e6c3dda50426d51.js +3 -0
  165. package/mcp-server/.next/static/chunks/541301cb5662b97b.js +4 -0
  166. package/mcp-server/.next/static/chunks/9713888fedfe1db9.js +1 -0
  167. package/mcp-server/.next/static/chunks/9eca4842d04ce395.js +20 -0
  168. package/mcp-server/.next/static/chunks/b8b614e19f1e5f19.js +1 -0
  169. package/mcp-server/.next/static/chunks/e0fc2c1c8371dd31.js +1 -0
  170. package/mcp-server/.next/static/chunks/e10632eea6a614ec.js +1 -0
  171. package/mcp-server/.next/static/chunks/eb4a4a37512a1b4e.js +3 -0
  172. package/mcp-server/.next/static/chunks/{d8a5fdca71b9c607.js → edae37866d6cb029.js} +1 -1
  173. package/mcp-server/.next/static/chunks/fa4eeb0b9c10fae4.js +3 -0
  174. package/mcp-server/.next/static/chunks/{turbopack-f59864db2f95ff01.js → turbopack-e3cd7a89396f3bb3.js} +2 -2
  175. package/mcp-server/app/logs/LogsClient.tsx +3 -4
  176. package/package.json +2 -2
  177. package/mcp-server/.next/server/chunks/927ef_next_b5c0ceab._.js +0 -17
  178. package/mcp-server/.next/server/chunks/927ef_next_b5c0ceab._.js.map +0 -1
  179. package/mcp-server/.next/server/chunks/927ef_next_dist_esm_build_templates_app-route_79d02384.js +0 -3
  180. package/mcp-server/.next/server/chunks/927ef_next_dist_esm_build_templates_app-route_79d02384.js.map +0 -1
  181. package/mcp-server/.next/server/chunks/[root-of-the-server]__0db33344._.js.map +0 -1
  182. package/mcp-server/.next/server/chunks/[root-of-the-server]__0ecb6808._.js +0 -3
  183. package/mcp-server/.next/server/chunks/[root-of-the-server]__0fb011f9._.js +0 -3
  184. package/mcp-server/.next/server/chunks/[root-of-the-server]__0fb011f9._.js.map +0 -1
  185. package/mcp-server/.next/server/chunks/[root-of-the-server]__307a61b6._.js +0 -3
  186. package/mcp-server/.next/server/chunks/[root-of-the-server]__307a61b6._.js.map +0 -1
  187. package/mcp-server/.next/server/chunks/[root-of-the-server]__4af7607d._.js +0 -7
  188. package/mcp-server/.next/server/chunks/[root-of-the-server]__4af7607d._.js.map +0 -1
  189. package/mcp-server/.next/server/chunks/[root-of-the-server]__560d6800._.js.map +0 -1
  190. package/mcp-server/.next/server/chunks/[root-of-the-server]__564803f8._.js.map +0 -1
  191. package/mcp-server/.next/server/chunks/[root-of-the-server]__62759808._.js +0 -3
  192. package/mcp-server/.next/server/chunks/[root-of-the-server]__62759808._.js.map +0 -1
  193. package/mcp-server/.next/server/chunks/[root-of-the-server]__6da2db92._.js.map +0 -1
  194. package/mcp-server/.next/server/chunks/[root-of-the-server]__94037b23._.js +0 -7
  195. package/mcp-server/.next/server/chunks/[root-of-the-server]__cc74dbef._.js +0 -7
  196. package/mcp-server/.next/server/chunks/[root-of-the-server]__d8486064._.js +0 -3
  197. package/mcp-server/.next/server/chunks/[root-of-the-server]__d8486064._.js.map +0 -1
  198. package/mcp-server/.next/server/chunks/[root-of-the-server]__e30dda1c._.js +0 -3
  199. package/mcp-server/.next/server/chunks/[root-of-the-server]__e30dda1c._.js.map +0 -1
  200. package/mcp-server/.next/server/chunks/[root-of-the-server]__e907f7c3._.js +0 -3
  201. package/mcp-server/.next/server/chunks/[root-of-the-server]__e907f7c3._.js.map +0 -1
  202. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_4ad3d29e._.js +0 -24
  203. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_4ad3d29e._.js.map +0 -1
  204. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_60ed0712._.js +0 -3
  205. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_60ed0712._.js.map +0 -1
  206. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_71a74a90._.js.map +0 -1
  207. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_b86f0c6a._.js +0 -3
  208. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_b86f0c6a._.js.map +0 -1
  209. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_cdf03b59._.js +0 -6
  210. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_cdf03b59._.js.map +0 -1
  211. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_client_components_3f326070._.js.map +0 -1
  212. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_client_components_builtin_forbidden_7f2836ae.js.map +0 -1
  213. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_client_components_builtin_global-error_c5387393.js +0 -3
  214. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_client_components_builtin_global-error_c5387393.js.map +0 -1
  215. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_client_components_builtin_unauthorized_9c9a021e.js.map +0 -1
  216. package/mcp-server/.next/server/chunks/ssr/927ef_next_dist_esm_build_templates_app-page_8574fd57.js.map +0 -1
  217. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__0f57b0cb._.js.map +0 -1
  218. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__1501212c._.js +0 -3
  219. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__1501212c._.js.map +0 -1
  220. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__1c5ac5f3._.js.map +0 -1
  221. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__2abfd016._.js.map +0 -1
  222. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__3d2bec74._.js.map +0 -1
  223. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__83f4a70b._.js +0 -3
  224. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__ab133e42._.js.map +0 -1
  225. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__cdc83fa5._.js +0 -3
  226. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__d6cfe4e2._.js.map +0 -1
  227. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__f28a30da._.js +0 -3
  228. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__f28a30da._.js.map +0 -1
  229. package/mcp-server/.next/server/chunks/ssr/[root-of-the-server]__fba25701._.js +0 -3
  230. package/mcp-server/.next/server/chunks/ssr/_2490ff37._.js.map +0 -1
  231. package/mcp-server/.next/server/chunks/ssr/_6a5662d5._.js.map +0 -1
  232. package/mcp-server/.next/server/chunks/ssr/_b0105d1e._.js +0 -8
  233. package/mcp-server/.next/server/chunks/ssr/_b0105d1e._.js.map +0 -1
  234. package/mcp-server/.next/server/chunks/ssr/_e1e3dbce._.js +0 -8
  235. package/mcp-server/.next/server/chunks/ssr/_e1e3dbce._.js.map +0 -1
  236. package/mcp-server/.next/server/chunks/ssr/node_modules__pnpm_e1c4d2de._.js.map +0 -1
  237. package/mcp-server/.next/static/chunks/0daa3bbf22255814.js +0 -3
  238. package/mcp-server/.next/static/chunks/166de2ba9f1d84b3.js +0 -3
  239. package/mcp-server/.next/static/chunks/1d0aa71dc83edb1b.js +0 -1
  240. package/mcp-server/.next/static/chunks/30cf3ce29791996b.js +0 -20
  241. package/mcp-server/.next/static/chunks/5ba0dac3773d4366.js +0 -3
  242. package/mcp-server/.next/static/chunks/64afb7547dc485e7.js +0 -1
  243. package/mcp-server/.next/static/chunks/6e21d6bccb01680d.js +0 -1
  244. package/mcp-server/.next/static/chunks/a85611618c82c0e6.js +0 -1
  245. package/mcp-server/.next/static/chunks/bb935d6ae29e5a29.js +0 -1
  246. package/mcp-server/.next/static/chunks/fc6991041566dbdc.js +0 -4
  247. /package/mcp-server/.next/server/chunks/ssr/{[root-of-the-server]__cdc83fa5._.js.map → [root-of-the-server]__4d783780._.js.map} +0 -0
  248. /package/mcp-server/.next/static/{Ks5jGPGu7PisFYLDFIEgx → eVcHKbTsqk-_vUXyVOoaO}/_buildManifest.js +0 -0
  249. /package/mcp-server/.next/static/{Ks5jGPGu7PisFYLDFIEgx → eVcHKbTsqk-_vUXyVOoaO}/_clientMiddlewareManifest.json +0 -0
  250. /package/mcp-server/.next/static/{Ks5jGPGu7PisFYLDFIEgx → eVcHKbTsqk-_vUXyVOoaO}/_ssgManifest.js +0 -0
@@ -1 +0,0 @@
1
- {"version":3,"sources":["turbopack:///[project]/mcp-server/app/api/jank/[session]/route.ts","turbopack:///[project]/node_modules/.pnpm/next@16.0.0-canary.18_babel-plugin-react-compiler@19.1.0-rc.3_react-dom@19.1.1_react@19.1.1__react@19.1.1/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 +0,0 @@
1
- {"version":3,"sources":["turbopack:///[project]/mcp-server/app/api/logs/append/route.ts","turbopack:///[project]/node_modules/.pnpm/next@16.0.0-canary.18_babel-plugin-react-compiler@19.1.0-rc.3_react-dom@19.1.1_react@19.1.1__react@19.1.1/node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import { appendFileSync, existsSync, mkdirSync } from \"fs\"\nimport type { NextRequest } from \"next/server\"\nimport { dirname } from \"path\"\n\ninterface LogEntry {\n entry: string\n source?: string\n}\n\nexport async function POST(request: NextRequest): Promise<Response> {\n try {\n const body = await request.json()\n const { entry, source }: LogEntry = body\n\n if (!entry) {\n return Response.json(\n { error: \"Log entry is required\" },\n {\n status: 400,\n headers: {\n \"Access-Control-Allow-Origin\": \"*\",\n \"Access-Control-Allow-Methods\": \"POST, OPTIONS\",\n \"Access-Control-Allow-Headers\": \"Content-Type\"\n }\n }\n )\n }\n\n const logPath = process.env.LOG_FILE_PATH || \"./ai-dev-tools/consolidated.log\"\n\n // Ensure directory exists\n const logDir = dirname(logPath)\n if (!existsSync(logDir)) {\n mkdirSync(logDir, { recursive: true })\n }\n\n // Append the log entry\n const logLine = `${entry}\\n`\n appendFileSync(logPath, logLine, \"utf-8\")\n\n return Response.json(\n {\n success: true,\n message: \"Log entry appended\",\n source: source || \"unknown\"\n },\n {\n headers: {\n \"Access-Control-Allow-Origin\": \"*\",\n \"Access-Control-Allow-Methods\": \"POST, OPTIONS\",\n \"Access-Control-Allow-Headers\": \"Content-Type\"\n }\n }\n )\n } catch (error) {\n console.error(\"Failed to append log:\", error)\n return Response.json(\n {\n error: error instanceof Error ? error.message : \"Unknown error\"\n },\n {\n status: 500,\n headers: {\n \"Access-Control-Allow-Origin\": \"*\",\n \"Access-Control-Allow-Methods\": \"POST, OPTIONS\",\n \"Access-Control-Allow-Headers\": \"Content-Type\"\n }\n }\n )\n }\n}\n\nexport async function OPTIONS(): Promise<Response> {\n return new Response(null, {\n status: 200,\n headers: {\n \"Access-Control-Allow-Origin\": \"*\",\n \"Access-Control-Allow-Methods\": \"POST, OPTIONS\",\n \"Access-Control-Allow-Headers\": \"Content-Type\"\n }\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/append/route\",\n pathname: \"/api/logs/append\",\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/append/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/append/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=[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"))},24725,(e,t,r)=>{t.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"))},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"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},14747,(e,t,r)=>{t.exports=e.x("path",()=>require("path"))},33405,(e,t,r)=>{t.exports=e.x("child_process",()=>require("child_process"))},2157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},60526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},50227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},52608,e=>{"use strict";var t=e.i(36217),r=e.i(15118),n=e.i(31438),a=e.i(52282),o=e.i(8277),s=e.i(18502),i=e.i(8634),l=e.i(82881),d=e.i(71126),p=e.i(61050),c=e.i(31211),u=e.i(36477),h=e.i(3030),x=e.i(31126),m=e.i(67830),v=e.i(72139),f=e.i(93695);e.i(68495);var g=e.i(52873),R=e.i(2157),C=e.i(60526),w=e.i(50227),y=e.i(64860),E=e.i(20539);async function P(e){let t=(0,E.getMCPClientManager)(),r=t.getConnectedMCPs(),n=t.getAllTools(),a=(0,w.join)((0,C.homedir)(),".d3k"),o=[];try{if((0,R.existsSync)(a))for(let e of(0,R.readdirSync)(a).filter(e=>e.endsWith(".json")))try{let t=(0,w.join)(a,e),r=JSON.parse((0,R.readFileSync)(t,"utf-8")),n=e.replace(".json","");o.push({name:n,cdpUrl:r.cdpUrl,appPort:r.appPort})}catch{}}catch(e){console.error("[Orchestrator API] Failed to read session files:",e)}let s=r.map(e=>{let t=n.filter(t=>t.mcpName===e),r=o.filter(t=>"chrome-devtools"===e?t.cdpUrl:"nextjs-dev"===e&&t.appPort);return{name:e,connected:!0,toolCount:t.length,tools:t.map(e=>e.tool.name),projects:r.map(e=>e.name)}});return y.NextResponse.json({orchestratorEnabled:!0,connectedMCPs:r,totalConnections:r.length,mcpDetails:s,totalProjects:o.length,projects:o.map(e=>e.name),message:r.length>0?`Connected to ${r.length} downstream MCP${r.length>1?"s":""} across ${o.length} project${1!==o.length?"s":""}`:"No downstream MCPs connected (waiting for dev3000 to start Chrome/dev server)"})}e.s(["GET",()=>P,"dynamic",0,"force-dynamic"],64269);var A=e.i(64269);let b=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/orchestrator/route",pathname:"/api/orchestrator",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/mcp-server/app/api/orchestrator/route.ts",nextConfigOutput:"",userland:A}),{workAsyncStorage:j,workUnitAsyncStorage:N,serverHooks:q}=b;function T(){return(0,n.patchFetch)({workAsyncStorage:j,workUnitAsyncStorage:N})}async function _(e,t,n){b.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let R="/api/orchestrator/route";R=R.replace(/\/index$/,"")||"/";let C=await b.prepare(e,t,{srcPage:R,multiZoneDraftMode:!1});if(!C)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:w,params:y,nextConfig:E,parsedUrl:P,isDraftMode:A,prerenderManifest:j,routerServerContext:N,isOnDemandRevalidate:q,revalidateOnlyGenerated:T,resolvedPathname:_,clientReferenceManifest:S,serverActionsManifest:k}=C,O=(0,l.normalizeAppPath)(R),M=!!(j.dynamicRoutes[O]||j.routes[_]),U=async()=>((null==N?void 0:N.render404)?await N.render404(e,t,P,!1):t.end("This page could not be found"),null);if(M&&!A){let e=!!j.routes[_],t=j.dynamicRoutes[O];if(t&&!1===t.fallback&&!e){if(E.experimental.adapterPath)return await U();throw new f.NoFallbackError}}let H=null;!M||b.isDev||A||(H="/index"===(H=_)?"/":H);let I=!0===b.isDev||!M,D=M&&!I;k&&S&&(0,s.setReferenceManifestsSingleton)({page:R,clientReferenceManifest:S,serverActionsManifest:k,serverModuleMap:(0,i.createServerModuleMap)({serverActionsManifest:k})});let $=e.method||"GET",F=(0,o.getTracer)(),K=F.getActiveScopeSpan(),B={params:y,prerenderManifest:j,renderOpts:{experimental:{authInterrupts:!!E.experimental.authInterrupts},cacheComponents:!!E.cacheComponents,supportsDynamicResponse:I,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:E.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n)=>b.onRequestError(e,t,n,N)},sharedContext:{buildId:w}},L=new d.NodeNextRequest(e),G=new d.NodeNextResponse(t),V=p.NextRequestAdapter.fromNodeNextRequest(L,(0,p.signalFromNodeResponse)(t));try{let s=async e=>b.handle(V,B).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=F.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=`${$} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${$} ${R}`)}),i=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var o,l;let d=async({previousCacheEntry:r})=>{try{if(!i&&q&&T&&!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=B.renderOpts.fetchMetrics;let l=B.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let d=B.renderOpts.collectedTags;if(!M)return await (0,h.sendResponse)(L,G,o,B.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,x.toNodeOutgoingHttpHeaders)(o.headers);d&&(t[v.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==B.renderOpts.collectedRevalidate&&!(B.renderOpts.collectedRevalidate>=v.INFINITE_CACHE)&&B.renderOpts.collectedRevalidate,n=void 0===B.renderOpts.collectedExpire||B.renderOpts.collectedExpire>=v.INFINITE_CACHE?void 0:B.renderOpts.collectedExpire;return{value:{kind:g.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 b.onRequestError(e,t,{routerKind:"App Router",routePath:R,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:q})},N),t}},p=await b.handleResponse({req:e,nextConfig:E,cacheKey:H,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:j,isRoutePPREnabled:!1,isOnDemandRevalidate:q,revalidateOnlyGenerated:T,responseGenerator:d,waitUntil:n.waitUntil,isMinimalMode:i});if(!M)return null;if((null==p||null==(o=p.value)?void 0:o.kind)!==g.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==p||null==(l=p.value)?void 0:l.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});i||t.setHeader("x-nextjs-cache",q?"REVALIDATED":p.isMiss?"MISS":p.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,x.fromNodeOutgoingHttpHeaders)(p.value.headers);return i&&M||c.delete(v.NEXT_CACHE_TAGS_HEADER),!p.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,m.getCacheControlHeader)(p.cacheControl)),await (0,h.sendResponse)(L,G,new Response(p.value.body,{headers:c,status:p.value.status||200})),null};K?await l(K):await F.withPropagatedContext(e.headers,()=>F.trace(c.BaseServerSpan.handleRequest,{spanName:`${$} ${R}`,kind:o.SpanKind.SERVER,attributes:{"http.method":$,"http.target":e.url}},l))}catch(t){if(t instanceof f.NoFallbackError||await b.onRequestError(e,t,{routerKind:"App Router",routePath:O,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:q})}),M)throw t;return await (0,h.sendResponse)(L,G,new Response(null,{status:500})),null}}e.s(["handler",()=>_,"patchFetch",()=>T,"routeModule",()=>b,"serverHooks",()=>q,"workAsyncStorage",()=>j,"workUnitAsyncStorage",()=>N],52608)},70729,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_node:crypto_c20cce38._.js"].map(t=>e.l(t))).then(()=>t(66680)))}];
2
-
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__0ecb6808._.js.map
@@ -1,3 +0,0 @@
1
- module.exports=[24725,(e,t,r)=>{t.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"))},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"))},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"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},55e3,e=>{"use strict";var t=e.i(36217),r=e.i(15118),n=e.i(31438),a=e.i(52282),o=e.i(8277),i=e.i(18502),s=e.i(8634),l=e.i(82881),p=e.i(71126),u=e.i(61050),d=e.i(31211),c=e.i(36477),f=e.i(3030),m=e.i(31126),x=e.i(67830),h=e.i(72139),R=e.i(93695);e.i(68495);var g=e.i(52873),E=e.i(64860);async function y(){try{let e=[{name:"fix_my_app",description:"🔧 **THE ULTIMATE FIND→FIX→VERIFY MACHINE!** This isn't just debugging—it's MAGICAL problem-solving that FIXES your app! 🪄\n\n🔥 **INSTANT FIX POWERS:**\n• FINDS: Server errors, browser crashes, build failures, API issues, performance problems—EVERYTHING\n• FIXES: Provides EXACT code fixes with file locations and line numbers\n• GUIDES: Step-by-step implementation of fixes\n• VERIFIES: Ensures fixes actually resolve the issues\n\n🚀 **3 ACTION MODES:**\n• **FIX NOW** (default): \"What's broken RIGHT NOW?\" → Find and fix immediately\n• **FIX REGRESSION**: \"What broke during testing?\" → Compare before/after and fix\n• **FIX CONTINUOUSLY**: \"Fix issues as they appear\" → Monitor and fix proactively\n\n⚡ **THE FIX-IT WORKFLOW:**\n1️⃣ I FIND all issues instantly\n2️⃣ I provide EXACT FIXES with code\n3️⃣ You implement the fixes\n4️⃣ We VERIFY everything works\n\n🎪 **WHY THIS TOOL IS MAGIC:**\n• Goes beyond debugging to actual fixing\n• Provides copy-paste fix code\n• Works with 'fix my app' or 'debug my app'\n• Makes broken apps work again!\n• You become the fix-it hero!\n\n💡 **PRO TIPS:**\n• Say 'fix my app' for instant error resolution\n• Use execute_browser_action to verify fixes\n• This tool doesn't just find problems—it SOLVES them!",category:"Error Fixing",parameters:[{name:"focusArea",type:"string",optional:!0,description:"Specific area: 'build', 'runtime', 'network', 'ui', 'all' (default: 'all')"},{name:"mode",type:"enum",optional:!0,description:"Fix mode: 'snapshot' (fix now), 'bisect' (fix regression), 'monitor' (fix continuously)"},{name:"waitForUserInteraction",type:"boolean",optional:!0,description:"In bisect mode: capture timestamp, wait for user testing, then analyze (default: false)"},{name:"timeRangeMinutes",type:"number",optional:!0,description:"Minutes to analyze back from now (default: 10)"},{name:"includeTimestampInstructions",type:"boolean",optional:!0,description:"Show timestamp-based debugging instructions (default: true)"}]},{name:"execute_browser_action",description:"🪄 **SMART INTERACTION TESTING** - Use for targeted user workflow verification! 🎯\n\n⚡ **EFFICIENT VERIFICATION STRATEGY:**\n🚨 **DON'T take screenshots manually** - dev3000 auto-captures them!\n✅ **DO use this for:** click, navigate, scroll, type to reproduce user interactions\n✅ **DO verify fixes by:** reproducing the original error scenario, then check fix_my_app for verification\n\n🔥 **BROWSER ACTIONS:**\n• CLICK buttons/links → Test specific user interactions\n• NAVIGATE to pages → Reproduce user journeys \n• SCROLL & TYPE → Simulate user workflows\n• EVALUATE JavaScript → Check app state (read-only)\n\n⚡ **OPTIMAL FIX VERIFICATION WORKFLOW:**\n1️⃣ fix_my_app finds issues + provides exact fixes\n2️⃣ You implement the fix code\n3️⃣ Use execute_browser_action to REPRODUCE the original interaction\n4️⃣ Run fix_my_app again to verify the fix worked\n\n🎯 **PERFECT FOR:**\n• Verifying fixes actually resolve the errors\n• Testing interactions after implementing fixes\n• Confirming forms work, buttons respond, etc.\n• Ensuring the app works correctly after fixes\n\n🚫 **AVOID:** Manual screenshot action (dev3000 auto-captures)\n✅ **USE:** Interaction reproduction + fix_my_app for verification\n\n🛡️ **SAFETY:** Safe operations only, read-only JS evaluation",category:"Browser Automation",parameters:[{name:"action",type:"enum",description:"Action to perform: 'click', 'navigate', 'screenshot', 'evaluate', 'scroll', 'type'"},{name:"params",type:"object",description:"Parameters for the action (coordinates, URL, selector, text, expression, etc.)"}]}];return E.NextResponse.json({tools:e,endpoint:`http://localhost:${process.env.PORT||"3684"}/mcp`,totalTools:e.length,categories:[...new Set(e.map(e=>e.category))]})}catch(e){return E.NextResponse.json({error:"Failed to extract tools documentation"},{status:500})}}e.s(["GET",()=>y],40004);var v=e.i(40004);let I=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/tools/route",pathname:"/api/tools",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/mcp-server/app/api/tools/route.ts",nextConfigOutput:"",userland:v}),{workAsyncStorage:T,workUnitAsyncStorage:w,serverHooks:b}=I;function A(){return(0,n.patchFetch)({workAsyncStorage:T,workUnitAsyncStorage:w})}async function C(e,t,n){I.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let E="/api/tools/route";E=E.replace(/\/index$/,"")||"/";let y=await I.prepare(e,t,{srcPage:E,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:v,params:T,nextConfig:w,parsedUrl:b,isDraftMode:A,prerenderManifest:C,routerServerContext:S,isOnDemandRevalidate:O,revalidateOnlyGenerated:N,resolvedPathname:k,clientReferenceManifest:F,serverActionsManifest:_}=y,P=(0,l.normalizeAppPath)(E),M=!!(C.dynamicRoutes[P]||C.routes[k]),U=async()=>((null==S?void 0:S.render404)?await S.render404(e,t,b,!1):t.end("This page could not be found"),null);if(M&&!A){let e=!!C.routes[k],t=C.dynamicRoutes[P];if(t&&!1===t.fallback&&!e){if(w.experimental.adapterPath)return await U();throw new R.NoFallbackError}}let H=null;!M||I.isDev||A||(H="/index"===(H=k)?"/":H);let j=!0===I.isDev||!M,D=M&&!j;_&&F&&(0,i.setReferenceManifestsSingleton)({page:E,clientReferenceManifest:F,serverActionsManifest:_,serverModuleMap:(0,s.createServerModuleMap)({serverActionsManifest:_})});let q=e.method||"GET",L=(0,o.getTracer)(),W=L.getActiveScopeSpan(),X={params:T,prerenderManifest:C,renderOpts:{experimental:{authInterrupts:!!w.experimental.authInterrupts},cacheComponents:!!w.cacheComponents,supportsDynamicResponse:j,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:w.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n)=>I.onRequestError(e,t,n,S)},sharedContext:{buildId:v}},G=new p.NodeNextRequest(e),V=new p.NodeNextResponse(t),K=u.NextRequestAdapter.fromNodeNextRequest(G,(0,u.signalFromNodeResponse)(t));try{let i=async e=>I.handle(K,X).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=L.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==d.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=`${q} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${q} ${E}`)}),s=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var o,l;let p=async({previousCacheEntry:r})=>{try{if(!s&&O&&N&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let o=await i(a);e.fetchMetrics=X.renderOpts.fetchMetrics;let l=X.renderOpts.pendingWaitUntil;l&&n.waitUntil&&(n.waitUntil(l),l=void 0);let p=X.renderOpts.collectedTags;if(!M)return await (0,f.sendResponse)(G,V,o,X.renderOpts.pendingWaitUntil),null;{let e=await o.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(o.headers);p&&(t[h.NEXT_CACHE_TAGS_HEADER]=p),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==X.renderOpts.collectedRevalidate&&!(X.renderOpts.collectedRevalidate>=h.INFINITE_CACHE)&&X.renderOpts.collectedRevalidate,n=void 0===X.renderOpts.collectedExpire||X.renderOpts.collectedExpire>=h.INFINITE_CACHE?void 0:X.renderOpts.collectedExpire;return{value:{kind:g.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 I.onRequestError(e,t,{routerKind:"App Router",routePath:E,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:O})},S),t}},u=await I.handleResponse({req:e,nextConfig:w,cacheKey:H,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:C,isRoutePPREnabled:!1,isOnDemandRevalidate:O,revalidateOnlyGenerated:N,responseGenerator:p,waitUntil:n.waitUntil,isMinimalMode:s});if(!M)return null;if((null==u||null==(o=u.value)?void 0:o.kind)!==g.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});s||t.setHeader("x-nextjs-cache",O?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),A&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,m.fromNodeOutgoingHttpHeaders)(u.value.headers);return s&&M||d.delete(h.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,x.getCacheControlHeader)(u.cacheControl)),await (0,f.sendResponse)(G,V,new Response(u.value.body,{headers:d,status:u.value.status||200})),null};W?await l(W):await L.withPropagatedContext(e.headers,()=>L.trace(d.BaseServerSpan.handleRequest,{spanName:`${q} ${E}`,kind:o.SpanKind.SERVER,attributes:{"http.method":q,"http.target":e.url}},l))}catch(t){if(t instanceof R.NoFallbackError||await I.onRequestError(e,t,{routerKind:"App Router",routePath:P,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:O})}),M)throw t;return await (0,f.sendResponse)(G,V,new Response(null,{status:500})),null}}e.s(["handler",()=>C,"patchFetch",()=>A,"routeModule",()=>I,"serverHooks",()=>b,"workAsyncStorage",()=>T,"workUnitAsyncStorage",()=>w],55e3)}];
2
-
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__0fb011f9._.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["turbopack:///[project]/mcp-server/app/api/tools/route.ts","turbopack:///[project]/node_modules/.pnpm/next@16.0.0-canary.18_babel-plugin-react-compiler@19.1.0-rc.3_react-dom@19.1.1_react@19.1.1__react@19.1.1/node_modules/next/dist/esm/build/templates/app-route.js"],"sourcesContent":["import { NextResponse } from \"next/server\"\n\n// This endpoint extracts MCP tools documentation by parsing the route handler\nexport async function GET() {\n try {\n // Streamlined tool set - reduced from 10 tools to 2 for zero authorization friction!\n const tools = [\n {\n name: \"fix_my_app\",\n description:\n \"🔧 **THE ULTIMATE FIND→FIX→VERIFY MACHINE!** This isn't just debugging—it's MAGICAL problem-solving that FIXES your app! 🪄\\n\\n🔥 **INSTANT FIX POWERS:**\\n• FINDS: Server errors, browser crashes, build failures, API issues, performance problems—EVERYTHING\\n• FIXES: Provides EXACT code fixes with file locations and line numbers\\n• GUIDES: Step-by-step implementation of fixes\\n• VERIFIES: Ensures fixes actually resolve the issues\\n\\n🚀 **3 ACTION MODES:**\\n• **FIX NOW** (default): \\\"What's broken RIGHT NOW?\\\" → Find and fix immediately\\n• **FIX REGRESSION**: \\\"What broke during testing?\\\" → Compare before/after and fix\\n• **FIX CONTINUOUSLY**: \\\"Fix issues as they appear\\\" → Monitor and fix proactively\\n\\n⚡ **THE FIX-IT WORKFLOW:**\\n1️⃣ I FIND all issues instantly\\n2️⃣ I provide EXACT FIXES with code\\n3️⃣ You implement the fixes\\n4️⃣ We VERIFY everything works\\n\\n🎪 **WHY THIS TOOL IS MAGIC:**\\n• Goes beyond debugging to actual fixing\\n• Provides copy-paste fix code\\n• Works with 'fix my app' or 'debug my app'\\n• Makes broken apps work again!\\n• You become the fix-it hero!\\n\\n💡 **PRO TIPS:**\\n• Say 'fix my app' for instant error resolution\\n• Use execute_browser_action to verify fixes\\n• This tool doesn't just find problems—it SOLVES them!\",\n category: \"Error Fixing\",\n parameters: [\n {\n name: \"focusArea\",\n type: \"string\",\n optional: true,\n description: \"Specific area: 'build', 'runtime', 'network', 'ui', 'all' (default: 'all')\"\n },\n {\n name: \"mode\",\n type: \"enum\",\n optional: true,\n description: \"Fix mode: 'snapshot' (fix now), 'bisect' (fix regression), 'monitor' (fix continuously)\"\n },\n {\n name: \"waitForUserInteraction\",\n type: \"boolean\",\n optional: true,\n description: \"In bisect mode: capture timestamp, wait for user testing, then analyze (default: false)\"\n },\n {\n name: \"timeRangeMinutes\",\n type: \"number\",\n optional: true,\n description: \"Minutes to analyze back from now (default: 10)\"\n },\n {\n name: \"includeTimestampInstructions\",\n type: \"boolean\",\n optional: true,\n description: \"Show timestamp-based debugging instructions (default: true)\"\n }\n ]\n },\n {\n name: \"execute_browser_action\",\n description:\n \"🪄 **SMART INTERACTION TESTING** - Use for targeted user workflow verification! 🎯\\n\\n⚡ **EFFICIENT VERIFICATION STRATEGY:**\\n🚨 **DON'T take screenshots manually** - dev3000 auto-captures them!\\n✅ **DO use this for:** click, navigate, scroll, type to reproduce user interactions\\n✅ **DO verify fixes by:** reproducing the original error scenario, then check fix_my_app for verification\\n\\n🔥 **BROWSER ACTIONS:**\\n• CLICK buttons/links → Test specific user interactions\\n• NAVIGATE to pages → Reproduce user journeys \\n• SCROLL & TYPE → Simulate user workflows\\n• EVALUATE JavaScript → Check app state (read-only)\\n\\n⚡ **OPTIMAL FIX VERIFICATION WORKFLOW:**\\n1️⃣ fix_my_app finds issues + provides exact fixes\\n2️⃣ You implement the fix code\\n3️⃣ Use execute_browser_action to REPRODUCE the original interaction\\n4️⃣ Run fix_my_app again to verify the fix worked\\n\\n🎯 **PERFECT FOR:**\\n• Verifying fixes actually resolve the errors\\n• Testing interactions after implementing fixes\\n• Confirming forms work, buttons respond, etc.\\n• Ensuring the app works correctly after fixes\\n\\n🚫 **AVOID:** Manual screenshot action (dev3000 auto-captures)\\n✅ **USE:** Interaction reproduction + fix_my_app for verification\\n\\n🛡️ **SAFETY:** Safe operations only, read-only JS evaluation\",\n category: \"Browser Automation\",\n parameters: [\n {\n name: \"action\",\n type: \"enum\",\n description: \"Action to perform: 'click', 'navigate', 'screenshot', 'evaluate', 'scroll', 'type'\"\n },\n {\n name: \"params\",\n type: \"object\",\n description: \"Parameters for the action (coordinates, URL, selector, text, expression, etc.)\"\n }\n ]\n }\n // TODO: Commenting out for now - need to figure out the right approach for proactive monitoring\n /*\n ,{\n name: \"start_error_monitoring\",\n description:\n \"🔍 **SIMPLE ERROR MONITORING** - Starts a lightweight background process that watches your app for errors and alerts you in real-time.\\n\\n⚡ **INSTANT ACTIVATION:**\\n• Claude offers to run the monitoring script immediately\\n• Just say 'yes' or 'monitor my app' to start\\n• Simple 15-line Python script that just works\\n• Real-time alerts when errors occur\\n\\n💡 **WHAT IT DOES:**\\n• Watches for ERROR, FAIL, Exception, TypeError, CRASH keywords\\n• Shows the error line when detected\\n• Prompts you to let Claude debug\\n• That's it - simple and effective!\\n\\n🎯 **USAGE FLOW:**\\n1. User: 'monitor my app'\\n2. Claude: 'Should I start monitoring now?'\\n3. User: 'yes'\\n4. Claude runs the script → monitoring active\\n5. When errors appear → 'Tell me: debug my app'\\n\\n✨ **THE BEAUTY:**\\n• No complex features - just works\\n• Lightweight and fast\\n• Perfect for quick error detection\",\n category: \"Monitoring\",\n parameters: [\n {\n name: \"projectName\",\n type: \"string\",\n optional: true,\n description: \"Project name to monitor (if multiple dev3000 instances are running)\"\n }\n ]\n }\n */\n ]\n\n return NextResponse.json({\n tools,\n endpoint: `http://localhost:${process.env.PORT || \"3684\"}/mcp`,\n totalTools: tools.length,\n categories: [...new Set(tools.map((t) => t.category))]\n })\n } catch (_error) {\n return NextResponse.json({ error: \"Failed to extract tools documentation\" }, { 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/tools/route\",\n pathname: \"/api/tools\",\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/tools/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/tools/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=[22734,(e,t,r)=>{t.exports=e.x("fs",()=>require("fs"))},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"))},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"))},70406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},86260,e=>{"use strict";var t=e.i(36217),r=e.i(15118),n=e.i(31438),a=e.i(52282),o=e.i(8277),s=e.i(18502),i=e.i(8634),l=e.i(82881),d=e.i(71126),u=e.i(61050),p=e.i(31211),c=e.i(36477),h=e.i(3030),x=e.i(31126),R=e.i(67830),v=e.i(72139),g=e.i(93695);e.i(68495);var f=e.i(52873),m=e.i(22734);async function E(e){try{let{searchParams:t}=new URL(e.url),r=parseInt(t.get("lines")||"50",10),n=t.get("logPath")||process.env.LOG_FILE_PATH||"./ai-dev-tools/consolidated.log";if(!(0,m.existsSync)(n))return Response.json({error:"Log file not found"},{status:404});let a=(0,m.readFileSync)(n,"utf-8").split("\n").filter(e=>e.trim()),o={logs:a.slice(0,r).join("\n"),total:a.length};return Response.json(o)}catch(t){let e={error:t instanceof Error?t.message:"Unknown error"};return Response.json(e,{status:500})}}e.s(["GET",()=>E],9421);var w=e.i(9421);let y=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/logs/head/route",pathname:"/api/logs/head",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/mcp-server/app/api/logs/head/route.ts",nextConfigOutput:"",userland:w}),{workAsyncStorage:C,workUnitAsyncStorage:A,serverHooks:b}=y;function T(){return(0,n.patchFetch)({workAsyncStorage:C,workUnitAsyncStorage:A})}async function P(e,t,n){y.isDev&&(0,a.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let m="/api/logs/head/route";m=m.replace(/\/index$/,"")||"/";let E=await y.prepare(e,t,{srcPage:m,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:A,parsedUrl:b,isDraftMode:T,prerenderManifest:P,routerServerContext:N,isOnDemandRevalidate:O,revalidateOnlyGenerated:S,resolvedPathname:_,clientReferenceManifest:k,serverActionsManifest:q}=E,j=(0,l.normalizeAppPath)(m),H=!!(P.dynamicRoutes[j]||P.routes[_]),U=async()=>((null==N?void 0:N.render404)?await N.render404(e,t,b,!1):t.end("This page could not be found"),null);if(H&&!T){let e=!!P.routes[_],t=P.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(A.experimental.adapterPath)return await U();throw new g.NoFallbackError}}let I=null;!H||y.isDev||T||(I="/index"===(I=_)?"/":I);let M=!0===y.isDev||!H,D=H&&!M;q&&k&&(0,s.setReferenceManifestsSingleton)({page:m,clientReferenceManifest:k,serverActionsManifest:q,serverModuleMap:(0,i.createServerModuleMap)({serverActionsManifest:q})});let F=e.method||"GET",L=(0,o.getTracer)(),$=L.getActiveScopeSpan(),K={params:C,prerenderManifest:P,renderOpts:{experimental:{authInterrupts:!!A.experimental.authInterrupts},cacheComponents:!!A.cacheComponents,supportsDynamicResponse:M,incrementalCache:(0,a.getRequestMeta)(e,"incrementalCache"),cacheLifeProfiles:A.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n)=>y.onRequestError(e,t,n,N)},sharedContext:{buildId:w}},B=new d.NodeNextRequest(e),G=new d.NodeNextResponse(t),V=u.NextRequestAdapter.fromNodeNextRequest(B,(0,u.signalFromNodeResponse)(t));try{let s=async e=>y.handle(V,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=L.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==p.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=`${F} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t)}else e.updateName(`${F} ${m}`)}),i=!!(0,a.getRequestMeta)(e,"minimalMode"),l=async a=>{var o,l;let d=async({previousCacheEntry:r})=>{try{if(!i&&O&&S&&!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,x.toNodeOutgoingHttpHeaders)(o.headers);d&&(t[v.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>=v.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,n=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=v.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:f.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 y.onRequestError(e,t,{routerKind:"App Router",routePath:m,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:O})},N),t}},u=await y.handleResponse({req:e,nextConfig:A,cacheKey:I,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:P,isRoutePPREnabled:!1,isOnDemandRevalidate:O,revalidateOnlyGenerated:S,responseGenerator:d,waitUntil:n.waitUntil,isMinimalMode:i});if(!H)return null;if((null==u||null==(o=u.value)?void 0:o.kind)!==f.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",O?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),T&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let p=(0,x.fromNodeOutgoingHttpHeaders)(u.value.headers);return i&&H||p.delete(v.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||p.get("Cache-Control")||p.set("Cache-Control",(0,R.getCacheControlHeader)(u.cacheControl)),await (0,h.sendResponse)(B,G,new Response(u.value.body,{headers:p,status:u.value.status||200})),null};$?await l($):await L.withPropagatedContext(e.headers,()=>L.trace(p.BaseServerSpan.handleRequest,{spanName:`${F} ${m}`,kind:o.SpanKind.SERVER,attributes:{"http.method":F,"http.target":e.url}},l))}catch(t){if(t instanceof g.NoFallbackError||await y.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:O})}),H)throw t;return await (0,h.sendResponse)(B,G,new Response(null,{status:500})),null}}e.s(["handler",()=>P,"patchFetch",()=>T,"routeModule",()=>y,"serverHooks",()=>b,"workAsyncStorage",()=>C,"workUnitAsyncStorage",()=>A],86260)}];
2
-
3
- //# sourceMappingURL=%5Broot-of-the-server%5D__307a61b6._.js.map
@@ -1 +0,0 @@
1
- {"version":3,"sources":["turbopack:///[project]/node_modules/.pnpm/next@16.0.0-canary.18_babel-plugin-react-compiler@19.1.0-rc.3_react-dom@19.1.1_react@19.1.1__react@19.1.1/node_modules/next/dist/esm/build/templates/app-route.js","turbopack:///[project]/mcp-server/app/api/logs/head/route.ts"],"sourcesContent":["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/head/route\",\n pathname: \"/api/logs/head\",\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/head/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/head/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","import { existsSync, readFileSync } from \"fs\"\nimport type { NextRequest } from \"next/server\"\nimport type { LogsApiError, LogsApiResponse } from \"@/types\"\n\nexport async function GET(request: NextRequest): Promise<Response> {\n try {\n const { searchParams } = new URL(request.url)\n const lines = parseInt(searchParams.get(\"lines\") || \"50\", 10)\n const logPath = searchParams.get(\"logPath\") || process.env.LOG_FILE_PATH || \"./ai-dev-tools/consolidated.log\"\n\n if (!existsSync(logPath)) {\n const errorResponse: LogsApiError = { error: \"Log file not found\" }\n return Response.json(errorResponse, { status: 404 })\n }\n\n const logContent = readFileSync(logPath, \"utf-8\")\n const allLines = logContent.split(\"\\n\").filter((line) => line.trim())\n const headLines = allLines.slice(0, lines)\n\n const response: LogsApiResponse = {\n logs: headLines.join(\"\\n\"),\n total: allLines.length\n }\n\n return Response.json(response)\n } catch (error) {\n const errorResponse: LogsApiError = {\n error: error instanceof Error ? error.message : \"Unknown error\"\n }\n return Response.json(errorResponse, { status: 500 })\n }\n}\n"],"names":[],"mappings":"u3BAAA,IAAA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,MACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,EAAA,CAAA,CAAA,OACA,EAAA,CAAA,CAAA,OAAA,IAAA,EAAA,EAAA,CAAA,CAAA,OCjBA,EAAA,EAAA,CAAA,CAAA,OAIO,eAAe,EAAI,CAAoB,EAC5C,GAAI,CACF,GAAM,cAAE,CAAY,CAAE,CAAG,IAAI,IAAI,EAAQ,GAAG,EACtC,EAAQ,SAAS,EAAa,GAAG,CAAC,UAAY,KAAM,IACpD,EAAU,EAAa,GAAG,CAAC,YAAc,QAAQ,GAAG,CAAC,aAAa,EAAI,kCAE5E,GAAI,CAAC,CAAA,EAAA,EAAA,UAAA,AAAU,EAAC,GAEd,OAFwB,AAEjB,SAAS,IAAI,CADgB,AACf,CADiB,MAAO,oBAAqB,EAC9B,CAAE,OAAQ,GAAI,GAIpD,IAAM,EAAW,AADE,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAS,SACb,KAAK,CAAC,MAAM,MAAM,CAAC,AAAC,GAAS,EAAK,IAAI,IAG5D,EAA4B,CAChC,KAHgB,AAGV,EAHmB,KAAK,CAAC,EAAG,GAGlB,IAAI,CAAC,MACrB,MAAO,EAAS,MAAM,AACxB,EAEA,OAAO,SAAS,IAAI,CAAC,EACvB,CAAE,MAAO,EAAO,CACd,IAAM,EAA8B,CAClC,MAAO,aAAiB,MAAQ,EAAM,OAAO,CAAG,eAClD,EACA,OAAO,SAAS,IAAI,CAAC,EAAe,CAAE,OAAQ,GAAI,EACpD,CACF,yBDbA,IAAA,EAAA,EAAA,CAAA,CAAA,MAIA,IAAM,EAAc,IAAI,EAAA,mBAAmB,CAAC,CACxC,WAAY,CACR,KAAM,EAAA,SAAS,CAAC,SAAS,CACzB,KAAM,uBACN,SAAU,iBACV,SAAU,QACV,WAAY,EAChB,EACA,QAAS,CAAA,OACT,IADiD,eACc,CAA3C,EACpB,iBAAkB,kDAClB,iBAZqB,GAarB,SAAA,CACJ,GAIM,kBAAE,CAAgB,sBAAE,CAAoB,aAAE,CAAW,CAAE,CAAG,EAChE,SAAS,IACL,MAAO,CAAA,EAAA,EAAA,UAAA,AAAW,EAAC,kBACf,uBACA,CACJ,EACJ,CAEO,eAAe,EAAQ,CAAG,CAAE,CAAG,CAAE,CAAG,EACnC,EAAY,KAAK,EACjB,AADmB,CACnB,EAAA,EAAA,cAAA,AAAc,EAAC,EAAK,+BAAgC,QAAQ,MAAM,CAAC,MAAM,IAE7E,IAAI,EAAU,uBAKV,EAAU,EAAQ,OAAO,CAAC,WAAY,KAAO,IAMjD,IAAM,EAAgB,MAAM,EAAY,OAAO,CAAC,EAAK,EAAK,CACtD,UACA,mBAHE,CAAA,CAIN,GACA,GAAI,CAAC,EAID,OAHA,EAAI,IADY,MACF,CAAG,IACjB,EAAI,GAAG,CAAC,eACS,MAAjB,CAAwB,CAApB,IAAyB,KAAhB,EAAoB,EAAI,SAAS,CAAC,IAAI,CAAC,EAAK,QAAQ,OAAO,IACjE,KAEX,GAAM,SAAE,CAAO,QAAE,CAAM,YAAE,CAAU,CAAE,WAAS,aAAE,CAAW,mBAAE,CAAiB,qBAAE,CAAmB,sBAAE,CAAoB,yBAAE,CAAuB,kBAAE,CAAgB,yBAAE,CAAuB,uBAAE,CAAqB,CAAE,CAAG,EACnN,EAAoB,CAAA,EAAA,EAAA,gBAAA,AAAgB,EAAC,GACvC,GAAQ,EAAQ,EAAkB,aAAa,CAAC,EAAkB,EAAI,EAAkB,MAAM,CAAC,EAAiB,AAAjB,EAC7F,EAAY,WAEa,MAAvB,EAA8B,KAAK,EAAI,EAAoB,SAAA,AAAS,EAAE,AACtE,MAAM,EAAoB,SAAS,CAAC,EAAK,EAAK,GAAW,GAEzD,EAAI,GAAG,CAAC,gCAEL,MAEX,GAAI,GAAS,CAAC,EAAa,CACvB,IAAM,GAAgB,CAAQ,EAAkB,MAAM,CAAC,EAAiB,CAClE,EAAgB,EAAkB,aAAa,CAAC,EAAkB,CACxE,GAAI,IAC+B,IAA3B,EAAc,KADH,GACW,EAAc,CAAC,EAAe,CACpD,GAAI,EAAW,YAAY,CAAC,WAAW,CACnC,CADqC,MAC9B,MAAM,GAEjB,OAAM,IAAI,EAAA,eAAe,AAC7B,CAER,CACA,IAAI,EAAW,MACX,GAAU,EAAY,IAAb,CAAkB,EAAK,EAAD,EAG/B,EAAW,AAAa,OAHqB,KAC7C,EAAW,CAAA,EAEwB,IAAM,CAAA,EAE7C,IAAM,EACN,CAAsB,MAAV,EAAkB,GAAb,EAEjB,CAAC,EAKK,EAAqB,GAAS,CAAC,EAIjC,GAAyB,GACzB,CAAA,EAAA,EAAA,iBADkD,aAClD,AAA8B,EAAC,CAC3B,KAAM,IAbqF,sBAc3F,wBACA,EACA,gBAAiB,CAAA,EAAA,EAAA,qBAAA,AAAqB,EAAC,uBACnC,CACJ,EACJ,GAEJ,IAAM,EAAS,EAAI,MAAM,EAAI,MACvB,EAAS,CAAA,EAAA,EAAA,SAAA,AAAS,IAClB,EAAa,EAAO,kBAAkB,GACtC,EAAU,CACZ,SACA,oBACA,WAAY,CACR,aAAc,CACV,gBAAgB,CAAQ,EAAW,YAAY,CAAC,cACpD,AADkE,EAElE,iBAAiB,CAAQ,EAAW,eAAe,yBACnD,EACA,iBAAkB,CAAA,EAAA,EAAA,cAAA,AAAc,EAAC,EAAK,oBACtC,kBAAmB,EAAW,SAAS,CACvC,UAAW,EAAI,SAAS,CACxB,QAAS,AAAC,IACN,EAAI,EAAE,CAAC,QAAS,EACpB,EACA,sBAAkB,EAClB,8BAA+B,CAAC,EAAO,EAAU,IAAe,EAAY,cAAc,CAAC,EAAK,EAAO,EAAc,EACzH,EACA,cAAe,SACX,CACJ,CACJ,EACM,EAAc,IAAI,EAAA,eAAe,CAAC,GAClC,EAAc,IAAI,EAAA,gBAAgB,CAAC,GACnC,EAAU,EAAA,kBAAkB,CAAC,mBAAmB,CAAC,EAAa,CAAA,EAAA,EAAA,sBAAA,AAAsB,EAAC,IAC3F,GAAI,CACA,IAAM,EAAoB,MAAO,GACtB,EAAY,MAAM,CAAC,EAAS,GAAS,OAAO,CAAC,KAChD,GAAI,CAAC,EAAM,OACX,EAAK,aAAa,CAAC,CACf,mBAAoB,EAAI,UAAU,CAClC,YAAY,CAChB,GACA,IAAM,EAAqB,EAAO,qBAAqB,GAEvD,GAAI,CAAC,EACD,OAEJ,GAAI,EAAmB,GAAG,CAAC,EAHF,kBAGwB,EAAA,cAAc,CAAC,aAAa,CAAE,YAC3E,QAAQ,IAAI,CAAC,CAAC,2BAA2B,EAAE,EAAmB,GAAG,CAAC,kBAAkB,qEAAqE,CAAC,EAG9J,IAAM,EAAQ,EAAmB,GAAG,CAAC,cACrC,GAAI,EAAO,CACP,IAAM,EAAO,CAAA,EAAG,EAAO,CAAC,EAAE,EAAA,CAAO,CACjC,EAAK,aAAa,CAAC,CACf,aAAc,EACd,aAAc,EACd,iBAAkB,CACtB,GACA,EAAK,UAAU,CAAC,EACpB,MACI,CADG,CACE,UAAU,CAAC,CAAA,EAAG,EAAO,CAAC,EAAE,EAAA,CAAS,CAE9C,GAEE,GAAgB,CAAoC,CAAA,EAAA,EAAA,EAA5B,YAA4B,AAAc,EAAC,EAAK,eACxE,EAAiB,MAAO,QACtB,EA2FI,EA1FR,IAAM,EAAoB,MAAO,CAAE,oBAAkB,CAAE,IACnD,GAAI,CACA,GAAI,CAAC,GAAiB,GAAwB,GAA2B,CAAC,EAKtE,OAJA,EAAI,SADsF,CAC5E,CAAG,IAEjB,EAAI,SAAS,CAAC,iBAAkB,eAChC,EAAI,GAAG,CAAC,gCACD,KAEX,IAAM,EAAW,MAAM,EAAkB,GACzC,EAAI,YAAY,CAAG,EAAQ,UAAU,CAAC,YAAY,CAClD,IAAI,EAAmB,EAAQ,UAAU,CAAC,gBAAgB,CAGtD,GACI,EAAI,SAAS,EAAE,CACf,CAFc,CAEV,SAAS,CAAC,GACd,OAAmB,GAG3B,IAAM,EAAY,EAAQ,UAAU,CAAC,aAAa,CAGlD,IAAI,EA6BA,OADA,MAAM,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAa,EAAa,EAAU,EAAQ,UAAU,CAAC,gBAAgB,EACnF,IA7BA,EACP,IAAM,EAAO,MAAM,EAAS,IAAI,GAE1B,EAAU,CAAA,EAAA,EAAA,yBAAA,AAAyB,EAAC,EAAS,OAAO,EACtD,IACA,CAAO,CAAC,EAAA,GADG,mBACmB,CAAC,CAAG,CAAA,EAElC,CAAC,CAAO,CAAC,eAAe,EAAI,EAAK,IAAI,EAAE,CACvC,CAAO,CAAC,eAAe,CAAG,EAAK,IAAI,AAAJ,EAEnC,IAAM,EAAa,KAAkD,IAA3C,EAAQ,UAAU,CAAC,mBAAmB,IAAoB,EAAQ,UAAU,CAAC,mBAAmB,EAAI,EAAA,cAAA,AAAc,GAAG,AAAQ,EAAQ,UAAU,CAAC,mBAAmB,CACvL,EAAS,KAA8C,IAAvC,EAAQ,UAAU,CAAC,eAAe,EAAoB,EAAQ,UAAU,CAAC,eAAe,EAAI,EAAA,cAAc,MAAG,EAAY,EAAQ,UAAU,CAAC,eAAe,CAcjL,MAZmB,CACf,AAWG,MAXI,CACH,KAAM,EAAA,eAAe,CAAC,SAAS,CAC/B,OAAQ,EAAS,MAAM,CACvB,KAAM,OAAO,IAAI,CAAC,MAAM,EAAK,WAAW,YACxC,CACJ,EACA,aAAc,YACV,SACA,CACJ,CACJ,CAEJ,CAKJ,CAAE,KALS,CAKF,EAAK,CAcV,MAX0B,MAAtB,EAA6B,KAAK,EAAI,EAAmB,OAAA,AAAO,EAAE,CAClE,MAAM,EAAY,cAAc,CAAC,EAAK,EAAK,CACvC,WAAY,aACZ,UAAW,EACX,UAAW,QACX,iBAAkB,CAAA,EAAA,EAAA,mBAAA,AAAmB,EAAC,oBAClC,EACA,sBACJ,EACJ,EAAG,GAED,CACV,CACJ,EACM,EAAa,MAAM,EAAY,cAAc,CAAC,KAChD,aACA,WACA,EACA,UAAW,EAAA,SAAS,CAAC,SAAS,CAC9B,YAAY,oBACZ,EACA,mBAAmB,uBACnB,0BACA,oBACA,EACA,UAAW,EAAI,SAAS,eACxB,CACJ,GAEA,GAAI,CAAC,EACD,KADQ,EACD,KAEX,GAAI,CAAe,MAAd,CAAqB,EAAS,AAA0C,GAA9C,IAAK,EAAoB,EAAW,KAAA,AAAK,EAAY,KAAK,EAAI,EAAkB,IAAI,IAAM,EAAA,eAAe,CAAC,SAAS,CAE9I,CAFgJ,KAE1I,OAAO,cAAc,CAAC,AAAI,MAAM,CAAC,kDAAkD,EAAgB,MAAd,CAAqB,EAAS,AAA2C,GAA/C,IAAK,EAAqB,EAAW,KAAA,AAAK,EAAY,KAAK,EAAI,EAAmB,IAAI,CAAA,CAAE,EAAG,oBAAqB,CACjO,MAAO,OACP,YAAY,EACZ,cAAc,CAClB,EAEA,CAAC,GACD,EAAI,SAAS,CADG,AACF,iBAAkB,EAAuB,cAAgB,EAAW,MAAM,CAAG,OAAS,EAAW,OAAO,CAAG,QAAU,OAGnI,GACA,EAAI,QADS,CACA,CAAC,gBAAiB,2DAEnC,IAAM,EAAU,CAAA,EAAA,EAAA,2BAAA,AAA2B,EAAC,EAAW,KAAK,CAAC,OAAO,EAcpE,OAbI,AAAE,CAAD,EAAkB,GACnB,EAAQ,AADgB,GAAG,GACb,CAAC,EAAA,sBAAsB,GAIrC,EAAW,YAAY,EAAK,EAAD,AAAK,SAAS,CAAC,kBAAqB,EAAD,AAAS,GAAG,CAAC,kBAAkB,AAC7F,EAAQ,GAAG,CAAC,gBAAiB,CAAA,EAAA,EAAA,qBAAA,AAAqB,EAAC,EAAW,YAAY,GAE9E,MAAM,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAa,EAChC,IAAI,SAAS,EAAW,KAAK,CAAC,IAAI,CAAE,SAChC,EACA,OAAQ,EAAW,KAAK,CAAC,MAAM,EAAI,GACvC,IACO,IACX,EAGI,EACA,MAAM,EAAe,EADT,CAGZ,MAAM,EAAO,qBAAqB,CAAC,EAAI,OAAO,CAAE,IAAI,EAAO,KAAK,CAAC,EAAA,cAAc,CAAC,aAAa,CAAE,CACvF,SAAU,CAAA,EAAG,EAAO,CAAC,EAAE,EAAA,CAAS,CAChC,KAAM,EAAA,QAAQ,CAAC,MAAM,CACrB,WAAY,CACR,cAAe,EACf,cAAe,EAAI,GAAG,AAC1B,CACJ,EAAG,GAEf,CAAE,MAAO,EAAK,CAcV,GAbI,AAAE,CAAD,YAAgB,EAAA,eAAe,EAChC,CADmC,KAC7B,EAAY,cAAc,CAAC,EAAK,EAAK,CACvC,WAAY,aACZ,UAAW,EACX,UAAW,QACX,iBAAkB,CAAA,EAAA,EAAA,mBAAA,AAAmB,EAAC,oBAClC,uBACA,CACJ,EACJ,GAIA,EAAO,MAAM,EAKjB,OAHA,MAAM,CAAA,EAAA,EAAA,YAAA,AAAY,EAAC,EAAa,EAAa,IAAI,SAAS,KAAM,CAC5D,OAAQ,GACZ,IACO,IACX,CACJ,EAEA,qCAAqC","ignoreList":[0]}