@alexjbarnes/cockpit 0.2.0 → 0.3.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (695) 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/I-rxZaJEzhe3ZUTjSqB11/_buildManifest.js +1 -0
  435. package/.next/static/chunks/{35922.5bdf78a760129504.js → 13541.056c34ca7fde6869.js} +1 -1
  436. package/.next/static/chunks/26126-97874904b42befb8.js +1 -0
  437. package/.next/static/chunks/31010-6e87f77b97544424.js +1 -0
  438. package/.next/static/chunks/3765-d323c6675307a63e.js +20 -0
  439. package/.next/static/chunks/{11242-d240a18d4e59390b.js → 41487-d802643f4a8fad3c.js} +5 -5
  440. package/.next/static/chunks/48273-fb393846bb4333c0.js +6 -0
  441. package/.next/static/chunks/63606.a387b0261d6523ab.js +1 -0
  442. package/.next/static/chunks/6935-f436a624267529fb.js +1 -0
  443. package/.next/static/chunks/{69427.0f379c6bdea95405.js → 69427.a0b463c808aa54c8.js} +1 -1
  444. package/.next/static/chunks/86939-dfc6f8eb395caa89.js +1 -0
  445. package/.next/static/chunks/app/(app)/agents/[name]/page-8bdd0359043537d4.js +8 -0
  446. package/.next/static/chunks/app/(app)/agents/page-6fcfd7ab6781814e.js +1 -0
  447. package/.next/static/chunks/app/(app)/changes/page-4549a5bd72d77e3e.js +1 -0
  448. package/.next/static/chunks/app/(app)/claude-md/edit/page-08e6e120e71979f4.js +1 -0
  449. package/.next/static/chunks/app/(app)/claude-md/page-cd9e2176a12ba241.js +1 -0
  450. package/.next/static/chunks/app/(app)/commands/[name]/page-7cdfdef29ded0aa0.js +6 -0
  451. package/.next/static/chunks/app/(app)/commands/page-f126b608b04747ac.js +1 -0
  452. package/.next/static/chunks/app/(app)/files/page-f526eb95821e000e.js +1 -0
  453. package/.next/static/chunks/app/(app)/hooks/[event]/page-28038323fd29adfa.js +6 -0
  454. package/.next/static/chunks/app/(app)/hooks/page-f1f39284e53c0344.js +1 -0
  455. package/.next/static/chunks/app/(app)/inbox/[id]/page-bc1ff3a0db0114a4.js +1 -0
  456. package/.next/static/chunks/app/(app)/inbox/page-82e03870103ce9bd.js +1 -0
  457. package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-7fb788f772ff2129.js +1 -0
  458. package/.next/static/chunks/app/(app)/jobs/[id]/page-a5856b9ae967ff59.js +1 -0
  459. package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-b7c513402db11db6.js +1 -0
  460. package/.next/static/chunks/app/(app)/jobs/page-e9bbd6c116b9699f.js +1 -0
  461. package/.next/static/chunks/app/(app)/{layout-81c1899969de11e6.js → layout-ce9e1be301c60fe5.js} +1 -1
  462. package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-d6d805a27ec0b0c0.js +1 -0
  463. package/.next/static/chunks/app/(app)/mcp-servers/page-4b7276d43451cd43.js +1 -0
  464. package/.next/static/chunks/app/(app)/page-027a5382da30ddb9.js +1 -0
  465. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-9ab2955c455bb5fa.js +13 -0
  466. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/{page-c7473a899c7c59c3.js → page-c5fd013309ab3eba.js} +1 -1
  467. package/.next/static/chunks/app/(app)/reviews/{page-0e6e7395a4f62b50.js → page-47530d93bb9d4a76.js} +1 -1
  468. package/.next/static/chunks/app/(app)/sessions/[id]/page-94f891e1b54fd05f.js +1 -0
  469. package/.next/static/chunks/app/(app)/settings/appearance/page-95902da748ac5f1e.js +1 -0
  470. package/.next/static/chunks/app/(app)/settings/notifications/{page-a28db2ebc9fd0de8.js → page-229f1db6beb1d19c.js} +1 -1
  471. package/.next/static/chunks/app/(app)/settings/page-8ed16a66fdde10cd.js +1 -0
  472. package/.next/static/chunks/app/(app)/settings/providers/[id]/page-13654263246617b3.js +1 -0
  473. package/.next/static/chunks/app/(app)/settings/providers/new/page-e1798e321ccbc6df.js +1 -0
  474. package/.next/static/chunks/app/(app)/settings/providers/page-0bb4c1db2ee35b3d.js +1 -0
  475. package/.next/static/chunks/app/(app)/settings/session/page-ab216a8fa37a0f76.js +1 -0
  476. package/.next/static/chunks/app/(app)/skills/[name]/page-8ab85d5090967ee4.js +6 -0
  477. package/.next/static/chunks/app/(app)/skills/page-c52773eacb27c04e.js +1 -0
  478. package/.next/static/chunks/app/_global-error/page-fc747760bd4c8a4b.js +1 -0
  479. package/.next/static/chunks/app/api/agents/[name]/route-fc747760bd4c8a4b.js +1 -0
  480. package/.next/static/chunks/app/api/agents/route-fc747760bd4c8a4b.js +1 -0
  481. package/.next/static/chunks/app/api/auth/check/route-fc747760bd4c8a4b.js +1 -0
  482. package/.next/static/chunks/app/api/auth/login/route-fc747760bd4c8a4b.js +1 -0
  483. package/.next/static/chunks/app/api/auth/setup/route-fc747760bd4c8a4b.js +1 -0
  484. package/.next/static/chunks/app/api/auth/ws-token/route-fc747760bd4c8a4b.js +1 -0
  485. package/.next/static/chunks/app/api/btw/route-fc747760bd4c8a4b.js +1 -0
  486. package/.next/static/chunks/app/api/claude-md/route-fc747760bd4c8a4b.js +1 -0
  487. package/.next/static/chunks/app/api/commands/[name]/route-fc747760bd4c8a4b.js +1 -0
  488. package/.next/static/chunks/app/api/commands/route-fc747760bd4c8a4b.js +1 -0
  489. package/.next/static/chunks/app/api/defaults/route-fc747760bd4c8a4b.js +1 -0
  490. package/.next/static/chunks/app/api/filesystem/browse/route-fc747760bd4c8a4b.js +1 -0
  491. package/.next/static/chunks/app/api/filesystem/files/route-fc747760bd4c8a4b.js +1 -0
  492. package/.next/static/chunks/app/api/filesystem/mkdir/route-fc747760bd4c8a4b.js +1 -0
  493. package/.next/static/chunks/app/api/filesystem/read/route-fc747760bd4c8a4b.js +1 -0
  494. package/.next/static/chunks/app/api/git/clone/route-fc747760bd4c8a4b.js +1 -0
  495. package/.next/static/chunks/app/api/git/commit/route-fc747760bd4c8a4b.js +1 -0
  496. package/.next/static/chunks/app/api/git/diff/route-fc747760bd4c8a4b.js +1 -0
  497. package/.next/static/chunks/app/api/git/discard/route-fc747760bd4c8a4b.js +1 -0
  498. package/.next/static/chunks/app/api/git/generate-message/route-fc747760bd4c8a4b.js +1 -0
  499. package/.next/static/chunks/app/api/git/push/route-fc747760bd4c8a4b.js +1 -0
  500. package/.next/static/chunks/app/api/git/status/route-fc747760bd4c8a4b.js +1 -0
  501. package/.next/static/chunks/app/api/github/file-content/route-fc747760bd4c8a4b.js +1 -0
  502. package/.next/static/chunks/app/api/github/orgs/route-fc747760bd4c8a4b.js +1 -0
  503. package/.next/static/chunks/app/api/github/prs/checks/route-fc747760bd4c8a4b.js +1 -0
  504. package/.next/static/chunks/app/api/github/prs/diff/route-fc747760bd4c8a4b.js +1 -0
  505. package/.next/static/chunks/app/api/github/prs/review/route-fc747760bd4c8a4b.js +1 -0
  506. package/.next/static/chunks/app/api/github/prs/route-fc747760bd4c8a4b.js +1 -0
  507. package/.next/static/chunks/app/api/github/prs/view/route-fc747760bd4c8a4b.js +1 -0
  508. package/.next/static/chunks/app/api/github/repos/route-fc747760bd4c8a4b.js +1 -0
  509. package/.next/static/chunks/app/api/github/review-session/route-fc747760bd4c8a4b.js +1 -0
  510. package/.next/static/chunks/app/api/health/route-fc747760bd4c8a4b.js +1 -0
  511. package/.next/static/chunks/app/api/hooks/route-fc747760bd4c8a4b.js +1 -0
  512. package/.next/static/chunks/app/api/inbox/[id]/route-fc747760bd4c8a4b.js +1 -0
  513. package/.next/static/chunks/app/api/inbox/route-fc747760bd4c8a4b.js +1 -0
  514. package/.next/static/chunks/app/api/jobs/[id]/route-fc747760bd4c8a4b.js +1 -0
  515. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-fc747760bd4c8a4b.js +1 -0
  516. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-fc747760bd4c8a4b.js +1 -0
  517. package/.next/static/chunks/app/api/jobs/[id]/runs/route-fc747760bd4c8a4b.js +1 -0
  518. package/.next/static/chunks/app/api/jobs/[id]/trigger/route-fc747760bd4c8a4b.js +1 -0
  519. package/.next/static/chunks/app/api/jobs/mcp-discover/route-fc747760bd4c8a4b.js +1 -0
  520. package/.next/static/chunks/app/api/jobs/route-fc747760bd4c8a4b.js +1 -0
  521. package/.next/static/chunks/app/api/jobs/status/route-fc747760bd4c8a4b.js +1 -0
  522. package/.next/static/chunks/app/api/mcp-servers/[name]/route-fc747760bd4c8a4b.js +1 -0
  523. package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-fc747760bd4c8a4b.js +1 -0
  524. package/.next/static/chunks/app/api/mcp-servers/route-fc747760bd4c8a4b.js +1 -0
  525. package/.next/static/chunks/app/api/notifications/route-fc747760bd4c8a4b.js +1 -0
  526. package/.next/static/chunks/app/api/notifications/test/route-fc747760bd4c8a4b.js +1 -0
  527. package/.next/static/chunks/app/api/providers/[id]/route-fc747760bd4c8a4b.js +1 -0
  528. package/.next/static/chunks/app/api/providers/route-fc747760bd4c8a4b.js +1 -0
  529. package/.next/static/chunks/app/api/reviews/pinned/route-fc747760bd4c8a4b.js +1 -0
  530. package/.next/static/chunks/app/api/sessions/[id]/context/route-fc747760bd4c8a4b.js +1 -0
  531. package/.next/static/chunks/app/api/sessions/[id]/mcp/route-fc747760bd4c8a4b.js +1 -0
  532. package/.next/static/chunks/app/api/sessions/[id]/route-fc747760bd4c8a4b.js +1 -0
  533. package/.next/static/chunks/app/api/sessions/[id]/search/route-fc747760bd4c8a4b.js +1 -0
  534. package/.next/static/chunks/app/api/sessions/[id]/tabs/route-fc747760bd4c8a4b.js +1 -0
  535. package/.next/static/chunks/app/api/sessions/bulk-delete/route-fc747760bd4c8a4b.js +1 -0
  536. package/.next/static/chunks/app/api/sessions/by-ids/route-fc747760bd4c8a4b.js +1 -0
  537. package/.next/static/chunks/app/api/sessions/group/route-fc747760bd4c8a4b.js +1 -0
  538. package/.next/static/chunks/app/api/sessions/pinned/route-fc747760bd4c8a4b.js +1 -0
  539. package/.next/static/chunks/app/api/sessions/route-fc747760bd4c8a4b.js +1 -0
  540. package/.next/static/chunks/app/api/sessions/search/route-fc747760bd4c8a4b.js +1 -0
  541. package/.next/static/chunks/app/api/sessions/thinking/route-fc747760bd4c8a4b.js +1 -0
  542. package/.next/static/chunks/app/api/skills/[name]/route-fc747760bd4c8a4b.js +1 -0
  543. package/.next/static/chunks/app/api/skills/route-fc747760bd4c8a4b.js +1 -0
  544. package/.next/static/chunks/app/api/terminal/[id]/route-fc747760bd4c8a4b.js +1 -0
  545. package/.next/static/chunks/app/api/terminal/route-fc747760bd4c8a4b.js +1 -0
  546. package/.next/static/chunks/app/api/usage/route-fc747760bd4c8a4b.js +1 -0
  547. package/.next/static/chunks/app/api/version/changelog/route-fc747760bd4c8a4b.js +1 -0
  548. package/.next/static/chunks/app/api/version/cockpit/changelog/route-fc747760bd4c8a4b.js +1 -0
  549. package/.next/static/chunks/app/api/version/cockpit/route-fc747760bd4c8a4b.js +1 -0
  550. package/.next/static/chunks/app/api/version/route-fc747760bd4c8a4b.js +1 -0
  551. package/.next/static/chunks/e868780c.f24b6da08e62c7b2.js +18 -0
  552. package/.next/static/chunks/next/dist/client/components/builtin/app-error-fc747760bd4c8a4b.js +1 -0
  553. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-fc747760bd4c8a4b.js +1 -0
  554. package/.next/static/chunks/next/dist/client/components/builtin/not-found-fc747760bd4c8a4b.js +1 -0
  555. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-fc747760bd4c8a4b.js +1 -0
  556. package/.next/static/chunks/webpack-e31bb45fa59caed8.js +1 -0
  557. package/.next/static/css/3f8af4ae6f812d5c.css +1 -0
  558. package/README.md +12 -3
  559. package/bin/cockpit-hook-bridge.mjs +170 -0
  560. package/dist/server.js +11 -1
  561. package/dist/src/lib/models.js +48 -7
  562. package/dist/src/server/auth.js +32 -10
  563. package/dist/src/server/claude-settings.js +153 -0
  564. package/dist/src/server/cli-init-fetch.js +86 -0
  565. package/dist/src/server/cron-utils.js +16 -5
  566. package/dist/src/server/debug-logger.js +2 -2
  567. package/dist/src/server/defaults.js +16 -7
  568. package/dist/src/server/fs-watcher.js +50 -0
  569. package/dist/src/server/hook-bridge-path.js +34 -0
  570. package/dist/src/server/hook-event-translator.js +211 -0
  571. package/dist/src/server/hook-router.js +150 -0
  572. package/dist/src/server/inbox.js +14 -10
  573. package/dist/src/server/job-lock.js +103 -0
  574. package/dist/src/server/job-scheduler.js +23 -8
  575. package/dist/src/server/job-storage.js +28 -13
  576. package/dist/src/server/notification-settings.js +13 -9
  577. package/dist/src/server/paths.js +23 -0
  578. package/dist/src/server/plans.js +8 -5
  579. package/dist/src/server/providers.js +128 -0
  580. package/dist/src/server/pty-runtime.js +324 -0
  581. package/dist/src/server/pty-session.js +178 -0
  582. package/dist/src/server/session-manager.js +727 -144
  583. package/dist/src/server/session-prefs.js +33 -8
  584. package/dist/src/server/singleton.js +18 -0
  585. package/dist/src/server/stream-processor.js +61 -48
  586. package/dist/src/server/terminal-manager.js +153 -0
  587. package/dist/src/server/todo-watcher.js +178 -0
  588. package/dist/src/server/transcript-watcher.js +91 -0
  589. package/dist/src/server/transcript.js +177 -11
  590. package/dist/src/server/ws-handler.js +235 -61
  591. package/next.config.ts +1 -0
  592. package/package.json +10 -3
  593. package/public/fonts/symbols-nerd-font-mono.woff2 +0 -0
  594. package/.next/server/chunks/1941.js +0 -9
  595. package/.next/server/chunks/2444.js +0 -6
  596. package/.next/static/brzairTqHmHwvfgKpdkYX/_buildManifest.js +0 -1
  597. package/.next/static/chunks/3765-a4c7a493ec83f918.js +0 -20
  598. package/.next/static/chunks/75866-76a3987dda1295ae.js +0 -1
  599. package/.next/static/chunks/93273-87110c1449e1e7fd.js +0 -6
  600. package/.next/static/chunks/app/(app)/agents/[name]/page-3ec9a3460e8e9006.js +0 -8
  601. package/.next/static/chunks/app/(app)/agents/page-d6d504e7d7757ea2.js +0 -1
  602. package/.next/static/chunks/app/(app)/changes/page-a09bf4742aa8b5ce.js +0 -1
  603. package/.next/static/chunks/app/(app)/claude-md/edit/page-ab42921ba2618dc3.js +0 -1
  604. package/.next/static/chunks/app/(app)/claude-md/page-c4c8b20aa002a94a.js +0 -1
  605. package/.next/static/chunks/app/(app)/commands/[name]/page-2124ffed9a4e95a3.js +0 -6
  606. package/.next/static/chunks/app/(app)/commands/page-d5bf1bddd17e31dd.js +0 -1
  607. package/.next/static/chunks/app/(app)/files/page-04e4e5bf1ca89945.js +0 -1
  608. package/.next/static/chunks/app/(app)/hooks/[event]/page-d988623e739973b5.js +0 -6
  609. package/.next/static/chunks/app/(app)/hooks/page-818242d7db432578.js +0 -1
  610. package/.next/static/chunks/app/(app)/inbox/[id]/page-c33dc94e309ff117.js +0 -1
  611. package/.next/static/chunks/app/(app)/inbox/page-ca3e1724b5072734.js +0 -1
  612. package/.next/static/chunks/app/(app)/jobs/[id]/edit/page-3a1c927d76333bf0.js +0 -1
  613. package/.next/static/chunks/app/(app)/jobs/[id]/page-8e698e00b90968b0.js +0 -1
  614. package/.next/static/chunks/app/(app)/jobs/[id]/runs/[runId]/page-f942df0b7c1d280b.js +0 -1
  615. package/.next/static/chunks/app/(app)/jobs/page-7a88cc6ac34550c2.js +0 -1
  616. package/.next/static/chunks/app/(app)/mcp-servers/[name]/page-3541bf3ccdef9145.js +0 -1
  617. package/.next/static/chunks/app/(app)/mcp-servers/page-3927dfd03d921040.js +0 -1
  618. package/.next/static/chunks/app/(app)/page-594120e0ea1df527.js +0 -1
  619. package/.next/static/chunks/app/(app)/reviews/[owner]/[repo]/[number]/page-74c23b04f5c3ff88.js +0 -13
  620. package/.next/static/chunks/app/(app)/sessions/[id]/page-435e9fb4dd34007d.js +0 -1
  621. package/.next/static/chunks/app/(app)/settings/page-f8ada7997c0d5b03.js +0 -1
  622. package/.next/static/chunks/app/(app)/skills/[name]/page-5dbe1e7682880145.js +0 -6
  623. package/.next/static/chunks/app/(app)/skills/page-fd1986ad7e060f4d.js +0 -1
  624. package/.next/static/chunks/app/_global-error/page-65c661eddfc65f5b.js +0 -1
  625. package/.next/static/chunks/app/api/agents/[name]/route-65c661eddfc65f5b.js +0 -1
  626. package/.next/static/chunks/app/api/agents/route-65c661eddfc65f5b.js +0 -1
  627. package/.next/static/chunks/app/api/auth/check/route-65c661eddfc65f5b.js +0 -1
  628. package/.next/static/chunks/app/api/auth/login/route-65c661eddfc65f5b.js +0 -1
  629. package/.next/static/chunks/app/api/auth/setup/route-65c661eddfc65f5b.js +0 -1
  630. package/.next/static/chunks/app/api/auth/ws-token/route-65c661eddfc65f5b.js +0 -1
  631. package/.next/static/chunks/app/api/btw/route-65c661eddfc65f5b.js +0 -1
  632. package/.next/static/chunks/app/api/claude-md/route-65c661eddfc65f5b.js +0 -1
  633. package/.next/static/chunks/app/api/commands/[name]/route-65c661eddfc65f5b.js +0 -1
  634. package/.next/static/chunks/app/api/commands/route-65c661eddfc65f5b.js +0 -1
  635. package/.next/static/chunks/app/api/defaults/route-65c661eddfc65f5b.js +0 -1
  636. package/.next/static/chunks/app/api/filesystem/browse/route-65c661eddfc65f5b.js +0 -1
  637. package/.next/static/chunks/app/api/filesystem/files/route-65c661eddfc65f5b.js +0 -1
  638. package/.next/static/chunks/app/api/filesystem/mkdir/route-65c661eddfc65f5b.js +0 -1
  639. package/.next/static/chunks/app/api/filesystem/read/route-65c661eddfc65f5b.js +0 -1
  640. package/.next/static/chunks/app/api/git/clone/route-65c661eddfc65f5b.js +0 -1
  641. package/.next/static/chunks/app/api/git/commit/route-65c661eddfc65f5b.js +0 -1
  642. package/.next/static/chunks/app/api/git/diff/route-65c661eddfc65f5b.js +0 -1
  643. package/.next/static/chunks/app/api/git/discard/route-65c661eddfc65f5b.js +0 -1
  644. package/.next/static/chunks/app/api/git/generate-message/route-65c661eddfc65f5b.js +0 -1
  645. package/.next/static/chunks/app/api/git/push/route-65c661eddfc65f5b.js +0 -1
  646. package/.next/static/chunks/app/api/git/status/route-65c661eddfc65f5b.js +0 -1
  647. package/.next/static/chunks/app/api/github/file-content/route-65c661eddfc65f5b.js +0 -1
  648. package/.next/static/chunks/app/api/github/orgs/route-65c661eddfc65f5b.js +0 -1
  649. package/.next/static/chunks/app/api/github/prs/checks/route-65c661eddfc65f5b.js +0 -1
  650. package/.next/static/chunks/app/api/github/prs/diff/route-65c661eddfc65f5b.js +0 -1
  651. package/.next/static/chunks/app/api/github/prs/review/route-65c661eddfc65f5b.js +0 -1
  652. package/.next/static/chunks/app/api/github/prs/route-65c661eddfc65f5b.js +0 -1
  653. package/.next/static/chunks/app/api/github/prs/view/route-65c661eddfc65f5b.js +0 -1
  654. package/.next/static/chunks/app/api/github/repos/route-65c661eddfc65f5b.js +0 -1
  655. package/.next/static/chunks/app/api/github/review-session/route-65c661eddfc65f5b.js +0 -1
  656. package/.next/static/chunks/app/api/health/route-65c661eddfc65f5b.js +0 -1
  657. package/.next/static/chunks/app/api/hooks/route-65c661eddfc65f5b.js +0 -1
  658. package/.next/static/chunks/app/api/inbox/[id]/route-65c661eddfc65f5b.js +0 -1
  659. package/.next/static/chunks/app/api/inbox/route-65c661eddfc65f5b.js +0 -1
  660. package/.next/static/chunks/app/api/jobs/[id]/route-65c661eddfc65f5b.js +0 -1
  661. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/route-65c661eddfc65f5b.js +0 -1
  662. package/.next/static/chunks/app/api/jobs/[id]/runs/[runId]/transcript/route-65c661eddfc65f5b.js +0 -1
  663. package/.next/static/chunks/app/api/jobs/[id]/runs/route-65c661eddfc65f5b.js +0 -1
  664. package/.next/static/chunks/app/api/jobs/[id]/trigger/route-65c661eddfc65f5b.js +0 -1
  665. package/.next/static/chunks/app/api/jobs/mcp-discover/route-65c661eddfc65f5b.js +0 -1
  666. package/.next/static/chunks/app/api/jobs/route-65c661eddfc65f5b.js +0 -1
  667. package/.next/static/chunks/app/api/jobs/status/route-65c661eddfc65f5b.js +0 -1
  668. package/.next/static/chunks/app/api/mcp-servers/[name]/route-65c661eddfc65f5b.js +0 -1
  669. package/.next/static/chunks/app/api/mcp-servers/[name]/test/route-65c661eddfc65f5b.js +0 -1
  670. package/.next/static/chunks/app/api/mcp-servers/route-65c661eddfc65f5b.js +0 -1
  671. package/.next/static/chunks/app/api/notifications/route-65c661eddfc65f5b.js +0 -1
  672. package/.next/static/chunks/app/api/notifications/test/route-65c661eddfc65f5b.js +0 -1
  673. package/.next/static/chunks/app/api/reviews/pinned/route-65c661eddfc65f5b.js +0 -1
  674. package/.next/static/chunks/app/api/sessions/[id]/context/route-65c661eddfc65f5b.js +0 -1
  675. package/.next/static/chunks/app/api/sessions/[id]/mcp/route-65c661eddfc65f5b.js +0 -1
  676. package/.next/static/chunks/app/api/sessions/[id]/route-65c661eddfc65f5b.js +0 -1
  677. package/.next/static/chunks/app/api/sessions/[id]/search/route-65c661eddfc65f5b.js +0 -1
  678. package/.next/static/chunks/app/api/sessions/bulk-delete/route-65c661eddfc65f5b.js +0 -1
  679. package/.next/static/chunks/app/api/sessions/by-ids/route-65c661eddfc65f5b.js +0 -1
  680. package/.next/static/chunks/app/api/sessions/group/route-65c661eddfc65f5b.js +0 -1
  681. package/.next/static/chunks/app/api/sessions/pinned/route-65c661eddfc65f5b.js +0 -1
  682. package/.next/static/chunks/app/api/sessions/route-65c661eddfc65f5b.js +0 -1
  683. package/.next/static/chunks/app/api/sessions/search/route-65c661eddfc65f5b.js +0 -1
  684. package/.next/static/chunks/app/api/skills/[name]/route-65c661eddfc65f5b.js +0 -1
  685. package/.next/static/chunks/app/api/skills/route-65c661eddfc65f5b.js +0 -1
  686. package/.next/static/chunks/app/api/usage/route-65c661eddfc65f5b.js +0 -1
  687. package/.next/static/chunks/app/api/version/cockpit/route-65c661eddfc65f5b.js +0 -1
  688. package/.next/static/chunks/app/api/version/route-65c661eddfc65f5b.js +0 -1
  689. package/.next/static/chunks/next/dist/client/components/builtin/app-error-65c661eddfc65f5b.js +0 -1
  690. package/.next/static/chunks/next/dist/client/components/builtin/forbidden-65c661eddfc65f5b.js +0 -1
  691. package/.next/static/chunks/next/dist/client/components/builtin/not-found-65c661eddfc65f5b.js +0 -1
  692. package/.next/static/chunks/next/dist/client/components/builtin/unauthorized-65c661eddfc65f5b.js +0 -1
  693. package/.next/static/chunks/webpack-3461a05957b13f46.js +0 -1
  694. package/.next/static/css/f04f303b5708dd90.css +0 -1
  695. /package/.next/static/{brzairTqHmHwvfgKpdkYX → I-rxZaJEzhe3ZUTjSqB11}/_ssgManifest.js +0 -0
@@ -11,21 +11,36 @@ exports.pruneAllRuns = pruneAllRuns;
11
11
  exports.getLatestRun = getLatestRun;
12
12
  exports.getRecentFailureCount = getRecentFailureCount;
13
13
  const node_fs_1 = require("node:fs");
14
- const node_os_1 = require("node:os");
15
14
  const node_path_1 = require("node:path");
16
- const PREFS_DIR = (0, node_path_1.join)((0, node_os_1.homedir)(), ".cockpit");
17
- const JOBS_FILE = (0, node_path_1.join)(PREFS_DIR, "scheduled-jobs.json");
18
- const RUNS_DIR = (0, node_path_1.join)(PREFS_DIR, "job-runs");
15
+ const models_1 = require("../lib/models");
16
+ const paths_1 = require("../server/paths");
17
+ function prefsDir() {
18
+ return (0, paths_1.getCockpitDir)();
19
+ }
20
+ function jobsFile() {
21
+ return (0, node_path_1.join)(prefsDir(), "scheduled-jobs.json");
22
+ }
23
+ function runsDir() {
24
+ return (0, node_path_1.join)(prefsDir(), "job-runs");
25
+ }
19
26
  function ensureDir(dir) {
20
27
  (0, node_fs_1.mkdirSync)(dir, { recursive: true });
21
28
  }
22
29
  function runsFile(jobId) {
23
- return (0, node_path_1.join)(RUNS_DIR, `${jobId}.json`);
30
+ return (0, node_path_1.join)(runsDir(), `${jobId}.json`);
31
+ }
32
+ function normalizeJob(raw) {
33
+ if (raw.model?.includes("[")) {
34
+ const split = (0, models_1.splitLegacyModel)(raw.model);
35
+ return { ...raw, model: split.model, contextSize: raw.contextSize ?? split.contextSize };
36
+ }
37
+ return raw;
24
38
  }
25
39
  function loadJobs() {
26
40
  try {
27
- const data = JSON.parse((0, node_fs_1.readFileSync)(JOBS_FILE, "utf-8"));
28
- return data.jobs || [];
41
+ const data = JSON.parse((0, node_fs_1.readFileSync)(jobsFile(), "utf-8"));
42
+ const jobs = data.jobs || [];
43
+ return jobs.map(normalizeJob);
29
44
  }
30
45
  catch {
31
46
  return [];
@@ -43,16 +58,16 @@ function saveJob(job) {
43
58
  else {
44
59
  jobs.push(job);
45
60
  }
46
- ensureDir(PREFS_DIR);
47
- (0, node_fs_1.writeFileSync)(JOBS_FILE, JSON.stringify({ jobs }, null, 2) + "\n");
61
+ ensureDir(prefsDir());
62
+ (0, node_fs_1.writeFileSync)(jobsFile(), JSON.stringify({ jobs }, null, 2) + "\n");
48
63
  }
49
64
  function deleteJob(id) {
50
65
  const jobs = loadJobs();
51
66
  const filtered = jobs.filter((j) => j.id !== id);
52
67
  if (filtered.length === jobs.length)
53
68
  return false;
54
- ensureDir(PREFS_DIR);
55
- (0, node_fs_1.writeFileSync)(JOBS_FILE, JSON.stringify({ jobs: filtered }, null, 2) + "\n");
69
+ ensureDir(prefsDir());
70
+ (0, node_fs_1.writeFileSync)(jobsFile(), JSON.stringify({ jobs: filtered }, null, 2) + "\n");
56
71
  const rf = runsFile(id);
57
72
  try {
58
73
  if ((0, node_fs_1.existsSync)(rf)) {
@@ -87,7 +102,7 @@ function saveRun(run) {
87
102
  const job = getJob(run.jobId);
88
103
  const maxAgeDays = job?.retentionDays ?? 90;
89
104
  pruneRuns(runs, 500, maxAgeDays);
90
- ensureDir(RUNS_DIR);
105
+ ensureDir(runsDir());
91
106
  (0, node_fs_1.writeFileSync)(runsFile(run.jobId), JSON.stringify({ runs }, null, 2) + "\n");
92
107
  }
93
108
  function pruneRuns(runs, maxCount, maxAgeDays) {
@@ -109,7 +124,7 @@ function pruneAllRuns() {
109
124
  const before = runs.length;
110
125
  pruneRuns(runs, 500, job.retentionDays ?? 90);
111
126
  if (runs.length < before) {
112
- ensureDir(RUNS_DIR);
127
+ ensureDir(runsDir());
113
128
  (0, node_fs_1.writeFileSync)(runsFile(job.id), JSON.stringify({ runs }, null, 2) + "\n");
114
129
  }
115
130
  }
@@ -4,16 +4,20 @@ exports.getNotificationSettings = getNotificationSettings;
4
4
  exports.setNotificationSettings = setNotificationSettings;
5
5
  exports.updateNotificationSettings = updateNotificationSettings;
6
6
  const node_fs_1 = require("node:fs");
7
- const node_os_1 = require("node:os");
8
7
  const node_path_1 = require("node:path");
9
- const CONFIG_DIR = (0, node_path_1.join)((0, node_os_1.homedir)(), ".cockpit");
10
- const CONFIG_FILE = (0, node_path_1.join)(CONFIG_DIR, "notifications.json");
8
+ const paths_1 = require("../server/paths");
9
+ function configDir() {
10
+ return (0, paths_1.getCockpitDir)();
11
+ }
12
+ function configFile() {
13
+ return (0, node_path_1.join)(configDir(), "notifications.json");
14
+ }
11
15
  const fallback = {
12
16
  providers: [],
13
17
  };
14
18
  function getNotificationSettings() {
15
19
  try {
16
- return { ...fallback, ...JSON.parse((0, node_fs_1.readFileSync)(CONFIG_FILE, "utf-8")) };
20
+ return { ...fallback, ...JSON.parse((0, node_fs_1.readFileSync)(configFile(), "utf-8")) };
17
21
  }
18
22
  catch {
19
23
  return { ...fallback };
@@ -21,8 +25,8 @@ function getNotificationSettings() {
21
25
  }
22
26
  function setNotificationSettings(settings) {
23
27
  try {
24
- (0, node_fs_1.mkdirSync)(CONFIG_DIR, { recursive: true });
25
- (0, node_fs_1.writeFileSync)(CONFIG_FILE, JSON.stringify(settings, null, 2) + "\n");
28
+ (0, node_fs_1.mkdirSync)(configDir(), { recursive: true });
29
+ (0, node_fs_1.writeFileSync)(configFile(), JSON.stringify(settings, null, 2) + "\n");
26
30
  }
27
31
  catch {
28
32
  // best effort
@@ -32,8 +36,8 @@ function setNotificationSettings(settings) {
32
36
  function updateNotificationSettings(partial) {
33
37
  const current = getNotificationSettings();
34
38
  const updated = { ...current, ...partial };
35
- if (!(0, node_fs_1.existsSync)(CONFIG_DIR))
36
- (0, node_fs_1.mkdirSync)(CONFIG_DIR, { recursive: true });
37
- (0, node_fs_1.writeFileSync)(CONFIG_FILE, JSON.stringify(updated, null, 2) + "\n");
39
+ if (!(0, node_fs_1.existsSync)(configDir()))
40
+ (0, node_fs_1.mkdirSync)(configDir(), { recursive: true });
41
+ (0, node_fs_1.writeFileSync)(configFile(), JSON.stringify(updated, null, 2) + "\n");
38
42
  return updated;
39
43
  }
@@ -0,0 +1,23 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.getCockpitDir = getCockpitDir;
7
+ exports.getCockpitCacheDir = getCockpitCacheDir;
8
+ exports.getClaudeDir = getClaudeDir;
9
+ exports.getClaudeUserConfigFile = getClaudeUserConfigFile;
10
+ const node_os_1 = require("node:os");
11
+ const node_path_1 = __importDefault(require("node:path"));
12
+ function getCockpitDir() {
13
+ return process.env.COCKPIT_CONFIG_DIR ?? node_path_1.default.join((0, node_os_1.homedir)(), ".cockpit");
14
+ }
15
+ function getCockpitCacheDir() {
16
+ return process.env.COCKPIT_CACHE_DIR ?? node_path_1.default.join((0, node_os_1.homedir)(), ".cache", "cockpit");
17
+ }
18
+ function getClaudeDir() {
19
+ return process.env.CLAUDE_CONFIG_DIR ?? node_path_1.default.join((0, node_os_1.homedir)(), ".claude");
20
+ }
21
+ function getClaudeUserConfigFile() {
22
+ return node_path_1.default.join(process.env.CLAUDE_CONFIG_DIR ?? (0, node_os_1.homedir)(), ".claude.json");
23
+ }
@@ -3,24 +3,27 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.findLatestPlanFile = findLatestPlanFile;
4
4
  exports.readPlanFile = readPlanFile;
5
5
  const node_fs_1 = require("node:fs");
6
- const node_os_1 = require("node:os");
7
6
  const node_path_1 = require("node:path");
8
- const PLANS_DIR = (0, node_path_1.join)((0, node_os_1.homedir)(), ".claude", "plans");
7
+ const paths_1 = require("../server/paths");
8
+ function plansDir() {
9
+ return (0, node_path_1.join)((0, paths_1.getClaudeDir)(), "plans");
10
+ }
9
11
  function findLatestPlanFile() {
10
12
  try {
11
- const files = (0, node_fs_1.readdirSync)(PLANS_DIR).filter((f) => f.endsWith(".md") && !f.includes("-agent-"));
13
+ const dir = plansDir();
14
+ const files = (0, node_fs_1.readdirSync)(dir).filter((f) => f.endsWith(".md") && !f.includes("-agent-"));
12
15
  if (files.length === 0)
13
16
  return undefined;
14
17
  let latest = files[0];
15
18
  let latestMtime = 0;
16
19
  for (const f of files) {
17
- const mtime = (0, node_fs_1.statSync)((0, node_path_1.join)(PLANS_DIR, f)).mtimeMs;
20
+ const mtime = (0, node_fs_1.statSync)((0, node_path_1.join)(dir, f)).mtimeMs;
18
21
  if (mtime > latestMtime) {
19
22
  latestMtime = mtime;
20
23
  latest = f;
21
24
  }
22
25
  }
23
- return (0, node_path_1.join)(PLANS_DIR, latest);
26
+ return (0, node_path_1.join)(dir, latest);
24
27
  }
25
28
  catch {
26
29
  return undefined;
@@ -0,0 +1,128 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getProviders = getProviders;
4
+ exports.getProvider = getProvider;
5
+ exports.addProvider = addProvider;
6
+ exports.updateProvider = updateProvider;
7
+ exports.deleteProvider = deleteProvider;
8
+ exports.setProviders = setProviders;
9
+ exports.resolveProviderModel = resolveProviderModel;
10
+ const node_fs_1 = require("node:fs");
11
+ const node_path_1 = require("node:path");
12
+ const uuid_1 = require("uuid");
13
+ const models_1 = require("../lib/models");
14
+ const paths_1 = require("../server/paths");
15
+ function prefsDir() {
16
+ return (0, paths_1.getCockpitDir)();
17
+ }
18
+ function providersFile() {
19
+ return (0, node_path_1.join)(prefsDir(), "providers.json");
20
+ }
21
+ function validateProvider(p) {
22
+ for (const m of p.models) {
23
+ if (!Array.isArray(m.contextSizes) || m.contextSizes.length === 0) {
24
+ throw new Error(`provider${p.id ? ` ${p.id}` : ""}: model ${m.modelId} has empty contextSizes`);
25
+ }
26
+ }
27
+ }
28
+ function buildAnthropicProvider() {
29
+ return {
30
+ id: "anthropic",
31
+ name: "Anthropic",
32
+ envVars: {},
33
+ models: (0, models_1.toProviderModels)(),
34
+ isBuiltin: true,
35
+ };
36
+ }
37
+ let cache = null;
38
+ function loadCustom() {
39
+ try {
40
+ return JSON.parse((0, node_fs_1.readFileSync)(providersFile(), "utf-8"));
41
+ }
42
+ catch {
43
+ return [];
44
+ }
45
+ }
46
+ function saveCustom(providers) {
47
+ try {
48
+ (0, node_fs_1.mkdirSync)(prefsDir(), { recursive: true });
49
+ (0, node_fs_1.writeFileSync)(providersFile(), JSON.stringify(providers, null, 2) + "\n");
50
+ }
51
+ catch {
52
+ // best effort
53
+ }
54
+ }
55
+ function getProviders() {
56
+ if (!cache) {
57
+ cache = [buildAnthropicProvider(), ...loadCustom()];
58
+ }
59
+ return cache;
60
+ }
61
+ function getProvider(id) {
62
+ return getProviders().find((p) => p.id === id);
63
+ }
64
+ function addProvider(provider) {
65
+ const newProvider = { ...provider, id: (0, uuid_1.v4)() };
66
+ validateProvider(newProvider);
67
+ const all = getProviders();
68
+ const custom = all.filter((p) => !p.isBuiltin);
69
+ custom.push(newProvider);
70
+ saveCustom(custom);
71
+ cache = [buildAnthropicProvider(), ...custom];
72
+ return newProvider;
73
+ }
74
+ function updateProvider(id, partial) {
75
+ if (id === "anthropic")
76
+ throw new Error("Cannot modify built-in provider");
77
+ const all = getProviders();
78
+ const custom = all.filter((p) => !p.isBuiltin);
79
+ const idx = custom.findIndex((p) => p.id === id);
80
+ if (idx === -1)
81
+ throw new Error(`Provider not found: ${id}`);
82
+ const merged = { ...custom[idx], ...partial, id };
83
+ validateProvider(merged);
84
+ custom[idx] = merged;
85
+ saveCustom(custom);
86
+ cache = [buildAnthropicProvider(), ...custom];
87
+ return custom[idx];
88
+ }
89
+ function deleteProvider(id) {
90
+ if (id === "anthropic")
91
+ throw new Error("Cannot delete built-in provider");
92
+ const all = getProviders();
93
+ const custom = all.filter((p) => !p.isBuiltin && p.id !== id);
94
+ if (custom.length === all.filter((p) => !p.isBuiltin).length) {
95
+ throw new Error(`Provider not found: ${id}`);
96
+ }
97
+ saveCustom(custom);
98
+ cache = [buildAnthropicProvider(), ...custom];
99
+ }
100
+ function setProviders(providers) {
101
+ const custom = providers.filter((p) => !p.isBuiltin);
102
+ for (const p of custom)
103
+ validateProvider(p);
104
+ saveCustom(custom);
105
+ cache = [buildAnthropicProvider(), ...custom];
106
+ }
107
+ function resolveProviderModel(modelId) {
108
+ if (!modelId)
109
+ return null;
110
+ const colon = modelId.indexOf(":");
111
+ if (colon > 0) {
112
+ const providerId = modelId.slice(0, colon);
113
+ const bareModel = modelId.slice(colon + 1);
114
+ const provider = getProvider(providerId);
115
+ if (provider) {
116
+ const model = provider.models.find((m) => m.modelId === bareModel);
117
+ if (model)
118
+ return { provider, model };
119
+ }
120
+ return null;
121
+ }
122
+ for (const provider of getProviders()) {
123
+ const model = provider.models.find((m) => m.modelId === modelId);
124
+ if (model)
125
+ return { provider, model };
126
+ }
127
+ return null;
128
+ }
@@ -0,0 +1,324 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.PtyRuntime = void 0;
4
+ const uuid_1 = require("uuid");
5
+ const claude_settings_1 = require("./claude-settings");
6
+ const cli_init_fetch_1 = require("./cli-init-fetch");
7
+ const hook_event_translator_1 = require("./hook-event-translator");
8
+ const pty_session_1 = require("./pty-session");
9
+ /**
10
+ * Owns a claude PTY process plus its HookRouter registration. Translates
11
+ * hook payloads into ParsedEvents and pumps them through opts.onEvents so
12
+ * SessionManager's existing stream-processor pipeline drives status, todos,
13
+ * pending permissions, etc.
14
+ *
15
+ * PermissionRequest hooks block the PTY until cockpit responds. We hold the
16
+ * resolver in `pendingPermissions` and the caller calls
17
+ * `notifyPermissionDecision` from its UI-facing respondToPermission path.
18
+ */
19
+ // biome-ignore lint/suspicious/noControlCharactersInRegex: strip ANSI escape sequences
20
+ const ANSI_RE = /\x1b\[[0-9;]*[a-zA-Z]/g;
21
+ class PtyRuntime {
22
+ opts;
23
+ pty = null;
24
+ settingsPath = null;
25
+ pendingPermissions = new Map();
26
+ exited = false;
27
+ cleaned = false;
28
+ ptyOutputBuffer = "";
29
+ errorDebounce = null;
30
+ constructor(opts) {
31
+ this.opts = opts;
32
+ }
33
+ get pid() {
34
+ return this.pty?.pid ?? -1;
35
+ }
36
+ get isAlive() {
37
+ return !!this.pty && !this.exited;
38
+ }
39
+ async start(initialText) {
40
+ const { sessionId, cwd, hookRouter } = this.opts;
41
+ const token = hookRouter.register(sessionId, this.buildHandler());
42
+ const { settingsPath, env } = await (0, claude_settings_1.prepareHookSettings)({
43
+ sessionId,
44
+ hookUrl: hookRouter.getUrl(),
45
+ hookToken: token,
46
+ allowList: this.opts.allowList,
47
+ denyList: this.opts.denyList,
48
+ });
49
+ this.settingsPath = settingsPath;
50
+ this.pty = new pty_session_1.PtySession({
51
+ cwd,
52
+ settingsPath,
53
+ env: { ...env, ...(this.opts.extraEnv ?? {}) },
54
+ extraArgs: this.opts.extraArgs,
55
+ bin: this.opts.claudeBin,
56
+ onData: (chunk) => {
57
+ this.scanForErrors(chunk);
58
+ this.opts.onPtyData?.(chunk);
59
+ },
60
+ onExit: (info) => {
61
+ this.exited = true;
62
+ this.opts.onExit(info);
63
+ this.cleanup().catch(() => { });
64
+ },
65
+ });
66
+ try {
67
+ await this.pty.start();
68
+ }
69
+ catch (err) {
70
+ await this.cleanup();
71
+ throw err;
72
+ }
73
+ if (initialText) {
74
+ await this.pty.sendText(initialText);
75
+ }
76
+ this.fetchInitData();
77
+ }
78
+ fetchInitData() {
79
+ const sid = this.opts.sessionId.slice(0, 8);
80
+ console.log(`[pty-runtime] fetching CLI init data for session ${sid}`);
81
+ (0, cli_init_fetch_1.fetchCliInitData)({ cwd: this.opts.cwd, bin: this.opts.claudeBin })
82
+ .then((initData) => {
83
+ if (initData && !this.exited) {
84
+ console.log(`[pty-runtime] emitting init event for session ${sid}: ${initData.slashCommands.length} commands`);
85
+ this.emit([{ type: "init", initData }]);
86
+ }
87
+ else {
88
+ console.log(`[pty-runtime] init fetch returned ${initData ? "data but session exited" : "null"} for session ${sid}`);
89
+ }
90
+ })
91
+ .catch((err) => {
92
+ console.log(`[pty-runtime] init fetch failed for session ${sid}: ${err}`);
93
+ });
94
+ }
95
+ async sendText(text) {
96
+ if (!this.pty)
97
+ throw new Error("PtyRuntime not started");
98
+ await this.pty.sendText(text);
99
+ }
100
+ sendSlash(command) {
101
+ if (!this.pty)
102
+ throw new Error("PtyRuntime not started");
103
+ this.pty.sendSlash(command);
104
+ }
105
+ sendKey(key) {
106
+ if (!this.pty)
107
+ throw new Error("PtyRuntime not started");
108
+ this.pty.sendKey(key);
109
+ }
110
+ /** Sends Esc to claude — the interactive REPL treats it as interrupt. */
111
+ interrupt() {
112
+ if (!this.pty)
113
+ return;
114
+ this.pty.sendKey("\x1b");
115
+ for (const [, resolve] of this.pendingPermissions) {
116
+ resolve({ behavior: "deny", message: "interrupted" });
117
+ }
118
+ this.pendingPermissions.clear();
119
+ }
120
+ resize(cols, rows) {
121
+ this.pty?.resize(cols, rows);
122
+ }
123
+ async kill(signal) {
124
+ this.cancelErrorDebounce();
125
+ if (this.pty) {
126
+ this.pty.kill(signal);
127
+ this.pty = null;
128
+ }
129
+ // Resolve any in-flight permission promises so the bridge subprocess can exit.
130
+ for (const [, resolve] of this.pendingPermissions) {
131
+ resolve({ behavior: "deny", message: "session ended" });
132
+ }
133
+ this.pendingPermissions.clear();
134
+ await this.cleanup();
135
+ }
136
+ /** Called by SessionManager.respondToPermission when this session is on the pty runtime. */
137
+ notifyPermissionDecision(requestId, decision) {
138
+ const resolver = this.pendingPermissions.get(requestId);
139
+ if (!resolver)
140
+ return false;
141
+ this.pendingPermissions.delete(requestId);
142
+ resolver(decision);
143
+ return true;
144
+ }
145
+ buildHandler() {
146
+ return {
147
+ onPreToolUse: (payload) => {
148
+ this.cancelErrorDebounce();
149
+ this.ptyOutputBuffer = "";
150
+ const toolName = typeof payload.tool_name === "string" ? payload.tool_name : "unknown";
151
+ const cliSession = typeof payload.session_id === "string" ? payload.session_id.slice(0, 8) : "none";
152
+ const toolUseId = typeof payload.tool_use_id === "string" ? payload.tool_use_id.slice(0, 12) : "none";
153
+ console.log(`[pty-runtime] PreToolUse: tool=${toolName} cli_session=${cliSession} tool_use_id=${toolUseId}`);
154
+ this.emit((0, hook_event_translator_1.translateHookEvent)("PreToolUse", payload));
155
+ },
156
+ onPostToolUse: (payload) => {
157
+ this.cancelErrorDebounce();
158
+ this.ptyOutputBuffer = "";
159
+ const toolName = typeof payload.tool_name === "string" ? payload.tool_name : "unknown";
160
+ const cliSession = typeof payload.session_id === "string" ? payload.session_id.slice(0, 8) : "none";
161
+ const toolUseId = typeof payload.tool_use_id === "string" ? payload.tool_use_id.slice(0, 12) : "none";
162
+ console.log(`[pty-runtime] PostToolUse: tool=${toolName} cli_session=${cliSession} tool_use_id=${toolUseId}`);
163
+ this.emit((0, hook_event_translator_1.translateHookEvent)("PostToolUse", payload));
164
+ },
165
+ onStop: (payload) => {
166
+ this.cancelErrorDebounce();
167
+ this.ptyOutputBuffer = "";
168
+ console.log(`[pty-runtime] Stop hook received for session ${this.opts.sessionId.slice(0, 8)}`);
169
+ const events = (0, hook_event_translator_1.translateHookEvent)("Stop", payload);
170
+ console.log(`[pty-runtime] Stop translated to ${events.length} events: [${events.map((e) => e.type).join(", ")}]`);
171
+ this.emit(events);
172
+ },
173
+ onStopFailure: (payload) => {
174
+ this.cancelErrorDebounce();
175
+ this.ptyOutputBuffer = "";
176
+ const errorType = typeof payload.error_type === "string" ? payload.error_type : "unknown";
177
+ const errorMessage = typeof payload.error_message === "string" ? payload.error_message : "Unknown error";
178
+ console.log(`[pty-runtime] StopFailure hook for session ${this.opts.sessionId.slice(0, 8)}: ${errorType} - ${errorMessage}`);
179
+ this.emit((0, hook_event_translator_1.translateHookEvent)("StopFailure", payload));
180
+ this.opts.onError(`${errorMessage} (${errorType})`);
181
+ },
182
+ onUserPromptSubmit: (payload) => {
183
+ this.cancelErrorDebounce();
184
+ this.ptyOutputBuffer = "";
185
+ this.emit((0, hook_event_translator_1.translateHookEvent)("UserPromptSubmit", payload));
186
+ },
187
+ onUserPromptExpansion: (payload) => {
188
+ this.cancelErrorDebounce();
189
+ this.ptyOutputBuffer = "";
190
+ const cmd = typeof payload.command_name === "string" ? payload.command_name : "unknown";
191
+ const sid = this.opts.sessionId.slice(0, 8);
192
+ console.log(`[pty-runtime] UserPromptExpansion: command=${cmd}, session=${sid}`);
193
+ this.emit((0, hook_event_translator_1.translateHookEvent)("UserPromptExpansion", payload));
194
+ },
195
+ onSubagentStart: (payload) => {
196
+ this.cancelErrorDebounce();
197
+ this.ptyOutputBuffer = "";
198
+ const cliSession = typeof payload.session_id === "string" ? payload.session_id.slice(0, 8) : "none";
199
+ const toolUseId = typeof payload.tool_use_id === "string" ? payload.tool_use_id.slice(0, 12) : "none";
200
+ const agentType = typeof payload.agent_type === "string" ? payload.agent_type : "unknown";
201
+ const desc = typeof payload.description === "string" ? payload.description.slice(0, 80) : "";
202
+ console.log(`[pty-runtime] SubagentStart: cli_session=${cliSession} tool_use_id=${toolUseId} type=${agentType} desc="${desc}"`);
203
+ console.log(`[pty-runtime] SubagentStart full payload keys: ${Object.keys(payload).join(", ")}`);
204
+ this.emit((0, hook_event_translator_1.translateHookEvent)("SubagentStart", payload));
205
+ },
206
+ onSubagentStop: (payload) => {
207
+ this.cancelErrorDebounce();
208
+ this.ptyOutputBuffer = "";
209
+ const cliSession = typeof payload.session_id === "string" ? payload.session_id.slice(0, 8) : "none";
210
+ const toolUseId = typeof payload.tool_use_id === "string" ? payload.tool_use_id.slice(0, 12) : "none";
211
+ const agentType = typeof payload.agent_type === "string" ? payload.agent_type : "unknown";
212
+ console.log(`[pty-runtime] SubagentStop: cli_session=${cliSession} tool_use_id=${toolUseId} type=${agentType}`);
213
+ console.log(`[pty-runtime] SubagentStop full payload keys: ${Object.keys(payload).join(", ")}`);
214
+ this.emit((0, hook_event_translator_1.translateHookEvent)("SubagentStop", payload));
215
+ },
216
+ onPreCompact: (payload) => {
217
+ this.cancelErrorDebounce();
218
+ this.ptyOutputBuffer = "";
219
+ console.log(`[pty-runtime] PreCompact for session ${this.opts.sessionId.slice(0, 8)}`);
220
+ this.emit((0, hook_event_translator_1.translateHookEvent)("PreCompact", payload));
221
+ },
222
+ onPostCompact: (payload) => {
223
+ this.cancelErrorDebounce();
224
+ this.ptyOutputBuffer = "";
225
+ console.log(`[pty-runtime] PostCompact for session ${this.opts.sessionId.slice(0, 8)}`);
226
+ this.emit((0, hook_event_translator_1.translateHookEvent)("PostCompact", payload));
227
+ },
228
+ onNotification: (payload) => {
229
+ this.cancelErrorDebounce();
230
+ this.emit((0, hook_event_translator_1.translateHookEvent)("Notification", payload));
231
+ },
232
+ onPermissionRequest: (payload) => this.handlePermissionRequest(payload),
233
+ };
234
+ }
235
+ handlePermissionRequest(payload) {
236
+ const requestId = (0, hook_event_translator_1.newPermissionRequestId)();
237
+ const toolName = typeof payload.tool_name === "string" ? payload.tool_name : "unknown";
238
+ const toolInput = payload.tool_input;
239
+ const event = {
240
+ type: "permission_request",
241
+ requestId,
242
+ toolName,
243
+ toolInput: toolInput ? JSON.stringify(toolInput) : "",
244
+ rawToolInput: toolInput,
245
+ };
246
+ return new Promise((resolve) => {
247
+ this.pendingPermissions.set(requestId, resolve);
248
+ try {
249
+ this.opts.onEvents([event]);
250
+ }
251
+ catch (err) {
252
+ this.pendingPermissions.delete(requestId);
253
+ resolve({ behavior: "deny", message: `cockpit handler error: ${String(err)}` });
254
+ }
255
+ });
256
+ }
257
+ emit(events) {
258
+ if (events.length === 0)
259
+ return;
260
+ try {
261
+ this.opts.onEvents(events);
262
+ }
263
+ catch (err) {
264
+ console.error(`[pty-runtime] onEvents threw for session ${this.opts.sessionId.slice(0, 8)}:`, err);
265
+ this.opts.onError(err instanceof Error ? err.message : String(err));
266
+ }
267
+ }
268
+ cancelErrorDebounce() {
269
+ if (this.errorDebounce) {
270
+ clearTimeout(this.errorDebounce);
271
+ this.errorDebounce = null;
272
+ }
273
+ }
274
+ scanForErrors(chunk) {
275
+ this.ptyOutputBuffer += chunk;
276
+ if (this.ptyOutputBuffer.length > 8 * 1024) {
277
+ this.ptyOutputBuffer = this.ptyOutputBuffer.slice(-4 * 1024);
278
+ }
279
+ if (this.errorDebounce)
280
+ return;
281
+ // biome-ignore lint/suspicious/noControlCharactersInRegex: strip terminal control chars
282
+ const clean = this.ptyOutputBuffer.replace(ANSI_RE, "").replace(/[\x00-\x1f]/g, "");
283
+ const match = clean.match(/API\s*Error:\s*(\d+)\s*([^✓✗❯]*)/) || clean.match(/APIError:\s*(\d+)\s*(.*)/);
284
+ if (!match)
285
+ return;
286
+ const httpCode = match[1];
287
+ const detail = match[2].trim().slice(0, 200);
288
+ const errMsg = detail ? `${detail} (HTTP ${httpCode})` : `API Error (HTTP ${httpCode})`;
289
+ this.errorDebounce = setTimeout(() => {
290
+ this.errorDebounce = null;
291
+ this.ptyOutputBuffer = "";
292
+ console.log(`[pty-runtime] API error detected for session ${this.opts.sessionId.slice(0, 8)}: ${errMsg}`);
293
+ const doneEvent = {
294
+ type: "message_done",
295
+ message: {
296
+ id: (0, uuid_1.v4)(),
297
+ role: "assistant",
298
+ content: "",
299
+ toolUses: [],
300
+ blocks: [],
301
+ timestamp: Date.now(),
302
+ },
303
+ };
304
+ try {
305
+ this.opts.onEvents([doneEvent]);
306
+ }
307
+ catch {
308
+ // best-effort
309
+ }
310
+ this.opts.onError(errMsg);
311
+ }, 10_000);
312
+ }
313
+ async cleanup() {
314
+ if (this.cleaned)
315
+ return;
316
+ this.cleaned = true;
317
+ this.opts.hookRouter.unregister(this.opts.sessionId);
318
+ if (this.settingsPath) {
319
+ await (0, claude_settings_1.cleanupHookSettings)(this.opts.sessionId).catch(() => { });
320
+ this.settingsPath = null;
321
+ }
322
+ }
323
+ }
324
+ exports.PtyRuntime = PtyRuntime;