@alexjbarnes/cockpit 0.2.0 → 0.3.0

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 (694) hide show
  1. package/.next/BUILD_ID +1 -1
  2. package/.next/app-path-routes-manifest.json +16 -3
  3. package/.next/build-manifest.json +3 -3
  4. package/.next/prerender-manifest.json +99 -3
  5. package/.next/react-loadable-manifest.json +18 -2
  6. package/.next/required-server-files.js +3 -0
  7. package/.next/required-server-files.json +3 -0
  8. package/.next/routes-manifest.json +86 -0
  9. package/.next/server/app/(app)/agents/[name]/page.js +2 -2
  10. package/.next/server/app/(app)/agents/[name]/page.js.nft.json +1 -1
  11. package/.next/server/app/(app)/agents/[name]/page_client-reference-manifest.js +1 -1
  12. package/.next/server/app/(app)/agents/page.js +2 -2
  13. package/.next/server/app/(app)/agents/page.js.nft.json +1 -1
  14. package/.next/server/app/(app)/agents/page_client-reference-manifest.js +1 -1
  15. package/.next/server/app/(app)/changes/page.js +2 -2
  16. package/.next/server/app/(app)/changes/page.js.nft.json +1 -1
  17. package/.next/server/app/(app)/changes/page_client-reference-manifest.js +1 -1
  18. package/.next/server/app/(app)/claude-md/edit/page.js +2 -2
  19. package/.next/server/app/(app)/claude-md/edit/page.js.nft.json +1 -1
  20. package/.next/server/app/(app)/claude-md/edit/page_client-reference-manifest.js +1 -1
  21. package/.next/server/app/(app)/claude-md/page.js +2 -2
  22. package/.next/server/app/(app)/claude-md/page.js.nft.json +1 -1
  23. package/.next/server/app/(app)/claude-md/page_client-reference-manifest.js +1 -1
  24. package/.next/server/app/(app)/commands/[name]/page.js +2 -2
  25. package/.next/server/app/(app)/commands/[name]/page.js.nft.json +1 -1
  26. package/.next/server/app/(app)/commands/[name]/page_client-reference-manifest.js +1 -1
  27. package/.next/server/app/(app)/commands/page.js +2 -2
  28. package/.next/server/app/(app)/commands/page.js.nft.json +1 -1
  29. package/.next/server/app/(app)/commands/page_client-reference-manifest.js +1 -1
  30. package/.next/server/app/(app)/files/page.js +2 -2
  31. package/.next/server/app/(app)/files/page.js.nft.json +1 -1
  32. package/.next/server/app/(app)/files/page_client-reference-manifest.js +1 -1
  33. package/.next/server/app/(app)/hooks/[event]/page.js +3 -3
  34. package/.next/server/app/(app)/hooks/[event]/page.js.nft.json +1 -1
  35. package/.next/server/app/(app)/hooks/[event]/page_client-reference-manifest.js +1 -1
  36. package/.next/server/app/(app)/hooks/page.js +2 -2
  37. package/.next/server/app/(app)/hooks/page.js.nft.json +1 -1
  38. package/.next/server/app/(app)/hooks/page_client-reference-manifest.js +1 -1
  39. package/.next/server/app/(app)/inbox/[id]/page.js +2 -2
  40. package/.next/server/app/(app)/inbox/[id]/page.js.nft.json +1 -1
  41. package/.next/server/app/(app)/inbox/[id]/page_client-reference-manifest.js +1 -1
  42. package/.next/server/app/(app)/inbox/page.js +2 -2
  43. package/.next/server/app/(app)/inbox/page.js.nft.json +1 -1
  44. package/.next/server/app/(app)/inbox/page_client-reference-manifest.js +1 -1
  45. package/.next/server/app/(app)/jobs/[id]/edit/page.js +2 -2
  46. package/.next/server/app/(app)/jobs/[id]/edit/page.js.nft.json +1 -1
  47. package/.next/server/app/(app)/jobs/[id]/edit/page_client-reference-manifest.js +1 -1
  48. package/.next/server/app/(app)/jobs/[id]/page.js +2 -2
  49. package/.next/server/app/(app)/jobs/[id]/page.js.nft.json +1 -1
  50. package/.next/server/app/(app)/jobs/[id]/page_client-reference-manifest.js +1 -1
  51. package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page.js +2 -2
  52. package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page.js.nft.json +1 -1
  53. package/.next/server/app/(app)/jobs/[id]/runs/[runId]/page_client-reference-manifest.js +1 -1
  54. package/.next/server/app/(app)/jobs/page.js +2 -2
  55. package/.next/server/app/(app)/jobs/page.js.nft.json +1 -1
  56. package/.next/server/app/(app)/jobs/page_client-reference-manifest.js +1 -1
  57. package/.next/server/app/(app)/mcp-servers/[name]/page.js +2 -2
  58. package/.next/server/app/(app)/mcp-servers/[name]/page.js.nft.json +1 -1
  59. package/.next/server/app/(app)/mcp-servers/[name]/page_client-reference-manifest.js +1 -1
  60. package/.next/server/app/(app)/mcp-servers/page.js +2 -2
  61. package/.next/server/app/(app)/mcp-servers/page.js.nft.json +1 -1
  62. package/.next/server/app/(app)/mcp-servers/page_client-reference-manifest.js +1 -1
  63. package/.next/server/app/(app)/page.js +2 -2
  64. package/.next/server/app/(app)/page.js.nft.json +1 -1
  65. package/.next/server/app/(app)/page_client-reference-manifest.js +1 -1
  66. package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page.js +10 -10
  67. package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page.js.nft.json +1 -1
  68. package/.next/server/app/(app)/reviews/[owner]/[repo]/[number]/page_client-reference-manifest.js +1 -1
  69. package/.next/server/app/(app)/reviews/[owner]/[repo]/page.js +2 -2
  70. package/.next/server/app/(app)/reviews/[owner]/[repo]/page.js.nft.json +1 -1
  71. package/.next/server/app/(app)/reviews/[owner]/[repo]/page_client-reference-manifest.js +1 -1
  72. package/.next/server/app/(app)/reviews/page.js +2 -2
  73. package/.next/server/app/(app)/reviews/page.js.nft.json +1 -1
  74. package/.next/server/app/(app)/reviews/page_client-reference-manifest.js +1 -1
  75. package/.next/server/app/(app)/sessions/[id]/page.js +2 -2
  76. package/.next/server/app/(app)/sessions/[id]/page.js.nft.json +1 -1
  77. package/.next/server/app/(app)/sessions/[id]/page_client-reference-manifest.js +1 -1
  78. package/.next/server/app/(app)/settings/appearance/page.js +2 -0
  79. package/.next/server/app/(app)/settings/appearance/page.js.nft.json +1 -0
  80. package/.next/server/app/(app)/settings/appearance/page_client-reference-manifest.js +1 -0
  81. package/.next/server/app/(app)/settings/notifications/page.js +2 -2
  82. package/.next/server/app/(app)/settings/notifications/page.js.nft.json +1 -1
  83. package/.next/server/app/(app)/settings/notifications/page_client-reference-manifest.js +1 -1
  84. package/.next/server/app/(app)/settings/page.js +2 -2
  85. package/.next/server/app/(app)/settings/page.js.nft.json +1 -1
  86. package/.next/server/app/(app)/settings/page_client-reference-manifest.js +1 -1
  87. package/.next/server/app/(app)/settings/providers/[id]/page.js +2 -0
  88. package/.next/server/app/(app)/settings/providers/[id]/page.js.nft.json +1 -0
  89. package/.next/server/app/(app)/settings/providers/[id]/page_client-reference-manifest.js +1 -0
  90. package/.next/server/app/(app)/settings/providers/new/page.js +2 -0
  91. package/.next/server/app/(app)/settings/providers/new/page.js.nft.json +1 -0
  92. package/.next/server/app/(app)/settings/providers/new/page_client-reference-manifest.js +1 -0
  93. package/.next/server/app/(app)/settings/providers/page.js +2 -0
  94. package/.next/server/app/(app)/settings/providers/page.js.nft.json +1 -0
  95. package/.next/server/app/(app)/settings/providers/page_client-reference-manifest.js +1 -0
  96. package/.next/server/app/(app)/settings/session/page.js +2 -0
  97. package/.next/server/app/(app)/settings/session/page.js.nft.json +1 -0
  98. package/.next/server/app/(app)/settings/session/page_client-reference-manifest.js +1 -0
  99. package/.next/server/app/(app)/skills/[name]/page.js +3 -3
  100. package/.next/server/app/(app)/skills/[name]/page.js.nft.json +1 -1
  101. package/.next/server/app/(app)/skills/[name]/page_client-reference-manifest.js +1 -1
  102. package/.next/server/app/(app)/skills/page.js +2 -2
  103. package/.next/server/app/(app)/skills/page.js.nft.json +1 -1
  104. package/.next/server/app/(app)/skills/page_client-reference-manifest.js +1 -1
  105. package/.next/server/app/_global-error/page.js +3 -3
  106. package/.next/server/app/_global-error/page_client-reference-manifest.js +1 -1
  107. package/.next/server/app/_global-error.html +1 -1
  108. package/.next/server/app/_global-error.rsc +1 -1
  109. package/.next/server/app/_global-error.segments/_full.segment.rsc +1 -1
  110. package/.next/server/app/_global-error.segments/_global-error/__PAGE__.segment.rsc +1 -1
  111. package/.next/server/app/_global-error.segments/_global-error.segment.rsc +1 -1
  112. package/.next/server/app/_global-error.segments/_head.segment.rsc +1 -1
  113. package/.next/server/app/_global-error.segments/_index.segment.rsc +1 -1
  114. package/.next/server/app/_global-error.segments/_tree.segment.rsc +1 -1
  115. package/.next/server/app/_not-found/page.js +2 -2
  116. package/.next/server/app/_not-found/page_client-reference-manifest.js +1 -1
  117. package/.next/server/app/_not-found.html +1 -1
  118. package/.next/server/app/_not-found.rsc +2 -2
  119. package/.next/server/app/_not-found.segments/_full.segment.rsc +2 -2
  120. package/.next/server/app/_not-found.segments/_head.segment.rsc +1 -1
  121. package/.next/server/app/_not-found.segments/_index.segment.rsc +2 -2
  122. package/.next/server/app/_not-found.segments/_not-found/__PAGE__.segment.rsc +1 -1
  123. package/.next/server/app/_not-found.segments/_not-found.segment.rsc +1 -1
  124. package/.next/server/app/_not-found.segments/_tree.segment.rsc +2 -2
  125. package/.next/server/app/agents.html +1 -1
  126. package/.next/server/app/agents.rsc +4 -4
  127. package/.next/server/app/agents.segments/!KGFwcCk/agents/__PAGE__.segment.rsc +2 -2
  128. package/.next/server/app/agents.segments/!KGFwcCk/agents.segment.rsc +1 -1
  129. package/.next/server/app/agents.segments/!KGFwcCk.segment.rsc +2 -2
  130. package/.next/server/app/agents.segments/_full.segment.rsc +4 -4
  131. package/.next/server/app/agents.segments/_head.segment.rsc +1 -1
  132. package/.next/server/app/agents.segments/_index.segment.rsc +2 -2
  133. package/.next/server/app/agents.segments/_tree.segment.rsc +2 -2
  134. package/.next/server/app/api/agents/[name]/route.js +1 -1
  135. package/.next/server/app/api/agents/route.js +1 -1
  136. package/.next/server/app/api/auth/check/route.js +1 -1
  137. package/.next/server/app/api/auth/login/route.js +1 -1
  138. package/.next/server/app/api/auth/setup/route.js +1 -1
  139. package/.next/server/app/api/auth/ws-token/route.js +1 -1
  140. package/.next/server/app/api/btw/route.js +2 -2
  141. package/.next/server/app/api/claude-md/route.js +1 -1
  142. package/.next/server/app/api/commands/[name]/route.js +1 -1
  143. package/.next/server/app/api/commands/route.js +1 -1
  144. package/.next/server/app/api/defaults/route.js +1 -1
  145. package/.next/server/app/api/filesystem/browse/route.js +1 -1
  146. package/.next/server/app/api/filesystem/files/route.js +1 -1
  147. package/.next/server/app/api/filesystem/mkdir/route.js +1 -1
  148. package/.next/server/app/api/filesystem/read/route.js +1 -1
  149. package/.next/server/app/api/git/clone/route.js +1 -1
  150. package/.next/server/app/api/git/commit/route.js +1 -1
  151. package/.next/server/app/api/git/diff/route.js +1 -1
  152. package/.next/server/app/api/git/discard/route.js +1 -1
  153. package/.next/server/app/api/git/generate-message/route.js +2 -2
  154. package/.next/server/app/api/git/push/route.js +1 -1
  155. package/.next/server/app/api/git/status/route.js +1 -1
  156. package/.next/server/app/api/github/file-content/route.js +1 -1
  157. package/.next/server/app/api/github/orgs/route.js +1 -1
  158. package/.next/server/app/api/github/prs/checks/route.js +1 -1
  159. package/.next/server/app/api/github/prs/diff/route.js +1 -1
  160. package/.next/server/app/api/github/prs/review/route.js +1 -1
  161. package/.next/server/app/api/github/prs/route.js +1 -1
  162. package/.next/server/app/api/github/prs/view/route.js +1 -1
  163. package/.next/server/app/api/github/repos/route.js +1 -1
  164. package/.next/server/app/api/github/review-session/route.js +1 -1
  165. package/.next/server/app/api/github/review-session/route.js.nft.json +1 -1
  166. package/.next/server/app/api/health/route.js +1 -1
  167. package/.next/server/app/api/hooks/route.js +1 -1
  168. package/.next/server/app/api/inbox/[id]/route.js +2 -2
  169. package/.next/server/app/api/inbox/route.js +2 -2
  170. package/.next/server/app/api/jobs/[id]/route.js +1 -1
  171. package/.next/server/app/api/jobs/[id]/route.js.nft.json +1 -1
  172. package/.next/server/app/api/jobs/[id]/runs/[runId]/route.js +1 -1
  173. package/.next/server/app/api/jobs/[id]/runs/[runId]/transcript/route.js +1 -1
  174. package/.next/server/app/api/jobs/[id]/runs/route.js +1 -1
  175. package/.next/server/app/api/jobs/[id]/trigger/route.js +1 -1
  176. package/.next/server/app/api/jobs/[id]/trigger/route.js.nft.json +1 -1
  177. package/.next/server/app/api/jobs/mcp-discover/route.js +1 -1
  178. package/.next/server/app/api/jobs/mcp-discover/route.js.nft.json +1 -1
  179. package/.next/server/app/api/jobs/route.js +1 -1
  180. package/.next/server/app/api/jobs/route.js.nft.json +1 -1
  181. package/.next/server/app/api/jobs/status/route.js +1 -1
  182. package/.next/server/app/api/mcp-servers/[name]/route.js +1 -1
  183. package/.next/server/app/api/mcp-servers/[name]/test/route.js +1 -1
  184. package/.next/server/app/api/mcp-servers/route.js +1 -1
  185. package/.next/server/app/api/notifications/route.js +1 -1
  186. package/.next/server/app/api/notifications/test/route.js +1 -1
  187. package/.next/server/app/api/providers/[id]/route.js +1 -0
  188. package/.next/server/app/api/providers/[id]/route.js.nft.json +1 -0
  189. package/.next/server/app/api/providers/[id]/route_client-reference-manifest.js +1 -0
  190. package/.next/server/app/api/providers/route.js +1 -0
  191. package/.next/server/app/api/providers/route.js.nft.json +1 -0
  192. package/.next/server/app/api/providers/route_client-reference-manifest.js +1 -0
  193. package/.next/server/app/api/reviews/pinned/route.js +1 -1
  194. package/.next/server/app/api/sessions/[id]/context/route.js +1 -1
  195. package/.next/server/app/api/sessions/[id]/mcp/route.js +1 -1
  196. package/.next/server/app/api/sessions/[id]/mcp/route.js.nft.json +1 -1
  197. package/.next/server/app/api/sessions/[id]/route.js +1 -1
  198. package/.next/server/app/api/sessions/[id]/route.js.nft.json +1 -1
  199. package/.next/server/app/api/sessions/[id]/search/route.js +1 -1
  200. package/.next/server/app/api/sessions/[id]/tabs/route.js +1 -0
  201. package/.next/server/app/api/sessions/[id]/tabs/route.js.nft.json +1 -0
  202. package/.next/server/app/api/sessions/[id]/tabs/route_client-reference-manifest.js +1 -0
  203. package/.next/server/app/api/sessions/bulk-delete/route.js +1 -1
  204. package/.next/server/app/api/sessions/bulk-delete/route.js.nft.json +1 -1
  205. package/.next/server/app/api/sessions/by-ids/route.js +1 -1
  206. package/.next/server/app/api/sessions/by-ids/route.js.nft.json +1 -1
  207. package/.next/server/app/api/sessions/group/route.js +1 -1
  208. package/.next/server/app/api/sessions/group/route.js.nft.json +1 -1
  209. package/.next/server/app/api/sessions/pinned/route.js +1 -1
  210. package/.next/server/app/api/sessions/route.js +1 -1
  211. package/.next/server/app/api/sessions/route.js.nft.json +1 -1
  212. package/.next/server/app/api/sessions/search/route.js +1 -1
  213. package/.next/server/app/api/sessions/thinking/route.js +1 -0
  214. package/.next/server/app/api/sessions/thinking/route.js.nft.json +1 -0
  215. package/.next/server/app/api/sessions/thinking/route_client-reference-manifest.js +1 -0
  216. package/.next/server/app/api/skills/[name]/route.js +1 -1
  217. package/.next/server/app/api/skills/route.js +1 -1
  218. package/.next/server/app/api/terminal/[id]/route.js +1 -0
  219. package/.next/server/app/api/terminal/[id]/route.js.nft.json +1 -0
  220. package/.next/server/app/api/terminal/[id]/route_client-reference-manifest.js +1 -0
  221. package/.next/server/app/api/terminal/route.js +1 -0
  222. package/.next/server/app/api/terminal/route.js.nft.json +1 -0
  223. package/.next/server/app/api/terminal/route_client-reference-manifest.js +1 -0
  224. package/.next/server/app/api/usage/route.js +1 -1
  225. package/.next/server/app/api/version/changelog/route.js +1 -0
  226. package/.next/server/app/api/version/changelog/route.js.nft.json +1 -0
  227. package/.next/server/app/api/version/changelog/route_client-reference-manifest.js +1 -0
  228. package/.next/server/app/api/version/cockpit/changelog/route.js +1 -0
  229. package/.next/server/app/api/version/cockpit/changelog/route.js.nft.json +1 -0
  230. package/.next/server/app/api/version/cockpit/changelog/route_client-reference-manifest.js +1 -0
  231. package/.next/server/app/api/version/cockpit/route.js +1 -1
  232. package/.next/server/app/api/version/route.js +2 -2
  233. package/.next/server/app/changes.html +1 -1
  234. package/.next/server/app/changes.rsc +4 -4
  235. package/.next/server/app/changes.segments/!KGFwcCk/changes/__PAGE__.segment.rsc +2 -2
  236. package/.next/server/app/changes.segments/!KGFwcCk/changes.segment.rsc +1 -1
  237. package/.next/server/app/changes.segments/!KGFwcCk.segment.rsc +2 -2
  238. package/.next/server/app/changes.segments/_full.segment.rsc +4 -4
  239. package/.next/server/app/changes.segments/_head.segment.rsc +1 -1
  240. package/.next/server/app/changes.segments/_index.segment.rsc +2 -2
  241. package/.next/server/app/changes.segments/_tree.segment.rsc +2 -2
  242. package/.next/server/app/claude-md/edit.html +1 -1
  243. package/.next/server/app/claude-md/edit.rsc +4 -4
  244. package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md/edit/__PAGE__.segment.rsc +2 -2
  245. package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md/edit.segment.rsc +1 -1
  246. package/.next/server/app/claude-md/edit.segments/!KGFwcCk/claude-md.segment.rsc +1 -1
  247. package/.next/server/app/claude-md/edit.segments/!KGFwcCk.segment.rsc +2 -2
  248. package/.next/server/app/claude-md/edit.segments/_full.segment.rsc +4 -4
  249. package/.next/server/app/claude-md/edit.segments/_head.segment.rsc +1 -1
  250. package/.next/server/app/claude-md/edit.segments/_index.segment.rsc +2 -2
  251. package/.next/server/app/claude-md/edit.segments/_tree.segment.rsc +2 -2
  252. package/.next/server/app/claude-md.html +1 -1
  253. package/.next/server/app/claude-md.rsc +4 -4
  254. package/.next/server/app/claude-md.segments/!KGFwcCk/claude-md/__PAGE__.segment.rsc +2 -2
  255. package/.next/server/app/claude-md.segments/!KGFwcCk/claude-md.segment.rsc +1 -1
  256. package/.next/server/app/claude-md.segments/!KGFwcCk.segment.rsc +2 -2
  257. package/.next/server/app/claude-md.segments/_full.segment.rsc +4 -4
  258. package/.next/server/app/claude-md.segments/_head.segment.rsc +1 -1
  259. package/.next/server/app/claude-md.segments/_index.segment.rsc +2 -2
  260. package/.next/server/app/claude-md.segments/_tree.segment.rsc +2 -2
  261. package/.next/server/app/commands.html +1 -1
  262. package/.next/server/app/commands.rsc +4 -4
  263. package/.next/server/app/commands.segments/!KGFwcCk/commands/__PAGE__.segment.rsc +2 -2
  264. package/.next/server/app/commands.segments/!KGFwcCk/commands.segment.rsc +1 -1
  265. package/.next/server/app/commands.segments/!KGFwcCk.segment.rsc +2 -2
  266. package/.next/server/app/commands.segments/_full.segment.rsc +4 -4
  267. package/.next/server/app/commands.segments/_head.segment.rsc +1 -1
  268. package/.next/server/app/commands.segments/_index.segment.rsc +2 -2
  269. package/.next/server/app/commands.segments/_tree.segment.rsc +2 -2
  270. package/.next/server/app/files.html +1 -1
  271. package/.next/server/app/files.rsc +4 -4
  272. package/.next/server/app/files.segments/!KGFwcCk/files/__PAGE__.segment.rsc +2 -2
  273. package/.next/server/app/files.segments/!KGFwcCk/files.segment.rsc +1 -1
  274. package/.next/server/app/files.segments/!KGFwcCk.segment.rsc +2 -2
  275. package/.next/server/app/files.segments/_full.segment.rsc +4 -4
  276. package/.next/server/app/files.segments/_head.segment.rsc +1 -1
  277. package/.next/server/app/files.segments/_index.segment.rsc +2 -2
  278. package/.next/server/app/files.segments/_tree.segment.rsc +2 -2
  279. package/.next/server/app/hooks.html +1 -1
  280. package/.next/server/app/hooks.rsc +4 -4
  281. package/.next/server/app/hooks.segments/!KGFwcCk/hooks/__PAGE__.segment.rsc +2 -2
  282. package/.next/server/app/hooks.segments/!KGFwcCk/hooks.segment.rsc +1 -1
  283. package/.next/server/app/hooks.segments/!KGFwcCk.segment.rsc +2 -2
  284. package/.next/server/app/hooks.segments/_full.segment.rsc +4 -4
  285. package/.next/server/app/hooks.segments/_head.segment.rsc +1 -1
  286. package/.next/server/app/hooks.segments/_index.segment.rsc +2 -2
  287. package/.next/server/app/hooks.segments/_tree.segment.rsc +2 -2
  288. package/.next/server/app/inbox.html +1 -1
  289. package/.next/server/app/inbox.rsc +4 -4
  290. package/.next/server/app/inbox.segments/!KGFwcCk/inbox/__PAGE__.segment.rsc +2 -2
  291. package/.next/server/app/inbox.segments/!KGFwcCk/inbox.segment.rsc +1 -1
  292. package/.next/server/app/inbox.segments/!KGFwcCk.segment.rsc +2 -2
  293. package/.next/server/app/inbox.segments/_full.segment.rsc +4 -4
  294. package/.next/server/app/inbox.segments/_head.segment.rsc +1 -1
  295. package/.next/server/app/inbox.segments/_index.segment.rsc +2 -2
  296. package/.next/server/app/inbox.segments/_tree.segment.rsc +2 -2
  297. package/.next/server/app/index.html +1 -1
  298. package/.next/server/app/index.rsc +4 -4
  299. package/.next/server/app/index.segments/!KGFwcCk/__PAGE__.segment.rsc +2 -2
  300. package/.next/server/app/index.segments/!KGFwcCk.segment.rsc +2 -2
  301. package/.next/server/app/index.segments/_full.segment.rsc +4 -4
  302. package/.next/server/app/index.segments/_head.segment.rsc +1 -1
  303. package/.next/server/app/index.segments/_index.segment.rsc +2 -2
  304. package/.next/server/app/index.segments/_tree.segment.rsc +2 -2
  305. package/.next/server/app/jobs.html +1 -1
  306. package/.next/server/app/jobs.rsc +4 -4
  307. package/.next/server/app/jobs.segments/!KGFwcCk/jobs/__PAGE__.segment.rsc +2 -2
  308. package/.next/server/app/jobs.segments/!KGFwcCk/jobs.segment.rsc +1 -1
  309. package/.next/server/app/jobs.segments/!KGFwcCk.segment.rsc +2 -2
  310. package/.next/server/app/jobs.segments/_full.segment.rsc +4 -4
  311. package/.next/server/app/jobs.segments/_head.segment.rsc +1 -1
  312. package/.next/server/app/jobs.segments/_index.segment.rsc +2 -2
  313. package/.next/server/app/jobs.segments/_tree.segment.rsc +2 -2
  314. package/.next/server/app/login/page.js +2 -2
  315. package/.next/server/app/login/page_client-reference-manifest.js +1 -1
  316. package/.next/server/app/login.html +1 -1
  317. package/.next/server/app/login.rsc +2 -2
  318. package/.next/server/app/login.segments/_full.segment.rsc +2 -2
  319. package/.next/server/app/login.segments/_head.segment.rsc +1 -1
  320. package/.next/server/app/login.segments/_index.segment.rsc +2 -2
  321. package/.next/server/app/login.segments/_tree.segment.rsc +2 -2
  322. package/.next/server/app/login.segments/login/__PAGE__.segment.rsc +1 -1
  323. package/.next/server/app/login.segments/login.segment.rsc +1 -1
  324. package/.next/server/app/mcp-servers.html +1 -1
  325. package/.next/server/app/mcp-servers.rsc +4 -4
  326. package/.next/server/app/mcp-servers.segments/!KGFwcCk/mcp-servers/__PAGE__.segment.rsc +2 -2
  327. package/.next/server/app/mcp-servers.segments/!KGFwcCk/mcp-servers.segment.rsc +1 -1
  328. package/.next/server/app/mcp-servers.segments/!KGFwcCk.segment.rsc +2 -2
  329. package/.next/server/app/mcp-servers.segments/_full.segment.rsc +4 -4
  330. package/.next/server/app/mcp-servers.segments/_head.segment.rsc +1 -1
  331. package/.next/server/app/mcp-servers.segments/_index.segment.rsc +2 -2
  332. package/.next/server/app/mcp-servers.segments/_tree.segment.rsc +2 -2
  333. package/.next/server/app/reviews.html +1 -1
  334. package/.next/server/app/reviews.rsc +4 -4
  335. package/.next/server/app/reviews.segments/!KGFwcCk/reviews/__PAGE__.segment.rsc +2 -2
  336. package/.next/server/app/reviews.segments/!KGFwcCk/reviews.segment.rsc +1 -1
  337. package/.next/server/app/reviews.segments/!KGFwcCk.segment.rsc +2 -2
  338. package/.next/server/app/reviews.segments/_full.segment.rsc +4 -4
  339. package/.next/server/app/reviews.segments/_head.segment.rsc +1 -1
  340. package/.next/server/app/reviews.segments/_index.segment.rsc +2 -2
  341. package/.next/server/app/reviews.segments/_tree.segment.rsc +2 -2
  342. package/.next/server/app/settings/appearance.html +1 -0
  343. package/.next/server/app/settings/appearance.meta +17 -0
  344. package/.next/server/app/settings/appearance.rsc +23 -0
  345. package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings/appearance/__PAGE__.segment.rsc +9 -0
  346. package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings/appearance.segment.rsc +5 -0
  347. package/.next/server/app/settings/appearance.segments/!KGFwcCk/settings.segment.rsc +5 -0
  348. package/.next/server/app/settings/appearance.segments/!KGFwcCk.segment.rsc +7 -0
  349. package/.next/server/app/settings/appearance.segments/_full.segment.rsc +23 -0
  350. package/.next/server/app/settings/appearance.segments/_head.segment.rsc +6 -0
  351. package/.next/server/app/settings/appearance.segments/_index.segment.rsc +5 -0
  352. package/.next/server/app/settings/appearance.segments/_tree.segment.rsc +2 -0
  353. package/.next/server/app/settings/notifications.html +1 -1
  354. package/.next/server/app/settings/notifications.rsc +4 -4
  355. package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications/__PAGE__.segment.rsc +2 -2
  356. package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings/notifications.segment.rsc +1 -1
  357. package/.next/server/app/settings/notifications.segments/!KGFwcCk/settings.segment.rsc +1 -1
  358. package/.next/server/app/settings/notifications.segments/!KGFwcCk.segment.rsc +2 -2
  359. package/.next/server/app/settings/notifications.segments/_full.segment.rsc +4 -4
  360. package/.next/server/app/settings/notifications.segments/_head.segment.rsc +1 -1
  361. package/.next/server/app/settings/notifications.segments/_index.segment.rsc +2 -2
  362. package/.next/server/app/settings/notifications.segments/_tree.segment.rsc +2 -2
  363. package/.next/server/app/settings/providers/new.html +1 -0
  364. package/.next/server/app/settings/providers/new.meta +18 -0
  365. package/.next/server/app/settings/providers/new.rsc +23 -0
  366. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers/new/__PAGE__.segment.rsc +9 -0
  367. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers/new.segment.rsc +5 -0
  368. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings/providers.segment.rsc +5 -0
  369. package/.next/server/app/settings/providers/new.segments/!KGFwcCk/settings.segment.rsc +5 -0
  370. package/.next/server/app/settings/providers/new.segments/!KGFwcCk.segment.rsc +7 -0
  371. package/.next/server/app/settings/providers/new.segments/_full.segment.rsc +23 -0
  372. package/.next/server/app/settings/providers/new.segments/_head.segment.rsc +6 -0
  373. package/.next/server/app/settings/providers/new.segments/_index.segment.rsc +5 -0
  374. package/.next/server/app/settings/providers/new.segments/_tree.segment.rsc +2 -0
  375. package/.next/server/app/settings/providers.html +1 -0
  376. package/.next/server/app/settings/providers.meta +17 -0
  377. package/.next/server/app/settings/providers.rsc +23 -0
  378. package/.next/server/app/settings/providers.segments/!KGFwcCk/settings/providers/__PAGE__.segment.rsc +9 -0
  379. package/.next/server/app/settings/providers.segments/!KGFwcCk/settings/providers.segment.rsc +5 -0
  380. package/.next/server/app/settings/providers.segments/!KGFwcCk/settings.segment.rsc +5 -0
  381. package/.next/server/app/settings/providers.segments/!KGFwcCk.segment.rsc +7 -0
  382. package/.next/server/app/settings/providers.segments/_full.segment.rsc +23 -0
  383. package/.next/server/app/settings/providers.segments/_head.segment.rsc +6 -0
  384. package/.next/server/app/settings/providers.segments/_index.segment.rsc +5 -0
  385. package/.next/server/app/settings/providers.segments/_tree.segment.rsc +2 -0
  386. package/.next/server/app/settings/session.html +1 -0
  387. package/.next/server/app/settings/session.meta +17 -0
  388. package/.next/server/app/settings/session.rsc +23 -0
  389. package/.next/server/app/settings/session.segments/!KGFwcCk/settings/session/__PAGE__.segment.rsc +9 -0
  390. package/.next/server/app/settings/session.segments/!KGFwcCk/settings/session.segment.rsc +5 -0
  391. package/.next/server/app/settings/session.segments/!KGFwcCk/settings.segment.rsc +5 -0
  392. package/.next/server/app/settings/session.segments/!KGFwcCk.segment.rsc +7 -0
  393. package/.next/server/app/settings/session.segments/_full.segment.rsc +23 -0
  394. package/.next/server/app/settings/session.segments/_head.segment.rsc +6 -0
  395. package/.next/server/app/settings/session.segments/_index.segment.rsc +5 -0
  396. package/.next/server/app/settings/session.segments/_tree.segment.rsc +2 -0
  397. package/.next/server/app/settings.html +1 -1
  398. package/.next/server/app/settings.rsc +4 -4
  399. package/.next/server/app/settings.segments/!KGFwcCk/settings/__PAGE__.segment.rsc +2 -2
  400. package/.next/server/app/settings.segments/!KGFwcCk/settings.segment.rsc +1 -1
  401. package/.next/server/app/settings.segments/!KGFwcCk.segment.rsc +2 -2
  402. package/.next/server/app/settings.segments/_full.segment.rsc +4 -4
  403. package/.next/server/app/settings.segments/_head.segment.rsc +1 -1
  404. package/.next/server/app/settings.segments/_index.segment.rsc +2 -2
  405. package/.next/server/app/settings.segments/_tree.segment.rsc +2 -2
  406. package/.next/server/app/skills.html +1 -1
  407. package/.next/server/app/skills.rsc +4 -4
  408. package/.next/server/app/skills.segments/!KGFwcCk/skills/__PAGE__.segment.rsc +2 -2
  409. package/.next/server/app/skills.segments/!KGFwcCk/skills.segment.rsc +1 -1
  410. package/.next/server/app/skills.segments/!KGFwcCk.segment.rsc +2 -2
  411. package/.next/server/app/skills.segments/_full.segment.rsc +4 -4
  412. package/.next/server/app/skills.segments/_head.segment.rsc +1 -1
  413. package/.next/server/app/skills.segments/_index.segment.rsc +2 -2
  414. package/.next/server/app/skills.segments/_tree.segment.rsc +2 -2
  415. package/.next/server/app-paths-manifest.json +16 -3
  416. package/.next/server/chunks/1002.js +18 -0
  417. package/.next/server/chunks/1011.js +1 -0
  418. package/.next/server/chunks/1659.js +1 -1
  419. package/.next/server/chunks/1979.js +2 -2
  420. package/.next/server/chunks/2408.js +1 -1
  421. package/.next/server/chunks/{7627.js → 3006.js} +3 -3
  422. package/.next/server/chunks/3434.js +1 -0
  423. package/.next/server/chunks/{5920.js → 4342.js} +1 -1
  424. package/.next/server/chunks/4352.js +1 -0
  425. package/.next/server/chunks/4445.js +1 -1
  426. package/.next/server/chunks/7782.js +6 -0
  427. package/.next/server/chunks/8148.js +1 -0
  428. package/.next/server/chunks/9599.js +11 -0
  429. package/.next/server/middleware-build-manifest.js +1 -1
  430. package/.next/server/middleware-react-loadable-manifest.js +1 -1
  431. package/.next/server/pages/404.html +1 -1
  432. package/.next/server/pages/500.html +1 -1
  433. package/.next/server/server-reference-manifest.json +1 -1
  434. package/.next/static/chunks/{35922.5bdf78a760129504.js → 13541.056c34ca7fde6869.js} +1 -1
  435. package/.next/static/chunks/26126-97874904b42befb8.js +1 -0
  436. package/.next/static/chunks/31010-6e87f77b97544424.js +1 -0
  437. package/.next/static/chunks/3765-d323c6675307a63e.js +20 -0
  438. package/.next/static/chunks/{11242-d240a18d4e59390b.js → 41487-d802643f4a8fad3c.js} +5 -5
  439. package/.next/static/chunks/48273-bbd15bac6733dfc4.js +6 -0
  440. package/.next/static/chunks/63606.a387b0261d6523ab.js +1 -0
  441. package/.next/static/chunks/6935-f436a624267529fb.js +1 -0
  442. package/.next/static/chunks/{69427.0f379c6bdea95405.js → 69427.a0b463c808aa54c8.js} +1 -1
  443. package/.next/static/chunks/86939-dfc6f8eb395caa89.js +1 -0
  444. package/.next/static/chunks/app/(app)/agents/[name]/page-8bdd0359043537d4.js +8 -0
  445. package/.next/static/chunks/app/(app)/agents/page-6fcfd7ab6781814e.js +1 -0
  446. package/.next/static/chunks/app/(app)/changes/page-4549a5bd72d77e3e.js +1 -0
  447. package/.next/static/chunks/app/(app)/claude-md/edit/page-08e6e120e71979f4.js +1 -0
  448. package/.next/static/chunks/app/(app)/claude-md/page-cd9e2176a12ba241.js +1 -0
  449. package/.next/static/chunks/app/(app)/commands/[name]/page-7cdfdef29ded0aa0.js +6 -0
  450. package/.next/static/chunks/app/(app)/commands/page-f126b608b04747ac.js +1 -0
  451. package/.next/static/chunks/app/(app)/files/page-f526eb95821e000e.js +1 -0
  452. package/.next/static/chunks/app/(app)/hooks/[event]/page-28038323fd29adfa.js +6 -0
  453. package/.next/static/chunks/app/(app)/hooks/page-f1f39284e53c0344.js +1 -0
  454. package/.next/static/chunks/app/(app)/inbox/[id]/page-bc1ff3a0db0114a4.js +1 -0
  455. package/.next/static/chunks/app/(app)/inbox/page-82e03870103ce9bd.js +1 -0
  456. package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-7fb788f772ff2129.js +1 -0
  457. package/.next/static/chunks/app/(app)/jobs/[id]/page-a5856b9ae967ff59.js +1 -0
  458. package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-b7c513402db11db6.js +1 -0
  459. package/.next/static/chunks/app/(app)/jobs/page-e9bbd6c116b9699f.js +1 -0
  460. package/.next/static/chunks/app/(app)/{layout-81c1899969de11e6.js → layout-ce9e1be301c60fe5.js} +1 -1
  461. package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-d6d805a27ec0b0c0.js +1 -0
  462. package/.next/static/chunks/app/(app)/mcp-servers/page-4b7276d43451cd43.js +1 -0
  463. package/.next/static/chunks/app/(app)/page-027a5382da30ddb9.js +1 -0
  464. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-9ab2955c455bb5fa.js +13 -0
  465. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/{page-c7473a899c7c59c3.js → page-c5fd013309ab3eba.js} +1 -1
  466. package/.next/static/chunks/app/(app)/reviews/{page-0e6e7395a4f62b50.js → page-47530d93bb9d4a76.js} +1 -1
  467. package/.next/static/chunks/app/(app)/sessions/[id]/page-94f891e1b54fd05f.js +1 -0
  468. package/.next/static/chunks/app/(app)/settings/appearance/page-95902da748ac5f1e.js +1 -0
  469. package/.next/static/chunks/app/(app)/settings/notifications/{page-a28db2ebc9fd0de8.js → page-229f1db6beb1d19c.js} +1 -1
  470. package/.next/static/chunks/app/(app)/settings/page-8ed16a66fdde10cd.js +1 -0
  471. package/.next/static/chunks/app/(app)/settings/providers/[id]/page-13654263246617b3.js +1 -0
  472. package/.next/static/chunks/app/(app)/settings/providers/new/page-e1798e321ccbc6df.js +1 -0
  473. package/.next/static/chunks/app/(app)/settings/providers/page-0bb4c1db2ee35b3d.js +1 -0
  474. package/.next/static/chunks/app/(app)/settings/session/page-ab216a8fa37a0f76.js +1 -0
  475. package/.next/static/chunks/app/(app)/skills/[name]/page-8ab85d5090967ee4.js +6 -0
  476. package/.next/static/chunks/app/(app)/skills/page-c52773eacb27c04e.js +1 -0
  477. package/.next/static/chunks/app/_global-error/page-fc747760bd4c8a4b.js +1 -0
  478. package/.next/static/chunks/app/api/agents/[name]/route-fc747760bd4c8a4b.js +1 -0
  479. package/.next/static/chunks/app/api/agents/route-fc747760bd4c8a4b.js +1 -0
  480. package/.next/static/chunks/app/api/auth/check/route-fc747760bd4c8a4b.js +1 -0
  481. package/.next/static/chunks/app/api/auth/login/route-fc747760bd4c8a4b.js +1 -0
  482. package/.next/static/chunks/app/api/auth/setup/route-fc747760bd4c8a4b.js +1 -0
  483. package/.next/static/chunks/app/api/auth/ws-token/route-fc747760bd4c8a4b.js +1 -0
  484. package/.next/static/chunks/app/api/btw/route-fc747760bd4c8a4b.js +1 -0
  485. package/.next/static/chunks/app/api/claude-md/route-fc747760bd4c8a4b.js +1 -0
  486. package/.next/static/chunks/app/api/commands/[name]/route-fc747760bd4c8a4b.js +1 -0
  487. package/.next/static/chunks/app/api/commands/route-fc747760bd4c8a4b.js +1 -0
  488. package/.next/static/chunks/app/api/defaults/route-fc747760bd4c8a4b.js +1 -0
  489. package/.next/static/chunks/app/api/filesystem/browse/route-fc747760bd4c8a4b.js +1 -0
  490. package/.next/static/chunks/app/api/filesystem/files/route-fc747760bd4c8a4b.js +1 -0
  491. package/.next/static/chunks/app/api/filesystem/mkdir/route-fc747760bd4c8a4b.js +1 -0
  492. package/.next/static/chunks/app/api/filesystem/read/route-fc747760bd4c8a4b.js +1 -0
  493. package/.next/static/chunks/app/api/git/clone/route-fc747760bd4c8a4b.js +1 -0
  494. package/.next/static/chunks/app/api/git/commit/route-fc747760bd4c8a4b.js +1 -0
  495. package/.next/static/chunks/app/api/git/diff/route-fc747760bd4c8a4b.js +1 -0
  496. package/.next/static/chunks/app/api/git/discard/route-fc747760bd4c8a4b.js +1 -0
  497. package/.next/static/chunks/app/api/git/generate-message/route-fc747760bd4c8a4b.js +1 -0
  498. package/.next/static/chunks/app/api/git/push/route-fc747760bd4c8a4b.js +1 -0
  499. package/.next/static/chunks/app/api/git/status/route-fc747760bd4c8a4b.js +1 -0
  500. package/.next/static/chunks/app/api/github/file-content/route-fc747760bd4c8a4b.js +1 -0
  501. package/.next/static/chunks/app/api/github/orgs/route-fc747760bd4c8a4b.js +1 -0
  502. package/.next/static/chunks/app/api/github/prs/checks/route-fc747760bd4c8a4b.js +1 -0
  503. package/.next/static/chunks/app/api/github/prs/diff/route-fc747760bd4c8a4b.js +1 -0
  504. package/.next/static/chunks/app/api/github/prs/review/route-fc747760bd4c8a4b.js +1 -0
  505. package/.next/static/chunks/app/api/github/prs/route-fc747760bd4c8a4b.js +1 -0
  506. package/.next/static/chunks/app/api/github/prs/view/route-fc747760bd4c8a4b.js +1 -0
  507. package/.next/static/chunks/app/api/github/repos/route-fc747760bd4c8a4b.js +1 -0
  508. package/.next/static/chunks/app/api/github/review-session/route-fc747760bd4c8a4b.js +1 -0
  509. package/.next/static/chunks/app/api/health/route-fc747760bd4c8a4b.js +1 -0
  510. package/.next/static/chunks/app/api/hooks/route-fc747760bd4c8a4b.js +1 -0
  511. package/.next/static/chunks/app/api/inbox/[id]/route-fc747760bd4c8a4b.js +1 -0
  512. package/.next/static/chunks/app/api/inbox/route-fc747760bd4c8a4b.js +1 -0
  513. package/.next/static/chunks/app/api/jobs/[id]/route-fc747760bd4c8a4b.js +1 -0
  514. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-fc747760bd4c8a4b.js +1 -0
  515. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-fc747760bd4c8a4b.js +1 -0
  516. package/.next/static/chunks/app/api/jobs/[id]/runs/route-fc747760bd4c8a4b.js +1 -0
  517. package/.next/static/chunks/app/api/jobs/[id]/trigger/route-fc747760bd4c8a4b.js +1 -0
  518. package/.next/static/chunks/app/api/jobs/mcp-discover/route-fc747760bd4c8a4b.js +1 -0
  519. package/.next/static/chunks/app/api/jobs/route-fc747760bd4c8a4b.js +1 -0
  520. package/.next/static/chunks/app/api/jobs/status/route-fc747760bd4c8a4b.js +1 -0
  521. package/.next/static/chunks/app/api/mcp-servers/[name]/route-fc747760bd4c8a4b.js +1 -0
  522. package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-fc747760bd4c8a4b.js +1 -0
  523. package/.next/static/chunks/app/api/mcp-servers/route-fc747760bd4c8a4b.js +1 -0
  524. package/.next/static/chunks/app/api/notifications/route-fc747760bd4c8a4b.js +1 -0
  525. package/.next/static/chunks/app/api/notifications/test/route-fc747760bd4c8a4b.js +1 -0
  526. package/.next/static/chunks/app/api/providers/[id]/route-fc747760bd4c8a4b.js +1 -0
  527. package/.next/static/chunks/app/api/providers/route-fc747760bd4c8a4b.js +1 -0
  528. package/.next/static/chunks/app/api/reviews/pinned/route-fc747760bd4c8a4b.js +1 -0
  529. package/.next/static/chunks/app/api/sessions/[id]/context/route-fc747760bd4c8a4b.js +1 -0
  530. package/.next/static/chunks/app/api/sessions/[id]/mcp/route-fc747760bd4c8a4b.js +1 -0
  531. package/.next/static/chunks/app/api/sessions/[id]/route-fc747760bd4c8a4b.js +1 -0
  532. package/.next/static/chunks/app/api/sessions/[id]/search/route-fc747760bd4c8a4b.js +1 -0
  533. package/.next/static/chunks/app/api/sessions/[id]/tabs/route-fc747760bd4c8a4b.js +1 -0
  534. package/.next/static/chunks/app/api/sessions/bulk-delete/route-fc747760bd4c8a4b.js +1 -0
  535. package/.next/static/chunks/app/api/sessions/by-ids/route-fc747760bd4c8a4b.js +1 -0
  536. package/.next/static/chunks/app/api/sessions/group/route-fc747760bd4c8a4b.js +1 -0
  537. package/.next/static/chunks/app/api/sessions/pinned/route-fc747760bd4c8a4b.js +1 -0
  538. package/.next/static/chunks/app/api/sessions/route-fc747760bd4c8a4b.js +1 -0
  539. package/.next/static/chunks/app/api/sessions/search/route-fc747760bd4c8a4b.js +1 -0
  540. package/.next/static/chunks/app/api/sessions/thinking/route-fc747760bd4c8a4b.js +1 -0
  541. package/.next/static/chunks/app/api/skills/[name]/route-fc747760bd4c8a4b.js +1 -0
  542. package/.next/static/chunks/app/api/skills/route-fc747760bd4c8a4b.js +1 -0
  543. package/.next/static/chunks/app/api/terminal/[id]/route-fc747760bd4c8a4b.js +1 -0
  544. package/.next/static/chunks/app/api/terminal/route-fc747760bd4c8a4b.js +1 -0
  545. package/.next/static/chunks/app/api/usage/route-fc747760bd4c8a4b.js +1 -0
  546. package/.next/static/chunks/app/api/version/changelog/route-fc747760bd4c8a4b.js +1 -0
  547. package/.next/static/chunks/app/api/version/cockpit/changelog/route-fc747760bd4c8a4b.js +1 -0
  548. package/.next/static/chunks/app/api/version/cockpit/route-fc747760bd4c8a4b.js +1 -0
  549. package/.next/static/chunks/app/api/version/route-fc747760bd4c8a4b.js +1 -0
  550. package/.next/static/chunks/e868780c.f24b6da08e62c7b2.js +18 -0
  551. package/.next/static/chunks/next/dist/client/components/builtin/app-error-fc747760bd4c8a4b.js +1 -0
  552. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-fc747760bd4c8a4b.js +1 -0
  553. package/.next/static/chunks/next/dist/client/components/builtin/not-found-fc747760bd4c8a4b.js +1 -0
  554. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-fc747760bd4c8a4b.js +1 -0
  555. package/.next/static/chunks/webpack-e31bb45fa59caed8.js +1 -0
  556. package/.next/static/css/3f8af4ae6f812d5c.css +1 -0
  557. package/.next/static/zr8XZzqb74eHitdlkpo-C/_buildManifest.js +1 -0
  558. package/bin/cockpit-hook-bridge.mjs +101 -0
  559. package/dist/server.js +11 -1
  560. package/dist/src/lib/models.js +48 -7
  561. package/dist/src/server/auth.js +32 -10
  562. package/dist/src/server/claude-settings.js +153 -0
  563. package/dist/src/server/cli-init-fetch.js +86 -0
  564. package/dist/src/server/cron-utils.js +16 -5
  565. package/dist/src/server/debug-logger.js +2 -2
  566. package/dist/src/server/defaults.js +16 -7
  567. package/dist/src/server/fs-watcher.js +50 -0
  568. package/dist/src/server/hook-bridge-path.js +34 -0
  569. package/dist/src/server/hook-event-translator.js +211 -0
  570. package/dist/src/server/hook-router.js +150 -0
  571. package/dist/src/server/inbox.js +14 -10
  572. package/dist/src/server/job-lock.js +103 -0
  573. package/dist/src/server/job-scheduler.js +23 -8
  574. package/dist/src/server/job-storage.js +28 -13
  575. package/dist/src/server/notification-settings.js +13 -9
  576. package/dist/src/server/paths.js +23 -0
  577. package/dist/src/server/plans.js +8 -5
  578. package/dist/src/server/providers.js +128 -0
  579. package/dist/src/server/pty-runtime.js +324 -0
  580. package/dist/src/server/pty-session.js +178 -0
  581. package/dist/src/server/session-manager.js +727 -144
  582. package/dist/src/server/session-prefs.js +33 -8
  583. package/dist/src/server/singleton.js +18 -0
  584. package/dist/src/server/stream-processor.js +61 -48
  585. package/dist/src/server/terminal-manager.js +153 -0
  586. package/dist/src/server/todo-watcher.js +178 -0
  587. package/dist/src/server/transcript-watcher.js +91 -0
  588. package/dist/src/server/transcript.js +177 -11
  589. package/dist/src/server/ws-handler.js +235 -61
  590. package/next.config.ts +1 -0
  591. package/package.json +10 -3
  592. package/public/fonts/symbols-nerd-font-mono.woff2 +0 -0
  593. package/.next/server/chunks/1941.js +0 -9
  594. package/.next/server/chunks/2444.js +0 -6
  595. package/.next/static/brzairTqHmHwvfgKpdkYX/_buildManifest.js +0 -1
  596. package/.next/static/chunks/3765-a4c7a493ec83f918.js +0 -20
  597. package/.next/static/chunks/75866-76a3987dda1295ae.js +0 -1
  598. package/.next/static/chunks/93273-87110c1449e1e7fd.js +0 -6
  599. package/.next/static/chunks/app/(app)/agents/[name]/page-3ec9a3460e8e9006.js +0 -8
  600. package/.next/static/chunks/app/(app)/agents/page-d6d504e7d7757ea2.js +0 -1
  601. package/.next/static/chunks/app/(app)/changes/page-a09bf4742aa8b5ce.js +0 -1
  602. package/.next/static/chunks/app/(app)/claude-md/edit/page-ab42921ba2618dc3.js +0 -1
  603. package/.next/static/chunks/app/(app)/claude-md/page-c4c8b20aa002a94a.js +0 -1
  604. package/.next/static/chunks/app/(app)/commands/[name]/page-2124ffed9a4e95a3.js +0 -6
  605. package/.next/static/chunks/app/(app)/commands/page-d5bf1bddd17e31dd.js +0 -1
  606. package/.next/static/chunks/app/(app)/files/page-04e4e5bf1ca89945.js +0 -1
  607. package/.next/static/chunks/app/(app)/hooks/[event]/page-d988623e739973b5.js +0 -6
  608. package/.next/static/chunks/app/(app)/hooks/page-818242d7db432578.js +0 -1
  609. package/.next/static/chunks/app/(app)/inbox/[id]/page-c33dc94e309ff117.js +0 -1
  610. package/.next/static/chunks/app/(app)/inbox/page-ca3e1724b5072734.js +0 -1
  611. package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-3a1c927d76333bf0.js +0 -1
  612. package/.next/static/chunks/app/(app)/jobs/[id]/page-8e698e00b90968b0.js +0 -1
  613. package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-f942df0b7c1d280b.js +0 -1
  614. package/.next/static/chunks/app/(app)/jobs/page-7a88cc6ac34550c2.js +0 -1
  615. package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-3541bf3ccdef9145.js +0 -1
  616. package/.next/static/chunks/app/(app)/mcp-servers/page-3927dfd03d921040.js +0 -1
  617. package/.next/static/chunks/app/(app)/page-594120e0ea1df527.js +0 -1
  618. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-74c23b04f5c3ff88.js +0 -13
  619. package/.next/static/chunks/app/(app)/sessions/[id]/page-435e9fb4dd34007d.js +0 -1
  620. package/.next/static/chunks/app/(app)/settings/page-f8ada7997c0d5b03.js +0 -1
  621. package/.next/static/chunks/app/(app)/skills/[name]/page-5dbe1e7682880145.js +0 -6
  622. package/.next/static/chunks/app/(app)/skills/page-fd1986ad7e060f4d.js +0 -1
  623. package/.next/static/chunks/app/_global-error/page-65c661eddfc65f5b.js +0 -1
  624. package/.next/static/chunks/app/api/agents/[name]/route-65c661eddfc65f5b.js +0 -1
  625. package/.next/static/chunks/app/api/agents/route-65c661eddfc65f5b.js +0 -1
  626. package/.next/static/chunks/app/api/auth/check/route-65c661eddfc65f5b.js +0 -1
  627. package/.next/static/chunks/app/api/auth/login/route-65c661eddfc65f5b.js +0 -1
  628. package/.next/static/chunks/app/api/auth/setup/route-65c661eddfc65f5b.js +0 -1
  629. package/.next/static/chunks/app/api/auth/ws-token/route-65c661eddfc65f5b.js +0 -1
  630. package/.next/static/chunks/app/api/btw/route-65c661eddfc65f5b.js +0 -1
  631. package/.next/static/chunks/app/api/claude-md/route-65c661eddfc65f5b.js +0 -1
  632. package/.next/static/chunks/app/api/commands/[name]/route-65c661eddfc65f5b.js +0 -1
  633. package/.next/static/chunks/app/api/commands/route-65c661eddfc65f5b.js +0 -1
  634. package/.next/static/chunks/app/api/defaults/route-65c661eddfc65f5b.js +0 -1
  635. package/.next/static/chunks/app/api/filesystem/browse/route-65c661eddfc65f5b.js +0 -1
  636. package/.next/static/chunks/app/api/filesystem/files/route-65c661eddfc65f5b.js +0 -1
  637. package/.next/static/chunks/app/api/filesystem/mkdir/route-65c661eddfc65f5b.js +0 -1
  638. package/.next/static/chunks/app/api/filesystem/read/route-65c661eddfc65f5b.js +0 -1
  639. package/.next/static/chunks/app/api/git/clone/route-65c661eddfc65f5b.js +0 -1
  640. package/.next/static/chunks/app/api/git/commit/route-65c661eddfc65f5b.js +0 -1
  641. package/.next/static/chunks/app/api/git/diff/route-65c661eddfc65f5b.js +0 -1
  642. package/.next/static/chunks/app/api/git/discard/route-65c661eddfc65f5b.js +0 -1
  643. package/.next/static/chunks/app/api/git/generate-message/route-65c661eddfc65f5b.js +0 -1
  644. package/.next/static/chunks/app/api/git/push/route-65c661eddfc65f5b.js +0 -1
  645. package/.next/static/chunks/app/api/git/status/route-65c661eddfc65f5b.js +0 -1
  646. package/.next/static/chunks/app/api/github/file-content/route-65c661eddfc65f5b.js +0 -1
  647. package/.next/static/chunks/app/api/github/orgs/route-65c661eddfc65f5b.js +0 -1
  648. package/.next/static/chunks/app/api/github/prs/checks/route-65c661eddfc65f5b.js +0 -1
  649. package/.next/static/chunks/app/api/github/prs/diff/route-65c661eddfc65f5b.js +0 -1
  650. package/.next/static/chunks/app/api/github/prs/review/route-65c661eddfc65f5b.js +0 -1
  651. package/.next/static/chunks/app/api/github/prs/route-65c661eddfc65f5b.js +0 -1
  652. package/.next/static/chunks/app/api/github/prs/view/route-65c661eddfc65f5b.js +0 -1
  653. package/.next/static/chunks/app/api/github/repos/route-65c661eddfc65f5b.js +0 -1
  654. package/.next/static/chunks/app/api/github/review-session/route-65c661eddfc65f5b.js +0 -1
  655. package/.next/static/chunks/app/api/health/route-65c661eddfc65f5b.js +0 -1
  656. package/.next/static/chunks/app/api/hooks/route-65c661eddfc65f5b.js +0 -1
  657. package/.next/static/chunks/app/api/inbox/[id]/route-65c661eddfc65f5b.js +0 -1
  658. package/.next/static/chunks/app/api/inbox/route-65c661eddfc65f5b.js +0 -1
  659. package/.next/static/chunks/app/api/jobs/[id]/route-65c661eddfc65f5b.js +0 -1
  660. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-65c661eddfc65f5b.js +0 -1
  661. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-65c661eddfc65f5b.js +0 -1
  662. package/.next/static/chunks/app/api/jobs/[id]/runs/route-65c661eddfc65f5b.js +0 -1
  663. package/.next/static/chunks/app/api/jobs/[id]/trigger/route-65c661eddfc65f5b.js +0 -1
  664. package/.next/static/chunks/app/api/jobs/mcp-discover/route-65c661eddfc65f5b.js +0 -1
  665. package/.next/static/chunks/app/api/jobs/route-65c661eddfc65f5b.js +0 -1
  666. package/.next/static/chunks/app/api/jobs/status/route-65c661eddfc65f5b.js +0 -1
  667. package/.next/static/chunks/app/api/mcp-servers/[name]/route-65c661eddfc65f5b.js +0 -1
  668. package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-65c661eddfc65f5b.js +0 -1
  669. package/.next/static/chunks/app/api/mcp-servers/route-65c661eddfc65f5b.js +0 -1
  670. package/.next/static/chunks/app/api/notifications/route-65c661eddfc65f5b.js +0 -1
  671. package/.next/static/chunks/app/api/notifications/test/route-65c661eddfc65f5b.js +0 -1
  672. package/.next/static/chunks/app/api/reviews/pinned/route-65c661eddfc65f5b.js +0 -1
  673. package/.next/static/chunks/app/api/sessions/[id]/context/route-65c661eddfc65f5b.js +0 -1
  674. package/.next/static/chunks/app/api/sessions/[id]/mcp/route-65c661eddfc65f5b.js +0 -1
  675. package/.next/static/chunks/app/api/sessions/[id]/route-65c661eddfc65f5b.js +0 -1
  676. package/.next/static/chunks/app/api/sessions/[id]/search/route-65c661eddfc65f5b.js +0 -1
  677. package/.next/static/chunks/app/api/sessions/bulk-delete/route-65c661eddfc65f5b.js +0 -1
  678. package/.next/static/chunks/app/api/sessions/by-ids/route-65c661eddfc65f5b.js +0 -1
  679. package/.next/static/chunks/app/api/sessions/group/route-65c661eddfc65f5b.js +0 -1
  680. package/.next/static/chunks/app/api/sessions/pinned/route-65c661eddfc65f5b.js +0 -1
  681. package/.next/static/chunks/app/api/sessions/route-65c661eddfc65f5b.js +0 -1
  682. package/.next/static/chunks/app/api/sessions/search/route-65c661eddfc65f5b.js +0 -1
  683. package/.next/static/chunks/app/api/skills/[name]/route-65c661eddfc65f5b.js +0 -1
  684. package/.next/static/chunks/app/api/skills/route-65c661eddfc65f5b.js +0 -1
  685. package/.next/static/chunks/app/api/usage/route-65c661eddfc65f5b.js +0 -1
  686. package/.next/static/chunks/app/api/version/cockpit/route-65c661eddfc65f5b.js +0 -1
  687. package/.next/static/chunks/app/api/version/route-65c661eddfc65f5b.js +0 -1
  688. package/.next/static/chunks/next/dist/client/components/builtin/app-error-65c661eddfc65f5b.js +0 -1
  689. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-65c661eddfc65f5b.js +0 -1
  690. package/.next/static/chunks/next/dist/client/components/builtin/not-found-65c661eddfc65f5b.js +0 -1
  691. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-65c661eddfc65f5b.js +0 -1
  692. package/.next/static/chunks/webpack-3461a05957b13f46.js +0 -1
  693. package/.next/static/css/f04f303b5708dd90.css +0 -1
  694. /package/.next/static/{brzairTqHmHwvfgKpdkYX → zr8XZzqb74eHitdlkpo-C}/_ssgManifest.js +0 -0
@@ -5,15 +5,88 @@ const ws_1 = require("ws");
5
5
  const auth_1 = require("./auth");
6
6
  // loadLastUsage no longer needed - usage is returned by loadTranscript
7
7
  const debug_logger_1 = require("./debug-logger");
8
+ const fs_watcher_1 = require("./fs-watcher");
8
9
  const plans_1 = require("./plans");
9
- const session_manager_1 = require("./session-manager");
10
10
  const session_prefs_1 = require("./session-prefs");
11
- function createWebSocketHandler(server, sessionManager) {
11
+ const RESIZE_PREFIX = "\x01R";
12
+ function setupTerminalWebSocket(terminalWss, terminalManager) {
13
+ const heartbeat = setInterval(() => {
14
+ for (const ws of terminalWss.clients) {
15
+ const ext = ws;
16
+ if (ext.isAlive === false) {
17
+ ws.terminate();
18
+ continue;
19
+ }
20
+ ext.isAlive = false;
21
+ ws.ping();
22
+ }
23
+ }, 30000);
24
+ terminalWss.on("close", () => {
25
+ clearInterval(heartbeat);
26
+ });
27
+ terminalWss.on("connection", (ws, req) => {
28
+ const ext = ws;
29
+ ext.isAlive = true;
30
+ ws.on("pong", () => {
31
+ ext.isAlive = true;
32
+ });
33
+ const url = new URL(req.url || "", "http://localhost");
34
+ const terminalId = url.searchParams.get("terminalId");
35
+ if (!terminalId) {
36
+ ws.close(1008, "Missing terminalId");
37
+ return;
38
+ }
39
+ const terminal = terminalManager.getTerminal(terminalId);
40
+ if (!terminal) {
41
+ console.log(`[terminal-ws] terminal not found: ${terminalId.slice(0, 8)}`);
42
+ ws.close(1008, "Terminal not found");
43
+ return;
44
+ }
45
+ const wantsReplay = url.searchParams.get("replay") !== "0";
46
+ console.log(`[terminal-ws] connected: ${terminalId.slice(0, 8)} replay=${wantsReplay}`);
47
+ terminalManager.attachClient(terminalId, (data) => {
48
+ if (ws.readyState === ws_1.WebSocket.OPEN) {
49
+ ws.send(data);
50
+ }
51
+ });
52
+ if (!wantsReplay) {
53
+ const delta = terminalManager.getDelta(terminalId);
54
+ if (delta) {
55
+ console.log(`[terminal-ws] sending delta: ${delta.length}b`);
56
+ ws.send(delta);
57
+ }
58
+ }
59
+ let bufferSent = !wantsReplay;
60
+ ws.on("message", (data) => {
61
+ const str = data.toString();
62
+ if (str.startsWith(RESIZE_PREFIX)) {
63
+ const parts = str.slice(RESIZE_PREFIX.length).split(";");
64
+ const cols = parseInt(parts[0], 10);
65
+ const rows = parseInt(parts[1], 10);
66
+ const replayBuffer = !bufferSent ? terminalManager.getBuffer(terminalId) : null;
67
+ if (cols > 0 && rows > 0) {
68
+ terminalManager.resizeTerminal(terminalId, cols, rows);
69
+ }
70
+ if (!bufferSent) {
71
+ bufferSent = true;
72
+ if (replayBuffer) {
73
+ ws.send("\x1b[2J\x1b[3J\x1b[H" + replayBuffer);
74
+ }
75
+ }
76
+ return;
77
+ }
78
+ terminalManager.writeToTerminal(terminalId, str);
79
+ });
80
+ ws.on("close", () => {
81
+ console.log(`[terminal-ws] disconnected: ${terminalId.slice(0, 8)}`);
82
+ terminalManager.detachClient(terminalId);
83
+ });
84
+ });
85
+ }
86
+ function createWebSocketHandler(server, sessionManager, terminalManager) {
12
87
  const wss = new ws_1.WebSocketServer({ noServer: true });
13
- // Server-side heartbeat: detect dead connections every 30s.
14
- // Without this, zombie connections persist for hours (TCP keepalive default)
15
- // and can cause CLI process stdout backpressure when send() buffers data
16
- // into a dead socket's TCP buffer.
88
+ const terminalWss = new ws_1.WebSocketServer({ noServer: true });
89
+ setupTerminalWebSocket(terminalWss, terminalManager);
17
90
  const heartbeat = setInterval(() => {
18
91
  for (const ws of wss.clients) {
19
92
  const ext = ws;
@@ -30,15 +103,31 @@ function createWebSocketHandler(server, sessionManager) {
30
103
  });
31
104
  server.on("upgrade", (req, socket, head) => {
32
105
  const url = req.url || "";
106
+ console.log(`[ws] upgrade: ${url}`);
107
+ if (url.startsWith("/ws/terminal")) {
108
+ const token = (0, auth_1.extractTokenFromQuery)(url);
109
+ if (!token || !(0, auth_1.validateSession)(token)) {
110
+ socket.write("HTTP/1.1 401 Unauthorized\r\n\r\n");
111
+ socket.destroy();
112
+ return;
113
+ }
114
+ terminalWss.handleUpgrade(req, socket, head, (ws) => {
115
+ terminalWss.emit("connection", ws, req);
116
+ });
117
+ return;
118
+ }
33
119
  if (!url.startsWith("/ws")) {
34
- return; // Let Next.js handle other upgrades (e.g. HMR)
120
+ console.log(`[ws] upgrade: ignoring non-ws url: ${url}`);
121
+ return;
35
122
  }
36
123
  const token = (0, auth_1.extractTokenFromQuery)(url);
37
124
  if (!token || !(0, auth_1.validateSession)(token)) {
125
+ console.log(`[ws] upgrade: auth failed for ${url} (token=${token?.slice(0, 10)}...)`);
38
126
  socket.write("HTTP/1.1 401 Unauthorized\r\n\r\n");
39
127
  socket.destroy();
40
128
  return;
41
129
  }
130
+ console.log(`[ws] upgrade: accepted for ${url}`);
42
131
  wss.handleUpgrade(req, socket, head, (ws) => {
43
132
  wss.emit("connection", ws, req);
44
133
  });
@@ -55,6 +144,8 @@ function createWebSocketHandler(server, sessionManager) {
55
144
  const sessionCleanups = new Map();
56
145
  // Lightweight status-only subscriptions for sidebar
57
146
  let watchCleanups = [];
147
+ // Explicit cwd watches requested by pages (e.g. changes view)
148
+ let cwdWatchCleanups = [];
58
149
  function subscribeSession(sessionId) {
59
150
  const prev = sessionCleanups.get(sessionId);
60
151
  if (prev) {
@@ -63,6 +154,12 @@ function createWebSocketHandler(server, sessionManager) {
63
154
  }
64
155
  const cleanups = [];
65
156
  sessionCleanups.set(sessionId, cleanups);
157
+ const cwd = sessionManager.getSessionCwd(sessionId);
158
+ if (cwd) {
159
+ cleanups.push((0, fs_watcher_1.watchCwd)(cwd, () => {
160
+ send(ws, { type: "session:fs_changed", cwd });
161
+ }));
162
+ }
66
163
  const unsubEvent = sessionManager.subscribe(sessionId, (event) => {
67
164
  (0, debug_logger_1.logParsedEvent)(sessionId, event);
68
165
  handleParsedEvent(ws, sessionId, event, sessionManager);
@@ -70,6 +167,7 @@ function createWebSocketHandler(server, sessionManager) {
70
167
  if (unsubEvent)
71
168
  cleanups.push(unsubEvent);
72
169
  const unsubStatus = sessionManager.onStatus(sessionId, (status) => {
170
+ console.log(`[ws] onStatus fired: ${sessionId.slice(0, 8)} -> ${status}`);
73
171
  (0, debug_logger_1.logStatus)(sessionId, status);
74
172
  send(ws, { type: "session:status", sessionId, status });
75
173
  });
@@ -85,6 +183,11 @@ function createWebSocketHandler(server, sessionManager) {
85
183
  });
86
184
  if (unsubError)
87
185
  cleanups.push(unsubError);
186
+ const unsubTranscript = sessionManager.onTranscript(sessionId, (messages) => {
187
+ send(ws, { type: "session:transcript", sessionId, messages });
188
+ });
189
+ if (unsubTranscript)
190
+ cleanups.push(unsubTranscript);
88
191
  const unsubSystem = sessionManager.onSystem(sessionId, (text) => {
89
192
  send(ws, { type: "session:system", sessionId, text });
90
193
  });
@@ -159,6 +262,7 @@ function createWebSocketHandler(server, sessionManager) {
159
262
  messages: result.messages,
160
263
  status: "idle",
161
264
  hasMore: result.hasMore,
265
+ promptHistory: result.promptHistory,
162
266
  });
163
267
  send(ws, { type: "session:connected", sessionId: msg.sessionId });
164
268
  send(ws, { type: "session:info_updated", sessionId: msg.sessionId, info: result.info });
@@ -185,10 +289,6 @@ function createWebSocketHandler(server, sessionManager) {
185
289
  if (prefs?.initData) {
186
290
  send(ws, { type: "session:init", sessionId: msg.sessionId, data: prefs.initData });
187
291
  }
188
- const historyTodos = (0, session_manager_1.extractTodosFromHistory)(result.messages);
189
- if (historyTodos.length > 0) {
190
- send(ws, { type: "session:todos", sessionId: msg.sessionId, todos: historyTodos });
191
- }
192
292
  });
193
293
  break;
194
294
  }
@@ -227,6 +327,36 @@ function createWebSocketHandler(server, sessionManager) {
227
327
  if (correctedStatus !== session.info.status) {
228
328
  sessionManager.fixStaleStatus(msg.sessionId);
229
329
  }
330
+ // Re-emit any pending permission/question requests BEFORE the
331
+ // history snapshot. Otherwise, on reconnect the client lands the
332
+ // assistant message with the AskUserQuestion tool_use first, and
333
+ // chat-view's Place1 renders nothing until question:request
334
+ // arrives 80+ms later — the chat looks stuck.
335
+ const pendingReqsEarly = sessionManager.getPendingRequests(msg.sessionId);
336
+ for (const req of pendingReqsEarly) {
337
+ if (req.type === "question") {
338
+ send(ws, {
339
+ type: "question:request",
340
+ sessionId: msg.sessionId,
341
+ requestId: req.requestId,
342
+ questions: req.toolInput,
343
+ });
344
+ }
345
+ else {
346
+ const permMsg = {
347
+ type: "permission:request",
348
+ sessionId: msg.sessionId,
349
+ requestId: req.requestId,
350
+ toolName: req.toolName,
351
+ input: req.toolInput,
352
+ };
353
+ if (req.planFilePath) {
354
+ permMsg.planFilePath = req.planFilePath;
355
+ permMsg.planContent = req.planContent;
356
+ }
357
+ send(ws, permMsg);
358
+ }
359
+ }
230
360
  // If client already has messages, send only the delta to avoid
231
361
  // re-sending 1000+ messages on every mobile reconnect.
232
362
  // Uses the last known server message ID instead of a count, since
@@ -255,6 +385,7 @@ function createWebSocketHandler(server, sessionManager) {
255
385
  messages: session.messages,
256
386
  status: correctedStatus,
257
387
  hasMore: session.hasMore,
388
+ promptHistory: session.promptHistory,
258
389
  });
259
390
  }
260
391
  }
@@ -265,23 +396,23 @@ function createWebSocketHandler(server, sessionManager) {
265
396
  messages: session.messages,
266
397
  status: correctedStatus,
267
398
  hasMore: session.hasMore,
399
+ promptHistory: session.promptHistory,
268
400
  });
269
401
  }
270
402
  // Send in-progress streaming message if the CLI is mid-response.
271
- // This restores tool calls and partial text that aren't yet in the transcript.
272
- // Only send when the session is actually running; an idle session has
273
- // no in-progress streaming, and a stale snapshot would briefly show
274
- // completed agents as still running until the status:idle clears it.
275
- const snapshot = correctedStatus === "running" ? sessionManager.getStreamingSnapshot(msg.sessionId) : null;
276
- if (snapshot) {
277
- send(ws, {
278
- type: "session:streaming_snapshot",
279
- sessionId: msg.sessionId,
280
- messageId: snapshot.messageId,
281
- content: snapshot.content,
282
- toolUses: snapshot.toolUses,
283
- blocks: snapshot.blocks,
284
- });
403
+ // Skip for PTY sessions - the transcript watcher provides message content.
404
+ if (session.info.runtime !== "pty") {
405
+ const snapshot = correctedStatus === "running" ? sessionManager.getStreamingSnapshot(msg.sessionId) : null;
406
+ if (snapshot) {
407
+ send(ws, {
408
+ type: "session:streaming_snapshot",
409
+ sessionId: msg.sessionId,
410
+ messageId: snapshot.messageId,
411
+ content: snapshot.content,
412
+ toolUses: snapshot.toolUses,
413
+ blocks: snapshot.blocks,
414
+ });
415
+ }
285
416
  }
286
417
  // Restore compacting indicator if compaction is in progress
287
418
  if (sessionManager.isCompacting(msg.sessionId)) {
@@ -335,6 +466,14 @@ function createWebSocketHandler(server, sessionManager) {
335
466
  text: `__thinking_level::${thinkingLevel}`,
336
467
  });
337
468
  }
469
+ const runtime = session.info.runtime;
470
+ if (runtime && runtime !== "stream") {
471
+ send(ws, {
472
+ type: "session:system",
473
+ sessionId: msg.sessionId,
474
+ text: `__runtime::${runtime}`,
475
+ });
476
+ }
338
477
  const currentUsage = sessionManager.getContextUsage(msg.sessionId);
339
478
  const usage = currentUsage || session.lastUsage;
340
479
  if (usage) {
@@ -345,12 +484,7 @@ function createWebSocketHandler(server, sessionManager) {
345
484
  });
346
485
  }
347
486
  subscribeSession(msg.sessionId);
348
- // Rebuild todos from last TodoWrite in history
349
- const tTodos0 = performance.now();
350
- const fullBuffer = sessionManager.getTranscriptBuffer(msg.sessionId);
351
- sessionManager.rebuildTodosFromHistory(msg.sessionId, fullBuffer.length > 0 ? fullBuffer : session.messages);
352
- const tTodos1 = performance.now();
353
- (0, debug_logger_1.debugLog)(`[ws:${wsId}] session ${sid} rebuildTodos in ${(tTodos1 - tTodos0).toFixed(0)}ms`);
487
+ sessionManager.loadTodosFromFiles(msg.sessionId);
354
488
  const currentTodos = sessionManager.getTodos(msg.sessionId);
355
489
  if (currentTodos.length > 0) {
356
490
  send(ws, {
@@ -374,33 +508,6 @@ function createWebSocketHandler(server, sessionManager) {
374
508
  messages: sessionManager.getQueuedMessages(msg.sessionId),
375
509
  paused: sessionManager.isQueuePaused(msg.sessionId),
376
510
  });
377
- // Re-emit any pending permission/question requests that were
378
- // sent to a previous (now dead) WebSocket connection
379
- const pendingReqs = sessionManager.getPendingRequests(msg.sessionId);
380
- for (const req of pendingReqs) {
381
- if (req.type === "question") {
382
- send(ws, {
383
- type: "question:request",
384
- sessionId: msg.sessionId,
385
- requestId: req.requestId,
386
- questions: req.toolInput,
387
- });
388
- }
389
- else {
390
- const permMsg = {
391
- type: "permission:request",
392
- sessionId: msg.sessionId,
393
- requestId: req.requestId,
394
- toolName: req.toolName,
395
- input: req.toolInput,
396
- };
397
- if (req.planFilePath) {
398
- permMsg.planFilePath = req.planFilePath;
399
- permMsg.planContent = req.planContent;
400
- }
401
- send(ws, permMsg);
402
- }
403
- }
404
511
  const tDone = performance.now();
405
512
  (0, debug_logger_1.debugLog)(`[ws:${wsId}] session ${sid} connect complete in ${(tDone - t0).toFixed(0)}ms`);
406
513
  });
@@ -528,8 +635,10 @@ function createWebSocketHandler(server, sessionManager) {
528
635
  break;
529
636
  }
530
637
  case "question:response": {
638
+ console.log(`[question-debug] question:response for session ${msg.sessionId.slice(0, 8)}, requestId=${msg.requestId}, hadPending=${!!sessionManager.getPendingRequest(msg.sessionId, msg.requestId)}`);
531
639
  const pending = sessionManager.getPendingRequest(msg.sessionId, msg.requestId);
532
640
  sessionManager.removePendingRequest(msg.sessionId, msg.requestId);
641
+ console.log(`[question-debug] after remove, remaining pending:`, sessionManager.getPendingRequests(msg.sessionId).map((r) => r.requestId));
533
642
  const originalQuestions = pending?.rawToolInput?.questions;
534
643
  sessionManager.respondToPermission(msg.sessionId, msg.requestId, true, {
535
644
  questions: originalQuestions || [],
@@ -542,7 +651,12 @@ function createWebSocketHandler(server, sessionManager) {
542
651
  break;
543
652
  }
544
653
  case "session:set_model": {
545
- sessionManager.setModel(msg.sessionId, msg.model);
654
+ (0, debug_logger_1.debugLog)(`[ws] session:set_model received: sessionId=${msg.sessionId.slice(0, 8)} model=${msg.model} contextSize=${msg.contextSize ?? "(unspecified)"}`);
655
+ sessionManager.setModel(msg.sessionId, msg.model, msg.contextSize);
656
+ break;
657
+ }
658
+ case "session:set_model_slot": {
659
+ sessionManager.setModelSlot(msg.sessionId, msg.slot, msg.modelId);
546
660
  break;
547
661
  }
548
662
  case "permission:set_bypass": {
@@ -554,6 +668,10 @@ function createWebSocketHandler(server, sessionManager) {
554
668
  }
555
669
  break;
556
670
  }
671
+ case "session:set_runtime": {
672
+ sessionManager.setRuntime(msg.sessionId, msg.runtime);
673
+ break;
674
+ }
557
675
  case "session:restart": {
558
676
  sessionManager.restartSession(msg.sessionId);
559
677
  break;
@@ -571,12 +689,18 @@ function createWebSocketHandler(server, sessionManager) {
571
689
  for (const fn of watchCleanups)
572
690
  fn();
573
691
  watchCleanups = [];
692
+ const watchedCwds = new Set();
574
693
  for (const id of msg.sessionIds) {
575
694
  const unsubStatus = sessionManager.onStatus(id, (status) => {
695
+ console.log(`[ws] onStatus (watch) fired: ${id.slice(0, 8)} -> ${status}`);
576
696
  send(ws, { type: "session:status", sessionId: id, status });
577
697
  });
578
- if (unsubStatus)
698
+ if (unsubStatus) {
579
699
  watchCleanups.push(unsubStatus);
700
+ }
701
+ else {
702
+ console.log(`[ws] session:subscribe onStatus returned null for ${id.slice(0, 8)}`);
703
+ }
580
704
  const unsubPending = sessionManager.onPending(id, (count) => {
581
705
  send(ws, { type: "session:pending", sessionId: id, count });
582
706
  });
@@ -587,9 +711,22 @@ function createWebSocketHandler(server, sessionManager) {
587
711
  });
588
712
  if (unsubInfo)
589
713
  watchCleanups.push(unsubInfo);
714
+ const cwd = sessionManager.getSessionCwd(id);
715
+ if (cwd && !watchedCwds.has(cwd)) {
716
+ watchedCwds.add(cwd);
717
+ watchCleanups.push((0, fs_watcher_1.watchCwd)(cwd, () => {
718
+ send(ws, { type: "session:fs_changed", cwd });
719
+ }));
720
+ }
590
721
  }
591
722
  break;
592
723
  }
724
+ case "watch:cwd": {
725
+ cwdWatchCleanups.push((0, fs_watcher_1.watchCwd)(msg.cwd, () => {
726
+ send(ws, { type: "session:fs_changed", cwd: msg.cwd });
727
+ }));
728
+ break;
729
+ }
593
730
  }
594
731
  });
595
732
  ws.on("close", (code, _reason) => {
@@ -603,13 +740,21 @@ function createWebSocketHandler(server, sessionManager) {
603
740
  for (const fn of watchCleanups)
604
741
  fn();
605
742
  watchCleanups = [];
743
+ for (const fn of cwdWatchCleanups)
744
+ fn();
745
+ cwdWatchCleanups = [];
606
746
  });
607
747
  });
608
748
  return wss;
609
749
  }
610
750
  function handleParsedEvent(ws, sessionId, event, sessionManager) {
751
+ // In PTY mode the transcript watcher is the sole source of message content.
752
+ // Only forward non-content events (permissions, rate limits, suggestions, etc.).
753
+ const isPty = sessionManager.getRuntime(sessionId) === "pty";
611
754
  switch (event.type) {
612
755
  case "thinking":
756
+ if (isPty)
757
+ break;
613
758
  send(ws, {
614
759
  type: "assistant:thinking",
615
760
  sessionId,
@@ -620,6 +765,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
620
765
  });
621
766
  break;
622
767
  case "text_delta":
768
+ if (isPty)
769
+ break;
623
770
  send(ws, {
624
771
  type: "assistant:text",
625
772
  sessionId,
@@ -627,6 +774,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
627
774
  });
628
775
  break;
629
776
  case "tool_use_start":
777
+ if (isPty)
778
+ break;
630
779
  send(ws, {
631
780
  type: "assistant:tool_use",
632
781
  sessionId,
@@ -637,6 +786,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
637
786
  });
638
787
  break;
639
788
  case "tool_done":
789
+ if (isPty)
790
+ break;
640
791
  send(ws, {
641
792
  type: "assistant:tool_use",
642
793
  sessionId,
@@ -647,6 +798,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
647
798
  });
648
799
  break;
649
800
  case "tool_result":
801
+ if (isPty)
802
+ break;
650
803
  send(ws, {
651
804
  type: "assistant:tool_result",
652
805
  sessionId,
@@ -656,6 +809,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
656
809
  });
657
810
  break;
658
811
  case "message_done":
812
+ if (isPty)
813
+ break;
659
814
  if (event.message) {
660
815
  send(ws, {
661
816
  type: "assistant:message_done",
@@ -664,7 +819,23 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
664
819
  });
665
820
  }
666
821
  break;
822
+ case "streaming_snapshot":
823
+ if (isPty)
824
+ break;
825
+ if (event.message) {
826
+ send(ws, {
827
+ type: "session:streaming_snapshot",
828
+ sessionId,
829
+ messageId: event.message.id,
830
+ content: event.message.content,
831
+ toolUses: event.message.toolUses,
832
+ blocks: event.message.blocks,
833
+ });
834
+ }
835
+ break;
667
836
  case "tool_children":
837
+ if (isPty)
838
+ break;
668
839
  send(ws, {
669
840
  type: "assistant:tool_children",
670
841
  sessionId,
@@ -674,6 +845,8 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
674
845
  });
675
846
  break;
676
847
  case "tool_progress":
848
+ if (isPty)
849
+ break;
677
850
  send(ws, {
678
851
  type: "assistant:tool_progress",
679
852
  sessionId,
@@ -720,7 +893,7 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
720
893
  taskId: event.taskInfo.taskId,
721
894
  toolUseId: event.taskInfo.toolUseId,
722
895
  status: isProgress ? "running" : event.taskInfo.status,
723
- title: isProgress ? undefined : event.taskInfo.description,
896
+ title: isProgress ? undefined : event.taskInfo.title || event.taskInfo.description,
724
897
  description: event.taskInfo.description,
725
898
  activity: isProgress ? event.taskInfo.description : undefined,
726
899
  summary: event.taskInfo.summary,
@@ -734,6 +907,7 @@ function handleParsedEvent(ws, sessionId, event, sessionManager) {
734
907
  const toolName = event.toolName || "";
735
908
  const requestId = event.requestId || "";
736
909
  if (toolName === "AskUserQuestion") {
910
+ console.log(`[question-debug] live question:request for session ${sessionId.slice(0, 8)}, requestId=${requestId}`);
737
911
  send(ws, {
738
912
  type: "question:request",
739
913
  sessionId,
package/next.config.ts CHANGED
@@ -3,6 +3,7 @@ import type { NextConfig } from "next";
3
3
  const nextConfig: NextConfig = {
4
4
  images: { unoptimized: true },
5
5
  allowedDevOrigins: ["192.168.0.39"],
6
+ serverExternalPackages: ["node-pty"],
6
7
  };
7
8
 
8
9
  export default nextConfig;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alexjbarnes/cockpit",
3
- "version": "0.2.0",
3
+ "version": "0.3.0",
4
4
  "description": "Web UI for Claude Code",
5
5
  "license": "Apache-2.0",
6
6
  "author": "Alex Barnes (https://github.com/alexjbarnes)",
@@ -44,6 +44,8 @@
44
44
  "lint": "biome check src/ tests/ server.ts",
45
45
  "lint:fix": "biome check --fix src/ tests/ server.ts",
46
46
  "format": "biome format --write src/ tests/ server.ts",
47
+ "pretest:integration": "npm run build",
48
+ "test:integration": "playwright test --config=tests/integration/playwright.config.ts",
47
49
  "prepublishOnly": "npm run build"
48
50
  },
49
51
  "dependencies": {
@@ -55,12 +57,16 @@
55
57
  "@pierre/diffs": "^1.1.16",
56
58
  "@radix-ui/react-slot": "^1.2.4",
57
59
  "@tailwindcss/postcss": "^4",
60
+ "@xterm/addon-fit": "^0.11.0",
61
+ "@xterm/addon-webgl": "^0.19.0",
62
+ "@xterm/xterm": "^6.0.0",
58
63
  "class-variance-authority": "^0.7",
59
64
  "clsx": "^2",
60
65
  "codemirror": "^6.0.2",
61
66
  "lucide-react": "^1.8.0",
62
67
  "magika": "^1.0.0",
63
68
  "next": "^16.2.4",
69
+ "node-pty": "^1.2.0-beta.13",
64
70
  "react": "^19",
65
71
  "react-dom": "^19",
66
72
  "react-markdown": "^10.1.0",
@@ -78,15 +84,16 @@
78
84
  },
79
85
  "devDependencies": {
80
86
  "@biomejs/biome": "^2.4.12",
87
+ "@playwright/test": "^1.60.0",
81
88
  "@types/node": "^25.6.0",
82
89
  "@types/react": "^19",
83
90
  "@types/react-dom": "^19",
84
91
  "@types/uuid": "^11.0.0",
85
92
  "@types/ws": "^8",
86
- "@vitest/coverage-v8": "^4.1.4",
93
+ "@vitest/coverage-v8": "^4.1.5",
87
94
  "tsc-alias": "^1.8.10",
88
95
  "tsx": "^4.19.2",
89
96
  "typescript": "6.0.3",
90
- "vitest": "^4.1.4"
97
+ "vitest": "^4.1.6"
91
98
  }
92
99
  }