tower-studio 0.1.14 → 0.1.16

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 (208) 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 +95 -95
  7. package/.next/fallback-build-manifest.json +3 -3
  8. package/.next/prerender-manifest.json +3 -3
  9. package/.next/server/app/_global-error.html +1 -1
  10. package/.next/server/app/_global-error.rsc +1 -1
  11. package/.next/server/app/_global-error.segments/__PAGE__.segment.rsc +1 -1
  12. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  13. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  14. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  15. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  16. package/.next/server/app/_not-found/page/react-loadable-manifest.json +1 -1
  17. package/.next/server/app/_not-found/page/server-reference-manifest.json +23 -23
  18. package/.next/server/app/_not-found/page.js.nft.json +1 -1
  19. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  20. package/.next/server/app/_not-found.html +1 -1
  21. package/.next/server/app/_not-found.rsc +14 -14
  22. package/.next/server/app/_not-found.segments/_full.segment.rsc +14 -14
  23. package/.next/server/app/_not-found.segments/_head.segment.rsc +4 -4
  24. package/.next/server/app/_not-found.segments/_index.segment.rsc +9 -9
  25. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +2 -2
  26. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +3 -3
  27. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  28. package/.next/server/app/api/internal/assistant/route.js +1 -1
  29. package/.next/server/app/api/internal/assistant/route.js.nft.json +1 -1
  30. package/.next/server/app/api/internal/terminal/[taskId]/start/route.js +2 -2
  31. package/.next/server/app/api/internal/terminal/[taskId]/start/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 +49 -49
  41. package/.next/server/app/missions/page.js +1 -1
  42. package/.next/server/app/missions/page.js.nft.json +1 -1
  43. package/.next/server/app/missions/page_client-reference-manifest.js +1 -1
  44. package/.next/server/app/onboarding/page/react-loadable-manifest.json +1 -1
  45. package/.next/server/app/onboarding/page/server-reference-manifest.json +23 -23
  46. package/.next/server/app/onboarding/page.js.nft.json +1 -1
  47. package/.next/server/app/onboarding/page_client-reference-manifest.js +1 -1
  48. package/.next/server/app/onboarding.html +1 -1
  49. package/.next/server/app/onboarding.rsc +16 -16
  50. package/.next/server/app/onboarding.segments/_full.segment.rsc +16 -16
  51. package/.next/server/app/onboarding.segments/_head.segment.rsc +4 -4
  52. package/.next/server/app/onboarding.segments/_index.segment.rsc +9 -9
  53. package/.next/server/app/onboarding.segments/_tree.segment.rsc +2 -2
  54. package/.next/server/app/onboarding.segments/onboarding/__PAGE__.segment.rsc +4 -4
  55. package/.next/server/app/onboarding.segments/onboarding.segment.rsc +3 -3
  56. package/.next/server/app/page/react-loadable-manifest.json +1 -1
  57. package/.next/server/app/page/server-reference-manifest.json +23 -23
  58. package/.next/server/app/page.js.nft.json +1 -1
  59. package/.next/server/app/page_client-reference-manifest.js +1 -1
  60. package/.next/server/app/settings/page/react-loadable-manifest.json +1 -1
  61. package/.next/server/app/settings/page/server-reference-manifest.json +56 -80
  62. package/.next/server/app/settings/page.js +1 -1
  63. package/.next/server/app/settings/page.js.nft.json +1 -1
  64. package/.next/server/app/settings/page_client-reference-manifest.js +1 -1
  65. package/.next/server/app/settings.html +1 -1
  66. package/.next/server/app/settings.rsc +16 -16
  67. package/.next/server/app/settings.segments/_full.segment.rsc +16 -16
  68. package/.next/server/app/settings.segments/_head.segment.rsc +4 -4
  69. package/.next/server/app/settings.segments/_index.segment.rsc +9 -9
  70. package/.next/server/app/settings.segments/_tree.segment.rsc +2 -2
  71. package/.next/server/app/settings.segments/settings/__PAGE__.segment.rsc +4 -4
  72. package/.next/server/app/settings.segments/settings.segment.rsc +3 -3
  73. package/.next/server/app/workspaces/[workspaceId]/archive/page/react-loadable-manifest.json +1 -1
  74. package/.next/server/app/workspaces/[workspaceId]/archive/page/server-reference-manifest.json +77 -77
  75. package/.next/server/app/workspaces/[workspaceId]/archive/page.js.nft.json +1 -1
  76. package/.next/server/app/workspaces/[workspaceId]/archive/page_client-reference-manifest.js +1 -1
  77. package/.next/server/app/workspaces/[workspaceId]/assets/page/react-loadable-manifest.json +1 -1
  78. package/.next/server/app/workspaces/[workspaceId]/assets/page/server-reference-manifest.json +62 -62
  79. package/.next/server/app/workspaces/[workspaceId]/assets/page.js.nft.json +1 -1
  80. package/.next/server/app/workspaces/[workspaceId]/assets/page_client-reference-manifest.js +1 -1
  81. package/.next/server/app/workspaces/[workspaceId]/notes/page/react-loadable-manifest.json +1 -1
  82. package/.next/server/app/workspaces/[workspaceId]/notes/page/server-reference-manifest.json +53 -53
  83. package/.next/server/app/workspaces/[workspaceId]/notes/page.js.nft.json +1 -1
  84. package/.next/server/app/workspaces/[workspaceId]/notes/page_client-reference-manifest.js +1 -1
  85. package/.next/server/app/workspaces/[workspaceId]/page/react-loadable-manifest.json +1 -1
  86. package/.next/server/app/workspaces/[workspaceId]/page/server-reference-manifest.json +51 -51
  87. package/.next/server/app/workspaces/[workspaceId]/page.js +1 -1
  88. package/.next/server/app/workspaces/[workspaceId]/page.js.nft.json +1 -1
  89. package/.next/server/app/workspaces/[workspaceId]/page_client-reference-manifest.js +1 -1
  90. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page/react-loadable-manifest.json +1 -1
  91. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page/server-reference-manifest.json +23 -23
  92. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page.js.nft.json +1 -1
  93. package/.next/server/app/workspaces/[workspaceId]/projects/[projectId]/page_client-reference-manifest.js +1 -1
  94. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page/react-loadable-manifest.json +1 -1
  95. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page/server-reference-manifest.json +52 -52
  96. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page.js +2 -2
  97. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page.js.nft.json +1 -1
  98. package/.next/server/app/workspaces/[workspaceId]/tasks/[taskId]/page_client-reference-manifest.js +1 -1
  99. package/.next/server/app/workspaces/page/react-loadable-manifest.json +1 -1
  100. package/.next/server/app/workspaces/page/server-reference-manifest.json +43 -43
  101. package/.next/server/app/workspaces/page.js.nft.json +1 -1
  102. package/.next/server/app/workspaces/page_client-reference-manifest.js +1 -1
  103. package/.next/server/chunks/0uz~_next_dist_esm_build_templates_app-route_05yec2y.js +2 -2
  104. package/.next/server/chunks/[root-of-the-server]__00~8_qz._.js +4 -0
  105. package/.next/server/chunks/[root-of-the-server]__05mc_xk._.js +1 -1
  106. package/.next/server/chunks/[root-of-the-server]__0p5iuez._.js +2 -2
  107. package/.next/server/chunks/[root-of-the-server]__0rb-ear._.js +4 -0
  108. package/.next/server/chunks/project_f_tower_0n1s3ym._.js +1 -1
  109. package/.next/server/chunks/project_f_tower_src_11e.cv5._.js +1 -1
  110. package/.next/server/chunks/ssr/04uy_src_app_workspaces_[workspaceId]_tasks_[taskId]_task-page-client_tsx_01.s1p0._.js +1 -1
  111. package/.next/server/chunks/ssr/0y0r_f_tower_src_app_workspaces_[workspaceId]_assets_assets-page-client_tsx_0n4g3bn._.js +1 -1
  112. package/.next/server/chunks/ssr/[root-of-the-server]__00.lowc._.js +1 -1
  113. package/.next/server/chunks/ssr/[root-of-the-server]__007tg36._.js +1 -1
  114. package/.next/server/chunks/ssr/[root-of-the-server]__025.0xa._.js +1 -1
  115. package/.next/server/chunks/ssr/[root-of-the-server]__04u4kb4._.js +1 -1
  116. package/.next/server/chunks/ssr/[root-of-the-server]__05a17ca._.js +1 -1
  117. package/.next/server/chunks/ssr/[root-of-the-server]__06qzctf._.js +1 -1
  118. package/.next/server/chunks/ssr/{[root-of-the-server]__0wkjslq._.js → [root-of-the-server]__08-2pn1._.js} +1 -1
  119. package/.next/server/chunks/ssr/[root-of-the-server]__0_47k-j._.js +3 -0
  120. package/.next/server/chunks/ssr/[root-of-the-server]__0aidehy._.js +3 -0
  121. package/.next/server/chunks/ssr/[root-of-the-server]__0bqzhpe._.js +3 -0
  122. package/.next/server/chunks/ssr/[root-of-the-server]__0ex911v._.js +30 -0
  123. package/.next/server/chunks/ssr/[root-of-the-server]__0ffdrwp._.js +1 -1
  124. package/.next/server/chunks/ssr/[root-of-the-server]__0h38s6n._.js +3 -0
  125. package/.next/server/chunks/ssr/[root-of-the-server]__0h8nl.m._.js +3 -0
  126. package/.next/server/chunks/ssr/[root-of-the-server]__0i4rk9v._.js +3 -3
  127. package/.next/server/chunks/ssr/[root-of-the-server]__0r6gkos._.js +1 -1
  128. package/.next/server/chunks/ssr/[root-of-the-server]__0u26l~e._.js +1 -1
  129. package/.next/server/chunks/ssr/[root-of-the-server]__0uca1bc._.js +1 -1
  130. package/.next/server/chunks/ssr/[root-of-the-server]__0w7gbe7._.js +1 -1
  131. package/.next/server/chunks/ssr/[root-of-the-server]__0xe-o3g._.js +1 -1
  132. package/.next/server/chunks/ssr/[root-of-the-server]__0zaw-fl._.js +3 -0
  133. package/.next/server/chunks/ssr/[root-of-the-server]__13eo85g._.js +1 -1
  134. package/.next/server/chunks/ssr/[root-of-the-server]__13x5mmo._.js +1 -1
  135. package/.next/server/chunks/ssr/project_f_tower_0.txwd8._.js +1 -1
  136. package/.next/server/chunks/ssr/project_f_tower_047pa2s._.js +3 -0
  137. package/.next/server/chunks/ssr/project_f_tower_0f0-wva._.js +1 -1
  138. package/.next/server/chunks/ssr/project_f_tower_0hgtev9._.js +1 -1
  139. package/.next/server/chunks/ssr/{project_f_tower_0pf464l._.js → project_f_tower_0i96rjz._.js} +2 -2
  140. package/.next/server/chunks/ssr/project_f_tower_0ivvjwd._.js +1 -1
  141. package/.next/server/chunks/ssr/{project_f_tower_0ntkd-l._.js → project_f_tower_0jhlcus._.js} +2 -2
  142. package/.next/server/chunks/ssr/project_f_tower_0jy~1uf._.js +1 -1
  143. package/.next/server/chunks/ssr/project_f_tower_0l6ssf8._.js +1 -1
  144. package/.next/server/chunks/ssr/project_f_tower_0o5.y1e._.js +1 -1
  145. package/.next/server/chunks/ssr/project_f_tower_0ps2~v1._.js +3 -0
  146. package/.next/server/chunks/ssr/project_f_tower_0ssr2sl._.js +3 -0
  147. package/.next/server/chunks/ssr/{project_f_tower_08mqp19._.js → project_f_tower_0tlnklr._.js} +2 -2
  148. package/.next/server/chunks/ssr/project_f_tower_0w01kgd._.js +3 -0
  149. package/.next/server/chunks/ssr/project_f_tower_0ym-aea._.js +1 -1
  150. package/.next/server/chunks/ssr/project_f_tower_12oax__._.js +3 -0
  151. package/.next/server/chunks/ssr/project_f_tower_src_10.nkh7._.js +3 -0
  152. package/.next/server/chunks/ssr/project_f_tower_src_actions_agent-actions_ts_0.s4~m-._.js +2 -2
  153. package/.next/server/chunks/ssr/project_f_tower_src_actions_file-actions_ts_02i742t._.js +1 -1
  154. package/.next/server/chunks/ssr/project_f_tower_src_app_missions_missions-client_tsx_0ums4qx._.js +1 -1
  155. package/.next/server/chunks/ssr/project_f_tower_src_app_onboarding_page_tsx_0_9_yoq._.js +1 -1
  156. package/.next/server/chunks/ssr/project_f_tower_src_app_settings_page_tsx_0oo06~d._.js +1 -1
  157. package/.next/server/chunks/ssr/project_f_tower_src_app_workspaces_[workspaceId]_board-page-client_tsx_0jmj1xz._.js +1 -1
  158. package/.next/server/chunks/ssr/{project_f_tower_0u6dr5n._.js → project_f_tower_src_components_ui_input_tsx_02yu4ri._.js} +2 -2
  159. package/.next/server/middleware-build-manifest.js +3 -3
  160. package/.next/server/pages/404.html +1 -1
  161. package/.next/server/pages/500.html +1 -1
  162. package/.next/server/server-reference-manifest.js +1 -1
  163. package/.next/server/server-reference-manifest.json +217 -241
  164. package/.next/static/chunks/{0z2rpkmoqlr-v.js → 06~5p79536pfs.js} +1 -1
  165. package/.next/static/chunks/{17ckwfwqtxcv7.js → 076vhlm6g1m9n.js} +1 -1
  166. package/.next/static/chunks/{1660q32oalq26.js → 08x0olwzpsczv.js} +2 -2
  167. package/.next/static/chunks/0amzt~927k5f5.js +1 -0
  168. package/.next/static/chunks/{0z-6e_hc3z22b.js → 0gwxdr2ihtu8z.js} +1 -1
  169. package/.next/static/chunks/{0x-v4tzitjxub.js → 0jef3e_wsh4mf.js} +1 -1
  170. package/.next/static/chunks/{08gl4lr7zkm6b.js → 0jfknbbi-cjcl.js} +1 -1
  171. package/.next/static/chunks/{11gkyogd_hqv~.js → 0l5tqul.pwfze.js} +1 -1
  172. package/.next/static/chunks/0pez9k2q~8lom.js +1 -0
  173. package/.next/static/chunks/0s4zpgzk~au6x.css +1 -0
  174. package/.next/static/chunks/{0qnz9q6uieuv8.js → 0sszltblb5pss.js} +1 -1
  175. package/.next/static/chunks/0uxf3e~tjkjuz.js +1 -0
  176. package/.next/static/chunks/1034h4copyi13.js +1 -0
  177. package/.next/static/chunks/11j_4bpiqb5on.js +1 -0
  178. package/.next/static/chunks/{12btaaeo1ik-t.js → 12q1f_9u6eduf.js} +1 -1
  179. package/.next/static/chunks/{14zxctn8~z26r.js → 14xrab1qyw2yw.js} +1 -1
  180. package/.next/static/chunks/{0qnvx~5op5b9e.js → 181v0f2l.x5_p.js} +1 -1
  181. package/.next/trace +2 -2
  182. package/.next/trace-build +1 -1
  183. package/package.json +2 -4
  184. package/scripts/init-db.ts +0 -17
  185. package/.next/server/chunks/[root-of-the-server]__02~bq0q._.js +0 -4
  186. package/.next/server/chunks/[root-of-the-server]__0~33o~m._.js +0 -4
  187. package/.next/server/chunks/ssr/[root-of-the-server]__0.4j53v._.js +0 -3
  188. package/.next/server/chunks/ssr/[root-of-the-server]__09bcer6._.js +0 -3
  189. package/.next/server/chunks/ssr/[root-of-the-server]__0fwuc5u._.js +0 -3
  190. package/.next/server/chunks/ssr/[root-of-the-server]__0gpx.d~._.js +0 -3
  191. package/.next/server/chunks/ssr/[root-of-the-server]__0nmyvwk._.js +0 -3
  192. package/.next/server/chunks/ssr/[root-of-the-server]__11j4k9o._.js +0 -3
  193. package/.next/server/chunks/ssr/[root-of-the-server]__13cjs8r._.js +0 -3
  194. package/.next/server/chunks/ssr/project_f_tower_01tnhbx._.js +0 -3
  195. package/.next/server/chunks/ssr/project_f_tower_04g3~44._.js +0 -30
  196. package/.next/server/chunks/ssr/project_f_tower_0760i8j._.js +0 -3
  197. package/.next/server/chunks/ssr/project_f_tower_0ddfsyt._.js +0 -3
  198. package/.next/server/chunks/ssr/project_f_tower_0sy7ynr._.js +0 -3
  199. package/.next/server/chunks/ssr/project_f_tower_src_0bqbs-1._.js +0 -3
  200. package/.next/static/chunks/04pjsuj.mivbh.css +0 -1
  201. package/.next/static/chunks/0brwcgj_cjdcc.js +0 -1
  202. package/.next/static/chunks/0q40u78uovc7y.js +0 -1
  203. package/.next/static/chunks/0w90t_ngr5_pj.js +0 -1
  204. package/.next/static/chunks/11y3rfp3d4n.0.js +0 -1
  205. package/.next/static/chunks/12.91avyb6b7-.js +0 -1
  206. /package/.next/static/{VzTy7iJ2D58ZvnVnTJZJi → UuR3rJNr0J0cwFZgsovkL}/_buildManifest.js +0 -0
  207. /package/.next/static/{VzTy7iJ2D58ZvnVnTJZJi → UuR3rJNr0J0cwFZgsovkL}/_clientMiddlewareManifest.js +0 -0
  208. /package/.next/static/{VzTy7iJ2D58ZvnVnTJZJi → UuR3rJNr0J0cwFZgsovkL}/_ssgManifest.js +0 -0
@@ -1,4 +1,4 @@
1
- module.exports=[655315,(e,t,r)=>{t.exports=e.x("@prisma/client-ac1b8067b36ef9d3",()=>require("@prisma/client-ac1b8067b36ef9d3"))},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"))},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"))},383893,e=>{"use strict";var t=e.i(532087);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})}])},429468,e=>{"use strict";var t=e.i(655315);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])},831757,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 o=["CLAUDECODE","CLAUDE_CODE_ENTRYPOINT","CLAUDE_CODE_SESSION","CLAUDE_CODE_PARENT_SESSION"];async function i(e,t={}){let r=t.cwd??process.cwd(),a=t.env??process.env,o=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,o)?t:null}let l=a.PATH??a.Path??"",u=s(o)?";":":",c=l.split(u).filter(Boolean),d=s(o)?(a.PATHEXT??".EXE;.CMD;.BAT;.COM").split(";").filter(Boolean):[""],h=s(o)&&n.default.extname(e).length>0;for(let t of c)for(let r of s(o)?h?[n.default.join(t,e)]:d.map(r=>n.default.join(t,`${e}${r}`)):[n.default.join(t,e)])if(await p(r,o))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 i(e,r)??e,t,n,s)}function d(e,t,r,o){if(!s(o))return{command:e,args:t};let i=n.default.extname(e).toLowerCase();return".cmd"===i||".bat"===i||".com"===i?{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 h(e=process.platform){return s(e)?f():m()}async function m(){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),o=s.get(a)??0;s.set(a,o+1),o>0&&(a=`${a} (${o+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 f(){let e=[],t=[],r=await i("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 i("pwsh",{platform:"win32"});a&&e.push({name:"PowerShell",path:a});let o=process.env.windir??"C:\\WINDOWS",l=n.default.join(o,"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(o,"System32","cmd.exe");return await p(u,"win32")&&e.push({name:"Command Prompt",path:u}),e}let g=[{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 v(e=process.platform){if("darwin"===e){let t=[];for(let r of g)await p(`/Applications/${r.bundleName}.app`,e)&&t.push({name:r.name,value:r.bundleName});return t}if(s(e)){let t=[],r=await i("wt",{platform:e});return r&&t.push({name:"Windows Terminal",value:r}),t}return[]}e.s(["detectShells",0,h,"detectTerminalApps",0,v,"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,i,"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 o)delete t[e];return t}])},498445,e=>{"use strict";var t=e.i(902157),r=e.i(660526),n=e.i(750227),s=e.i(831757);let a=["sonnet","opus","haiku","claude-sonnet-4-6","claude-opus-4-6","claude-haiku-4-5-20251001"];e.s(["ClaudeCliAdapter",0,class{buildSpawnArgs(e){let t=[];e.profileArgs?.length&&t.push(...e.profileArgs),e.resumeSessionId?t.push("--resume",e.resumeSessionId):e.continueLatest?t.push("--continue"):e.prompt&&t.push(e.prompt);let r={...e.profileEnvVars??{},...e.envOverrides??{}};return{command:this.resolveCommand(),args:t,env:r}}buildEnvOverrides(e){let t={TOWER_TASK_ID:e.taskId,TOWER_TASK_TITLE:e.taskTitle,TOWER_STARTED_AT:new Date().toISOString(),TOWER_API_URL:e.apiUrl};return e.callbackUrl&&(t.CALLBACK_URL=e.callbackUrl),t}async installHooks(e){let t=this.readSettings(),r=t.hooks??{},s=this.getPostToolUseArray(t);if(this.findTowerHookIndex(s)>=0)return;let a=n.join(process.cwd(),"scripts","post-tool-hook.js"),o={hooks:[{command:`node "${a}"`,timeout:10,type:"command"}],matcher:"Write|Edit|MultiEdit"};t.hooks={...r,PostToolUse:[...s,o]},this.writeSettings(t)}async uninstallHooks(){let e=this.readSettings(),t=e.hooks??{},r=this.getPostToolUseArray(e).filter(e=>!e.hooks?.some(e=>e.command?.includes("post-tool-hook.js")));e.hooks={...t,PostToolUse:r},this.writeSettings(e)}async isHooksInstalled(){let e=this.readSettings(),t=this.getPostToolUseArray(e);return this.findTowerHookIndex(t)>=0}async isAvailable(){return null!==await this.getVersion()}async getVersion(){try{let{execFile:t}=await e.A(144264),{promisify:r}=await e.A(534777),n=r(t),s=this.resolveCommand(),{stdout:a}=await n(s,["--version"],{timeout:5e3});return a.trim()||null}catch{return null}}async getModels(){return a}getConfigDir(){return n.join(r.homedir(),".claude")}getSettingsPath(){return n.join(this.getConfigDir(),"settings.json")}getSessionsDir(){return n.join(this.getConfigDir(),"projects")}resolveCommand(){return process.env.CLAUDE_CODE_PATH?process.env.CLAUDE_CODE_PATH:(0,s.resolveCommandPathSync)("claude")}readSettings(){try{return JSON.parse(t.readFileSync(this.getSettingsPath(),"utf-8"))}catch{return{}}}writeSettings(e){let r=this.getConfigDir();t.existsSync(r)||t.mkdirSync(r,{recursive:!0}),t.writeFileSync(this.getSettingsPath(),JSON.stringify(e,null,2),"utf-8")}getPostToolUseArray(e){let t=e.hooks;if(!t)return[];let r=t.PostToolUse;return Array.isArray(r)?r:[]}findTowerHookIndex(e){return e.findIndex(e=>e.hooks?.some(e=>e.command?.includes("post-tool-hook.js")))}}])},660526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},679502,e=>{"use strict";let t;var r=e.i(750227),n=e.i(660526),s=e.i(902157);function a(){return t||(t=(0,r.join)((0,n.homedir)(),".tower"),(0,s.existsSync)(t)||(0,s.mkdirSync)(t,{recursive:!0})),t}e.s(["getAssistantDir",0,function(){let e=(0,r.join)(a(),"assistant");return(0,s.existsSync)(e)||(0,s.mkdirSync)(e,{recursive:!0}),e},"getStorageDir",0,function(){let e=(0,r.join)(a(),"storage");return(0,s.existsSync)(e)||(0,s.mkdirSync)(e,{recursive:!0}),e}])},666680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},480776,e=>{"use strict";var t=e.i(666680),r=e.i(902157),n=e.i(750227);let s=(0,e.i(679502).getStorageDir)();function a(e){if(!e.startsWith(s+n.sep))throw Error("Path traversal detected")}let o=new Set(["image","screenshot","img","photo","picture","clipboard","paste","untitled"]);e.s(["buildCacheFilename",0,function(e,r){let s=n.basename(e,n.extname(e)),a=t.randomUUID().replace(/-/g,"").slice(0,8),i=s.toLowerCase();if(!s||o.has(i)||/^screenshot[\s_\-]/i.test(s))return`tower_image-${a}${r}`;let l=s.replace(/[^\p{L}\p{N}]/gu,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"");return`${l||"file"}-${a}${r}`},"ensureAssetsDir",0,function(e){let t,o=(a(t=n.join(s,"assets",e)),t);return r.mkdirSync(o,{recursive:!0}),o},"getAssistantCacheDir",0,function(e="images"){let t=new Date,o=`${t.getFullYear()}-${String(t.getMonth()+1).padStart(2,"0")}`,i=n.join(s,"cache","assistant",o,e);return a(i),r.mkdirSync(i,{recursive:!0}),i},"getAssistantCacheRoot",0,function(){let e=n.join(s,"cache","assistant");return a(e),e}])},214950,e=>{"use strict";var t=e.i(730358),r=e.i(70480),n=e.i(907338),s=e.i(976017),a=e.i(61776),o=e.i(973805),i=e.i(750012),l=e.i(986958),u=e.i(205236),c=e.i(748231),d=e.i(922554),p=e.i(841326),h=e.i(138459),m=e.i(157544),f=e.i(455548),g=e.i(193695);e.i(745561);var v=e.i(949568),w=e.i(383893),y=e.i(902157),x=e.i(750227);let _=/^\d{4}-\d{2}\/(images|files)\/[^/]+\.(jpg|jpeg|png|gif|webp)$/i;var b=e.i(480776),C=e.i(498445),S=e.i(429468);let A=new C.ClaudeCliAdapter;async function T(t){let r,n=(0,w.requireLocalhost)(t);if(n)return n;try{r=await t.json()}catch{return new Response(JSON.stringify({error:"Invalid JSON body"}),{status:400,headers:{"Content-Type":"application/json"}})}let s=/^\d{4}-\d{2}\/(images|files)\/[^/]+\.(jpg|jpeg|png|gif|webp)$/i,a=Array.isArray(r.imageFilenames)?r.imageFilenames.filter(e=>"string"==typeof e&&s.test(e)):[];if(!r.message?.trim()&&0===a.length)return new Response(JSON.stringify({error:"Message or images required"}),{status:400,headers:{"Content-Type":"application/json"}});let o=new ReadableStream({async start(t){let n=new TextEncoder;function s(e){t.enqueue(n.encode(`data: ${JSON.stringify(e)}
1
+ module.exports=[655315,(e,t,r)=>{t.exports=e.x("@prisma/client-ac1b8067b36ef9d3",()=>require("@prisma/client-ac1b8067b36ef9d3"))},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"))},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"))},383893,e=>{"use strict";var t=e.i(532087);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})}])},429468,e=>{"use strict";var t=e.i(655315);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])},831757,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 o=["CLAUDECODE","CLAUDE_CODE_ENTRYPOINT","CLAUDE_CODE_SESSION","CLAUDE_CODE_PARENT_SESSION"];async function i(e,t={}){let r=t.cwd??process.cwd(),a=t.env??process.env,o=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,o)?t:null}let l=a.PATH??a.Path??"",u=s(o)?";":":",c=l.split(u).filter(Boolean),d=s(o)?(a.PATHEXT??".EXE;.CMD;.BAT;.COM").split(";").filter(Boolean):[""],m=s(o)&&n.default.extname(e).length>0;for(let t of c)for(let r of s(o)?m?[n.default.join(t,e)]:d.map(r=>n.default.join(t,`${e}${r}`)):[n.default.join(t,e)])if(await p(r,o))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 i(e,r)??e,t,n,s)}function d(e,t,r,o){if(!s(o))return{command:e,args:t};let i=n.default.extname(e).toLowerCase();return".cmd"===i||".bat"===i||".com"===i?{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 m(e=process.platform){return s(e)?f():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),o=s.get(a)??0;s.set(a,o+1),o>0&&(a=`${a} (${o+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 f(){let e=[],t=[],r=await i("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 i("pwsh",{platform:"win32"});a&&e.push({name:"PowerShell",path:a});let o=process.env.windir??"C:\\WINDOWS",l=n.default.join(o,"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(o,"System32","cmd.exe");return await p(u,"win32")&&e.push({name:"Command Prompt",path:u}),e}let g=[{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 v(e=process.platform){if("darwin"===e){let t=[];for(let r of g)await p(`/Applications/${r.bundleName}.app`,e)&&t.push({name:r.name,value:r.bundleName});return t}if(s(e)){let t=[],r=await i("wt",{platform:e});return r&&t.push({name:"Windows Terminal",value:r}),t}return[]}e.s(["detectShells",0,m,"detectTerminalApps",0,v,"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,i,"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 o)delete t[e];return t}])},498445,e=>{"use strict";var t=e.i(902157),r=e.i(660526),n=e.i(750227),s=e.i(831757);let a=["sonnet","opus","haiku","claude-sonnet-4-6","claude-opus-4-6","claude-haiku-4-5-20251001"];e.s(["ClaudeCliAdapter",0,class{buildSpawnArgs(e){let t=["--dangerously-skip-permissions"];e.extraArgs?.length&&t.push(...e.extraArgs),e.resumeSessionId?t.push("--resume",e.resumeSessionId):e.continueLatest?t.push("--continue"):e.prompt&&t.push(e.prompt);let r={...e.envOverrides??{}};return{command:this.resolveCommand(),args:t,env:r}}buildEnvOverrides(e){let t={TOWER_TASK_ID:e.taskId,TOWER_TASK_TITLE:e.taskTitle,TOWER_STARTED_AT:new Date().toISOString(),TOWER_API_URL:e.apiUrl};return e.callbackUrl&&(t.CALLBACK_URL=e.callbackUrl),t}async installHooks(e){let t=this.readSettings(),r=t.hooks??{},s=this.getPostToolUseArray(t);if(this.findTowerHookIndex(s)>=0)return;let a=n.join(process.cwd(),"scripts","post-tool-hook.js"),o={hooks:[{command:`node "${a}"`,timeout:10,type:"command"}],matcher:"Write|Edit|MultiEdit"};t.hooks={...r,PostToolUse:[...s,o]},this.writeSettings(t)}async uninstallHooks(){let e=this.readSettings(),t=e.hooks??{},r=this.getPostToolUseArray(e).filter(e=>!e.hooks?.some(e=>e.command?.includes("post-tool-hook.js")));e.hooks={...t,PostToolUse:r},this.writeSettings(e)}async isHooksInstalled(){let e=this.readSettings(),t=this.getPostToolUseArray(e);return this.findTowerHookIndex(t)>=0}async isAvailable(){return null!==await this.getVersion()}async getVersion(){try{let{execFile:t}=await e.A(144264),{promisify:r}=await e.A(534777),n=r(t),s=this.resolveCommand(),{stdout:a}=await n(s,["--version"],{timeout:5e3});return a.trim()||null}catch{return null}}async getModels(){return a}getConfigDir(){return n.join(r.homedir(),".claude")}getSettingsPath(){return n.join(this.getConfigDir(),"settings.json")}getSessionsDir(){return n.join(this.getConfigDir(),"projects")}resolveCommand(){return process.env.CLAUDE_CODE_PATH?process.env.CLAUDE_CODE_PATH:(0,s.resolveCommandPathSync)("claude")}readSettings(){try{return JSON.parse(t.readFileSync(this.getSettingsPath(),"utf-8"))}catch{return{}}}writeSettings(e){let r=this.getConfigDir();t.existsSync(r)||t.mkdirSync(r,{recursive:!0}),t.writeFileSync(this.getSettingsPath(),JSON.stringify(e,null,2),"utf-8")}getPostToolUseArray(e){let t=e.hooks;if(!t)return[];let r=t.PostToolUse;return Array.isArray(r)?r:[]}findTowerHookIndex(e){return e.findIndex(e=>e.hooks?.some(e=>e.command?.includes("post-tool-hook.js")))}}])},660526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},679502,e=>{"use strict";let t;var r=e.i(750227),n=e.i(660526),s=e.i(902157);function a(){return t||(t=(0,r.join)((0,n.homedir)(),".tower"),(0,s.existsSync)(t)||(0,s.mkdirSync)(t,{recursive:!0})),t}e.s(["getAssistantDir",0,function(){let e=(0,r.join)(a(),"assistant");return(0,s.existsSync)(e)||(0,s.mkdirSync)(e,{recursive:!0}),e},"getStorageDir",0,function(){let e=(0,r.join)(a(),"storage");return(0,s.existsSync)(e)||(0,s.mkdirSync)(e,{recursive:!0}),e}])},666680,(e,t,r)=>{t.exports=e.x("node:crypto",()=>require("node:crypto"))},480776,e=>{"use strict";var t=e.i(666680),r=e.i(902157),n=e.i(750227);let s=(0,e.i(679502).getStorageDir)();function a(e){if(!e.startsWith(s+n.sep))throw Error("Path traversal detected")}let o=new Set(["image","screenshot","img","photo","picture","clipboard","paste","untitled"]);e.s(["buildCacheFilename",0,function(e,r){let s=n.basename(e,n.extname(e)),a=t.randomUUID().replace(/-/g,"").slice(0,8),i=s.toLowerCase();if(!s||o.has(i)||/^screenshot[\s_\-]/i.test(s))return`tower_image-${a}${r}`;let l=s.replace(/[^\p{L}\p{N}]/gu,"_").replace(/_+/g,"_").replace(/^_+|_+$/g,"");return`${l||"file"}-${a}${r}`},"ensureAssetsDir",0,function(e){let t,o=(a(t=n.join(s,"assets",e)),t);return r.mkdirSync(o,{recursive:!0}),o},"getAssistantCacheDir",0,function(e="images"){let t=new Date,o=`${t.getFullYear()}-${String(t.getMonth()+1).padStart(2,"0")}`,i=n.join(s,"cache","assistant",o,e);return a(i),r.mkdirSync(i,{recursive:!0}),i},"getAssistantCacheRoot",0,function(){let e=n.join(s,"cache","assistant");return a(e),e}])},214950,e=>{"use strict";var t=e.i(730358),r=e.i(70480),n=e.i(907338),s=e.i(976017),a=e.i(61776),o=e.i(973805),i=e.i(750012),l=e.i(986958),u=e.i(205236),c=e.i(748231),d=e.i(922554),p=e.i(841326),m=e.i(138459),h=e.i(157544),f=e.i(455548),g=e.i(193695);e.i(745561);var v=e.i(949568),w=e.i(383893),y=e.i(902157),x=e.i(750227);let _=/^\d{4}-\d{2}\/(images|files)\/[^/]+\.(jpg|jpeg|png|gif|webp)$/i;var b=e.i(480776),C=e.i(498445),S=e.i(429468);let A=new C.ClaudeCliAdapter;async function T(t){let r,n=(0,w.requireLocalhost)(t);if(n)return n;try{r=await t.json()}catch{return new Response(JSON.stringify({error:"Invalid JSON body"}),{status:400,headers:{"Content-Type":"application/json"}})}let s=/^\d{4}-\d{2}\/(images|files)\/[^/]+\.(jpg|jpeg|png|gif|webp)$/i,a=Array.isArray(r.imageFilenames)?r.imageFilenames.filter(e=>"string"==typeof e&&s.test(e)):[];if(!r.message?.trim()&&0===a.length)return new Response(JSON.stringify({error:"Message or images required"}),{status:400,headers:{"Content-Type":"application/json"}});let o=new ReadableStream({async start(t){let n=new TextEncoder;function s(e){t.enqueue(n.encode(`data: ${JSON.stringify(e)}
2
2
 
3
3
  `))}try{let{query:t}=await e.A(118534),n=A.resolveCommand(),{ensureTowerDir:o}=await e.A(777705),i=o(),l=a.length>0,u={tools:l?["Read"]:[],allowedTools:l?["mcp__tower__*","Read"]:["mcp__tower__*"],includePartialMessages:!0,cwd:i,pathToClaudeCodeExecutable:n};r.sessionId&&(u.resume=r.sessionId);let c="";if(!r.sessionId){let e=await S.db.systemConfig.findUnique({where:{key:"onboarding.username"}});try{let t=e?JSON.parse(e.value):null;"string"==typeof t&&t.length>0&&(c=`[Context: The user's name is ${t}.]
4
4
 
@@ -6,6 +6,6 @@ module.exports=[655315,(e,t,r)=>{t.exports=e.x("@prisma/client-ac1b8067b36ef9d3"
6
6
 
7
7
  ---
8
8
  The user has attached the following image(s). Use the Read tool to view them:
9
- ${o}`}(d,a,(0,b.getAssistantCacheRoot)()):d;for await(let e of t({prompt:p,options:u}))switch(e.type){case"assistant":{let t=e.message.content.filter(e=>"text"===e.type).map(e=>e.text??"").join(""),r=e.message.content.filter(e=>"tool_use"===e.type);for(let n of(t&&s({type:"text",content:t,sessionId:e.session_id}),r))s({type:"tool_use",content:n.name??"unknown",toolInput:n.input,sessionId:e.session_id});break}case"result":e.subtype?.includes("error")&&s({type:"error",content:e.error??"Execution error"}),s({type:"done",sessionId:e.session_id});break;case"system":"tool_result"===e.subtype&&s({type:"tool_result",content:e.tool_name??"tool",toolOutput:e.content??""});break;case"stream_event":{let t=e.event;"content_block_delta"===t.type&&t.delta?.type==="text_delta"&&t.delta.text?s({type:"text_delta",content:t.delta.text,sessionId:e.session_id}):"content_block_start"===t.type&&t.content_block?.type==="tool_use"&&s({type:"tool_start",content:t.content_block.name??"tool",sessionId:e.session_id})}}}catch(e){s({type:"error",content:"Assistant encountered an error. Please try again."})}finally{s({type:"done"}),t.close()}}});return new Response(o,{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}})}e.s(["POST",0,T,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],961351);var R=e.i(961351);let E=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/internal/assistant/chat/route",pathname:"/api/internal/assistant/chat",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/project/f/tower/src/app/api/internal/assistant/chat/route.ts",nextConfigOutput:"",userland:R}),{workAsyncStorage:k,workUnitAsyncStorage:P,serverHooks:j}=E;async function I(e,t,n){n.requestMeta&&(0,s.setRequestMeta)(e,n.requestMeta),E.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let w="/api/internal/assistant/chat/route";w=w.replace(/\/index$/,"")||"/";let y=await E.prepare(e,t,{srcPage:w,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:x,params:_,nextConfig:b,parsedUrl:C,isDraftMode:S,prerenderManifest:A,routerServerContext:T,isOnDemandRevalidate:R,revalidateOnlyGenerated:k,resolvedPathname:P,clientReferenceManifest:j,serverActionsManifest:I}=y,N=(0,i.normalizeAppPath)(w),O=!!(A.dynamicRoutes[N]||A.routes[P]),D=async()=>((null==T?void 0:T.render404)?await T.render404(e,t,C,!1):t.end("This page could not be found"),null);if(O&&!S){let e=!!A.routes[P],t=A.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(b.adapterPath)return await D();throw new g.NoFallbackError}}let U=null;!O||E.isDev||S||(U="/index"===(U=P)?"/":U);let $=!0===E.isDev||!O,q=O&&!$;I&&j&&(0,o.setManifestsSingleton)({page:w,clientReferenceManifest:j,serverActionsManifest:I});let H=e.method||"GET",L=(0,a.getTracer)(),W=L.getActiveScopeSpan(),M=!!(null==T?void 0:T.isWrappedByNextServer),F=!!(0,s.getRequestMeta)(e,"minimalMode"),B=(0,s.getRequestMeta)(e,"incrementalCache")||await E.getIncrementalCache(e,b,A,F);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let K={params:_,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!b.experimental.authInterrupts},cacheComponents:!!b.cacheComponents,supportsDynamicResponse:$,incrementalCache:B,cacheLifeProfiles:b.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,s)=>E.onRequestError(e,t,n,s,T)},sharedContext:{buildId:x}},G=new l.NodeNextRequest(e),J=new l.NodeNextResponse(t),z=u.NextRequestAdapter.fromNodeNextRequest(G,(0,u.signalFromNodeResponse)(t));try{let s,o=async e=>E.handle(z,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=L.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==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=`${H} ${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(`${H} ${w}`)}),i=async s=>{var a,i;let l=async({previousCacheEntry:r})=>{try{if(!F&&R&&k&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await o(s);e.fetchMetrics=K.renderOpts.fetchMetrics;let i=K.renderOpts.pendingWaitUntil;i&&n.waitUntil&&(n.waitUntil(i),i=void 0);let l=K.renderOpts.collectedTags;if(!O)return await (0,p.sendResponse)(G,J,a,K.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(a.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,n=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:v.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 E.onRequestError(e,t,{routerKind:"App Router",routePath:w,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:R})},!1,T),t}},u=await E.handleResponse({req:e,nextConfig:b,cacheKey:U,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:R,revalidateOnlyGenerated:k,responseGenerator:l,waitUntil:n.waitUntil,isMinimalMode:F});if(!O)return null;if((null==u||null==(a=u.value)?void 0:a.kind)!==v.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(i=u.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});F||t.setHeader("x-nextjs-cache",R?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),S&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,h.fromNodeOutgoingHttpHeaders)(u.value.headers);return F&&O||c.delete(f.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||c.get("Cache-Control")||c.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(G,J,new Response(u.value.body,{headers:c,status:u.value.status||200})),null};M&&W?await i(W):(s=L.getActiveScopeSpan(),await L.withPropagatedContext(e.headers,()=>L.trace(c.BaseServerSpan.handleRequest,{spanName:`${H} ${w}`,kind:a.SpanKind.SERVER,attributes:{"http.method":H,"http.target":e.url}},i),void 0,!M))}catch(t){if(t instanceof g.NoFallbackError||await E.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:R})},!1,T),O)throw t;return await (0,p.sendResponse)(G,J,new Response(null,{status:500})),null}}e.s(["handler",0,I,"patchFetch",0,function(){return(0,n.patchFetch)({workAsyncStorage:k,workUnitAsyncStorage:P})},"routeModule",0,E,"serverHooks",0,j,"workAsyncStorage",0,k,"workUnitAsyncStorage",0,P],214950)},144264,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_child_process_0pwkpv9._.js"].map(t=>e.l(t))).then(()=>t(233405)))},534777,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_util_0wtvqkc._.js"].map(t=>e.l(t))).then(()=>t(224361)))},118534,e=>{e.v(t=>Promise.all(["server/chunks/[externals]__11rejr-._.js","server/chunks/0b0n_@anthropic-ai_claude-agent-sdk_sdk_mjs_0wzx_-c._.js"].map(t=>e.l(t))).then(()=>t(210664)))},777705,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0k6_.b8._.js"].map(t=>e.l(t))).then(()=>t(40054)))}];
9
+ ${o}`}(d,a,(0,b.getAssistantCacheRoot)()):d;for await(let e of t({prompt:p,options:u}))switch(e.type){case"assistant":{let t=e.message.content.filter(e=>"text"===e.type).map(e=>e.text??"").join(""),r=e.message.content.filter(e=>"tool_use"===e.type);for(let n of(t&&s({type:"text",content:t,sessionId:e.session_id}),r))s({type:"tool_use",content:n.name??"unknown",toolInput:n.input,sessionId:e.session_id});break}case"result":e.subtype?.includes("error")&&s({type:"error",content:e.error??"Execution error"}),s({type:"done",sessionId:e.session_id});break;case"system":"tool_result"===e.subtype&&s({type:"tool_result",content:e.tool_name??"tool",toolOutput:e.content??""});break;case"stream_event":{let t=e.event;"content_block_delta"===t.type&&t.delta?.type==="text_delta"&&t.delta.text?s({type:"text_delta",content:t.delta.text,sessionId:e.session_id}):"content_block_start"===t.type&&t.content_block?.type==="tool_use"&&s({type:"tool_start",content:t.content_block.name??"tool",sessionId:e.session_id})}}}catch(e){s({type:"error",content:"Assistant encountered an error. Please try again."})}finally{s({type:"done"}),t.close()}}});return new Response(o,{headers:{"Content-Type":"text/event-stream","Cache-Control":"no-cache",Connection:"keep-alive"}})}e.s(["POST",0,T,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],961351);var R=e.i(961351);let E=new t.AppRouteRouteModule({definition:{kind:r.RouteKind.APP_ROUTE,page:"/api/internal/assistant/chat/route",pathname:"/api/internal/assistant/chat",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/project/f/tower/src/app/api/internal/assistant/chat/route.ts",nextConfigOutput:"",userland:R}),{workAsyncStorage:k,workUnitAsyncStorage:P,serverHooks:j}=E;async function I(e,t,n){n.requestMeta&&(0,s.setRequestMeta)(e,n.requestMeta),E.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let w="/api/internal/assistant/chat/route";w=w.replace(/\/index$/,"")||"/";let y=await E.prepare(e,t,{srcPage:w,multiZoneDraftMode:!1});if(!y)return t.statusCode=400,t.end("Bad Request"),null==n.waitUntil||n.waitUntil.call(n,Promise.resolve()),null;let{buildId:x,params:_,nextConfig:b,parsedUrl:C,isDraftMode:S,prerenderManifest:A,routerServerContext:T,isOnDemandRevalidate:R,revalidateOnlyGenerated:k,resolvedPathname:P,clientReferenceManifest:j,serverActionsManifest:I}=y,N=(0,i.normalizeAppPath)(w),O=!!(A.dynamicRoutes[N]||A.routes[P]),D=async()=>((null==T?void 0:T.render404)?await T.render404(e,t,C,!1):t.end("This page could not be found"),null);if(O&&!S){let e=!!A.routes[P],t=A.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(b.adapterPath)return await D();throw new g.NoFallbackError}}let U=null;!O||E.isDev||S||(U="/index"===(U=P)?"/":U);let $=!0===E.isDev||!O,q=O&&!$;I&&j&&(0,o.setManifestsSingleton)({page:w,clientReferenceManifest:j,serverActionsManifest:I});let H=e.method||"GET",L=(0,a.getTracer)(),W=L.getActiveScopeSpan(),M=!!(null==T?void 0:T.isWrappedByNextServer),F=!!(0,s.getRequestMeta)(e,"minimalMode"),B=(0,s.getRequestMeta)(e,"incrementalCache")||await E.getIncrementalCache(e,b,A,F);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let K={params:_,previewProps:A.preview,renderOpts:{experimental:{authInterrupts:!!b.experimental.authInterrupts},cacheComponents:!!b.cacheComponents,supportsDynamicResponse:$,incrementalCache:B,cacheLifeProfiles:b.cacheLife,waitUntil:n.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,n,s)=>E.onRequestError(e,t,n,s,T)},sharedContext:{buildId:x}},G=new l.NodeNextRequest(e),J=new l.NodeNextResponse(t),z=u.NextRequestAdapter.fromNodeNextRequest(G,(0,u.signalFromNodeResponse)(t));try{let s,o=async e=>E.handle(z,K).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let r=L.getRootSpanAttributes();if(!r)return;if(r.get("next.span_type")!==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=`${H} ${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(`${H} ${w}`)}),i=async s=>{var a,i;let l=async({previousCacheEntry:r})=>{try{if(!F&&R&&k&&!r)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let a=await o(s);e.fetchMetrics=K.renderOpts.fetchMetrics;let i=K.renderOpts.pendingWaitUntil;i&&n.waitUntil&&(n.waitUntil(i),i=void 0);let l=K.renderOpts.collectedTags;if(!O)return await (0,p.sendResponse)(G,J,a,K.renderOpts.pendingWaitUntil),null;{let e=await a.blob(),t=(0,m.toNodeOutgoingHttpHeaders)(a.headers);l&&(t[f.NEXT_CACHE_TAGS_HEADER]=l),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let r=void 0!==K.renderOpts.collectedRevalidate&&!(K.renderOpts.collectedRevalidate>=f.INFINITE_CACHE)&&K.renderOpts.collectedRevalidate,n=void 0===K.renderOpts.collectedExpire||K.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:K.renderOpts.collectedExpire;return{value:{kind:v.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 E.onRequestError(e,t,{routerKind:"App Router",routePath:w,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:R})},!1,T),t}},u=await E.handleResponse({req:e,nextConfig:b,cacheKey:U,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:A,isRoutePPREnabled:!1,isOnDemandRevalidate:R,revalidateOnlyGenerated:k,responseGenerator:l,waitUntil:n.waitUntil,isMinimalMode:F});if(!O)return null;if((null==u||null==(a=u.value)?void 0:a.kind)!==v.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==u||null==(i=u.value)?void 0:i.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});F||t.setHeader("x-nextjs-cache",R?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),S&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let c=(0,m.fromNodeOutgoingHttpHeaders)(u.value.headers);return F&&O||c.delete(f.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)(G,J,new Response(u.value.body,{headers:c,status:u.value.status||200})),null};M&&W?await i(W):(s=L.getActiveScopeSpan(),await L.withPropagatedContext(e.headers,()=>L.trace(c.BaseServerSpan.handleRequest,{spanName:`${H} ${w}`,kind:a.SpanKind.SERVER,attributes:{"http.method":H,"http.target":e.url}},i),void 0,!M))}catch(t){if(t instanceof g.NoFallbackError||await E.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,d.getRevalidateReason)({isStaticGeneration:q,isOnDemandRevalidate:R})},!1,T),O)throw t;return await (0,p.sendResponse)(G,J,new Response(null,{status:500})),null}}e.s(["handler",0,I,"patchFetch",0,function(){return(0,n.patchFetch)({workAsyncStorage:k,workUnitAsyncStorage:P})},"routeModule",0,E,"serverHooks",0,j,"workAsyncStorage",0,k,"workUnitAsyncStorage",0,P],214950)},144264,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_child_process_0pwkpv9._.js"].map(t=>e.l(t))).then(()=>t(233405)))},534777,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_util_0wtvqkc._.js"].map(t=>e.l(t))).then(()=>t(224361)))},118534,e=>{e.v(t=>Promise.all(["server/chunks/[externals]__11rejr-._.js","server/chunks/0b0n_@anthropic-ai_claude-agent-sdk_sdk_mjs_0wzx_-c._.js"].map(t=>e.l(t))).then(()=>t(210664)))},777705,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0k6_.b8._.js"].map(t=>e.l(t))).then(()=>t(40054)))}];
10
10
 
11
11
  //# sourceMappingURL=%5Broot-of-the-server%5D__0p5iuez._.js.map
@@ -0,0 +1,4 @@
1
+ module.exports=[660526,(e,t,r)=>{t.exports=e.x("node:os",()=>require("node:os"))},655315,(e,t,r)=>{t.exports=e.x("@prisma/client-ac1b8067b36ef9d3",()=>require("@prisma/client-ac1b8067b36ef9d3"))},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"))},456551,(e,t,r)=>{t.exports=e.x("node-pty-0c54088e7263f93d",()=>require("node-pty-0c54088e7263f93d"))},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"))},383893,e=>{"use strict";var t=e.i(532087);let r=["localhost","127.0.0.1","[::1]"],s=new Set(["127.0.0.1","::1","::ffff:127.0.0.1"]),n=/^c[a-z0-9]{20,30}$/;e.s(["requireLocalhost",0,function(e){let n=e.headers.get("x-forwarded-for");if(n&&!n.split(",").map(e=>e.trim()).every(e=>s.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 n.test(e)?null:t.NextResponse.json({error:"Invalid projectId format"},{status:400})},"validateTaskId",0,function(e){return n.test(e)?null:t.NextResponse.json({error:"Invalid taskId format"},{status:400})}])},498445,e=>{"use strict";var t=e.i(902157),r=e.i(660526),s=e.i(750227),n=e.i(831757);let i=["sonnet","opus","haiku","claude-sonnet-4-6","claude-opus-4-6","claude-haiku-4-5-20251001"];e.s(["ClaudeCliAdapter",0,class{buildSpawnArgs(e){let t=["--dangerously-skip-permissions"];e.extraArgs?.length&&t.push(...e.extraArgs),e.resumeSessionId?t.push("--resume",e.resumeSessionId):e.continueLatest?t.push("--continue"):e.prompt&&t.push(e.prompt);let r={...e.envOverrides??{}};return{command:this.resolveCommand(),args:t,env:r}}buildEnvOverrides(e){let t={TOWER_TASK_ID:e.taskId,TOWER_TASK_TITLE:e.taskTitle,TOWER_STARTED_AT:new Date().toISOString(),TOWER_API_URL:e.apiUrl};return e.callbackUrl&&(t.CALLBACK_URL=e.callbackUrl),t}async installHooks(e){let t=this.readSettings(),r=t.hooks??{},n=this.getPostToolUseArray(t);if(this.findTowerHookIndex(n)>=0)return;let i=s.join(process.cwd(),"scripts","post-tool-hook.js"),a={hooks:[{command:`node "${i}"`,timeout:10,type:"command"}],matcher:"Write|Edit|MultiEdit"};t.hooks={...r,PostToolUse:[...n,a]},this.writeSettings(t)}async uninstallHooks(){let e=this.readSettings(),t=e.hooks??{},r=this.getPostToolUseArray(e).filter(e=>!e.hooks?.some(e=>e.command?.includes("post-tool-hook.js")));e.hooks={...t,PostToolUse:r},this.writeSettings(e)}async isHooksInstalled(){let e=this.readSettings(),t=this.getPostToolUseArray(e);return this.findTowerHookIndex(t)>=0}async isAvailable(){return null!==await this.getVersion()}async getVersion(){try{let{execFile:t}=await e.A(144264),{promisify:r}=await e.A(534777),s=r(t),n=this.resolveCommand(),{stdout:i}=await s(n,["--version"],{timeout:5e3});return i.trim()||null}catch{return null}}async getModels(){return i}getConfigDir(){return s.join(r.homedir(),".claude")}getSettingsPath(){return s.join(this.getConfigDir(),"settings.json")}getSessionsDir(){return s.join(this.getConfigDir(),"projects")}resolveCommand(){return process.env.CLAUDE_CODE_PATH?process.env.CLAUDE_CODE_PATH:(0,n.resolveCommandPathSync)("claude")}readSettings(){try{return JSON.parse(t.readFileSync(this.getSettingsPath(),"utf-8"))}catch{return{}}}writeSettings(e){let r=this.getConfigDir();t.existsSync(r)||t.mkdirSync(r,{recursive:!0}),t.writeFileSync(this.getSettingsPath(),JSON.stringify(e,null,2),"utf-8")}getPostToolUseArray(e){let t=e.hooks;if(!t)return[];let r=t.PostToolUse;return Array.isArray(r)?r:[]}findTowerHookIndex(e){return e.findIndex(e=>e.hooks?.some(e=>e.command?.includes("post-tool-hook.js")))}}])},831757,e=>{"use strict";var t=e.i(902157),r=e.i(874533),s=e.i(750227);function n(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=s.default.isAbsolute(e)?e:s.default.resolve(r,e);return await p(t,a)?t:null}let l=i.PATH??i.Path??"",u=n(a)?";":":",d=l.split(u).filter(Boolean),c=n(a)?(i.PATHEXT??".EXE;.CMD;.BAT;.COM").split(";").filter(Boolean):[""],h=n(a)&&s.default.extname(e).length>0;for(let t of d)for(let r of n(a)?h?[s.default.join(t,e)]:c.map(r=>s.default.join(t,`${e}${r}`)):[s.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(s.default.extname(e)||e.includes("/")||e.includes("\\")||!n(t))return e;try{let t=r(`where ${e}`).trim().split("\n").map(e=>e.trim()).filter(Boolean),s=t.find(e=>/\.(cmd|bat|exe)$/i.test(e));if(s)return s;if(t.length>0)return t[0]}catch{}return e}async function d(e,t,r={}){let s=r.env??process.env,n=r.platform??process.platform;return c(await o(e,r)??e,t,s,n)}function c(e,t,r,a){if(!n(a))return{command:e,args:t};let o=s.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,n(r)?t.constants.F_OK:t.constants.X_OK),!0}catch{return!1}}async function h(e=process.platform){return n(e)?f():m()}async function m(){try{let e=await t.promises.readFile("/etc/shells","utf-8"),r=[],n=new Map;for(let t of e.split("\n")){let e=t.replace(/#.*/,"").trim();if(!e||!e.startsWith("/")||!await p(e))continue;let i=s.default.basename(e),a=n.get(i)??0;n.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:s.default.basename(t),path:t});return e}}async function f(){let e=[],t=[],r=await o("git",{platform:"win32"});if(r){let e=s.default.resolve(s.default.dirname(r),"..","..");t.push(s.default.join(e,"bin","bash.exe"),s.default.join(e,"usr","bin","bash.exe"))}for(let e of[process.env.ProgramW6432,process.env.ProgramFiles,process.env["ProgramFiles(x86)"],process.env.LocalAppData?s.default.join(process.env.LocalAppData,"Programs"):null].filter(Boolean))t.push(s.default.join(e,"Git","bin","bash.exe"),s.default.join(e,"Git","usr","bin","bash.exe"));let n=process.env.USERPROFILE??"";for(let r of(n&&t.push(s.default.join(n,"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=s.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??s.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 g(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(n(e)){let t=[],r=await o("wt",{platform:e});return r&&t.push({name:"Windows Terminal",value:r}),t}return[]}e.s(["detectShells",0,h,"detectTerminalApps",0,g,"ensurePathInEnv",0,function(e,t=process.platform){let r=n(t)?"Path":"PATH";return(e.PATH??e.Path??"").length>0?e:{...e,[r]:function(e=process.platform){return n(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,d,"resolveSpawnTargetSync",0,function(e,t,r=process.platform,s){return c(u(e,r,s),t,process.env,r)},"stripClaudeNestingEnv",0,function(e){let t={...e};for(let e of a)delete t[e];return t}])},707940,e=>{"use strict";var t=e.i(456551),r=e.i(831757);class s{taskId;_pty;killed=!1;disconnectTimer=null;_buffer="";static BUFFER_MAX=51200;_onData;_exitListeners=[];_idleTimer=null;_idleThresholdMs;_onIdle;_idleFired=!1;constructor(e,n,i,a,o,l,u,d,c){this.taskId=e,this._onData=o,this._onIdle=d??null,this._idleThresholdMs=Math.max(c??18e4,18e4);const p=(0,r.stripClaudeNestingEnv)((0,r.ensurePathInEnv)(process.env));this._pty=t.spawn(n,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>s.BUFFER_MAX&&(this._buffer=this._buffer.slice(this._buffer.length-s.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 n=globalThis;n.__ptySessions||(n.__ptySessions=new Map);let i=n.__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,n,o,l,u,d,c,p){a(e);let{command:h,args:m}=(0,r.resolveSpawnTargetSync)(t,n),f=new s(e,h,m,o,l,u,d,c,p);return i.set(e,f),f},"destroySession",0,a,"getSession",0,function(e){return i.get(e)}],707940)},429468,e=>{"use strict";var t=e.i(655315);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])},987300,e=>{"use strict";var t=e.i(429468);async function r(e,r){let s=await t.db.systemConfig.findUnique({where:{key:e}});if(!s)return r;try{return JSON.parse(s.value)}catch{return r}}e.s(["readConfigValue",0,r])},575572,(e,t,r)=>{"use strict";t.exports=e.r(585005).vendored["react-rsc"].ReactServerDOMTurbopackServer},236422,(e,t,r)=>{"use strict";Object.defineProperty(r,"__esModule",{value:!0}),Object.defineProperty(r,"registerServerReference",{enumerable:!0,get:function(){return s.registerServerReference}});let s=e.r(575572)},12421,(e,t,r)=>{"use strict";function s(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 s}})},254799,(e,t,r)=>{t.exports=e.x("crypto",()=>require("crypto"))},984629,e=>{"use strict";var t=e.i(429468);class r{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 r=this.providers.get(e);return r?"api"===t?r.api?.adapter??null:r.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 r=!!t.cli&&await t.cli.adapter.isAvailable(),s=r&&t.cli?await t.cli.adapter.getVersion():null,n=!!t.api&&!!process.env[t.api.keyEnvVar],i=!!t.api&&n;e.push({name:t.name,displayName:t.displayName,cli:{available:r,version:s},api:{available:i,keyConfigured:n}})}return e}}var s=e.i(498445);let n=globalThis;if(!n.__providerRegistry){let e=new r;e.register({name:"claude",displayName:"Claude Code",agentFieldValue:"CLAUDE_CODE",cli:{command:"claude",adapter:new s.ClaudeCliAdapter},models:{cli:["sonnet","opus","haiku","claude-sonnet-4-6","claude-opus-4-6","claude-haiku-4-5-20251001"],api:[]}}),n.__providerRegistry=e}let i=n.__providerRegistry;class a extends Error{code;provider;constructor(e,t,r){super(r),this.code=e,this.provider=t,this.name="AiProviderError"}}async function o(e){return t.db.aiCapabilityConfig.findUnique({where:{slot:e}})}async function l(e){let t=await o(e),r=t?.provider??"claude",s=t?.model??void 0,n=i.get(r);if(!n)throw new a("CLI_NOT_FOUND",r,`Provider "${r}" 未注册`);let l=n.cli?.adapter;if(!l)throw new a("UNSUPPORTED_MODE",r,`Provider "${r}" 不支持 CLI 模式`);return{adapter:l,provider:n,model:s}}e.s(["resolveCliAdapter",0,l],984629)},521220,e=>{"use strict";var t=e.i(730358),r=e.i(70480),s=e.i(907338),n=e.i(976017),i=e.i(61776),a=e.i(973805),o=e.i(750012),l=e.i(986958),u=e.i(205236),d=e.i(748231),c=e.i(922554),p=e.i(841326),h=e.i(138459),m=e.i(157544),f=e.i(455548),v=e.i(193695);e.i(745561);var g=e.i(949568),y=e.i(532087),_=e.i(383893),w=e.i(236422),x=e.i(254799),T=e.i(707940),b=e.i(987300),E=e.i(984629);let S="__assistant__";async function C(e){(0,T.destroySession)(S);let{adapter:t}=await (0,E.resolveCliAdapter)("terminal"),r=await (0,b.readConfigValue)("assistant.systemPrompt","You are Tower Assistant, an AI operator for the Tower task management platform."),s=process.cwd(),n=["--allowedTools","mcp__tower__*","--append-system-prompt",r];e?n.push("--resume",e):n.push("--session-id",(0,x.randomUUID)());let i=t.buildSpawnArgs({taskId:S,prompt:"",cwd:s,extraArgs:n});(0,T.createSession)(S,i.command,i.args,s,()=>{},()=>{},i.env)}async function R(){(0,T.destroySession)(S)}async function A(){let e=(0,T.getSession)(S);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 C(t),y.NextResponse.json({ok:!0,sessionKey:S,sessionId:t??null})}catch(t){let e=t instanceof Error?t.message:String(t);return y.NextResponse.json({error:e},{status:500})}}async function k(e){let t=(0,_.requireLocalhost)(e);return t||(await R(),y.NextResponse.json({ok:!0}))}async function I(e){let t=(0,_.requireLocalhost)(e);if(t)return t;let r=await A();return y.NextResponse.json({status:r})}(0,e.i(12421).ensureServerEntryExports)([C,R,A]),(0,w.registerServerReference)(C,"4000ae1fd2be4a38197c9b350822d5053c2e2611bb",null),(0,w.registerServerReference)(R,"00730421523d95b1cf56307b54495515bb00f51802",null),(0,w.registerServerReference)(A,"006e0c81ab0daa1be16aa8e703473aede589900c8a",null),e.s(["DELETE",0,k,"GET",0,I,"POST",0,P,"dynamic",0,"force-dynamic","runtime",0,"nodejs"],528426);var N=e.i(528426);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]/project/f/tower/src/app/api/internal/assistant/route.ts",nextConfigOutput:"",userland:N}),{workAsyncStorage:j,workUnitAsyncStorage:D,serverHooks:U}=O;async function q(e,t,s){s.requestMeta&&(0,n.setRequestMeta)(e,s.requestMeta),O.isDev&&(0,n.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let y="/api/internal/assistant/route";y=y.replace(/\/index$/,"")||"/";let _=await O.prepare(e,t,{srcPage:y,multiZoneDraftMode:!1});if(!_)return t.statusCode=400,t.end("Bad Request"),null==s.waitUntil||s.waitUntil.call(s,Promise.resolve()),null;let{buildId:w,params:x,nextConfig:T,parsedUrl:b,isDraftMode:E,prerenderManifest:S,routerServerContext:C,isOnDemandRevalidate:R,revalidateOnlyGenerated:A,resolvedPathname:P,clientReferenceManifest:k,serverActionsManifest:I}=_,N=(0,o.normalizeAppPath)(y),j=!!(S.dynamicRoutes[N]||S.routes[P]),D=async()=>((null==C?void 0:C.render404)?await C.render404(e,t,b,!1):t.end("This page could not be found"),null);if(j&&!E){let e=!!S.routes[P],t=S.dynamicRoutes[N];if(t&&!1===t.fallback&&!e){if(T.adapterPath)return await D();throw new v.NoFallbackError}}let U=null;!j||O.isDev||E||(U="/index"===(U=P)?"/":U);let q=!0===O.isDev||!j,M=j&&!q;I&&k&&(0,a.setManifestsSingleton)({page:y,clientReferenceManifest:k,serverActionsManifest:I});let L=e.method||"GET",H=(0,i.getTracer)(),F=H.getActiveScopeSpan(),W=!!(null==C?void 0:C.isWrappedByNextServer),$=!!(0,n.getRequestMeta)(e,"minimalMode"),B=(0,n.getRequestMeta)(e,"incrementalCache")||await O.getIncrementalCache(e,T,S,$);null==B||B.resetRequestCache(),globalThis.__incrementalCache=B;let G={params:x,previewProps:S.preview,renderOpts:{experimental:{authInterrupts:!!T.experimental.authInterrupts},cacheComponents:!!T.cacheComponents,supportsDynamicResponse:q,incrementalCache:B,cacheLifeProfiles:T.cacheLife,waitUntil:s.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,r,s,n)=>O.onRequestError(e,t,s,n,C)},sharedContext:{buildId:w}},K=new l.NodeNextRequest(e),V=new l.NodeNextResponse(t),X=u.NextRequestAdapter.fromNodeNextRequest(K,(0,u.signalFromNodeResponse)(t));try{let n,a=async e=>O.handle(X,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")!==d.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${r.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let s=r.get("next.route");if(s){let t=`${L} ${s}`;e.setAttributes({"next.route":s,"http.route":s,"next.span_name":t}),e.updateName(t),n&&n!==e&&(n.setAttribute("http.route",s),n.updateName(t))}else e.updateName(`${L} ${y}`)}),o=async n=>{var i,o;let l=async({previousCacheEntry:r})=>{try{if(!$&&R&&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(n);e.fetchMetrics=G.renderOpts.fetchMetrics;let o=G.renderOpts.pendingWaitUntil;o&&s.waitUntil&&(s.waitUntil(o),o=void 0);let l=G.renderOpts.collectedTags;if(!j)return await (0,p.sendResponse)(K,V,i,G.renderOpts.pendingWaitUntil),null;{let e=await i.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(i.headers);l&&(t[f.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>=f.INFINITE_CACHE)&&G.renderOpts.collectedRevalidate,s=void 0===G.renderOpts.collectedExpire||G.renderOpts.collectedExpire>=f.INFINITE_CACHE?void 0:G.renderOpts.collectedExpire;return{value:{kind:g.CachedRouteKind.APP_ROUTE,status:i.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:r,expire:s}}}}catch(t){throw(null==r?void 0:r.isStale)&&await O.onRequestError(e,t,{routerKind:"App Router",routePath:y,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:R})},!1,C),t}},u=await O.handleResponse({req:e,nextConfig:T,cacheKey:U,routeKind:r.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:S,isRoutePPREnabled:!1,isOnDemandRevalidate:R,revalidateOnlyGenerated:A,responseGenerator:l,waitUntil:s.waitUntil,isMinimalMode:$});if(!j)return null;if((null==u||null==(i=u.value)?void 0:i.kind)!==g.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});$||t.setHeader("x-nextjs-cache",R?"REVALIDATED":u.isMiss?"MISS":u.isStale?"STALE":"HIT"),E&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(u.value.headers);return $&&j||d.delete(f.NEXT_CACHE_TAGS_HEADER),!u.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,m.getCacheControlHeader)(u.cacheControl)),await (0,p.sendResponse)(K,V,new Response(u.value.body,{headers:d,status:u.value.status||200})),null};W&&F?await o(F):(n=H.getActiveScopeSpan(),await H.withPropagatedContext(e.headers,()=>H.trace(d.BaseServerSpan.handleRequest,{spanName:`${L} ${y}`,kind:i.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!W))}catch(t){if(t instanceof v.NoFallbackError||await O.onRequestError(e,t,{routerKind:"App Router",routePath:N,routeType:"route",revalidateReason:(0,c.getRevalidateReason)({isStaticGeneration:M,isOnDemandRevalidate:R})},!1,C),j)throw t;return await (0,p.sendResponse)(K,V,new Response(null,{status:500})),null}}e.s(["handler",0,q,"patchFetch",0,function(){return(0,s.patchFetch)({workAsyncStorage:j,workUnitAsyncStorage:D})},"routeModule",0,O,"serverHooks",0,U,"workAsyncStorage",0,j,"workUnitAsyncStorage",0,D],521220)},144264,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_child_process_0pwkpv9._.js"].map(t=>e.l(t))).then(()=>t(233405)))},534777,e=>{e.v(t=>Promise.all(["server/chunks/[externals]_util_0wtvqkc._.js"].map(t=>e.l(t))).then(()=>t(224361)))}];
3
+
4
+ //# sourceMappingURL=%5Broot-of-the-server%5D__0rb-ear._.js.map
@@ -1,3 +1,3 @@
1
- module.exports=[587619,e=>{"use strict";let t=[{mime:"image/jpeg",check:e=>255===e[0]&&216===e[1]&&255===e[2]},{mime:"image/png",check:e=>137===e[0]&&80===e[1]&&78===e[2]&&71===e[3]},{mime:"image/gif",check:e=>71===e[0]&&73===e[1]&&70===e[2]},{mime:"image/webp",check:e=>82===e[0]&&73===e[1]&&70===e[2]&&70===e[3]&&87===e[8]&&69===e[9]&&66===e[10]&&80===e[11]}];e.s(["MIME_TO_EXT",0,{"image/jpeg":".jpg","image/png":".png","image/gif":".gif","image/webp":".webp"},"detectImageMime",0,function(e){if(e.length<12)return null;for(let a of t)if(a.check(e))return a.mime;return null}])},528913,e=>{"use strict";e.s(["CONFIG_DEFAULTS",0,{"git.pathMappingRules":{defaultValue:[],type:"object",label:"Git Path Mapping Rules"},"system.maxUploadBytes":{defaultValue:0x3200000,type:"number",label:"Max Upload Size (bytes)"},"system.maxConcurrentExecutions":{defaultValue:20,type:"number",label:"Max Concurrent Executions"},"git.timeoutSec":{defaultValue:30,type:"number",label:"Git Operation Timeout (seconds)"},"search.resultLimit":{defaultValue:20,type:"number",label:"Search Result Limit"},"search.allModeCap":{defaultValue:5,type:"number",label:"All-Mode Per-Type Cap"},"search.debounceMs":{defaultValue:250,type:"number",label:"Search Debounce (ms)"},"search.snippetLength":{defaultValue:80,type:"number",label:"Snippet Length (characters)"},"missions.grid.minCols":{defaultValue:1,type:"number",label:"Grid Min Columns"},"missions.grid.maxCols":{defaultValue:5,type:"number",label:"Grid Max Columns"},"missions.grid.minRows":{defaultValue:1,type:"number",label:"Grid Min Rows"},"missions.grid.maxRows":{defaultValue:5,type:"number",label:"Grid Max Rows"},"terminal.app":{defaultValue:"Terminal",type:"string",label:"Default Terminal App"},"terminal.wsPort":{defaultValue:3001,type:"number",label:"WebSocket Port"},"terminal.idleTimeoutSec":{defaultValue:180,type:"number",label:"Idle Timeout (seconds)"},"assistant.systemPrompt":{defaultValue:'You are Tower Assistant — the built-in AI operator for the Tower task management platform.\n\n## Identity\n- You are a task management operator, NOT a coding assistant.\n- You can ONLY use Tower MCP tools. You CANNOT read files, edit code, run shell commands, or search the web.\n- Always respond in the same language the user uses.\n\n## Capabilities\nWhen users ask what you can do, respond with EXACTLY these 6 groups. Translate to the user\'s language.\n\n1. **Workspace & Project** — View, create, update, delete workspaces and projects. Search projects and repositories.\n2. **Task Management** — Create tasks (priority, labels, worktree branch isolation, sub-path, auto-start). Move task status (TODO → IN_PROGRESS → IN_REVIEW → DONE / CANCELLED). Update task info and labels.\n3. **Execution Monitor** — Start task execution, check execution status, get terminal output, send commands to running terminals.\n4. **Daily Report & Todo** — Generate daily work summary (completed + in-progress). View pending task list sorted by priority.\n5. **Labels & Notes & Assets** — Manage workspace labels, project notes, and file attachments.\n6. **Global Search** — Search tasks, projects, repositories, notes, and assets by keyword.\n\nDo NOT list any capabilities beyond the above. Do NOT mention code editing, debugging, testing, git operations, or any development capabilities.\n\n## Scope Boundary\nIf the user asks you to write code, explain code, debug, search the web, read/write files, or anything outside Tower task management, reply:\n"抱歉,我只能帮你管理工作区、项目和任务。编码、调试等操作请在任务终端中完成。"',type:"string",label:"Assistant System Prompt"},"assistant.displayMode":{defaultValue:"sidebar",type:"string",label:"Assistant Display Mode"},"assistant.communicationMode":{defaultValue:"chat",type:"string",label:"Assistant Communication Mode"}}])},217990,e=>{"use strict";var t=e.i(446786),a=e.i(814747);function r(e){return e.startsWith("~/")?a.default.join(t.default.homedir(),e.slice(2)):e}function n(e){let t,a=e.match(/^git@([^:]+):(.+)$/);if(a)return{host:a[1],pathSegments:i(a[2]).split("/").filter(Boolean)};try{t=new URL(e)}catch{return null}return{host:t.hostname,pathSegments:i(decodeURIComponent(t.pathname)).split("/").filter(Boolean)}}function i(e){return e.replace(/\.git\/?$/,"")}e.s(["gitUrlToLocalPath",0,function(e){let t=e.trim();if(!t)return"";try{let e=n(t);if(!e)return"";let{host:i,pathSegments:s}=e;if("code.iflytek.com"===i){let e,t;return r((e=[...s],"osc"===e[0]&&"_source"===e[1]&&(e=e.slice(2)),((t=e.indexOf("-"))>0&&(e=e.slice(0,t)),0===e.length)?"":`~/company/${e.join("/")}`))}if("github.com"===i){var a;let e,t;return r((e=(a=s)[0],t=a[1],e&&t?`${"jp-liu"===e?"~/project/i":"~/project/f"}/${t}`:""))}let l=s[s.length-1];return l?r(`~/project/f/${l}`):""}catch{return""}},"matchGitPathRule",0,function(e,t){if(!t.length)return"";let a=e.trim();if(!a)return"";let i=n(a);if(!i)return"";let{host:s,pathSegments:l}=i,o=l[0]??"",u=l[l.length-1]??"",c=[...t].sort((e,t)=>{let a=+("*"===e.ownerMatch),r=+("*"===t.ownerMatch);return a!==r?a-r:e.priority-t.priority}),d=l.join("/");for(let e of c){if(e.host!==s||"*"!==e.ownerMatch&&e.ownerMatch!==o)continue;let t=e.localPathTemplate;if(t.includes("{path}"))return r(t.replace("{path}",d).replace("{owner}",o).replace("{repo}",u).replace(/\/+$/,""));let a=t.replace("{owner}",o).replace("{repo}","").replace(/\/+$/,"");return r(`${a}/${u}`)}return""}])},599372,e=>e.a(async(t,a)=>{try{var r=e.i(236422),n=e.i(429468),i=e.i(528913),s=e.i(217990),l=e.i(831757),o=e.i(319491),u=e.i(12421),c=t([o]);async function d(e,t){let a=await n.db.systemConfig.findUnique({where:{key:e}});if(!a)return t;try{return JSON.parse(a.value)}catch{return t}}async function p(e,t){await n.db.systemConfig.upsert({where:{key:e},create:{key:e,value:JSON.stringify(t)},update:{value:JSON.stringify(t)}})}async function f(e){let t=e.trim();if(!t)return"";try{let e=await d("git.pathMappingRules",[]),a=(0,s.matchGitPathRule)(t,e);if(a)return a;return(0,s.gitUrlToLocalPath)(t)}catch{return(0,s.gitUrlToLocalPath)(t)}}async function m(e){let t=await n.db.systemConfig.findMany({where:{key:{in:e}}}),a=Object.fromEntries(t.map(e=>{try{return[e.key,JSON.parse(e.value)]}catch{return[e.key,null]}})),r={};for(let t of e)r[t]=t in a?a[t]:i.CONFIG_DEFAULTS[t]?.defaultValue??null;return r}async function h(){return(0,l.detectShells)()}async function g(){return(0,l.detectTerminalApps)()}async function y(){return{platform:process.platform}}async function b(){let e=(0,o.getActiveWsPort)();if(null!==e)return e;let t=parseInt(process.env.PORT||"3000",10);return d("terminal.wsPort",t+1)}[o]=c.then?(await c)():c,(0,u.ensureServerEntryExports)([d,p,f,m,h,g,y,b]),(0,r.registerServerReference)(d,"60c210ff07fecafa2265f30dd96eb4de225a19aa77",null),(0,r.registerServerReference)(p,"609b34226fbdf6994c63c038d9626094d8aaf093ec",null),(0,r.registerServerReference)(f,"409b01a0501cd6418e001637818a45b4908f321079",null),(0,r.registerServerReference)(m,"40a714cf8a5713943d9460d44e361c6d739f12efc9",null),(0,r.registerServerReference)(h,"007bb464ca3b46f9ebd7c87834dc26a0c629df67e5",null),(0,r.registerServerReference)(g,"009b3dc59e0ae9151a27ab16a3c29647b18ed6677c",null),(0,r.registerServerReference)(y,"001398427306d12f2f89c7ae3050daeee981a3616d",null),(0,r.registerServerReference)(b,"0073dca5d0325409af9b7177621b17fe326cebe488",null),e.s(["getConfigValue",0,d]),a()}catch(e){a(e)}},!1),17033,e=>e.a(async(t,a)=>{try{var r=e.i(750227),n=e.i(902157),i=e.i(532087),s=e.i(383893),l=e.i(587619),o=e.i(480776),u=e.i(599372),c=t([u]);async function d(e){let t=(0,s.requireLocalhost)(e);if(t)return t;let a=(await e.formData()).get("file");if(!a)return i.NextResponse.json({error:"Missing file field"},{status:400});let c=await (0,u.getConfigValue)("system.maxUploadBytes",0x3200000);if(a.size>c)return i.NextResponse.json({error:"File too large"},{status:400});let d=Buffer.from(await a.arrayBuffer()),p=(0,l.detectImageMime)(d);if(!p)return i.NextResponse.json({error:"Unsupported file type"},{status:400});let f=l.MIME_TO_EXT[p],m=(0,o.getAssistantCacheDir)("images"),h=(0,o.buildCacheFilename)(a.name,f),g=r.join(m,h);if(!g.startsWith(m+r.sep)&&g!==m)return i.NextResponse.json({error:"Invalid path"},{status:400});await n.promises.writeFile(g,d);let y=r.relative((0,o.getAssistantCacheRoot)(),g);return i.NextResponse.json({filename:y,mimeType:p})}[u]=c.then?(await c)():c,e.s(["POST",0,d,"dynamic",0,"force-dynamic","runtime",0,"nodejs"]),a()}catch(e){a(e)}},!1),301773,e=>e.a(async(t,a)=>{try{var r=e.i(730358),n=e.i(70480),i=e.i(907338),s=e.i(976017),l=e.i(61776),o=e.i(973805),u=e.i(750012),c=e.i(986958),d=e.i(205236),p=e.i(748231),f=e.i(922554),m=e.i(841326),h=e.i(138459),g=e.i(157544),y=e.i(455548),b=e.i(193695);e.i(745561);var R=e.i(949568),w=e.i(17033),v=t([w]);[w]=v.then?(await v)():v;let E=new r.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/internal/assistant/images/route",pathname:"/api/internal/assistant/images",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/project/f/tower/src/app/api/internal/assistant/images/route.ts",nextConfigOutput:"",userland:w}),{workAsyncStorage:T,workUnitAsyncStorage:S,serverHooks:x}=E;async function C(e,t,a){a.requestMeta&&(0,s.setRequestMeta)(e,a.requestMeta),E.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let r="/api/internal/assistant/images/route";r=r.replace(/\/index$/,"")||"/";let i=await E.prepare(e,t,{srcPage:r,multiZoneDraftMode:!1});if(!i)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:w,params:v,nextConfig:C,parsedUrl:T,isDraftMode:S,prerenderManifest:x,routerServerContext:A,isOnDemandRevalidate:M,revalidateOnlyGenerated:N,resolvedPathname:O,clientReferenceManifest:P,serverActionsManifest:k}=i,j=(0,u.normalizeAppPath)(r),I=!!(x.dynamicRoutes[j]||x.routes[O]),_=async()=>((null==A?void 0:A.render404)?await A.render404(e,t,T,!1):t.end("This page could not be found"),null);if(I&&!S){let e=!!x.routes[O],t=x.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(C.adapterPath)return await _();throw new b.NoFallbackError}}let U=null;!I||E.isDev||S||(U=O,U="/index"===U?"/":U);let V=!0===E.isDev||!I,D=I&&!V;k&&P&&(0,o.setManifestsSingleton)({page:r,clientReferenceManifest:P,serverActionsManifest:k});let L=e.method||"GET",q=(0,l.getTracer)(),$=q.getActiveScopeSpan(),H=!!(null==A?void 0:A.isWrappedByNextServer),G=!!(0,s.getRequestMeta)(e,"minimalMode"),F=(0,s.getRequestMeta)(e,"incrementalCache")||await E.getIncrementalCache(e,C,x,G);null==F||F.resetRequestCache(),globalThis.__incrementalCache=F;let B={params:v,previewProps:x.preview,renderOpts:{experimental:{authInterrupts:!!C.experimental.authInterrupts},cacheComponents:!!C.cacheComponents,supportsDynamicResponse:V,incrementalCache:F,cacheLifeProfiles:C.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,r,n)=>E.onRequestError(e,t,r,n,A)},sharedContext:{buildId:w}},W=new c.NodeNextRequest(e),K=new c.NodeNextResponse(t),X=d.NextRequestAdapter.fromNodeNextRequest(W,(0,d.signalFromNodeResponse)(t));try{let i,s=async e=>E.handle(X,B).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=q.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==p.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=a.get("next.route");if(n){let t=`${L} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t),i&&i!==e&&(i.setAttribute("http.route",n),i.updateName(t))}else e.updateName(`${L} ${r}`)}),o=async i=>{var l,o;let u=async({previousCacheEntry:n})=>{try{if(!G&&M&&N&&!n)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let r=await s(i);e.fetchMetrics=B.renderOpts.fetchMetrics;let l=B.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let o=B.renderOpts.collectedTags;if(!I)return await (0,m.sendResponse)(W,K,r,B.renderOpts.pendingWaitUntil),null;{let e=await r.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(r.headers);o&&(t[y.NEXT_CACHE_TAGS_HEADER]=o),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==B.renderOpts.collectedRevalidate&&!(B.renderOpts.collectedRevalidate>=y.INFINITE_CACHE)&&B.renderOpts.collectedRevalidate,n=void 0===B.renderOpts.collectedExpire||B.renderOpts.collectedExpire>=y.INFINITE_CACHE?void 0:B.renderOpts.collectedExpire;return{value:{kind:R.CachedRouteKind.APP_ROUTE,status:r.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:n}}}}catch(t){throw(null==n?void 0:n.isStale)&&await E.onRequestError(e,t,{routerKind:"App Router",routePath:r,routeType:"route",revalidateReason:(0,f.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:M})},!1,A),t}},c=await E.handleResponse({req:e,nextConfig:C,cacheKey:U,routeKind:n.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:x,isRoutePPREnabled:!1,isOnDemandRevalidate:M,revalidateOnlyGenerated:N,responseGenerator:u,waitUntil:a.waitUntil,isMinimalMode:G});if(!I)return null;if((null==c||null==(l=c.value)?void 0:l.kind)!==R.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(o=c.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});G||t.setHeader("x-nextjs-cache",M?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),S&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return G&&I||d.delete(y.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,g.getCacheControlHeader)(c.cacheControl)),await (0,m.sendResponse)(W,K,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};H&&$?await o($):(i=q.getActiveScopeSpan(),await q.withPropagatedContext(e.headers,()=>q.trace(p.BaseServerSpan.handleRequest,{spanName:`${L} ${r}`,kind:l.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!H))}catch(t){if(t instanceof b.NoFallbackError||await E.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,f.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:M})},!1,A),I)throw t;return await (0,m.sendResponse)(W,K,new Response(null,{status:500})),null}}e.s(["handler",0,C,"patchFetch",0,function(){return(0,i.patchFetch)({workAsyncStorage:T,workUnitAsyncStorage:S})},"routeModule",0,E,"serverHooks",0,x,"workAsyncStorage",0,T,"workUnitAsyncStorage",0,S]),a()}catch(e){a(e)}},!1)];
1
+ module.exports=[587619,e=>{"use strict";let t=[{mime:"image/jpeg",check:e=>255===e[0]&&216===e[1]&&255===e[2]},{mime:"image/png",check:e=>137===e[0]&&80===e[1]&&78===e[2]&&71===e[3]},{mime:"image/gif",check:e=>71===e[0]&&73===e[1]&&70===e[2]},{mime:"image/webp",check:e=>82===e[0]&&73===e[1]&&70===e[2]&&70===e[3]&&87===e[8]&&69===e[9]&&66===e[10]&&80===e[11]}];e.s(["MIME_TO_EXT",0,{"image/jpeg":".jpg","image/png":".png","image/gif":".gif","image/webp":".webp"},"detectImageMime",0,function(e){if(e.length<12)return null;for(let a of t)if(a.check(e))return a.mime;return null}])},528913,e=>{"use strict";e.s(["CONFIG_DEFAULTS",0,{"git.pathMappingRules":{defaultValue:[],type:"object",label:"Git Path Mapping Rules"},"system.maxUploadBytes":{defaultValue:0x3200000,type:"number",label:"Max Upload Size (bytes)"},"system.maxConcurrentExecutions":{defaultValue:20,type:"number",label:"Max Concurrent Executions"},"git.timeoutSec":{defaultValue:30,type:"number",label:"Git Operation Timeout (seconds)"},"search.resultLimit":{defaultValue:20,type:"number",label:"Search Result Limit"},"search.allModeCap":{defaultValue:5,type:"number",label:"All-Mode Per-Type Cap"},"search.debounceMs":{defaultValue:250,type:"number",label:"Search Debounce (ms)"},"search.snippetLength":{defaultValue:80,type:"number",label:"Snippet Length (characters)"},"missions.grid.minCols":{defaultValue:1,type:"number",label:"Grid Min Columns"},"missions.grid.maxCols":{defaultValue:5,type:"number",label:"Grid Max Columns"},"missions.grid.minRows":{defaultValue:1,type:"number",label:"Grid Min Rows"},"missions.grid.maxRows":{defaultValue:5,type:"number",label:"Grid Max Rows"},"terminal.app":{defaultValue:"Terminal",type:"string",label:"Default Terminal App"},"terminal.wsPort":{defaultValue:3001,type:"number",label:"WebSocket Port"},"terminal.idleTimeoutSec":{defaultValue:180,type:"number",label:"Idle Timeout (seconds)"},"assistant.systemPrompt":{defaultValue:'You are Tower Assistant — the built-in AI operator for the Tower task management platform.\n\n## Identity\n- You are a task management operator, NOT a coding assistant.\n- You can ONLY use Tower MCP tools. You CANNOT read files, edit code, run shell commands, or search the web.\n- Always respond in the same language the user uses.\n\n## Capabilities\nWhen users ask what you can do, respond with EXACTLY these 6 groups. Translate to the user\'s language.\n\n1. **Workspace & Project** — View, create, update, delete workspaces and projects. Search projects and repositories.\n2. **Task Management** — Create tasks (priority, labels, worktree branch isolation, sub-path, auto-start). Move task status (TODO → IN_PROGRESS → IN_REVIEW → DONE / CANCELLED). Update task info and labels.\n3. **Execution Monitor** — Start task execution, check execution status, get terminal output, send commands to running terminals.\n4. **Daily Report & Todo** — Generate daily work summary (completed + in-progress). View pending task list sorted by priority.\n5. **Labels & Notes & Assets** — Manage workspace labels, project notes, and file attachments.\n6. **Global Search** — Search tasks, projects, repositories, notes, and assets by keyword.\n\nDo NOT list any capabilities beyond the above. Do NOT mention code editing, debugging, testing, git operations, or any development capabilities.\n\n## Scope Boundary\nIf the user asks you to write code, explain code, debug, search the web, read/write files, or anything outside Tower task management, reply:\n"抱歉,我只能帮你管理工作区、项目和任务。编码、调试等操作请在任务终端中完成。"',type:"string",label:"Assistant System Prompt"},"assistant.displayMode":{defaultValue:"sidebar",type:"string",label:"Assistant Display Mode"},"assistant.communicationMode":{defaultValue:"chat",type:"string",label:"Assistant Communication Mode"}}])},217990,e=>{"use strict";var t=e.i(446786),a=e.i(814747);function r(e){return e.startsWith("~/")?a.default.join(t.default.homedir(),e.slice(2)):e}function n(e){let t,a=e.match(/^git@([^:]+):(.+)$/);if(a)return{host:a[1],pathSegments:i(a[2]).split("/").filter(Boolean)};try{t=new URL(e)}catch{return null}return{host:t.hostname,pathSegments:i(decodeURIComponent(t.pathname)).split("/").filter(Boolean)}}function i(e){return e.replace(/\.git\/?$/,"")}e.s(["gitUrlToLocalPath",0,function(e){let t=e.trim();if(!t)return"";try{let e=n(t);if(!e)return"";let{host:i,pathSegments:s}=e;if("code.iflytek.com"===i){let e,t;return r((e=[...s],"osc"===e[0]&&"_source"===e[1]&&(e=e.slice(2)),((t=e.indexOf("-"))>0&&(e=e.slice(0,t)),0===e.length)?"":`~/company/${e.join("/")}`))}if("github.com"===i){var a;let e,t;return r((e=(a=s)[0],t=a[1],e&&t?`${"jp-liu"===e?"~/project/i":"~/project/f"}/${t}`:""))}let l=s[s.length-1];return l?r(`~/project/f/${l}`):""}catch{return""}},"matchGitPathRule",0,function(e,t){if(!t.length)return"";let a=e.trim();if(!a)return"";let i=n(a);if(!i)return"";let{host:s,pathSegments:l}=i,o=l[0]??"",u=l[l.length-1]??"",c=[...t].sort((e,t)=>{let a=+("*"===e.ownerMatch),r=+("*"===t.ownerMatch);return a!==r?a-r:e.priority-t.priority}),d=l.join("/");for(let e of c){if(e.host!==s||"*"!==e.ownerMatch&&e.ownerMatch!==o)continue;let t=e.localPathTemplate;if(t.includes("{path}"))return r(t.replace("{path}",d).replace("{owner}",o).replace("{repo}",u).replace(/\/+$/,""));let a=t.replace("{owner}",o).replace("{repo}","").replace(/\/+$/,"");return r(`${a}/${u}`)}return""}])},599372,e=>e.a(async(t,a)=>{try{var r=e.i(236422),n=e.i(429468),i=e.i(528913),s=e.i(217990),l=e.i(831757),o=e.i(319491),u=e.i(12421),c=t([o]);async function d(e,t){let a=await n.db.systemConfig.findUnique({where:{key:e}});if(!a)return t;try{return JSON.parse(a.value)}catch{return t}}async function p(e,t){await n.db.systemConfig.upsert({where:{key:e},create:{key:e,value:JSON.stringify(t)},update:{value:JSON.stringify(t)}})}async function f(e){let t=e.trim();if(!t)return"";try{let e=await d("git.pathMappingRules",[]),a=(0,s.matchGitPathRule)(t,e);if(a)return a;return(0,s.gitUrlToLocalPath)(t)}catch{return(0,s.gitUrlToLocalPath)(t)}}async function m(e){let t=await n.db.systemConfig.findMany({where:{key:{in:e}}}),a=Object.fromEntries(t.map(e=>{try{return[e.key,JSON.parse(e.value)]}catch{return[e.key,null]}})),r={};for(let t of e)r[t]=t in a?a[t]:i.CONFIG_DEFAULTS[t]?.defaultValue??null;return r}async function h(){return(0,l.detectShells)()}async function g(){return(0,l.detectTerminalApps)()}async function b(){return{platform:process.platform}}async function y(){let e=(0,o.getActiveWsPort)();if(null!==e)return e;let t=parseInt(process.env.PORT||"3000",10);return d("terminal.wsPort",t+1)}[o]=c.then?(await c)():c,(0,u.ensureServerEntryExports)([d,p,f,m,h,g,b,y]),(0,r.registerServerReference)(d,"60b4bbab24cd5fcee6effb0677c002d7f3c8be8252",null),(0,r.registerServerReference)(p,"60d7ee112ff4e3f58ea3585ad8b20ba9bd551a805c",null),(0,r.registerServerReference)(f,"40f717adff2971d11320b6aa0d6ba72cc3dae7b53d",null),(0,r.registerServerReference)(m,"405c05edca6d848111ef9bf828871ea1a8a7c2e1ae",null),(0,r.registerServerReference)(h,"002b3ab8b0b4bffbac8a5f4936dfcb2aeb8e63cc2b",null),(0,r.registerServerReference)(g,"00bb31f16bc35b11ac323547725b885aa5d4c9f698",null),(0,r.registerServerReference)(b,"0068bcdb7668f6775587717082c1d591615c6cdafa",null),(0,r.registerServerReference)(y,"007f19f19aa7f0acb7a761c314a29d3ed85512a22c",null),e.s(["getConfigValue",0,d]),a()}catch(e){a(e)}},!1),17033,e=>e.a(async(t,a)=>{try{var r=e.i(750227),n=e.i(902157),i=e.i(532087),s=e.i(383893),l=e.i(587619),o=e.i(480776),u=e.i(599372),c=t([u]);async function d(e){let t=(0,s.requireLocalhost)(e);if(t)return t;let a=(await e.formData()).get("file");if(!a)return i.NextResponse.json({error:"Missing file field"},{status:400});let c=await (0,u.getConfigValue)("system.maxUploadBytes",0x3200000);if(a.size>c)return i.NextResponse.json({error:"File too large"},{status:400});let d=Buffer.from(await a.arrayBuffer()),p=(0,l.detectImageMime)(d);if(!p)return i.NextResponse.json({error:"Unsupported file type"},{status:400});let f=l.MIME_TO_EXT[p],m=(0,o.getAssistantCacheDir)("images"),h=(0,o.buildCacheFilename)(a.name,f),g=r.join(m,h);if(!g.startsWith(m+r.sep)&&g!==m)return i.NextResponse.json({error:"Invalid path"},{status:400});await n.promises.writeFile(g,d);let b=r.relative((0,o.getAssistantCacheRoot)(),g);return i.NextResponse.json({filename:b,mimeType:p})}[u]=c.then?(await c)():c,e.s(["POST",0,d,"dynamic",0,"force-dynamic","runtime",0,"nodejs"]),a()}catch(e){a(e)}},!1),301773,e=>e.a(async(t,a)=>{try{var r=e.i(730358),n=e.i(70480),i=e.i(907338),s=e.i(976017),l=e.i(61776),o=e.i(973805),u=e.i(750012),c=e.i(986958),d=e.i(205236),p=e.i(748231),f=e.i(922554),m=e.i(841326),h=e.i(138459),g=e.i(157544),b=e.i(455548),y=e.i(193695);e.i(745561);var R=e.i(949568),w=e.i(17033),v=t([w]);[w]=v.then?(await v)():v;let E=new r.AppRouteRouteModule({definition:{kind:n.RouteKind.APP_ROUTE,page:"/api/internal/assistant/images/route",pathname:"/api/internal/assistant/images",filename:"route",bundlePath:""},distDir:".next",relativeProjectDir:"",resolvedPagePath:"[project]/project/f/tower/src/app/api/internal/assistant/images/route.ts",nextConfigOutput:"",userland:w}),{workAsyncStorage:T,workUnitAsyncStorage:S,serverHooks:x}=E;async function C(e,t,a){a.requestMeta&&(0,s.setRequestMeta)(e,a.requestMeta),E.isDev&&(0,s.addRequestMeta)(e,"devRequestTimingInternalsEnd",process.hrtime.bigint());let r="/api/internal/assistant/images/route";r=r.replace(/\/index$/,"")||"/";let i=await E.prepare(e,t,{srcPage:r,multiZoneDraftMode:!1});if(!i)return t.statusCode=400,t.end("Bad Request"),null==a.waitUntil||a.waitUntil.call(a,Promise.resolve()),null;let{buildId:w,params:v,nextConfig:C,parsedUrl:T,isDraftMode:S,prerenderManifest:x,routerServerContext:A,isOnDemandRevalidate:M,revalidateOnlyGenerated:N,resolvedPathname:O,clientReferenceManifest:P,serverActionsManifest:k}=i,j=(0,u.normalizeAppPath)(r),I=!!(x.dynamicRoutes[j]||x.routes[O]),_=async()=>((null==A?void 0:A.render404)?await A.render404(e,t,T,!1):t.end("This page could not be found"),null);if(I&&!S){let e=!!x.routes[O],t=x.dynamicRoutes[j];if(t&&!1===t.fallback&&!e){if(C.adapterPath)return await _();throw new y.NoFallbackError}}let U=null;!I||E.isDev||S||(U=O,U="/index"===U?"/":U);let V=!0===E.isDev||!I,D=I&&!V;k&&P&&(0,o.setManifestsSingleton)({page:r,clientReferenceManifest:P,serverActionsManifest:k});let L=e.method||"GET",q=(0,l.getTracer)(),$=q.getActiveScopeSpan(),H=!!(null==A?void 0:A.isWrappedByNextServer),G=!!(0,s.getRequestMeta)(e,"minimalMode"),F=(0,s.getRequestMeta)(e,"incrementalCache")||await E.getIncrementalCache(e,C,x,G);null==F||F.resetRequestCache(),globalThis.__incrementalCache=F;let B={params:v,previewProps:x.preview,renderOpts:{experimental:{authInterrupts:!!C.experimental.authInterrupts},cacheComponents:!!C.cacheComponents,supportsDynamicResponse:V,incrementalCache:F,cacheLifeProfiles:C.cacheLife,waitUntil:a.waitUntil,onClose:e=>{t.on("close",e)},onAfterTaskError:void 0,onInstrumentationRequestError:(t,a,r,n)=>E.onRequestError(e,t,r,n,A)},sharedContext:{buildId:w}},W=new c.NodeNextRequest(e),K=new c.NodeNextResponse(t),X=d.NextRequestAdapter.fromNodeNextRequest(W,(0,d.signalFromNodeResponse)(t));try{let i,s=async e=>E.handle(X,B).finally(()=>{if(!e)return;e.setAttributes({"http.status_code":t.statusCode,"next.rsc":!1});let a=q.getRootSpanAttributes();if(!a)return;if(a.get("next.span_type")!==p.BaseServerSpan.handleRequest)return void console.warn(`Unexpected root span type '${a.get("next.span_type")}'. Please report this Next.js issue https://github.com/vercel/next.js`);let n=a.get("next.route");if(n){let t=`${L} ${n}`;e.setAttributes({"next.route":n,"http.route":n,"next.span_name":t}),e.updateName(t),i&&i!==e&&(i.setAttribute("http.route",n),i.updateName(t))}else e.updateName(`${L} ${r}`)}),o=async i=>{var l,o;let u=async({previousCacheEntry:n})=>{try{if(!G&&M&&N&&!n)return t.statusCode=404,t.setHeader("x-nextjs-cache","REVALIDATED"),t.end("This page could not be found"),null;let r=await s(i);e.fetchMetrics=B.renderOpts.fetchMetrics;let l=B.renderOpts.pendingWaitUntil;l&&a.waitUntil&&(a.waitUntil(l),l=void 0);let o=B.renderOpts.collectedTags;if(!I)return await (0,m.sendResponse)(W,K,r,B.renderOpts.pendingWaitUntil),null;{let e=await r.blob(),t=(0,h.toNodeOutgoingHttpHeaders)(r.headers);o&&(t[b.NEXT_CACHE_TAGS_HEADER]=o),!t["content-type"]&&e.type&&(t["content-type"]=e.type);let a=void 0!==B.renderOpts.collectedRevalidate&&!(B.renderOpts.collectedRevalidate>=b.INFINITE_CACHE)&&B.renderOpts.collectedRevalidate,n=void 0===B.renderOpts.collectedExpire||B.renderOpts.collectedExpire>=b.INFINITE_CACHE?void 0:B.renderOpts.collectedExpire;return{value:{kind:R.CachedRouteKind.APP_ROUTE,status:r.status,body:Buffer.from(await e.arrayBuffer()),headers:t},cacheControl:{revalidate:a,expire:n}}}}catch(t){throw(null==n?void 0:n.isStale)&&await E.onRequestError(e,t,{routerKind:"App Router",routePath:r,routeType:"route",revalidateReason:(0,f.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:M})},!1,A),t}},c=await E.handleResponse({req:e,nextConfig:C,cacheKey:U,routeKind:n.RouteKind.APP_ROUTE,isFallback:!1,prerenderManifest:x,isRoutePPREnabled:!1,isOnDemandRevalidate:M,revalidateOnlyGenerated:N,responseGenerator:u,waitUntil:a.waitUntil,isMinimalMode:G});if(!I)return null;if((null==c||null==(l=c.value)?void 0:l.kind)!==R.CachedRouteKind.APP_ROUTE)throw Object.defineProperty(Error(`Invariant: app-route received invalid cache entry ${null==c||null==(o=c.value)?void 0:o.kind}`),"__NEXT_ERROR_CODE",{value:"E701",enumerable:!1,configurable:!0});G||t.setHeader("x-nextjs-cache",M?"REVALIDATED":c.isMiss?"MISS":c.isStale?"STALE":"HIT"),S&&t.setHeader("Cache-Control","private, no-cache, no-store, max-age=0, must-revalidate");let d=(0,h.fromNodeOutgoingHttpHeaders)(c.value.headers);return G&&I||d.delete(b.NEXT_CACHE_TAGS_HEADER),!c.cacheControl||t.getHeader("Cache-Control")||d.get("Cache-Control")||d.set("Cache-Control",(0,g.getCacheControlHeader)(c.cacheControl)),await (0,m.sendResponse)(W,K,new Response(c.value.body,{headers:d,status:c.value.status||200})),null};H&&$?await o($):(i=q.getActiveScopeSpan(),await q.withPropagatedContext(e.headers,()=>q.trace(p.BaseServerSpan.handleRequest,{spanName:`${L} ${r}`,kind:l.SpanKind.SERVER,attributes:{"http.method":L,"http.target":e.url}},o),void 0,!H))}catch(t){if(t instanceof y.NoFallbackError||await E.onRequestError(e,t,{routerKind:"App Router",routePath:j,routeType:"route",revalidateReason:(0,f.getRevalidateReason)({isStaticGeneration:D,isOnDemandRevalidate:M})},!1,A),I)throw t;return await (0,m.sendResponse)(W,K,new Response(null,{status:500})),null}}e.s(["handler",0,C,"patchFetch",0,function(){return(0,i.patchFetch)({workAsyncStorage:T,workUnitAsyncStorage:S})},"routeModule",0,E,"serverHooks",0,x,"workAsyncStorage",0,T,"workUnitAsyncStorage",0,S]),a()}catch(e){a(e)}},!1)];
2
2
 
3
3
  //# sourceMappingURL=project_f_tower_0n1s3ym._.js.map
@@ -1,3 +1,3 @@
1
- module.exports=[336577,e=>{"use strict";var t=e.i(236422),a=e.i(429468),r=e.i(892587),n=e.i(308241),i=e.i(12421);let o=["onboarding.completed","onboarding.lastStep","onboarding.username"];async function s(){let e=await a.db.systemConfig.findMany({where:{key:{in:[...o]}}}),t={};for(let a of e)try{t[a.key]=JSON.parse(a.value)}catch{t[a.key]=null}let r=!0===t["onboarding.completed"],n=t["onboarding.lastStep"],i=t["onboarding.username"];return{isFirstRun:!r,isCompleted:r,lastStep:"number"==typeof n?n:0,username:"string"==typeof i&&i.length>0?i:null}}async function l(e){await a.db.systemConfig.upsert({where:{key:"onboarding.lastStep"},create:{key:"onboarding.lastStep",value:JSON.stringify(e)},update:{value:JSON.stringify(e)}}),(0,r.revalidatePath)("/","layout")}async function d(e){if(await a.db.systemConfig.upsert({where:{key:"onboarding.completed"},create:{key:"onboarding.completed",value:"true"},update:{value:"true"}}),await a.db.systemConfig.upsert({where:{key:"onboarding.lastStep"},create:{key:"onboarding.lastStep",value:"2"},update:{value:"2"}}),void 0!==e){let t=e.trim().slice(0,64).replace(/[\r\n]/g," ");t.length>0&&await a.db.systemConfig.upsert({where:{key:"onboarding.username"},create:{key:"onboarding.username",value:JSON.stringify(t)},update:{value:JSON.stringify(t)}})}(0,r.revalidatePath)("/","layout")}async function c(t){try{n.logger.create("task-completion").info("Task completion event dispatched",{taskId:t.taskId,taskTitle:t.taskTitle,status:t.status,executionId:t.executionId});let{broadcastNotification:a}=await e.A(888829);a({...t,type:"completion"})}catch{}}(0,i.ensureServerEntryExports)([s,l,d,c]),(0,t.registerServerReference)(s,"000fb4e39ec972db9511a0189892de76b46ee6e9aa",null),(0,t.registerServerReference)(l,"4086718196d2df7c995adeceabd3b4eff491f6f38a",null),(0,t.registerServerReference)(d,"4061302b8376f5d81135ccb1917c082eef7fca658a",null),(0,t.registerServerReference)(c,"409c0dd81d080577529994de4ce29a7c0a38dc7435",null),e.s(["dispatchTaskCompletionEvent",0,c])},888829,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0pe2bmo._.js"].map(t=>e.l(t))).then(()=>t(319491)))}];
1
+ module.exports=[336577,e=>{"use strict";var t=e.i(236422),a=e.i(429468),r=e.i(892587),n=e.i(308241),i=e.i(12421);let o=["onboarding.completed","onboarding.lastStep","onboarding.username"];async function s(){let e=await a.db.systemConfig.findMany({where:{key:{in:[...o]}}}),t={};for(let a of e)try{t[a.key]=JSON.parse(a.value)}catch{t[a.key]=null}let r=!0===t["onboarding.completed"],n=t["onboarding.lastStep"],i=t["onboarding.username"];return{isFirstRun:!r,isCompleted:r,lastStep:"number"==typeof n?n:0,username:"string"==typeof i&&i.length>0?i:null}}async function l(e){await a.db.systemConfig.upsert({where:{key:"onboarding.lastStep"},create:{key:"onboarding.lastStep",value:JSON.stringify(e)},update:{value:JSON.stringify(e)}}),(0,r.revalidatePath)("/","layout")}async function d(e){if(await a.db.systemConfig.upsert({where:{key:"onboarding.completed"},create:{key:"onboarding.completed",value:"true"},update:{value:"true"}}),await a.db.systemConfig.upsert({where:{key:"onboarding.lastStep"},create:{key:"onboarding.lastStep",value:"2"},update:{value:"2"}}),void 0!==e){let t=e.trim().slice(0,64).replace(/[\r\n]/g," ");t.length>0&&await a.db.systemConfig.upsert({where:{key:"onboarding.username"},create:{key:"onboarding.username",value:JSON.stringify(t)},update:{value:JSON.stringify(t)}})}(0,r.revalidatePath)("/","layout")}async function u(t){try{n.logger.create("task-completion").info("Task completion event dispatched",{taskId:t.taskId,taskTitle:t.taskTitle,status:t.status,executionId:t.executionId});let{broadcastNotification:a}=await e.A(888829);a({...t,type:"completion"})}catch{}}(0,i.ensureServerEntryExports)([s,l,d,u]),(0,t.registerServerReference)(s,"00bc3693793d5b54f783edd1d2980266ef77dd187a",null),(0,t.registerServerReference)(l,"40bf29122e3767079bdd6ed916b5ad5c005ee11ccc",null),(0,t.registerServerReference)(d,"40f25741b725b8f8b3f2e3a6cb06f71ef80d5258ad",null),(0,t.registerServerReference)(u,"40fa0f9e83c40e87c5a6d5d8de2d56ce714505c16b",null),e.s(["dispatchTaskCompletionEvent",0,u])},888829,e=>{e.v(t=>Promise.all(["server/chunks/[root-of-the-server]__0pe2bmo._.js"].map(t=>e.l(t))).then(()=>t(319491)))}];
2
2
 
3
3
  //# sourceMappingURL=project_f_tower_src_11e.cv5._.js.map