tower-studio 0.1.0 → 0.1.1

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 (173) 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/cache/.tsbuildinfo +1 -1
  6. package/.next/diagnostics/route-bundle-stats.json +38 -38
  7. package/.next/fallback-build-manifest.json +3 -3
  8. package/.next/prerender-manifest.json +3 -3
  9. package/.next/required-server-files.js +0 -1
  10. package/.next/required-server-files.json +0 -1
  11. package/.next/server/app/_global-error.html +1 -1
  12. package/.next/server/app/_global-error.rsc +1 -1
  13. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  14. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  15. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  16. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  17. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  18. package/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -1
  19. package/.next/server/app/_not-found/page/server-reference-manifest.json +23 -23
  20. package/.next/server/app/_not-found/page.js.nft.json +1 -1
  21. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  22. package/.next/server/app/_not-found.html +1 -1
  23. package/.next/server/app/_not-found.rsc +14 -14
  24. package/.next/server/app/_not-found.segments/_full.segment.rsc +14 -14
  25. package/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  26. package/.next/server/app/_not-found.segments/_index.segment.rsc +9 -9
  27. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  28. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  29. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  30. package/.next/server/app/api/browse-fs/route.js.nft.json +1 -1
  31. package/.next/server/app/api/git/route.js.nft.json +1 -1
  32. package/.next/server/app/index.html +1 -1
  33. package/.next/server/app/index.rsc +14 -14
  34. package/.next/server/app/index.segments/__PAGE__.segment.rsc +2 -2
  35. package/.next/server/app/index.segments/_full.segment.rsc +14 -14
  36. package/.next/server/app/index.segments/_head.segment.rsc +4 -4
  37. package/.next/server/app/index.segments/_index.segment.rsc +9 -9
  38. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  39. package/.next/server/app/missions/page/react-loadable-manifest.json +1 -1
  40. package/.next/server/app/missions/page/server-reference-manifest.json +51 -51
  41. package/.next/server/app/missions/page.js.nft.json +1 -1
  42. package/.next/server/app/missions/page_client-reference-manifest.js +1 -1
  43. package/.next/server/app/onboarding/page/react-loadable-manifest.json +1 -1
  44. package/.next/server/app/onboarding/page/server-reference-manifest.json +23 -23
  45. package/.next/server/app/onboarding/page.js.nft.json +1 -1
  46. package/.next/server/app/onboarding/page_client-reference-manifest.js +1 -1
  47. package/.next/server/app/onboarding.html +1 -1
  48. package/.next/server/app/onboarding.rsc +16 -16
  49. package/.next/server/app/onboarding.segments/_full.segment.rsc +16 -16
  50. package/.next/server/app/onboarding.segments/_head.segment.rsc +4 -4
  51. package/.next/server/app/onboarding.segments/_index.segment.rsc +9 -9
  52. package/.next/server/app/onboarding.segments/_tree.segment.rsc +2 -2
  53. package/.next/server/app/onboarding.segments/onboarding/__PAGE__.segment.rsc +4 -4
  54. package/.next/server/app/onboarding.segments/onboarding.segment.rsc +3 -3
  55. package/.next/server/app/page/react-loadable-manifest.json +1 -1
  56. package/.next/server/app/page/server-reference-manifest.json +23 -23
  57. package/.next/server/app/page.js.nft.json +1 -1
  58. package/.next/server/app/page_client-reference-manifest.js +1 -1
  59. package/.next/server/app/settings/page/react-loadable-manifest.json +1 -1
  60. package/.next/server/app/settings/page/server-reference-manifest.json +32 -32
  61. package/.next/server/app/settings/page.js.nft.json +1 -1
  62. package/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  63. package/.next/server/app/settings.html +1 -1
  64. package/.next/server/app/settings.rsc +16 -16
  65. package/.next/server/app/settings.segments/_full.segment.rsc +16 -16
  66. package/.next/server/app/settings.segments/_head.segment.rsc +4 -4
  67. package/.next/server/app/settings.segments/_index.segment.rsc +9 -9
  68. package/.next/server/app/settings.segments/_tree.segment.rsc +2 -2
  69. package/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +4 -4
  70. package/.next/server/app/settings.segments/settings.segment.rsc +3 -3
  71. package/.next/server/app/workspaces/[workspaceId]/archive/page/react-loadable-manifest.json +1 -1
  72. package/.next/server/app/workspaces/[workspaceId]/archive/page/server-reference-manifest.json +79 -79
  73. package/.next/server/app/workspaces/[workspaceId]/archive/page.js.nft.json +1 -1
  74. package/.next/server/app/workspaces/[workspaceId]/archive/page_client-reference-manifest.js +1 -1
  75. package/.next/server/app/workspaces/[workspaceId]/assets/page/react-loadable-manifest.json +1 -1
  76. package/.next/server/app/workspaces/[workspaceId]/assets/page/server-reference-manifest.json +70 -70
  77. package/.next/server/app/workspaces/[workspaceId]/assets/page.js.nft.json +1 -1
  78. package/.next/server/app/workspaces/[workspaceId]/assets/page_client-reference-manifest.js +1 -1
  79. package/.next/server/app/workspaces/[workspaceId]/notes/page/react-loadable-manifest.json +1 -1
  80. package/.next/server/app/workspaces/[workspaceId]/notes/page/server-reference-manifest.json +61 -61
  81. package/.next/server/app/workspaces/[workspaceId]/notes/page.js.nft.json +1 -1
  82. package/.next/server/app/workspaces/[workspaceId]/notes/page_client-reference-manifest.js +1 -1
  83. package/.next/server/app/workspaces/[workspaceId]/page/react-loadable-manifest.json +1 -1
  84. package/.next/server/app/workspaces/[workspaceId]/page/server-reference-manifest.json +51 -51
  85. package/.next/server/app/workspaces/[workspaceId]/page.js.nft.json +1 -1
  86. package/.next/server/app/workspaces/[workspaceId]/page_client-reference-manifest.js +1 -1
  87. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page/react-loadable-manifest.json +1 -1
  88. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page/server-reference-manifest.json +23 -23
  89. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page.js.nft.json +1 -1
  90. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page_client-reference-manifest.js +1 -1
  91. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page/react-loadable-manifest.json +1 -1
  92. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page/server-reference-manifest.json +56 -56
  93. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page.js.nft.json +1 -1
  94. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page_client-reference-manifest.js +1 -1
  95. package/.next/server/app/workspaces/page/react-loadable-manifest.json +1 -1
  96. package/.next/server/app/workspaces/page/server-reference-manifest.json +43 -43
  97. package/.next/server/app/workspaces/page.js.nft.json +1 -1
  98. package/.next/server/app/workspaces/page_client-reference-manifest.js +1 -1
  99. package/.next/server/chunks/10ge_next_dist_esm_build_templates_app-route_13~vb_i.js +2 -2
  100. package/.next/server/chunks/[root-of-the-server]__043lk8~._.js +2 -2
  101. package/.next/server/chunks/ssr/0~.g_src_app_workspaces_[workspaceId]_tasks_[taskId]_task-page-client_tsx_0bbseig._.js +1 -1
  102. package/.next/server/chunks/ssr/[root-of-the-server]__0.8y0n9._.js +1 -1
  103. package/.next/server/chunks/ssr/[root-of-the-server]__01ws4-7._.js +1 -1
  104. package/.next/server/chunks/ssr/[root-of-the-server]__02ipahf._.js +1 -1
  105. package/.next/server/chunks/ssr/{[root-of-the-server]__0h44~z8._.js → [root-of-the-server]__03swpls._.js} +2 -2
  106. package/.next/server/chunks/ssr/[root-of-the-server]__0bk3s4l._.js +1 -1
  107. package/.next/server/chunks/ssr/[root-of-the-server]__0l~dc3x._.js +1 -1
  108. package/.next/server/chunks/ssr/[root-of-the-server]__0rs7pkn._.js +1 -1
  109. package/.next/server/chunks/ssr/[root-of-the-server]__0sysz2q._.js +3 -3
  110. package/.next/server/chunks/ssr/{[root-of-the-server]__0deh_.r._.js → [root-of-the-server]__0v0dk_o._.js} +2 -2
  111. package/.next/server/chunks/ssr/[root-of-the-server]__0vpgotk._.js +3 -0
  112. package/.next/server/chunks/ssr/[root-of-the-server]__0y-lkvf._.js +1 -1
  113. package/.next/server/chunks/ssr/[root-of-the-server]__12f810l._.js +1 -1
  114. package/.next/server/chunks/ssr/tower_0_i~57x._.js +3 -0
  115. package/.next/server/chunks/ssr/{tower_0j.-goc._.js → tower_0agzi_m._.js} +2 -2
  116. package/.next/server/chunks/ssr/tower_0kl_bfy._.js +1 -1
  117. package/.next/server/chunks/ssr/{tower_0mocaf7._.js → tower_0le1h0h._.js} +2 -2
  118. package/.next/server/chunks/ssr/tower_0mz4ut.._.js +1 -1
  119. package/.next/server/chunks/ssr/tower_0pcqezm._.js +1 -1
  120. package/.next/server/chunks/ssr/{tower_0txw7ny._.js → tower_0rdk81e._.js} +2 -2
  121. package/.next/server/chunks/ssr/tower_0wvk~r.._.js +1 -1
  122. package/.next/server/chunks/ssr/{tower_0x1wfcs._.js → tower_0xg_zeq._.js} +2 -2
  123. package/.next/server/chunks/ssr/{tower_11f_poc._.js → tower_0~oir9k._.js} +2 -2
  124. package/.next/server/chunks/ssr/tower_10p15te._.js +1 -1
  125. package/.next/server/chunks/ssr/tower_117pzh8._.js +1 -1
  126. package/.next/server/chunks/ssr/tower_11q5_.m._.js +1 -1
  127. package/.next/server/chunks/ssr/tower_138qlx5._.js +1 -1
  128. package/.next/server/chunks/ssr/tower_src_0puzd-6._.js +3 -0
  129. package/.next/server/chunks/ssr/tower_src_actions_agent-actions_ts_0j.e1tn._.js +1 -1
  130. package/.next/server/chunks/ssr/tower_src_actions_file-actions_ts_0424lna._.js +1 -1
  131. package/.next/server/chunks/ssr/tower_src_app_missions_missions-client_tsx_0a9vjyr._.js +1 -1
  132. package/.next/server/chunks/ssr/tower_src_app_onboarding_page_tsx_0_3krz1._.js +1 -1
  133. package/.next/server/chunks/ssr/tower_src_app_settings_page_tsx_0vo5e-o._.js +1 -1
  134. package/.next/server/chunks/ssr/tower_src_app_workspaces_[workspaceId]_assets_assets-page-client_tsx_0zfgzhi._.js +1 -1
  135. package/.next/server/chunks/ssr/tower_src_app_workspaces_[workspaceId]_board-page-client_tsx_0kjp1u0._.js +1 -1
  136. package/.next/server/chunks/tower_0a-x6m.._.js +1 -1
  137. package/.next/server/chunks/tower_src_0..vg-t._.js +1 -1
  138. package/.next/server/middleware-build-manifest.js +3 -3
  139. package/.next/server/pages/404.html +1 -1
  140. package/.next/server/pages/500.html +1 -1
  141. package/.next/server/server-reference-manifest.js +1 -1
  142. package/.next/server/server-reference-manifest.json +214 -214
  143. package/.next/static/chunks/0.uav~g39w7rr.js +1 -0
  144. package/.next/static/chunks/{11_3ea_a8knah.js → 02f8le_y~6gnd.js} +1 -1
  145. package/.next/static/chunks/{0o.ks3~iuzx4r.js → 06-mw~zl.diaf.js} +1 -1
  146. package/.next/static/chunks/{023~s6crmvsm8.js → 06fsp5nfga486.js} +1 -1
  147. package/.next/static/chunks/{0c.0-8lt3bz.1.js → 07~c.vc82_c1-.js} +1 -1
  148. package/.next/static/chunks/{179_l7917u3p2.js → 0amhu3hs4zxxw.js} +1 -1
  149. package/.next/static/chunks/0drgc-oztq6o-.css +1 -0
  150. package/.next/static/chunks/{0vg49pdw~qd37.js → 0k_9.73yz~q10.js} +1 -1
  151. package/.next/static/chunks/0ltsz~s~e4wzu.js +1 -0
  152. package/.next/static/chunks/{051mi_101oh.a.js → 0mf7~j7tvqr46.js} +1 -1
  153. package/.next/static/chunks/{0gt7r3-vbdfj9.js → 0qe.8bmmwuucu.js} +1 -1
  154. package/.next/static/chunks/0qpq1~6v-eql7.js +1 -0
  155. package/.next/static/chunks/0uxf0jd91e-0r.js +1 -0
  156. package/.next/static/chunks/{0r1oyqeuqr030.js → 0vn2y~4w7u3ui.js} +1 -1
  157. package/.next/static/chunks/{0ziax8rwv_767.js → 15gjy.xhhriy8.js} +2 -2
  158. package/.next/static/chunks/{0qagt5x67~~sx.js → 16ft9mdv3zwse.js} +1 -1
  159. package/.next/trace +2 -2
  160. package/.next/trace-build +1 -1
  161. package/next.config.ts +1 -1
  162. package/package.json +1 -1
  163. package/.next/server/chunks/ssr/[root-of-the-server]__0iluaa1._.js +0 -3
  164. package/.next/server/chunks/ssr/tower_0h2g2_e._.js +0 -3
  165. package/.next/server/chunks/ssr/tower_src_0u.-h7b._.js +0 -3
  166. package/.next/static/chunks/08g2tlzp2n4gz.js +0 -1
  167. package/.next/static/chunks/0_guif4s2s3q..css +0 -1
  168. package/.next/static/chunks/0q5~5fua-vef8.js +0 -1
  169. package/.next/static/chunks/0v1_be48b8jhu.js +0 -1
  170. package/.next/static/chunks/18augppu.eqk1.js +0 -1
  171. /package/.next/static/{BIQ1l5etqo7aJnbnv-Bqt → dwsGxWRLV_FPRJyEkai5s}/_buildManifest.js +0 -0
  172. /package/.next/static/{BIQ1l5etqo7aJnbnv-Bqt → dwsGxWRLV_FPRJyEkai5s}/_clientMiddlewareManifest.js +0 -0
  173. /package/.next/static/{BIQ1l5etqo7aJnbnv-Bqt → dwsGxWRLV_FPRJyEkai5s}/_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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.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/0gt7r3-vbdfj9.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/0vg49pdw~qd37.js"],"async":false}},"ssrModuleMapping":{"193331":{"*":{"id":863321,"name":"*","chunks":["server/chunks/ssr/tower_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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_0x1wfcs._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__0h44~z8._.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/0_guif4s2s3q..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/0_guif4s2s3q..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/0gt7r3-vbdfj9.js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0vg49pdw~qd37.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/0gt7r3-vbdfj9.js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0vg49pdw~qd37.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.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/0qe.8bmmwuucu.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/0k_9.73yz~q10.js"],"async":false}},"ssrModuleMapping":{"193331":{"*":{"id":863321,"name":"*","chunks":["server/chunks/ssr/tower_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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_0xg_zeq._.js","server/chunks/ssr/tower_0sojjnu._.js","server/chunks/ssr/[root-of-the-server]__03swpls._.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/0qe.8bmmwuucu.js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0k_9.73yz~q10.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/0qe.8bmmwuucu.js","static/chunks/151wr~6x8aclx.js","static/chunks/0lvd52mjiit6s.js","static/chunks/05-b9qqm3av9~.js","static/chunks/0z7bwntvfhxzi.js","static/chunks/0k_9.73yz~q10.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),g=e.i(298600),k=e.i(48671),m=e.i(985726),b=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,m=null;if(o.baseBranch&&o.project.localPath){let{worktreePath:e,worktreeBranch:a}=await (0,P.createWorktree)(o.project.localPath,t,o.baseBranch);k=e,m=a}let b=k??o.project.localPath,y=o.subPath?(0,F.join)(b,o.subPath):b,x=await R.db.taskExecution.create({data:{taskId:t,agent:h.agentFieldValue,status:"RUNNING",startedAt:new Date,worktreePath:k??null,worktreeBranch:m??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??b??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,b.registerServerReference)(V,"60e64a73a1a812c4621d813809c8c9bf7702f635e4",null),(0,b.registerServerReference)(G,"404c821ce0995dc7cf7f711a32c9ad460a7c66e61a",null),(0,b.registerServerReference)(H,"7809e0414dee5cd1fe76e0e46f161b3b52837d42f6",null),(0,b.registerServerReference)(K,"60dc97fcfae55a8cb6b7fce7331641c356a9f9092a",null),(0,b.registerServerReference)(W,"40ac92863af9c83943ea9bf4a4806e9b2250ec60ab",null),(0,b.registerServerReference)(z,"40aa27a83e9645e48240c4dece40365e948a04fa08",null),(0,b.registerServerReference)(X,"601cd59cdad7f0fc9db897805c687ad392804fdebc",null),(0,b.registerServerReference)(Q,"401822c186c107c6263d750905e04e0f3c50efa409",null),(0,b.registerServerReference)(J,"787e3bda2725d32a68cb2da8187fbe6638e9f9bf8a",null),(0,b.registerServerReference)(Z,"003cf40feb767da03b1e5e3e0b2218a5fd8604f735",null);let Y=k.z.object({prompt:k.z.string().optional().default("")});async function ee(e,{params:t}){let a=(0,m.requireLocalhost)(e);if(a)return a;let{taskId:r}=await t,i=(0,m.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:m,params:b,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:b,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:m}},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)}];
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,"60623c106b77e5c802c16fc14fc356d08fc2ab5b8f",null),(0,m.registerServerReference)(G,"40dc9db41cd9e67e584f1a7adb4fd456f6ecf8e681",null),(0,m.registerServerReference)(H,"78d5fe423bacd7c2d19725ee8bf41ae3f9e82e29dc",null),(0,m.registerServerReference)(K,"60e7e6b1fe4178e321a92fbee3432490858f73e9bd",null),(0,m.registerServerReference)(W,"4012c0bc23424605056e6aae4956aa7718060ca459",null),(0,m.registerServerReference)(z,"40a90c7d3374bc46c6aa4f2390ae82109f7ddeddf8",null),(0,m.registerServerReference)(X,"60ff3af7bd9fbc86b8e4acf2805e6b108b1c083d61",null),(0,m.registerServerReference)(Q,"4085bdb12a7c36130ca4425f712f21e4c411b89a51",null),(0,m.registerServerReference)(J,"7886ea6863d0931282634b87c57a3551c22c488c3b",null),(0,m.registerServerReference)(Z,"007d2549a6289f05294d74bc2e40423a85bc1f2d56",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),g=e.i(604719),y=e.i(254799),b=e.i(112310),T=e.i(451724),E=e.i(647085);let R="__assistant__";async function S(e){let t,r;(0,b.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,y.randomUUID)());let o={...r};(0,b.createSession)(R,n.command,a,i,()=>{},()=>{},o)}async function C(){(0,b.destroySession)(R)}async function A(){let e=(0,b.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,g.registerServerReference)(S,"40bd1751f3ebf0736c08a9ccf4bc243b7d31f32057",null),(0,g.registerServerReference)(C,"00eecec2345287632361f19ffe535d55f2e4e2c75b",null),(0,g.registerServerReference)(A,"00b08633e28166dfbacd8fae8e8828ab9c94db7f6c",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:g,params:y,nextConfig:b,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(b.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,b,R,W);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let G={params:y,previewProps:R.preview,renderOpts:{experimental:{authInterrupts:!!b.experimental.authInterrupts},cacheComponents:!!b.cacheComponents,supportsDynamicResponse:M,incrementalCache:B,cacheLifeProfiles:b.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:g}},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:b,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),g=e.i(604719),y=e.i(254799),b=e.i(112310),T=e.i(451724),E=e.i(647085);let R="__assistant__";async function S(e){let t,r;(0,b.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,y.randomUUID)());let o={...r};(0,b.createSession)(R,n.command,i,a,()=>{},()=>{},o)}async function C(){(0,b.destroySession)(R)}async function A(){let e=(0,b.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,g.registerServerReference)(S,"406630225f51ba23ec66f93c505594f97aa84529aa",null),(0,g.registerServerReference)(C,"00764338dd10906f37ec6a3d4efb895b7644d539bf",null),(0,g.registerServerReference)(A,"00c586b31fd88e0b2301365d9555424afee5109ae6",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:g,params:y,nextConfig:b,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(b.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,b,R,W);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let G={params:y,previewProps:R.preview,renderOpts:{experimental:{authInterrupts:!!b.experimental.authInterrupts},cacheComponents:!!b.cacheComponents,supportsDynamicResponse:M,incrementalCache:B,cacheLifeProfiles:b.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:g}},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:b,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