@juspay/shooter 1.19.0 → 1.21.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 (283) hide show
  1. package/build/client/_app/immutable/assets/11.F10lvwyh.css +1 -0
  2. package/build/client/_app/immutable/assets/11.F10lvwyh.css.br +0 -0
  3. package/build/client/_app/immutable/assets/11.F10lvwyh.css.gz +0 -0
  4. package/build/client/_app/immutable/assets/2.BHi6pjT2.css +1 -0
  5. package/build/client/_app/immutable/assets/2.BHi6pjT2.css.br +0 -0
  6. package/build/client/_app/immutable/assets/2.BHi6pjT2.css.gz +0 -0
  7. package/build/client/_app/immutable/chunks/{ZS5XYDx_.js → B1bOvemT.js} +1 -1
  8. package/build/client/_app/immutable/chunks/B1bOvemT.js.br +0 -0
  9. package/build/client/_app/immutable/chunks/{ZS5XYDx_.js.gz → B1bOvemT.js.gz} +0 -0
  10. package/build/client/_app/immutable/chunks/{DCDL_9ys.js → BmfLecb1.js} +1 -1
  11. package/build/client/_app/immutable/chunks/BmfLecb1.js.br +0 -0
  12. package/build/client/_app/immutable/chunks/BmfLecb1.js.gz +0 -0
  13. package/build/client/_app/immutable/chunks/C87ZRWX0.js +1 -0
  14. package/build/client/_app/immutable/chunks/C87ZRWX0.js.br +0 -0
  15. package/build/client/_app/immutable/chunks/C87ZRWX0.js.gz +0 -0
  16. package/build/client/_app/immutable/chunks/{BvmdJful.js → CJulw9ux.js} +1 -1
  17. package/build/client/_app/immutable/chunks/CJulw9ux.js.br +0 -0
  18. package/build/client/_app/immutable/chunks/CJulw9ux.js.gz +0 -0
  19. package/build/client/_app/immutable/chunks/DOEXXmsh.js +3 -0
  20. package/build/client/_app/immutable/chunks/DOEXXmsh.js.br +0 -0
  21. package/build/client/_app/immutable/chunks/DOEXXmsh.js.gz +0 -0
  22. package/build/client/_app/immutable/chunks/{ClIPTXf3.js → DomZZqvG.js} +1 -1
  23. package/build/client/_app/immutable/chunks/DomZZqvG.js.br +0 -0
  24. package/build/client/_app/immutable/chunks/DomZZqvG.js.gz +0 -0
  25. package/build/client/_app/immutable/chunks/{DA4Zt9Me.js → EqMAkEha.js} +1 -1
  26. package/build/client/_app/immutable/chunks/EqMAkEha.js.br +0 -0
  27. package/build/client/_app/immutable/chunks/EqMAkEha.js.gz +0 -0
  28. package/build/client/_app/immutable/chunks/J5-Cr5oR.js +6 -0
  29. package/build/client/_app/immutable/chunks/J5-Cr5oR.js.br +0 -0
  30. package/build/client/_app/immutable/chunks/J5-Cr5oR.js.gz +0 -0
  31. package/build/client/_app/immutable/chunks/{BB2l8o4X.js → i5iZvmIH.js} +1 -1
  32. package/build/client/_app/immutable/chunks/i5iZvmIH.js.br +0 -0
  33. package/build/client/_app/immutable/chunks/i5iZvmIH.js.gz +0 -0
  34. package/build/client/_app/immutable/entry/{app.D4TXlu7A.js → app.CeSxgGat.js} +2 -2
  35. package/build/client/_app/immutable/entry/app.CeSxgGat.js.br +0 -0
  36. package/build/client/_app/immutable/entry/app.CeSxgGat.js.gz +0 -0
  37. package/build/client/_app/immutable/entry/start.DrnJFwxA.js +1 -0
  38. package/build/client/_app/immutable/entry/start.DrnJFwxA.js.br +2 -0
  39. package/build/client/_app/immutable/entry/start.DrnJFwxA.js.gz +0 -0
  40. package/build/client/_app/immutable/nodes/0.oaPwxh1O.js +10 -0
  41. package/build/client/_app/immutable/nodes/0.oaPwxh1O.js.br +0 -0
  42. package/build/client/_app/immutable/nodes/0.oaPwxh1O.js.gz +0 -0
  43. package/build/client/_app/immutable/nodes/{1.BVnLUSs-.js → 1.DMPyoM-M.js} +1 -1
  44. package/build/client/_app/immutable/nodes/1.DMPyoM-M.js.br +0 -0
  45. package/build/client/_app/immutable/nodes/1.DMPyoM-M.js.gz +0 -0
  46. package/build/client/_app/immutable/nodes/{10.D1wl2wPX.js → 10.Cbm7nQKK.js} +1 -1
  47. package/build/client/_app/immutable/nodes/10.Cbm7nQKK.js.br +0 -0
  48. package/build/client/_app/immutable/nodes/10.Cbm7nQKK.js.gz +0 -0
  49. package/build/client/_app/immutable/nodes/11.CKmZjP_a.js +2 -0
  50. package/build/client/_app/immutable/nodes/11.CKmZjP_a.js.br +0 -0
  51. package/build/client/_app/immutable/nodes/11.CKmZjP_a.js.gz +0 -0
  52. package/build/client/_app/immutable/nodes/2.zlrdNFtH.js +13 -0
  53. package/build/client/_app/immutable/nodes/2.zlrdNFtH.js.br +0 -0
  54. package/build/client/_app/immutable/nodes/2.zlrdNFtH.js.gz +0 -0
  55. package/build/client/_app/immutable/nodes/{3.Wfz3TcJd.js → 3.BgLpGnzb.js} +1 -1
  56. package/build/client/_app/immutable/nodes/3.BgLpGnzb.js.br +0 -0
  57. package/build/client/_app/immutable/nodes/3.BgLpGnzb.js.gz +0 -0
  58. package/build/client/_app/immutable/nodes/{4.CBX9A3ka.js → 4.BFYS2g9C.js} +3 -3
  59. package/build/client/_app/immutable/nodes/4.BFYS2g9C.js.br +0 -0
  60. package/build/client/_app/immutable/nodes/4.BFYS2g9C.js.gz +0 -0
  61. package/build/client/_app/immutable/nodes/{5.DIVKuZc9.js → 5.Avc1-gVb.js} +1 -1
  62. package/build/client/_app/immutable/nodes/5.Avc1-gVb.js.br +0 -0
  63. package/build/client/_app/immutable/nodes/5.Avc1-gVb.js.gz +0 -0
  64. package/build/client/_app/immutable/nodes/{6.DtZAEPXb.js → 6.Dw2wEssJ.js} +1 -1
  65. package/build/client/_app/immutable/nodes/6.Dw2wEssJ.js.br +0 -0
  66. package/build/client/_app/immutable/nodes/6.Dw2wEssJ.js.gz +0 -0
  67. package/build/client/_app/immutable/nodes/{7.MfBRh32I.js → 7.DwKZjoBg.js} +1 -1
  68. package/build/client/_app/immutable/nodes/7.DwKZjoBg.js.br +0 -0
  69. package/build/client/_app/immutable/nodes/7.DwKZjoBg.js.gz +0 -0
  70. package/build/client/_app/immutable/nodes/{8.DVE6LnOC.js → 8.ZUAI6g5E.js} +1 -1
  71. package/build/client/_app/immutable/nodes/8.ZUAI6g5E.js.br +0 -0
  72. package/build/client/_app/immutable/nodes/8.ZUAI6g5E.js.gz +0 -0
  73. package/build/client/_app/immutable/nodes/{9.BCel5OqI.js → 9.I_KGXPwB.js} +1 -1
  74. package/build/client/_app/immutable/nodes/9.I_KGXPwB.js.br +0 -0
  75. package/build/client/_app/immutable/nodes/9.I_KGXPwB.js.gz +0 -0
  76. package/build/client/_app/version.json +1 -1
  77. package/build/client/_app/version.json.br +0 -0
  78. package/build/client/_app/version.json.gz +0 -0
  79. package/build/server/chunks/{0-DJqyZZTr.js → 0-vrTNAfZB.js} +4 -2
  80. package/build/server/chunks/0-vrTNAfZB.js.map +1 -0
  81. package/build/server/chunks/{1-2YUVen1F.js → 1-nbr-bOoF.js} +2 -2
  82. package/build/server/chunks/{1-2YUVen1F.js.map → 1-nbr-bOoF.js.map} +1 -1
  83. package/build/server/chunks/{10-D1X7LB3v.js → 10-ChyvvJ6w.js} +2 -2
  84. package/build/server/chunks/{10-D1X7LB3v.js.map → 10-ChyvvJ6w.js.map} +1 -1
  85. package/build/server/chunks/{11-qXSPdF5j.js → 11-6ZAjL3uU.js} +4 -4
  86. package/build/server/chunks/11-6ZAjL3uU.js.map +1 -0
  87. package/build/server/chunks/{2-BD7kj1mt.js → 2-DWFRVDWJ.js} +3 -3
  88. package/build/server/chunks/{2-BD7kj1mt.js.map → 2-DWFRVDWJ.js.map} +1 -1
  89. package/build/server/chunks/{3-oNjv-BhZ.js → 3-CKANM_WM.js} +2 -2
  90. package/build/server/chunks/{3-oNjv-BhZ.js.map → 3-CKANM_WM.js.map} +1 -1
  91. package/build/server/chunks/{4-Bb5VFhsO.js → 4-D92KnTmb.js} +3 -3
  92. package/build/server/chunks/{4-Bb5VFhsO.js.map → 4-D92KnTmb.js.map} +1 -1
  93. package/build/server/chunks/{5-oNoWuIsn.js → 5-BxVjs2qi.js} +2 -2
  94. package/build/server/chunks/{5-oNoWuIsn.js.map → 5-BxVjs2qi.js.map} +1 -1
  95. package/build/server/chunks/{6-DRJGUqHG.js → 6-Cbf1AAMQ.js} +2 -2
  96. package/build/server/chunks/{6-DRJGUqHG.js.map → 6-Cbf1AAMQ.js.map} +1 -1
  97. package/build/server/chunks/{7-_giJiu0L.js → 7-CMK2quEf.js} +2 -2
  98. package/build/server/chunks/{7-_giJiu0L.js.map → 7-CMK2quEf.js.map} +1 -1
  99. package/build/server/chunks/{8-zvWAVNT5.js → 8-DhdfkfDM.js} +2 -2
  100. package/build/server/chunks/{8-zvWAVNT5.js.map → 8-DhdfkfDM.js.map} +1 -1
  101. package/build/server/chunks/{9-DVyDL445.js → 9-CPpxtRM5.js} +2 -2
  102. package/build/server/chunks/{9-DVyDL445.js.map → 9-CPpxtRM5.js.map} +1 -1
  103. package/build/server/chunks/Banner-BgaAs1rs.js.map +1 -1
  104. package/build/server/chunks/Button-D0hZ7JYt.js.map +1 -1
  105. package/build/server/chunks/Icon-D0GBnDcs.js.map +1 -1
  106. package/build/server/chunks/Input-OmIiydSx.js.map +1 -1
  107. package/build/server/chunks/Pill-4xJ-VhAA.js.map +1 -1
  108. package/build/server/chunks/Shimmer-Dw2uvTC1.js.map +1 -1
  109. package/build/server/chunks/_error.svelte-CZnkxeLr.js.map +1 -1
  110. package/build/server/chunks/_layout.svelte-DfgNGGiM.js.map +1 -1
  111. package/build/server/chunks/_page.svelte-BTlfUsBp.js.map +1 -1
  112. package/build/server/chunks/_page.svelte-BX2FMgSg.js.map +1 -1
  113. package/build/server/chunks/_page.svelte-C7B0qdrC.js.map +1 -1
  114. package/build/server/chunks/_page.svelte-CE7COWnF.js.map +1 -1
  115. package/build/server/chunks/_page.svelte-CWsjjd4l.js.map +1 -1
  116. package/build/server/chunks/_page.svelte-D5S2hkBk.js.map +1 -1
  117. package/build/server/chunks/_page.svelte-D_Ey8QRG.js.map +1 -1
  118. package/build/server/chunks/{_page.svelte-BLo2v_8E.js → _page.svelte-Gv9p8nlS.js} +3 -4
  119. package/build/server/chunks/_page.svelte-Gv9p8nlS.js.map +1 -0
  120. package/build/server/chunks/{_page.svelte-BUBLUSGo.js → _page.svelte-dabsQl9c.js} +206 -5
  121. package/build/server/chunks/_page.svelte-dabsQl9c.js.map +1 -0
  122. package/build/server/chunks/_page.svelte-tBuIq8Pg.js.map +1 -1
  123. package/build/server/chunks/_server.ts-B-evHL2q.js +13 -0
  124. package/build/server/chunks/_server.ts-B-evHL2q.js.map +1 -0
  125. package/build/server/chunks/_server.ts-BB46Fbqn.js +59 -0
  126. package/build/server/chunks/_server.ts-BB46Fbqn.js.map +1 -0
  127. package/build/server/chunks/{_server.ts-DMm0hBP4.js → _server.ts-BWVlO8iV.js} +8 -5
  128. package/build/server/chunks/_server.ts-BWVlO8iV.js.map +1 -0
  129. package/build/server/chunks/{_server.ts-BRAzC6W1.js → _server.ts-BevnuePu.js} +27 -6
  130. package/build/server/chunks/_server.ts-BevnuePu.js.map +1 -0
  131. package/build/server/chunks/_server.ts-CA5KUENM.js +95 -0
  132. package/build/server/chunks/_server.ts-CA5KUENM.js.map +1 -0
  133. package/build/server/chunks/{_server.ts-DhJx0DLr.js → _server.ts-CC2K8-L2.js} +16 -7
  134. package/build/server/chunks/_server.ts-CC2K8-L2.js.map +1 -0
  135. package/build/server/chunks/{_server.ts-Bi0Oe4PF.js → _server.ts-CD7JP3fz.js} +14 -9
  136. package/build/server/chunks/_server.ts-CD7JP3fz.js.map +1 -0
  137. package/build/server/chunks/{_server.ts-C_OOUqsd.js → _server.ts-D0zRDSx0.js} +2 -2
  138. package/build/server/chunks/{_server.ts-C_OOUqsd.js.map → _server.ts-D0zRDSx0.js.map} +1 -1
  139. package/build/server/chunks/{_server.ts-DxT9IlZF.js → _server.ts-Dp-hXW_I.js} +3 -3
  140. package/build/server/chunks/{_server.ts-DxT9IlZF.js.map → _server.ts-Dp-hXW_I.js.map} +1 -1
  141. package/build/server/chunks/_server.ts-DpRr0Tfh.js +68 -0
  142. package/build/server/chunks/_server.ts-DpRr0Tfh.js.map +1 -0
  143. package/build/server/chunks/{_server.ts-Bjbr7glm.js → _server.ts-QN-Bo5ql.js} +12 -5
  144. package/build/server/chunks/_server.ts-QN-Bo5ql.js.map +1 -0
  145. package/build/server/chunks/_server.ts-VzDcFFgy.js +157 -0
  146. package/build/server/chunks/_server.ts-VzDcFFgy.js.map +1 -0
  147. package/build/server/chunks/{_server.ts-BrqaMMAa.js → _server.ts-W6i3EnGX.js} +29 -6
  148. package/build/server/chunks/_server.ts-W6i3EnGX.js.map +1 -0
  149. package/build/server/chunks/{_server.ts-CRVNEOd2.js → _server.ts-X1R7L_QI.js} +3 -3
  150. package/build/server/chunks/{_server.ts-CRVNEOd2.js.map → _server.ts-X1R7L_QI.js.map} +1 -1
  151. package/build/server/chunks/cache-BlMaDsHi.js.map +1 -1
  152. package/build/server/chunks/guest-registry-Dxvd7p-g.js +48 -0
  153. package/build/server/chunks/guest-registry-Dxvd7p-g.js.map +1 -0
  154. package/build/server/chunks/index-CoYB03g7.js.map +1 -1
  155. package/build/server/chunks/index2-dSGQ9Eaa.js.map +1 -1
  156. package/build/server/chunks/{pty-manager-41h3IK8K.js → pty-manager-ZqXqa-6A.js} +6 -2
  157. package/build/server/chunks/pty-manager-ZqXqa-6A.js.map +1 -0
  158. package/build/server/chunks/root-D4IoFC8F.js.map +1 -1
  159. package/build/server/chunks/share-auth-BS7JuiHf.js +27 -0
  160. package/build/server/chunks/share-auth-BS7JuiHf.js.map +1 -0
  161. package/build/server/chunks/share-store-B9jMpVg0.js +127 -0
  162. package/build/server/chunks/share-store-B9jMpVg0.js.map +1 -0
  163. package/build/server/chunks/state.svelte-CmHqngc_.js.map +1 -1
  164. package/build/server/chunks/stores-CRYxfF0o.js.map +1 -1
  165. package/build/server/index.js +1 -1
  166. package/build/server/index.js.map +1 -1
  167. package/build/server/manifest.js +57 -22
  168. package/build/server/manifest.js.map +1 -1
  169. package/package.json +2 -2
  170. package/server.ts +10 -3
  171. package/src/lib/modules/client/dashboard/AutopilotPanel.svelte +400 -0
  172. package/src/lib/modules/client/dashboard/index.ts +1 -0
  173. package/src/lib/modules/client/neurolink/provider-config.ts +13 -37
  174. package/src/lib/modules/client/terminal/ShareGate.svelte +96 -0
  175. package/src/lib/modules/client/terminal/ShareSheet.svelte +395 -0
  176. package/src/lib/modules/client/terminal/xterm-wrapper.ts +19 -2
  177. package/src/lib/modules/server/sessions/autopilot-engine.ts +346 -0
  178. package/src/lib/modules/server/sessions/litellm-client.ts +115 -0
  179. package/src/lib/modules/server/sessions/next-step-consensus.ts +185 -0
  180. package/src/lib/modules/server/sessions/summary-store.ts +111 -0
  181. package/src/lib/modules/server/terminal/pty-manager.ts +6 -0
  182. package/src/lib/modules/server/terminal/share-auth.ts +37 -0
  183. package/src/lib/modules/server/terminal/share-store.ts +172 -0
  184. package/src/lib/modules/server/ws/events-handler.ts +32 -0
  185. package/src/lib/modules/server/ws/guest-registry.ts +49 -0
  186. package/src/lib/modules/server/ws/server.ts +22 -3
  187. package/src/lib/modules/server/ws/session-handler.ts +18 -4
  188. package/src/lib/modules/server/ws/terminal-handler.ts +21 -2
  189. package/src/lib/modules/server/ws/ticket-store.ts +18 -10
  190. package/src/lib/types/autopilot.ts +73 -0
  191. package/src/lib/types/generated/Client.ts +25 -1
  192. package/src/lib/types/generated/Share.ts +404 -0
  193. package/src/lib/types/generated/WsProtocol.ts +73 -2
  194. package/src/lib/types/generated/index.ts +1 -0
  195. package/src/lib/types/index.ts +1 -0
  196. package/src/lib/types/terminal-client.ts +21 -2
  197. package/src/lib/types/ws.ts +1 -0
  198. package/src/routes/+layout.server.ts +2 -0
  199. package/src/routes/+layout.svelte +19 -4
  200. package/src/routes/+page.svelte +9 -1
  201. package/src/routes/api/autopilot/+server.ts +74 -0
  202. package/src/routes/api/neurolink-proxy/+server.ts +31 -6
  203. package/src/routes/api/notify/+server.ts +20 -3
  204. package/src/routes/api/summaries/+server.ts +99 -0
  205. package/src/routes/api/terminals/[id]/+server.ts +14 -3
  206. package/src/routes/api/terminals/[id]/paste-image/+server.ts +8 -4
  207. package/src/routes/api/terminals/[id]/resize/+server.ts +8 -4
  208. package/src/routes/api/terminals/[id]/share/+server.ts +98 -0
  209. package/src/routes/api/terminals/[id]/share/auth/+server.ts +81 -0
  210. package/src/routes/api/terminals/[id]/share/status/+server.ts +11 -0
  211. package/src/routes/api/ws-ticket/+server.ts +26 -5
  212. package/src/routes/terminals/[id]/+page.svelte +184 -43
  213. package/build/client/_app/immutable/assets/11.v5KA95xm.css +0 -1
  214. package/build/client/_app/immutable/assets/11.v5KA95xm.css.br +0 -0
  215. package/build/client/_app/immutable/assets/11.v5KA95xm.css.gz +0 -0
  216. package/build/client/_app/immutable/assets/2.DjiwkLqE.css +0 -1
  217. package/build/client/_app/immutable/assets/2.DjiwkLqE.css.br +0 -0
  218. package/build/client/_app/immutable/assets/2.DjiwkLqE.css.gz +0 -0
  219. package/build/client/_app/immutable/chunks/BB2l8o4X.js.br +0 -0
  220. package/build/client/_app/immutable/chunks/BB2l8o4X.js.gz +0 -0
  221. package/build/client/_app/immutable/chunks/BcqA7eKM.js +0 -3
  222. package/build/client/_app/immutable/chunks/BcqA7eKM.js.br +0 -0
  223. package/build/client/_app/immutable/chunks/BcqA7eKM.js.gz +0 -0
  224. package/build/client/_app/immutable/chunks/BvmdJful.js.br +0 -0
  225. package/build/client/_app/immutable/chunks/BvmdJful.js.gz +0 -0
  226. package/build/client/_app/immutable/chunks/CR6bkGJW.js +0 -6
  227. package/build/client/_app/immutable/chunks/CR6bkGJW.js.br +0 -0
  228. package/build/client/_app/immutable/chunks/CR6bkGJW.js.gz +0 -0
  229. package/build/client/_app/immutable/chunks/ClIPTXf3.js.br +0 -0
  230. package/build/client/_app/immutable/chunks/ClIPTXf3.js.gz +0 -0
  231. package/build/client/_app/immutable/chunks/DA4Zt9Me.js.br +0 -0
  232. package/build/client/_app/immutable/chunks/DA4Zt9Me.js.gz +0 -0
  233. package/build/client/_app/immutable/chunks/DCDL_9ys.js.br +0 -0
  234. package/build/client/_app/immutable/chunks/DCDL_9ys.js.gz +0 -0
  235. package/build/client/_app/immutable/chunks/ZS5XYDx_.js.br +0 -0
  236. package/build/client/_app/immutable/chunks/pRcLbE0d.js +0 -1
  237. package/build/client/_app/immutable/chunks/pRcLbE0d.js.br +0 -0
  238. package/build/client/_app/immutable/chunks/pRcLbE0d.js.gz +0 -0
  239. package/build/client/_app/immutable/entry/app.D4TXlu7A.js.br +0 -0
  240. package/build/client/_app/immutable/entry/app.D4TXlu7A.js.gz +0 -0
  241. package/build/client/_app/immutable/entry/start.BBQhtURO.js +0 -1
  242. package/build/client/_app/immutable/entry/start.BBQhtURO.js.br +0 -0
  243. package/build/client/_app/immutable/entry/start.BBQhtURO.js.gz +0 -0
  244. package/build/client/_app/immutable/nodes/0.1zylwAPT.js +0 -10
  245. package/build/client/_app/immutable/nodes/0.1zylwAPT.js.br +0 -0
  246. package/build/client/_app/immutable/nodes/0.1zylwAPT.js.gz +0 -0
  247. package/build/client/_app/immutable/nodes/1.BVnLUSs-.js.br +0 -0
  248. package/build/client/_app/immutable/nodes/1.BVnLUSs-.js.gz +0 -0
  249. package/build/client/_app/immutable/nodes/10.D1wl2wPX.js.br +0 -0
  250. package/build/client/_app/immutable/nodes/10.D1wl2wPX.js.gz +0 -0
  251. package/build/client/_app/immutable/nodes/11.C18nMGmp.js +0 -2
  252. package/build/client/_app/immutable/nodes/11.C18nMGmp.js.br +0 -0
  253. package/build/client/_app/immutable/nodes/11.C18nMGmp.js.gz +0 -0
  254. package/build/client/_app/immutable/nodes/2.D1Mm0DUX.js +0 -13
  255. package/build/client/_app/immutable/nodes/2.D1Mm0DUX.js.br +0 -0
  256. package/build/client/_app/immutable/nodes/2.D1Mm0DUX.js.gz +0 -0
  257. package/build/client/_app/immutable/nodes/3.Wfz3TcJd.js.br +0 -0
  258. package/build/client/_app/immutable/nodes/3.Wfz3TcJd.js.gz +0 -0
  259. package/build/client/_app/immutable/nodes/4.CBX9A3ka.js.br +0 -0
  260. package/build/client/_app/immutable/nodes/4.CBX9A3ka.js.gz +0 -0
  261. package/build/client/_app/immutable/nodes/5.DIVKuZc9.js.br +0 -0
  262. package/build/client/_app/immutable/nodes/5.DIVKuZc9.js.gz +0 -0
  263. package/build/client/_app/immutable/nodes/6.DtZAEPXb.js.br +0 -0
  264. package/build/client/_app/immutable/nodes/6.DtZAEPXb.js.gz +0 -0
  265. package/build/client/_app/immutable/nodes/7.MfBRh32I.js.br +0 -0
  266. package/build/client/_app/immutable/nodes/7.MfBRh32I.js.gz +0 -0
  267. package/build/client/_app/immutable/nodes/8.DVE6LnOC.js.br +0 -0
  268. package/build/client/_app/immutable/nodes/8.DVE6LnOC.js.gz +0 -0
  269. package/build/client/_app/immutable/nodes/9.BCel5OqI.js.br +0 -0
  270. package/build/client/_app/immutable/nodes/9.BCel5OqI.js.gz +0 -0
  271. package/build/server/chunks/0-DJqyZZTr.js.map +0 -1
  272. package/build/server/chunks/11-qXSPdF5j.js.map +0 -1
  273. package/build/server/chunks/_page.svelte-BLo2v_8E.js.map +0 -1
  274. package/build/server/chunks/_page.svelte-BUBLUSGo.js.map +0 -1
  275. package/build/server/chunks/_server.ts-BRAzC6W1.js.map +0 -1
  276. package/build/server/chunks/_server.ts-Bi0Oe4PF.js.map +0 -1
  277. package/build/server/chunks/_server.ts-Bjbr7glm.js.map +0 -1
  278. package/build/server/chunks/_server.ts-BrqaMMAa.js.map +0 -1
  279. package/build/server/chunks/_server.ts-DMm0hBP4.js.map +0 -1
  280. package/build/server/chunks/_server.ts-DhJx0DLr.js.map +0 -1
  281. package/build/server/chunks/events-handler-Dm1mNPQP.js +0 -20
  282. package/build/server/chunks/events-handler-Dm1mNPQP.js.map +0 -1
  283. package/build/server/chunks/pty-manager-41h3IK8K.js.map +0 -1
@@ -0,0 +1,73 @@
1
+ // Hand-written autopilot types — union/record types not expressible in YAML.
2
+
3
+ /** A raw proposal from a single agent. */
4
+ export interface AgentProposal {
5
+ confidence: number;
6
+ text: string;
7
+ }
8
+
9
+ /** Autopilot module-level state (not a Svelte store — held in the autopilot module). */
10
+ export interface AutopilotState {
11
+ enabled: boolean;
12
+ status: Record<string, AutopilotStatus>;
13
+ }
14
+
15
+ /** Per-session autopilot lifecycle state. */
16
+ export type AutopilotStatus = 'error' | 'idle' | 'running';
17
+
18
+ /** Result from mergeNextStepConsensus(). */
19
+ export interface ConsensusResult {
20
+ /** Number of agent lists passed in. */
21
+ agentCount: number;
22
+ /** Quorum threshold used. */
23
+ quorum: number;
24
+ /** Consensus (or tentative) next-step list, sorted by votes desc then confidence desc. */
25
+ steps: NextStep[];
26
+ }
27
+
28
+ /** Options for mergeNextStepConsensus(). */
29
+ export interface MergeOptions {
30
+ /** Max steps taken from each agent list (default 3). */
31
+ k?: number;
32
+ /** Minimum vote count for a group to reach consensus (default 3). */
33
+ quorum?: number;
34
+ }
35
+
36
+ /** A single proposed next step from one agent or the merged consensus. */
37
+ export interface NextStep {
38
+ /** Confidence score in [0, 1]. For consensus steps this is the mean across proposers. */
39
+ confidence: number;
40
+ /** Present and true when no group reached quorum; indicates low-certainty result. */
41
+ tentative?: boolean;
42
+ /** The original (highest-confidence) phrasing of the step. */
43
+ text: string;
44
+ /** Number of distinct agents that proposed this step (consensus only). */
45
+ votes?: number;
46
+ }
47
+
48
+ /**
49
+ * Additional per-session fields added by the autopilot engine.
50
+ * These are optional so that SessionState objects (which lack them by default)
51
+ * remain assignable; the engine writes them via Svelte 5's reactive proxy.
52
+ */
53
+ export interface SessionAutopilotFields {
54
+ /** ISO 8601 timestamp of the last completed autopilot pipeline run. */
55
+ autopilotLastRun?: null | string;
56
+ /** Current autopilot pipeline status for this session. */
57
+ autopilotStatus?: AutopilotStatus;
58
+ /** Consensus next-step list from the last pipeline run. */
59
+ nextSteps?: NextStep[];
60
+ }
61
+
62
+ /** A persisted summary record stored in session_summaries. */
63
+ export interface SessionSummaryRecord {
64
+ createdAt: string;
65
+ id: string;
66
+ /** JSON-serialised NextStep[] */
67
+ nextSteps: string;
68
+ projectName: null | string;
69
+ sessionId: null | string;
70
+ summary: string;
71
+ terminalId: null | string;
72
+ trigger: string;
73
+ }
@@ -1,4 +1,4 @@
1
- import { type SessionSource, decodeSessionSource } from './index';
1
+ import { type ShareMode, decodeShareMode, type SessionSource, decodeSessionSource } from './index';
2
2
  import {
3
3
  isJSON,
4
4
  decodeString,
@@ -307,6 +307,24 @@ export type TerminalDetailView = {
307
307
  * @memberof TerminalDetailView
308
308
  */
309
309
  sessionWs: string;
310
+ /**
311
+ * @description Current PTY width in columns (for fixed-size guest rendering)
312
+ * @type { number }
313
+ * @memberof TerminalDetailView
314
+ */
315
+ cols: number | null;
316
+ /**
317
+ * @description Current PTY height in rows (for fixed-size guest rendering)
318
+ * @type { number }
319
+ * @memberof TerminalDetailView
320
+ */
321
+ rows: number | null;
322
+ /**
323
+ * @description Present when fetched with a guest share token — the guest's access mode
324
+ * @type { ShareMode }
325
+ * @memberof TerminalDetailView
326
+ */
327
+ shareMode: ShareMode | null;
310
328
  };
311
329
 
312
330
  export function decodeTerminalDetailView(rawInput: unknown): TerminalDetailView | null {
@@ -325,6 +343,9 @@ export function decodeTerminalDetailView(rawInput: unknown): TerminalDetailView
325
343
  const decodedTimestamp = decodeString(rawInput['timestamp']);
326
344
  const decodedWs = decodeString(rawInput['ws']);
327
345
  const decodedSessionWs = decodeString(rawInput['sessionWs']);
346
+ const decodedCols = decodeNumber(rawInput['cols']);
347
+ const decodedRows = decodeNumber(rawInput['rows']);
348
+ const decodedShareMode = decodeShareMode(rawInput['shareMode']);
328
349
 
329
350
  if (
330
351
  decodedId === null ||
@@ -355,6 +376,9 @@ export function decodeTerminalDetailView(rawInput: unknown): TerminalDetailView
355
376
  timestamp: decodedTimestamp,
356
377
  ws: decodedWs,
357
378
  sessionWs: decodedSessionWs,
379
+ cols: decodedCols,
380
+ rows: decodedRows,
381
+ shareMode: decodedShareMode,
358
382
  };
359
383
  }
360
384
  return null;
@@ -0,0 +1,404 @@
1
+ import {
2
+ isJSON,
3
+ decodeString,
4
+ _decodeString,
5
+ decodeNumber,
6
+ _decodeNumber,
7
+ decodeBoolean,
8
+ _decodeBoolean,
9
+ } from 'type-decoder';
10
+
11
+ /**
12
+ * @type { ShareMode }
13
+ * @description What a share guest may do — watch only, or full input control
14
+ */
15
+ export type ShareMode = 'view' | 'control';
16
+
17
+ export function decodeShareMode(rawInput: unknown): ShareMode | null {
18
+ switch (rawInput) {
19
+ case 'view':
20
+ case 'control':
21
+ return rawInput;
22
+ }
23
+ return null;
24
+ }
25
+
26
+ export function _decodeShareMode(rawInput: unknown): ShareMode | undefined {
27
+ switch (rawInput) {
28
+ case 'view':
29
+ case 'control':
30
+ return rawInput;
31
+ }
32
+ return;
33
+ }
34
+
35
+ /**
36
+ * @type { AccessLevel }
37
+ * @description Authorization level resolved for a terminal-scoped request
38
+ */
39
+ export type AccessLevel = 'owner' | 'guest';
40
+
41
+ export function decodeAccessLevel(rawInput: unknown): AccessLevel | null {
42
+ switch (rawInput) {
43
+ case 'owner':
44
+ case 'guest':
45
+ return rawInput;
46
+ }
47
+ return null;
48
+ }
49
+
50
+ export function _decodeAccessLevel(rawInput: unknown): AccessLevel | undefined {
51
+ switch (rawInput) {
52
+ case 'owner':
53
+ case 'guest':
54
+ return rawInput;
55
+ }
56
+ return;
57
+ }
58
+
59
+ /**
60
+ * @type { AccessContext }
61
+ * @description Resolved authorization for a terminal-scoped API request
62
+ */
63
+ export type AccessContext = {
64
+ /**
65
+ * @description owner (API key) or guest (share session token)
66
+ * @type { AccessLevel }
67
+ * @memberof AccessContext
68
+ */
69
+ level: AccessLevel;
70
+ /**
71
+ * @description Guest access mode (present only when level is guest)
72
+ * @type { ShareMode }
73
+ * @memberof AccessContext
74
+ */
75
+ mode: ShareMode | null;
76
+ };
77
+
78
+ export function decodeAccessContext(rawInput: unknown): AccessContext | null {
79
+ if (isJSON(rawInput)) {
80
+ const decodedLevel = decodeAccessLevel(rawInput['level']);
81
+ const decodedMode = decodeShareMode(rawInput['mode']);
82
+
83
+ if (decodedLevel === null) {
84
+ return null;
85
+ }
86
+
87
+ return {
88
+ level: decodedLevel,
89
+ mode: decodedMode,
90
+ };
91
+ }
92
+ return null;
93
+ }
94
+
95
+ /**
96
+ * @type { TerminalShareRecord }
97
+ * @description Persisted share configuration for one terminal (terminal_shares table)
98
+ */
99
+ export type TerminalShareRecord = {
100
+ /**
101
+ * @description Terminal this share belongs to (primary key)
102
+ * @type { string }
103
+ * @memberof TerminalShareRecord
104
+ */
105
+ terminalId: string;
106
+ /**
107
+ * @description scrypt:<salt-hex>:<hash-hex> password hash
108
+ * @type { string }
109
+ * @memberof TerminalShareRecord
110
+ */
111
+ passwordHash: string;
112
+ /**
113
+ * @description Access mode granted to guests
114
+ * @type { ShareMode }
115
+ * @memberof TerminalShareRecord
116
+ */
117
+ mode: ShareMode;
118
+ /**
119
+ * @description Unix timestamp (ms) when the share was created
120
+ * @type { number }
121
+ * @memberof TerminalShareRecord
122
+ */
123
+ createdAt: number;
124
+ /**
125
+ * @description Unix timestamp (ms) when the share was last updated
126
+ * @type { number }
127
+ * @memberof TerminalShareRecord
128
+ */
129
+ updatedAt: number;
130
+ };
131
+
132
+ export function decodeTerminalShareRecord(rawInput: unknown): TerminalShareRecord | null {
133
+ if (isJSON(rawInput)) {
134
+ const decodedTerminalId = decodeString(rawInput['terminalId']);
135
+ const decodedPasswordHash = decodeString(rawInput['passwordHash']);
136
+ const decodedMode = decodeShareMode(rawInput['mode']);
137
+ const decodedCreatedAt = decodeNumber(rawInput['createdAt']);
138
+ const decodedUpdatedAt = decodeNumber(rawInput['updatedAt']);
139
+
140
+ if (
141
+ decodedTerminalId === null ||
142
+ decodedPasswordHash === null ||
143
+ decodedMode === null ||
144
+ decodedCreatedAt === null ||
145
+ decodedUpdatedAt === null
146
+ ) {
147
+ return null;
148
+ }
149
+
150
+ return {
151
+ terminalId: decodedTerminalId,
152
+ passwordHash: decodedPasswordHash,
153
+ mode: decodedMode,
154
+ createdAt: decodedCreatedAt,
155
+ updatedAt: decodedUpdatedAt,
156
+ };
157
+ }
158
+ return null;
159
+ }
160
+
161
+ /**
162
+ * @type { ShareSessionRecord }
163
+ * @description Persisted guest session (share_sessions table); token stored as sha256 hash
164
+ */
165
+ export type ShareSessionRecord = {
166
+ /**
167
+ * @description sha256 hex of the guest bearer token (primary key)
168
+ * @type { string }
169
+ * @memberof ShareSessionRecord
170
+ */
171
+ tokenHash: string;
172
+ /**
173
+ * @description Terminal the session grants access to
174
+ * @type { string }
175
+ * @memberof ShareSessionRecord
176
+ */
177
+ terminalId: string;
178
+ /**
179
+ * @description Unix timestamp (ms) when the session was created
180
+ * @type { number }
181
+ * @memberof ShareSessionRecord
182
+ */
183
+ createdAt: number;
184
+ /**
185
+ * @description Unix timestamp (ms) when the session expires (created + 7 days)
186
+ * @type { number }
187
+ * @memberof ShareSessionRecord
188
+ */
189
+ expiresAt: number;
190
+ };
191
+
192
+ export function decodeShareSessionRecord(rawInput: unknown): ShareSessionRecord | null {
193
+ if (isJSON(rawInput)) {
194
+ const decodedTokenHash = decodeString(rawInput['tokenHash']);
195
+ const decodedTerminalId = decodeString(rawInput['terminalId']);
196
+ const decodedCreatedAt = decodeNumber(rawInput['createdAt']);
197
+ const decodedExpiresAt = decodeNumber(rawInput['expiresAt']);
198
+
199
+ if (
200
+ decodedTokenHash === null ||
201
+ decodedTerminalId === null ||
202
+ decodedCreatedAt === null ||
203
+ decodedExpiresAt === null
204
+ ) {
205
+ return null;
206
+ }
207
+
208
+ return {
209
+ tokenHash: decodedTokenHash,
210
+ terminalId: decodedTerminalId,
211
+ createdAt: decodedCreatedAt,
212
+ expiresAt: decodedExpiresAt,
213
+ };
214
+ }
215
+ return null;
216
+ }
217
+
218
+ /**
219
+ * @type { ShareInfoResponse }
220
+ * @description Owner view of a terminal's share state (GET /api/terminals/[id]/share)
221
+ */
222
+ export type ShareInfoResponse = {
223
+ /**
224
+ * @description Whether sharing is currently enabled for this terminal
225
+ * @type { boolean }
226
+ * @memberof ShareInfoResponse
227
+ */
228
+ active: boolean;
229
+ /**
230
+ * @description Current access mode (present when active)
231
+ * @type { ShareMode }
232
+ * @memberof ShareInfoResponse
233
+ */
234
+ mode: ShareMode | null;
235
+ /**
236
+ * @description Unix timestamp (ms) when the share was created (present when active)
237
+ * @type { number }
238
+ * @memberof ShareInfoResponse
239
+ */
240
+ createdAt: number | null;
241
+ /**
242
+ * @description Unix timestamp (ms) when the share was last updated (present when active)
243
+ * @type { number }
244
+ * @memberof ShareInfoResponse
245
+ */
246
+ updatedAt: number | null;
247
+ };
248
+
249
+ export function decodeShareInfoResponse(rawInput: unknown): ShareInfoResponse | null {
250
+ if (isJSON(rawInput)) {
251
+ const decodedActive = decodeBoolean(rawInput['active']);
252
+ const decodedMode = decodeShareMode(rawInput['mode']);
253
+ const decodedCreatedAt = decodeNumber(rawInput['createdAt']);
254
+ const decodedUpdatedAt = decodeNumber(rawInput['updatedAt']);
255
+
256
+ if (decodedActive === null) {
257
+ return null;
258
+ }
259
+
260
+ return {
261
+ active: decodedActive,
262
+ mode: decodedMode,
263
+ createdAt: decodedCreatedAt,
264
+ updatedAt: decodedUpdatedAt,
265
+ };
266
+ }
267
+ return null;
268
+ }
269
+
270
+ /**
271
+ * @type { ShareStatusResponse }
272
+ * @description Public probe response (GET /api/terminals/[id]/share/status)
273
+ */
274
+ export type ShareStatusResponse = {
275
+ /**
276
+ * @description Whether a share exists for this terminal
277
+ * @type { boolean }
278
+ * @memberof ShareStatusResponse
279
+ */
280
+ shared: boolean;
281
+ };
282
+
283
+ export function decodeShareStatusResponse(rawInput: unknown): ShareStatusResponse | null {
284
+ if (isJSON(rawInput)) {
285
+ const decodedShared = decodeBoolean(rawInput['shared']);
286
+
287
+ if (decodedShared === null) {
288
+ return null;
289
+ }
290
+
291
+ return {
292
+ shared: decodedShared,
293
+ };
294
+ }
295
+ return null;
296
+ }
297
+
298
+ /**
299
+ * @type { ShareAuthRequest }
300
+ * @description Guest password exchange request (POST /api/terminals/[id]/share/auth)
301
+ */
302
+ export type ShareAuthRequest = {
303
+ /**
304
+ * @description The share password
305
+ * @type { string }
306
+ * @memberof ShareAuthRequest
307
+ */
308
+ password: string;
309
+ };
310
+
311
+ export function decodeShareAuthRequest(rawInput: unknown): ShareAuthRequest | null {
312
+ if (isJSON(rawInput)) {
313
+ const decodedPassword = decodeString(rawInput['password']);
314
+
315
+ if (decodedPassword === null) {
316
+ return null;
317
+ }
318
+
319
+ return {
320
+ password: decodedPassword,
321
+ };
322
+ }
323
+ return null;
324
+ }
325
+
326
+ /**
327
+ * @type { ShareAuthResponse }
328
+ * @description Guest session issued after successful password exchange
329
+ */
330
+ export type ShareAuthResponse = {
331
+ /**
332
+ * @description Guest bearer token (64-char hex, shown once)
333
+ * @type { string }
334
+ * @memberof ShareAuthResponse
335
+ */
336
+ token: string;
337
+ /**
338
+ * @description Access mode granted by this session
339
+ * @type { ShareMode }
340
+ * @memberof ShareAuthResponse
341
+ */
342
+ mode: ShareMode;
343
+ /**
344
+ * @description Unix timestamp (ms) when this session expires
345
+ * @type { number }
346
+ * @memberof ShareAuthResponse
347
+ */
348
+ expiresAt: number;
349
+ };
350
+
351
+ export function decodeShareAuthResponse(rawInput: unknown): ShareAuthResponse | null {
352
+ if (isJSON(rawInput)) {
353
+ const decodedToken = decodeString(rawInput['token']);
354
+ const decodedMode = decodeShareMode(rawInput['mode']);
355
+ const decodedExpiresAt = decodeNumber(rawInput['expiresAt']);
356
+
357
+ if (decodedToken === null || decodedMode === null || decodedExpiresAt === null) {
358
+ return null;
359
+ }
360
+
361
+ return {
362
+ token: decodedToken,
363
+ mode: decodedMode,
364
+ expiresAt: decodedExpiresAt,
365
+ };
366
+ }
367
+ return null;
368
+ }
369
+
370
+ /**
371
+ * @type { ShareConfigRequest }
372
+ * @description Owner create/update share request (PUT /api/terminals/[id]/share)
373
+ */
374
+ export type ShareConfigRequest = {
375
+ /**
376
+ * @description New share password (min 6 chars; required on create, optional on update)
377
+ * @type { string }
378
+ * @memberof ShareConfigRequest
379
+ */
380
+ password: string | null;
381
+ /**
382
+ * @description Access mode to grant guests
383
+ * @type { ShareMode }
384
+ * @memberof ShareConfigRequest
385
+ */
386
+ mode: ShareMode;
387
+ };
388
+
389
+ export function decodeShareConfigRequest(rawInput: unknown): ShareConfigRequest | null {
390
+ if (isJSON(rawInput)) {
391
+ const decodedPassword = decodeString(rawInput['password']);
392
+ const decodedMode = decodeShareMode(rawInput['mode']);
393
+
394
+ if (decodedMode === null) {
395
+ return null;
396
+ }
397
+
398
+ return {
399
+ password: decodedPassword,
400
+ mode: decodedMode,
401
+ };
402
+ }
403
+ return null;
404
+ }
@@ -435,7 +435,8 @@ export type TerminalServerMessage =
435
435
  | CTerminalServerMessageTerminalOutputDroppedMessage
436
436
  | CTerminalServerMessageTerminalScrollbackMessage
437
437
  | CTerminalServerMessageTerminalExitMessage
438
- | CTerminalServerMessageTerminalErrorMessage;
438
+ | CTerminalServerMessageTerminalErrorMessage
439
+ | CTerminalServerMessageTerminalResizeMessage;
439
440
 
440
441
  export function decodeTerminalServerMessage(rawInput: unknown): TerminalServerMessage | null {
441
442
  const result: TerminalServerMessage | null =
@@ -443,7 +444,8 @@ export function decodeTerminalServerMessage(rawInput: unknown): TerminalServerMe
443
444
  decodeCTerminalServerMessageTerminalOutputDroppedMessage(rawInput) ??
444
445
  decodeCTerminalServerMessageTerminalScrollbackMessage(rawInput) ??
445
446
  decodeCTerminalServerMessageTerminalExitMessage(rawInput) ??
446
- decodeCTerminalServerMessageTerminalErrorMessage(rawInput);
447
+ decodeCTerminalServerMessageTerminalErrorMessage(rawInput) ??
448
+ decodeCTerminalServerMessageTerminalResizeMessage(rawInput);
447
449
 
448
450
  return result;
449
451
  }
@@ -533,6 +535,23 @@ export function decodeCTerminalServerMessageTerminalErrorMessage(
533
535
  return new CTerminalServerMessageTerminalErrorMessage(result);
534
536
  }
535
537
 
538
+ export class CTerminalServerMessageTerminalResizeMessage {
539
+ data: TerminalResizeMessage;
540
+ constructor(data: TerminalResizeMessage) {
541
+ this.data = data;
542
+ }
543
+ }
544
+
545
+ export function decodeCTerminalServerMessageTerminalResizeMessage(
546
+ rawInput: unknown
547
+ ): CTerminalServerMessageTerminalResizeMessage | null {
548
+ const result = decodeTerminalResizeMessage(rawInput);
549
+ if (result === null) {
550
+ return null;
551
+ }
552
+ return new CTerminalServerMessageTerminalResizeMessage(result);
553
+ }
554
+
536
555
  /**
537
556
  * @type { TextContentBlock }
538
557
  * @description Content block in the live 'message' payload
@@ -2326,12 +2345,26 @@ export type Ticket = {
2326
2345
  * @memberof Ticket
2327
2346
  */
2328
2347
  used: boolean;
2348
+ /**
2349
+ * @description When set, the ticket may only open WS channels for this terminal
2350
+ * @type { string }
2351
+ * @memberof Ticket
2352
+ */
2353
+ terminalId: string | null;
2354
+ /**
2355
+ * @description When true, input/resize/signal/send-input/cancel frames are dropped
2356
+ * @type { boolean }
2357
+ * @memberof Ticket
2358
+ */
2359
+ readOnly: boolean | null;
2329
2360
  };
2330
2361
 
2331
2362
  export function decodeTicket(rawInput: unknown): Ticket | null {
2332
2363
  if (isJSON(rawInput)) {
2333
2364
  const decodedCreatedAt = decodeNumber(rawInput['createdAt']);
2334
2365
  const decodedUsed = decodeBoolean(rawInput['used']);
2366
+ const decodedTerminalId = decodeString(rawInput['terminalId']);
2367
+ const decodedReadOnly = decodeBoolean(rawInput['readOnly']);
2335
2368
 
2336
2369
  if (decodedCreatedAt === null || decodedUsed === null) {
2337
2370
  return null;
@@ -2340,6 +2373,44 @@ export function decodeTicket(rawInput: unknown): Ticket | null {
2340
2373
  return {
2341
2374
  createdAt: decodedCreatedAt,
2342
2375
  used: decodedUsed,
2376
+ terminalId: decodedTerminalId,
2377
+ readOnly: decodedReadOnly,
2378
+ };
2379
+ }
2380
+ return null;
2381
+ }
2382
+
2383
+ /**
2384
+ * @type { TicketScope }
2385
+ * @description Scope restriction carried by a guest WebSocket ticket
2386
+ */
2387
+ export type TicketScope = {
2388
+ /**
2389
+ * @description Only WS channels for this terminal may be opened
2390
+ * @type { string }
2391
+ * @memberof TicketScope
2392
+ */
2393
+ terminalId: string;
2394
+ /**
2395
+ * @description Whether the connection is view-only (input frames dropped)
2396
+ * @type { boolean }
2397
+ * @memberof TicketScope
2398
+ */
2399
+ readOnly: boolean;
2400
+ };
2401
+
2402
+ export function decodeTicketScope(rawInput: unknown): TicketScope | null {
2403
+ if (isJSON(rawInput)) {
2404
+ const decodedTerminalId = decodeString(rawInput['terminalId']);
2405
+ const decodedReadOnly = decodeBoolean(rawInput['readOnly']);
2406
+
2407
+ if (decodedTerminalId === null || decodedReadOnly === null) {
2408
+ return null;
2409
+ }
2410
+
2411
+ return {
2412
+ terminalId: decodedTerminalId,
2413
+ readOnly: decodedReadOnly,
2343
2414
  };
2344
2415
  }
2345
2416
  return null;
@@ -10,3 +10,4 @@ export * from './OpenCode';
10
10
  export * from './Notification';
11
11
  export * from './Client';
12
12
  export * from './Config';
13
+ export * from './Share';
@@ -3,6 +3,7 @@
3
3
 
4
4
  export type * from './activity';
5
5
  export type * from './apn';
6
+ export type * from './autopilot';
6
7
  export type * from './cli';
7
8
  export type * from './codex';
8
9
  export type * from './common';
@@ -56,6 +56,8 @@ export interface LaunchSheetProps {
56
56
 
57
57
  export interface LayoutData {
58
58
  aiProviders: Record<string, boolean>;
59
+ litellmBaseUrl: string;
60
+ litellmModel: string;
59
61
  neurolinkProvider: string;
60
62
  }
61
63
 
@@ -80,12 +82,24 @@ export interface QuickKeysProps {
80
82
 
81
83
  // --- keyboard-shortcuts types ---
82
84
 
83
- export interface ShortcutManagerOptions {
84
- onHelp: () => void;
85
+ export interface ShareGateProps {
86
+ /** Returns an error message to display, or null on success. */
87
+ onSubmit: (password: string) => Promise<null | string>;
85
88
  }
86
89
 
87
90
  // --- xterm-wrapper types ---
88
91
 
92
+ export interface ShareSheetProps {
93
+ onClose: () => void;
94
+ open?: boolean;
95
+ shareUrl: string;
96
+ terminalId: string;
97
+ }
98
+
99
+ export interface ShortcutManagerOptions {
100
+ onHelp: () => void;
101
+ }
102
+
89
103
  export interface ShortcutsHelpProps {
90
104
  onClose: () => void;
91
105
  open: boolean;
@@ -105,11 +119,14 @@ export interface TerminalOptions {
105
119
  container: HTMLElement;
106
120
  fontSize?: number;
107
121
  getTicket: () => Promise<string>;
122
+ initialCols?: number;
123
+ initialRows?: number;
108
124
  onActivity?: (active: boolean) => void;
109
125
  onCwd?: (path: string) => void;
110
126
  onDisconnect?: () => void;
111
127
  onExit?: (code: number) => void;
112
128
  onReconnect?: () => void;
129
+ readOnly?: boolean;
113
130
  terminalId?: string;
114
131
  wsUrl: string;
115
132
  }
@@ -126,7 +143,9 @@ export interface WsTerminalInboundMessage {
126
143
  active?: boolean;
127
144
  bytes?: number;
128
145
  code?: number;
146
+ cols?: number;
129
147
  data?: string;
130
148
  path?: string;
149
+ rows?: number;
131
150
  type: string;
132
151
  }