@ck123pm/paseo-server 0.1.80

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 (1077) hide show
  1. package/.env.example +23 -0
  2. package/README.md +111 -0
  3. package/dist/scripts/dev-runner.js +49 -0
  4. package/dist/scripts/dev-runner.js.map +1 -0
  5. package/dist/scripts/mcp-stdio-socket-bridge-cli.mjs +62 -0
  6. package/dist/scripts/supervisor-entrypoint.js +126 -0
  7. package/dist/scripts/supervisor-entrypoint.js.map +1 -0
  8. package/dist/scripts/supervisor-log-config.js +31 -0
  9. package/dist/scripts/supervisor-log-config.js.map +1 -0
  10. package/dist/scripts/supervisor.js +213 -0
  11. package/dist/scripts/supervisor.js.map +1 -0
  12. package/dist/server/client/daemon-client-relay-e2ee-transport.d.ts +8 -0
  13. package/dist/server/client/daemon-client-relay-e2ee-transport.d.ts.map +1 -0
  14. package/dist/server/client/daemon-client-relay-e2ee-transport.js +161 -0
  15. package/dist/server/client/daemon-client-relay-e2ee-transport.js.map +1 -0
  16. package/dist/server/client/daemon-client-runtime-metrics.d.ts +39 -0
  17. package/dist/server/client/daemon-client-runtime-metrics.d.ts.map +1 -0
  18. package/dist/server/client/daemon-client-runtime-metrics.js +173 -0
  19. package/dist/server/client/daemon-client-runtime-metrics.js.map +1 -0
  20. package/dist/server/client/daemon-client-transport-types.d.ts +36 -0
  21. package/dist/server/client/daemon-client-transport-types.d.ts.map +1 -0
  22. package/dist/server/client/daemon-client-transport-types.js +2 -0
  23. package/dist/server/client/daemon-client-transport-types.js.map +1 -0
  24. package/dist/server/client/daemon-client-transport-utils.d.ts +9 -0
  25. package/dist/server/client/daemon-client-transport-utils.d.ts.map +1 -0
  26. package/dist/server/client/daemon-client-transport-utils.js +121 -0
  27. package/dist/server/client/daemon-client-transport-utils.js.map +1 -0
  28. package/dist/server/client/daemon-client-transport.d.ts +5 -0
  29. package/dist/server/client/daemon-client-transport.d.ts.map +1 -0
  30. package/dist/server/client/daemon-client-transport.js +4 -0
  31. package/dist/server/client/daemon-client-transport.js.map +1 -0
  32. package/dist/server/client/daemon-client-websocket-transport.d.ts +8 -0
  33. package/dist/server/client/daemon-client-websocket-transport.d.ts.map +1 -0
  34. package/dist/server/client/daemon-client-websocket-transport.js +120 -0
  35. package/dist/server/client/daemon-client-websocket-transport.js.map +1 -0
  36. package/dist/server/client/daemon-client.d.ts +862 -0
  37. package/dist/server/client/daemon-client.d.ts.map +1 -0
  38. package/dist/server/client/daemon-client.js +3376 -0
  39. package/dist/server/client/daemon-client.js.map +1 -0
  40. package/dist/server/client/terminal-stream-router.d.ts +24 -0
  41. package/dist/server/client/terminal-stream-router.d.ts.map +1 -0
  42. package/dist/server/client/terminal-stream-router.js +100 -0
  43. package/dist/server/client/terminal-stream-router.js.map +1 -0
  44. package/dist/server/server/agent/activity-curator.d.ts +11 -0
  45. package/dist/server/server/agent/activity-curator.d.ts.map +1 -0
  46. package/dist/server/server/agent/activity-curator.js +150 -0
  47. package/dist/server/server/agent/activity-curator.js.map +1 -0
  48. package/dist/server/server/agent/agent-archive.d.ts +11 -0
  49. package/dist/server/server/agent/agent-archive.d.ts.map +1 -0
  50. package/dist/server/server/agent/agent-archive.js +16 -0
  51. package/dist/server/server/agent/agent-archive.js.map +1 -0
  52. package/dist/server/server/agent/agent-loading.d.ts +12 -0
  53. package/dist/server/server/agent/agent-loading.d.ts.map +1 -0
  54. package/dist/server/server/agent/agent-loading.js +51 -0
  55. package/dist/server/server/agent/agent-loading.js.map +1 -0
  56. package/dist/server/server/agent/agent-manager.d.ts +342 -0
  57. package/dist/server/server/agent/agent-manager.d.ts.map +1 -0
  58. package/dist/server/server/agent/agent-manager.js +2572 -0
  59. package/dist/server/server/agent/agent-manager.js.map +1 -0
  60. package/dist/server/server/agent/agent-metadata-generator.d.ts +27 -0
  61. package/dist/server/server/agent/agent-metadata-generator.d.ts.map +1 -0
  62. package/dist/server/server/agent/agent-metadata-generator.js +104 -0
  63. package/dist/server/server/agent/agent-metadata-generator.js.map +1 -0
  64. package/dist/server/server/agent/agent-projections.d.ts +24 -0
  65. package/dist/server/server/agent/agent-projections.d.ts.map +1 -0
  66. package/dist/server/server/agent/agent-projections.js +406 -0
  67. package/dist/server/server/agent/agent-projections.js.map +1 -0
  68. package/dist/server/server/agent/agent-prompt.d.ts +72 -0
  69. package/dist/server/server/agent/agent-prompt.d.ts.map +1 -0
  70. package/dist/server/server/agent/agent-prompt.js +196 -0
  71. package/dist/server/server/agent/agent-prompt.js.map +1 -0
  72. package/dist/server/server/agent/agent-response-loop.d.ts +62 -0
  73. package/dist/server/server/agent/agent-response-loop.d.ts.map +1 -0
  74. package/dist/server/server/agent/agent-response-loop.js +321 -0
  75. package/dist/server/server/agent/agent-response-loop.js.map +1 -0
  76. package/dist/server/server/agent/agent-sdk-types.d.ts +540 -0
  77. package/dist/server/server/agent/agent-sdk-types.d.ts.map +1 -0
  78. package/dist/server/server/agent/agent-sdk-types.js +22 -0
  79. package/dist/server/server/agent/agent-sdk-types.js.map +1 -0
  80. package/dist/server/server/agent/agent-storage.d.ts +346 -0
  81. package/dist/server/server/agent/agent-storage.d.ts.map +1 -0
  82. package/dist/server/server/agent/agent-storage.js +340 -0
  83. package/dist/server/server/agent/agent-storage.js.map +1 -0
  84. package/dist/server/server/agent/agent-stream-coalescer.d.ts +41 -0
  85. package/dist/server/server/agent/agent-stream-coalescer.d.ts.map +1 -0
  86. package/dist/server/server/agent/agent-stream-coalescer.js +166 -0
  87. package/dist/server/server/agent/agent-stream-coalescer.js.map +1 -0
  88. package/dist/server/server/agent/agent-timeline-store-types.d.ts +54 -0
  89. package/dist/server/server/agent/agent-timeline-store-types.d.ts.map +1 -0
  90. package/dist/server/server/agent/agent-timeline-store-types.js +2 -0
  91. package/dist/server/server/agent/agent-timeline-store-types.js.map +1 -0
  92. package/dist/server/server/agent/agent-timeline-store.d.ts +32 -0
  93. package/dist/server/server/agent/agent-timeline-store.d.ts.map +1 -0
  94. package/dist/server/server/agent/agent-timeline-store.js +263 -0
  95. package/dist/server/server/agent/agent-timeline-store.js.map +1 -0
  96. package/dist/server/server/agent/agent-title-limits.d.ts +3 -0
  97. package/dist/server/server/agent/agent-title-limits.d.ts.map +1 -0
  98. package/dist/server/server/agent/agent-title-limits.js +3 -0
  99. package/dist/server/server/agent/agent-title-limits.js.map +1 -0
  100. package/dist/server/server/agent/audio-utils.d.ts +3 -0
  101. package/dist/server/server/agent/audio-utils.d.ts.map +1 -0
  102. package/dist/server/server/agent/audio-utils.js +19 -0
  103. package/dist/server/server/agent/audio-utils.js.map +1 -0
  104. package/dist/server/server/agent/create-agent-mode.d.ts +16 -0
  105. package/dist/server/server/agent/create-agent-mode.d.ts.map +1 -0
  106. package/dist/server/server/agent/create-agent-mode.js +26 -0
  107. package/dist/server/server/agent/create-agent-mode.js.map +1 -0
  108. package/dist/server/server/agent/create-agent-title.d.ts +8 -0
  109. package/dist/server/server/agent/create-agent-title.d.ts.map +1 -0
  110. package/dist/server/server/agent/create-agent-title.js +29 -0
  111. package/dist/server/server/agent/create-agent-title.js.map +1 -0
  112. package/dist/server/server/agent/dictation-debug.d.ts +13 -0
  113. package/dist/server/server/agent/dictation-debug.d.ts.map +1 -0
  114. package/dist/server/server/agent/dictation-debug.js +50 -0
  115. package/dist/server/server/agent/dictation-debug.js.map +1 -0
  116. package/dist/server/server/agent/foreground-run-state.d.ts +50 -0
  117. package/dist/server/server/agent/foreground-run-state.d.ts.map +1 -0
  118. package/dist/server/server/agent/foreground-run-state.js +160 -0
  119. package/dist/server/server/agent/foreground-run-state.js.map +1 -0
  120. package/dist/server/server/agent/import-sessions.d.ts +52 -0
  121. package/dist/server/server/agent/import-sessions.d.ts.map +1 -0
  122. package/dist/server/server/agent/import-sessions.js +212 -0
  123. package/dist/server/server/agent/import-sessions.js.map +1 -0
  124. package/dist/server/server/agent/mcp-server.d.ts +46 -0
  125. package/dist/server/server/agent/mcp-server.d.ts.map +1 -0
  126. package/dist/server/server/agent/mcp-server.js +1962 -0
  127. package/dist/server/server/agent/mcp-server.js.map +1 -0
  128. package/dist/server/server/agent/mcp-shared.d.ts +316 -0
  129. package/dist/server/server/agent/mcp-shared.d.ts.map +1 -0
  130. package/dist/server/server/agent/mcp-shared.js +194 -0
  131. package/dist/server/server/agent/mcp-shared.js.map +1 -0
  132. package/dist/server/server/agent/model-resolver.d.ts +11 -0
  133. package/dist/server/server/agent/model-resolver.d.ts.map +1 -0
  134. package/dist/server/server/agent/model-resolver.js +27 -0
  135. package/dist/server/server/agent/model-resolver.js.map +1 -0
  136. package/dist/server/server/agent/pcm16-resampler.d.ts +14 -0
  137. package/dist/server/server/agent/pcm16-resampler.d.ts.map +1 -0
  138. package/dist/server/server/agent/pcm16-resampler.js +63 -0
  139. package/dist/server/server/agent/pcm16-resampler.js.map +1 -0
  140. package/dist/server/server/agent/prompt-attachments.d.ts +7 -0
  141. package/dist/server/server/agent/prompt-attachments.d.ts.map +1 -0
  142. package/dist/server/server/agent/prompt-attachments.js +72 -0
  143. package/dist/server/server/agent/prompt-attachments.js.map +1 -0
  144. package/dist/server/server/agent/provider-history-timestamps.d.ts +2 -0
  145. package/dist/server/server/agent/provider-history-timestamps.d.ts.map +1 -0
  146. package/dist/server/server/agent/provider-history-timestamps.js +16 -0
  147. package/dist/server/server/agent/provider-history-timestamps.js.map +1 -0
  148. package/dist/server/server/agent/provider-launch-config.d.ts +368 -0
  149. package/dist/server/server/agent/provider-launch-config.d.ts.map +1 -0
  150. package/dist/server/server/agent/provider-launch-config.js +190 -0
  151. package/dist/server/server/agent/provider-launch-config.js.map +1 -0
  152. package/dist/server/server/agent/provider-manifest.d.ts +33 -0
  153. package/dist/server/server/agent/provider-manifest.d.ts.map +1 -0
  154. package/dist/server/server/agent/provider-manifest.js +211 -0
  155. package/dist/server/server/agent/provider-manifest.js.map +1 -0
  156. package/dist/server/server/agent/provider-registry.d.ts +33 -0
  157. package/dist/server/server/agent/provider-registry.d.ts.map +1 -0
  158. package/dist/server/server/agent/provider-registry.js +396 -0
  159. package/dist/server/server/agent/provider-registry.js.map +1 -0
  160. package/dist/server/server/agent/provider-snapshot-manager.d.ts +49 -0
  161. package/dist/server/server/agent/provider-snapshot-manager.d.ts.map +1 -0
  162. package/dist/server/server/agent/provider-snapshot-manager.js +348 -0
  163. package/dist/server/server/agent/provider-snapshot-manager.js.map +1 -0
  164. package/dist/server/server/agent/providers/acp-agent.d.ts +286 -0
  165. package/dist/server/server/agent/providers/acp-agent.d.ts.map +1 -0
  166. package/dist/server/server/agent/providers/acp-agent.js +2070 -0
  167. package/dist/server/server/agent/providers/acp-agent.js.map +1 -0
  168. package/dist/server/server/agent/providers/claude/agent.d.ts +60 -0
  169. package/dist/server/server/agent/providers/claude/agent.d.ts.map +1 -0
  170. package/dist/server/server/agent/providers/claude/agent.js +3815 -0
  171. package/dist/server/server/agent/providers/claude/agent.js.map +1 -0
  172. package/dist/server/server/agent/providers/claude/models.d.ts +10 -0
  173. package/dist/server/server/agent/providers/claude/models.d.ts.map +1 -0
  174. package/dist/server/server/agent/providers/claude/models.js +170 -0
  175. package/dist/server/server/agent/providers/claude/models.js.map +1 -0
  176. package/dist/server/server/agent/providers/claude/partial-json.d.ts +5 -0
  177. package/dist/server/server/agent/providers/claude/partial-json.d.ts.map +1 -0
  178. package/dist/server/server/agent/providers/claude/partial-json.js +306 -0
  179. package/dist/server/server/agent/providers/claude/partial-json.js.map +1 -0
  180. package/dist/server/server/agent/providers/claude/project-dir.d.ts +5 -0
  181. package/dist/server/server/agent/providers/claude/project-dir.d.ts.map +1 -0
  182. package/dist/server/server/agent/providers/claude/project-dir.js +40 -0
  183. package/dist/server/server/agent/providers/claude/project-dir.js.map +1 -0
  184. package/dist/server/server/agent/providers/claude/query.d.ts +14 -0
  185. package/dist/server/server/agent/providers/claude/query.d.ts.map +1 -0
  186. package/dist/server/server/agent/providers/claude/query.js +84 -0
  187. package/dist/server/server/agent/providers/claude/query.js.map +1 -0
  188. package/dist/server/server/agent/providers/claude/sidechain-tracker.d.ts +22 -0
  189. package/dist/server/server/agent/providers/claude/sidechain-tracker.d.ts.map +1 -0
  190. package/dist/server/server/agent/providers/claude/sidechain-tracker.js +232 -0
  191. package/dist/server/server/agent/providers/claude/sidechain-tracker.js.map +1 -0
  192. package/dist/server/server/agent/providers/claude/task-notification-tool-call.d.ts +55 -0
  193. package/dist/server/server/agent/providers/claude/task-notification-tool-call.d.ts.map +1 -0
  194. package/dist/server/server/agent/providers/claude/task-notification-tool-call.js +272 -0
  195. package/dist/server/server/agent/providers/claude/task-notification-tool-call.js.map +1 -0
  196. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.d.ts +3 -0
  197. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.d.ts.map +1 -0
  198. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.js +130 -0
  199. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.js.map +1 -0
  200. package/dist/server/server/agent/providers/claude/tool-call-mapper.d.ts +16 -0
  201. package/dist/server/server/agent/providers/claude/tool-call-mapper.d.ts.map +1 -0
  202. package/dist/server/server/agent/providers/claude/tool-call-mapper.js +129 -0
  203. package/dist/server/server/agent/providers/claude/tool-call-mapper.js.map +1 -0
  204. package/dist/server/server/agent/providers/codex/app-server-transport.d.ts +32 -0
  205. package/dist/server/server/agent/providers/codex/app-server-transport.d.ts.map +1 -0
  206. package/dist/server/server/agent/providers/codex/app-server-transport.js +214 -0
  207. package/dist/server/server/agent/providers/codex/app-server-transport.js.map +1 -0
  208. package/dist/server/server/agent/providers/codex/test-utils/fake-app-server.d.ts +31 -0
  209. package/dist/server/server/agent/providers/codex/test-utils/fake-app-server.d.ts.map +1 -0
  210. package/dist/server/server/agent/providers/codex/test-utils/fake-app-server.js +172 -0
  211. package/dist/server/server/agent/providers/codex/test-utils/fake-app-server.js.map +1 -0
  212. package/dist/server/server/agent/providers/codex/tool-call-detail-parser.d.ts +12 -0
  213. package/dist/server/server/agent/providers/codex/tool-call-detail-parser.d.ts.map +1 -0
  214. package/dist/server/server/agent/providers/codex/tool-call-detail-parser.js +104 -0
  215. package/dist/server/server/agent/providers/codex/tool-call-detail-parser.js.map +1 -0
  216. package/dist/server/server/agent/providers/codex/tool-call-mapper.d.ts +15 -0
  217. package/dist/server/server/agent/providers/codex/tool-call-mapper.d.ts.map +1 -0
  218. package/dist/server/server/agent/providers/codex/tool-call-mapper.js +791 -0
  219. package/dist/server/server/agent/providers/codex/tool-call-mapper.js.map +1 -0
  220. package/dist/server/server/agent/providers/codex-app-server-agent.d.ts +307 -0
  221. package/dist/server/server/agent/providers/codex-app-server-agent.d.ts.map +1 -0
  222. package/dist/server/server/agent/providers/codex-app-server-agent.js +4364 -0
  223. package/dist/server/server/agent/providers/codex-app-server-agent.js.map +1 -0
  224. package/dist/server/server/agent/providers/codex-feature-definitions.d.ts +11 -0
  225. package/dist/server/server/agent/providers/codex-feature-definitions.d.ts.map +1 -0
  226. package/dist/server/server/agent/providers/codex-feature-definitions.js +45 -0
  227. package/dist/server/server/agent/providers/codex-feature-definitions.js.map +1 -0
  228. package/dist/server/server/agent/providers/codex-rollout-timeline.d.ts +9 -0
  229. package/dist/server/server/agent/providers/codex-rollout-timeline.d.ts.map +1 -0
  230. package/dist/server/server/agent/providers/codex-rollout-timeline.js +555 -0
  231. package/dist/server/server/agent/providers/codex-rollout-timeline.js.map +1 -0
  232. package/dist/server/server/agent/providers/copilot-acp-agent.d.ts +25 -0
  233. package/dist/server/server/agent/providers/copilot-acp-agent.d.ts.map +1 -0
  234. package/dist/server/server/agent/providers/copilot-acp-agent.js +203 -0
  235. package/dist/server/server/agent/providers/copilot-acp-agent.js.map +1 -0
  236. package/dist/server/server/agent/providers/cursor-acp-agent.d.ts +21 -0
  237. package/dist/server/server/agent/providers/cursor-acp-agent.d.ts.map +1 -0
  238. package/dist/server/server/agent/providers/cursor-acp-agent.js +95 -0
  239. package/dist/server/server/agent/providers/cursor-acp-agent.js.map +1 -0
  240. package/dist/server/server/agent/providers/diagnostic-utils.d.ts +17 -0
  241. package/dist/server/server/agent/providers/diagnostic-utils.d.ts.map +1 -0
  242. package/dist/server/server/agent/providers/diagnostic-utils.js +127 -0
  243. package/dist/server/server/agent/providers/diagnostic-utils.js.map +1 -0
  244. package/dist/server/server/agent/providers/generic-acp-agent.d.ts +33 -0
  245. package/dist/server/server/agent/providers/generic-acp-agent.d.ts.map +1 -0
  246. package/dist/server/server/agent/providers/generic-acp-agent.js +234 -0
  247. package/dist/server/server/agent/providers/generic-acp-agent.js.map +1 -0
  248. package/dist/server/server/agent/providers/mock-load-test-agent.d.ts +68 -0
  249. package/dist/server/server/agent/providers/mock-load-test-agent.d.ts.map +1 -0
  250. package/dist/server/server/agent/providers/mock-load-test-agent.js +770 -0
  251. package/dist/server/server/agent/providers/mock-load-test-agent.js.map +1 -0
  252. package/dist/server/server/agent/providers/opencode/runtime.d.ts +27 -0
  253. package/dist/server/server/agent/providers/opencode/runtime.d.ts.map +1 -0
  254. package/dist/server/server/agent/providers/opencode/runtime.js +5 -0
  255. package/dist/server/server/agent/providers/opencode/runtime.js.map +1 -0
  256. package/dist/server/server/agent/providers/opencode/server-manager.d.ts +55 -0
  257. package/dist/server/server/agent/providers/opencode/server-manager.d.ts.map +1 -0
  258. package/dist/server/server/agent/providers/opencode/server-manager.js +256 -0
  259. package/dist/server/server/agent/providers/opencode/server-manager.js.map +1 -0
  260. package/dist/server/server/agent/providers/opencode/test-server-manager.d.ts +22 -0
  261. package/dist/server/server/agent/providers/opencode/test-server-manager.d.ts.map +1 -0
  262. package/dist/server/server/agent/providers/opencode/test-server-manager.js +28 -0
  263. package/dist/server/server/agent/providers/opencode/test-server-manager.js.map +1 -0
  264. package/dist/server/server/agent/providers/opencode/test-utils/test-opencode-runtime.d.ts +83 -0
  265. package/dist/server/server/agent/providers/opencode/test-utils/test-opencode-runtime.d.ts.map +1 -0
  266. package/dist/server/server/agent/providers/opencode/test-utils/test-opencode-runtime.js +225 -0
  267. package/dist/server/server/agent/providers/opencode/test-utils/test-opencode-runtime.js.map +1 -0
  268. package/dist/server/server/agent/providers/opencode/tool-call-detail-parser.d.ts +3 -0
  269. package/dist/server/server/agent/providers/opencode/tool-call-detail-parser.d.ts.map +1 -0
  270. package/dist/server/server/agent/providers/opencode/tool-call-detail-parser.js +131 -0
  271. package/dist/server/server/agent/providers/opencode/tool-call-detail-parser.js.map +1 -0
  272. package/dist/server/server/agent/providers/opencode/tool-call-mapper.d.ts +13 -0
  273. package/dist/server/server/agent/providers/opencode/tool-call-mapper.d.ts.map +1 -0
  274. package/dist/server/server/agent/providers/opencode/tool-call-mapper.js +53 -0
  275. package/dist/server/server/agent/providers/opencode/tool-call-mapper.js.map +1 -0
  276. package/dist/server/server/agent/providers/opencode-agent.d.ts +231 -0
  277. package/dist/server/server/agent/providers/opencode-agent.d.ts.map +1 -0
  278. package/dist/server/server/agent/providers/opencode-agent.js +2443 -0
  279. package/dist/server/server/agent/providers/opencode-agent.js.map +1 -0
  280. package/dist/server/server/agent/providers/pi/agent.d.ts +84 -0
  281. package/dist/server/server/agent/providers/pi/agent.d.ts.map +1 -0
  282. package/dist/server/server/agent/providers/pi/agent.js +828 -0
  283. package/dist/server/server/agent/providers/pi/agent.js.map +1 -0
  284. package/dist/server/server/agent/providers/pi/cli-runtime.d.ts +18 -0
  285. package/dist/server/server/agent/providers/pi/cli-runtime.d.ts.map +1 -0
  286. package/dist/server/server/agent/providers/pi/cli-runtime.js +211 -0
  287. package/dist/server/server/agent/providers/pi/cli-runtime.js.map +1 -0
  288. package/dist/server/server/agent/providers/pi/history-mapper.d.ts +5 -0
  289. package/dist/server/server/agent/providers/pi/history-mapper.d.ts.map +1 -0
  290. package/dist/server/server/agent/providers/pi/history-mapper.js +139 -0
  291. package/dist/server/server/agent/providers/pi/history-mapper.js.map +1 -0
  292. package/dist/server/server/agent/providers/pi/rpc-types.d.ts +185 -0
  293. package/dist/server/server/agent/providers/pi/rpc-types.d.ts.map +1 -0
  294. package/dist/server/server/agent/providers/pi/rpc-types.js +2 -0
  295. package/dist/server/server/agent/providers/pi/rpc-types.js.map +1 -0
  296. package/dist/server/server/agent/providers/pi/runtime.d.ts +47 -0
  297. package/dist/server/server/agent/providers/pi/runtime.d.ts.map +1 -0
  298. package/dist/server/server/agent/providers/pi/runtime.js +47 -0
  299. package/dist/server/server/agent/providers/pi/runtime.js.map +1 -0
  300. package/dist/server/server/agent/providers/pi/session-descriptor.d.ts +10 -0
  301. package/dist/server/server/agent/providers/pi/session-descriptor.d.ts.map +1 -0
  302. package/dist/server/server/agent/providers/pi/session-descriptor.js +300 -0
  303. package/dist/server/server/agent/providers/pi/session-descriptor.js.map +1 -0
  304. package/dist/server/server/agent/providers/pi/test-utils/fake-pi.d.ts +52 -0
  305. package/dist/server/server/agent/providers/pi/test-utils/fake-pi.d.ts.map +1 -0
  306. package/dist/server/server/agent/providers/pi/test-utils/fake-pi.js +109 -0
  307. package/dist/server/server/agent/providers/pi/test-utils/fake-pi.js.map +1 -0
  308. package/dist/server/server/agent/providers/pi/tool-call-mapper.d.ts +112 -0
  309. package/dist/server/server/agent/providers/pi/tool-call-mapper.d.ts.map +1 -0
  310. package/dist/server/server/agent/providers/pi/tool-call-mapper.js +284 -0
  311. package/dist/server/server/agent/providers/pi/tool-call-mapper.js.map +1 -0
  312. package/dist/server/server/agent/providers/provider-image-output.d.ts +20 -0
  313. package/dist/server/server/agent/providers/provider-image-output.d.ts.map +1 -0
  314. package/dist/server/server/agent/providers/provider-image-output.js +51 -0
  315. package/dist/server/server/agent/providers/provider-image-output.js.map +1 -0
  316. package/dist/server/server/agent/providers/provider-runner.d.ts +27 -0
  317. package/dist/server/server/agent/providers/provider-runner.d.ts.map +1 -0
  318. package/dist/server/server/agent/providers/provider-runner.js +81 -0
  319. package/dist/server/server/agent/providers/provider-runner.js.map +1 -0
  320. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.d.ts +3 -0
  321. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.d.ts.map +1 -0
  322. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.js +60 -0
  323. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.js.map +1 -0
  324. package/dist/server/server/agent/providers/tool-call-detail-primitives.d.ts +1751 -0
  325. package/dist/server/server/agent/providers/tool-call-detail-primitives.d.ts.map +1 -0
  326. package/dist/server/server/agent/providers/tool-call-detail-primitives.js +709 -0
  327. package/dist/server/server/agent/providers/tool-call-detail-primitives.js.map +1 -0
  328. package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts +20 -0
  329. package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts.map +1 -0
  330. package/dist/server/server/agent/providers/tool-call-mapper-utils.js +146 -0
  331. package/dist/server/server/agent/providers/tool-call-mapper-utils.js.map +1 -0
  332. package/dist/server/server/agent/recordings-debug.d.ts +3 -0
  333. package/dist/server/server/agent/recordings-debug.d.ts.map +1 -0
  334. package/dist/server/server/agent/recordings-debug.js +19 -0
  335. package/dist/server/server/agent/recordings-debug.js.map +1 -0
  336. package/dist/server/server/agent/stt-debug.d.ts +10 -0
  337. package/dist/server/server/agent/stt-debug.d.ts.map +1 -0
  338. package/dist/server/server/agent/stt-debug.js +33 -0
  339. package/dist/server/server/agent/stt-debug.js.map +1 -0
  340. package/dist/server/server/agent/stt-manager.d.ts +38 -0
  341. package/dist/server/server/agent/stt-manager.d.ts.map +1 -0
  342. package/dist/server/server/agent/stt-manager.js +246 -0
  343. package/dist/server/server/agent/stt-manager.js.map +1 -0
  344. package/dist/server/server/agent/system-prompt.d.ts +2 -0
  345. package/dist/server/server/agent/system-prompt.d.ts.map +1 -0
  346. package/dist/server/server/agent/system-prompt.js +8 -0
  347. package/dist/server/server/agent/system-prompt.js.map +1 -0
  348. package/dist/server/server/agent/timeline-append.d.ts +10 -0
  349. package/dist/server/server/agent/timeline-append.d.ts.map +1 -0
  350. package/dist/server/server/agent/timeline-append.js +27 -0
  351. package/dist/server/server/agent/timeline-append.js.map +1 -0
  352. package/dist/server/server/agent/timeline-projection.d.ts +55 -0
  353. package/dist/server/server/agent/timeline-projection.d.ts.map +1 -0
  354. package/dist/server/server/agent/timeline-projection.js +279 -0
  355. package/dist/server/server/agent/timeline-projection.js.map +1 -0
  356. package/dist/server/server/agent/tool-name-normalization.d.ts +9 -0
  357. package/dist/server/server/agent/tool-name-normalization.d.ts.map +1 -0
  358. package/dist/server/server/agent/tool-name-normalization.js +82 -0
  359. package/dist/server/server/agent/tool-name-normalization.js.map +1 -0
  360. package/dist/server/server/agent/tts-debug.d.ts +8 -0
  361. package/dist/server/server/agent/tts-debug.d.ts.map +1 -0
  362. package/dist/server/server/agent/tts-debug.js +24 -0
  363. package/dist/server/server/agent/tts-debug.js.map +1 -0
  364. package/dist/server/server/agent/tts-manager.d.ts +41 -0
  365. package/dist/server/server/agent/tts-manager.d.ts.map +1 -0
  366. package/dist/server/server/agent/tts-manager.js +375 -0
  367. package/dist/server/server/agent/tts-manager.js.map +1 -0
  368. package/dist/server/server/agent/wait-for-agent-tracker.d.ts +15 -0
  369. package/dist/server/server/agent/wait-for-agent-tracker.d.ts.map +1 -0
  370. package/dist/server/server/agent/wait-for-agent-tracker.js +53 -0
  371. package/dist/server/server/agent/wait-for-agent-tracker.js.map +1 -0
  372. package/dist/server/server/agent-attention-policy.d.ts +20 -0
  373. package/dist/server/server/agent-attention-policy.d.ts.map +1 -0
  374. package/dist/server/server/agent-attention-policy.js +24 -0
  375. package/dist/server/server/agent-attention-policy.js.map +1 -0
  376. package/dist/server/server/auth.d.ts +25 -0
  377. package/dist/server/server/auth.d.ts.map +1 -0
  378. package/dist/server/server/auth.js +93 -0
  379. package/dist/server/server/auth.js.map +1 -0
  380. package/dist/server/server/auto-archive-on-merge/archive-if-safe.d.ts +40 -0
  381. package/dist/server/server/auto-archive-on-merge/archive-if-safe.d.ts.map +1 -0
  382. package/dist/server/server/auto-archive-on-merge/archive-if-safe.js +80 -0
  383. package/dist/server/server/auto-archive-on-merge/archive-if-safe.js.map +1 -0
  384. package/dist/server/server/auto-archive-on-merge/index.d.ts +8 -0
  385. package/dist/server/server/auto-archive-on-merge/index.d.ts.map +1 -0
  386. package/dist/server/server/auto-archive-on-merge/index.js +15 -0
  387. package/dist/server/server/auto-archive-on-merge/index.js.map +1 -0
  388. package/dist/server/server/bootstrap.d.ts +98 -0
  389. package/dist/server/server/bootstrap.d.ts.map +1 -0
  390. package/dist/server/server/bootstrap.js +800 -0
  391. package/dist/server/server/bootstrap.js.map +1 -0
  392. package/dist/server/server/chat/chat-mentions.d.ts +47 -0
  393. package/dist/server/server/chat/chat-mentions.d.ts.map +1 -0
  394. package/dist/server/server/chat/chat-mentions.js +113 -0
  395. package/dist/server/server/chat/chat-mentions.js.map +1 -0
  396. package/dist/server/server/chat/chat-rpc-schemas.d.ts +728 -0
  397. package/dist/server/server/chat/chat-rpc-schemas.d.ts.map +1 -0
  398. package/dist/server/server/chat/chat-rpc-schemas.js +103 -0
  399. package/dist/server/server/chat/chat-rpc-schemas.js.map +1 -0
  400. package/dist/server/server/chat/chat-service.d.ts +78 -0
  401. package/dist/server/server/chat/chat-service.d.ts.map +1 -0
  402. package/dist/server/server/chat/chat-service.js +339 -0
  403. package/dist/server/server/chat/chat-service.js.map +1 -0
  404. package/dist/server/server/chat/chat-types.d.ts +75 -0
  405. package/dist/server/server/chat/chat-types.d.ts.map +1 -0
  406. package/dist/server/server/chat/chat-types.js +22 -0
  407. package/dist/server/server/chat/chat-types.js.map +1 -0
  408. package/dist/server/server/checkout/status-projection.d.ts +19 -0
  409. package/dist/server/server/checkout/status-projection.d.ts.map +1 -0
  410. package/dist/server/server/checkout/status-projection.js +102 -0
  411. package/dist/server/server/checkout/status-projection.js.map +1 -0
  412. package/dist/server/server/checkout-diff-manager.d.ts +41 -0
  413. package/dist/server/server/checkout-diff-manager.d.ts.map +1 -0
  414. package/dist/server/server/checkout-diff-manager.js +189 -0
  415. package/dist/server/server/checkout-diff-manager.js.map +1 -0
  416. package/dist/server/server/checkout-git-utils.d.ts +11 -0
  417. package/dist/server/server/checkout-git-utils.d.ts.map +1 -0
  418. package/dist/server/server/checkout-git-utils.js +34 -0
  419. package/dist/server/server/checkout-git-utils.js.map +1 -0
  420. package/dist/server/server/client-message-id.d.ts +3 -0
  421. package/dist/server/server/client-message-id.d.ts.map +1 -0
  422. package/dist/server/server/client-message-id.js +12 -0
  423. package/dist/server/server/client-message-id.js.map +1 -0
  424. package/dist/server/server/config.d.ts +23 -0
  425. package/dist/server/server/config.d.ts.map +1 -0
  426. package/dist/server/server/config.js +233 -0
  427. package/dist/server/server/config.js.map +1 -0
  428. package/dist/server/server/connection-offer.d.ts +20 -0
  429. package/dist/server/server/connection-offer.d.ts.map +1 -0
  430. package/dist/server/server/connection-offer.js +59 -0
  431. package/dist/server/server/connection-offer.js.map +1 -0
  432. package/dist/server/server/daemon-config-store.d.ts +25 -0
  433. package/dist/server/server/daemon-config-store.d.ts.map +1 -0
  434. package/dist/server/server/daemon-config-store.js +138 -0
  435. package/dist/server/server/daemon-config-store.js.map +1 -0
  436. package/dist/server/server/daemon-keypair.d.ts +8 -0
  437. package/dist/server/server/daemon-keypair.d.ts.map +1 -0
  438. package/dist/server/server/daemon-keypair.js +42 -0
  439. package/dist/server/server/daemon-keypair.js.map +1 -0
  440. package/dist/server/server/daemon-version.d.ts +5 -0
  441. package/dist/server/server/daemon-version.d.ts.map +1 -0
  442. package/dist/server/server/daemon-version.js +22 -0
  443. package/dist/server/server/daemon-version.js.map +1 -0
  444. package/dist/server/server/daemon-worker.d.ts +2 -0
  445. package/dist/server/server/daemon-worker.d.ts.map +1 -0
  446. package/dist/server/server/daemon-worker.js +155 -0
  447. package/dist/server/server/daemon-worker.js.map +1 -0
  448. package/dist/server/server/dictation/dictation-stream-manager.d.ts +87 -0
  449. package/dist/server/server/dictation/dictation-stream-manager.d.ts.map +1 -0
  450. package/dist/server/server/dictation/dictation-stream-manager.js +572 -0
  451. package/dist/server/server/dictation/dictation-stream-manager.js.map +1 -0
  452. package/dist/server/server/editor-targets.d.ts +18 -0
  453. package/dist/server/server/editor-targets.d.ts.map +1 -0
  454. package/dist/server/server/editor-targets.js +109 -0
  455. package/dist/server/server/editor-targets.js.map +1 -0
  456. package/dist/server/server/exports.d.ts +26 -0
  457. package/dist/server/server/exports.d.ts.map +1 -0
  458. package/dist/server/server/exports.js +25 -0
  459. package/dist/server/server/exports.js.map +1 -0
  460. package/dist/server/server/file-download/token-store.d.ts +24 -0
  461. package/dist/server/server/file-download/token-store.d.ts.map +1 -0
  462. package/dist/server/server/file-download/token-store.js +40 -0
  463. package/dist/server/server/file-download/token-store.js.map +1 -0
  464. package/dist/server/server/file-explorer/service.d.ts +51 -0
  465. package/dist/server/server/file-explorer/service.d.ts.map +1 -0
  466. package/dist/server/server/file-explorer/service.js +246 -0
  467. package/dist/server/server/file-explorer/service.js.map +1 -0
  468. package/dist/server/server/hostnames.d.ts +13 -0
  469. package/dist/server/server/hostnames.d.ts.map +1 -0
  470. package/dist/server/server/hostnames.js +94 -0
  471. package/dist/server/server/hostnames.js.map +1 -0
  472. package/dist/server/server/json-utils.d.ts +11 -0
  473. package/dist/server/server/json-utils.d.ts.map +1 -0
  474. package/dist/server/server/json-utils.js +45 -0
  475. package/dist/server/server/json-utils.js.map +1 -0
  476. package/dist/server/server/logger.d.ts +29 -0
  477. package/dist/server/server/logger.d.ts.map +1 -0
  478. package/dist/server/server/logger.js +125 -0
  479. package/dist/server/server/logger.js.map +1 -0
  480. package/dist/server/server/loop/rpc-schemas.d.ts +3005 -0
  481. package/dist/server/server/loop/rpc-schemas.d.ts.map +1 -0
  482. package/dist/server/server/loop/rpc-schemas.js +163 -0
  483. package/dist/server/server/loop/rpc-schemas.js.map +1 -0
  484. package/dist/server/server/loop-service.d.ts +529 -0
  485. package/dist/server/server/loop-service.d.ts.map +1 -0
  486. package/dist/server/server/loop-service.js +751 -0
  487. package/dist/server/server/loop-service.js.map +1 -0
  488. package/dist/server/server/messages.d.ts +9 -0
  489. package/dist/server/server/messages.d.ts.map +1 -0
  490. package/dist/server/server/messages.js +29 -0
  491. package/dist/server/server/messages.js.map +1 -0
  492. package/dist/server/server/package-version.d.ts +25 -0
  493. package/dist/server/server/package-version.d.ts.map +1 -0
  494. package/dist/server/server/package-version.js +60 -0
  495. package/dist/server/server/package-version.js.map +1 -0
  496. package/dist/server/server/pagination/cursor.d.ts +16 -0
  497. package/dist/server/server/pagination/cursor.d.ts.map +1 -0
  498. package/dist/server/server/pagination/cursor.js +62 -0
  499. package/dist/server/server/pagination/cursor.js.map +1 -0
  500. package/dist/server/server/pagination/sortable-pager.d.ts +24 -0
  501. package/dist/server/server/pagination/sortable-pager.d.ts.map +1 -0
  502. package/dist/server/server/pagination/sortable-pager.js +68 -0
  503. package/dist/server/server/pagination/sortable-pager.js.map +1 -0
  504. package/dist/server/server/pairing-offer.d.ts +18 -0
  505. package/dist/server/server/pairing-offer.d.ts.map +1 -0
  506. package/dist/server/server/pairing-offer.js +47 -0
  507. package/dist/server/server/pairing-offer.js.map +1 -0
  508. package/dist/server/server/pairing-qr.d.ts +7 -0
  509. package/dist/server/server/pairing-qr.d.ts.map +1 -0
  510. package/dist/server/server/pairing-qr.js +45 -0
  511. package/dist/server/server/pairing-qr.js.map +1 -0
  512. package/dist/server/server/paseo-env.d.ts +13 -0
  513. package/dist/server/server/paseo-env.d.ts.map +1 -0
  514. package/dist/server/server/paseo-env.js +53 -0
  515. package/dist/server/server/paseo-env.js.map +1 -0
  516. package/dist/server/server/paseo-home.d.ts +2 -0
  517. package/dist/server/server/paseo-home.d.ts.map +1 -0
  518. package/dist/server/server/paseo-home.js +19 -0
  519. package/dist/server/server/paseo-home.js.map +1 -0
  520. package/dist/server/server/paseo-worktree-archive-service.d.ts +43 -0
  521. package/dist/server/server/paseo-worktree-archive-service.d.ts.map +1 -0
  522. package/dist/server/server/paseo-worktree-archive-service.js +145 -0
  523. package/dist/server/server/paseo-worktree-archive-service.js.map +1 -0
  524. package/dist/server/server/paseo-worktree-service.d.ts +43 -0
  525. package/dist/server/server/paseo-worktree-service.d.ts.map +1 -0
  526. package/dist/server/server/paseo-worktree-service.js +218 -0
  527. package/dist/server/server/paseo-worktree-service.js.map +1 -0
  528. package/dist/server/server/path-utils.d.ts +4 -0
  529. package/dist/server/server/path-utils.d.ts.map +1 -0
  530. package/dist/server/server/path-utils.js +29 -0
  531. package/dist/server/server/path-utils.js.map +1 -0
  532. package/dist/server/server/persisted-config.d.ts +1056 -0
  533. package/dist/server/server/persisted-config.d.ts.map +1 -0
  534. package/dist/server/server/persisted-config.js +398 -0
  535. package/dist/server/server/persisted-config.js.map +1 -0
  536. package/dist/server/server/persistence-hooks.d.ts +33 -0
  537. package/dist/server/server/persistence-hooks.d.ts.map +1 -0
  538. package/dist/server/server/persistence-hooks.js +99 -0
  539. package/dist/server/server/persistence-hooks.js.map +1 -0
  540. package/dist/server/server/pid-lock.d.ts +46 -0
  541. package/dist/server/server/pid-lock.d.ts.map +1 -0
  542. package/dist/server/server/pid-lock.js +170 -0
  543. package/dist/server/server/pid-lock.js.map +1 -0
  544. package/dist/server/server/private-files.d.ts +7 -0
  545. package/dist/server/server/private-files.d.ts.map +1 -0
  546. package/dist/server/server/private-files.js +42 -0
  547. package/dist/server/server/private-files.js.map +1 -0
  548. package/dist/server/server/push/notifications.d.ts +9 -0
  549. package/dist/server/server/push/notifications.d.ts.map +1 -0
  550. package/dist/server/server/push/notifications.js +15 -0
  551. package/dist/server/server/push/notifications.js.map +1 -0
  552. package/dist/server/server/push/push-service.d.ts +20 -0
  553. package/dist/server/server/push/push-service.d.ts.map +1 -0
  554. package/dist/server/server/push/push-service.js +66 -0
  555. package/dist/server/server/push/push-service.js.map +1 -0
  556. package/dist/server/server/push/token-store.d.ts +18 -0
  557. package/dist/server/server/push/token-store.d.ts.map +1 -0
  558. package/dist/server/server/push/token-store.js +68 -0
  559. package/dist/server/server/push/token-store.js.map +1 -0
  560. package/dist/server/server/relay-transport.d.ts +31 -0
  561. package/dist/server/server/relay-transport.d.ts.map +1 -0
  562. package/dist/server/server/relay-transport.js +514 -0
  563. package/dist/server/server/relay-transport.js.map +1 -0
  564. package/dist/server/server/resolve-worktree-creation-intent.d.ts +29 -0
  565. package/dist/server/server/resolve-worktree-creation-intent.d.ts.map +1 -0
  566. package/dist/server/server/resolve-worktree-creation-intent.js +119 -0
  567. package/dist/server/server/resolve-worktree-creation-intent.js.map +1 -0
  568. package/dist/server/server/schedule/cron.d.ts +4 -0
  569. package/dist/server/server/schedule/cron.d.ts.map +1 -0
  570. package/dist/server/server/schedule/cron.js +103 -0
  571. package/dist/server/server/schedule/cron.js.map +1 -0
  572. package/dist/server/server/schedule/rpc-schemas.d.ts +3909 -0
  573. package/dist/server/server/schedule/rpc-schemas.d.ts.map +1 -0
  574. package/dist/server/server/schedule/rpc-schemas.js +151 -0
  575. package/dist/server/server/schedule/rpc-schemas.js.map +1 -0
  576. package/dist/server/server/schedule/service.d.ts +40 -0
  577. package/dist/server/server/schedule/service.d.ts.map +1 -0
  578. package/dist/server/server/schedule/service.js +476 -0
  579. package/dist/server/server/schedule/service.js.map +1 -0
  580. package/dist/server/server/schedule/store.d.ts +13 -0
  581. package/dist/server/server/schedule/store.d.ts.map +1 -0
  582. package/dist/server/server/schedule/store.js +56 -0
  583. package/dist/server/server/schedule/store.js.map +1 -0
  584. package/dist/server/server/schedule/types.d.ts +726 -0
  585. package/dist/server/server/schedule/types.d.ts.map +1 -0
  586. package/dist/server/server/schedule/types.js +73 -0
  587. package/dist/server/server/schedule/types.js.map +1 -0
  588. package/dist/server/server/script-health-monitor.d.ts +39 -0
  589. package/dist/server/server/script-health-monitor.d.ts.map +1 -0
  590. package/dist/server/server/script-health-monitor.js +159 -0
  591. package/dist/server/server/script-health-monitor.js.map +1 -0
  592. package/dist/server/server/script-proxy.d.ts +40 -0
  593. package/dist/server/server/script-proxy.d.ts.map +1 -0
  594. package/dist/server/server/script-proxy.js +245 -0
  595. package/dist/server/server/script-proxy.js.map +1 -0
  596. package/dist/server/server/script-route-branch-handler.d.ts +10 -0
  597. package/dist/server/server/script-route-branch-handler.d.ts.map +1 -0
  598. package/dist/server/server/script-route-branch-handler.js +45 -0
  599. package/dist/server/server/script-route-branch-handler.js.map +1 -0
  600. package/dist/server/server/script-status-projection.d.ts +34 -0
  601. package/dist/server/server/script-status-projection.d.ts.map +1 -0
  602. package/dist/server/server/script-status-projection.js +152 -0
  603. package/dist/server/server/script-status-projection.js.map +1 -0
  604. package/dist/server/server/server-id.d.ts +17 -0
  605. package/dist/server/server/server-id.d.ts.map +1 -0
  606. package/dist/server/server/server-id.js +68 -0
  607. package/dist/server/server/server-id.js.map +1 -0
  608. package/dist/server/server/session.d.ts +586 -0
  609. package/dist/server/server/session.d.ts.map +1 -0
  610. package/dist/server/server/session.js +7072 -0
  611. package/dist/server/server/session.js.map +1 -0
  612. package/dist/server/server/speech/audio.d.ts +10 -0
  613. package/dist/server/server/speech/audio.d.ts.map +1 -0
  614. package/dist/server/server/speech/audio.js +101 -0
  615. package/dist/server/server/speech/audio.js.map +1 -0
  616. package/dist/server/server/speech/provider-resolver.d.ts +3 -0
  617. package/dist/server/server/speech/provider-resolver.d.ts.map +1 -0
  618. package/dist/server/server/speech/provider-resolver.js +7 -0
  619. package/dist/server/server/speech/provider-resolver.js.map +1 -0
  620. package/dist/server/server/speech/providers/local/config.d.ts +30 -0
  621. package/dist/server/server/speech/providers/local/config.d.ts.map +1 -0
  622. package/dist/server/server/speech/providers/local/config.js +134 -0
  623. package/dist/server/server/speech/providers/local/config.js.map +1 -0
  624. package/dist/server/server/speech/providers/local/models.d.ts +11 -0
  625. package/dist/server/server/speech/providers/local/models.d.ts.map +1 -0
  626. package/dist/server/server/speech/providers/local/models.js +17 -0
  627. package/dist/server/server/speech/providers/local/models.js.map +1 -0
  628. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.d.ts +24 -0
  629. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.d.ts.map +1 -0
  630. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.js +459 -0
  631. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.js.map +1 -0
  632. package/dist/server/server/speech/providers/local/runtime.d.ts +31 -0
  633. package/dist/server/server/speech/providers/local/runtime.d.ts.map +1 -0
  634. package/dist/server/server/speech/providers/local/runtime.js +278 -0
  635. package/dist/server/server/speech/providers/local/runtime.js.map +1 -0
  636. package/dist/server/server/speech/providers/local/sherpa/assets/silero_vad.onnx +0 -0
  637. package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts +117 -0
  638. package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts.map +1 -0
  639. package/dist/server/server/speech/providers/local/sherpa/model-catalog.js +169 -0
  640. package/dist/server/server/speech/providers/local/sherpa/model-catalog.js.map +1 -0
  641. package/dist/server/server/speech/providers/local/sherpa/model-downloader.d.ts +15 -0
  642. package/dist/server/server/speech/providers/local/sherpa/model-downloader.d.ts.map +1 -0
  643. package/dist/server/server/speech/providers/local/sherpa/model-downloader.js +167 -0
  644. package/dist/server/server/speech/providers/local/sherpa/model-downloader.js.map +1 -0
  645. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.d.ts +49 -0
  646. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.d.ts.map +1 -0
  647. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.js +73 -0
  648. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.js.map +1 -0
  649. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.d.ts +56 -0
  650. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.d.ts.map +1 -0
  651. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.js +91 -0
  652. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.js.map +1 -0
  653. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.d.ts +7 -0
  654. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.d.ts.map +1 -0
  655. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.js +11 -0
  656. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.js.map +1 -0
  657. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.d.ts +9 -0
  658. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.d.ts.map +1 -0
  659. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.js +107 -0
  660. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.js.map +1 -0
  661. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.d.ts +28 -0
  662. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.d.ts.map +1 -0
  663. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.js +137 -0
  664. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.js.map +1 -0
  665. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.d.ts +21 -0
  666. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.d.ts.map +1 -0
  667. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.js +133 -0
  668. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.js.map +1 -0
  669. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.d.ts +23 -0
  670. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.d.ts.map +1 -0
  671. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.js +116 -0
  672. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.js.map +1 -0
  673. package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.d.ts +18 -0
  674. package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.d.ts.map +1 -0
  675. package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.js +84 -0
  676. package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.js.map +1 -0
  677. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.d.ts +23 -0
  678. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.d.ts.map +1 -0
  679. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.js +141 -0
  680. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.js.map +1 -0
  681. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.d.ts +21 -0
  682. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.d.ts.map +1 -0
  683. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.js +115 -0
  684. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.js.map +1 -0
  685. package/dist/server/server/speech/providers/local/sherpa/silero-vad-provider.d.ts +19 -0
  686. package/dist/server/server/speech/providers/local/sherpa/silero-vad-provider.d.ts.map +1 -0
  687. package/dist/server/server/speech/providers/local/sherpa/silero-vad-provider.js +49 -0
  688. package/dist/server/server/speech/providers/local/sherpa/silero-vad-provider.js.map +1 -0
  689. package/dist/server/server/speech/providers/local/sherpa/silero-vad-session.d.ts +38 -0
  690. package/dist/server/server/speech/providers/local/sherpa/silero-vad-session.d.ts.map +1 -0
  691. package/dist/server/server/speech/providers/local/sherpa/silero-vad-session.js +176 -0
  692. package/dist/server/server/speech/providers/local/sherpa/silero-vad-session.js.map +1 -0
  693. package/dist/server/server/speech/providers/openai/config.d.ts +22 -0
  694. package/dist/server/server/speech/providers/openai/config.d.ts.map +1 -0
  695. package/dist/server/server/speech/providers/openai/config.js +107 -0
  696. package/dist/server/server/speech/providers/openai/config.js.map +1 -0
  697. package/dist/server/server/speech/providers/openai/realtime-transcription-session.d.ts +42 -0
  698. package/dist/server/server/speech/providers/openai/realtime-transcription-session.d.ts.map +1 -0
  699. package/dist/server/server/speech/providers/openai/realtime-transcription-session.js +168 -0
  700. package/dist/server/server/speech/providers/openai/realtime-transcription-session.js.map +1 -0
  701. package/dist/server/server/speech/providers/openai/runtime.d.ts +29 -0
  702. package/dist/server/server/speech/providers/openai/runtime.d.ts.map +1 -0
  703. package/dist/server/server/speech/providers/openai/runtime.js +117 -0
  704. package/dist/server/server/speech/providers/openai/runtime.js.map +1 -0
  705. package/dist/server/server/speech/providers/openai/stt.d.ts +22 -0
  706. package/dist/server/server/speech/providers/openai/stt.d.ts.map +1 -0
  707. package/dist/server/server/speech/providers/openai/stt.js +207 -0
  708. package/dist/server/server/speech/providers/openai/stt.js.map +1 -0
  709. package/dist/server/server/speech/providers/openai/tts.d.ts +18 -0
  710. package/dist/server/server/speech/providers/openai/tts.d.ts.map +1 -0
  711. package/dist/server/server/speech/providers/openai/tts.js +47 -0
  712. package/dist/server/server/speech/providers/openai/tts.js.map +1 -0
  713. package/dist/server/server/speech/speech-config-resolver.d.ts +11 -0
  714. package/dist/server/server/speech/speech-config-resolver.d.ts.map +1 -0
  715. package/dist/server/server/speech/speech-config-resolver.js +132 -0
  716. package/dist/server/server/speech/speech-config-resolver.js.map +1 -0
  717. package/dist/server/server/speech/speech-provider.d.ts +59 -0
  718. package/dist/server/server/speech/speech-provider.d.ts.map +1 -0
  719. package/dist/server/server/speech/speech-provider.js +2 -0
  720. package/dist/server/server/speech/speech-provider.js.map +1 -0
  721. package/dist/server/server/speech/speech-runtime.d.ts +45 -0
  722. package/dist/server/server/speech/speech-runtime.d.ts.map +1 -0
  723. package/dist/server/server/speech/speech-runtime.js +562 -0
  724. package/dist/server/server/speech/speech-runtime.js.map +1 -0
  725. package/dist/server/server/speech/speech-types.d.ts +24 -0
  726. package/dist/server/server/speech/speech-types.d.ts.map +1 -0
  727. package/dist/server/server/speech/speech-types.js +8 -0
  728. package/dist/server/server/speech/speech-types.js.map +1 -0
  729. package/dist/server/server/speech/turn-detection-provider.d.ts +23 -0
  730. package/dist/server/server/speech/turn-detection-provider.d.ts.map +1 -0
  731. package/dist/server/server/speech/turn-detection-provider.js +2 -0
  732. package/dist/server/server/speech/turn-detection-provider.js.map +1 -0
  733. package/dist/server/server/utils/diff-highlighter.d.ts +57 -0
  734. package/dist/server/server/utils/diff-highlighter.d.ts.map +1 -0
  735. package/dist/server/server/utils/diff-highlighter.js +279 -0
  736. package/dist/server/server/utils/diff-highlighter.js.map +1 -0
  737. package/dist/server/server/voice/voice-turn-controller.d.ts +38 -0
  738. package/dist/server/server/voice/voice-turn-controller.d.ts.map +1 -0
  739. package/dist/server/server/voice/voice-turn-controller.js +393 -0
  740. package/dist/server/server/voice/voice-turn-controller.js.map +1 -0
  741. package/dist/server/server/voice-config.d.ts +15 -0
  742. package/dist/server/server/voice-config.d.ts.map +1 -0
  743. package/dist/server/server/voice-config.js +54 -0
  744. package/dist/server/server/voice-config.js.map +1 -0
  745. package/dist/server/server/voice-permission-policy.d.ts +4 -0
  746. package/dist/server/server/voice-permission-policy.d.ts.map +1 -0
  747. package/dist/server/server/voice-permission-policy.js +13 -0
  748. package/dist/server/server/voice-permission-policy.js.map +1 -0
  749. package/dist/server/server/voice-types.d.ts +12 -0
  750. package/dist/server/server/voice-types.d.ts.map +1 -0
  751. package/dist/server/server/voice-types.js +2 -0
  752. package/dist/server/server/voice-types.js.map +1 -0
  753. package/dist/server/server/websocket/runtime-metrics.d.ts +71 -0
  754. package/dist/server/server/websocket/runtime-metrics.d.ts.map +1 -0
  755. package/dist/server/server/websocket/runtime-metrics.js +148 -0
  756. package/dist/server/server/websocket/runtime-metrics.js.map +1 -0
  757. package/dist/server/server/websocket-server.d.ts +153 -0
  758. package/dist/server/server/websocket-server.d.ts.map +1 -0
  759. package/dist/server/server/websocket-server.js +1300 -0
  760. package/dist/server/server/websocket-server.js.map +1 -0
  761. package/dist/server/server/workspace-archive-service.d.ts +8 -0
  762. package/dist/server/server/workspace-archive-service.d.ts.map +1 -0
  763. package/dist/server/server/workspace-archive-service.js +17 -0
  764. package/dist/server/server/workspace-archive-service.js.map +1 -0
  765. package/dist/server/server/workspace-directory.d.ts +67 -0
  766. package/dist/server/server/workspace-directory.d.ts.map +1 -0
  767. package/dist/server/server/workspace-directory.js +214 -0
  768. package/dist/server/server/workspace-directory.js.map +1 -0
  769. package/dist/server/server/workspace-git-metadata.d.ts +24 -0
  770. package/dist/server/server/workspace-git-metadata.d.ts.map +1 -0
  771. package/dist/server/server/workspace-git-metadata.js +55 -0
  772. package/dist/server/server/workspace-git-metadata.js.map +1 -0
  773. package/dist/server/server/workspace-git-service.d.ts +257 -0
  774. package/dist/server/server/workspace-git-service.d.ts.map +1 -0
  775. package/dist/server/server/workspace-git-service.js +1277 -0
  776. package/dist/server/server/workspace-git-service.js.map +1 -0
  777. package/dist/server/server/workspace-reconciliation-service.d.ts +58 -0
  778. package/dist/server/server/workspace-reconciliation-service.d.ts.map +1 -0
  779. package/dist/server/server/workspace-reconciliation-service.js +274 -0
  780. package/dist/server/server/workspace-reconciliation-service.js.map +1 -0
  781. package/dist/server/server/workspace-registry-bootstrap.d.ts +13 -0
  782. package/dist/server/server/workspace-registry-bootstrap.d.ts.map +1 -0
  783. package/dist/server/server/workspace-registry-bootstrap.js +108 -0
  784. package/dist/server/server/workspace-registry-bootstrap.js.map +1 -0
  785. package/dist/server/server/workspace-registry-model.d.ts +55 -0
  786. package/dist/server/server/workspace-registry-model.d.ts.map +1 -0
  787. package/dist/server/server/workspace-registry-model.js +191 -0
  788. package/dist/server/server/workspace-registry-model.js.map +1 -0
  789. package/dist/server/server/workspace-registry.d.ts +135 -0
  790. package/dist/server/server/workspace-registry.d.ts.map +1 -0
  791. package/dist/server/server/workspace-registry.js +162 -0
  792. package/dist/server/server/workspace-registry.js.map +1 -0
  793. package/dist/server/server/workspace-script-runtime-store.d.ts +28 -0
  794. package/dist/server/server/workspace-script-runtime-store.d.ts.map +1 -0
  795. package/dist/server/server/workspace-script-runtime-store.js +78 -0
  796. package/dist/server/server/workspace-script-runtime-store.js.map +1 -0
  797. package/dist/server/server/workspace-service-env.d.ts +17 -0
  798. package/dist/server/server/workspace-service-env.d.ts.map +1 -0
  799. package/dist/server/server/workspace-service-env.js +80 -0
  800. package/dist/server/server/workspace-service-env.js.map +1 -0
  801. package/dist/server/server/workspace-service-port-registry.d.ts +19 -0
  802. package/dist/server/server/workspace-service-port-registry.d.ts.map +1 -0
  803. package/dist/server/server/workspace-service-port-registry.js +59 -0
  804. package/dist/server/server/workspace-service-port-registry.js.map +1 -0
  805. package/dist/server/server/worktree-bootstrap.d.ts +74 -0
  806. package/dist/server/server/worktree-bootstrap.d.ts.map +1 -0
  807. package/dist/server/server/worktree-bootstrap.js +716 -0
  808. package/dist/server/server/worktree-bootstrap.js.map +1 -0
  809. package/dist/server/server/worktree-branch-name-generator.d.ts +21 -0
  810. package/dist/server/server/worktree-branch-name-generator.d.ts.map +1 -0
  811. package/dist/server/server/worktree-branch-name-generator.js +59 -0
  812. package/dist/server/server/worktree-branch-name-generator.js.map +1 -0
  813. package/dist/server/server/worktree-core.d.ts +29 -0
  814. package/dist/server/server/worktree-core.d.ts.map +1 -0
  815. package/dist/server/server/worktree-core.js +99 -0
  816. package/dist/server/server/worktree-core.js.map +1 -0
  817. package/dist/server/server/worktree-errors.d.ts +12 -0
  818. package/dist/server/server/worktree-errors.d.ts.map +1 -0
  819. package/dist/server/server/worktree-errors.js +28 -0
  820. package/dist/server/server/worktree-errors.js.map +1 -0
  821. package/dist/server/server/worktree-session.d.ts +149 -0
  822. package/dist/server/server/worktree-session.d.ts.map +1 -0
  823. package/dist/server/server/worktree-session.js +464 -0
  824. package/dist/server/server/worktree-session.js.map +1 -0
  825. package/dist/server/services/github-service.d.ts +279 -0
  826. package/dist/server/services/github-service.d.ts.map +1 -0
  827. package/dist/server/services/github-service.js +1666 -0
  828. package/dist/server/services/github-service.js.map +1 -0
  829. package/dist/server/shared/agent-attention-notification.d.ts +41 -0
  830. package/dist/server/shared/agent-attention-notification.d.ts.map +1 -0
  831. package/dist/server/shared/agent-attention-notification.js +140 -0
  832. package/dist/server/shared/agent-attention-notification.js.map +1 -0
  833. package/dist/server/shared/agent-labels.d.ts +2 -0
  834. package/dist/server/shared/agent-labels.d.ts.map +1 -0
  835. package/dist/server/shared/agent-labels.js +2 -0
  836. package/dist/server/shared/agent-labels.js.map +1 -0
  837. package/dist/server/shared/agent-lifecycle.d.ts +3 -0
  838. package/dist/server/shared/agent-lifecycle.d.ts.map +1 -0
  839. package/dist/server/shared/agent-lifecycle.js +8 -0
  840. package/dist/server/shared/agent-lifecycle.js.map +1 -0
  841. package/dist/server/shared/agent-state-bucket.d.ts +13 -0
  842. package/dist/server/shared/agent-state-bucket.d.ts.map +1 -0
  843. package/dist/server/shared/agent-state-bucket.js +41 -0
  844. package/dist/server/shared/agent-state-bucket.js.map +1 -0
  845. package/dist/server/shared/binary-frames/file-transfer.d.ts +56 -0
  846. package/dist/server/shared/binary-frames/file-transfer.d.ts.map +1 -0
  847. package/dist/server/shared/binary-frames/file-transfer.js +108 -0
  848. package/dist/server/shared/binary-frames/file-transfer.js.map +1 -0
  849. package/dist/server/shared/binary-frames/index.d.ts +3 -0
  850. package/dist/server/shared/binary-frames/index.d.ts.map +1 -0
  851. package/dist/server/shared/binary-frames/index.js +3 -0
  852. package/dist/server/shared/binary-frames/index.js.map +1 -0
  853. package/dist/server/shared/binary-frames/terminal.d.ts +36 -0
  854. package/dist/server/shared/binary-frames/terminal.d.ts.map +1 -0
  855. package/dist/server/shared/binary-frames/terminal.js +99 -0
  856. package/dist/server/shared/binary-frames/terminal.js.map +1 -0
  857. package/dist/server/shared/client-capabilities.d.ts +5 -0
  858. package/dist/server/shared/client-capabilities.d.ts.map +1 -0
  859. package/dist/server/shared/client-capabilities.js +4 -0
  860. package/dist/server/shared/client-capabilities.js.map +1 -0
  861. package/dist/server/shared/connection-offer.d.ts +80 -0
  862. package/dist/server/shared/connection-offer.d.ts.map +1 -0
  863. package/dist/server/shared/connection-offer.js +53 -0
  864. package/dist/server/shared/connection-offer.js.map +1 -0
  865. package/dist/server/shared/daemon-endpoints.d.ts +47 -0
  866. package/dist/server/shared/daemon-endpoints.d.ts.map +1 -0
  867. package/dist/server/shared/daemon-endpoints.js +201 -0
  868. package/dist/server/shared/daemon-endpoints.js.map +1 -0
  869. package/dist/server/shared/error-utils.d.ts +11 -0
  870. package/dist/server/shared/error-utils.d.ts.map +1 -0
  871. package/dist/server/shared/error-utils.js +27 -0
  872. package/dist/server/shared/error-utils.js.map +1 -0
  873. package/dist/server/shared/git-remote.d.ts +16 -0
  874. package/dist/server/shared/git-remote.d.ts.map +1 -0
  875. package/dist/server/shared/git-remote.js +72 -0
  876. package/dist/server/shared/git-remote.js.map +1 -0
  877. package/dist/server/shared/host-connection-schema.d.ts +23 -0
  878. package/dist/server/shared/host-connection-schema.d.ts.map +1 -0
  879. package/dist/server/shared/host-connection-schema.js +9 -0
  880. package/dist/server/shared/host-connection-schema.js.map +1 -0
  881. package/dist/server/shared/importable-providers.d.ts +7 -0
  882. package/dist/server/shared/importable-providers.d.ts.map +1 -0
  883. package/dist/server/shared/importable-providers.js +7 -0
  884. package/dist/server/shared/importable-providers.js.map +1 -0
  885. package/dist/server/shared/literal-union.d.ts +2 -0
  886. package/dist/server/shared/literal-union.d.ts.map +1 -0
  887. package/dist/server/shared/literal-union.js +2 -0
  888. package/dist/server/shared/literal-union.js.map +1 -0
  889. package/dist/server/shared/messages.d.ts +140180 -0
  890. package/dist/server/shared/messages.d.ts.map +1 -0
  891. package/dist/server/shared/messages.js +3259 -0
  892. package/dist/server/shared/messages.js.map +1 -0
  893. package/dist/server/shared/path-utils.d.ts +2 -0
  894. package/dist/server/shared/path-utils.d.ts.map +1 -0
  895. package/dist/server/shared/path-utils.js +16 -0
  896. package/dist/server/shared/path-utils.js.map +1 -0
  897. package/dist/server/shared/terminal-input-mode.d.ts +26 -0
  898. package/dist/server/shared/terminal-input-mode.d.ts.map +1 -0
  899. package/dist/server/shared/terminal-input-mode.js +151 -0
  900. package/dist/server/shared/terminal-input-mode.js.map +1 -0
  901. package/dist/server/shared/tool-call-display.d.ts +11 -0
  902. package/dist/server/shared/tool-call-display.d.ts.map +1 -0
  903. package/dist/server/shared/tool-call-display.js +135 -0
  904. package/dist/server/shared/tool-call-display.js.map +1 -0
  905. package/dist/server/terminal/shell-integration/zsh/.zshenv +17 -0
  906. package/dist/server/terminal/shell-integration/zsh/paseo-integration.zsh +32 -0
  907. package/dist/server/terminal/terminal-capture.d.ts +12 -0
  908. package/dist/server/terminal/terminal-capture.d.ts.map +1 -0
  909. package/dist/server/terminal/terminal-capture.js +43 -0
  910. package/dist/server/terminal/terminal-capture.js.map +1 -0
  911. package/dist/server/terminal/terminal-manager-factory.d.ts +3 -0
  912. package/dist/server/terminal/terminal-manager-factory.d.ts.map +1 -0
  913. package/dist/server/terminal/terminal-manager-factory.js +5 -0
  914. package/dist/server/terminal/terminal-manager-factory.js.map +1 -0
  915. package/dist/server/terminal/terminal-manager.d.ts +47 -0
  916. package/dist/server/terminal/terminal-manager.d.ts.map +1 -0
  917. package/dist/server/terminal/terminal-manager.js +183 -0
  918. package/dist/server/terminal/terminal-manager.js.map +1 -0
  919. package/dist/server/terminal/terminal-output-coalescer.d.ts +30 -0
  920. package/dist/server/terminal/terminal-output-coalescer.d.ts.map +1 -0
  921. package/dist/server/terminal/terminal-output-coalescer.js +55 -0
  922. package/dist/server/terminal/terminal-output-coalescer.js.map +1 -0
  923. package/dist/server/terminal/terminal-session-controller.d.ts +64 -0
  924. package/dist/server/terminal/terminal-session-controller.d.ts.map +1 -0
  925. package/dist/server/terminal/terminal-session-controller.js +653 -0
  926. package/dist/server/terminal/terminal-session-controller.js.map +1 -0
  927. package/dist/server/terminal/terminal-ts-loader.mjs +20 -0
  928. package/dist/server/terminal/terminal-worker-process.d.ts +2 -0
  929. package/dist/server/terminal/terminal-worker-process.d.ts.map +1 -0
  930. package/dist/server/terminal/terminal-worker-process.js +221 -0
  931. package/dist/server/terminal/terminal-worker-process.js.map +1 -0
  932. package/dist/server/terminal/terminal-worker-protocol.d.ts +113 -0
  933. package/dist/server/terminal/terminal-worker-protocol.d.ts.map +1 -0
  934. package/dist/server/terminal/terminal-worker-protocol.js +2 -0
  935. package/dist/server/terminal/terminal-worker-protocol.js.map +1 -0
  936. package/dist/server/terminal/terminal.d.ts +99 -0
  937. package/dist/server/terminal/terminal.d.ts.map +1 -0
  938. package/dist/server/terminal/terminal.js +877 -0
  939. package/dist/server/terminal/terminal.js.map +1 -0
  940. package/dist/server/terminal/worker-terminal-manager.d.ts +19 -0
  941. package/dist/server/terminal/worker-terminal-manager.d.ts.map +1 -0
  942. package/dist/server/terminal/worker-terminal-manager.js +492 -0
  943. package/dist/server/terminal/worker-terminal-manager.js.map +1 -0
  944. package/dist/server/utils/branch-slug.d.ts +14 -0
  945. package/dist/server/utils/branch-slug.d.ts.map +1 -0
  946. package/dist/server/utils/branch-slug.js +49 -0
  947. package/dist/server/utils/branch-slug.js.map +1 -0
  948. package/dist/server/utils/build-metadata-prompt.d.ts +14 -0
  949. package/dist/server/utils/build-metadata-prompt.d.ts.map +1 -0
  950. package/dist/server/utils/build-metadata-prompt.js +28 -0
  951. package/dist/server/utils/build-metadata-prompt.js.map +1 -0
  952. package/dist/server/utils/checkout-git.d.ts +213 -0
  953. package/dist/server/utils/checkout-git.d.ts.map +1 -0
  954. package/dist/server/utils/checkout-git.js +1885 -0
  955. package/dist/server/utils/checkout-git.js.map +1 -0
  956. package/dist/server/utils/directory-suggestions.d.ts +26 -0
  957. package/dist/server/utils/directory-suggestions.d.ts.map +1 -0
  958. package/dist/server/utils/directory-suggestions.js +732 -0
  959. package/dist/server/utils/directory-suggestions.js.map +1 -0
  960. package/dist/server/utils/executable.d.ts +10 -0
  961. package/dist/server/utils/executable.d.ts.map +1 -0
  962. package/dist/server/utils/executable.js +116 -0
  963. package/dist/server/utils/executable.js.map +1 -0
  964. package/dist/server/utils/git-rev-parse-path.d.ts +3 -0
  965. package/dist/server/utils/git-rev-parse-path.d.ts.map +1 -0
  966. package/dist/server/utils/git-rev-parse-path.js +21 -0
  967. package/dist/server/utils/git-rev-parse-path.js.map +1 -0
  968. package/dist/server/utils/github-remote.d.ts +9 -0
  969. package/dist/server/utils/github-remote.d.ts.map +1 -0
  970. package/dist/server/utils/github-remote.js +62 -0
  971. package/dist/server/utils/github-remote.js.map +1 -0
  972. package/dist/server/utils/paseo-config-file.d.ts +30 -0
  973. package/dist/server/utils/paseo-config-file.d.ts.map +1 -0
  974. package/dist/server/utils/paseo-config-file.js +90 -0
  975. package/dist/server/utils/paseo-config-file.js.map +1 -0
  976. package/dist/server/utils/paseo-config-schema.d.ts +915 -0
  977. package/dist/server/utils/paseo-config-schema.d.ts.map +1 -0
  978. package/dist/server/utils/paseo-config-schema.js +77 -0
  979. package/dist/server/utils/paseo-config-schema.js.map +1 -0
  980. package/dist/server/utils/path.d.ts +16 -0
  981. package/dist/server/utils/path.d.ts.map +1 -0
  982. package/dist/server/utils/path.js +110 -0
  983. package/dist/server/utils/path.js.map +1 -0
  984. package/dist/server/utils/project-icon.d.ts +39 -0
  985. package/dist/server/utils/project-icon.d.ts.map +1 -0
  986. package/dist/server/utils/project-icon.js +364 -0
  987. package/dist/server/utils/project-icon.js.map +1 -0
  988. package/dist/server/utils/promise-timeout.d.ts +9 -0
  989. package/dist/server/utils/promise-timeout.d.ts.map +1 -0
  990. package/dist/server/utils/promise-timeout.js +25 -0
  991. package/dist/server/utils/promise-timeout.js.map +1 -0
  992. package/dist/server/utils/run-git-command.d.ts +20 -0
  993. package/dist/server/utils/run-git-command.d.ts.map +1 -0
  994. package/dist/server/utils/run-git-command.js +146 -0
  995. package/dist/server/utils/run-git-command.js.map +1 -0
  996. package/dist/server/utils/script-hostname.d.ts +8 -0
  997. package/dist/server/utils/script-hostname.d.ts.map +1 -0
  998. package/dist/server/utils/script-hostname.js +14 -0
  999. package/dist/server/utils/script-hostname.js.map +1 -0
  1000. package/dist/server/utils/spawn.d.ts +33 -0
  1001. package/dist/server/utils/spawn.d.ts.map +1 -0
  1002. package/dist/server/utils/spawn.js +71 -0
  1003. package/dist/server/utils/spawn.js.map +1 -0
  1004. package/dist/server/utils/string-command-shell.d.ts +10 -0
  1005. package/dist/server/utils/string-command-shell.d.ts.map +1 -0
  1006. package/dist/server/utils/string-command-shell.js +21 -0
  1007. package/dist/server/utils/string-command-shell.js.map +1 -0
  1008. package/dist/server/utils/tree-kill.d.ts +18 -0
  1009. package/dist/server/utils/tree-kill.d.ts.map +1 -0
  1010. package/dist/server/utils/tree-kill.js +77 -0
  1011. package/dist/server/utils/tree-kill.js.map +1 -0
  1012. package/dist/server/utils/windows-command.d.ts +15 -0
  1013. package/dist/server/utils/windows-command.d.ts.map +1 -0
  1014. package/dist/server/utils/windows-command.js +41 -0
  1015. package/dist/server/utils/windows-command.js.map +1 -0
  1016. package/dist/server/utils/worktree-metadata.d.ts +91 -0
  1017. package/dist/server/utils/worktree-metadata.d.ts.map +1 -0
  1018. package/dist/server/utils/worktree-metadata.js +174 -0
  1019. package/dist/server/utils/worktree-metadata.js.map +1 -0
  1020. package/dist/server/utils/worktree.d.ts +195 -0
  1021. package/dist/server/utils/worktree.d.ts.map +1 -0
  1022. package/dist/server/utils/worktree.js +1004 -0
  1023. package/dist/server/utils/worktree.js.map +1 -0
  1024. package/dist/server/utils/wrap-user-instructions.d.ts +2 -0
  1025. package/dist/server/utils/wrap-user-instructions.d.ts.map +1 -0
  1026. package/dist/server/utils/wrap-user-instructions.js +13 -0
  1027. package/dist/server/utils/wrap-user-instructions.js.map +1 -0
  1028. package/dist/src/server/agent/agent-sdk-types.js +22 -0
  1029. package/dist/src/server/agent/agent-sdk-types.js.map +1 -0
  1030. package/dist/src/server/agent/agent-title-limits.js +3 -0
  1031. package/dist/src/server/agent/agent-title-limits.js.map +1 -0
  1032. package/dist/src/server/agent/provider-launch-config.js +190 -0
  1033. package/dist/src/server/agent/provider-launch-config.js.map +1 -0
  1034. package/dist/src/server/agent/provider-manifest.js +211 -0
  1035. package/dist/src/server/agent/provider-manifest.js.map +1 -0
  1036. package/dist/src/server/chat/chat-rpc-schemas.js +103 -0
  1037. package/dist/src/server/chat/chat-rpc-schemas.js.map +1 -0
  1038. package/dist/src/server/chat/chat-types.js +22 -0
  1039. package/dist/src/server/chat/chat-types.js.map +1 -0
  1040. package/dist/src/server/loop/rpc-schemas.js +163 -0
  1041. package/dist/src/server/loop/rpc-schemas.js.map +1 -0
  1042. package/dist/src/server/paseo-env.js +53 -0
  1043. package/dist/src/server/paseo-env.js.map +1 -0
  1044. package/dist/src/server/paseo-home.js +19 -0
  1045. package/dist/src/server/paseo-home.js.map +1 -0
  1046. package/dist/src/server/persisted-config.js +398 -0
  1047. package/dist/src/server/persisted-config.js.map +1 -0
  1048. package/dist/src/server/pid-lock.js +170 -0
  1049. package/dist/src/server/pid-lock.js.map +1 -0
  1050. package/dist/src/server/private-files.js +42 -0
  1051. package/dist/src/server/private-files.js.map +1 -0
  1052. package/dist/src/server/schedule/rpc-schemas.js +151 -0
  1053. package/dist/src/server/schedule/rpc-schemas.js.map +1 -0
  1054. package/dist/src/server/schedule/types.js +73 -0
  1055. package/dist/src/server/schedule/types.js.map +1 -0
  1056. package/dist/src/server/speech/providers/local/sherpa/sherpa-runtime-env.js +84 -0
  1057. package/dist/src/server/speech/providers/local/sherpa/sherpa-runtime-env.js.map +1 -0
  1058. package/dist/src/shared/agent-lifecycle.js +8 -0
  1059. package/dist/src/shared/agent-lifecycle.js.map +1 -0
  1060. package/dist/src/shared/client-capabilities.js +4 -0
  1061. package/dist/src/shared/client-capabilities.js.map +1 -0
  1062. package/dist/src/shared/literal-union.js +2 -0
  1063. package/dist/src/shared/literal-union.js.map +1 -0
  1064. package/dist/src/shared/messages.js +3259 -0
  1065. package/dist/src/shared/messages.js.map +1 -0
  1066. package/dist/src/terminal/shell-integration/zsh/.zshenv +17 -0
  1067. package/dist/src/terminal/shell-integration/zsh/paseo-integration.zsh +32 -0
  1068. package/dist/src/utils/executable.js +116 -0
  1069. package/dist/src/utils/executable.js.map +1 -0
  1070. package/dist/src/utils/paseo-config-schema.js +77 -0
  1071. package/dist/src/utils/paseo-config-schema.js.map +1 -0
  1072. package/dist/src/utils/spawn.js +71 -0
  1073. package/dist/src/utils/spawn.js.map +1 -0
  1074. package/dist/src/utils/windows-command.js +41 -0
  1075. package/dist/src/utils/windows-command.js.map +1 -0
  1076. package/package.json +115 -0
  1077. package/src/server/speech/providers/local/sherpa/assets/silero_vad.onnx +0 -0
@@ -0,0 +1,3376 @@
1
+ import { CLIENT_CAPS } from "../shared/client-capabilities.js";
2
+ import { AgentCreateFailedStatusPayloadSchema, AgentCreatedStatusPayloadSchema, AgentRefreshedStatusPayloadSchema, AgentResumedStatusPayloadSchema, parseServerInfoStatusPayload, RestartRequestedStatusPayloadSchema, ShutdownRequestedStatusPayloadSchema, SessionInboundMessageSchema, WSOutboundMessageSchema, } from "../shared/messages.js";
3
+ import { isRelayClientWebSocketUrl } from "../shared/daemon-endpoints.js";
4
+ import { asUint8Array, decodeFileTransferFrame, decodeTerminalStreamFrame, FileTransferOpcode, TerminalStreamOpcode, } from "../shared/binary-frames/index.js";
5
+ import { createRelayE2eeTransportFactory, createWebSocketTransportFactory, decodeMessageData, defaultWebSocketFactory, describeTransportClose, describeTransportError, } from "./daemon-client-transport.js";
6
+ import { DaemonClientRuntimeMetrics } from "./daemon-client-runtime-metrics.js";
7
+ import { TerminalStreamRouter } from "./terminal-stream-router.js";
8
+ const consoleLogger = {
9
+ debug: () => { },
10
+ info: (obj, msg) => console.log(msg, obj),
11
+ warn: (obj, msg) => console.warn(msg, obj),
12
+ error: (obj, msg) => console.error(msg, obj),
13
+ };
14
+ const perfNow = typeof performance !== "undefined" && typeof performance.now === "function"
15
+ ? () => performance.now()
16
+ : () => Date.now();
17
+ function normalizePassword(value) {
18
+ if (typeof value !== "string") {
19
+ return null;
20
+ }
21
+ return value.length > 0 ? value : null;
22
+ }
23
+ class DaemonRpcError extends Error {
24
+ constructor(params) {
25
+ const parts = [params.error];
26
+ if (params.requestType)
27
+ parts.push(`requestType=${params.requestType}`);
28
+ if (params.code)
29
+ parts.push(`code=${params.code}`);
30
+ super(parts.join(" "));
31
+ this.name = "DaemonRpcError";
32
+ this.requestId = params.requestId;
33
+ this.requestType = params.requestType;
34
+ this.code = params.code;
35
+ }
36
+ }
37
+ const DEFAULT_RECONNECT_BASE_DELAY_MS = 1500;
38
+ const DEFAULT_RECONNECT_MAX_DELAY_MS = 30000;
39
+ const DEFAULT_CONNECT_TIMEOUT_MS = 15000;
40
+ /** Default timeout for waiting for connection before sending queued messages */
41
+ const DEFAULT_SEND_QUEUE_TIMEOUT_MS = 10000;
42
+ const DEFAULT_DICTATION_FINISH_ACCEPT_TIMEOUT_MS = 15000;
43
+ const DEFAULT_DICTATION_FINISH_FALLBACK_TIMEOUT_MS = 5 * 60 * 1000;
44
+ const DEFAULT_DICTATION_FINISH_TIMEOUT_GRACE_MS = 5000;
45
+ function isWaiterTimeoutError(error) {
46
+ return error instanceof Error && error.message.startsWith("Timeout waiting for message");
47
+ }
48
+ function normalizeClientId(value) {
49
+ if (typeof value !== "string") {
50
+ return null;
51
+ }
52
+ const trimmed = value.trim();
53
+ return trimmed.length > 0 ? trimmed : null;
54
+ }
55
+ function decodeBase64ToBytes(base64) {
56
+ const binary = globalThis.atob(base64);
57
+ const bytes = new Uint8Array(binary.length);
58
+ for (let index = 0; index < binary.length; index += 1) {
59
+ bytes[index] = binary.charCodeAt(index);
60
+ }
61
+ return bytes;
62
+ }
63
+ function legacyExplorerFileToBytes(file) {
64
+ let bytes;
65
+ if (file.encoding === "base64" && file.content) {
66
+ bytes = decodeBase64ToBytes(file.content);
67
+ }
68
+ else if (file.encoding === "utf-8" && file.content) {
69
+ bytes = new TextEncoder().encode(file.content);
70
+ }
71
+ else {
72
+ bytes = new Uint8Array();
73
+ }
74
+ return {
75
+ bytes,
76
+ mime: file.mimeType ?? "application/octet-stream",
77
+ size: file.size,
78
+ path: file.path,
79
+ kind: file.kind,
80
+ modifiedAt: file.modifiedAt,
81
+ };
82
+ }
83
+ function binaryFileKind(mime, encoding) {
84
+ if (mime.startsWith("image/")) {
85
+ return "image";
86
+ }
87
+ if (encoding === "utf-8" || mime.startsWith("text/") || mime === "application/json") {
88
+ return "text";
89
+ }
90
+ return "binary";
91
+ }
92
+ function concatByteChunks(chunks, size) {
93
+ const bytes = new Uint8Array(size);
94
+ let offset = 0;
95
+ for (const chunk of chunks) {
96
+ bytes.set(chunk, offset);
97
+ offset += chunk.byteLength;
98
+ }
99
+ return bytes;
100
+ }
101
+ function hashForLog(value) {
102
+ let hash = 0;
103
+ for (let index = 0; index < value.length; index += 1) {
104
+ hash = (hash * 31 + value.charCodeAt(index)) | 0;
105
+ }
106
+ return `h_${Math.abs(hash).toString(16)}`;
107
+ }
108
+ function toReasonCode(reason) {
109
+ if (!reason) {
110
+ return null;
111
+ }
112
+ const normalized = reason.toLowerCase();
113
+ if (normalized.includes("timed out")) {
114
+ return "connect_timeout";
115
+ }
116
+ if (normalized.includes("disposed")) {
117
+ return "disposed";
118
+ }
119
+ if (normalized.includes("client closed")) {
120
+ return "client_closed";
121
+ }
122
+ if (normalized.includes("transport")) {
123
+ return "transport_error";
124
+ }
125
+ if (normalized.includes("failed to connect")) {
126
+ return "connect_failed";
127
+ }
128
+ return "unknown";
129
+ }
130
+ export class DaemonClient {
131
+ constructor(config) {
132
+ this.config = config;
133
+ this.transport = null;
134
+ this.transportCleanup = [];
135
+ this.rawMessageListeners = new Set();
136
+ this.messageHandlers = new Map();
137
+ this.eventListeners = new Set();
138
+ this.waiters = new Set();
139
+ this.checkoutStatusInFlight = new Map();
140
+ this.connectionListeners = new Set();
141
+ this.reconnectTimeout = null;
142
+ this.connectTimeout = null;
143
+ this.pendingGenericTransportErrorTimeout = null;
144
+ this.reconnectAttempt = 0;
145
+ this.shouldReconnect = true;
146
+ this.connectPromise = null;
147
+ this.connectResolve = null;
148
+ this.connectReject = null;
149
+ this.lastErrorValue = null;
150
+ this.connectionState = { status: "idle" };
151
+ this.checkoutDiffSubscriptions = new Map();
152
+ this.terminalDirectorySubscriptions = new Set();
153
+ this.terminalStreams = new TerminalStreamRouter();
154
+ this.pendingBinaryFileReads = new Map();
155
+ this.activeBinaryFileTransfers = new Map();
156
+ this.completedBinaryFileReads = new Map();
157
+ this.pendingSendQueue = [];
158
+ this.lastServerInfoMessage = null;
159
+ this.runtimeMetricsInterval = null;
160
+ this.runtimeMetrics = null;
161
+ this.logger = config.logger ?? consoleLogger;
162
+ this.logConnectionPath = isRelayClientWebSocketUrl(this.config.url) ? "relay" : "direct";
163
+ let parsedUrlForLog = null;
164
+ try {
165
+ parsedUrlForLog = new URL(this.config.url);
166
+ }
167
+ catch {
168
+ parsedUrlForLog = null;
169
+ }
170
+ const parsedServerIdForLog = normalizeClientId(parsedUrlForLog?.searchParams.get("serverId"));
171
+ this.logServerId = parsedServerIdForLog ?? parsedUrlForLog?.host ?? null;
172
+ const resolvedClientId = normalizeClientId(this.config.clientId);
173
+ if (!resolvedClientId) {
174
+ throw new Error("Daemon client requires a non-empty clientId");
175
+ }
176
+ this.config.clientId = resolvedClientId;
177
+ this.logClientIdHash = hashForLog(resolvedClientId);
178
+ this.logGeneration =
179
+ typeof this.config.runtimeGeneration === "number" &&
180
+ Number.isFinite(this.config.runtimeGeneration)
181
+ ? this.config.runtimeGeneration
182
+ : null;
183
+ const runtimeMetricsIntervalMs = typeof config.runtimeMetricsIntervalMs === "number" && config.runtimeMetricsIntervalMs > 0
184
+ ? config.runtimeMetricsIntervalMs
185
+ : 0;
186
+ if (runtimeMetricsIntervalMs > 0) {
187
+ const runtimeMetricsWindowMs = typeof config.runtimeMetricsWindowMs === "number" && config.runtimeMetricsWindowMs > 0
188
+ ? Math.max(config.runtimeMetricsWindowMs, runtimeMetricsIntervalMs)
189
+ : undefined;
190
+ this.runtimeMetrics = new DaemonClientRuntimeMetrics(this.logger, {
191
+ connectionPath: this.logConnectionPath,
192
+ serverId: this.logServerId,
193
+ getConnectionStatus: () => this.connectionState.status,
194
+ }, runtimeMetricsWindowMs ? { windowMs: runtimeMetricsWindowMs } : undefined);
195
+ this.runtimeMetricsInterval = setInterval(() => {
196
+ this.runtimeMetrics?.flush();
197
+ }, runtimeMetricsIntervalMs);
198
+ }
199
+ }
200
+ // ============================================================================
201
+ // Connection
202
+ // ============================================================================
203
+ async connect() {
204
+ if (this.connectionState.status === "disposed") {
205
+ throw new Error("Daemon client is disposed");
206
+ }
207
+ if (this.connectionState.status === "connected") {
208
+ return;
209
+ }
210
+ if (this.connectPromise) {
211
+ return this.connectPromise;
212
+ }
213
+ this.shouldReconnect = true;
214
+ this.connectPromise = new Promise((resolve, reject) => {
215
+ this.connectResolve = resolve;
216
+ this.connectReject = reject;
217
+ this.attemptConnect();
218
+ });
219
+ return this.connectPromise;
220
+ }
221
+ attemptConnect() {
222
+ if (this.connectionState.status === "disposed") {
223
+ this.rejectConnect(new Error("Daemon client is disposed"));
224
+ return;
225
+ }
226
+ if (!this.shouldReconnect) {
227
+ this.rejectConnect(new Error("Daemon client is closed"));
228
+ return;
229
+ }
230
+ if (this.connectionState.status === "connecting") {
231
+ return;
232
+ }
233
+ const headers = {};
234
+ const password = normalizePassword(this.config.password);
235
+ if (password) {
236
+ headers.Authorization = `Bearer ${password}`;
237
+ }
238
+ else if (this.config.authHeader) {
239
+ headers.Authorization = this.config.authHeader;
240
+ }
241
+ const protocols = password ? [`paseo.bearer.${password}`] : undefined;
242
+ try {
243
+ // Reconnect can overlap with browser close/error delivery ordering.
244
+ // Always dispose previous transport before constructing the next one.
245
+ this.disposeTransport();
246
+ const baseTransportFactory = this.config.transportFactory ??
247
+ createWebSocketTransportFactory(this.config.webSocketFactory ?? defaultWebSocketFactory);
248
+ const shouldUseRelayE2ee = this.config.e2ee?.enabled === true && isRelayClientWebSocketUrl(this.config.url);
249
+ let transportFactory = baseTransportFactory;
250
+ if (shouldUseRelayE2ee) {
251
+ const daemonPublicKeyB64 = this.config.e2ee?.daemonPublicKeyB64;
252
+ if (!daemonPublicKeyB64) {
253
+ throw new Error("daemonPublicKeyB64 is required for relay E2EE");
254
+ }
255
+ transportFactory = createRelayE2eeTransportFactory({
256
+ baseFactory: baseTransportFactory,
257
+ daemonPublicKeyB64,
258
+ logger: this.logger,
259
+ });
260
+ }
261
+ const transportUrl = this.resolveTransportUrlForAttempt();
262
+ const transport = transportFactory({
263
+ url: transportUrl,
264
+ headers,
265
+ ...(protocols ? { protocols } : {}),
266
+ });
267
+ this.transport = transport;
268
+ this.lastServerInfoMessage = null;
269
+ this.updateConnectionState({
270
+ status: "connecting",
271
+ attempt: this.reconnectAttempt,
272
+ }, { event: "CONNECT_REQUEST" });
273
+ this.resetConnectTimeout();
274
+ const timeoutMs = Math.max(1, this.config.connectTimeoutMs ?? DEFAULT_CONNECT_TIMEOUT_MS);
275
+ this.connectTimeout = setTimeout(() => {
276
+ if (this.connectionState.status !== "connecting") {
277
+ return;
278
+ }
279
+ this.lastErrorValue = "Connection timed out";
280
+ this.disposeTransport(1001, "Connection timed out");
281
+ this.scheduleReconnect({
282
+ reason: "Connection timed out",
283
+ event: "CONNECT_TIMEOUT",
284
+ reasonCode: "connect_timeout",
285
+ });
286
+ }, timeoutMs);
287
+ this.transportCleanup = [
288
+ transport.onOpen(() => {
289
+ if (this.pendingGenericTransportErrorTimeout) {
290
+ clearTimeout(this.pendingGenericTransportErrorTimeout);
291
+ this.pendingGenericTransportErrorTimeout = null;
292
+ }
293
+ this.lastErrorValue = null;
294
+ this.sendHelloMessage();
295
+ }),
296
+ transport.onClose((event) => {
297
+ this.resetConnectTimeout();
298
+ if (this.pendingGenericTransportErrorTimeout) {
299
+ clearTimeout(this.pendingGenericTransportErrorTimeout);
300
+ this.pendingGenericTransportErrorTimeout = null;
301
+ }
302
+ const reason = describeTransportClose(event);
303
+ if (reason) {
304
+ this.lastErrorValue = reason;
305
+ }
306
+ this.scheduleReconnect({
307
+ reason,
308
+ event: "TRANSPORT_CLOSE",
309
+ reasonCode: "transport_closed",
310
+ });
311
+ }),
312
+ transport.onError((event) => {
313
+ this.resetConnectTimeout();
314
+ const reason = describeTransportError(event);
315
+ const isGeneric = reason === "Transport error";
316
+ // Browser WebSocket.onerror often provides no useful details and is followed
317
+ // by a close event (often with code 1006). Prefer surfacing the close details
318
+ // instead of immediately disconnecting with a generic "Transport error".
319
+ if (isGeneric) {
320
+ this.lastErrorValue ?? (this.lastErrorValue = reason);
321
+ if (!this.pendingGenericTransportErrorTimeout) {
322
+ this.pendingGenericTransportErrorTimeout = setTimeout(() => {
323
+ this.pendingGenericTransportErrorTimeout = null;
324
+ if (this.connectionState.status === "connected" ||
325
+ this.connectionState.status === "connecting") {
326
+ this.lastErrorValue = reason;
327
+ this.scheduleReconnect({
328
+ reason,
329
+ event: "TRANSPORT_ERROR",
330
+ reasonCode: "transport_error",
331
+ });
332
+ }
333
+ }, 250);
334
+ }
335
+ return;
336
+ }
337
+ if (this.pendingGenericTransportErrorTimeout) {
338
+ clearTimeout(this.pendingGenericTransportErrorTimeout);
339
+ this.pendingGenericTransportErrorTimeout = null;
340
+ }
341
+ this.lastErrorValue = reason;
342
+ this.scheduleReconnect({
343
+ reason,
344
+ event: "TRANSPORT_ERROR",
345
+ reasonCode: "transport_error",
346
+ });
347
+ }),
348
+ transport.onMessage((data) => this.handleTransportMessage(data)),
349
+ ];
350
+ }
351
+ catch (error) {
352
+ this.resetConnectTimeout();
353
+ const message = error instanceof Error ? error.message : "Failed to connect";
354
+ this.lastErrorValue = message;
355
+ this.scheduleReconnect({
356
+ reason: message,
357
+ event: "CONNECT_FAILED",
358
+ reasonCode: "connect_failed",
359
+ });
360
+ this.rejectConnect(error instanceof Error ? error : new Error(message));
361
+ }
362
+ }
363
+ resolveConnect() {
364
+ if (this.connectResolve) {
365
+ this.connectResolve();
366
+ }
367
+ this.connectPromise = null;
368
+ this.connectResolve = null;
369
+ this.connectReject = null;
370
+ }
371
+ rejectConnect(error) {
372
+ if (this.connectReject) {
373
+ this.connectReject(error);
374
+ }
375
+ this.connectPromise = null;
376
+ this.connectResolve = null;
377
+ this.connectReject = null;
378
+ }
379
+ async close() {
380
+ if (this.connectionState.status === "disposed") {
381
+ return;
382
+ }
383
+ this.shouldReconnect = false;
384
+ this.connectPromise = null;
385
+ this.connectResolve = null;
386
+ this.connectReject = null;
387
+ if (this.reconnectTimeout) {
388
+ clearTimeout(this.reconnectTimeout);
389
+ this.reconnectTimeout = null;
390
+ }
391
+ this.resetConnectTimeout();
392
+ this.disposeTransport(1000, "Client closed");
393
+ this.clearWaiters(new Error("Daemon client closed"));
394
+ this.rejectPendingSendQueue(new Error("Daemon client closed"));
395
+ this.terminalStreams.clearSlots();
396
+ this.lastServerInfoMessage = null;
397
+ if (this.runtimeMetricsInterval) {
398
+ clearInterval(this.runtimeMetricsInterval);
399
+ this.runtimeMetricsInterval = null;
400
+ this.runtimeMetrics?.flush({ final: true });
401
+ this.runtimeMetrics = null;
402
+ }
403
+ this.updateConnectionState({ status: "disposed" }, { event: "DISPOSE", reason: "Client closed", reasonCode: "disposed" });
404
+ }
405
+ ensureConnected() {
406
+ if (this.connectionState.status === "disposed") {
407
+ return;
408
+ }
409
+ if (!this.shouldReconnect) {
410
+ this.shouldReconnect = true;
411
+ }
412
+ if (this.connectionState.status === "connected" ||
413
+ this.connectionState.status === "connecting") {
414
+ return;
415
+ }
416
+ void this.connect();
417
+ }
418
+ getConnectionState() {
419
+ return this.connectionState;
420
+ }
421
+ subscribeConnectionStatus(listener) {
422
+ this.connectionListeners.add(listener);
423
+ listener(this.connectionState);
424
+ return () => {
425
+ this.connectionListeners.delete(listener);
426
+ };
427
+ }
428
+ get isConnected() {
429
+ return this.connectionState.status === "connected";
430
+ }
431
+ get isConnecting() {
432
+ return this.connectionState.status === "connecting";
433
+ }
434
+ get lastError() {
435
+ return this.lastErrorValue;
436
+ }
437
+ // ============================================================================
438
+ // Message Subscription
439
+ // ============================================================================
440
+ subscribe(handler) {
441
+ this.eventListeners.add(handler);
442
+ return () => this.eventListeners.delete(handler);
443
+ }
444
+ subscribeRawMessages(handler) {
445
+ this.rawMessageListeners.add(handler);
446
+ return () => {
447
+ this.rawMessageListeners.delete(handler);
448
+ };
449
+ }
450
+ on(arg1, arg2) {
451
+ if (typeof arg1 === "function") {
452
+ return this.subscribe(arg1);
453
+ }
454
+ const type = arg1;
455
+ const handler = arg2;
456
+ if (!this.messageHandlers.has(type)) {
457
+ this.messageHandlers.set(type, new Set());
458
+ }
459
+ this.messageHandlers.get(type).add(handler);
460
+ return () => {
461
+ const handlers = this.messageHandlers.get(type);
462
+ if (!handlers) {
463
+ return;
464
+ }
465
+ handlers.delete(handler);
466
+ if (handlers.size === 0) {
467
+ this.messageHandlers.delete(type);
468
+ }
469
+ };
470
+ }
471
+ // ============================================================================
472
+ // Core Send Helpers
473
+ // ============================================================================
474
+ /**
475
+ * Send a session message. For fire-and-forget messages (heartbeats, etc.),
476
+ * failures are suppressed if `suppressSendErrors` is configured.
477
+ * For RPC methods that wait for responses, use `sendSessionMessageOrThrow` instead.
478
+ */
479
+ sendSessionMessage(message) {
480
+ if (!this.transport || this.connectionState.status !== "connected") {
481
+ if (this.config.suppressSendErrors) {
482
+ return;
483
+ }
484
+ throw new Error(`Transport not connected (status: ${this.connectionState.status})`);
485
+ }
486
+ const payload = SessionInboundMessageSchema.parse(message);
487
+ try {
488
+ this.transport.send(JSON.stringify({ type: "session", message: payload }));
489
+ }
490
+ catch (error) {
491
+ if (this.config.suppressSendErrors) {
492
+ return;
493
+ }
494
+ throw error instanceof Error ? error : new Error(String(error));
495
+ }
496
+ }
497
+ sendBinaryFrame(frame) {
498
+ if (!this.transport || this.connectionState.status !== "connected") {
499
+ if (this.config.suppressSendErrors) {
500
+ return;
501
+ }
502
+ throw new Error(`Transport not connected (status: ${this.connectionState.status})`);
503
+ }
504
+ try {
505
+ this.transport.send(frame);
506
+ }
507
+ catch (error) {
508
+ if (this.config.suppressSendErrors) {
509
+ return;
510
+ }
511
+ throw error instanceof Error ? error : new Error(String(error));
512
+ }
513
+ }
514
+ /**
515
+ * Send a session message for RPC methods that create waiters.
516
+ * If the connection is still being established ("connecting"), the message
517
+ * is queued and will be sent once connected (or rejected after timeout).
518
+ * This prevents waiters from hanging forever when called during connection.
519
+ */
520
+ sendSessionMessageOrThrow(message) {
521
+ const status = this.connectionState.status;
522
+ // If connected, send immediately
523
+ if (this.transport && status === "connected") {
524
+ const payload = SessionInboundMessageSchema.parse(message);
525
+ this.transport.send(JSON.stringify({ type: "session", message: payload }));
526
+ return Promise.resolve();
527
+ }
528
+ // If connecting, queue the message to be sent once connected
529
+ if (status === "connecting") {
530
+ return new Promise((resolve, reject) => {
531
+ const timeoutHandle = setTimeout(() => {
532
+ // Remove from queue
533
+ const idx = this.pendingSendQueue.findIndex((p) => p.resolve === resolve);
534
+ if (idx !== -1) {
535
+ this.pendingSendQueue.splice(idx, 1);
536
+ }
537
+ reject(new Error(`Timed out waiting for connection to send message`));
538
+ }, DEFAULT_SEND_QUEUE_TIMEOUT_MS);
539
+ this.pendingSendQueue.push({ message, resolve, reject, timeoutHandle });
540
+ });
541
+ }
542
+ // Not connected and not connecting - fail immediately
543
+ return Promise.reject(new Error(`Transport not connected (status: ${status})`));
544
+ }
545
+ /**
546
+ * Flush pending send queue - called when connection is established.
547
+ */
548
+ flushPendingSendQueue() {
549
+ const queue = this.pendingSendQueue;
550
+ this.pendingSendQueue = [];
551
+ for (const pending of queue) {
552
+ clearTimeout(pending.timeoutHandle);
553
+ try {
554
+ if (this.transport && this.connectionState.status === "connected") {
555
+ const payload = SessionInboundMessageSchema.parse(pending.message);
556
+ this.transport.send(JSON.stringify({ type: "session", message: payload }));
557
+ pending.resolve();
558
+ }
559
+ else {
560
+ pending.reject(new Error("Connection lost before message could be sent"));
561
+ }
562
+ }
563
+ catch (error) {
564
+ pending.reject(error instanceof Error ? error : new Error(String(error)));
565
+ }
566
+ }
567
+ }
568
+ /**
569
+ * Reject all pending sends - called when connection fails or is closed.
570
+ */
571
+ rejectPendingSendQueue(error) {
572
+ const queue = this.pendingSendQueue;
573
+ this.pendingSendQueue = [];
574
+ for (const pending of queue) {
575
+ clearTimeout(pending.timeoutHandle);
576
+ pending.reject(error);
577
+ }
578
+ }
579
+ async sendRequest(params) {
580
+ const { promise, cancel } = this.waitForWithCancel((msg) => {
581
+ if (msg.type === "rpc_error" && msg.payload.requestId === params.requestId) {
582
+ return {
583
+ kind: "error",
584
+ error: new DaemonRpcError({
585
+ requestId: msg.payload.requestId,
586
+ error: msg.payload.error,
587
+ requestType: msg.payload.requestType,
588
+ code: msg.payload.code,
589
+ }),
590
+ };
591
+ }
592
+ const value = params.select(msg);
593
+ if (value === null) {
594
+ return null;
595
+ }
596
+ return { kind: "ok", value };
597
+ }, params.timeout, params.options);
598
+ try {
599
+ await this.sendSessionMessageOrThrow(params.message);
600
+ }
601
+ catch (error) {
602
+ const err = error instanceof Error ? error : new Error(String(error));
603
+ cancel(err);
604
+ void promise.catch(() => undefined);
605
+ throw err;
606
+ }
607
+ const result = await promise;
608
+ if (result.kind === "error") {
609
+ throw result.error;
610
+ }
611
+ return result.value;
612
+ }
613
+ async sendCorrelatedRequest(params) {
614
+ return this.sendRequest({
615
+ requestId: params.requestId,
616
+ message: params.message,
617
+ timeout: params.timeout,
618
+ options: params.options,
619
+ select: (msg) => {
620
+ const correlated = msg;
621
+ if (correlated.type !== params.responseType) {
622
+ return null;
623
+ }
624
+ const payload = correlated.payload;
625
+ if (payload.requestId !== params.requestId) {
626
+ return null;
627
+ }
628
+ if (!params.selectPayload) {
629
+ return payload;
630
+ }
631
+ return params.selectPayload(payload);
632
+ },
633
+ });
634
+ }
635
+ sendCorrelatedSessionRequest(params) {
636
+ const resolvedRequestId = this.createRequestId(params.requestId);
637
+ const message = SessionInboundMessageSchema.parse({
638
+ ...params.message,
639
+ requestId: resolvedRequestId,
640
+ });
641
+ return this.sendCorrelatedRequest({
642
+ requestId: resolvedRequestId,
643
+ message,
644
+ responseType: params.responseType,
645
+ timeout: params.timeout,
646
+ options: { skipQueue: true },
647
+ ...(params.selectPayload ? { selectPayload: params.selectPayload } : {}),
648
+ });
649
+ }
650
+ sendNamespacedCorrelatedSessionRequest(params) {
651
+ const responseType = params.message.type.replace(/\.request$/, ".response");
652
+ return this.sendCorrelatedSessionRequest({
653
+ ...params,
654
+ responseType,
655
+ });
656
+ }
657
+ sendSessionMessageStrict(message) {
658
+ if (!this.transport || this.connectionState.status !== "connected") {
659
+ throw new Error("Transport not connected");
660
+ }
661
+ const payload = SessionInboundMessageSchema.parse(message);
662
+ try {
663
+ this.transport.send(JSON.stringify({ type: "session", message: payload }));
664
+ }
665
+ catch (error) {
666
+ throw error instanceof Error ? error : new Error(String(error));
667
+ }
668
+ }
669
+ async clearAgentAttention(agentId) {
670
+ const requestId = this.createRequestId();
671
+ const message = SessionInboundMessageSchema.parse({
672
+ type: "clear_agent_attention",
673
+ agentId,
674
+ requestId,
675
+ });
676
+ await this.sendRequest({
677
+ requestId,
678
+ message,
679
+ timeout: 15000,
680
+ options: { skipQueue: true },
681
+ select: (msg) => {
682
+ if (msg.type !== "clear_agent_attention_response") {
683
+ return null;
684
+ }
685
+ if (msg.payload.requestId !== requestId) {
686
+ return null;
687
+ }
688
+ return msg.payload;
689
+ },
690
+ });
691
+ }
692
+ sendHeartbeat(params) {
693
+ this.sendSessionMessage({
694
+ type: "client_heartbeat",
695
+ deviceType: params.deviceType,
696
+ focusedAgentId: params.focusedAgentId,
697
+ lastActivityAt: params.lastActivityAt,
698
+ appVisible: params.appVisible,
699
+ appVisibilityChangedAt: params.appVisibilityChangedAt,
700
+ });
701
+ }
702
+ registerPushToken(token) {
703
+ this.sendSessionMessage({
704
+ type: "register_push_token",
705
+ token,
706
+ });
707
+ }
708
+ async ping(params) {
709
+ const requestId = params?.requestId ?? `ping-${Date.now()}-${Math.random().toString(36).slice(2)}`;
710
+ const clientSentAt = Date.now();
711
+ const payload = await this.sendRequest({
712
+ requestId,
713
+ message: { type: "ping", requestId, clientSentAt },
714
+ timeout: params?.timeoutMs ?? 5000,
715
+ select: (msg) => {
716
+ if (msg.type !== "pong")
717
+ return null;
718
+ if (msg.payload.requestId !== requestId)
719
+ return null;
720
+ if (typeof msg.payload.serverReceivedAt !== "number")
721
+ return null;
722
+ if (typeof msg.payload.serverSentAt !== "number")
723
+ return null;
724
+ return msg.payload;
725
+ },
726
+ });
727
+ return {
728
+ requestId,
729
+ clientSentAt,
730
+ serverReceivedAt: payload.serverReceivedAt,
731
+ serverSentAt: payload.serverSentAt,
732
+ rttMs: Date.now() - clientSentAt,
733
+ };
734
+ }
735
+ // ============================================================================
736
+ // Agent RPCs (requestId-correlated)
737
+ // ============================================================================
738
+ async fetchAgents(options) {
739
+ const resolvedRequestId = this.createRequestId(options?.requestId);
740
+ const message = SessionInboundMessageSchema.parse({
741
+ type: "fetch_agents_request",
742
+ requestId: resolvedRequestId,
743
+ ...(options?.scope ? { scope: options.scope } : {}),
744
+ ...(options?.filter ? { filter: options.filter } : {}),
745
+ ...(options?.sort ? { sort: options.sort } : {}),
746
+ ...(options?.page ? { page: options.page } : {}),
747
+ ...(options?.subscribe ? { subscribe: options.subscribe } : {}),
748
+ });
749
+ return this.sendRequest({
750
+ requestId: resolvedRequestId,
751
+ message,
752
+ timeout: 10000,
753
+ options: { skipQueue: true },
754
+ select: (msg) => {
755
+ if (msg.type !== "fetch_agents_response") {
756
+ return null;
757
+ }
758
+ if (msg.payload.requestId !== resolvedRequestId) {
759
+ return null;
760
+ }
761
+ return msg.payload;
762
+ },
763
+ });
764
+ }
765
+ async fetchAgentHistory(options) {
766
+ const resolvedRequestId = this.createRequestId(options?.requestId);
767
+ const message = SessionInboundMessageSchema.parse({
768
+ type: "fetch_agent_history_request",
769
+ requestId: resolvedRequestId,
770
+ ...(options?.filter ? { filter: options.filter } : {}),
771
+ ...(options?.sort ? { sort: options.sort } : {}),
772
+ ...(options?.page ? { page: options.page } : {}),
773
+ });
774
+ return this.sendRequest({
775
+ requestId: resolvedRequestId,
776
+ message,
777
+ timeout: 10000,
778
+ options: { skipQueue: true },
779
+ select: (msg) => {
780
+ if (msg.type !== "fetch_agent_history_response") {
781
+ return null;
782
+ }
783
+ if (msg.payload.requestId !== resolvedRequestId) {
784
+ return null;
785
+ }
786
+ return msg.payload;
787
+ },
788
+ });
789
+ }
790
+ async fetchRecentProviderSessions(options) {
791
+ const resolvedRequestId = this.createRequestId(options?.requestId);
792
+ const message = SessionInboundMessageSchema.parse({
793
+ type: "fetch_recent_provider_sessions_request",
794
+ requestId: resolvedRequestId,
795
+ ...(options?.cwd ? { cwd: options.cwd } : {}),
796
+ ...(options?.providers ? { providers: options.providers } : {}),
797
+ ...(options?.since ? { since: options.since } : {}),
798
+ ...(options?.limit ? { limit: options.limit } : {}),
799
+ });
800
+ return this.sendRequest({
801
+ requestId: resolvedRequestId,
802
+ message,
803
+ timeout: 10000,
804
+ options: { skipQueue: true },
805
+ select: (msg) => {
806
+ if (msg.type !== "fetch_recent_provider_sessions_response") {
807
+ return null;
808
+ }
809
+ if (msg.payload.requestId !== resolvedRequestId) {
810
+ return null;
811
+ }
812
+ return msg.payload;
813
+ },
814
+ });
815
+ }
816
+ async fetchWorkspaces(options) {
817
+ const resolvedRequestId = this.createRequestId(options?.requestId);
818
+ const message = SessionInboundMessageSchema.parse({
819
+ type: "fetch_workspaces_request",
820
+ requestId: resolvedRequestId,
821
+ ...(options?.filter ? { filter: options.filter } : {}),
822
+ ...(options?.sort ? { sort: options.sort } : {}),
823
+ ...(options?.page ? { page: options.page } : {}),
824
+ ...(options?.subscribe ? { subscribe: options.subscribe } : {}),
825
+ });
826
+ return this.sendRequest({
827
+ requestId: resolvedRequestId,
828
+ message,
829
+ timeout: 10000,
830
+ options: { skipQueue: true },
831
+ select: (msg) => {
832
+ if (msg.type !== "fetch_workspaces_response") {
833
+ return null;
834
+ }
835
+ if (msg.payload.requestId !== resolvedRequestId) {
836
+ return null;
837
+ }
838
+ return msg.payload;
839
+ },
840
+ });
841
+ }
842
+ async openProject(cwd, requestId) {
843
+ return this.sendCorrelatedSessionRequest({
844
+ requestId,
845
+ message: {
846
+ type: "open_project_request",
847
+ cwd,
848
+ },
849
+ responseType: "open_project_response",
850
+ timeout: 10000,
851
+ });
852
+ }
853
+ async startWorkspaceScript(workspaceId, scriptName, requestId) {
854
+ return this.sendCorrelatedSessionRequest({
855
+ requestId,
856
+ message: {
857
+ type: "start_workspace_script_request",
858
+ workspaceId,
859
+ scriptName,
860
+ },
861
+ responseType: "start_workspace_script_response",
862
+ timeout: 10000,
863
+ });
864
+ }
865
+ async listAvailableEditors(requestId) {
866
+ return this.sendCorrelatedSessionRequest({
867
+ requestId,
868
+ message: {
869
+ type: "list_available_editors_request",
870
+ },
871
+ responseType: "list_available_editors_response",
872
+ timeout: 10000,
873
+ });
874
+ }
875
+ async openInEditor(path, editorId, requestId) {
876
+ return this.sendCorrelatedSessionRequest({
877
+ requestId,
878
+ message: {
879
+ type: "open_in_editor_request",
880
+ path,
881
+ editorId,
882
+ },
883
+ responseType: "open_in_editor_response",
884
+ timeout: 10000,
885
+ });
886
+ }
887
+ async archiveWorkspace(workspaceId, requestId) {
888
+ return this.sendCorrelatedSessionRequest({
889
+ requestId,
890
+ message: {
891
+ type: "archive_workspace_request",
892
+ workspaceId,
893
+ },
894
+ responseType: "archive_workspace_response",
895
+ timeout: 10000,
896
+ });
897
+ }
898
+ async fetchWorkspaceSetupStatus(workspaceId, requestId) {
899
+ return this.sendCorrelatedSessionRequest({
900
+ requestId,
901
+ message: {
902
+ type: "workspace_setup_status_request",
903
+ workspaceId,
904
+ },
905
+ responseType: "workspace_setup_status_response",
906
+ timeout: 10000,
907
+ });
908
+ }
909
+ async fetchAgent(agentId, requestId) {
910
+ const resolvedRequestId = this.createRequestId(requestId);
911
+ const message = SessionInboundMessageSchema.parse({
912
+ type: "fetch_agent_request",
913
+ requestId: resolvedRequestId,
914
+ agentId,
915
+ });
916
+ const payload = await this.sendRequest({
917
+ requestId: resolvedRequestId,
918
+ message,
919
+ timeout: 10000,
920
+ options: { skipQueue: true },
921
+ select: (msg) => {
922
+ if (msg.type !== "fetch_agent_response") {
923
+ return null;
924
+ }
925
+ if (msg.payload.requestId !== resolvedRequestId) {
926
+ return null;
927
+ }
928
+ return msg.payload;
929
+ },
930
+ });
931
+ if (payload.error) {
932
+ throw new Error(payload.error);
933
+ }
934
+ if (!payload.agent) {
935
+ return null;
936
+ }
937
+ return { agent: payload.agent, project: payload.project ?? null };
938
+ }
939
+ resubscribeCheckoutDiffSubscriptions() {
940
+ if (this.checkoutDiffSubscriptions.size === 0) {
941
+ return;
942
+ }
943
+ for (const [subscriptionId, subscription] of this.checkoutDiffSubscriptions) {
944
+ const message = SessionInboundMessageSchema.parse({
945
+ type: "subscribe_checkout_diff_request",
946
+ subscriptionId,
947
+ cwd: subscription.cwd,
948
+ compare: subscription.compare,
949
+ requestId: this.createRequestId(),
950
+ });
951
+ this.sendSessionMessage(message);
952
+ }
953
+ }
954
+ resubscribeTerminalDirectorySubscriptions() {
955
+ if (this.terminalDirectorySubscriptions.size === 0) {
956
+ return;
957
+ }
958
+ for (const cwd of this.terminalDirectorySubscriptions) {
959
+ this.sendSessionMessage({
960
+ type: "subscribe_terminals_request",
961
+ cwd,
962
+ });
963
+ }
964
+ }
965
+ // ============================================================================
966
+ // Agent Lifecycle
967
+ // ============================================================================
968
+ async createAgent(options) {
969
+ const requestId = this.createRequestId(options.requestId);
970
+ const config = resolveAgentConfig(options);
971
+ const message = SessionInboundMessageSchema.parse({
972
+ type: "create_agent_request",
973
+ requestId,
974
+ config,
975
+ ...(options.workspaceId !== undefined ? { workspaceId: options.workspaceId } : {}),
976
+ ...(options.initialPrompt ? { initialPrompt: options.initialPrompt } : {}),
977
+ ...(options.clientMessageId ? { clientMessageId: options.clientMessageId } : {}),
978
+ ...(options.outputSchema ? { outputSchema: options.outputSchema } : {}),
979
+ ...(options.images && options.images.length > 0 ? { images: options.images } : {}),
980
+ ...(options.attachments && options.attachments.length > 0
981
+ ? { attachments: options.attachments }
982
+ : {}),
983
+ ...(options.git ? { git: options.git } : {}),
984
+ ...(options.worktreeName ? { worktreeName: options.worktreeName } : {}),
985
+ ...(options.labels && Object.keys(options.labels).length > 0
986
+ ? { labels: options.labels }
987
+ : {}),
988
+ });
989
+ const status = await this.sendRequest({
990
+ requestId,
991
+ message,
992
+ timeout: 60000,
993
+ options: { skipQueue: true },
994
+ select: (msg) => {
995
+ if (msg.type !== "status") {
996
+ return null;
997
+ }
998
+ const created = AgentCreatedStatusPayloadSchema.safeParse(msg.payload);
999
+ if (created.success && created.data.requestId === requestId) {
1000
+ return created.data;
1001
+ }
1002
+ const failed = AgentCreateFailedStatusPayloadSchema.safeParse(msg.payload);
1003
+ if (failed.success && failed.data.requestId === requestId) {
1004
+ return failed.data;
1005
+ }
1006
+ return null;
1007
+ },
1008
+ });
1009
+ if (status.status === "agent_create_failed") {
1010
+ throw new Error(status.error);
1011
+ }
1012
+ return status.agent;
1013
+ }
1014
+ async deleteAgent(agentId) {
1015
+ const requestId = this.createRequestId();
1016
+ const message = SessionInboundMessageSchema.parse({
1017
+ type: "delete_agent_request",
1018
+ agentId,
1019
+ requestId,
1020
+ });
1021
+ await this.sendRequest({
1022
+ requestId,
1023
+ message,
1024
+ timeout: 10000,
1025
+ options: { skipQueue: true },
1026
+ select: (msg) => {
1027
+ if (msg.type !== "agent_deleted") {
1028
+ return null;
1029
+ }
1030
+ if (msg.payload.requestId !== requestId) {
1031
+ return null;
1032
+ }
1033
+ return msg.payload;
1034
+ },
1035
+ });
1036
+ }
1037
+ async archiveAgent(agentId) {
1038
+ const requestId = this.createRequestId();
1039
+ const message = SessionInboundMessageSchema.parse({
1040
+ type: "archive_agent_request",
1041
+ agentId,
1042
+ requestId,
1043
+ });
1044
+ const result = await this.sendRequest({
1045
+ requestId,
1046
+ message,
1047
+ timeout: 10000,
1048
+ options: { skipQueue: true },
1049
+ select: (msg) => {
1050
+ if (msg.type !== "agent_archived") {
1051
+ return null;
1052
+ }
1053
+ if (msg.payload.requestId !== requestId) {
1054
+ return null;
1055
+ }
1056
+ return msg.payload;
1057
+ },
1058
+ });
1059
+ return { archivedAt: result.archivedAt };
1060
+ }
1061
+ async updateAgent(agentId, updates) {
1062
+ const requestId = this.createRequestId();
1063
+ const message = SessionInboundMessageSchema.parse({
1064
+ type: "update_agent_request",
1065
+ agentId,
1066
+ ...(updates.name !== undefined ? { name: updates.name } : {}),
1067
+ ...(updates.labels && Object.keys(updates.labels).length > 0
1068
+ ? { labels: updates.labels }
1069
+ : {}),
1070
+ requestId,
1071
+ });
1072
+ const payload = await this.sendRequest({
1073
+ requestId,
1074
+ message,
1075
+ timeout: 10000,
1076
+ options: { skipQueue: true },
1077
+ select: (msg) => {
1078
+ if (msg.type !== "update_agent_response") {
1079
+ return null;
1080
+ }
1081
+ if (msg.payload.requestId !== requestId) {
1082
+ return null;
1083
+ }
1084
+ return msg.payload;
1085
+ },
1086
+ });
1087
+ if (!payload.accepted) {
1088
+ throw new Error(payload.error ?? "updateAgent rejected");
1089
+ }
1090
+ }
1091
+ async renameProject(projectId, customName, requestId) {
1092
+ const payload = await this.sendCorrelatedSessionRequest({
1093
+ requestId,
1094
+ message: {
1095
+ type: "project.rename.request",
1096
+ projectId,
1097
+ customName,
1098
+ },
1099
+ responseType: "project.rename.response",
1100
+ timeout: 10000,
1101
+ });
1102
+ if (!payload.accepted) {
1103
+ throw new Error(payload.error ?? "renameProject rejected");
1104
+ }
1105
+ return { customName: payload.customName };
1106
+ }
1107
+ async resumeAgent(handle, overrides) {
1108
+ const requestId = this.createRequestId();
1109
+ const message = SessionInboundMessageSchema.parse({
1110
+ type: "resume_agent_request",
1111
+ requestId,
1112
+ handle,
1113
+ ...(overrides ? { overrides } : {}),
1114
+ });
1115
+ const status = await this.sendRequest({
1116
+ requestId,
1117
+ message,
1118
+ timeout: 15000,
1119
+ options: { skipQueue: true },
1120
+ select: (msg) => {
1121
+ if (msg.type !== "status") {
1122
+ return null;
1123
+ }
1124
+ const resumed = AgentResumedStatusPayloadSchema.safeParse(msg.payload);
1125
+ if (resumed.success && resumed.data.requestId === requestId) {
1126
+ return resumed.data;
1127
+ }
1128
+ return null;
1129
+ },
1130
+ });
1131
+ return status.agent;
1132
+ }
1133
+ async importAgent(input) {
1134
+ const requestId = this.createRequestId();
1135
+ const message = SessionInboundMessageSchema.parse({
1136
+ type: "import_agent_request",
1137
+ requestId,
1138
+ ...("providerId" in input
1139
+ ? { providerId: input.providerId, providerHandleId: input.providerHandleId }
1140
+ : { provider: input.provider, sessionId: input.sessionId }),
1141
+ ...(input.cwd ? { cwd: input.cwd } : {}),
1142
+ ...(input.labels && Object.keys(input.labels).length > 0 ? { labels: input.labels } : {}),
1143
+ });
1144
+ const status = await this.sendRequest({
1145
+ requestId,
1146
+ message,
1147
+ timeout: 15000,
1148
+ options: { skipQueue: true },
1149
+ select: (msg) => {
1150
+ if (msg.type !== "status") {
1151
+ return null;
1152
+ }
1153
+ const resumed = AgentResumedStatusPayloadSchema.safeParse(msg.payload);
1154
+ if (resumed.success && resumed.data.requestId === requestId) {
1155
+ return resumed.data;
1156
+ }
1157
+ const failed = AgentCreateFailedStatusPayloadSchema.safeParse(msg.payload);
1158
+ if (failed.success && failed.data.requestId === requestId) {
1159
+ return failed.data;
1160
+ }
1161
+ return null;
1162
+ },
1163
+ });
1164
+ if (status.status === "agent_create_failed") {
1165
+ throw new Error(status.error);
1166
+ }
1167
+ return status.agent;
1168
+ }
1169
+ async refreshAgent(agentId, requestId) {
1170
+ const resolvedRequestId = this.createRequestId(requestId);
1171
+ const message = SessionInboundMessageSchema.parse({
1172
+ type: "refresh_agent_request",
1173
+ agentId,
1174
+ requestId: resolvedRequestId,
1175
+ });
1176
+ return this.sendRequest({
1177
+ requestId: resolvedRequestId,
1178
+ message,
1179
+ timeout: 15000,
1180
+ options: { skipQueue: true },
1181
+ select: (msg) => {
1182
+ if (msg.type !== "status") {
1183
+ return null;
1184
+ }
1185
+ const refreshed = AgentRefreshedStatusPayloadSchema.safeParse(msg.payload);
1186
+ if (refreshed.success && refreshed.data.requestId === resolvedRequestId) {
1187
+ return refreshed.data;
1188
+ }
1189
+ return null;
1190
+ },
1191
+ });
1192
+ }
1193
+ async fetchAgentTimeline(agentId, options = {}) {
1194
+ const resolvedRequestId = this.createRequestId(options.requestId);
1195
+ const message = SessionInboundMessageSchema.parse({
1196
+ type: "fetch_agent_timeline_request",
1197
+ agentId,
1198
+ requestId: resolvedRequestId,
1199
+ ...(options.direction ? { direction: options.direction } : {}),
1200
+ ...(options.cursor ? { cursor: options.cursor } : {}),
1201
+ ...(typeof options.limit === "number" ? { limit: options.limit } : {}),
1202
+ ...(options.projection ? { projection: options.projection } : {}),
1203
+ });
1204
+ const payload = await this.sendRequest({
1205
+ requestId: resolvedRequestId,
1206
+ message,
1207
+ timeout: 15000,
1208
+ options: { skipQueue: true },
1209
+ select: (msg) => {
1210
+ if (msg.type !== "fetch_agent_timeline_response") {
1211
+ return null;
1212
+ }
1213
+ if (msg.payload.requestId !== resolvedRequestId) {
1214
+ return null;
1215
+ }
1216
+ return msg.payload;
1217
+ },
1218
+ });
1219
+ if (payload.error) {
1220
+ throw new Error(payload.error);
1221
+ }
1222
+ return payload;
1223
+ }
1224
+ // ============================================================================
1225
+ // Agent Interaction
1226
+ // ============================================================================
1227
+ async sendAgentMessage(agentId, text, options) {
1228
+ const requestId = this.createRequestId();
1229
+ const messageId = options?.messageId ?? crypto.randomUUID();
1230
+ const message = SessionInboundMessageSchema.parse({
1231
+ type: "send_agent_message_request",
1232
+ requestId,
1233
+ agentId,
1234
+ text,
1235
+ ...(messageId ? { messageId } : {}),
1236
+ ...(options?.images ? { images: options.images } : {}),
1237
+ ...(options?.attachments ? { attachments: options.attachments } : {}),
1238
+ });
1239
+ const payload = await this.sendRequest({
1240
+ requestId,
1241
+ message,
1242
+ timeout: 15000,
1243
+ options: { skipQueue: true },
1244
+ select: (msg) => {
1245
+ if (msg.type !== "send_agent_message_response") {
1246
+ return null;
1247
+ }
1248
+ if (msg.payload.requestId !== requestId) {
1249
+ return null;
1250
+ }
1251
+ return msg.payload;
1252
+ },
1253
+ });
1254
+ if (!payload.accepted) {
1255
+ throw new Error(payload.error ?? "sendAgentMessage rejected");
1256
+ }
1257
+ }
1258
+ async sendMessage(agentId, text, options) {
1259
+ await this.sendAgentMessage(agentId, text, options);
1260
+ }
1261
+ async cancelAgent(agentId) {
1262
+ const requestId = this.createRequestId();
1263
+ const message = SessionInboundMessageSchema.parse({
1264
+ type: "cancel_agent_request",
1265
+ agentId,
1266
+ requestId,
1267
+ });
1268
+ await this.sendRequest({
1269
+ requestId,
1270
+ message,
1271
+ timeout: 15000,
1272
+ options: { skipQueue: true },
1273
+ select: (msg) => {
1274
+ if (msg.type !== "cancel_agent_response") {
1275
+ return null;
1276
+ }
1277
+ if (msg.payload.requestId !== requestId) {
1278
+ return null;
1279
+ }
1280
+ return msg.payload;
1281
+ },
1282
+ });
1283
+ }
1284
+ async setAgentMode(agentId, modeId) {
1285
+ const requestId = this.createRequestId();
1286
+ const message = SessionInboundMessageSchema.parse({
1287
+ type: "set_agent_mode_request",
1288
+ agentId,
1289
+ modeId,
1290
+ requestId,
1291
+ });
1292
+ const payload = await this.sendRequest({
1293
+ requestId,
1294
+ message,
1295
+ timeout: 15000,
1296
+ options: { skipQueue: true },
1297
+ select: (msg) => {
1298
+ if (msg.type !== "set_agent_mode_response") {
1299
+ return null;
1300
+ }
1301
+ if (msg.payload.requestId !== requestId) {
1302
+ return null;
1303
+ }
1304
+ return msg.payload;
1305
+ },
1306
+ });
1307
+ if (!payload.accepted) {
1308
+ throw new Error(payload.error ?? "setAgentMode rejected");
1309
+ }
1310
+ }
1311
+ async setAgentModel(agentId, modelId) {
1312
+ const requestId = this.createRequestId();
1313
+ const message = SessionInboundMessageSchema.parse({
1314
+ type: "set_agent_model_request",
1315
+ agentId,
1316
+ modelId,
1317
+ requestId,
1318
+ });
1319
+ const payload = await this.sendRequest({
1320
+ requestId,
1321
+ message,
1322
+ timeout: 15000,
1323
+ options: { skipQueue: true },
1324
+ select: (msg) => {
1325
+ if (msg.type !== "set_agent_model_response") {
1326
+ return null;
1327
+ }
1328
+ if (msg.payload.requestId !== requestId) {
1329
+ return null;
1330
+ }
1331
+ return msg.payload;
1332
+ },
1333
+ });
1334
+ if (!payload.accepted) {
1335
+ throw new Error(payload.error ?? "setAgentModel rejected");
1336
+ }
1337
+ }
1338
+ async setAgentFeature(agentId, featureId, value) {
1339
+ const requestId = this.createRequestId();
1340
+ const message = SessionInboundMessageSchema.parse({
1341
+ type: "set_agent_feature_request",
1342
+ agentId,
1343
+ featureId,
1344
+ value,
1345
+ requestId,
1346
+ });
1347
+ const payload = await this.sendRequest({
1348
+ requestId,
1349
+ message,
1350
+ timeout: 15000,
1351
+ options: { skipQueue: true },
1352
+ select: (msg) => {
1353
+ if (msg.type !== "set_agent_feature_response") {
1354
+ return null;
1355
+ }
1356
+ if (msg.payload.requestId !== requestId) {
1357
+ return null;
1358
+ }
1359
+ return msg.payload;
1360
+ },
1361
+ });
1362
+ if (!payload.accepted) {
1363
+ throw new Error(payload.error ?? "setAgentFeature rejected");
1364
+ }
1365
+ }
1366
+ async setAgentThinkingOption(agentId, thinkingOptionId) {
1367
+ const requestId = this.createRequestId();
1368
+ const message = SessionInboundMessageSchema.parse({
1369
+ type: "set_agent_thinking_request",
1370
+ agentId,
1371
+ thinkingOptionId,
1372
+ requestId,
1373
+ });
1374
+ const payload = await this.sendRequest({
1375
+ requestId,
1376
+ message,
1377
+ timeout: 15000,
1378
+ options: { skipQueue: true },
1379
+ select: (msg) => {
1380
+ if (msg.type !== "set_agent_thinking_response") {
1381
+ return null;
1382
+ }
1383
+ if (msg.payload.requestId !== requestId) {
1384
+ return null;
1385
+ }
1386
+ return msg.payload;
1387
+ },
1388
+ });
1389
+ if (!payload.accepted) {
1390
+ throw new Error(payload.error ?? "setAgentThinkingOption rejected");
1391
+ }
1392
+ }
1393
+ async restartServer(reason, requestId) {
1394
+ const resolvedRequestId = this.createRequestId(requestId);
1395
+ const message = SessionInboundMessageSchema.parse({
1396
+ type: "restart_server_request",
1397
+ ...(reason && reason.trim().length > 0 ? { reason } : {}),
1398
+ requestId: resolvedRequestId,
1399
+ });
1400
+ return this.sendRequest({
1401
+ requestId: resolvedRequestId,
1402
+ message,
1403
+ timeout: 10000,
1404
+ options: { skipQueue: true },
1405
+ select: (msg) => {
1406
+ if (msg.type !== "status") {
1407
+ return null;
1408
+ }
1409
+ const restarted = RestartRequestedStatusPayloadSchema.safeParse(msg.payload);
1410
+ if (!restarted.success) {
1411
+ return null;
1412
+ }
1413
+ if (restarted.data.requestId !== resolvedRequestId) {
1414
+ return null;
1415
+ }
1416
+ return restarted.data;
1417
+ },
1418
+ });
1419
+ }
1420
+ async shutdownServer(requestId) {
1421
+ const resolvedRequestId = this.createRequestId(requestId);
1422
+ const message = SessionInboundMessageSchema.parse({
1423
+ type: "shutdown_server_request",
1424
+ requestId: resolvedRequestId,
1425
+ });
1426
+ return this.sendRequest({
1427
+ requestId: resolvedRequestId,
1428
+ message,
1429
+ timeout: 10000,
1430
+ options: { skipQueue: true },
1431
+ select: (msg) => {
1432
+ if (msg.type !== "status") {
1433
+ return null;
1434
+ }
1435
+ const shutdown = ShutdownRequestedStatusPayloadSchema.safeParse(msg.payload);
1436
+ if (!shutdown.success) {
1437
+ return null;
1438
+ }
1439
+ if (shutdown.data.requestId !== resolvedRequestId) {
1440
+ return null;
1441
+ }
1442
+ return shutdown.data;
1443
+ },
1444
+ });
1445
+ }
1446
+ // ============================================================================
1447
+ // Audio / Voice
1448
+ // ============================================================================
1449
+ async setVoiceMode(enabled, agentId) {
1450
+ const requestId = this.createRequestId();
1451
+ const message = SessionInboundMessageSchema.parse({
1452
+ type: "set_voice_mode",
1453
+ enabled,
1454
+ ...(agentId ? { agentId } : {}),
1455
+ requestId,
1456
+ });
1457
+ const response = await this.sendRequest({
1458
+ requestId,
1459
+ message,
1460
+ timeout: 10000,
1461
+ select: (msg) => {
1462
+ if (msg.type !== "set_voice_mode_response") {
1463
+ return null;
1464
+ }
1465
+ if (msg.payload.requestId !== requestId) {
1466
+ return null;
1467
+ }
1468
+ return msg.payload;
1469
+ },
1470
+ });
1471
+ if (!response.accepted) {
1472
+ const codeSuffix = typeof response.reasonCode === "string" && response.reasonCode.trim().length > 0
1473
+ ? ` (${response.reasonCode})`
1474
+ : "";
1475
+ throw new Error((response.error ?? "Failed to set voice mode") + codeSuffix);
1476
+ }
1477
+ return response;
1478
+ }
1479
+ async sendVoiceAudioChunk(audio, format, isLast = false) {
1480
+ this.sendSessionMessage({ type: "voice_audio_chunk", audio, format, isLast });
1481
+ }
1482
+ async startDictationStream(dictationId, format) {
1483
+ const ack = this.waitForWithCancel((msg) => {
1484
+ if (msg.type !== "dictation_stream_ack") {
1485
+ return null;
1486
+ }
1487
+ if (msg.payload.dictationId !== dictationId) {
1488
+ return null;
1489
+ }
1490
+ if (msg.payload.ackSeq !== -1) {
1491
+ return null;
1492
+ }
1493
+ return msg.payload;
1494
+ }, 30000, { skipQueue: true });
1495
+ const ackPromise = ack.promise.then(() => undefined);
1496
+ const streamError = this.waitForWithCancel((msg) => {
1497
+ if (msg.type !== "dictation_stream_error") {
1498
+ return null;
1499
+ }
1500
+ if (msg.payload.dictationId !== dictationId) {
1501
+ return null;
1502
+ }
1503
+ return msg.payload;
1504
+ }, 30000, { skipQueue: true });
1505
+ const errorPromise = streamError.promise.then((payload) => {
1506
+ throw new Error(payload.error);
1507
+ });
1508
+ const cleanupError = new Error("Cancelled dictation start waiter");
1509
+ try {
1510
+ this.sendSessionMessageStrict({ type: "dictation_stream_start", dictationId, format });
1511
+ await Promise.race([ackPromise, errorPromise]);
1512
+ }
1513
+ finally {
1514
+ ack.cancel(cleanupError);
1515
+ streamError.cancel(cleanupError);
1516
+ void ackPromise.catch(() => undefined);
1517
+ void errorPromise.catch(() => undefined);
1518
+ }
1519
+ }
1520
+ sendDictationStreamChunk(dictationId, seq, audio, format) {
1521
+ this.sendSessionMessageStrict({
1522
+ type: "dictation_stream_chunk",
1523
+ dictationId,
1524
+ seq,
1525
+ audio,
1526
+ format,
1527
+ });
1528
+ }
1529
+ async finishDictationStream(dictationId, finalSeq) {
1530
+ const final = this.waitForWithCancel((msg) => {
1531
+ if (msg.type !== "dictation_stream_final") {
1532
+ return null;
1533
+ }
1534
+ if (msg.payload.dictationId !== dictationId) {
1535
+ return null;
1536
+ }
1537
+ return msg.payload;
1538
+ }, 0, { skipQueue: true });
1539
+ const streamError = this.waitForWithCancel((msg) => {
1540
+ if (msg.type !== "dictation_stream_error") {
1541
+ return null;
1542
+ }
1543
+ if (msg.payload.dictationId !== dictationId) {
1544
+ return null;
1545
+ }
1546
+ return msg.payload;
1547
+ }, 0, { skipQueue: true });
1548
+ const finishAccepted = this.waitForWithCancel((msg) => {
1549
+ if (msg.type !== "dictation_stream_finish_accepted") {
1550
+ return null;
1551
+ }
1552
+ if (msg.payload.dictationId !== dictationId) {
1553
+ return null;
1554
+ }
1555
+ return msg.payload;
1556
+ }, DEFAULT_DICTATION_FINISH_ACCEPT_TIMEOUT_MS, { skipQueue: true });
1557
+ const finalPromise = final.promise;
1558
+ const errorPromise = streamError.promise.then((payload) => {
1559
+ throw new Error(payload.error);
1560
+ });
1561
+ const finishAcceptedPromise = finishAccepted.promise;
1562
+ const finalOutcomePromise = finalPromise.then((payload) => ({
1563
+ kind: "final",
1564
+ payload,
1565
+ }));
1566
+ const errorOutcomePromise = errorPromise.then(() => ({
1567
+ kind: "error",
1568
+ error: new Error("Unexpected dictation stream error state"),
1569
+ }), (error) => ({
1570
+ kind: "error",
1571
+ error: error instanceof Error ? error : new Error(String(error)),
1572
+ }));
1573
+ const finishAcceptedOutcomePromise = finishAcceptedPromise.then((payload) => ({ kind: "accepted", payload }), (error) => {
1574
+ if (isWaiterTimeoutError(error)) {
1575
+ return { kind: "accepted_timeout" };
1576
+ }
1577
+ return {
1578
+ kind: "accepted_error",
1579
+ error: error instanceof Error ? error : new Error(String(error)),
1580
+ };
1581
+ });
1582
+ const waitForFinalResult = async (timeoutMs) => {
1583
+ if (!Number.isFinite(timeoutMs) || timeoutMs <= 0) {
1584
+ const outcome = await Promise.race([finalOutcomePromise, errorOutcomePromise]);
1585
+ if (outcome.kind === "error") {
1586
+ throw outcome.error;
1587
+ }
1588
+ return outcome.payload;
1589
+ }
1590
+ let timeoutHandle = null;
1591
+ const timeoutPromise = new Promise((resolve) => {
1592
+ timeoutHandle = setTimeout(() => resolve({ kind: "timeout" }), timeoutMs);
1593
+ });
1594
+ const outcome = await Promise.race([
1595
+ finalOutcomePromise,
1596
+ errorOutcomePromise,
1597
+ timeoutPromise,
1598
+ ]);
1599
+ if (timeoutHandle) {
1600
+ clearTimeout(timeoutHandle);
1601
+ }
1602
+ if (outcome.kind === "timeout") {
1603
+ throw new Error(`Timeout waiting for dictation finalization (${timeoutMs}ms)`);
1604
+ }
1605
+ if (outcome.kind === "error") {
1606
+ throw outcome.error;
1607
+ }
1608
+ return outcome.payload;
1609
+ };
1610
+ const cleanupError = new Error("Cancelled dictation finish waiter");
1611
+ try {
1612
+ this.sendSessionMessageStrict({ type: "dictation_stream_finish", dictationId, finalSeq });
1613
+ const firstOutcome = await Promise.race([
1614
+ finalOutcomePromise,
1615
+ errorOutcomePromise,
1616
+ finishAcceptedOutcomePromise,
1617
+ ]);
1618
+ if (firstOutcome.kind === "final") {
1619
+ return firstOutcome.payload;
1620
+ }
1621
+ if (firstOutcome.kind === "error") {
1622
+ throw firstOutcome.error;
1623
+ }
1624
+ if (firstOutcome.kind === "accepted") {
1625
+ return await waitForFinalResult(firstOutcome.payload.timeoutMs + DEFAULT_DICTATION_FINISH_TIMEOUT_GRACE_MS);
1626
+ }
1627
+ return await waitForFinalResult(DEFAULT_DICTATION_FINISH_FALLBACK_TIMEOUT_MS);
1628
+ }
1629
+ finally {
1630
+ final.cancel(cleanupError);
1631
+ streamError.cancel(cleanupError);
1632
+ finishAccepted.cancel(cleanupError);
1633
+ void finalPromise.catch(() => undefined);
1634
+ void errorPromise.catch(() => undefined);
1635
+ void finishAcceptedPromise.catch(() => undefined);
1636
+ }
1637
+ }
1638
+ cancelDictationStream(dictationId) {
1639
+ this.sendSessionMessageStrict({ type: "dictation_stream_cancel", dictationId });
1640
+ }
1641
+ async abortRequest() {
1642
+ this.sendSessionMessage({ type: "abort_request" });
1643
+ }
1644
+ async audioPlayed(id) {
1645
+ this.sendSessionMessage({ type: "audio_played", id });
1646
+ }
1647
+ // ============================================================================
1648
+ // Git Operations
1649
+ // ============================================================================
1650
+ async getCheckoutStatus(cwd, options) {
1651
+ const requestId = options?.requestId;
1652
+ if (!requestId) {
1653
+ const existing = this.checkoutStatusInFlight.get(cwd);
1654
+ if (existing) {
1655
+ return existing;
1656
+ }
1657
+ }
1658
+ const resolvedRequestId = this.createRequestId(requestId);
1659
+ const message = SessionInboundMessageSchema.parse({
1660
+ type: "checkout_status_request",
1661
+ cwd,
1662
+ requestId: resolvedRequestId,
1663
+ });
1664
+ const responsePromise = this.sendRequest({
1665
+ requestId: resolvedRequestId,
1666
+ message,
1667
+ timeout: 60000,
1668
+ options: { skipQueue: true },
1669
+ select: (msg) => {
1670
+ if (msg.type !== "checkout_status_response") {
1671
+ return null;
1672
+ }
1673
+ if (msg.payload.requestId !== resolvedRequestId) {
1674
+ return null;
1675
+ }
1676
+ return msg.payload;
1677
+ },
1678
+ });
1679
+ if (!requestId) {
1680
+ this.checkoutStatusInFlight.set(cwd, responsePromise);
1681
+ void responsePromise
1682
+ .finally(() => {
1683
+ if (this.checkoutStatusInFlight.get(cwd) === responsePromise) {
1684
+ this.checkoutStatusInFlight.delete(cwd);
1685
+ }
1686
+ })
1687
+ .catch(() => undefined);
1688
+ }
1689
+ return responsePromise;
1690
+ }
1691
+ normalizeCheckoutDiffCompare(compare) {
1692
+ if (compare.mode === "uncommitted") {
1693
+ return compare.ignoreWhitespace === true
1694
+ ? { mode: "uncommitted", ignoreWhitespace: true }
1695
+ : { mode: "uncommitted" };
1696
+ }
1697
+ const trimmedBaseRef = compare.baseRef?.trim();
1698
+ if (!trimmedBaseRef) {
1699
+ return compare.ignoreWhitespace === true
1700
+ ? { mode: "base", ignoreWhitespace: true }
1701
+ : { mode: "base" };
1702
+ }
1703
+ return compare.ignoreWhitespace === true
1704
+ ? { mode: "base", baseRef: trimmedBaseRef, ignoreWhitespace: true }
1705
+ : { mode: "base", baseRef: trimmedBaseRef };
1706
+ }
1707
+ async getCheckoutDiff(cwd, compare, requestId) {
1708
+ const oneShotSubscriptionId = `oneshot-checkout-diff:${crypto.randomUUID()}`;
1709
+ try {
1710
+ const payload = await this.subscribeCheckoutDiff(cwd, compare, {
1711
+ subscriptionId: oneShotSubscriptionId,
1712
+ requestId,
1713
+ });
1714
+ return {
1715
+ cwd: payload.cwd,
1716
+ files: payload.files,
1717
+ error: payload.error,
1718
+ requestId: payload.requestId,
1719
+ };
1720
+ }
1721
+ finally {
1722
+ try {
1723
+ this.unsubscribeCheckoutDiff(oneShotSubscriptionId);
1724
+ }
1725
+ catch {
1726
+ // Ignore disconnect races during one-shot cleanup.
1727
+ }
1728
+ }
1729
+ }
1730
+ async subscribeCheckoutDiff(cwd, compare, options) {
1731
+ const subscriptionId = options?.subscriptionId ?? crypto.randomUUID();
1732
+ const normalizedCompare = this.normalizeCheckoutDiffCompare(compare);
1733
+ const previousSubscription = this.checkoutDiffSubscriptions.get(subscriptionId) ?? null;
1734
+ this.checkoutDiffSubscriptions.set(subscriptionId, {
1735
+ cwd,
1736
+ compare: normalizedCompare,
1737
+ });
1738
+ const resolvedRequestId = this.createRequestId(options?.requestId);
1739
+ const message = SessionInboundMessageSchema.parse({
1740
+ type: "subscribe_checkout_diff_request",
1741
+ subscriptionId,
1742
+ cwd,
1743
+ compare: normalizedCompare,
1744
+ requestId: resolvedRequestId,
1745
+ });
1746
+ try {
1747
+ return await this.sendCorrelatedRequest({
1748
+ requestId: resolvedRequestId,
1749
+ message,
1750
+ responseType: "subscribe_checkout_diff_response",
1751
+ timeout: 60000,
1752
+ options: { skipQueue: true },
1753
+ selectPayload: (payload) => {
1754
+ if (payload.subscriptionId !== subscriptionId) {
1755
+ return null;
1756
+ }
1757
+ return payload;
1758
+ },
1759
+ });
1760
+ }
1761
+ catch (error) {
1762
+ if (previousSubscription) {
1763
+ this.checkoutDiffSubscriptions.set(subscriptionId, previousSubscription);
1764
+ }
1765
+ else {
1766
+ this.checkoutDiffSubscriptions.delete(subscriptionId);
1767
+ }
1768
+ throw error;
1769
+ }
1770
+ }
1771
+ unsubscribeCheckoutDiff(subscriptionId) {
1772
+ this.checkoutDiffSubscriptions.delete(subscriptionId);
1773
+ this.sendSessionMessage({
1774
+ type: "unsubscribe_checkout_diff_request",
1775
+ subscriptionId,
1776
+ });
1777
+ }
1778
+ async checkoutCommit(cwd, input, requestId) {
1779
+ return this.sendCorrelatedSessionRequest({
1780
+ requestId,
1781
+ message: {
1782
+ type: "checkout_commit_request",
1783
+ cwd,
1784
+ message: input.message,
1785
+ addAll: input.addAll,
1786
+ },
1787
+ responseType: "checkout_commit_response",
1788
+ timeout: 60000,
1789
+ });
1790
+ }
1791
+ async checkoutMerge(cwd, input, requestId) {
1792
+ return this.sendCorrelatedSessionRequest({
1793
+ requestId,
1794
+ message: {
1795
+ type: "checkout_merge_request",
1796
+ cwd,
1797
+ baseRef: input.baseRef,
1798
+ strategy: input.strategy,
1799
+ requireCleanTarget: input.requireCleanTarget,
1800
+ },
1801
+ responseType: "checkout_merge_response",
1802
+ timeout: 60000,
1803
+ });
1804
+ }
1805
+ async checkoutMergeFromBase(cwd, input, requestId) {
1806
+ return this.sendCorrelatedSessionRequest({
1807
+ requestId,
1808
+ message: {
1809
+ type: "checkout_merge_from_base_request",
1810
+ cwd,
1811
+ baseRef: input.baseRef,
1812
+ requireCleanTarget: input.requireCleanTarget,
1813
+ },
1814
+ responseType: "checkout_merge_from_base_response",
1815
+ timeout: 60000,
1816
+ });
1817
+ }
1818
+ async checkoutPull(cwd, requestId) {
1819
+ return this.sendCorrelatedSessionRequest({
1820
+ requestId,
1821
+ message: {
1822
+ type: "checkout_pull_request",
1823
+ cwd,
1824
+ },
1825
+ responseType: "checkout_pull_response",
1826
+ timeout: 60000,
1827
+ });
1828
+ }
1829
+ async checkoutPush(cwd, requestId) {
1830
+ return this.sendCorrelatedSessionRequest({
1831
+ requestId,
1832
+ message: {
1833
+ type: "checkout_push_request",
1834
+ cwd,
1835
+ },
1836
+ responseType: "checkout_push_response",
1837
+ timeout: 60000,
1838
+ });
1839
+ }
1840
+ async checkoutPrCreate(cwd, input, requestId) {
1841
+ return this.sendCorrelatedSessionRequest({
1842
+ requestId,
1843
+ message: {
1844
+ type: "checkout_pr_create_request",
1845
+ cwd,
1846
+ title: input.title,
1847
+ body: input.body,
1848
+ baseRef: input.baseRef,
1849
+ },
1850
+ responseType: "checkout_pr_create_response",
1851
+ timeout: 60000,
1852
+ });
1853
+ }
1854
+ async checkoutPrMerge(cwd, input, requestId) {
1855
+ return this.sendCorrelatedSessionRequest({
1856
+ requestId,
1857
+ message: {
1858
+ type: "checkout_pr_merge_request",
1859
+ cwd,
1860
+ mergeMethod: input.method,
1861
+ },
1862
+ responseType: "checkout_pr_merge_response",
1863
+ timeout: 60000,
1864
+ });
1865
+ }
1866
+ async checkoutGithubSetAutoMerge(cwd, input, requestId) {
1867
+ return this.sendNamespacedCorrelatedSessionRequest({
1868
+ requestId,
1869
+ message: {
1870
+ type: "checkout.github.set_auto_merge.request",
1871
+ cwd,
1872
+ enabled: input.enabled,
1873
+ ...(input.enabled ? { mergeMethod: input.method } : {}),
1874
+ },
1875
+ timeout: 60000,
1876
+ });
1877
+ }
1878
+ async checkoutPrStatus(cwd, requestId) {
1879
+ return this.sendCorrelatedSessionRequest({
1880
+ requestId,
1881
+ message: {
1882
+ type: "checkout_pr_status_request",
1883
+ cwd,
1884
+ },
1885
+ responseType: "checkout_pr_status_response",
1886
+ timeout: 60000,
1887
+ });
1888
+ }
1889
+ async pullRequestTimeline(input, requestId) {
1890
+ return this.sendCorrelatedSessionRequest({
1891
+ requestId,
1892
+ message: {
1893
+ type: "pull_request_timeline_request",
1894
+ cwd: input.cwd,
1895
+ prNumber: input.prNumber,
1896
+ repoOwner: input.repoOwner,
1897
+ repoName: input.repoName,
1898
+ },
1899
+ responseType: "pull_request_timeline_response",
1900
+ timeout: 60000,
1901
+ });
1902
+ }
1903
+ async checkoutSwitchBranch(cwd, branch, requestId) {
1904
+ return this.sendCorrelatedSessionRequest({
1905
+ requestId,
1906
+ message: {
1907
+ type: "checkout_switch_branch_request",
1908
+ cwd,
1909
+ branch,
1910
+ },
1911
+ responseType: "checkout_switch_branch_response",
1912
+ timeout: 30000,
1913
+ });
1914
+ }
1915
+ async renameBranch(input) {
1916
+ return this.sendCorrelatedSessionRequest({
1917
+ requestId: input.requestId,
1918
+ message: {
1919
+ type: "checkout.rename_branch.request",
1920
+ cwd: input.cwd,
1921
+ branch: input.branch,
1922
+ },
1923
+ responseType: "checkout.rename_branch.response",
1924
+ timeout: 30000,
1925
+ });
1926
+ }
1927
+ async stashSave(cwd, options, requestId) {
1928
+ return this.sendCorrelatedSessionRequest({
1929
+ requestId,
1930
+ message: {
1931
+ type: "stash_save_request",
1932
+ cwd,
1933
+ branch: options?.branch,
1934
+ },
1935
+ responseType: "stash_save_response",
1936
+ timeout: 30000,
1937
+ });
1938
+ }
1939
+ async stashPop(cwd, stashIndex, requestId) {
1940
+ return this.sendCorrelatedSessionRequest({
1941
+ requestId,
1942
+ message: {
1943
+ type: "stash_pop_request",
1944
+ cwd,
1945
+ stashIndex,
1946
+ },
1947
+ responseType: "stash_pop_response",
1948
+ timeout: 30000,
1949
+ });
1950
+ }
1951
+ async stashList(cwd, options, requestId) {
1952
+ return this.sendCorrelatedSessionRequest({
1953
+ requestId,
1954
+ message: {
1955
+ type: "stash_list_request",
1956
+ cwd,
1957
+ paseoOnly: options?.paseoOnly,
1958
+ },
1959
+ responseType: "stash_list_response",
1960
+ timeout: 10000,
1961
+ });
1962
+ }
1963
+ async getPaseoWorktreeList(input, requestId) {
1964
+ return this.sendCorrelatedSessionRequest({
1965
+ requestId,
1966
+ message: {
1967
+ type: "paseo_worktree_list_request",
1968
+ cwd: input.cwd,
1969
+ repoRoot: input.repoRoot,
1970
+ },
1971
+ responseType: "paseo_worktree_list_response",
1972
+ timeout: 60000,
1973
+ });
1974
+ }
1975
+ async archivePaseoWorktree(input, requestId) {
1976
+ return this.sendCorrelatedSessionRequest({
1977
+ requestId,
1978
+ message: {
1979
+ type: "paseo_worktree_archive_request",
1980
+ worktreePath: input.worktreePath,
1981
+ repoRoot: input.repoRoot,
1982
+ branchName: input.branchName,
1983
+ },
1984
+ responseType: "paseo_worktree_archive_response",
1985
+ timeout: 60000,
1986
+ });
1987
+ }
1988
+ async createPaseoWorktree(input, requestId) {
1989
+ return this.sendCorrelatedSessionRequest({
1990
+ requestId,
1991
+ message: {
1992
+ type: "create_paseo_worktree_request",
1993
+ cwd: input.cwd,
1994
+ ...(input.projectId !== undefined ? { projectId: input.projectId } : {}),
1995
+ worktreeSlug: input.worktreeSlug,
1996
+ ...(input.firstAgentContext !== undefined
1997
+ ? { firstAgentContext: input.firstAgentContext }
1998
+ : {}),
1999
+ ...(input.refName !== undefined ? { refName: input.refName } : {}),
2000
+ ...(input.action !== undefined ? { action: input.action } : {}),
2001
+ ...(input.githubPrNumber !== undefined ? { githubPrNumber: input.githubPrNumber } : {}),
2002
+ },
2003
+ responseType: "create_paseo_worktree_response",
2004
+ timeout: 60000,
2005
+ });
2006
+ }
2007
+ async validateBranch(options, requestId) {
2008
+ return this.sendCorrelatedSessionRequest({
2009
+ requestId,
2010
+ message: {
2011
+ type: "validate_branch_request",
2012
+ cwd: options.cwd,
2013
+ branchName: options.branchName,
2014
+ },
2015
+ responseType: "validate_branch_response",
2016
+ timeout: 10000,
2017
+ });
2018
+ }
2019
+ async getBranchSuggestions(options, requestId) {
2020
+ return this.sendCorrelatedSessionRequest({
2021
+ requestId,
2022
+ message: {
2023
+ type: "branch_suggestions_request",
2024
+ cwd: options.cwd,
2025
+ query: options.query,
2026
+ limit: options.limit,
2027
+ },
2028
+ responseType: "branch_suggestions_response",
2029
+ timeout: 10000,
2030
+ });
2031
+ }
2032
+ async searchGitHub(options, requestId) {
2033
+ return this.sendCorrelatedSessionRequest({
2034
+ requestId,
2035
+ message: {
2036
+ type: "github_search_request",
2037
+ cwd: options.cwd,
2038
+ query: options.query,
2039
+ limit: options.limit,
2040
+ kinds: options.kinds,
2041
+ },
2042
+ responseType: "github_search_response",
2043
+ timeout: 15000,
2044
+ });
2045
+ }
2046
+ async getDirectorySuggestions(options, requestId) {
2047
+ return this.sendCorrelatedSessionRequest({
2048
+ requestId,
2049
+ message: {
2050
+ type: "directory_suggestions_request",
2051
+ query: options.query,
2052
+ cwd: options.cwd,
2053
+ includeFiles: options.includeFiles,
2054
+ includeDirectories: options.includeDirectories,
2055
+ matchMode: options.matchMode,
2056
+ limit: options.limit,
2057
+ },
2058
+ responseType: "directory_suggestions_response",
2059
+ timeout: 10000,
2060
+ });
2061
+ }
2062
+ // ============================================================================
2063
+ // File Explorer
2064
+ // ============================================================================
2065
+ async requestFileExplorer(cwd, path, mode, requestId, acceptBinary = false) {
2066
+ return this.sendCorrelatedSessionRequest({
2067
+ requestId,
2068
+ message: {
2069
+ type: "file_explorer_request",
2070
+ cwd,
2071
+ path,
2072
+ mode,
2073
+ ...(acceptBinary ? { acceptBinary: true } : {}),
2074
+ },
2075
+ responseType: "file_explorer_response",
2076
+ timeout: 10000,
2077
+ });
2078
+ }
2079
+ async listDirectory(cwd, path, requestId) {
2080
+ const payload = await this.requestFileExplorer(cwd, path, "list", requestId);
2081
+ if (payload.error) {
2082
+ throw new Error(payload.error);
2083
+ }
2084
+ if (!payload.directory) {
2085
+ throw new Error("Directory listing unavailable.");
2086
+ }
2087
+ return payload.directory;
2088
+ }
2089
+ async readFile(cwd, path, requestId) {
2090
+ const resolvedRequestId = this.createRequestId(requestId);
2091
+ this.pendingBinaryFileReads.set(resolvedRequestId, { cwd, path });
2092
+ try {
2093
+ const payload = await this.requestFileExplorer(cwd, path, "file", resolvedRequestId, true);
2094
+ if (payload.error) {
2095
+ throw new Error(payload.error);
2096
+ }
2097
+ const binaryResult = this.completedBinaryFileReads.get(resolvedRequestId);
2098
+ if (binaryResult) {
2099
+ this.completedBinaryFileReads.delete(resolvedRequestId);
2100
+ return binaryResult;
2101
+ }
2102
+ if (!payload.file) {
2103
+ throw new Error("File unavailable.");
2104
+ }
2105
+ return legacyExplorerFileToBytes(payload.file);
2106
+ }
2107
+ finally {
2108
+ this.pendingBinaryFileReads.delete(resolvedRequestId);
2109
+ this.activeBinaryFileTransfers.delete(resolvedRequestId);
2110
+ }
2111
+ }
2112
+ async requestDownloadToken(cwd, path, requestId) {
2113
+ return this.sendCorrelatedSessionRequest({
2114
+ requestId,
2115
+ message: {
2116
+ type: "file_download_token_request",
2117
+ cwd,
2118
+ path,
2119
+ },
2120
+ responseType: "file_download_token_response",
2121
+ timeout: 10000,
2122
+ });
2123
+ }
2124
+ async requestProjectIcon(cwd, requestId) {
2125
+ return this.sendCorrelatedSessionRequest({
2126
+ requestId,
2127
+ message: {
2128
+ type: "project_icon_request",
2129
+ cwd,
2130
+ },
2131
+ responseType: "project_icon_response",
2132
+ timeout: 10000,
2133
+ });
2134
+ }
2135
+ // ============================================================================
2136
+ // Provider Models / Commands
2137
+ // ============================================================================
2138
+ async listProviderModels(provider, options) {
2139
+ return this.sendCorrelatedSessionRequest({
2140
+ requestId: options?.requestId,
2141
+ message: {
2142
+ type: "list_provider_models_request",
2143
+ provider,
2144
+ cwd: options?.cwd,
2145
+ },
2146
+ responseType: "list_provider_models_response",
2147
+ // Provider SDK cold starts (especially model discovery) can exceed 30s.
2148
+ timeout: 45000,
2149
+ });
2150
+ }
2151
+ async listProviderModes(provider, options) {
2152
+ return this.sendCorrelatedSessionRequest({
2153
+ requestId: options?.requestId,
2154
+ message: {
2155
+ type: "list_provider_modes_request",
2156
+ provider,
2157
+ cwd: options?.cwd,
2158
+ },
2159
+ responseType: "list_provider_modes_response",
2160
+ timeout: 45000,
2161
+ });
2162
+ }
2163
+ async listProviderFeatures(draftConfig, options) {
2164
+ return this.sendCorrelatedSessionRequest({
2165
+ requestId: options?.requestId,
2166
+ message: {
2167
+ type: "list_provider_features_request",
2168
+ draftConfig,
2169
+ },
2170
+ responseType: "list_provider_features_response",
2171
+ timeout: 45000,
2172
+ });
2173
+ }
2174
+ async listAvailableProviders(options) {
2175
+ return this.sendCorrelatedSessionRequest({
2176
+ requestId: options?.requestId,
2177
+ message: {
2178
+ type: "list_available_providers_request",
2179
+ },
2180
+ responseType: "list_available_providers_response",
2181
+ timeout: 30000,
2182
+ });
2183
+ }
2184
+ async getProvidersSnapshot(options) {
2185
+ return this.sendCorrelatedSessionRequest({
2186
+ requestId: options?.requestId,
2187
+ message: {
2188
+ type: "get_providers_snapshot_request",
2189
+ cwd: options?.cwd,
2190
+ },
2191
+ responseType: "get_providers_snapshot_response",
2192
+ timeout: 10000,
2193
+ });
2194
+ }
2195
+ async getDaemonConfig(requestId) {
2196
+ return this.sendCorrelatedSessionRequest({
2197
+ requestId,
2198
+ message: {
2199
+ type: "get_daemon_config_request",
2200
+ },
2201
+ responseType: "get_daemon_config_response",
2202
+ timeout: 10000,
2203
+ });
2204
+ }
2205
+ async getDaemonStatus(requestId) {
2206
+ return this.sendCorrelatedSessionRequest({
2207
+ requestId,
2208
+ message: {
2209
+ type: "daemon.get_status.request",
2210
+ },
2211
+ responseType: "daemon.get_status.response",
2212
+ timeout: 10000,
2213
+ });
2214
+ }
2215
+ async getDaemonPairingOffer(requestId) {
2216
+ return this.sendCorrelatedSessionRequest({
2217
+ requestId,
2218
+ message: {
2219
+ type: "daemon.get_pairing_offer.request",
2220
+ },
2221
+ responseType: "daemon.get_pairing_offer.response",
2222
+ timeout: 10000,
2223
+ });
2224
+ }
2225
+ async patchDaemonConfig(config, requestId) {
2226
+ return this.sendCorrelatedSessionRequest({
2227
+ requestId,
2228
+ message: {
2229
+ type: "set_daemon_config_request",
2230
+ config,
2231
+ },
2232
+ responseType: "set_daemon_config_response",
2233
+ timeout: 10000,
2234
+ });
2235
+ }
2236
+ async readProjectConfig(repoRoot, requestId) {
2237
+ return this.sendCorrelatedSessionRequest({
2238
+ requestId,
2239
+ message: {
2240
+ type: "read_project_config_request",
2241
+ repoRoot,
2242
+ },
2243
+ responseType: "read_project_config_response",
2244
+ timeout: 10000,
2245
+ });
2246
+ }
2247
+ async writeProjectConfig(input) {
2248
+ return this.sendCorrelatedSessionRequest({
2249
+ requestId: input.requestId,
2250
+ message: {
2251
+ type: "write_project_config_request",
2252
+ repoRoot: input.repoRoot,
2253
+ config: input.config,
2254
+ expectedRevision: input.expectedRevision,
2255
+ },
2256
+ responseType: "write_project_config_response",
2257
+ timeout: 10000,
2258
+ });
2259
+ }
2260
+ async refreshProvidersSnapshot(options) {
2261
+ return this.sendCorrelatedSessionRequest({
2262
+ requestId: options?.requestId,
2263
+ message: {
2264
+ type: "refresh_providers_snapshot_request",
2265
+ cwd: options?.cwd,
2266
+ providers: options?.providers,
2267
+ },
2268
+ responseType: "refresh_providers_snapshot_response",
2269
+ timeout: 60000,
2270
+ });
2271
+ }
2272
+ async getProviderDiagnostic(provider, options) {
2273
+ return this.sendCorrelatedSessionRequest({
2274
+ requestId: options?.requestId,
2275
+ message: {
2276
+ type: "provider_diagnostic_request",
2277
+ provider,
2278
+ },
2279
+ responseType: "provider_diagnostic_response",
2280
+ timeout: 30000,
2281
+ });
2282
+ }
2283
+ async listCommands(agentId, requestIdOrOptions) {
2284
+ const requestId = typeof requestIdOrOptions === "string" ? requestIdOrOptions : requestIdOrOptions?.requestId;
2285
+ const draftConfig = typeof requestIdOrOptions === "string" ? undefined : requestIdOrOptions?.draftConfig;
2286
+ return this.sendCorrelatedSessionRequest({
2287
+ requestId,
2288
+ message: {
2289
+ type: "list_commands_request",
2290
+ agentId,
2291
+ ...(draftConfig ? { draftConfig } : {}),
2292
+ },
2293
+ responseType: "list_commands_response",
2294
+ timeout: 30000,
2295
+ });
2296
+ }
2297
+ // ============================================================================
2298
+ // Permissions
2299
+ // ============================================================================
2300
+ async respondToPermission(agentId, requestId, response) {
2301
+ this.sendSessionMessage({
2302
+ type: "agent_permission_response",
2303
+ agentId,
2304
+ requestId,
2305
+ response,
2306
+ });
2307
+ }
2308
+ async respondToPermissionAndWait(agentId, requestId, response, timeout = 15000) {
2309
+ const message = SessionInboundMessageSchema.parse({
2310
+ type: "agent_permission_response",
2311
+ agentId,
2312
+ requestId,
2313
+ response,
2314
+ });
2315
+ return this.sendRequest({
2316
+ requestId,
2317
+ message,
2318
+ timeout,
2319
+ options: { skipQueue: true },
2320
+ select: (msg) => {
2321
+ if (msg.type !== "agent_permission_resolved") {
2322
+ return null;
2323
+ }
2324
+ if (msg.payload.requestId !== requestId) {
2325
+ return null;
2326
+ }
2327
+ if (msg.payload.agentId !== agentId) {
2328
+ return null;
2329
+ }
2330
+ return msg.payload;
2331
+ },
2332
+ });
2333
+ }
2334
+ // ============================================================================
2335
+ // Waiting / Streaming Helpers
2336
+ // ============================================================================
2337
+ async waitForAgentUpsert(agentId, predicate, timeout = 60000) {
2338
+ const initialResult = await this.fetchAgent(agentId).catch(() => null);
2339
+ if (initialResult && predicate(initialResult.agent)) {
2340
+ return initialResult.agent;
2341
+ }
2342
+ const deadline = Date.now() + timeout;
2343
+ return await new Promise((resolve, reject) => {
2344
+ let settled = false;
2345
+ let pollInFlight = false;
2346
+ let pollTimer = null;
2347
+ let timeoutTimer = null;
2348
+ let unsubscribe = null;
2349
+ const finish = (result) => {
2350
+ if (settled) {
2351
+ return;
2352
+ }
2353
+ settled = true;
2354
+ if (timeoutTimer) {
2355
+ clearTimeout(timeoutTimer);
2356
+ timeoutTimer = null;
2357
+ }
2358
+ if (pollTimer) {
2359
+ clearInterval(pollTimer);
2360
+ pollTimer = null;
2361
+ }
2362
+ if (unsubscribe) {
2363
+ unsubscribe();
2364
+ unsubscribe = null;
2365
+ }
2366
+ if (result.kind === "ok") {
2367
+ resolve(result.snapshot);
2368
+ return;
2369
+ }
2370
+ reject(result.error);
2371
+ };
2372
+ const maybeResolve = (snapshot) => {
2373
+ if (!snapshot) {
2374
+ return false;
2375
+ }
2376
+ if (!predicate(snapshot)) {
2377
+ return false;
2378
+ }
2379
+ finish({ kind: "ok", snapshot });
2380
+ return true;
2381
+ };
2382
+ const poll = async () => {
2383
+ if (settled || pollInFlight) {
2384
+ return;
2385
+ }
2386
+ pollInFlight = true;
2387
+ try {
2388
+ const result = await this.fetchAgent(agentId).catch(() => null);
2389
+ maybeResolve(result?.agent ?? null);
2390
+ }
2391
+ finally {
2392
+ pollInFlight = false;
2393
+ }
2394
+ };
2395
+ unsubscribe = this.on("agent_update", (message) => {
2396
+ if (settled) {
2397
+ return;
2398
+ }
2399
+ if (message.payload.kind !== "upsert") {
2400
+ return;
2401
+ }
2402
+ const snapshot = message.payload.agent;
2403
+ if (snapshot.id !== agentId) {
2404
+ return;
2405
+ }
2406
+ maybeResolve(snapshot);
2407
+ });
2408
+ const remaining = Math.max(1, deadline - Date.now());
2409
+ timeoutTimer = setTimeout(() => {
2410
+ finish({
2411
+ kind: "error",
2412
+ error: new Error(`Timed out waiting for agent ${agentId}`),
2413
+ });
2414
+ }, remaining);
2415
+ pollTimer = setInterval(() => {
2416
+ void poll();
2417
+ }, 250);
2418
+ void poll();
2419
+ });
2420
+ }
2421
+ async waitForFinish(agentId, timeout = 60000) {
2422
+ const requestId = this.createRequestId();
2423
+ const hasTimeout = Number.isFinite(timeout) && timeout > 0;
2424
+ const message = SessionInboundMessageSchema.parse({
2425
+ type: "wait_for_finish_request",
2426
+ requestId,
2427
+ agentId,
2428
+ ...(hasTimeout ? { timeoutMs: timeout } : {}),
2429
+ });
2430
+ const payload = await this.sendCorrelatedRequest({
2431
+ requestId,
2432
+ message,
2433
+ responseType: "wait_for_finish_response",
2434
+ timeout: hasTimeout ? timeout + 5000 : 0,
2435
+ options: { skipQueue: true },
2436
+ });
2437
+ return {
2438
+ status: payload.status,
2439
+ final: payload.final,
2440
+ error: payload.error,
2441
+ lastMessage: payload.lastMessage,
2442
+ };
2443
+ }
2444
+ // ============================================================================
2445
+ // Terminals
2446
+ // ============================================================================
2447
+ subscribeTerminals(input) {
2448
+ this.terminalDirectorySubscriptions.add(input.cwd);
2449
+ if (!this.transport || this.connectionState.status !== "connected") {
2450
+ return;
2451
+ }
2452
+ this.sendSessionMessage({
2453
+ type: "subscribe_terminals_request",
2454
+ cwd: input.cwd,
2455
+ });
2456
+ }
2457
+ unsubscribeTerminals(input) {
2458
+ this.terminalDirectorySubscriptions.delete(input.cwd);
2459
+ if (!this.transport || this.connectionState.status !== "connected") {
2460
+ return;
2461
+ }
2462
+ this.sendSessionMessage({
2463
+ type: "unsubscribe_terminals_request",
2464
+ cwd: input.cwd,
2465
+ });
2466
+ }
2467
+ async listTerminals(cwd, requestId) {
2468
+ const resolvedRequestId = this.createRequestId(requestId);
2469
+ const message = SessionInboundMessageSchema.parse({
2470
+ type: "list_terminals_request",
2471
+ ...(cwd === undefined ? {} : { cwd }),
2472
+ requestId: resolvedRequestId,
2473
+ });
2474
+ return this.sendCorrelatedRequest({
2475
+ requestId: resolvedRequestId,
2476
+ message,
2477
+ responseType: "list_terminals_response",
2478
+ timeout: 10000,
2479
+ options: { skipQueue: true },
2480
+ });
2481
+ }
2482
+ async createTerminal(cwd, name, requestId, options) {
2483
+ const resolvedRequestId = this.createRequestId(requestId);
2484
+ const message = SessionInboundMessageSchema.parse({
2485
+ type: "create_terminal_request",
2486
+ cwd,
2487
+ name,
2488
+ agentId: options?.agentId,
2489
+ command: options?.command,
2490
+ args: options?.args,
2491
+ requestId: resolvedRequestId,
2492
+ });
2493
+ return this.sendCorrelatedRequest({
2494
+ requestId: resolvedRequestId,
2495
+ message,
2496
+ responseType: "create_terminal_response",
2497
+ timeout: 10000,
2498
+ options: { skipQueue: true },
2499
+ });
2500
+ }
2501
+ async renameTerminal(input) {
2502
+ return this.sendCorrelatedSessionRequest({
2503
+ requestId: input.requestId,
2504
+ message: {
2505
+ type: "terminal.rename.request",
2506
+ terminalId: input.terminalId,
2507
+ title: input.title,
2508
+ },
2509
+ responseType: "terminal.rename.response",
2510
+ timeout: 10000,
2511
+ });
2512
+ }
2513
+ async subscribeTerminal(terminalId, requestId) {
2514
+ const resolvedRequestId = this.createRequestId(requestId);
2515
+ const message = SessionInboundMessageSchema.parse({
2516
+ type: "subscribe_terminal_request",
2517
+ terminalId,
2518
+ requestId: resolvedRequestId,
2519
+ });
2520
+ const payload = await this.sendCorrelatedRequest({
2521
+ requestId: resolvedRequestId,
2522
+ message,
2523
+ responseType: "subscribe_terminal_response",
2524
+ timeout: 10000,
2525
+ options: { skipQueue: true },
2526
+ });
2527
+ if (payload.error === null) {
2528
+ this.terminalStreams.setSlot(terminalId, payload.slot);
2529
+ }
2530
+ return payload;
2531
+ }
2532
+ unsubscribeTerminal(terminalId) {
2533
+ this.terminalStreams.removeTerminal(terminalId);
2534
+ this.sendSessionMessage({
2535
+ type: "unsubscribe_terminal_request",
2536
+ terminalId,
2537
+ });
2538
+ }
2539
+ sendTerminalInput(terminalId, message) {
2540
+ const frame = this.terminalStreams.encodeInput(terminalId, message);
2541
+ if (frame) {
2542
+ this.sendBinaryFrame(frame);
2543
+ return;
2544
+ }
2545
+ this.sendSessionMessage({
2546
+ type: "terminal_input",
2547
+ terminalId,
2548
+ message,
2549
+ });
2550
+ }
2551
+ async killTerminal(terminalId, requestId) {
2552
+ const resolvedRequestId = this.createRequestId(requestId);
2553
+ const message = SessionInboundMessageSchema.parse({
2554
+ type: "kill_terminal_request",
2555
+ terminalId,
2556
+ requestId: resolvedRequestId,
2557
+ });
2558
+ return this.sendCorrelatedRequest({
2559
+ requestId: resolvedRequestId,
2560
+ message,
2561
+ responseType: "kill_terminal_response",
2562
+ timeout: 10000,
2563
+ options: { skipQueue: true },
2564
+ });
2565
+ }
2566
+ async closeItems(input, requestId) {
2567
+ const resolvedRequestId = this.createRequestId(requestId);
2568
+ const message = SessionInboundMessageSchema.parse({
2569
+ type: "close_items_request",
2570
+ agentIds: input.agentIds ?? [],
2571
+ terminalIds: input.terminalIds ?? [],
2572
+ requestId: resolvedRequestId,
2573
+ });
2574
+ return this.sendCorrelatedRequest({
2575
+ requestId: resolvedRequestId,
2576
+ message,
2577
+ responseType: "close_items_response",
2578
+ timeout: 10000,
2579
+ options: { skipQueue: true },
2580
+ });
2581
+ }
2582
+ async captureTerminal(terminalId, options, requestId) {
2583
+ const resolvedRequestId = this.createRequestId(requestId);
2584
+ const message = SessionInboundMessageSchema.parse({
2585
+ type: "capture_terminal_request",
2586
+ terminalId,
2587
+ ...(options?.start === undefined ? {} : { start: options.start }),
2588
+ ...(options?.end === undefined ? {} : { end: options.end }),
2589
+ ...(options?.stripAnsi === undefined ? {} : { stripAnsi: options.stripAnsi }),
2590
+ requestId: resolvedRequestId,
2591
+ });
2592
+ return this.sendCorrelatedRequest({
2593
+ requestId: resolvedRequestId,
2594
+ message,
2595
+ responseType: "capture_terminal_response",
2596
+ timeout: 10000,
2597
+ options: { skipQueue: true },
2598
+ });
2599
+ }
2600
+ async createChatRoom(options) {
2601
+ return this.sendCorrelatedSessionRequest({
2602
+ requestId: options.requestId,
2603
+ message: {
2604
+ type: "chat/create",
2605
+ name: options.name,
2606
+ ...(options.purpose ? { purpose: options.purpose } : {}),
2607
+ },
2608
+ responseType: "chat/create/response",
2609
+ timeout: 10000,
2610
+ });
2611
+ }
2612
+ async listChatRooms(requestId) {
2613
+ return this.sendCorrelatedSessionRequest({
2614
+ requestId,
2615
+ message: {
2616
+ type: "chat/list",
2617
+ },
2618
+ responseType: "chat/list/response",
2619
+ timeout: 10000,
2620
+ });
2621
+ }
2622
+ async inspectChatRoom(options) {
2623
+ return this.sendCorrelatedSessionRequest({
2624
+ requestId: options.requestId,
2625
+ message: {
2626
+ type: "chat/inspect",
2627
+ room: options.room,
2628
+ },
2629
+ responseType: "chat/inspect/response",
2630
+ timeout: 10000,
2631
+ });
2632
+ }
2633
+ async deleteChatRoom(options) {
2634
+ return this.sendCorrelatedSessionRequest({
2635
+ requestId: options.requestId,
2636
+ message: {
2637
+ type: "chat/delete",
2638
+ room: options.room,
2639
+ },
2640
+ responseType: "chat/delete/response",
2641
+ timeout: 10000,
2642
+ });
2643
+ }
2644
+ async postChatMessage(options) {
2645
+ return this.sendCorrelatedSessionRequest({
2646
+ requestId: options.requestId,
2647
+ message: {
2648
+ type: "chat/post",
2649
+ room: options.room,
2650
+ body: options.body,
2651
+ ...(options.authorAgentId ? { authorAgentId: options.authorAgentId } : {}),
2652
+ ...(options.replyToMessageId ? { replyToMessageId: options.replyToMessageId } : {}),
2653
+ },
2654
+ responseType: "chat/post/response",
2655
+ timeout: 10000,
2656
+ });
2657
+ }
2658
+ async readChatMessages(options) {
2659
+ return this.sendCorrelatedSessionRequest({
2660
+ requestId: options.requestId,
2661
+ message: {
2662
+ type: "chat/read",
2663
+ room: options.room,
2664
+ ...(typeof options.limit === "number" ? { limit: options.limit } : {}),
2665
+ ...(options.since ? { since: options.since } : {}),
2666
+ ...(options.authorAgentId ? { authorAgentId: options.authorAgentId } : {}),
2667
+ },
2668
+ responseType: "chat/read/response",
2669
+ timeout: 10000,
2670
+ });
2671
+ }
2672
+ async waitForChatMessages(options) {
2673
+ return this.sendCorrelatedSessionRequest({
2674
+ requestId: options.requestId,
2675
+ message: {
2676
+ type: "chat/wait",
2677
+ room: options.room,
2678
+ ...(options.afterMessageId ? { afterMessageId: options.afterMessageId } : {}),
2679
+ ...(typeof options.timeoutMs === "number" ? { timeoutMs: options.timeoutMs } : {}),
2680
+ },
2681
+ responseType: "chat/wait/response",
2682
+ timeout: (options.timeoutMs ?? 0) + 10000,
2683
+ });
2684
+ }
2685
+ async scheduleCreate(options) {
2686
+ return this.sendCorrelatedSessionRequest({
2687
+ requestId: options.requestId,
2688
+ message: {
2689
+ type: "schedule/create",
2690
+ prompt: options.prompt,
2691
+ cadence: options.cadence,
2692
+ target: options.target,
2693
+ ...(options.name ? { name: options.name } : {}),
2694
+ ...(typeof options.maxRuns === "number" ? { maxRuns: options.maxRuns } : {}),
2695
+ ...(options.expiresAt ? { expiresAt: options.expiresAt } : {}),
2696
+ ...(typeof options.runOnCreate === "boolean" ? { runOnCreate: options.runOnCreate } : {}),
2697
+ },
2698
+ responseType: "schedule/create/response",
2699
+ timeout: 10000,
2700
+ });
2701
+ }
2702
+ async scheduleList(requestId) {
2703
+ return this.sendCorrelatedSessionRequest({
2704
+ requestId,
2705
+ message: {
2706
+ type: "schedule/list",
2707
+ },
2708
+ responseType: "schedule/list/response",
2709
+ timeout: 10000,
2710
+ });
2711
+ }
2712
+ async scheduleInspect(options) {
2713
+ return this.sendCorrelatedSessionRequest({
2714
+ requestId: options.requestId,
2715
+ message: {
2716
+ type: "schedule/inspect",
2717
+ scheduleId: options.id,
2718
+ },
2719
+ responseType: "schedule/inspect/response",
2720
+ timeout: 10000,
2721
+ });
2722
+ }
2723
+ async scheduleLogs(options) {
2724
+ return this.sendCorrelatedSessionRequest({
2725
+ requestId: options.requestId,
2726
+ message: {
2727
+ type: "schedule/logs",
2728
+ scheduleId: options.id,
2729
+ },
2730
+ responseType: "schedule/logs/response",
2731
+ timeout: 10000,
2732
+ });
2733
+ }
2734
+ async schedulePause(options) {
2735
+ return this.sendCorrelatedSessionRequest({
2736
+ requestId: options.requestId,
2737
+ message: {
2738
+ type: "schedule/pause",
2739
+ scheduleId: options.id,
2740
+ },
2741
+ responseType: "schedule/pause/response",
2742
+ timeout: 10000,
2743
+ });
2744
+ }
2745
+ async scheduleResume(options) {
2746
+ return this.sendCorrelatedSessionRequest({
2747
+ requestId: options.requestId,
2748
+ message: {
2749
+ type: "schedule/resume",
2750
+ scheduleId: options.id,
2751
+ },
2752
+ responseType: "schedule/resume/response",
2753
+ timeout: 10000,
2754
+ });
2755
+ }
2756
+ async scheduleDelete(options) {
2757
+ return this.sendCorrelatedSessionRequest({
2758
+ requestId: options.requestId,
2759
+ message: {
2760
+ type: "schedule/delete",
2761
+ scheduleId: options.id,
2762
+ },
2763
+ responseType: "schedule/delete/response",
2764
+ timeout: 10000,
2765
+ });
2766
+ }
2767
+ async scheduleRunOnce(options) {
2768
+ return this.sendCorrelatedSessionRequest({
2769
+ requestId: options.requestId,
2770
+ message: {
2771
+ type: "schedule/run-once",
2772
+ scheduleId: options.id,
2773
+ },
2774
+ responseType: "schedule/run-once/response",
2775
+ timeout: 10000,
2776
+ });
2777
+ }
2778
+ async scheduleUpdate(options) {
2779
+ return this.sendCorrelatedSessionRequest({
2780
+ requestId: options.requestId,
2781
+ message: {
2782
+ type: "schedule/update",
2783
+ scheduleId: options.id,
2784
+ ...(options.name !== undefined ? { name: options.name } : {}),
2785
+ ...(options.prompt !== undefined ? { prompt: options.prompt } : {}),
2786
+ ...(options.cadence !== undefined ? { cadence: options.cadence } : {}),
2787
+ ...(options.newAgentConfig !== undefined ? { newAgentConfig: options.newAgentConfig } : {}),
2788
+ ...(options.maxRuns !== undefined ? { maxRuns: options.maxRuns } : {}),
2789
+ ...(options.expiresAt !== undefined ? { expiresAt: options.expiresAt } : {}),
2790
+ },
2791
+ responseType: "schedule/update/response",
2792
+ timeout: 10000,
2793
+ });
2794
+ }
2795
+ async loopRun(options) {
2796
+ return this.sendCorrelatedSessionRequest({
2797
+ requestId: options.requestId,
2798
+ message: {
2799
+ type: "loop/run",
2800
+ prompt: options.prompt,
2801
+ cwd: options.cwd,
2802
+ ...(options.provider ? { provider: options.provider } : {}),
2803
+ ...(options.model ? { model: options.model } : {}),
2804
+ ...(options.modeId ? { modeId: options.modeId } : {}),
2805
+ ...(options.verifierProvider ? { verifierProvider: options.verifierProvider } : {}),
2806
+ ...(options.verifierModel ? { verifierModel: options.verifierModel } : {}),
2807
+ ...(options.verifierModeId ? { verifierModeId: options.verifierModeId } : {}),
2808
+ ...(options.verifyPrompt ? { verifyPrompt: options.verifyPrompt } : {}),
2809
+ ...(options.verifyChecks && options.verifyChecks.length > 0
2810
+ ? { verifyChecks: options.verifyChecks }
2811
+ : {}),
2812
+ ...(options.name ? { name: options.name } : {}),
2813
+ ...(typeof options.sleepMs === "number" ? { sleepMs: options.sleepMs } : {}),
2814
+ ...(typeof options.maxIterations === "number"
2815
+ ? { maxIterations: options.maxIterations }
2816
+ : {}),
2817
+ ...(typeof options.maxTimeMs === "number" ? { maxTimeMs: options.maxTimeMs } : {}),
2818
+ },
2819
+ responseType: "loop/run/response",
2820
+ timeout: 15000,
2821
+ });
2822
+ }
2823
+ async loopList(requestId) {
2824
+ return this.sendCorrelatedSessionRequest({
2825
+ requestId,
2826
+ message: {
2827
+ type: "loop/list",
2828
+ },
2829
+ responseType: "loop/list/response",
2830
+ timeout: 10000,
2831
+ });
2832
+ }
2833
+ async loopInspect(options) {
2834
+ const normalized = typeof options === "string" ? { id: options } : options;
2835
+ return this.sendCorrelatedSessionRequest({
2836
+ requestId: normalized.requestId,
2837
+ message: {
2838
+ type: "loop/inspect",
2839
+ id: normalized.id,
2840
+ },
2841
+ responseType: "loop/inspect/response",
2842
+ timeout: 10000,
2843
+ });
2844
+ }
2845
+ async loopLogs(options, afterSeq) {
2846
+ const normalized = typeof options === "string" ? { id: options, afterSeq } : options;
2847
+ return this.sendCorrelatedSessionRequest({
2848
+ requestId: normalized.requestId,
2849
+ message: {
2850
+ type: "loop/logs",
2851
+ id: normalized.id,
2852
+ ...(typeof normalized.afterSeq === "number" ? { afterSeq: normalized.afterSeq } : {}),
2853
+ },
2854
+ responseType: "loop/logs/response",
2855
+ timeout: 10000,
2856
+ });
2857
+ }
2858
+ async loopStop(options) {
2859
+ const normalized = typeof options === "string" ? { id: options } : options;
2860
+ return this.sendCorrelatedSessionRequest({
2861
+ requestId: normalized.requestId,
2862
+ message: {
2863
+ type: "loop/stop",
2864
+ id: normalized.id,
2865
+ },
2866
+ responseType: "loop/stop/response",
2867
+ timeout: 10000,
2868
+ });
2869
+ }
2870
+ onTerminalStreamEvent(handler) {
2871
+ return this.terminalStreams.onEvent(handler);
2872
+ }
2873
+ async waitForTerminalStreamEvent(predicate, timeout = 5000) {
2874
+ return new Promise((resolve, reject) => {
2875
+ const timeoutHandle = setTimeout(() => {
2876
+ unsubscribe();
2877
+ reject(new Error(`Timeout waiting for terminal stream event (${timeout}ms)`));
2878
+ }, timeout);
2879
+ const unsubscribe = this.onTerminalStreamEvent((event) => {
2880
+ if (!predicate(event)) {
2881
+ return;
2882
+ }
2883
+ clearTimeout(timeoutHandle);
2884
+ unsubscribe();
2885
+ resolve(event);
2886
+ });
2887
+ });
2888
+ }
2889
+ // ============================================================================
2890
+ // Internals
2891
+ // ============================================================================
2892
+ createRequestId(requestId) {
2893
+ return requestId ?? crypto.randomUUID();
2894
+ }
2895
+ getLastServerInfoMessage() {
2896
+ return this.lastServerInfoMessage;
2897
+ }
2898
+ resolveTransportUrlForAttempt() {
2899
+ return this.config.url;
2900
+ }
2901
+ sendHelloMessage() {
2902
+ if (!this.transport) {
2903
+ this.scheduleReconnect({
2904
+ reason: "Transport unavailable before hello",
2905
+ event: "HELLO_TRANSPORT_MISSING",
2906
+ reasonCode: "transport_error",
2907
+ });
2908
+ return;
2909
+ }
2910
+ try {
2911
+ this.transport.send(JSON.stringify({
2912
+ type: "hello",
2913
+ clientId: this.config.clientId,
2914
+ clientType: this.config.clientType ?? "cli",
2915
+ protocolVersion: 1,
2916
+ capabilities: {
2917
+ [CLIENT_CAPS.reasoningMergeEnum]: true,
2918
+ },
2919
+ ...(this.config.appVersion ? { appVersion: this.config.appVersion } : {}),
2920
+ }));
2921
+ }
2922
+ catch (error) {
2923
+ const message = error instanceof Error ? error.message : "Failed to send hello message";
2924
+ this.lastErrorValue = message;
2925
+ this.scheduleReconnect({
2926
+ reason: message,
2927
+ event: "HELLO_SEND_FAILED",
2928
+ reasonCode: "transport_error",
2929
+ });
2930
+ }
2931
+ }
2932
+ disposeTransport(code = 1001, reason = "Reconnecting") {
2933
+ this.cleanupTransport();
2934
+ if (this.transport) {
2935
+ try {
2936
+ this.transport.close(code, reason);
2937
+ }
2938
+ catch {
2939
+ // no-op
2940
+ }
2941
+ this.transport = null;
2942
+ }
2943
+ }
2944
+ cleanupTransport() {
2945
+ this.resetConnectTimeout();
2946
+ if (this.pendingGenericTransportErrorTimeout) {
2947
+ clearTimeout(this.pendingGenericTransportErrorTimeout);
2948
+ this.pendingGenericTransportErrorTimeout = null;
2949
+ }
2950
+ for (const cleanup of this.transportCleanup) {
2951
+ try {
2952
+ cleanup();
2953
+ }
2954
+ catch {
2955
+ // no-op
2956
+ }
2957
+ }
2958
+ this.transportCleanup = [];
2959
+ }
2960
+ resetConnectTimeout() {
2961
+ if (!this.connectTimeout) {
2962
+ return;
2963
+ }
2964
+ clearTimeout(this.connectTimeout);
2965
+ this.connectTimeout = null;
2966
+ }
2967
+ handleTransportMessage(data) {
2968
+ const rawData = data && typeof data === "object" && "data" in data ? data.data : data;
2969
+ if (typeof Blob !== "undefined" &&
2970
+ rawData instanceof Blob &&
2971
+ typeof rawData.arrayBuffer === "function") {
2972
+ void rawData
2973
+ .arrayBuffer()
2974
+ .then((buffer) => {
2975
+ this.handleTransportMessage(buffer);
2976
+ return;
2977
+ })
2978
+ .catch(() => {
2979
+ // Ignore failed blob decoding and allow reconnect logic to recover.
2980
+ });
2981
+ return;
2982
+ }
2983
+ const rawBytes = asUint8Array(rawData);
2984
+ if (rawBytes && this.tryHandleBinaryFrame(rawBytes)) {
2985
+ return;
2986
+ }
2987
+ const payload = decodeMessageData(rawData);
2988
+ if (!payload) {
2989
+ return;
2990
+ }
2991
+ this.handleJsonPayload(payload, rawBytes?.byteLength);
2992
+ }
2993
+ handleJsonPayload(payload, rawBytesLength) {
2994
+ const bytes = rawBytesLength ?? payload.length;
2995
+ const startMs = perfNow();
2996
+ let parsedJson;
2997
+ try {
2998
+ parsedJson = JSON.parse(payload);
2999
+ }
3000
+ catch {
3001
+ return;
3002
+ }
3003
+ const parsed = WSOutboundMessageSchema.safeParse(parsedJson);
3004
+ if (!parsed.success) {
3005
+ const msgType = parsedJson != null &&
3006
+ typeof parsedJson === "object" &&
3007
+ "type" in parsedJson &&
3008
+ typeof parsedJson.type === "string"
3009
+ ? parsedJson.type
3010
+ : "unknown";
3011
+ this.logger.warn({ msgType, error: parsed.error.message }, "Message validation failed");
3012
+ return;
3013
+ }
3014
+ if (parsed.data.type === "pong") {
3015
+ this.runtimeMetrics?.recordMessage("pong", bytes, perfNow() - startMs);
3016
+ return;
3017
+ }
3018
+ this.handleSessionMessage(parsed.data.message);
3019
+ const msgType = parsed.data.message.type;
3020
+ this.runtimeMetrics?.recordMessage(msgType, bytes, perfNow() - startMs);
3021
+ if (parsed.data.message.type === "agent_stream") {
3022
+ this.runtimeMetrics?.recordAgentStream(parsed.data.message.payload);
3023
+ }
3024
+ }
3025
+ tryHandleBinaryFrame(rawBytes) {
3026
+ const fileFrame = decodeFileTransferFrame(rawBytes);
3027
+ if (fileFrame) {
3028
+ this.handleFileTransferFrame(fileFrame);
3029
+ this.runtimeMetrics?.recordBinaryFrame("other", rawBytes.byteLength, 0);
3030
+ return true;
3031
+ }
3032
+ const frame = decodeTerminalStreamFrame(rawBytes);
3033
+ if (!frame) {
3034
+ return false;
3035
+ }
3036
+ const binaryStartMs = perfNow();
3037
+ this.terminalStreams.handleFrame(frame);
3038
+ let frameKind = "other";
3039
+ if (frame.opcode === TerminalStreamOpcode.Output) {
3040
+ frameKind = "output";
3041
+ }
3042
+ else if (frame.opcode === TerminalStreamOpcode.Snapshot) {
3043
+ frameKind = "snapshot";
3044
+ }
3045
+ this.runtimeMetrics?.recordBinaryFrame(frameKind, rawBytes.byteLength, perfNow() - binaryStartMs);
3046
+ return true;
3047
+ }
3048
+ handleFileTransferFrame(frame) {
3049
+ if (frame.opcode === FileTransferOpcode.FileBegin) {
3050
+ const pending = this.pendingBinaryFileReads.get(frame.requestId);
3051
+ if (!pending) {
3052
+ return;
3053
+ }
3054
+ this.activeBinaryFileTransfers.set(frame.requestId, {
3055
+ ...pending,
3056
+ mime: frame.metadata.mime,
3057
+ size: frame.metadata.size,
3058
+ encoding: frame.metadata.encoding,
3059
+ modifiedAt: frame.metadata.modifiedAt,
3060
+ chunks: [],
3061
+ });
3062
+ return;
3063
+ }
3064
+ const transfer = this.activeBinaryFileTransfers.get(frame.requestId);
3065
+ if (!transfer) {
3066
+ return;
3067
+ }
3068
+ if (frame.opcode === FileTransferOpcode.FileChunk) {
3069
+ transfer.chunks.push(frame.payload);
3070
+ return;
3071
+ }
3072
+ const bytes = concatByteChunks(transfer.chunks, transfer.size);
3073
+ this.activeBinaryFileTransfers.delete(frame.requestId);
3074
+ this.completedBinaryFileReads.set(frame.requestId, {
3075
+ bytes,
3076
+ mime: transfer.mime,
3077
+ size: transfer.size,
3078
+ path: transfer.path,
3079
+ kind: binaryFileKind(transfer.mime, transfer.encoding),
3080
+ modifiedAt: transfer.modifiedAt,
3081
+ });
3082
+ this.handleSessionMessage({
3083
+ type: "file_explorer_response",
3084
+ payload: {
3085
+ cwd: transfer.cwd,
3086
+ path: transfer.path,
3087
+ mode: "file",
3088
+ directory: null,
3089
+ file: null,
3090
+ error: null,
3091
+ requestId: frame.requestId,
3092
+ },
3093
+ });
3094
+ }
3095
+ updateConnectionState(next, metadata) {
3096
+ const previous = this.connectionState;
3097
+ this.connectionState = next;
3098
+ const reasonFromNext = next.status === "disconnected" && typeof next.reason === "string" ? next.reason : null;
3099
+ const reason = metadata?.reason ?? reasonFromNext;
3100
+ const reasonCode = metadata?.reasonCode ?? toReasonCode(reason);
3101
+ this.logger.debug({
3102
+ serverId: this.logServerId,
3103
+ clientIdHash: this.logClientIdHash,
3104
+ from: previous.status,
3105
+ to: next.status,
3106
+ event: metadata?.event ?? "STATE_UPDATE",
3107
+ connectionPath: this.logConnectionPath,
3108
+ generation: this.logGeneration,
3109
+ reasonCode,
3110
+ reason,
3111
+ }, "DaemonClientTransition");
3112
+ for (const listener of this.connectionListeners) {
3113
+ try {
3114
+ listener(next);
3115
+ }
3116
+ catch {
3117
+ // no-op
3118
+ }
3119
+ }
3120
+ }
3121
+ setReconnectEnabled(enabled) {
3122
+ this.config = { ...this.config, reconnect: { ...this.config.reconnect, enabled } };
3123
+ }
3124
+ scheduleReconnect(input) {
3125
+ if (this.reconnectTimeout) {
3126
+ clearTimeout(this.reconnectTimeout);
3127
+ this.reconnectTimeout = null;
3128
+ }
3129
+ const wasDisposed = this.connectionState.status === "disposed";
3130
+ const reason = input?.reason;
3131
+ if (typeof reason === "string" && reason.trim().length > 0) {
3132
+ this.lastErrorValue = reason.trim();
3133
+ }
3134
+ // Clear all pending waiters and queued sends since the connection was lost
3135
+ // and responses from the previous connection will never arrive.
3136
+ this.clearWaiters(new Error(reason ?? "Connection lost"));
3137
+ this.rejectPendingSendQueue(new Error(reason ?? "Connection lost"));
3138
+ this.terminalStreams.clearSlots();
3139
+ this.lastServerInfoMessage = null;
3140
+ if (wasDisposed) {
3141
+ this.rejectConnect(new Error(reason ?? "Daemon client is disposed"));
3142
+ return;
3143
+ }
3144
+ this.emitDisconnectedStateForReconnect(reason, input);
3145
+ if (!this.shouldReconnect || this.config.reconnect?.enabled === false) {
3146
+ this.rejectConnect(new Error(reason ?? "Transport disconnected before connect"));
3147
+ return;
3148
+ }
3149
+ this.armReconnectTimer();
3150
+ }
3151
+ emitDisconnectedStateForReconnect(reason, input) {
3152
+ this.updateConnectionState({
3153
+ status: "disconnected",
3154
+ ...(reason ? { reason } : {}),
3155
+ }, {
3156
+ event: input?.event ?? "TRANSPORT_CLOSE",
3157
+ ...(reason ? { reason } : {}),
3158
+ ...(input?.reasonCode ? { reasonCode: input.reasonCode } : {}),
3159
+ });
3160
+ }
3161
+ armReconnectTimer() {
3162
+ const attempt = this.reconnectAttempt;
3163
+ const baseDelay = this.config.reconnect?.baseDelayMs ?? DEFAULT_RECONNECT_BASE_DELAY_MS;
3164
+ const maxDelay = this.config.reconnect?.maxDelayMs ?? DEFAULT_RECONNECT_MAX_DELAY_MS;
3165
+ const delay = Math.min(baseDelay * 2 ** attempt, maxDelay);
3166
+ this.reconnectAttempt = attempt + 1;
3167
+ this.reconnectTimeout = setTimeout(() => {
3168
+ this.reconnectTimeout = null;
3169
+ if (!this.shouldReconnect) {
3170
+ return;
3171
+ }
3172
+ this.attemptConnect();
3173
+ }, delay);
3174
+ }
3175
+ handleSessionMessage(msg) {
3176
+ if (msg.type === "status") {
3177
+ const serverInfo = parseServerInfoStatusPayload(msg.payload);
3178
+ if (serverInfo) {
3179
+ this.lastServerInfoMessage = serverInfo;
3180
+ if (this.connectionState.status === "connecting") {
3181
+ this.resetConnectTimeout();
3182
+ this.reconnectAttempt = 0;
3183
+ this.updateConnectionState({ status: "connected" }, { event: "HELLO_SERVER_INFO" });
3184
+ this.resubscribeCheckoutDiffSubscriptions();
3185
+ this.resubscribeTerminalDirectorySubscriptions();
3186
+ this.flushPendingSendQueue();
3187
+ this.resolveConnect();
3188
+ }
3189
+ }
3190
+ }
3191
+ if (msg.type === "terminal_stream_exit") {
3192
+ this.terminalStreams.removeTerminal(msg.payload.terminalId);
3193
+ }
3194
+ if (this.rawMessageListeners.size > 0) {
3195
+ for (const handler of this.rawMessageListeners) {
3196
+ try {
3197
+ handler(msg);
3198
+ }
3199
+ catch {
3200
+ // no-op
3201
+ }
3202
+ }
3203
+ }
3204
+ const handlers = this.messageHandlers.get(msg.type);
3205
+ if (handlers) {
3206
+ for (const handler of handlers) {
3207
+ try {
3208
+ handler(msg);
3209
+ }
3210
+ catch {
3211
+ // no-op
3212
+ }
3213
+ }
3214
+ }
3215
+ const event = this.toEvent(msg);
3216
+ if (event) {
3217
+ for (const handler of this.eventListeners) {
3218
+ handler(event);
3219
+ }
3220
+ }
3221
+ this.resolveWaiters(msg);
3222
+ }
3223
+ resolveWaiters(msg) {
3224
+ for (const waiter of Array.from(this.waiters)) {
3225
+ const result = waiter.predicate(msg);
3226
+ if (result !== null) {
3227
+ this.waiters.delete(waiter);
3228
+ if (waiter.timeoutHandle) {
3229
+ clearTimeout(waiter.timeoutHandle);
3230
+ }
3231
+ waiter.resolve(result);
3232
+ }
3233
+ }
3234
+ }
3235
+ clearWaiters(error) {
3236
+ for (const waiter of Array.from(this.waiters)) {
3237
+ if (waiter.timeoutHandle) {
3238
+ clearTimeout(waiter.timeoutHandle);
3239
+ }
3240
+ waiter.reject(error);
3241
+ }
3242
+ this.waiters.clear();
3243
+ }
3244
+ toEvent(msg) {
3245
+ switch (msg.type) {
3246
+ case "agent_update":
3247
+ return {
3248
+ type: "agent_update",
3249
+ agentId: msg.payload.kind === "upsert" ? msg.payload.agent.id : msg.payload.agentId,
3250
+ payload: msg.payload,
3251
+ };
3252
+ case "workspace_update":
3253
+ return {
3254
+ type: "workspace_update",
3255
+ workspaceId: msg.payload.kind === "upsert" ? msg.payload.workspace.id : msg.payload.id,
3256
+ payload: msg.payload,
3257
+ };
3258
+ case "workspace_setup_progress":
3259
+ return {
3260
+ type: "workspace_setup_progress",
3261
+ workspaceId: msg.payload.workspaceId,
3262
+ payload: msg.payload,
3263
+ };
3264
+ case "agent_stream":
3265
+ return {
3266
+ type: "agent_stream",
3267
+ agentId: msg.payload.agentId,
3268
+ event: msg.payload.event,
3269
+ timestamp: msg.payload.timestamp,
3270
+ ...(typeof msg.payload.seq === "number" ? { seq: msg.payload.seq } : {}),
3271
+ ...(typeof msg.payload.epoch === "string" ? { epoch: msg.payload.epoch } : {}),
3272
+ };
3273
+ case "status":
3274
+ return { type: "status", payload: msg.payload };
3275
+ case "agent_deleted":
3276
+ return { type: "agent_deleted", agentId: msg.payload.agentId };
3277
+ case "agent_permission_request":
3278
+ return {
3279
+ type: "agent_permission_request",
3280
+ agentId: msg.payload.agentId,
3281
+ request: msg.payload.request,
3282
+ };
3283
+ case "agent_permission_resolved":
3284
+ return {
3285
+ type: "agent_permission_resolved",
3286
+ agentId: msg.payload.agentId,
3287
+ requestId: msg.payload.requestId,
3288
+ resolution: msg.payload.resolution,
3289
+ };
3290
+ case "providers_snapshot_update":
3291
+ return {
3292
+ type: "providers_snapshot_update",
3293
+ payload: msg.payload,
3294
+ };
3295
+ default:
3296
+ return null;
3297
+ }
3298
+ }
3299
+ waitForWithCancel(predicate, timeout = 30000, _options) {
3300
+ // Capture stack trace at call site, not inside setTimeout
3301
+ const timeoutError = new Error(`Timeout waiting for message (${timeout}ms)`);
3302
+ let waiter = null;
3303
+ let settled = false;
3304
+ let rejectFn = null;
3305
+ const promise = new Promise((resolve, reject) => {
3306
+ const wrappedResolve = (value) => {
3307
+ if (settled)
3308
+ return;
3309
+ settled = true;
3310
+ resolve(value);
3311
+ };
3312
+ const wrappedReject = (error) => {
3313
+ if (settled)
3314
+ return;
3315
+ settled = true;
3316
+ reject(error);
3317
+ };
3318
+ rejectFn = wrappedReject;
3319
+ const timeoutHandle = timeout > 0
3320
+ ? setTimeout(() => {
3321
+ if (waiter) {
3322
+ this.waiters.delete(waiter);
3323
+ }
3324
+ wrappedReject(timeoutError);
3325
+ }, timeout)
3326
+ : null;
3327
+ waiter = {
3328
+ predicate,
3329
+ resolve: wrappedResolve,
3330
+ reject: wrappedReject,
3331
+ timeoutHandle,
3332
+ };
3333
+ this.waiters.add(waiter);
3334
+ });
3335
+ const cancel = (error) => {
3336
+ if (settled) {
3337
+ return;
3338
+ }
3339
+ if (waiter) {
3340
+ this.waiters.delete(waiter);
3341
+ if (waiter.timeoutHandle) {
3342
+ clearTimeout(waiter.timeoutHandle);
3343
+ }
3344
+ }
3345
+ if (rejectFn) {
3346
+ rejectFn(error);
3347
+ return;
3348
+ }
3349
+ // Extremely unlikely: cancel called before the Promise executor ran.
3350
+ queueMicrotask(() => {
3351
+ if (!settled && rejectFn) {
3352
+ rejectFn(error);
3353
+ }
3354
+ });
3355
+ };
3356
+ return { promise, cancel };
3357
+ }
3358
+ }
3359
+ function resolveAgentConfig(options) {
3360
+ const { config, provider, cwd, workspaceId: _workspaceId, initialPrompt: _initialPrompt, images: _images, git: _git, worktreeName: _worktreeName, requestId: _requestId, labels: _labels, ...overrides } = options;
3361
+ const baseConfig = {
3362
+ ...(provider ? { provider } : {}),
3363
+ ...(cwd ? { cwd } : {}),
3364
+ ...overrides,
3365
+ };
3366
+ const merged = config ? { ...baseConfig, ...config } : baseConfig;
3367
+ if (!merged.provider || !merged.cwd) {
3368
+ throw new Error("createAgent requires provider and cwd");
3369
+ }
3370
+ return {
3371
+ ...merged,
3372
+ provider: merged.provider,
3373
+ cwd: merged.cwd,
3374
+ };
3375
+ }
3376
+ //# sourceMappingURL=daemon-client.js.map