tower-studio 0.1.6 → 0.1.9

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 (174) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/build-manifest.json +3 -3
  3. package/.next/cache/.previewinfo +1 -1
  4. package/.next/cache/.rscinfo +1 -1
  5. package/.next/diagnostics/route-bundle-stats.json +37 -37
  6. package/.next/fallback-build-manifest.json +3 -3
  7. package/.next/prerender-manifest.json +3 -3
  8. package/.next/server/app/_global-error.html +1 -1
  9. package/.next/server/app/_global-error.rsc +1 -1
  10. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  11. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  12. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  13. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  14. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  15. package/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -1
  16. package/.next/server/app/_not-found/page/server-reference-manifest.json +23 -23
  17. package/.next/server/app/_not-found/page.js.nft.json +1 -1
  18. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  19. package/.next/server/app/_not-found.html +1 -1
  20. package/.next/server/app/_not-found.rsc +13 -13
  21. package/.next/server/app/_not-found.segments/_full.segment.rsc +13 -13
  22. package/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  23. package/.next/server/app/_not-found.segments/_index.segment.rsc +8 -8
  24. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  25. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  26. package/.next/server/app/_not-found.segments/_tree.segment.rsc +1 -1
  27. package/.next/server/app/api/browse-fs/route.js.nft.json +1 -1
  28. package/.next/server/app/api/files/assets/[projectId]/[filename]/route.js.nft.json +1 -1
  29. package/.next/server/app/api/git/route.js.nft.json +1 -1
  30. package/.next/server/app/api/internal/assets/[projectId]/[filename]/route.js.nft.json +1 -1
  31. package/.next/server/app/api/internal/assets/reveal/route.js.nft.json +1 -1
  32. package/.next/server/app/api/internal/assistant/chat/route.js.nft.json +1 -1
  33. package/.next/server/app/api/internal/assistant/images/route.js.nft.json +1 -1
  34. package/.next/server/app/api/internal/assistant/sessions/route.js.nft.json +1 -1
  35. package/.next/server/app/api/internal/cache/[...segments]/route.js.nft.json +1 -1
  36. package/.next/server/app/api/internal/hooks/upload/route.js.nft.json +1 -1
  37. package/.next/server/app/api/internal/terminal/[taskId]/start/route.js.nft.json +1 -1
  38. package/.next/server/app/api/tasks/[taskId]/merge/route.js.nft.json +1 -1
  39. package/.next/server/app/index.html +1 -1
  40. package/.next/server/app/index.rsc +13 -13
  41. package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  42. package/.next/server/app/index.segments/_full.segment.rsc +13 -13
  43. package/.next/server/app/index.segments/_head.segment.rsc +4 -4
  44. package/.next/server/app/index.segments/_index.segment.rsc +8 -8
  45. package/.next/server/app/index.segments/_tree.segment.rsc +1 -1
  46. package/.next/server/app/missions/page/react-loadable-manifest.json +1 -1
  47. package/.next/server/app/missions/page/server-reference-manifest.json +51 -51
  48. package/.next/server/app/missions/page.js.nft.json +1 -1
  49. package/.next/server/app/missions/page_client-reference-manifest.js +1 -1
  50. package/.next/server/app/onboarding/page/react-loadable-manifest.json +1 -1
  51. package/.next/server/app/onboarding/page/server-reference-manifest.json +23 -23
  52. package/.next/server/app/onboarding/page.js.nft.json +1 -1
  53. package/.next/server/app/onboarding/page_client-reference-manifest.js +1 -1
  54. package/.next/server/app/onboarding.html +1 -1
  55. package/.next/server/app/onboarding.rsc +15 -15
  56. package/.next/server/app/onboarding.segments/_full.segment.rsc +15 -15
  57. package/.next/server/app/onboarding.segments/_head.segment.rsc +4 -4
  58. package/.next/server/app/onboarding.segments/_index.segment.rsc +8 -8
  59. package/.next/server/app/onboarding.segments/_tree.segment.rsc +1 -1
  60. package/.next/server/app/onboarding.segments/onboarding/__PAGE__.segment.rsc +4 -4
  61. package/.next/server/app/onboarding.segments/onboarding.segment.rsc +3 -3
  62. package/.next/server/app/page/react-loadable-manifest.json +1 -1
  63. package/.next/server/app/page/server-reference-manifest.json +23 -23
  64. package/.next/server/app/page.js.nft.json +1 -1
  65. package/.next/server/app/page_client-reference-manifest.js +1 -1
  66. package/.next/server/app/settings/page/react-loadable-manifest.json +1 -1
  67. package/.next/server/app/settings/page/server-reference-manifest.json +32 -32
  68. package/.next/server/app/settings/page.js.nft.json +1 -1
  69. package/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  70. package/.next/server/app/settings.html +1 -1
  71. package/.next/server/app/settings.rsc +15 -15
  72. package/.next/server/app/settings.segments/_full.segment.rsc +15 -15
  73. package/.next/server/app/settings.segments/_head.segment.rsc +4 -4
  74. package/.next/server/app/settings.segments/_index.segment.rsc +8 -8
  75. package/.next/server/app/settings.segments/_tree.segment.rsc +1 -1
  76. package/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +4 -4
  77. package/.next/server/app/settings.segments/settings.segment.rsc +3 -3
  78. package/.next/server/app/workspaces/[workspaceId]/archive/page/react-loadable-manifest.json +1 -1
  79. package/.next/server/app/workspaces/[workspaceId]/archive/page/server-reference-manifest.json +77 -77
  80. package/.next/server/app/workspaces/[workspaceId]/archive/page.js.nft.json +1 -1
  81. package/.next/server/app/workspaces/[workspaceId]/archive/page_client-reference-manifest.js +1 -1
  82. package/.next/server/app/workspaces/[workspaceId]/assets/page/react-loadable-manifest.json +1 -1
  83. package/.next/server/app/workspaces/[workspaceId]/assets/page/server-reference-manifest.json +64 -64
  84. package/.next/server/app/workspaces/[workspaceId]/assets/page.js.nft.json +1 -1
  85. package/.next/server/app/workspaces/[workspaceId]/assets/page_client-reference-manifest.js +1 -1
  86. package/.next/server/app/workspaces/[workspaceId]/notes/page/react-loadable-manifest.json +1 -1
  87. package/.next/server/app/workspaces/[workspaceId]/notes/page/server-reference-manifest.json +55 -55
  88. package/.next/server/app/workspaces/[workspaceId]/notes/page.js.nft.json +1 -1
  89. package/.next/server/app/workspaces/[workspaceId]/notes/page_client-reference-manifest.js +1 -1
  90. package/.next/server/app/workspaces/[workspaceId]/page/react-loadable-manifest.json +1 -1
  91. package/.next/server/app/workspaces/[workspaceId]/page/server-reference-manifest.json +51 -51
  92. package/.next/server/app/workspaces/[workspaceId]/page.js.nft.json +1 -1
  93. package/.next/server/app/workspaces/[workspaceId]/page_client-reference-manifest.js +1 -1
  94. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page/react-loadable-manifest.json +1 -1
  95. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page/server-reference-manifest.json +23 -23
  96. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page.js.nft.json +1 -1
  97. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page_client-reference-manifest.js +1 -1
  98. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page/react-loadable-manifest.json +1 -1
  99. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page/server-reference-manifest.json +56 -56
  100. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page.js.nft.json +1 -1
  101. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page_client-reference-manifest.js +1 -1
  102. package/.next/server/app/workspaces/page/react-loadable-manifest.json +1 -1
  103. package/.next/server/app/workspaces/page/server-reference-manifest.json +41 -41
  104. package/.next/server/app/workspaces/page.js.nft.json +1 -1
  105. package/.next/server/app/workspaces/page_client-reference-manifest.js +1 -1
  106. package/.next/server/chunks/10ge_next_dist_esm_build_templates_app-route_13~vb_i.js +2 -2
  107. package/.next/server/chunks/[root-of-the-server]__043lk8~._.js +2 -2
  108. package/.next/server/chunks/ssr/0~.g_src_app_workspaces_[workspaceId]_tasks_[taskId]_task-page-client_tsx_0bbseig._.js +1 -1
  109. package/.next/server/chunks/ssr/[root-of-the-server]__0.8y0n9._.js +1 -1
  110. package/.next/server/chunks/ssr/[root-of-the-server]__01ws4-7._.js +1 -1
  111. package/.next/server/chunks/ssr/[root-of-the-server]__02ipahf._.js +1 -1
  112. package/.next/server/chunks/ssr/[root-of-the-server]__0bk3s4l._.js +1 -1
  113. package/.next/server/chunks/ssr/{[root-of-the-server]__0~jc3l5._.js → [root-of-the-server]__0i1tzvg._.js} +2 -2
  114. package/.next/server/chunks/ssr/{[root-of-the-server]__0hvz_0c._.js → [root-of-the-server]__0i52qt7._.js} +2 -2
  115. package/.next/server/chunks/ssr/[root-of-the-server]__0l~dc3x._.js +1 -1
  116. package/.next/server/chunks/ssr/[root-of-the-server]__0rs7pkn._.js +1 -1
  117. package/.next/server/chunks/ssr/[root-of-the-server]__0sysz2q._.js +3 -3
  118. package/.next/server/chunks/ssr/[root-of-the-server]__0y-lkvf._.js +1 -1
  119. package/.next/server/chunks/ssr/{[root-of-the-server]__0mab0km._.js → [root-of-the-server]__0yuwh~5._.js} +2 -2
  120. package/.next/server/chunks/ssr/[root-of-the-server]__12f810l._.js +1 -1
  121. package/.next/server/chunks/ssr/{tower_00.hg6u._.js → tower_0.csoof._.js} +2 -2
  122. package/.next/server/chunks/ssr/{tower_12sld1c._.js → tower_005_jvc._.js} +2 -2
  123. package/.next/server/chunks/ssr/{tower_09~lpto._.js → tower_0c8unc1._.js} +2 -2
  124. package/.next/server/chunks/ssr/{tower_0gzwyem._.js → tower_0cmuq4n._.js} +2 -2
  125. package/.next/server/chunks/ssr/tower_0ih8lcc._.js +3 -0
  126. package/.next/server/chunks/ssr/tower_0kl_bfy._.js +1 -1
  127. package/.next/server/chunks/ssr/tower_0mz4ut.._.js +1 -1
  128. package/.next/server/chunks/ssr/tower_0pcqezm._.js +1 -1
  129. package/.next/server/chunks/ssr/{tower_0vo6u9i._.js → tower_0tjo~2z._.js} +2 -2
  130. package/.next/server/chunks/ssr/tower_0wvk~r.._.js +1 -1
  131. package/.next/server/chunks/ssr/tower_10p15te._.js +1 -1
  132. package/.next/server/chunks/ssr/tower_117pzh8._.js +1 -1
  133. package/.next/server/chunks/ssr/tower_11q5_.m._.js +1 -1
  134. package/.next/server/chunks/ssr/tower_138qlx5._.js +1 -1
  135. package/.next/server/chunks/ssr/{tower_src_08t.wy-._.js → tower_src_0lq.aoc._.js} +2 -2
  136. package/.next/server/chunks/ssr/tower_src_actions_agent-actions_ts_0j.e1tn._.js +1 -1
  137. package/.next/server/chunks/ssr/tower_src_actions_file-actions_ts_0424lna._.js +1 -1
  138. package/.next/server/chunks/ssr/tower_src_app_missions_missions-client_tsx_0a9vjyr._.js +1 -1
  139. package/.next/server/chunks/ssr/tower_src_app_onboarding_page_tsx_0_3krz1._.js +1 -1
  140. package/.next/server/chunks/ssr/tower_src_app_settings_page_tsx_0vo5e-o._.js +1 -1
  141. package/.next/server/chunks/ssr/tower_src_app_workspaces_[workspaceId]_assets_assets-page-client_tsx_0zfgzhi._.js +1 -1
  142. package/.next/server/chunks/ssr/tower_src_app_workspaces_[workspaceId]_board-page-client_tsx_0kjp1u0._.js +1 -1
  143. package/.next/server/chunks/tower_0a-x6m.._.js +1 -1
  144. package/.next/server/chunks/tower_src_0..vg-t._.js +1 -1
  145. package/.next/server/instrumentation.js.nft.json +1 -1
  146. package/.next/server/middleware-build-manifest.js +3 -3
  147. package/.next/server/pages/404.html +1 -1
  148. package/.next/server/pages/500.html +1 -1
  149. package/.next/server/server-reference-manifest.js +1 -1
  150. package/.next/server/server-reference-manifest.json +198 -198
  151. package/.next/static/chunks/{0kubr70r_r2f2.js → 01499ombtjk9..js} +1 -1
  152. package/.next/static/chunks/{05j6t69jmpqju.js → 0465wja5wuj_t.js} +1 -1
  153. package/.next/static/chunks/{0_.pyr2jhdqa2.js → 04zt_ewq9gd.f.js} +2 -2
  154. package/.next/static/chunks/{0a2blrvqw8t5y.js → 07ll8eylriw_..js} +1 -1
  155. package/.next/static/chunks/{049.9ha2n6os5.js → 08kdkf9zhbx5h.js} +1 -1
  156. package/.next/static/chunks/{0z61ts2ro9_k3.js → 0_dgukndtuspa.js} +1 -1
  157. package/.next/static/chunks/{07a_xadb-3w1a.js → 0focg9l2pd5qe.js} +1 -1
  158. package/.next/static/chunks/{0-64z7pmj57~d.js → 0jod832.e8dvp.js} +1 -1
  159. package/.next/static/chunks/{00xbbu.nlx92z.js → 0o0v~cegree8o.js} +1 -1
  160. package/.next/static/chunks/{0kc-95qs2~eid.js → 0uukquowg_doj.js} +1 -1
  161. package/.next/static/chunks/{0kojsk~4uroqj.js → 0v593lcts~8.5.js} +1 -1
  162. package/.next/static/chunks/0yz33_rbgu2sz.js +1 -0
  163. package/.next/static/chunks/{0_c8duf92i~xg.js → 0~2w0fbj7o3fv.js} +1 -1
  164. package/.next/static/chunks/{0z-ecklemrfx-.js → 12p4plfwlovc5.js} +1 -1
  165. package/.next/static/chunks/{0kt2vohpgb7h6.js → 13juk.piouzom.js} +1 -1
  166. package/.next/trace +2 -2
  167. package/.next/trace-build +1 -1
  168. package/bin/tower.mjs +22 -23
  169. package/package.json +2 -2
  170. package/.next/server/chunks/ssr/tower_02he7d6._.js +0 -3
  171. package/.next/static/chunks/0ttrpz.l-v-yv.js +0 -1
  172. /package/.next/static/{6AW1vTU7iJEkEhqIH0txT → uSvLXzMcHlsrWUxtSBOMM}/_buildManifest.js +0 -0
  173. /package/.next/static/{6AW1vTU7iJEkEhqIH0txT → uSvLXzMcHlsrWUxtSBOMM}/_clientMiddlewareManifest.js +0 -0
  174. /package/.next/static/{6AW1vTU7iJEkEhqIH0txT → uSvLXzMcHlsrWUxtSBOMM}/_ssgManifest.js +0 -0
@@ -1,3 +1,3 @@
1
1
  globalThis.__RSC_MANIFEST = globalThis.__RSC_MANIFEST || {};
2
- globalThis.__RSC_MANIFEST["/workspaces/page"] = {"moduleLoading":{"prefix":"","crossOrigin":null},"clientModules":{"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/layout-router.js <module evaluation>":{"id":193331,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/layout-router.js":{"id":193331,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/render-from-template-context.js <module evaluation>":{"id":763751,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/render-from-template-context.js":{"id":763751,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-page.js <module evaluation>":{"id":203958,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-page.js":{"id":203958,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-segment.js <module evaluation>":{"id":236586,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-segment.js":{"id":236586,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/http-access-fallback/error-boundary.js <module evaluation>":{"id":646162,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/http-access-fallback/error-boundary.js":{"id":646162,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/framework/boundary-components.js <module evaluation>":{"id":322510,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/framework/boundary-components.js":{"id":322510,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/metadata/generate/icon-mark.js <module evaluation>":{"id":13413,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/metadata/generate/icon-mark.js":{"id":13413,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/ui/tooltip.tsx <module evaluation>":{"id":814329,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/ui/tooltip.tsx":{"id":814329,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/layout/layout-client.tsx <module evaluation>":{"id":632612,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/layout/layout-client.tsx":{"id":632612,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/lib/i18n.tsx <module evaluation>":{"id":349369,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/lib/i18n.tsx":{"id":349369,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/providers/theme-provider.tsx <module evaluation>":{"id":574117,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/providers/theme-provider.tsx":{"id":574117,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/ui/sonner.tsx <module evaluation>":{"id":764878,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/src/components/ui/sonner.tsx":{"id":764878,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error.js <module evaluation>":{"id":498737,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error.js":{"id":498737,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/0a2blrvqw8t5y.js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0kc-95qs2~eid.js"],"async":false}},"ssrModuleMapping":{"193331":{"*":{"id":863321,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"763751":{"*":{"id":679804,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"203958":{"*":{"id":471842,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"236586":{"*":{"id":740779,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"646162":{"*":{"id":728230,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"322510":{"*":{"id":776117,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"13413":{"*":{"id":686930,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"814329":{"*":{"id":348160,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"632612":{"*":{"id":916881,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"349369":{"*":{"id":282980,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"574117":{"*":{"id":40298,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"764878":{"*":{"id":646745,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"498737":{"*":{"id":255408,"name":"*","chunks":["server/chunks/ssr/tower_0vo6u9i._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0~jc3l5._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js","server/chunks/ssr/10ge_next_dist_client_components_0eil7-a._.js"],"async":false}}},"edgeSSRModuleMapping":{},"rscModuleMapping":{"193331":{"*":{"id":621383,"name":"*","chunks":[],"async":false}},"763751":{"*":{"id":194590,"name":"*","chunks":[],"async":false}},"203958":{"*":{"id":582699,"name":"*","chunks":[],"async":false}},"236586":{"*":{"id":556338,"name":"*","chunks":[],"async":false}},"646162":{"*":{"id":991317,"name":"*","chunks":[],"async":false}},"322510":{"*":{"id":962511,"name":"*","chunks":[],"async":false}},"13413":{"*":{"id":747326,"name":"*","chunks":[],"async":false}},"814329":{"*":{"id":455508,"name":"*","chunks":[],"async":false}},"632612":{"*":{"id":648047,"name":"*","chunks":[],"async":false}},"349369":{"*":{"id":508373,"name":"*","chunks":[],"async":false}},"574117":{"*":{"id":589401,"name":"*","chunks":[],"async":false}},"764878":{"*":{"id":145764,"name":"*","chunks":[],"async":false}},"498737":{"*":{"id":594865,"name":"*","chunks":[],"async":false}}},"edgeRscModuleMapping":{},"entryCSSFiles":{"[project]/tower/src/app/layout":[{"path":"static/chunks/0neevhl_o1ozu.css","inlined":false},{"path":"static/chunks/0drgc-oztq6o-.css","inlined":false}],"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error":[{"path":"static/chunks/0neevhl_o1ozu.css","inlined":false},{"path":"static/chunks/0drgc-oztq6o-.css","inlined":false}]},"entryJSFiles":{"[project]/tower/src/app/layout":["static/chunks/0uqimvsni_op~.js","static/chunks/05~v02mkan5z..js","static/chunks/0t-gr6j-c65qb.js","static/chunks/0abtpeymj-58i.js","static/chunks/0wt3kws~_yr8z.js","static/chunks/0a2blrvqw8t5y.js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0kc-95qs2~eid.js"],"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error":["static/chunks/0uqimvsni_op~.js","static/chunks/05~v02mkan5z..js","static/chunks/0t-gr6j-c65qb.js","static/chunks/0abtpeymj-58i.js","static/chunks/0wt3kws~_yr8z.js","static/chunks/0a2blrvqw8t5y.js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0kc-95qs2~eid.js"]}};
2
+ globalThis.__RSC_MANIFEST["/workspaces/page"] = {"moduleLoading":{"prefix":"","crossOrigin":null},"clientModules":{"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/layout-router.js <module evaluation>":{"id":193331,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/layout-router.js":{"id":193331,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/render-from-template-context.js <module evaluation>":{"id":763751,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/render-from-template-context.js":{"id":763751,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-page.js <module evaluation>":{"id":203958,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-page.js":{"id":203958,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-segment.js <module evaluation>":{"id":236586,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/client-segment.js":{"id":236586,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/http-access-fallback/error-boundary.js <module evaluation>":{"id":646162,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/client/components/http-access-fallback/error-boundary.js":{"id":646162,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/framework/boundary-components.js <module evaluation>":{"id":322510,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/framework/boundary-components.js":{"id":322510,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/metadata/generate/icon-mark.js <module evaluation>":{"id":13413,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/esm/lib/metadata/generate/icon-mark.js":{"id":13413,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/ui/tooltip.tsx <module evaluation>":{"id":814329,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/ui/tooltip.tsx":{"id":814329,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/layout/layout-client.tsx <module evaluation>":{"id":632612,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/layout/layout-client.tsx":{"id":632612,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/lib/i18n.tsx <module evaluation>":{"id":349369,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/lib/i18n.tsx":{"id":349369,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/providers/theme-provider.tsx <module evaluation>":{"id":574117,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/providers/theme-provider.tsx":{"id":574117,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/ui/sonner.tsx <module evaluation>":{"id":764878,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/src/components/ui/sonner.tsx":{"id":764878,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error.js <module evaluation>":{"id":498737,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false},"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error.js":{"id":498737,"name":"*","chunks":["/_next/static/chunks/0uqimvsni_op~.js","/_next/static/chunks/05~v02mkan5z..js","/_next/static/chunks/0t-gr6j-c65qb.js","/_next/static/chunks/0abtpeymj-58i.js","/_next/static/chunks/0wt3kws~_yr8z.js","/_next/static/chunks/07ll8eylriw_..js","/_next/static/chunks/151wr~6x8aclx.js","/_next/static/chunks/0lvd52mjiit6s.js","/_next/static/chunks/05-b9qqm3av9~.js","/_next/static/chunks/0z7bwntvfhxzi.js","/_next/static/chunks/0uukquowg_doj.js"],"async":false}},"ssrModuleMapping":{"193331":{"*":{"id":863321,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"763751":{"*":{"id":679804,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"203958":{"*":{"id":471842,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"236586":{"*":{"id":740779,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"646162":{"*":{"id":728230,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"322510":{"*":{"id":776117,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"13413":{"*":{"id":686930,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"814329":{"*":{"id":348160,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"632612":{"*":{"id":916881,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"349369":{"*":{"id":282980,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"574117":{"*":{"id":40298,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"764878":{"*":{"id":646745,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js"],"async":false}},"498737":{"*":{"id":255408,"name":"*","chunks":["server/chunks/ssr/tower_0tjo~2z._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0i1tzvg._.js","server/chunks/ssr/tower_0-nwtka._.js","server/chunks/ssr/tower_035l~qv._.js","server/chunks/ssr/tower_01szasw._.js","server/chunks/ssr/tower_10t13p4._.js","server/chunks/ssr/10ge_next_dist_01n~t8z._.js","server/chunks/ssr/0kjx__pnpm_0g9g8h6._.js","server/chunks/ssr/tower_03jazku._.js","server/chunks/ssr/0kjx__pnpm_0wrn.h9._.js","server/chunks/ssr/10ge_next_dist_0~ti7jc._.js","server/chunks/ssr/tower_0kl_bfy._.js","server/chunks/ssr/10ge_next_dist_client_components_0eil7-a._.js"],"async":false}}},"edgeSSRModuleMapping":{},"rscModuleMapping":{"193331":{"*":{"id":621383,"name":"*","chunks":[],"async":false}},"763751":{"*":{"id":194590,"name":"*","chunks":[],"async":false}},"203958":{"*":{"id":582699,"name":"*","chunks":[],"async":false}},"236586":{"*":{"id":556338,"name":"*","chunks":[],"async":false}},"646162":{"*":{"id":991317,"name":"*","chunks":[],"async":false}},"322510":{"*":{"id":962511,"name":"*","chunks":[],"async":false}},"13413":{"*":{"id":747326,"name":"*","chunks":[],"async":false}},"814329":{"*":{"id":455508,"name":"*","chunks":[],"async":false}},"632612":{"*":{"id":648047,"name":"*","chunks":[],"async":false}},"349369":{"*":{"id":508373,"name":"*","chunks":[],"async":false}},"574117":{"*":{"id":589401,"name":"*","chunks":[],"async":false}},"764878":{"*":{"id":145764,"name":"*","chunks":[],"async":false}},"498737":{"*":{"id":594865,"name":"*","chunks":[],"async":false}}},"edgeRscModuleMapping":{},"entryCSSFiles":{"[project]/tower/src/app/layout":[{"path":"static/chunks/0neevhl_o1ozu.css","inlined":false},{"path":"static/chunks/0drgc-oztq6o-.css","inlined":false}],"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error":[{"path":"static/chunks/0neevhl_o1ozu.css","inlined":false},{"path":"static/chunks/0drgc-oztq6o-.css","inlined":false}]},"entryJSFiles":{"[project]/tower/src/app/layout":["static/chunks/0uqimvsni_op~.js","static/chunks/05~v02mkan5z..js","static/chunks/0t-gr6j-c65qb.js","static/chunks/0abtpeymj-58i.js","static/chunks/0wt3kws~_yr8z.js","static/chunks/07ll8eylriw_..js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0uukquowg_doj.js"],"[project]/tower/node_modules/.pnpm/next@16.2.1_@babel+core@7.29.0_@playwright+test@1.58.2_react-dom@19.2.4_react@19.2.4__react@19.2.4/node_modules/next/dist/client/components/builtin/global-error":["static/chunks/0uqimvsni_op~.js","static/chunks/05~v02mkan5z..js","static/chunks/0t-gr6j-c65qb.js","static/chunks/0abtpeymj-58i.js","static/chunks/0wt3kws~_yr8z.js","static/chunks/07ll8eylriw_..js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0uukquowg_doj.js"]}};
3
3
 
@@ -1,4 +1,4 @@
1
- module.exports=[54500,e=>{"use strict";var t=e.i(958699),a=e.i(953193),r=e.i(314093),i=e.i(159515),n=e.i(952192),s=e.i(939747),o=e.i(348399),d=e.i(887426),l=e.i(626524),c=e.i(479201),u=e.i(336951),p=e.i(546302),w=e.i(431732),h=e.i(899284),f=e.i(104600),v=e.i(193695);e.i(792325);var E=e.i(27732),b=e.i(298600),g=e.i(48671),k=e.i(985726),m=e.i(604719),R=e.i(647085),A=e.i(356776),P=e.i(997179),N=e.i(112310),y=e.i(741550),I=e.i(451724);class x{providers=new Map;register(e){this.providers.set(e.name,e)}get(e){return this.providers.get(e)}getAll(){return Array.from(this.providers.values())}getCliAdapter(e){return this.providers.get(e)?.cli?.adapter??null}getQueryAdapter(e,t){let a=this.providers.get(e);return a?"api"===t?a.api?.adapter??null:a.cliQuery?.adapter??null:null}getAllowedCommands(){let e=[];for(let t of this.providers.values())t.cli?.command&&e.push(t.cli.command);return e}async getAvailableProviders(){let e=[];for(let t of this.providers.values()){let a=!!t.cli&&await t.cli.adapter.isAvailable(),r=a&&t.cli?await t.cli.adapter.getVersion():null,i=!!t.api&&!!process.env[t.api.keyEnvVar],n=!!t.api&&i;e.push({name:t.name,displayName:t.displayName,cli:{available:a,version:r},api:{available:n,keyConfigured:i}})}return e}}var C=e.i(47533);let S=globalThis;if(!S.__providerRegistry){let e=new x;e.register({name:"claude",displayName:"Claude Code",agentFieldValue:"CLAUDE_CODE",cli:{command:"claude",adapter:new C.ClaudeCliAdapter},models:{cli:["sonnet","opus","haiku","claude-sonnet-4-6","claude-opus-4-6","claude-haiku-4-5-20251001"],api:[]}}),S.__providerRegistry=e}let T=S.__providerRegistry;class j extends Error{code;provider;constructor(e,t,a){super(a),this.code=e,this.provider=t,this.name="AiProviderError"}}async function D(e){return R.db.aiCapabilityConfig.findUnique({where:{slot:e}})}async function O(e){let t=await D(e),a=t?.provider??"claude",r=t?.model??void 0,i=T.get(a);if(!i)throw new j("CLI_NOT_FOUND",a,`Provider "${a}" 未注册`);let n=i.cli?.adapter;if(!n)throw new j("UNSUPPORTED_MODE",a,`Provider "${a}" 不支持 CLI 模式`);return{adapter:n,provider:i,model:r}}var U=e.i(924868),_=e.i(446786),F=e.i(814747),L=e.i(77129);let M=y.logger.create("agent-actions"),q=(0,F.join)((0,_.tmpdir)(),"tower-signals");async function B(e,t){try{await (0,U.mkdir)(q,{recursive:!0,mode:448}),await (0,U.writeFile)((0,F.join)(q,`exit-${e}`),String(t),{mode:384})}catch{}}function $(e,t){try{return JSON.parse(e)}catch{throw Error(`CLI Profile ${t} 格式损坏,请在 Settings 中修复`)}}async function V(e,t){let a=await R.db.taskMessage.create({data:{role:"USER",content:t,taskId:e}});return(0,A.revalidatePath)("/workspaces"),{userMessage:a}}async function G(e){return R.db.taskMessage.findMany({where:{taskId:e},orderBy:{createdAt:"asc"}})}async function H(e,t="CLAUDE_CODE",a,r){let i=await R.db.taskExecution.create({data:{taskId:e,agent:t,status:"RUNNING",startedAt:new Date,worktreePath:a??null,worktreeBranch:r??null}});return await R.db.task.update({where:{id:e},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces"),i}async function K(e,t="FAILED"){let a=await R.db.taskExecution.update({where:{id:e},data:{status:t,endedAt:new Date}});return(0,A.revalidatePath)("/workspaces"),a}async function W(t){let{destroySession:a,getSession:r}=await e.A(229073),i=r(t),n=i?.getBuffer()??"",s=await R.db.taskExecution.findFirst({where:{taskId:t,status:"RUNNING"},orderBy:{createdAt:"desc"}}),o=await R.db.task.findUnique({where:{id:t},include:{project:{select:{localPath:!0}}}});if(a(t),s){await R.db.taskExecution.update({where:{id:s.id},data:{status:"COMPLETED",endedAt:new Date}}),await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}});let a=s.worktreePath||o?.project?.localPath||null,{captureExecutionSummary:r}=await e.A(274428);await r(s.id,t,0,n,a)}(0,A.revalidatePath)("/workspaces")}async function z(e){return R.db.taskExecution.findMany({where:{taskId:e},orderBy:{createdAt:"desc"},include:{insightNote:{select:{id:!0,title:!0,content:!0}}}})}async function X(t,a){let r=await R.db.task.findUnique({where:{id:t},include:{project:!0}});if(!r)throw Error("Task not found");if(!r.project?.localPath)throw Error("Project has no local path configured");await R.db.taskExecution.updateMany({where:{taskId:t,status:"RUNNING",NOT:{sessionId:a}},data:{status:"FAILED",endedAt:new Date}});let i=await R.db.taskExecution.findFirst({where:{taskId:t,sessionId:a},orderBy:{createdAt:"desc"}});if(!i)throw Error("Previous execution not found");let n=i.worktreePath??r.project.localPath,s=r.subPath?(0,F.join)(n,r.subPath):n,o=await R.db.cliProfile.findFirst({where:{isDefault:!0}});if(!o)throw Error("No default CLI profile found — run seed first");let d=$(o.baseArgs,"baseArgs"),l=$(o.envVars,"envVars"),c=await (0,I.readConfigValue)("terminal.idleTimeoutSec",180),{adapter:u}=await O("terminal"),p=u.buildEnvOverrides({taskId:t,taskTitle:r.title,apiUrl:`http://localhost:${process.env.PORT||"3000"}`,callbackUrl:i.callbackUrl??void 0}),w=await R.db.taskExecution.update({where:{id:i.id},data:{status:"RUNNING",endedAt:null}});await R.db.task.update({where:{id:t},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces");let h=await (0,I.readConfigValue)("onboarding.username",""),f=u.buildSpawnArgs({taskId:t,prompt:"",cwd:s,resumeSessionId:a,profileArgs:[...d,...h?["--append-system-prompt",`The user's name is ${h}.`]:[]],profileEnvVars:l,envOverrides:p}),v=/no conversation found with session id|unknown session|session .* not found/i;return(0,N.createSession)(t,f.command,f.args,s,()=>{},async n=>{await B(t,n);let s=await R.db.taskExecution.findUnique({where:{id:w.id}});if(s?.status!=="RUNNING")return;let{getSession:o}=await e.A(229073),d=o(t),l=d?.getBuffer()??"";if(0!==n&&v.test(l)){M.info("Session resume failed — retrying with fresh execution",{taskId:t,previousSessionId:a}),await R.db.taskExecution.update({where:{id:w.id},data:{status:"FAILED",endedAt:new Date}}).catch(()=>{});try{await J(t,r.title)}catch(e){M.error("Fresh execution retry also failed",e,{taskId:t})}return}await R.db.taskExecution.update({where:{id:w.id},data:{status:0===n?"COMPLETED":"FAILED",endedAt:new Date}}).catch(()=>{});let c=i.worktreePath||r.project.localPath,{captureExecutionSummary:u}=await e.A(274428);await u(w.id,t,n,l,c);let{dispatchTaskCompletionEvent:p}=await e.A(6206);await p({taskId:t,taskTitle:r.title,status:0===n?"COMPLETED":"FAILED",executionId:w.id,workspaceId:r.project.workspaceId}),0===n&&await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}}).catch(()=>{})},f.env,void 0,1e3*c),{executionId:w.id,worktreePath:i.worktreePath??n??null}}async function Q(t){let a=await R.db.task.findUnique({where:{id:t},include:{project:!0}});if(!a)throw Error("Task not found");if(!a.project?.localPath)throw Error("Project has no local path configured");let r=await R.db.taskExecution.findFirst({where:{taskId:t},orderBy:{createdAt:"desc"}}),{destroySession:i}=await e.A(229073);i(t),await R.db.taskExecution.updateMany({where:{taskId:t,status:"RUNNING"},data:{status:"FAILED",endedAt:new Date}});let n=r?.worktreePath??a.project.localPath,s=a.subPath?(0,F.join)(n,a.subPath):n,o=await R.db.cliProfile.findFirst({where:{isDefault:!0}});if(!o)throw Error("No default CLI profile found — run seed first");let d=$(o.baseArgs,"baseArgs"),l=$(o.envVars,"envVars"),c=await (0,I.readConfigValue)("terminal.idleTimeoutSec",180),{adapter:u,provider:p}=await O("terminal"),w=u.buildEnvOverrides({taskId:t,taskTitle:a.title,apiUrl:`http://localhost:${process.env.PORT||"3000"}`}),h=await R.db.taskExecution.create({data:{taskId:t,agent:p.agentFieldValue,status:"RUNNING",startedAt:new Date,worktreePath:r?.worktreePath??null,worktreeBranch:r?.worktreeBranch??null}});await R.db.task.update({where:{id:t},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces");let f=await (0,I.readConfigValue)("onboarding.username",""),v=u.buildSpawnArgs({taskId:t,prompt:"",cwd:s,continueLatest:!0,profileArgs:[...d,...f?["--append-system-prompt",`The user's name is ${f}.`]:[]],profileEnvVars:l,envOverrides:w});return(0,N.createSession)(t,v.command,v.args,s,()=>{},async i=>{await B(t,i);let n=await R.db.taskExecution.findUnique({where:{id:h.id}});if(n?.status!=="RUNNING")return;let{getSession:s}=await e.A(229073),o=s(t),d=o?.getBuffer()??"";await R.db.taskExecution.update({where:{id:h.id},data:{status:0===i?"COMPLETED":"FAILED",endedAt:new Date}}).catch(()=>{});let l=r?.worktreePath||a.project.localPath,{captureExecutionSummary:c}=await e.A(274428);await c(h.id,t,i,d,l);let{dispatchTaskCompletionEvent:u}=await e.A(6206);await u({taskId:t,taskTitle:a.title,status:0===i?"COMPLETED":"FAILED",executionId:h.id,workspaceId:a.project.workspaceId}),0===i&&await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}}).catch(()=>{})},v.env,void 0,1e3*c),{executionId:h.id,worktreePath:r?.worktreePath??n??null}}async function J(t,a,r,i){let n,s,o=await R.db.task.findUnique({where:{id:t},include:{project:!0}});if(!o)throw Error("Task not found");if(!o.project?.localPath)throw Error("Project has no local path configured");let d=await (0,I.readConfigValue)("system.maxConcurrentExecutions",20);if(await R.db.taskExecution.count({where:{status:"RUNNING"}})>=d)throw Error(`已达并发上限(${d}),请等待其他任务完成后再启动`);let l=await R.db.cliProfile.findFirst({where:{isDefault:!0}});if(!l)throw Error("No default CLI profile found — run seed first");let c=$(l.baseArgs,"baseArgs"),u=$(l.envVars,"envVars"),p=await (0,I.readConfigValue)("terminal.idleTimeoutSec",180),{adapter:w,provider:h,model:f}=await O("terminal");await R.db.taskExecution.updateMany({where:{taskId:t,status:"RUNNING"},data:{status:"FAILED",endedAt:new Date}}),"IN_PROGRESS"!==o.status&&(await R.db.task.update({where:{id:t},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces"));let v=await R.db.taskMessage.findMany({where:{taskId:t},orderBy:{createdAt:"desc"},take:10}),E=[`Task: ${o.title}`,o.description?`Description: ${o.description}`:"",v.length>0?`Recent conversation:
2
- ${v.reverse().map(e=>`${e.role}: ${e.content}`).join("\n")}`:"",a.trim()?`User message: ${a}`:""].filter(Boolean).join("\n\n"),b=r??o.promptId;if(b){let e=await R.db.agentPrompt.findUnique({where:{id:b}});e?.content&&(s=await (0,U.mkdtemp)((0,F.join)((0,_.tmpdir)(),"tower-pty-")),n=(0,F.join)(s,"instructions.md"),await (0,U.writeFile)(n,e.content,"utf-8"))}let g=null,k=null;if(o.baseBranch&&o.project.localPath){let{worktreePath:e,worktreeBranch:a}=await (0,P.createWorktree)(o.project.localPath,t,o.baseBranch);g=e,k=a}let m=g??o.project.localPath,y=o.subPath?(0,F.join)(m,o.subPath):m,x=await R.db.taskExecution.create({data:{taskId:t,agent:h.agentFieldValue,status:"RUNNING",startedAt:new Date,worktreePath:g??null,worktreeBranch:k??null,callbackUrl:i??null}});if(o.project.localPath)try{let t,{execFileSync:a}=await e.A(144264);(t=g&&o.baseBranch?a("git",["merge-base",o.baseBranch,"HEAD"],{cwd:g,encoding:"utf-8",timeout:5e3}).trim():a("git",["rev-parse","HEAD"],{cwd:o.project.localPath,encoding:"utf-8",timeout:5e3}).trim())&&await R.db.taskExecution.update({where:{id:x.id},data:{forkCommit:t}})}catch{}let C="";if(n){let{readFile:t}=await e.A(260815);C+=await t(n,"utf-8")}let S=await (0,I.readConfigValue)("onboarding.username","");S&&(C+=(C?"\n":"")+`The user's name is ${S}.`);let T=w.buildSpawnArgs({taskId:t,prompt:E,cwd:y,profileArgs:[...c,...C?["--append-system-prompt",C]:[],...f?["--model",f]:[]],profileEnvVars:u,envOverrides:w.buildEnvOverrides({taskId:t,taskTitle:o.title,apiUrl:`http://localhost:${process.env.PORT||"3000"}`,callbackUrl:i??void 0})});return(0,N.createSession)(t,T.command,T.args,y,()=>{},async a=>{await B(t,a);let r=await R.db.taskExecution.findUnique({where:{id:x.id}});if(r?.status!=="RUNNING")return;let{getSession:i}=await e.A(229073),n=i(t),d=n?.getBuffer()??"";await R.db.taskExecution.update({where:{id:x.id},data:{status:0===a?"COMPLETED":"FAILED",endedAt:new Date}}).catch(e=>{M.error("Failed to update execution status",e)});let l=g||o.project.localPath,{captureExecutionSummary:c}=await e.A(274428);await c(x.id,t,a,d,l);let{dispatchTaskCompletionEvent:u}=await e.A(6206);await u({taskId:t,taskTitle:o.title,status:0===a?"COMPLETED":"FAILED",executionId:x.id,workspaceId:o.project.workspaceId}),0===a&&await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}}).catch(e=>{M.error("Failed to update task status",e)}),s&&await (0,U.rm)(s,{recursive:!0,force:!0}).catch(()=>{})},T.env,void 0,1e3*p),{executionId:x.id,worktreePath:g??m??null}}async function Z(){return(await R.db.taskExecution.findMany({where:{status:"RUNNING"},orderBy:{startedAt:"asc"},include:{task:{include:{project:{include:{workspace:!0}}}}}})).map(e=>({executionId:e.id,taskId:e.taskId,taskTitle:e.task.title,projectId:e.task.project.id,projectName:e.task.project.name,projectAlias:e.task.project.alias,projectLocalPath:e.task.project.localPath,workspaceId:e.task.project.workspace.id,workspaceName:e.task.project.workspace.name,worktreePath:e.worktreePath,startedAt:e.startedAt?.toISOString()??null}))}(0,L.ensureServerEntryExports)([V,G,H,K,W,z,X,Q,J,Z]),(0,m.registerServerReference)(V,"6027147e4d1f3f60722842600ed13315efa1344a4d",null),(0,m.registerServerReference)(G,"406d2d84388af8c8869d391c1f1ce1efccb70851bc",null),(0,m.registerServerReference)(H,"78abc5b6471bdb19972bc8eae3900be1ca14db53a4",null),(0,m.registerServerReference)(K,"60b0ba47f5651c401e6b1d244a475fd9d3d103411f",null),(0,m.registerServerReference)(W,"40b0be328179f86f28b11332f6259165af2ee8a56c",null),(0,m.registerServerReference)(z,"4072d632192adf6a43f929ae7adc0a98eb7e20c0e2",null),(0,m.registerServerReference)(X,"60448ee810344f12b03a536b18e82bfe384bfce12b",null),(0,m.registerServerReference)(Q,"4024f6d9f41e09e98a12ce95afe006665fa0a81c7d",null),(0,m.registerServerReference)(J,"78c11d994f9eece26b847bf3139b779d97ec363c54",null),(0,m.registerServerReference)(Z,"00752bfe863d97d0ed6a191b4afceab5c641608e58",null);let Y=g.z.object({prompt:g.z.string().optional().default("")});async function ee(e,{params:t}){let a=(0,k.requireLocalhost)(e);if(a)return a;let{taskId:r}=await t,i=(0,k.validateTaskId)(r);if(i)return i;try{let t=await e.json(),a=Y.safeParse(t);if(!a.success)return b.NextResponse.json({error:"Invalid body"},{status:400});let i=await J(r,a.data.prompt);return b.NextResponse.json(i)}catch(t){let e=t instanceof Error?t.message:String(t);return b.NextResponse.json({error:e},{status:500})}}e.s(["POST",0,ee,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],798207);var et=e.i(798207);let ea=new t.AppRouteRouteModule({definition:{kind:a.RouteKind.APP_ROUTE,page:"/api/internal/terminal/[taskId]/start/route",pathname:"/api/internal/terminal/[taskId]/start",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/tower/src/app/api/internal/terminal/[taskId]/start/route.ts",nextConfigOutput:"",userland:et}),{workAsyncStorage:er,workUnitAsyncStorage:ei,serverHooks:en}=ea;async function es(e,t,r){r.requestMeta&&(0,i.setRequestMeta)(e,r.requestMeta),ea.isDev&&(0,i.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let b="/api/internal/terminal/[taskId]/start/route";b=b.replace(/\/index$/,"")||"/";let g=await ea.prepare(e,t,{srcPage:b,multiZoneDraftMode:!1});if(!g)return t.statusCode=400,t.end("Bad Request"),null==r.waitUntil||r.waitUntil.call(r,Promise.resolve()),null;let{buildId:k,params:m,nextConfig:R,parsedUrl:A,isDraftMode:P,prerenderManifest:N,routerServerContext:y,isOnDemandRevalidate:I,revalidateOnlyGenerated:x,resolvedPathname:C,clientReferenceManifest:S,serverActionsManifest:T}=g,j=(0,o.normalizeAppPath)(b),D=!!(N.dynamicRoutes[j]||N.routes[C]),O=async()=>((null==y?void 0:y.render404)?await y.render404(e,t,A,!1):t.end("This page could not be found"),null);if(D&&!P){let e=!!N.routes[C],t=N.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(R.adapterPath)return await O();throw new v.NoFallbackError}}let U=null;!D||ea.isDev||P||(U="/index"===(U=C)?"/":U);let _=!0===ea.isDev||!D,F=D&&!_;T&&S&&(0,s.setManifestsSingleton)({page:b,clientReferenceManifest:S,serverActionsManifest:T});let L=e.method||"GET",M=(0,n.getTracer)(),q=M.getActiveScopeSpan(),B=!!(null==y?void 0:y.isWrappedByNextServer),$=!!(0,i.getRequestMeta)(e,"minimalMode"),V=(0,i.getRequestMeta)(e,"incrementalCache")||await ea.getIncrementalCache(e,R,N,$);null==V||V.resetRequestCache(),globalThis.__incrementalCache=V;let G={params:m,previewProps:N.preview,renderOpts:{experimental:{authInterrupts:!!R.experimental.authInterrupts},cacheComponents:!!R.cacheComponents,supportsDynamicResponse:_,incrementalCache:V,cacheLifeProfiles:R.cacheLife,waitUntil:r.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,r,i)=>ea.onRequestError(e,t,r,i,y)},sharedContext:{buildId:k}},H=new d.NodeNextRequest(e),K=new d.NodeNextResponse(t),W=l.NextRequestAdapter.fromNodeNextRequest(H,(0,l.signalFromNodeResponse)(t));try{let i,s=async e=>ea.handle(W,G).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=M.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==c.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let r=a.get("next.route");if(r){let t=`${L} ${r}`;e.setAttributes({"next.route":r,"http.route":r,"next.span_name":t}),e.updateName(t),i&&i!==e&&(i.setAttribute("http.route",r),i.updateName(t))}else e.updateName(`${L} ${b}`)}),o=async i=>{var n,o;let d=async({previousCacheEntry:a})=>{try{if(!$&&I&&x&&!a)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await s(i);e.fetchMetrics=G.renderOpts.fetchMetrics;let o=G.renderOpts.pendingWaitUntil;o&&r.waitUntil&&(r.waitUntil(o),o=void 0);let d=G.renderOpts.collectedTags;if(!D)return await (0,p.sendResponse)(H,K,n,G.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,w.toNodeOutgoingHttpHeaders)(n.headers);d&&(t[f.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==G.renderOpts.collectedRevalidate&&!(G.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,r=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:E.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:r}}}}catch(t){throw(null==a?void 0:a.isStale)&&await ea.onRequestError(e,t,{routerKind:"App Router",routePath:b,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:F,isOnDemandRevalidate:I})},!1,y),t}},l=await ea.handleResponse({req:e,nextConfig:R,cacheKey:U,routeKind:a.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:N,isRoutePPREnabled:!1,isOnDemandRevalidate:I,revalidateOnlyGenerated:x,responseGenerator:d,waitUntil:r.waitUntil,isMinimalMode:$});if(!D)return null;if((null==l||null==(n=l.value)?void 0:n.kind)!==E.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==l||null==(o=l.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});$||t.setHeader("x-nextjs-cache",I?"REVALIDATED":l.isMiss?"MISS":l.isStale?"STALE":"HIT"),P&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,w.fromNodeOutgoingHttpHeaders)(l.value.headers);return $&&D||c.delete(f.NEXT_CACHE_TAGS_HEADER),!l.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,h.getCacheControlHeader)(l.cacheControl)),await (0,p.sendResponse)(H,K,new Response(l.value.body,{headers:c,status:l.value.status||200})),null};B&&q?await o(q):(i=M.getActiveScopeSpan(),await M.withPropagatedContext(e.headers,()=>M.trace(c.BaseServerSpan.handleRequest,{spanName:`${L} ${b}`,kind:n.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!B))}catch(t){if(t instanceof v.NoFallbackError||await ea.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:F,isOnDemandRevalidate:I})},!1,y),D)throw t;return await (0,p.sendResponse)(H,K,new Response(null,{status:500})),null}}e.s(["handler",0,es,"patchFetch",0,function(){return(0,r.patchFetch)({workAsyncStorage:er,workUnitAsyncStorage:ei})},"routeModule",0,ea,"serverHooks",0,en,"workAsyncStorage",0,er,"workUnitAsyncStorage",0,ei],54500)}];
1
+ module.exports=[54500,e=>{"use strict";var t=e.i(958699),a=e.i(953193),r=e.i(314093),i=e.i(159515),n=e.i(952192),s=e.i(939747),o=e.i(348399),d=e.i(887426),l=e.i(626524),c=e.i(479201),u=e.i(336951),p=e.i(546302),w=e.i(431732),h=e.i(899284),f=e.i(104600),v=e.i(193695);e.i(792325);var E=e.i(27732),g=e.i(298600),k=e.i(48671),b=e.i(985726),m=e.i(604719),R=e.i(647085),A=e.i(356776),P=e.i(997179),N=e.i(112310),y=e.i(741550),I=e.i(451724);class x{providers=new Map;register(e){this.providers.set(e.name,e)}get(e){return this.providers.get(e)}getAll(){return Array.from(this.providers.values())}getCliAdapter(e){return this.providers.get(e)?.cli?.adapter??null}getQueryAdapter(e,t){let a=this.providers.get(e);return a?"api"===t?a.api?.adapter??null:a.cliQuery?.adapter??null:null}getAllowedCommands(){let e=[];for(let t of this.providers.values())t.cli?.command&&e.push(t.cli.command);return e}async getAvailableProviders(){let e=[];for(let t of this.providers.values()){let a=!!t.cli&&await t.cli.adapter.isAvailable(),r=a&&t.cli?await t.cli.adapter.getVersion():null,i=!!t.api&&!!process.env[t.api.keyEnvVar],n=!!t.api&&i;e.push({name:t.name,displayName:t.displayName,cli:{available:a,version:r},api:{available:n,keyConfigured:i}})}return e}}var C=e.i(47533);let S=globalThis;if(!S.__providerRegistry){let e=new x;e.register({name:"claude",displayName:"Claude Code",agentFieldValue:"CLAUDE_CODE",cli:{command:"claude",adapter:new C.ClaudeCliAdapter},models:{cli:["sonnet","opus","haiku","claude-sonnet-4-6","claude-opus-4-6","claude-haiku-4-5-20251001"],api:[]}}),S.__providerRegistry=e}let T=S.__providerRegistry;class j extends Error{code;provider;constructor(e,t,a){super(a),this.code=e,this.provider=t,this.name="AiProviderError"}}async function D(e){return R.db.aiCapabilityConfig.findUnique({where:{slot:e}})}async function O(e){let t=await D(e),a=t?.provider??"claude",r=t?.model??void 0,i=T.get(a);if(!i)throw new j("CLI_NOT_FOUND",a,`Provider "${a}" 未注册`);let n=i.cli?.adapter;if(!n)throw new j("UNSUPPORTED_MODE",a,`Provider "${a}" 不支持 CLI 模式`);return{adapter:n,provider:i,model:r}}var U=e.i(924868),_=e.i(446786),F=e.i(814747),L=e.i(77129);let M=y.logger.create("agent-actions"),q=(0,F.join)((0,_.tmpdir)(),"tower-signals");async function B(e,t){try{await (0,U.mkdir)(q,{recursive:!0,mode:448}),await (0,U.writeFile)((0,F.join)(q,`exit-${e}`),String(t),{mode:384})}catch{}}function $(e,t){try{return JSON.parse(e)}catch{throw Error(`CLI Profile ${t} 格式损坏,请在 Settings 中修复`)}}async function V(e,t){let a=await R.db.taskMessage.create({data:{role:"USER",content:t,taskId:e}});return(0,A.revalidatePath)("/workspaces"),{userMessage:a}}async function G(e){return R.db.taskMessage.findMany({where:{taskId:e},orderBy:{createdAt:"asc"}})}async function H(e,t="CLAUDE_CODE",a,r){let i=await R.db.taskExecution.create({data:{taskId:e,agent:t,status:"RUNNING",startedAt:new Date,worktreePath:a??null,worktreeBranch:r??null}});return await R.db.task.update({where:{id:e},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces"),i}async function K(e,t="FAILED"){let a=await R.db.taskExecution.update({where:{id:e},data:{status:t,endedAt:new Date}});return(0,A.revalidatePath)("/workspaces"),a}async function W(t){let{destroySession:a,getSession:r}=await e.A(229073),i=r(t),n=i?.getBuffer()??"",s=await R.db.taskExecution.findFirst({where:{taskId:t,status:"RUNNING"},orderBy:{createdAt:"desc"}}),o=await R.db.task.findUnique({where:{id:t},include:{project:{select:{localPath:!0}}}});if(a(t),s){await R.db.taskExecution.update({where:{id:s.id},data:{status:"COMPLETED",endedAt:new Date}}),await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}});let a=s.worktreePath||o?.project?.localPath||null,{captureExecutionSummary:r}=await e.A(274428);await r(s.id,t,0,n,a)}(0,A.revalidatePath)("/workspaces")}async function z(e){return R.db.taskExecution.findMany({where:{taskId:e},orderBy:{createdAt:"desc"},include:{insightNote:{select:{id:!0,title:!0,content:!0}}}})}async function X(t,a){let r=await R.db.task.findUnique({where:{id:t},include:{project:!0}});if(!r)throw Error("Task not found");if(!r.project?.localPath)throw Error("Project has no local path configured");await R.db.taskExecution.updateMany({where:{taskId:t,status:"RUNNING",NOT:{sessionId:a}},data:{status:"FAILED",endedAt:new Date}});let i=await R.db.taskExecution.findFirst({where:{taskId:t,sessionId:a},orderBy:{createdAt:"desc"}});if(!i)throw Error("Previous execution not found");let n=i.worktreePath??r.project.localPath,s=r.subPath?(0,F.join)(n,r.subPath):n,o=await R.db.cliProfile.findFirst({where:{isDefault:!0}});if(!o)throw Error("No default CLI profile found — run seed first");let d=$(o.baseArgs,"baseArgs"),l=$(o.envVars,"envVars"),c=await (0,I.readConfigValue)("terminal.idleTimeoutSec",180),{adapter:u}=await O("terminal"),p=u.buildEnvOverrides({taskId:t,taskTitle:r.title,apiUrl:`http://localhost:${process.env.PORT||"3000"}`,callbackUrl:i.callbackUrl??void 0}),w=await R.db.taskExecution.update({where:{id:i.id},data:{status:"RUNNING",endedAt:null}});await R.db.task.update({where:{id:t},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces");let h=await (0,I.readConfigValue)("onboarding.username",""),f=u.buildSpawnArgs({taskId:t,prompt:"",cwd:s,resumeSessionId:a,profileArgs:[...d,...h?["--append-system-prompt",`The user's name is ${h}.`]:[]],profileEnvVars:l,envOverrides:p}),v=/no conversation found with session id|unknown session|session .* not found/i;return(0,N.createSession)(t,f.command,f.args,s,()=>{},async n=>{await B(t,n);let s=await R.db.taskExecution.findUnique({where:{id:w.id}});if(s?.status!=="RUNNING")return;let{getSession:o}=await e.A(229073),d=o(t),l=d?.getBuffer()??"";if(0!==n&&v.test(l)){M.info("Session resume failed — retrying with fresh execution",{taskId:t,previousSessionId:a}),await R.db.taskExecution.update({where:{id:w.id},data:{status:"FAILED",endedAt:new Date}}).catch(()=>{});try{await J(t,r.title)}catch(e){M.error("Fresh execution retry also failed",e,{taskId:t})}return}await R.db.taskExecution.update({where:{id:w.id},data:{status:0===n?"COMPLETED":"FAILED",endedAt:new Date}}).catch(()=>{});let c=i.worktreePath||r.project.localPath,{captureExecutionSummary:u}=await e.A(274428);await u(w.id,t,n,l,c);let{dispatchTaskCompletionEvent:p}=await e.A(6206);await p({taskId:t,taskTitle:r.title,status:0===n?"COMPLETED":"FAILED",executionId:w.id,workspaceId:r.project.workspaceId}),0===n&&await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}}).catch(()=>{})},f.env,void 0,1e3*c),{executionId:w.id,worktreePath:i.worktreePath??n??null}}async function Q(t){let a=await R.db.task.findUnique({where:{id:t},include:{project:!0}});if(!a)throw Error("Task not found");if(!a.project?.localPath)throw Error("Project has no local path configured");let r=await R.db.taskExecution.findFirst({where:{taskId:t},orderBy:{createdAt:"desc"}}),{destroySession:i}=await e.A(229073);i(t),await R.db.taskExecution.updateMany({where:{taskId:t,status:"RUNNING"},data:{status:"FAILED",endedAt:new Date}});let n=r?.worktreePath??a.project.localPath,s=a.subPath?(0,F.join)(n,a.subPath):n,o=await R.db.cliProfile.findFirst({where:{isDefault:!0}});if(!o)throw Error("No default CLI profile found — run seed first");let d=$(o.baseArgs,"baseArgs"),l=$(o.envVars,"envVars"),c=await (0,I.readConfigValue)("terminal.idleTimeoutSec",180),{adapter:u,provider:p}=await O("terminal"),w=u.buildEnvOverrides({taskId:t,taskTitle:a.title,apiUrl:`http://localhost:${process.env.PORT||"3000"}`}),h=await R.db.taskExecution.create({data:{taskId:t,agent:p.agentFieldValue,status:"RUNNING",startedAt:new Date,worktreePath:r?.worktreePath??null,worktreeBranch:r?.worktreeBranch??null}});await R.db.task.update({where:{id:t},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces");let f=await (0,I.readConfigValue)("onboarding.username",""),v=u.buildSpawnArgs({taskId:t,prompt:"",cwd:s,continueLatest:!0,profileArgs:[...d,...f?["--append-system-prompt",`The user's name is ${f}.`]:[]],profileEnvVars:l,envOverrides:w});return(0,N.createSession)(t,v.command,v.args,s,()=>{},async i=>{await B(t,i);let n=await R.db.taskExecution.findUnique({where:{id:h.id}});if(n?.status!=="RUNNING")return;let{getSession:s}=await e.A(229073),o=s(t),d=o?.getBuffer()??"";await R.db.taskExecution.update({where:{id:h.id},data:{status:0===i?"COMPLETED":"FAILED",endedAt:new Date}}).catch(()=>{});let l=r?.worktreePath||a.project.localPath,{captureExecutionSummary:c}=await e.A(274428);await c(h.id,t,i,d,l);let{dispatchTaskCompletionEvent:u}=await e.A(6206);await u({taskId:t,taskTitle:a.title,status:0===i?"COMPLETED":"FAILED",executionId:h.id,workspaceId:a.project.workspaceId}),0===i&&await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}}).catch(()=>{})},v.env,void 0,1e3*c),{executionId:h.id,worktreePath:r?.worktreePath??n??null}}async function J(t,a,r,i){let n,s,o=await R.db.task.findUnique({where:{id:t},include:{project:!0}});if(!o)throw Error("Task not found");if(!o.project?.localPath)throw Error("Project has no local path configured");let d=await (0,I.readConfigValue)("system.maxConcurrentExecutions",20);if(await R.db.taskExecution.count({where:{status:"RUNNING"}})>=d)throw Error(`已达并发上限(${d}),请等待其他任务完成后再启动`);let l=await R.db.cliProfile.findFirst({where:{isDefault:!0}});if(!l)throw Error("No default CLI profile found — run seed first");let c=$(l.baseArgs,"baseArgs"),u=$(l.envVars,"envVars"),p=await (0,I.readConfigValue)("terminal.idleTimeoutSec",180),{adapter:w,provider:h,model:f}=await O("terminal");await R.db.taskExecution.updateMany({where:{taskId:t,status:"RUNNING"},data:{status:"FAILED",endedAt:new Date}}),"IN_PROGRESS"!==o.status&&(await R.db.task.update({where:{id:t},data:{status:"IN_PROGRESS"}}),(0,A.revalidatePath)("/workspaces"));let v=await R.db.taskMessage.findMany({where:{taskId:t},orderBy:{createdAt:"desc"},take:10}),E=[`Task: ${o.title}`,o.description?`Description: ${o.description}`:"",v.length>0?`Recent conversation:
2
+ ${v.reverse().map(e=>`${e.role}: ${e.content}`).join("\n")}`:"",a.trim()?`User message: ${a}`:""].filter(Boolean).join("\n\n"),g=r??o.promptId;if(g){let e=await R.db.agentPrompt.findUnique({where:{id:g}});e?.content&&(s=await (0,U.mkdtemp)((0,F.join)((0,_.tmpdir)(),"tower-pty-")),n=(0,F.join)(s,"instructions.md"),await (0,U.writeFile)(n,e.content,"utf-8"))}let k=null,b=null;if(o.baseBranch&&o.project.localPath){let{worktreePath:e,worktreeBranch:a}=await (0,P.createWorktree)(o.project.localPath,t,o.baseBranch);k=e,b=a}let m=k??o.project.localPath,y=o.subPath?(0,F.join)(m,o.subPath):m,x=await R.db.taskExecution.create({data:{taskId:t,agent:h.agentFieldValue,status:"RUNNING",startedAt:new Date,worktreePath:k??null,worktreeBranch:b??null,callbackUrl:i??null}});if(o.project.localPath)try{let t,{execFileSync:a}=await e.A(144264);(t=k&&o.baseBranch?a("git",["merge-base",o.baseBranch,"HEAD"],{cwd:k,encoding:"utf-8",timeout:5e3}).trim():a("git",["rev-parse","HEAD"],{cwd:o.project.localPath,encoding:"utf-8",timeout:5e3}).trim())&&await R.db.taskExecution.update({where:{id:x.id},data:{forkCommit:t}})}catch{}let C="";if(n){let{readFile:t}=await e.A(260815);C+=await t(n,"utf-8")}let S=await (0,I.readConfigValue)("onboarding.username","");S&&(C+=(C?"\n":"")+`The user's name is ${S}.`);let T=w.buildSpawnArgs({taskId:t,prompt:E,cwd:y,profileArgs:[...c,...C?["--append-system-prompt",C]:[],...f?["--model",f]:[]],profileEnvVars:u,envOverrides:w.buildEnvOverrides({taskId:t,taskTitle:o.title,apiUrl:`http://localhost:${process.env.PORT||"3000"}`,callbackUrl:i??void 0})});return(0,N.createSession)(t,T.command,T.args,y,()=>{},async a=>{await B(t,a);let r=await R.db.taskExecution.findUnique({where:{id:x.id}});if(r?.status!=="RUNNING")return;let{getSession:i}=await e.A(229073),n=i(t),d=n?.getBuffer()??"";await R.db.taskExecution.update({where:{id:x.id},data:{status:0===a?"COMPLETED":"FAILED",endedAt:new Date}}).catch(e=>{M.error("Failed to update execution status",e)});let l=k||o.project.localPath,{captureExecutionSummary:c}=await e.A(274428);await c(x.id,t,a,d,l);let{dispatchTaskCompletionEvent:u}=await e.A(6206);await u({taskId:t,taskTitle:o.title,status:0===a?"COMPLETED":"FAILED",executionId:x.id,workspaceId:o.project.workspaceId}),0===a&&await R.db.task.update({where:{id:t},data:{status:"IN_REVIEW"}}).catch(e=>{M.error("Failed to update task status",e)}),s&&await (0,U.rm)(s,{recursive:!0,force:!0}).catch(()=>{})},T.env,void 0,1e3*p),{executionId:x.id,worktreePath:k??m??null}}async function Z(){return(await R.db.taskExecution.findMany({where:{status:"RUNNING"},orderBy:{startedAt:"asc"},include:{task:{include:{project:{include:{workspace:!0}}}}}})).map(e=>({executionId:e.id,taskId:e.taskId,taskTitle:e.task.title,projectId:e.task.project.id,projectName:e.task.project.name,projectAlias:e.task.project.alias,projectLocalPath:e.task.project.localPath,workspaceId:e.task.project.workspace.id,workspaceName:e.task.project.workspace.name,worktreePath:e.worktreePath,startedAt:e.startedAt?.toISOString()??null}))}(0,L.ensureServerEntryExports)([V,G,H,K,W,z,X,Q,J,Z]),(0,m.registerServerReference)(V,"60fd02be1199a75ab601e3d0cf94400db69ad080f4",null),(0,m.registerServerReference)(G,"40c781bcf5f2d820e508850bc2999667fea2af4b4e",null),(0,m.registerServerReference)(H,"78e3691aa6b1ec2884874a5aeb698d9155b46db783",null),(0,m.registerServerReference)(K,"60330564158ae1a77022ac7d952c883e50f212369f",null),(0,m.registerServerReference)(W,"40d3c7de8b64ddb900e3f7ac46ac802673feb23198",null),(0,m.registerServerReference)(z,"4047135f0933191c5ee458162e6e6d92a29ed59f4b",null),(0,m.registerServerReference)(X,"607d47f7159f261048faf87ff026b8508d0239fdaa",null),(0,m.registerServerReference)(Q,"40f21730f368b920d8bd0817480ffbbc2b201c3e95",null),(0,m.registerServerReference)(J,"784ae1b90278fff4ac2f4d261a8f5298a3e7986b0a",null),(0,m.registerServerReference)(Z,"0014f15c969c980aa4f372768360135b01c9760165",null);let Y=k.z.object({prompt:k.z.string().optional().default("")});async function ee(e,{params:t}){let a=(0,b.requireLocalhost)(e);if(a)return a;let{taskId:r}=await t,i=(0,b.validateTaskId)(r);if(i)return i;try{let t=await e.json(),a=Y.safeParse(t);if(!a.success)return g.NextResponse.json({error:"Invalid body"},{status:400});let i=await J(r,a.data.prompt);return g.NextResponse.json(i)}catch(t){let e=t instanceof Error?t.message:String(t);return g.NextResponse.json({error:e},{status:500})}}e.s(["POST",0,ee,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],798207);var et=e.i(798207);let ea=new t.AppRouteRouteModule({definition:{kind:a.RouteKind.APP_ROUTE,page:"/api/internal/terminal/[taskId]/start/route",pathname:"/api/internal/terminal/[taskId]/start",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/tower/src/app/api/internal/terminal/[taskId]/start/route.ts",nextConfigOutput:"",userland:et}),{workAsyncStorage:er,workUnitAsyncStorage:ei,serverHooks:en}=ea;async function es(e,t,r){r.requestMeta&&(0,i.setRequestMeta)(e,r.requestMeta),ea.isDev&&(0,i.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let g="/api/internal/terminal/[taskId]/start/route";g=g.replace(/\/index$/,"")||"/";let k=await ea.prepare(e,t,{srcPage:g,multiZoneDraftMode:!1});if(!k)return t.statusCode=400,t.end("Bad Request"),null==r.waitUntil||r.waitUntil.call(r,Promise.resolve()),null;let{buildId:b,params:m,nextConfig:R,parsedUrl:A,isDraftMode:P,prerenderManifest:N,routerServerContext:y,isOnDemandRevalidate:I,revalidateOnlyGenerated:x,resolvedPathname:C,clientReferenceManifest:S,serverActionsManifest:T}=k,j=(0,o.normalizeAppPath)(g),D=!!(N.dynamicRoutes[j]||N.routes[C]),O=async()=>((null==y?void 0:y.render404)?await y.render404(e,t,A,!1):t.end("This page could not be found"),null);if(D&&!P){let e=!!N.routes[C],t=N.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(R.adapterPath)return await O();throw new v.NoFallbackError}}let U=null;!D||ea.isDev||P||(U="/index"===(U=C)?"/":U);let _=!0===ea.isDev||!D,F=D&&!_;T&&S&&(0,s.setManifestsSingleton)({page:g,clientReferenceManifest:S,serverActionsManifest:T});let L=e.method||"GET",M=(0,n.getTracer)(),q=M.getActiveScopeSpan(),B=!!(null==y?void 0:y.isWrappedByNextServer),$=!!(0,i.getRequestMeta)(e,"minimalMode"),V=(0,i.getRequestMeta)(e,"incrementalCache")||await ea.getIncrementalCache(e,R,N,$);null==V||V.resetRequestCache(),globalThis.__incrementalCache=V;let G={params:m,previewProps:N.preview,renderOpts:{experimental:{authInterrupts:!!R.experimental.authInterrupts},cacheComponents:!!R.cacheComponents,supportsDynamicResponse:_,incrementalCache:V,cacheLifeProfiles:R.cacheLife,waitUntil:r.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,r,i)=>ea.onRequestError(e,t,r,i,y)},sharedContext:{buildId:b}},H=new d.NodeNextRequest(e),K=new d.NodeNextResponse(t),W=l.NextRequestAdapter.fromNodeNextRequest(H,(0,l.signalFromNodeResponse)(t));try{let i,s=async e=>ea.handle(W,G).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=M.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==c.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let r=a.get("next.route");if(r){let t=`${L} ${r}`;e.setAttributes({"next.route":r,"http.route":r,"next.span_name":t}),e.updateName(t),i&&i!==e&&(i.setAttribute("http.route",r),i.updateName(t))}else e.updateName(`${L} ${g}`)}),o=async i=>{var n,o;let d=async({previousCacheEntry:a})=>{try{if(!$&&I&&x&&!a)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let n=await s(i);e.fetchMetrics=G.renderOpts.fetchMetrics;let o=G.renderOpts.pendingWaitUntil;o&&r.waitUntil&&(r.waitUntil(o),o=void 0);let d=G.renderOpts.collectedTags;if(!D)return await (0,p.sendResponse)(H,K,n,G.renderOpts.pendingWaitUntil),null;{let e=await n.blob(),t=(0,w.toNodeOutgoingHttpHeaders)(n.headers);d&&(t[f.NEXT_CACHE_TAGS_HEADER]=d),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==G.renderOpts.collectedRevalidate&&!(G.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,r=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:E.CachedRouteKind.APP_ROUTE,status:n.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:r}}}}catch(t){throw(null==a?void 0:a.isStale)&&await ea.onRequestError(e,t,{routerKind:"App Router",routePath:g,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:F,isOnDemandRevalidate:I})},!1,y),t}},l=await ea.handleResponse({req:e,nextConfig:R,cacheKey:U,routeKind:a.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:N,isRoutePPREnabled:!1,isOnDemandRevalidate:I,revalidateOnlyGenerated:x,responseGenerator:d,waitUntil:r.waitUntil,isMinimalMode:$});if(!D)return null;if((null==l||null==(n=l.value)?void 0:n.kind)!==E.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==l||null==(o=l.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});$||t.setHeader("x-nextjs-cache",I?"REVALIDATED":l.isMiss?"MISS":l.isStale?"STALE":"HIT"),P&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,w.fromNodeOutgoingHttpHeaders)(l.value.headers);return $&&D||c.delete(f.NEXT_CACHE_TAGS_HEADER),!l.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,h.getCacheControlHeader)(l.cacheControl)),await (0,p.sendResponse)(H,K,new Response(l.value.body,{headers:c,status:l.value.status||200})),null};B&&q?await o(q):(i=M.getActiveScopeSpan(),await M.withPropagatedContext(e.headers,()=>M.trace(c.BaseServerSpan.handleRequest,{spanName:`${L} ${g}`,kind:n.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!B))}catch(t){if(t instanceof v.NoFallbackError||await ea.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,u.getRevalidateReason)({isStaticGeneration:F,isOnDemandRevalidate:I})},!1,y),D)throw t;return await (0,p.sendResponse)(H,K,new Response(null,{status:500})),null}}e.s(["handler",0,es,"patchFetch",0,function(){return(0,r.patchFetch)({workAsyncStorage:er,workUnitAsyncStorage:ei})},"routeModule",0,ea,"serverHooks",0,en,"workAsyncStorage",0,er,"workUnitAsyncStorage",0,ei],54500)}];
3
3
 
4
4
  //# sourceMappingURL=10ge_next_dist_esm_build_templates_app-route_13~vb_i.js.map
@@ -1,4 +1,4 @@
1
- module.exports=[477714,(e,t,r)=>{t.exports=e.x("@prisma/client-44bae9bb3052ac14",()=>require("@prisma/client-44bae9bb3052ac14"))},750227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},902157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},874533,(e,t,r)=>{t.exports=e.x("node:child_process",()=>require("node:child_process"))},351032,(e,t,r)=>{t.exports=e.x("node-pty-17f56ec9e6acce49",()=>require("node-pty-17f56ec9e6acce49"))},193695,(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"))},918622,(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"))},556704,(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"))},832319,(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"))},270406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},324725,(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"))},985726,e=>{"use strict";var t=e.i(298600);let r=["localhost","127.0.0.1","[::1]"],n=new Set(["127.0.0.1","::1","::ffff:127.0.0.1"]),s=/^c[a-z0-9]{20,30}$/;e.s(["requireLocalhost",0,function(e){let s=e.headers.get("x-forwarded-for");if(s&&!s.split(",").map(e=>e.trim()).every(e=>n.has(e)))return t.NextResponse.json({error:"Forbidden"},{status:403});let i=e.headers.get("host")??"";return r.some(e=>i.startsWith(e))?null:t.NextResponse.json({error:"Forbidden"},{status:403})},"validateProjectId",0,function(e){return s.test(e)?null:t.NextResponse.json({error:"Invalid projectId format"},{status:400})},"validateTaskId",0,function(e){return s.test(e)?null:t.NextResponse.json({error:"Invalid taskId format"},{status:400})}])},359703,e=>{"use strict";var t=e.i(902157),r=e.i(874533),n=e.i(750227);function s(e=process.platform){return"win32"===e}function i(e){let t=e.replace(/\r\n|\r|\n/g," ");if(!t.length)return'""';let r=t.replace(/"/g,'""');return/[\s"&<>|^()]/.test(r)?`"${r}"`:r}let a=["CLAUDECODE","CLAUDE_CODE_ENTRYPOINT","CLAUDE_CODE_SESSION","CLAUDE_CODE_PARENT_SESSION"];async function o(e,t={}){let r=t.cwd??process.cwd(),i=t.env??process.env,a=t.platform??process.platform;if(e.includes("/")||e.includes("\\")){let t=n.default.isAbsolute(e)?e:n.default.resolve(r,e);return await p(t,a)?t:null}let l=i.PATH??i.Path??"",u=s(a)?";":":",c=l.split(u).filter(Boolean),d=s(a)?(i.PATHEXT??".EXE;.CMD;.BAT;.COM").split(";").filter(Boolean):[""],f=s(a)&&n.default.extname(e).length>0;for(let t of c)for(let r of s(a)?f?[n.default.join(t,e)]:d.map(r=>n.default.join(t,`${e}${r}`)):[n.default.join(t,e)])if(await p(r,a))return r;return null}let l=e=>(0,r.execSync)(e,{encoding:"utf-8",timeout:5e3});function u(e,t=process.platform,r=l){if(n.default.extname(e)||e.includes("/")||e.includes("\\")||!s(t))return e;try{let t=r(`where ${e}`).trim().split("\n").map(e=>e.trim()).filter(Boolean),n=t.find(e=>/\.(cmd|bat|exe)$/i.test(e));if(n)return n;if(t.length>0)return t[0]}catch{}return e}async function c(e,t,r={}){let n=r.env??process.env,s=r.platform??process.platform;return d(await o(e,r)??e,t,n,s)}function d(e,t,r,a){if(!s(a))return{command:e,args:t};let o=n.default.extname(e).toLowerCase();return".cmd"===o||".bat"===o||".com"===o?{command:r.ComSpec||"cmd.exe",args:["/d","/s","/c",[i(e),...t.map(i)].join(" ")]}:{command:e,args:t}}async function p(e,r=process.platform){try{return await t.promises.access(e,s(r)?t.constants.F_OK:t.constants.X_OK),!0}catch{return!1}}async function f(e=process.platform){return s(e)?m():h()}async function h(){try{let e=await t.promises.readFile("/etc/shells","utf-8"),r=[],s=new Map;for(let t of e.split("\n")){let e=t.replace(/#.*/,"").trim();if(!e||!e.startsWith("/")||!await p(e))continue;let i=n.default.basename(e),a=s.get(i)??0;s.set(i,a+1),a>0&&(i=`${i} (${a+1})`),r.push({name:i,path:e})}return r}catch{let e=[];for(let t of["/bin/zsh","/bin/bash","/bin/sh"])await p(t)&&e.push({name:n.default.basename(t),path:t});return e}}async function m(){let e=[],t=[],r=await o("git",{platform:"win32"});if(r){let e=n.default.resolve(n.default.dirname(r),"..","..");t.push(n.default.join(e,"bin","bash.exe"),n.default.join(e,"usr","bin","bash.exe"))}for(let e of[process.env.ProgramW6432,process.env.ProgramFiles,process.env["ProgramFiles(x86)"],process.env.LocalAppData?n.default.join(process.env.LocalAppData,"Programs"):null].filter(Boolean))t.push(n.default.join(e,"Git","bin","bash.exe"),n.default.join(e,"Git","usr","bin","bash.exe"));let s=process.env.USERPROFILE??"";for(let r of(s&&t.push(n.default.join(s,"scoop","apps","git","current","bin","bash.exe")),process.env.CLAUDE_CODE_GIT_BASH_PATH&&t.unshift(process.env.CLAUDE_CODE_GIT_BASH_PATH),t))if(await p(r,"win32")){e.push({name:"Git Bash",path:r});break}let i=await o("pwsh",{platform:"win32"});i&&e.push({name:"PowerShell",path:i});let a=process.env.windir??"C:\\WINDOWS",l=n.default.join(a,"System32","WindowsPowerShell","v1.0","powershell.exe");await p(l,"win32")&&e.push({name:"Windows PowerShell",path:l});let u=process.env.ComSpec??n.default.join(a,"System32","cmd.exe");return await p(u,"win32")&&e.push({name:"Command Prompt",path:u}),e}let v=[{name:"Terminal",bundleName:"Terminal"},{name:"iTerm2",bundleName:"iTerm"},{name:"Warp",bundleName:"Warp"},{name:"Alacritty",bundleName:"Alacritty"},{name:"WezTerm",bundleName:"WezTerm"},{name:"kitty",bundleName:"kitty"},{name:"Hyper",bundleName:"Hyper"}];async function x(e=process.platform){if("darwin"===e){let t=[];for(let r of v)await p(`/Applications/${r.bundleName}.app`,e)&&t.push({name:r.name,value:r.bundleName});return t}if(s(e)){let t=[],r=await o("wt",{platform:e});return r&&t.push({name:"Windows Terminal",value:r}),t}return[]}e.s(["detectShells",0,f,"detectTerminalApps",0,x,"ensurePathInEnv",0,function(e,t=process.platform){let r=s(t)?"Path":"PATH";return(e.PATH??e.Path??"").length>0?e:{...e,[r]:function(e=process.platform){return s(e)?"C:\\Windows\\System32;C:\\Windows;C:\\Windows\\System32\\Wbem":"/usr/local/bin:/opt/homebrew/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin"}(t)}},"resolveCommandPath",0,o,"resolveCommandPathSync",0,u,"resolveSpawnTarget",0,c,"resolveSpawnTargetSync",0,function(e,t,r=process.platform,n){return d(u(e,r,n),t,process.env,r)},"stripClaudeNestingEnv",0,function(e){let t={...e};for(let e of a)delete t[e];return t}])},112310,e=>{"use strict";var t=e.i(351032),r=e.i(359703);class n{taskId;_pty;killed=!1;disconnectTimer=null;_buffer="";static BUFFER_MAX=51200;_onData;_exitListeners=[];_idleTimer=null;_idleThresholdMs;_onIdle;_idleFired=!1;constructor(e,s,i,a,o,l,u,c,d){this.taskId=e,this._onData=o,this._onIdle=c??null,this._idleThresholdMs=Math.max(d??18e4,18e4);const p=(0,r.stripClaudeNestingEnv)((0,r.ensurePathInEnv)(process.env));this._pty=t.spawn(s,i,{name:"xterm-color",cols:80,rows:24,cwd:a,env:{...p,TERM:"xterm-color",...u}}),this._pty.onData(e=>{this._buffer+=e,this._buffer.length>n.BUFFER_MAX&&(this._buffer=this._buffer.slice(this._buffer.length-n.BUFFER_MAX)),this._resetIdleTimer(),this._onData(e)}),this._pty.onExit(({exitCode:e,signal:t})=>{for(let r of(this.killed=!0,this._idleTimer&&(clearTimeout(this._idleTimer),this._idleTimer=null),l(e,t),this._exitListeners))r(e)}),this._resetIdleTimer()}_resetIdleTimer(){this._idleTimer&&(clearTimeout(this._idleTimer),this._idleTimer=null),null===this._onIdle||this.killed||this._idleFired||(this._idleTimer=setTimeout(()=>{this._idleFired=!0,this._onIdle?.()},this._idleThresholdMs))}setDataListener(e){this._onData=e}setExitListener(e){this._exitListeners=[e]}write(e){this.killed||(this._resetIdleTimer(),this._pty.write(e))}resize(e,t){this.killed||this._pty.resize(e,t)}getBuffer(){return this._buffer}get isIdle(){return this._idleFired}kill(){if(!this.killed){this.killed=!0,this._idleTimer&&(clearTimeout(this._idleTimer),this._idleTimer=null);try{this._pty.kill()}catch{}}}}let s=globalThis;s.__ptySessions||(s.__ptySessions=new Map);let i=s.__ptySessions;function a(e){let t=i.get(e);t&&(i.delete(e),t.disconnectTimer&&(clearTimeout(t.disconnectTimer),t.disconnectTimer=null),t.kill())}function o(){for(let e of i.keys())a(e)}process.once("SIGTERM",()=>{console.error("[session-store] SIGTERM received — cleaning up PTY sessions"),o()}),process.once("SIGINT",()=>{console.error("[session-store] SIGINT received — cleaning up PTY sessions"),o()}),e.s(["createSession",0,function(e,t,s,o,l,u,c,d,p){a(e);let{command:f,args:h}=(0,r.resolveSpawnTargetSync)(t,s),m=new n(e,f,h,o,l,u,c,d,p);return i.set(e,m),m},"destroySession",0,a,"getSession",0,function(e){return i.get(e)}],112310)},647085,e=>{"use strict";var t=e.i(477714);let r=globalThis.prisma??new t.PrismaClient({log:[]});process.on("SIGTERM",()=>{r.$disconnect().catch(()=>{})}),process.on("SIGINT",()=>{r.$disconnect().catch(()=>{})}),e.s(["db",0,r])},451724,e=>{"use strict";var t=e.i(647085);async function r(e,r){let n=await t.db.systemConfig.findUnique({where:{key:e}});if(!n)return r;try{return JSON.parse(n.value)}catch{return r}}e.s(["readConfigValue",0,r])},333956,(e,t,r)=>{"use strict";t.exports=e.r(950820).vendored["react-rsc"].ReactServerDOMTurbopackServer},604719,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"registerServerReference",{enumerable:!0,get:function(){return n.registerServerReference}});let n=e.r(333956)},77129,(e,t,r)=>{"use strict";function n(e){for(let t=0;t<e.length;t++){let r=e[t];if("function"!=typeof r)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof r}.
2
- Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"ensureServerEntryExports",{enumerable:!0,get:function(){return n}})},254799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},950051,e=>{"use strict";var t=e.i(958699),r=e.i(953193),n=e.i(314093),s=e.i(159515),i=e.i(952192),a=e.i(939747),o=e.i(348399),l=e.i(887426),u=e.i(626524),c=e.i(479201),d=e.i(336951),p=e.i(546302),f=e.i(431732),h=e.i(899284),m=e.i(104600),v=e.i(193695);e.i(792325);var x=e.i(27732),w=e.i(298600),_=e.i(985726),b=e.i(604719),g=e.i(254799),y=e.i(112310),T=e.i(451724),E=e.i(647085);let R="__assistant__";async function S(e){let t,r;(0,y.destroySession)(R);let n=await E.db.cliProfile.findFirst({where:{isDefault:!0}});if(!n)throw Error("No default CLI profile — configure one in Settings");try{t=JSON.parse(n.baseArgs)}catch{throw Error("CLI Profile baseArgs is malformed — fix in Settings")}try{r=JSON.parse(n.envVars)}catch{throw Error("CLI Profile envVars is malformed — fix in Settings")}let s=await (0,T.readConfigValue)("assistant.systemPrompt","You are Tower Assistant, an AI operator for the Tower task management platform."),i=process.cwd(),a=[...t,"--allowedTools","mcp__tower__*","--append-system-prompt",s];e?a.push("--resume",e):a.push("--session-id",(0,g.randomUUID)());let o={...r};(0,y.createSession)(R,n.command,a,i,()=>{},()=>{},o)}async function C(){(0,y.destroySession)(R)}async function A(){let e=(0,y.getSession)(R);return!e||e.killed?"idle":"running"}async function P(e){let t,r=(0,_.requireLocalhost)(e);if(r)return r;try{let r=await e.json().catch(()=>({}));r.sessionId&&"string"==typeof r.sessionId&&(t=r.sessionId)}catch{}try{return await S(t),w.NextResponse.json({ok:!0,sessionKey:R,sessionId:t??null})}catch(t){let e=t instanceof Error?t.message:String(t);return w.NextResponse.json({error:e},{status:500})}}async function I(e){let t=(0,_.requireLocalhost)(e);return t||(await C(),w.NextResponse.json({ok:!0}))}async function N(e){let t=(0,_.requireLocalhost)(e);if(t)return t;let r=await A();return w.NextResponse.json({status:r})}(0,e.i(77129).ensureServerEntryExports)([S,C,A]),(0,b.registerServerReference)(S,"409f045527233c54fcfdb6b983d27f9e5508cd4a3e",null),(0,b.registerServerReference)(C,"00497d65bbfc499e3dbd46a146122735fd34cd22c5",null),(0,b.registerServerReference)(A,"0043cad8bb3dbae79131fb140b5965f07bf733ff20",null),e.s(["DELETE",0,I,"GET",0,N,"POST",0,P,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],333278);var j=e.i(333278);let O=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/internal/assistant/route",pathname:"/api/internal/assistant",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/tower/src/app/api/internal/assistant/route.ts",nextConfigOutput:"",userland:j}),{workAsyncStorage:k,workUnitAsyncStorage:D,serverHooks:q}=O;async function M(e,t,n){n.requestMeta&&(0,s.setRequestMeta)(e,n.requestMeta),O.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let w="/api/internal/assistant/route";w=w.replace(/\/index$/,"")||"/";let _=await O.prepare(e,t,{srcPage:w,multiZoneDraftMode:!1});if(!_)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:b,params:g,nextConfig:y,parsedUrl:T,isDraftMode:E,prerenderManifest:R,routerServerContext:S,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,resolvedPathname:P,clientReferenceManifest:I,serverActionsManifest:N}=_,j=(0,o.normalizeAppPath)(w),k=!!(R.dynamicRoutes[j]||R.routes[P]),D=async()=>((null==S?void 0:S.render404)?await S.render404(e,t,T,!1):t.end("This page could not be found"),null);if(k&&!E){let e=!!R.routes[P],t=R.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(y.adapterPath)return await D();throw new v.NoFallbackError}}let q=null;!k||O.isDev||E||(q="/index"===(q=P)?"/":q);let M=!0===O.isDev||!k,U=k&&!M;N&&I&&(0,a.setManifestsSingleton)({page:w,clientReferenceManifest:I,serverActionsManifest:N});let L=e.method||"GET",H=(0,i.getTracer)(),F=H.getActiveScopeSpan(),$=!!(null==S?void 0:S.isWrappedByNextServer),W=!!(0,s.getRequestMeta)(e,"minimalMode"),B=(0,s.getRequestMeta)(e,"incrementalCache")||await O.getIncrementalCache(e,y,R,W);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let G={params:g,previewProps:R.preview,renderOpts:{experimental:{authInterrupts:!!y.experimental.authInterrupts},cacheComponents:!!y.cacheComponents,supportsDynamicResponse:M,incrementalCache:B,cacheLifeProfiles:y.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,s)=>O.onRequestError(e,t,n,s,S)},sharedContext:{buildId:b}},K=new l.NodeNextRequest(e),X=new l.NodeNextResponse(t),z=u.NextRequestAdapter.fromNodeNextRequest(K,(0,u.signalFromNodeResponse)(t));try{let s,a=async e=>O.handle(z,G).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.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=`${L} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t),s&&s!==e&&(s.setAttribute("http.route",n),s.updateName(t))}else e.updateName(`${L} ${w}`)}),o=async s=>{var i,o;let l=async({previousCacheEntry:r})=>{try{if(!W&&C&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let i=await a(s);e.fetchMetrics=G.renderOpts.fetchMetrics;let o=G.renderOpts.pendingWaitUntil;o&&n.waitUntil&&(n.waitUntil(o),o=void 0);let l=G.renderOpts.collectedTags;if(!k)return await (0,p.sendResponse)(K,X,i,G.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[m.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==G.renderOpts.collectedRevalidate&&!(G.renderOpts.collectedRevalidate>=m.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,n=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=m.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await O.onRequestError(e,t,{routerKind:"App Router",routePath:w,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:C})},!1,S),t}},u=await O.handleResponse({req:e,nextConfig:y,cacheKey:q,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:R,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,responseGenerator:l,waitUntil:n.waitUntil,isMinimalMode:W});if(!k)return null;if((null==u||null==(i=u.value)?void 0:i.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(o=u.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});W||t.setHeader("x-nextjs-cache",C?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return W&&k||c.delete(m.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,h.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(K,X,new Response(u.value.body,{headers:c,status:u.value.status||200})),null};$&&F?await o(F):(s=H.getActiveScopeSpan(),await H.withPropagatedContext(e.headers,()=>H.trace(c.BaseServerSpan.handleRequest,{spanName:`${L} ${w}`,kind:i.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!$))}catch(t){if(t instanceof v.NoFallbackError||await O.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:C})},!1,S),k)throw t;return await (0,p.sendResponse)(K,X,new Response(null,{status:500})),null}}e.s(["handler",0,M,"patchFetch",0,function(){return(0,n.patchFetch)({workAsyncStorage:k,workUnitAsyncStorage:D})},"routeModule",0,O,"serverHooks",0,q,"workAsyncStorage",0,k,"workUnitAsyncStorage",0,D],950051)}];
1
+ module.exports=[477714,(e,t,r)=>{t.exports=e.x("@prisma/client-44bae9bb3052ac14",()=>require("@prisma/client-44bae9bb3052ac14"))},750227,(e,t,r)=>{t.exports=e.x("node:path",()=>require("node:path"))},902157,(e,t,r)=>{t.exports=e.x("node:fs",()=>require("node:fs"))},874533,(e,t,r)=>{t.exports=e.x("node:child_process",()=>require("node:child_process"))},351032,(e,t,r)=>{t.exports=e.x("node-pty-17f56ec9e6acce49",()=>require("node-pty-17f56ec9e6acce49"))},193695,(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"))},918622,(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"))},556704,(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"))},832319,(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"))},270406,(e,t,r)=>{t.exports=e.x("next/dist/compiled/@opentelemetry/api",()=>require("next/dist/compiled/@opentelemetry/api"))},324725,(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"))},985726,e=>{"use strict";var t=e.i(298600);let r=["localhost","127.0.0.1","[::1]"],n=new Set(["127.0.0.1","::1","::ffff:127.0.0.1"]),s=/^c[a-z0-9]{20,30}$/;e.s(["requireLocalhost",0,function(e){let s=e.headers.get("x-forwarded-for");if(s&&!s.split(",").map(e=>e.trim()).every(e=>n.has(e)))return t.NextResponse.json({error:"Forbidden"},{status:403});let a=e.headers.get("host")??"";return r.some(e=>a.startsWith(e))?null:t.NextResponse.json({error:"Forbidden"},{status:403})},"validateProjectId",0,function(e){return s.test(e)?null:t.NextResponse.json({error:"Invalid projectId format"},{status:400})},"validateTaskId",0,function(e){return s.test(e)?null:t.NextResponse.json({error:"Invalid taskId format"},{status:400})}])},359703,e=>{"use strict";var t=e.i(902157),r=e.i(874533),n=e.i(750227);function s(e=process.platform){return"win32"===e}function a(e){let t=e.replace(/\r\n|\r|\n/g," ");if(!t.length)return'""';let r=t.replace(/"/g,'""');return/[\s"&<>|^()]/.test(r)?`"${r}"`:r}let i=["CLAUDECODE","CLAUDE_CODE_ENTRYPOINT","CLAUDE_CODE_SESSION","CLAUDE_CODE_PARENT_SESSION"];async function o(e,t={}){let r=t.cwd??process.cwd(),a=t.env??process.env,i=t.platform??process.platform;if(e.includes("/")||e.includes("\\")){let t=n.default.isAbsolute(e)?e:n.default.resolve(r,e);return await p(t,i)?t:null}let l=a.PATH??a.Path??"",u=s(i)?";":":",c=l.split(u).filter(Boolean),d=s(i)?(a.PATHEXT??".EXE;.CMD;.BAT;.COM").split(";").filter(Boolean):[""],f=s(i)&&n.default.extname(e).length>0;for(let t of c)for(let r of s(i)?f?[n.default.join(t,e)]:d.map(r=>n.default.join(t,`${e}${r}`)):[n.default.join(t,e)])if(await p(r,i))return r;return null}let l=e=>(0,r.execSync)(e,{encoding:"utf-8",timeout:5e3});function u(e,t=process.platform,r=l){if(n.default.extname(e)||e.includes("/")||e.includes("\\")||!s(t))return e;try{let t=r(`where ${e}`).trim().split("\n").map(e=>e.trim()).filter(Boolean),n=t.find(e=>/\.(cmd|bat|exe)$/i.test(e));if(n)return n;if(t.length>0)return t[0]}catch{}return e}async function c(e,t,r={}){let n=r.env??process.env,s=r.platform??process.platform;return d(await o(e,r)??e,t,n,s)}function d(e,t,r,i){if(!s(i))return{command:e,args:t};let o=n.default.extname(e).toLowerCase();return".cmd"===o||".bat"===o||".com"===o?{command:r.ComSpec||"cmd.exe",args:["/d","/s","/c",[a(e),...t.map(a)].join(" ")]}:{command:e,args:t}}async function p(e,r=process.platform){try{return await t.promises.access(e,s(r)?t.constants.F_OK:t.constants.X_OK),!0}catch{return!1}}async function f(e=process.platform){return s(e)?m():h()}async function h(){try{let e=await t.promises.readFile("/etc/shells","utf-8"),r=[],s=new Map;for(let t of e.split("\n")){let e=t.replace(/#.*/,"").trim();if(!e||!e.startsWith("/")||!await p(e))continue;let a=n.default.basename(e),i=s.get(a)??0;s.set(a,i+1),i>0&&(a=`${a} (${i+1})`),r.push({name:a,path:e})}return r}catch{let e=[];for(let t of["/bin/zsh","/bin/bash","/bin/sh"])await p(t)&&e.push({name:n.default.basename(t),path:t});return e}}async function m(){let e=[],t=[],r=await o("git",{platform:"win32"});if(r){let e=n.default.resolve(n.default.dirname(r),"..","..");t.push(n.default.join(e,"bin","bash.exe"),n.default.join(e,"usr","bin","bash.exe"))}for(let e of[process.env.ProgramW6432,process.env.ProgramFiles,process.env["ProgramFiles(x86)"],process.env.LocalAppData?n.default.join(process.env.LocalAppData,"Programs"):null].filter(Boolean))t.push(n.default.join(e,"Git","bin","bash.exe"),n.default.join(e,"Git","usr","bin","bash.exe"));let s=process.env.USERPROFILE??"";for(let r of(s&&t.push(n.default.join(s,"scoop","apps","git","current","bin","bash.exe")),process.env.CLAUDE_CODE_GIT_BASH_PATH&&t.unshift(process.env.CLAUDE_CODE_GIT_BASH_PATH),t))if(await p(r,"win32")){e.push({name:"Git Bash",path:r});break}let a=await o("pwsh",{platform:"win32"});a&&e.push({name:"PowerShell",path:a});let i=process.env.windir??"C:\\WINDOWS",l=n.default.join(i,"System32","WindowsPowerShell","v1.0","powershell.exe");await p(l,"win32")&&e.push({name:"Windows PowerShell",path:l});let u=process.env.ComSpec??n.default.join(i,"System32","cmd.exe");return await p(u,"win32")&&e.push({name:"Command Prompt",path:u}),e}let v=[{name:"Terminal",bundleName:"Terminal"},{name:"iTerm2",bundleName:"iTerm"},{name:"Warp",bundleName:"Warp"},{name:"Alacritty",bundleName:"Alacritty"},{name:"WezTerm",bundleName:"WezTerm"},{name:"kitty",bundleName:"kitty"},{name:"Hyper",bundleName:"Hyper"}];async function x(e=process.platform){if("darwin"===e){let t=[];for(let r of v)await p(`/Applications/${r.bundleName}.app`,e)&&t.push({name:r.name,value:r.bundleName});return t}if(s(e)){let t=[],r=await o("wt",{platform:e});return r&&t.push({name:"Windows Terminal",value:r}),t}return[]}e.s(["detectShells",0,f,"detectTerminalApps",0,x,"ensurePathInEnv",0,function(e,t=process.platform){let r=s(t)?"Path":"PATH";return(e.PATH??e.Path??"").length>0?e:{...e,[r]:function(e=process.platform){return s(e)?"C:\\Windows\\System32;C:\\Windows;C:\\Windows\\System32\\Wbem":"/usr/local/bin:/opt/homebrew/bin:/usr/local/sbin:/usr/bin:/bin:/usr/sbin:/sbin"}(t)}},"resolveCommandPath",0,o,"resolveCommandPathSync",0,u,"resolveSpawnTarget",0,c,"resolveSpawnTargetSync",0,function(e,t,r=process.platform,n){return d(u(e,r,n),t,process.env,r)},"stripClaudeNestingEnv",0,function(e){let t={...e};for(let e of i)delete t[e];return t}])},112310,e=>{"use strict";var t=e.i(351032),r=e.i(359703);class n{taskId;_pty;killed=!1;disconnectTimer=null;_buffer="";static BUFFER_MAX=51200;_onData;_exitListeners=[];_idleTimer=null;_idleThresholdMs;_onIdle;_idleFired=!1;constructor(e,s,a,i,o,l,u,c,d){this.taskId=e,this._onData=o,this._onIdle=c??null,this._idleThresholdMs=Math.max(d??18e4,18e4);const p=(0,r.stripClaudeNestingEnv)((0,r.ensurePathInEnv)(process.env));this._pty=t.spawn(s,a,{name:"xterm-color",cols:80,rows:24,cwd:i,env:{...p,TERM:"xterm-color",...u}}),this._pty.onData(e=>{this._buffer+=e,this._buffer.length>n.BUFFER_MAX&&(this._buffer=this._buffer.slice(this._buffer.length-n.BUFFER_MAX)),this._resetIdleTimer(),this._onData(e)}),this._pty.onExit(({exitCode:e,signal:t})=>{for(let r of(this.killed=!0,this._idleTimer&&(clearTimeout(this._idleTimer),this._idleTimer=null),l(e,t),this._exitListeners))r(e)}),this._resetIdleTimer()}_resetIdleTimer(){this._idleTimer&&(clearTimeout(this._idleTimer),this._idleTimer=null),null===this._onIdle||this.killed||this._idleFired||(this._idleTimer=setTimeout(()=>{this._idleFired=!0,this._onIdle?.()},this._idleThresholdMs))}setDataListener(e){this._onData=e}setExitListener(e){this._exitListeners=[e]}write(e){this.killed||(this._resetIdleTimer(),this._pty.write(e))}resize(e,t){this.killed||this._pty.resize(e,t)}getBuffer(){return this._buffer}get isIdle(){return this._idleFired}kill(){if(!this.killed){this.killed=!0,this._idleTimer&&(clearTimeout(this._idleTimer),this._idleTimer=null);try{this._pty.kill()}catch{}}}}let s=globalThis;s.__ptySessions||(s.__ptySessions=new Map);let a=s.__ptySessions;function i(e){let t=a.get(e);t&&(a.delete(e),t.disconnectTimer&&(clearTimeout(t.disconnectTimer),t.disconnectTimer=null),t.kill())}function o(){for(let e of a.keys())i(e)}process.once("SIGTERM",()=>{console.error("[session-store] SIGTERM received — cleaning up PTY sessions"),o()}),process.once("SIGINT",()=>{console.error("[session-store] SIGINT received — cleaning up PTY sessions"),o()}),e.s(["createSession",0,function(e,t,s,o,l,u,c,d,p){i(e);let{command:f,args:h}=(0,r.resolveSpawnTargetSync)(t,s),m=new n(e,f,h,o,l,u,c,d,p);return a.set(e,m),m},"destroySession",0,i,"getSession",0,function(e){return a.get(e)}],112310)},647085,e=>{"use strict";var t=e.i(477714);let r=globalThis.prisma??new t.PrismaClient({log:[]});process.on("SIGTERM",()=>{r.$disconnect().catch(()=>{})}),process.on("SIGINT",()=>{r.$disconnect().catch(()=>{})}),e.s(["db",0,r])},451724,e=>{"use strict";var t=e.i(647085);async function r(e,r){let n=await t.db.systemConfig.findUnique({where:{key:e}});if(!n)return r;try{return JSON.parse(n.value)}catch{return r}}e.s(["readConfigValue",0,r])},333956,(e,t,r)=>{"use strict";t.exports=e.r(950820).vendored["react-rsc"].ReactServerDOMTurbopackServer},604719,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"registerServerReference",{enumerable:!0,get:function(){return n.registerServerReference}});let n=e.r(333956)},77129,(e,t,r)=>{"use strict";function n(e){for(let t=0;t<e.length;t++){let r=e[t];if("function"!=typeof r)throw Object.defineProperty(Error(`A "use server" file can only export async functions, found ${typeof r}.
2
+ Read more: https://nextjs.org/docs/messages/invalid-use-server-value`),"__NEXT_ERROR_CODE",{value:"E352",enumerable:!1,configurable:!0})}}Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"ensureServerEntryExports",{enumerable:!0,get:function(){return n}})},254799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},950051,e=>{"use strict";var t=e.i(958699),r=e.i(953193),n=e.i(314093),s=e.i(159515),a=e.i(952192),i=e.i(939747),o=e.i(348399),l=e.i(887426),u=e.i(626524),c=e.i(479201),d=e.i(336951),p=e.i(546302),f=e.i(431732),h=e.i(899284),m=e.i(104600),v=e.i(193695);e.i(792325);var x=e.i(27732),w=e.i(298600),_=e.i(985726),b=e.i(604719),g=e.i(254799),y=e.i(112310),T=e.i(451724),E=e.i(647085);let R="__assistant__";async function S(e){let t,r;(0,y.destroySession)(R);let n=await E.db.cliProfile.findFirst({where:{isDefault:!0}});if(!n)throw Error("No default CLI profile — configure one in Settings");try{t=JSON.parse(n.baseArgs)}catch{throw Error("CLI Profile baseArgs is malformed — fix in Settings")}try{r=JSON.parse(n.envVars)}catch{throw Error("CLI Profile envVars is malformed — fix in Settings")}let s=await (0,T.readConfigValue)("assistant.systemPrompt","You are Tower Assistant, an AI operator for the Tower task management platform."),a=process.cwd(),i=[...t,"--allowedTools","mcp__tower__*","--append-system-prompt",s];e?i.push("--resume",e):i.push("--session-id",(0,g.randomUUID)());let o={...r};(0,y.createSession)(R,n.command,i,a,()=>{},()=>{},o)}async function C(){(0,y.destroySession)(R)}async function A(){let e=(0,y.getSession)(R);return!e||e.killed?"idle":"running"}async function P(e){let t,r=(0,_.requireLocalhost)(e);if(r)return r;try{let r=await e.json().catch(()=>({}));r.sessionId&&"string"==typeof r.sessionId&&(t=r.sessionId)}catch{}try{return await S(t),w.NextResponse.json({ok:!0,sessionKey:R,sessionId:t??null})}catch(t){let e=t instanceof Error?t.message:String(t);return w.NextResponse.json({error:e},{status:500})}}async function I(e){let t=(0,_.requireLocalhost)(e);return t||(await C(),w.NextResponse.json({ok:!0}))}async function N(e){let t=(0,_.requireLocalhost)(e);if(t)return t;let r=await A();return w.NextResponse.json({status:r})}(0,e.i(77129).ensureServerEntryExports)([S,C,A]),(0,b.registerServerReference)(S,"40ee0a7b3f8b21d34dba3c1c81d620e6931ffaca16",null),(0,b.registerServerReference)(C,"0094888efa961030322dc2bb225b692c4a5e7aabf6",null),(0,b.registerServerReference)(A,"002d1b740008dc00a26187feea716af42b67b99a0d",null),e.s(["DELETE",0,I,"GET",0,N,"POST",0,P,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],333278);var j=e.i(333278);let O=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/internal/assistant/route",pathname:"/api/internal/assistant",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/tower/src/app/api/internal/assistant/route.ts",nextConfigOutput:"",userland:j}),{workAsyncStorage:k,workUnitAsyncStorage:D,serverHooks:q}=O;async function M(e,t,n){n.requestMeta&&(0,s.setRequestMeta)(e,n.requestMeta),O.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let w="/api/internal/assistant/route";w=w.replace(/\/index$/,"")||"/";let _=await O.prepare(e,t,{srcPage:w,multiZoneDraftMode:!1});if(!_)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:b,params:g,nextConfig:y,parsedUrl:T,isDraftMode:E,prerenderManifest:R,routerServerContext:S,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,resolvedPathname:P,clientReferenceManifest:I,serverActionsManifest:N}=_,j=(0,o.normalizeAppPath)(w),k=!!(R.dynamicRoutes[j]||R.routes[P]),D=async()=>((null==S?void 0:S.render404)?await S.render404(e,t,T,!1):t.end("This page could not be found"),null);if(k&&!E){let e=!!R.routes[P],t=R.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(y.adapterPath)return await D();throw new v.NoFallbackError}}let q=null;!k||O.isDev||E||(q="/index"===(q=P)?"/":q);let M=!0===O.isDev||!k,U=k&&!M;N&&I&&(0,i.setManifestsSingleton)({page:w,clientReferenceManifest:I,serverActionsManifest:N});let L=e.method||"GET",H=(0,a.getTracer)(),F=H.getActiveScopeSpan(),$=!!(null==S?void 0:S.isWrappedByNextServer),W=!!(0,s.getRequestMeta)(e,"minimalMode"),B=(0,s.getRequestMeta)(e,"incrementalCache")||await O.getIncrementalCache(e,y,R,W);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let G={params:g,previewProps:R.preview,renderOpts:{experimental:{authInterrupts:!!y.experimental.authInterrupts},cacheComponents:!!y.cacheComponents,supportsDynamicResponse:M,incrementalCache:B,cacheLifeProfiles:y.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,s)=>O.onRequestError(e,t,n,s,S)},sharedContext:{buildId:b}},K=new l.NodeNextRequest(e),X=new l.NodeNextResponse(t),z=u.NextRequestAdapter.fromNodeNextRequest(K,(0,u.signalFromNodeResponse)(t));try{let s,i=async e=>O.handle(z,G).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=H.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=`${L} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t),s&&s!==e&&(s.setAttribute("http.route",n),s.updateName(t))}else e.updateName(`${L} ${w}`)}),o=async s=>{var a,o;let l=async({previousCacheEntry:r})=>{try{if(!W&&C&&A&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await i(s);e.fetchMetrics=G.renderOpts.fetchMetrics;let o=G.renderOpts.pendingWaitUntil;o&&n.waitUntil&&(n.waitUntil(o),o=void 0);let l=G.renderOpts.collectedTags;if(!k)return await (0,p.sendResponse)(K,X,a,G.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,f.toNodeOutgoingHttpHeaders)(a.headers);l&&(t[m.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==G.renderOpts.collectedRevalidate&&!(G.renderOpts.collectedRevalidate>=m.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,n=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=m.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:x.CachedRouteKind.APP_ROUTE,status:a.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:n}}}}catch(t){throw(null==r?void 0:r.isStale)&&await O.onRequestError(e,t,{routerKind:"App Router",routePath:w,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:C})},!1,S),t}},u=await O.handleResponse({req:e,nextConfig:y,cacheKey:q,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:R,isRoutePPREnabled:!1,isOnDemandRevalidate:C,revalidateOnlyGenerated:A,responseGenerator:l,waitUntil:n.waitUntil,isMinimalMode:W});if(!k)return null;if((null==u||null==(a=u.value)?void 0:a.kind)!==x.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(o=u.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});W||t.setHeader("x-nextjs-cache",C?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,f.fromNodeOutgoingHttpHeaders)(u.value.headers);return W&&k||c.delete(m.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,h.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(K,X,new Response(u.value.body,{headers:c,status:u.value.status||200})),null};$&&F?await o(F):(s=H.getActiveScopeSpan(),await H.withPropagatedContext(e.headers,()=>H.trace(c.BaseServerSpan.handleRequest,{spanName:`${L} ${w}`,kind:a.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!$))}catch(t){if(t instanceof v.NoFallbackError||await O.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:U,isOnDemandRevalidate:C})},!1,S),k)throw t;return await (0,p.sendResponse)(K,X,new Response(null,{status:500})),null}}e.s(["handler",0,M,"patchFetch",0,function(){return(0,n.patchFetch)({workAsyncStorage:k,workUnitAsyncStorage:D})},"routeModule",0,O,"serverHooks",0,q,"workAsyncStorage",0,k,"workUnitAsyncStorage",0,D],950051)}];
3
3
 
4
4
  //# sourceMappingURL=%5Broot-of-the-server%5D__043lk8~._.js.map