@getpaseo/server 0.1.62 → 0.1.63

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 (464) hide show
  1. package/README.md +4 -0
  2. package/dist/server/client/daemon-client-runtime-metrics.d.ts +6 -6
  3. package/dist/server/client/daemon-client-runtime-metrics.d.ts.map +1 -1
  4. package/dist/server/client/daemon-client-transport-types.d.ts +13 -13
  5. package/dist/server/client/daemon-client-transport-types.d.ts.map +1 -1
  6. package/dist/server/client/daemon-client-websocket-transport.d.ts +1 -1
  7. package/dist/server/client/daemon-client-websocket-transport.d.ts.map +1 -1
  8. package/dist/server/client/daemon-client-websocket-transport.js +5 -4
  9. package/dist/server/client/daemon-client-websocket-transport.js.map +1 -1
  10. package/dist/server/client/daemon-client.d.ts +59 -37
  11. package/dist/server/client/daemon-client.d.ts.map +1 -1
  12. package/dist/server/client/daemon-client.js +62 -17
  13. package/dist/server/client/daemon-client.js.map +1 -1
  14. package/dist/server/server/agent/agent-loading.d.ts.map +1 -1
  15. package/dist/server/server/agent/agent-loading.js +5 -3
  16. package/dist/server/server/agent/agent-loading.js.map +1 -1
  17. package/dist/server/server/agent/agent-manager.d.ts +45 -19
  18. package/dist/server/server/agent/agent-manager.d.ts.map +1 -1
  19. package/dist/server/server/agent/agent-manager.js +393 -290
  20. package/dist/server/server/agent/agent-manager.js.map +1 -1
  21. package/dist/server/server/agent/agent-metadata-generator.d.ts +6 -6
  22. package/dist/server/server/agent/agent-metadata-generator.d.ts.map +1 -1
  23. package/dist/server/server/agent/agent-metadata-generator.js +46 -38
  24. package/dist/server/server/agent/agent-metadata-generator.js.map +1 -1
  25. package/dist/server/server/agent/agent-projections.d.ts +4 -6
  26. package/dist/server/server/agent/agent-projections.d.ts.map +1 -1
  27. package/dist/server/server/agent/agent-projections.js +59 -65
  28. package/dist/server/server/agent/agent-projections.js.map +1 -1
  29. package/dist/server/server/agent/agent-response-loop.d.ts +4 -4
  30. package/dist/server/server/agent/agent-response-loop.d.ts.map +1 -1
  31. package/dist/server/server/agent/agent-response-loop.js +58 -45
  32. package/dist/server/server/agent/agent-response-loop.js.map +1 -1
  33. package/dist/server/server/agent/agent-sdk-types.d.ts +43 -40
  34. package/dist/server/server/agent/agent-sdk-types.d.ts.map +1 -1
  35. package/dist/server/server/agent/agent-sdk-types.js.map +1 -1
  36. package/dist/server/server/agent/agent-storage.d.ts +2 -2
  37. package/dist/server/server/agent/agent-storage.d.ts.map +1 -1
  38. package/dist/server/server/agent/agent-storage.js +29 -36
  39. package/dist/server/server/agent/agent-storage.js.map +1 -1
  40. package/dist/server/server/agent/agent-stream-coalescer.d.ts +6 -6
  41. package/dist/server/server/agent/agent-stream-coalescer.d.ts.map +1 -1
  42. package/dist/server/server/agent/agent-timeline-store-types.d.ts +10 -10
  43. package/dist/server/server/agent/agent-timeline-store-types.d.ts.map +1 -1
  44. package/dist/server/server/agent/agent-timeline-store.d.ts +2 -2
  45. package/dist/server/server/agent/agent-timeline-store.d.ts.map +1 -1
  46. package/dist/server/server/agent/agent-timeline-store.js +85 -64
  47. package/dist/server/server/agent/agent-timeline-store.js.map +1 -1
  48. package/dist/server/server/agent/mcp-server.d.ts.map +1 -1
  49. package/dist/server/server/agent/mcp-server.js +185 -148
  50. package/dist/server/server/agent/mcp-server.js.map +1 -1
  51. package/dist/server/server/agent/mcp-shared.d.ts +9 -2
  52. package/dist/server/server/agent/mcp-shared.d.ts.map +1 -1
  53. package/dist/server/server/agent/mcp-shared.js +2 -0
  54. package/dist/server/server/agent/mcp-shared.js.map +1 -1
  55. package/dist/server/server/agent/model-resolver.d.ts +2 -2
  56. package/dist/server/server/agent/model-resolver.d.ts.map +1 -1
  57. package/dist/server/server/agent/model-resolver.js +9 -5
  58. package/dist/server/server/agent/model-resolver.js.map +1 -1
  59. package/dist/server/server/agent/provider-launch-config.d.ts +28 -17
  60. package/dist/server/server/agent/provider-launch-config.d.ts.map +1 -1
  61. package/dist/server/server/agent/provider-launch-config.js +20 -9
  62. package/dist/server/server/agent/provider-launch-config.js.map +1 -1
  63. package/dist/server/server/agent/provider-registry.d.ts +4 -2
  64. package/dist/server/server/agent/provider-registry.d.ts.map +1 -1
  65. package/dist/server/server/agent/provider-registry.js +24 -21
  66. package/dist/server/server/agent/provider-registry.js.map +1 -1
  67. package/dist/server/server/agent/provider-snapshot-manager.d.ts +6 -5
  68. package/dist/server/server/agent/provider-snapshot-manager.d.ts.map +1 -1
  69. package/dist/server/server/agent/provider-snapshot-manager.js +40 -31
  70. package/dist/server/server/agent/provider-snapshot-manager.js.map +1 -1
  71. package/dist/server/server/agent/providers/acp-agent.d.ts +11 -12
  72. package/dist/server/server/agent/providers/acp-agent.d.ts.map +1 -1
  73. package/dist/server/server/agent/providers/acp-agent.js +148 -122
  74. package/dist/server/server/agent/providers/acp-agent.js.map +1 -1
  75. package/dist/server/server/agent/providers/claude/sidechain-tracker.d.ts +2 -0
  76. package/dist/server/server/agent/providers/claude/sidechain-tracker.d.ts.map +1 -1
  77. package/dist/server/server/agent/providers/claude/sidechain-tracker.js +47 -45
  78. package/dist/server/server/agent/providers/claude/sidechain-tracker.js.map +1 -1
  79. package/dist/server/server/agent/providers/claude/task-notification-tool-call.d.ts +2 -2
  80. package/dist/server/server/agent/providers/claude/task-notification-tool-call.d.ts.map +1 -1
  81. package/dist/server/server/agent/providers/claude/task-notification-tool-call.js +10 -5
  82. package/dist/server/server/agent/providers/claude/task-notification-tool-call.js.map +1 -1
  83. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.d.ts.map +1 -1
  84. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.js +11 -2
  85. package/dist/server/server/agent/providers/claude/tool-call-detail-parser.js.map +1 -1
  86. package/dist/server/server/agent/providers/claude/tool-call-mapper.d.ts +2 -2
  87. package/dist/server/server/agent/providers/claude/tool-call-mapper.d.ts.map +1 -1
  88. package/dist/server/server/agent/providers/claude/tool-call-mapper.js +20 -13
  89. package/dist/server/server/agent/providers/claude/tool-call-mapper.js.map +1 -1
  90. package/dist/server/server/agent/providers/claude-agent.d.ts +20 -8
  91. package/dist/server/server/agent/providers/claude-agent.d.ts.map +1 -1
  92. package/dist/server/server/agent/providers/claude-agent.js +610 -460
  93. package/dist/server/server/agent/providers/claude-agent.js.map +1 -1
  94. package/dist/server/server/agent/providers/codex/tool-call-detail-parser.d.ts +2 -2
  95. package/dist/server/server/agent/providers/codex/tool-call-detail-parser.d.ts.map +1 -1
  96. package/dist/server/server/agent/providers/codex/tool-call-mapper.d.ts +2 -2
  97. package/dist/server/server/agent/providers/codex/tool-call-mapper.d.ts.map +1 -1
  98. package/dist/server/server/agent/providers/codex/tool-call-mapper.js +49 -44
  99. package/dist/server/server/agent/providers/codex/tool-call-mapper.js.map +1 -1
  100. package/dist/server/server/agent/providers/codex-app-server-agent.d.ts +27 -8
  101. package/dist/server/server/agent/providers/codex-app-server-agent.d.ts.map +1 -1
  102. package/dist/server/server/agent/providers/codex-app-server-agent.js +564 -492
  103. package/dist/server/server/agent/providers/codex-app-server-agent.js.map +1 -1
  104. package/dist/server/server/agent/providers/codex-rollout-timeline.d.ts +2 -2
  105. package/dist/server/server/agent/providers/codex-rollout-timeline.d.ts.map +1 -1
  106. package/dist/server/server/agent/providers/codex-rollout-timeline.js +58 -47
  107. package/dist/server/server/agent/providers/codex-rollout-timeline.js.map +1 -1
  108. package/dist/server/server/agent/providers/copilot-acp-agent.d.ts +2 -2
  109. package/dist/server/server/agent/providers/copilot-acp-agent.d.ts.map +1 -1
  110. package/dist/server/server/agent/providers/diagnostic-utils.d.ts +3 -3
  111. package/dist/server/server/agent/providers/diagnostic-utils.d.ts.map +1 -1
  112. package/dist/server/server/agent/providers/diagnostic-utils.js +82 -9
  113. package/dist/server/server/agent/providers/diagnostic-utils.js.map +1 -1
  114. package/dist/server/server/agent/providers/generic-acp-agent.d.ts +2 -2
  115. package/dist/server/server/agent/providers/generic-acp-agent.d.ts.map +1 -1
  116. package/dist/server/server/agent/providers/mock-load-test-agent.d.ts.map +1 -1
  117. package/dist/server/server/agent/providers/mock-load-test-agent.js.map +1 -1
  118. package/dist/server/server/agent/providers/opencode/tool-call-mapper.d.ts +2 -2
  119. package/dist/server/server/agent/providers/opencode/tool-call-mapper.d.ts.map +1 -1
  120. package/dist/server/server/agent/providers/opencode-agent.d.ts +2 -2
  121. package/dist/server/server/agent/providers/opencode-agent.d.ts.map +1 -1
  122. package/dist/server/server/agent/providers/opencode-agent.js +385 -360
  123. package/dist/server/server/agent/providers/opencode-agent.js.map +1 -1
  124. package/dist/server/server/agent/providers/pi-direct-agent.d.ts +1 -0
  125. package/dist/server/server/agent/providers/pi-direct-agent.d.ts.map +1 -1
  126. package/dist/server/server/agent/providers/pi-direct-agent.js +109 -140
  127. package/dist/server/server/agent/providers/pi-direct-agent.js.map +1 -1
  128. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.d.ts.map +1 -1
  129. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.js +3 -1
  130. package/dist/server/server/agent/providers/test-utils/session-stream-adapter.js.map +1 -1
  131. package/dist/server/server/agent/providers/tool-call-detail-primitives.d.ts +3 -3
  132. package/dist/server/server/agent/providers/tool-call-detail-primitives.d.ts.map +1 -1
  133. package/dist/server/server/agent/providers/tool-call-detail-primitives.js +102 -73
  134. package/dist/server/server/agent/providers/tool-call-detail-primitives.js.map +1 -1
  135. package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts +2 -2
  136. package/dist/server/server/agent/providers/tool-call-mapper-utils.d.ts.map +1 -1
  137. package/dist/server/server/agent/stt-manager.d.ts.map +1 -1
  138. package/dist/server/server/agent/stt-manager.js +63 -53
  139. package/dist/server/server/agent/stt-manager.js.map +1 -1
  140. package/dist/server/server/agent/timeline-projection.d.ts +6 -6
  141. package/dist/server/server/agent/timeline-projection.d.ts.map +1 -1
  142. package/dist/server/server/agent/timeline-projection.js +11 -6
  143. package/dist/server/server/agent/timeline-projection.js.map +1 -1
  144. package/dist/server/server/agent/tts-manager.d.ts.map +1 -1
  145. package/dist/server/server/agent/tts-manager.js +1 -0
  146. package/dist/server/server/agent/tts-manager.js.map +1 -1
  147. package/dist/server/server/agent-attention-policy.d.ts +2 -2
  148. package/dist/server/server/agent-attention-policy.d.ts.map +1 -1
  149. package/dist/server/server/bootstrap.d.ts +4 -4
  150. package/dist/server/server/bootstrap.d.ts.map +1 -1
  151. package/dist/server/server/bootstrap.js +493 -485
  152. package/dist/server/server/bootstrap.js.map +1 -1
  153. package/dist/server/server/chat/chat-service.d.ts +1 -1
  154. package/dist/server/server/chat/chat-service.d.ts.map +1 -1
  155. package/dist/server/server/chat/chat-service.js +3 -3
  156. package/dist/server/server/chat/chat-service.js.map +1 -1
  157. package/dist/server/server/checkout-diff-manager.d.ts +2 -2
  158. package/dist/server/server/checkout-diff-manager.d.ts.map +1 -1
  159. package/dist/server/server/checkout-git-utils.d.ts +5 -3
  160. package/dist/server/server/checkout-git-utils.d.ts.map +1 -1
  161. package/dist/server/server/checkout-git-utils.js +1 -2
  162. package/dist/server/server/checkout-git-utils.js.map +1 -1
  163. package/dist/server/server/config.d.ts.map +1 -1
  164. package/dist/server/server/config.js +68 -39
  165. package/dist/server/server/config.js.map +1 -1
  166. package/dist/server/server/connection-offer.d.ts +2 -2
  167. package/dist/server/server/connection-offer.d.ts.map +1 -1
  168. package/dist/server/server/daemon-config-store.d.ts +5 -3
  169. package/dist/server/server/daemon-config-store.d.ts.map +1 -1
  170. package/dist/server/server/daemon-config-store.js +26 -0
  171. package/dist/server/server/daemon-config-store.js.map +1 -1
  172. package/dist/server/server/daemon-keypair.d.ts +2 -2
  173. package/dist/server/server/daemon-keypair.d.ts.map +1 -1
  174. package/dist/server/server/editor-targets.d.ts +4 -4
  175. package/dist/server/server/editor-targets.d.ts.map +1 -1
  176. package/dist/server/server/editor-targets.js +11 -15
  177. package/dist/server/server/editor-targets.js.map +1 -1
  178. package/dist/server/server/exports.d.ts +3 -3
  179. package/dist/server/server/exports.d.ts.map +1 -1
  180. package/dist/server/server/exports.js +1 -3
  181. package/dist/server/server/exports.js.map +1 -1
  182. package/dist/server/server/file-download/token-store.d.ts +4 -4
  183. package/dist/server/server/file-download/token-store.d.ts.map +1 -1
  184. package/dist/server/server/index.js +16 -12
  185. package/dist/server/server/index.js.map +1 -1
  186. package/dist/server/server/logger.d.ts +4 -4
  187. package/dist/server/server/logger.d.ts.map +1 -1
  188. package/dist/server/server/logger.js +26 -20
  189. package/dist/server/server/logger.js.map +1 -1
  190. package/dist/server/server/loop/rpc-schemas.d.ts +52 -52
  191. package/dist/server/server/loop-service.d.ts +13 -12
  192. package/dist/server/server/loop-service.d.ts.map +1 -1
  193. package/dist/server/server/loop-service.js +22 -18
  194. package/dist/server/server/loop-service.js.map +1 -1
  195. package/dist/server/server/package-version.d.ts +2 -2
  196. package/dist/server/server/package-version.d.ts.map +1 -1
  197. package/dist/server/server/package-version.js +19 -17
  198. package/dist/server/server/package-version.js.map +1 -1
  199. package/dist/server/server/pairing-offer.d.ts +2 -2
  200. package/dist/server/server/pairing-offer.d.ts.map +1 -1
  201. package/dist/server/server/paseo-env.d.ts +9 -0
  202. package/dist/server/server/paseo-env.d.ts.map +1 -0
  203. package/dist/server/server/paseo-env.js +70 -0
  204. package/dist/server/server/paseo-env.js.map +1 -0
  205. package/dist/server/server/paseo-worktree-archive-service.d.ts +4 -4
  206. package/dist/server/server/paseo-worktree-archive-service.d.ts.map +1 -1
  207. package/dist/server/server/paseo-worktree-archive-service.js +11 -11
  208. package/dist/server/server/paseo-worktree-archive-service.js.map +1 -1
  209. package/dist/server/server/persisted-config.d.ts +62 -62
  210. package/dist/server/server/persisted-config.d.ts.map +1 -1
  211. package/dist/server/server/persisted-config.js +4 -4
  212. package/dist/server/server/persisted-config.js.map +1 -1
  213. package/dist/server/server/persistence-hooks.d.ts +8 -9
  214. package/dist/server/server/persistence-hooks.d.ts.map +1 -1
  215. package/dist/server/server/persistence-hooks.js +4 -12
  216. package/dist/server/server/persistence-hooks.js.map +1 -1
  217. package/dist/server/server/pid-lock.js.map +1 -1
  218. package/dist/server/server/push/push-service.d.ts.map +1 -1
  219. package/dist/server/server/push/push-service.js +1 -3
  220. package/dist/server/server/push/push-service.js.map +1 -1
  221. package/dist/server/server/relay-transport.d.ts +8 -8
  222. package/dist/server/server/relay-transport.d.ts.map +1 -1
  223. package/dist/server/server/relay-transport.js +27 -16
  224. package/dist/server/server/relay-transport.js.map +1 -1
  225. package/dist/server/server/schedule/service.d.ts.map +1 -1
  226. package/dist/server/server/schedule/service.js +2 -2
  227. package/dist/server/server/schedule/service.js.map +1 -1
  228. package/dist/server/server/script-health-monitor.d.ts.map +1 -1
  229. package/dist/server/server/script-health-monitor.js +7 -6
  230. package/dist/server/server/script-health-monitor.js.map +1 -1
  231. package/dist/server/server/script-proxy.js +1 -1
  232. package/dist/server/server/script-proxy.js.map +1 -1
  233. package/dist/server/server/script-status-projection.d.ts +4 -4
  234. package/dist/server/server/script-status-projection.d.ts.map +1 -1
  235. package/dist/server/server/script-status-projection.js +54 -44
  236. package/dist/server/server/script-status-projection.js.map +1 -1
  237. package/dist/server/server/server-id.d.ts +4 -4
  238. package/dist/server/server/server-id.d.ts.map +1 -1
  239. package/dist/server/server/session.d.ts +45 -14
  240. package/dist/server/server/session.d.ts.map +1 -1
  241. package/dist/server/server/session.js +1098 -761
  242. package/dist/server/server/session.js.map +1 -1
  243. package/dist/server/server/speech/audio.js +1 -1
  244. package/dist/server/server/speech/audio.js.map +1 -1
  245. package/dist/server/server/speech/providers/local/config.d.ts +6 -6
  246. package/dist/server/server/speech/providers/local/config.d.ts.map +1 -1
  247. package/dist/server/server/speech/providers/local/config.js +41 -16
  248. package/dist/server/server/speech/providers/local/config.js.map +1 -1
  249. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.d.ts +2 -2
  250. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.d.ts.map +1 -1
  251. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.js +42 -19
  252. package/dist/server/server/speech/providers/local/pocket/pocket-tts-onnx.js.map +1 -1
  253. package/dist/server/server/speech/providers/local/runtime.d.ts +4 -4
  254. package/dist/server/server/speech/providers/local/runtime.d.ts.map +1 -1
  255. package/dist/server/server/speech/providers/local/runtime.js +108 -77
  256. package/dist/server/server/speech/providers/local/runtime.js.map +1 -1
  257. package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts +2 -2
  258. package/dist/server/server/speech/providers/local/sherpa/model-catalog.d.ts.map +1 -1
  259. package/dist/server/server/speech/providers/local/sherpa/model-catalog.js +1 -4
  260. package/dist/server/server/speech/providers/local/sherpa/model-catalog.js.map +1 -1
  261. package/dist/server/server/speech/providers/local/sherpa/model-downloader.d.ts +2 -2
  262. package/dist/server/server/speech/providers/local/sherpa/model-downloader.d.ts.map +1 -1
  263. package/dist/server/server/speech/providers/local/sherpa/model-downloader.js +19 -19
  264. package/dist/server/server/speech/providers/local/sherpa/model-downloader.js.map +1 -1
  265. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.d.ts +28 -7
  266. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.d.ts.map +1 -1
  267. package/dist/server/server/speech/providers/local/sherpa/sherpa-offline-recognizer.js.map +1 -1
  268. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.d.ts +23 -4
  269. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.d.ts.map +1 -1
  270. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.js +35 -28
  271. package/dist/server/server/speech/providers/local/sherpa/sherpa-online-recognizer.js.map +1 -1
  272. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.d.ts +5 -5
  273. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-loader.d.ts.map +1 -1
  274. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.d.ts +7 -7
  275. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.d.ts.map +1 -1
  276. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.js +5 -0
  277. package/dist/server/server/speech/providers/local/sherpa/sherpa-onnx-node-loader.js.map +1 -1
  278. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.d.ts.map +1 -1
  279. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.js +3 -1
  280. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-realtime-session.js.map +1 -1
  281. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.d.ts +2 -2
  282. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.d.ts.map +1 -1
  283. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.js +3 -1
  284. package/dist/server/server/speech/providers/local/sherpa/sherpa-parakeet-stt.js.map +1 -1
  285. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.d.ts.map +1 -1
  286. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.js +10 -4
  287. package/dist/server/server/speech/providers/local/sherpa/sherpa-realtime-session.js.map +1 -1
  288. package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.d.ts +2 -2
  289. package/dist/server/server/speech/providers/local/sherpa/sherpa-runtime-env.d.ts.map +1 -1
  290. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.d.ts +2 -2
  291. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.d.ts.map +1 -1
  292. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.js +4 -1
  293. package/dist/server/server/speech/providers/local/sherpa/sherpa-stt.js.map +1 -1
  294. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.d.ts +2 -2
  295. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.d.ts.map +1 -1
  296. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.js +18 -11
  297. package/dist/server/server/speech/providers/local/sherpa/sherpa-tts.js.map +1 -1
  298. package/dist/server/server/speech/providers/openai/config.d.ts +2 -2
  299. package/dist/server/server/speech/providers/openai/config.d.ts.map +1 -1
  300. package/dist/server/server/speech/providers/openai/config.js +58 -31
  301. package/dist/server/server/speech/providers/openai/config.js.map +1 -1
  302. package/dist/server/server/speech/providers/openai/realtime-transcription-session.d.ts.map +1 -1
  303. package/dist/server/server/speech/providers/openai/realtime-transcription-session.js +2 -2
  304. package/dist/server/server/speech/providers/openai/realtime-transcription-session.js.map +1 -1
  305. package/dist/server/server/speech/providers/openai/runtime.d.ts +4 -4
  306. package/dist/server/server/speech/providers/openai/runtime.d.ts.map +1 -1
  307. package/dist/server/server/speech/providers/openai/runtime.js +37 -32
  308. package/dist/server/server/speech/providers/openai/runtime.js.map +1 -1
  309. package/dist/server/server/speech/providers/openai/stt.d.ts.map +1 -1
  310. package/dist/server/server/speech/providers/openai/stt.js +4 -3
  311. package/dist/server/server/speech/providers/openai/stt.js.map +1 -1
  312. package/dist/server/server/speech/providers/openai/tts.d.ts.map +1 -1
  313. package/dist/server/server/speech/providers/openai/tts.js +3 -2
  314. package/dist/server/server/speech/providers/openai/tts.js.map +1 -1
  315. package/dist/server/server/speech/speech-config-resolver.d.ts.map +1 -1
  316. package/dist/server/server/speech/speech-config-resolver.js +46 -17
  317. package/dist/server/server/speech/speech-config-resolver.js.map +1 -1
  318. package/dist/server/server/speech/speech-provider.d.ts +2 -2
  319. package/dist/server/server/speech/speech-provider.d.ts.map +1 -1
  320. package/dist/server/server/speech/speech-runtime.d.ts +6 -6
  321. package/dist/server/server/speech/speech-runtime.d.ts.map +1 -1
  322. package/dist/server/server/speech/speech-runtime.js +17 -17
  323. package/dist/server/server/speech/speech-runtime.js.map +1 -1
  324. package/dist/server/server/speech/speech-types.d.ts +2 -2
  325. package/dist/server/server/speech/speech-types.d.ts.map +1 -1
  326. package/dist/server/server/speech/turn-detection-provider.d.ts +2 -2
  327. package/dist/server/server/speech/turn-detection-provider.d.ts.map +1 -1
  328. package/dist/server/server/utils/diff-highlighter.d.ts +0 -3
  329. package/dist/server/server/utils/diff-highlighter.d.ts.map +1 -1
  330. package/dist/server/server/utils/diff-highlighter.js +67 -66
  331. package/dist/server/server/utils/diff-highlighter.js.map +1 -1
  332. package/dist/server/server/voice/voice-turn-controller.d.ts.map +1 -1
  333. package/dist/server/server/voice/voice-turn-controller.js +1 -0
  334. package/dist/server/server/voice/voice-turn-controller.js.map +1 -1
  335. package/dist/server/server/voice-types.d.ts +2 -2
  336. package/dist/server/server/voice-types.d.ts.map +1 -1
  337. package/dist/server/server/websocket-server.d.ts +31 -21
  338. package/dist/server/server/websocket-server.d.ts.map +1 -1
  339. package/dist/server/server/websocket-server.js +299 -197
  340. package/dist/server/server/websocket-server.js.map +1 -1
  341. package/dist/server/server/workspace-git-metadata.d.ts +2 -2
  342. package/dist/server/server/workspace-git-metadata.d.ts.map +1 -1
  343. package/dist/server/server/workspace-git-metadata.js +2 -32
  344. package/dist/server/server/workspace-git-metadata.js.map +1 -1
  345. package/dist/server/server/workspace-git-service.d.ts +8 -4
  346. package/dist/server/server/workspace-git-service.d.ts.map +1 -1
  347. package/dist/server/server/workspace-git-service.js +163 -115
  348. package/dist/server/server/workspace-git-service.js.map +1 -1
  349. package/dist/server/server/workspace-reconciliation-service.d.ts +5 -4
  350. package/dist/server/server/workspace-reconciliation-service.d.ts.map +1 -1
  351. package/dist/server/server/workspace-reconciliation-service.js +82 -82
  352. package/dist/server/server/workspace-reconciliation-service.js.map +1 -1
  353. package/dist/server/server/workspace-registry-bootstrap.d.ts.map +1 -1
  354. package/dist/server/server/workspace-registry-bootstrap.js +40 -33
  355. package/dist/server/server/workspace-registry-bootstrap.js.map +1 -1
  356. package/dist/server/server/workspace-registry-model.d.ts +19 -6
  357. package/dist/server/server/workspace-registry-model.d.ts.map +1 -1
  358. package/dist/server/server/workspace-registry-model.js +35 -21
  359. package/dist/server/server/workspace-registry-model.js.map +1 -1
  360. package/dist/server/server/workspace-registry.d.ts +2 -2
  361. package/dist/server/server/workspace-script-runtime-store.d.ts +2 -2
  362. package/dist/server/server/workspace-script-runtime-store.d.ts.map +1 -1
  363. package/dist/server/server/workspace-service-env.js +3 -3
  364. package/dist/server/server/workspace-service-env.js.map +1 -1
  365. package/dist/server/server/worktree-bootstrap.d.ts +4 -4
  366. package/dist/server/server/worktree-bootstrap.d.ts.map +1 -1
  367. package/dist/server/server/worktree-bootstrap.js +95 -67
  368. package/dist/server/server/worktree-bootstrap.js.map +1 -1
  369. package/dist/server/server/worktree-session.d.ts +8 -8
  370. package/dist/server/server/worktree-session.d.ts.map +1 -1
  371. package/dist/server/server/worktree-session.js +27 -19
  372. package/dist/server/server/worktree-session.js.map +1 -1
  373. package/dist/server/services/github-service.d.ts +1 -7
  374. package/dist/server/services/github-service.d.ts.map +1 -1
  375. package/dist/server/services/github-service.js +123 -143
  376. package/dist/server/services/github-service.js.map +1 -1
  377. package/dist/server/shared/agent-attention-notification.d.ts +9 -8
  378. package/dist/server/shared/agent-attention-notification.d.ts.map +1 -1
  379. package/dist/server/shared/agent-attention-notification.js +27 -17
  380. package/dist/server/shared/agent-attention-notification.js.map +1 -1
  381. package/dist/server/shared/daemon-endpoints.d.ts +2 -2
  382. package/dist/server/shared/daemon-endpoints.d.ts.map +1 -1
  383. package/dist/server/shared/daemon-endpoints.js +17 -2
  384. package/dist/server/shared/daemon-endpoints.js.map +1 -1
  385. package/dist/server/shared/messages.d.ts +21962 -3049
  386. package/dist/server/shared/messages.d.ts.map +1 -1
  387. package/dist/server/shared/messages.js +79 -2
  388. package/dist/server/shared/messages.js.map +1 -1
  389. package/dist/server/shared/terminal-stream-protocol.d.ts +2 -2
  390. package/dist/server/shared/terminal-stream-protocol.d.ts.map +1 -1
  391. package/dist/server/shared/tool-call-display.d.ts +2 -2
  392. package/dist/server/shared/tool-call-display.d.ts.map +1 -1
  393. package/dist/server/terminal/terminal-manager.d.ts.map +1 -1
  394. package/dist/server/terminal/terminal-manager.js +1 -3
  395. package/dist/server/terminal/terminal-manager.js.map +1 -1
  396. package/dist/server/terminal/terminal-output-coalescer.d.ts +6 -6
  397. package/dist/server/terminal/terminal-output-coalescer.d.ts.map +1 -1
  398. package/dist/server/terminal/terminal.d.ts +3 -2
  399. package/dist/server/terminal/terminal.d.ts.map +1 -1
  400. package/dist/server/terminal/terminal.js +57 -19
  401. package/dist/server/terminal/terminal.js.map +1 -1
  402. package/dist/server/utils/checkout-git.d.ts +13 -12
  403. package/dist/server/utils/checkout-git.d.ts.map +1 -1
  404. package/dist/server/utils/checkout-git.js +351 -281
  405. package/dist/server/utils/checkout-git.js.map +1 -1
  406. package/dist/server/utils/directory-suggestions.js +12 -33
  407. package/dist/server/utils/directory-suggestions.js.map +1 -1
  408. package/dist/server/utils/executable.d.ts +1 -14
  409. package/dist/server/utils/executable.d.ts.map +1 -1
  410. package/dist/server/utils/executable.js +13 -49
  411. package/dist/server/utils/executable.js.map +1 -1
  412. package/dist/server/utils/github-remote.d.ts +13 -0
  413. package/dist/server/utils/github-remote.d.ts.map +1 -0
  414. package/dist/server/utils/github-remote.js +128 -0
  415. package/dist/server/utils/github-remote.js.map +1 -0
  416. package/dist/server/utils/paseo-config-file.d.ts +30 -0
  417. package/dist/server/utils/paseo-config-file.d.ts.map +1 -0
  418. package/dist/server/utils/paseo-config-file.js +90 -0
  419. package/dist/server/utils/paseo-config-file.js.map +1 -0
  420. package/dist/server/utils/paseo-config-schema.d.ts +290 -0
  421. package/dist/server/utils/paseo-config-schema.d.ts.map +1 -0
  422. package/dist/server/utils/paseo-config-schema.js +60 -0
  423. package/dist/server/utils/paseo-config-schema.js.map +1 -0
  424. package/dist/server/utils/project-icon.d.ts.map +1 -1
  425. package/dist/server/utils/project-icon.js +84 -109
  426. package/dist/server/utils/project-icon.js.map +1 -1
  427. package/dist/server/utils/promise-timeout.d.ts +2 -2
  428. package/dist/server/utils/promise-timeout.d.ts.map +1 -1
  429. package/dist/server/utils/run-git-command.d.ts +3 -1
  430. package/dist/server/utils/run-git-command.d.ts.map +1 -1
  431. package/dist/server/utils/run-git-command.js +10 -1
  432. package/dist/server/utils/run-git-command.js.map +1 -1
  433. package/dist/server/utils/script-hostname.d.ts +2 -2
  434. package/dist/server/utils/script-hostname.d.ts.map +1 -1
  435. package/dist/server/utils/spawn.d.ts +10 -3
  436. package/dist/server/utils/spawn.d.ts.map +1 -1
  437. package/dist/server/utils/spawn.js +30 -5
  438. package/dist/server/utils/spawn.js.map +1 -1
  439. package/dist/server/utils/windows-command.d.ts +15 -0
  440. package/dist/server/utils/windows-command.d.ts.map +1 -0
  441. package/dist/server/utils/windows-command.js +37 -0
  442. package/dist/server/utils/windows-command.js.map +1 -0
  443. package/dist/server/utils/worktree.d.ts +10 -7
  444. package/dist/server/utils/worktree.d.ts.map +1 -1
  445. package/dist/server/utils/worktree.js +64 -55
  446. package/dist/server/utils/worktree.js.map +1 -1
  447. package/dist/src/server/pid-lock.js.map +1 -1
  448. package/package.json +15 -20
  449. package/dist/server/server/agent/llm-openai.d.ts +0 -7
  450. package/dist/server/server/agent/llm-openai.d.ts.map +0 -1
  451. package/dist/server/server/agent/llm-openai.js +0 -8
  452. package/dist/server/server/agent/llm-openai.js.map +0 -1
  453. package/dist/server/server/agent/orchestrator.d.ts +0 -12
  454. package/dist/server/server/agent/orchestrator.d.ts.map +0 -1
  455. package/dist/server/server/agent/orchestrator.js +0 -12
  456. package/dist/server/server/agent/orchestrator.js.map +0 -1
  457. package/dist/server/server/types.d.ts +0 -5
  458. package/dist/server/server/types.d.ts.map +0 -1
  459. package/dist/server/server/types.js +0 -3
  460. package/dist/server/server/types.js.map +0 -1
  461. package/dist/server/server/workspace-registry.test-helpers.d.ts +0 -37
  462. package/dist/server/server/workspace-registry.test-helpers.d.ts.map +0 -1
  463. package/dist/server/server/workspace-registry.test-helpers.js +0 -121
  464. package/dist/server/server/workspace-registry.test-helpers.js.map +0 -1
@@ -1,12 +1,13 @@
1
1
  import { WebSocketServer } from "ws";
2
2
  import { basename, join } from "path";
3
3
  import { hostname as getHostname } from "node:os";
4
+ import { applyMutableProviderConfigToOverrides } from "./daemon-config-store.js";
4
5
  import { WSInboundMessageSchema, wrapSessionMessage, } from "./messages.js";
5
6
  import { asUint8Array, decodeTerminalStreamFrame } from "../shared/terminal-stream-protocol.js";
6
7
  import { isHostnameAllowed } from "./hostnames.js";
7
8
  import { Session } from "./session.js";
8
9
  import { ProviderSnapshotManager } from "./agent/provider-snapshot-manager.js";
9
- import { buildProviderRegistry } from "./agent/provider-registry.js";
10
+ import { buildProviderRegistry, createClientsFromRegistry } from "./agent/provider-registry.js";
10
11
  import { buildWorkspaceGitMetadataFromSnapshot } from "./workspace-git-metadata.js";
11
12
  import { PushTokenStore } from "./push/token-store.js";
12
13
  import { PushService } from "./push/push-service.js";
@@ -44,6 +45,15 @@ function createFallbackWorkspaceGitService() {
44
45
  unsubscribe: () => { },
45
46
  }),
46
47
  peekSnapshot: () => null,
48
+ getCheckout: async (cwd) => ({
49
+ cwd,
50
+ isGit: false,
51
+ currentBranch: null,
52
+ remoteUrl: null,
53
+ worktreeRoot: null,
54
+ isPaseoOwnedWorktree: false,
55
+ mainRepoRoot: null,
56
+ }),
47
57
  getSnapshot: async (cwd) => createFallbackWorkspaceGitSnapshot(cwd),
48
58
  getCheckoutDiff: async () => ({ diff: "" }),
49
59
  validateBranchRef: async () => ({ kind: "not-found" }),
@@ -169,6 +179,22 @@ export class MissingDaemonVersionError extends Error {
169
179
  this.name = "MissingDaemonVersionError";
170
180
  }
171
181
  }
182
+ function requireWebSocketServices(params) {
183
+ const { chatService, loopService, scheduleService, checkoutDiffManager } = params;
184
+ if (!chatService) {
185
+ throw new Error("VoiceAssistantWebSocketServer requires a chat service.");
186
+ }
187
+ if (!loopService) {
188
+ throw new Error("VoiceAssistantWebSocketServer requires a loop service.");
189
+ }
190
+ if (!scheduleService) {
191
+ throw new Error("VoiceAssistantWebSocketServer requires a schedule service.");
192
+ }
193
+ if (!checkoutDiffManager) {
194
+ throw new Error("VoiceAssistantWebSocketServer requires a checkout diff manager.");
195
+ }
196
+ return { chatService, loopService, scheduleService, checkoutDiffManager };
197
+ }
172
198
  /**
173
199
  * WebSocket server that only accepts sockets + parses/forwards messages to the session layer.
174
200
  */
@@ -220,47 +246,43 @@ export class VoiceAssistantWebSocketServer {
220
246
  this.agentStorage = agentStorage;
221
247
  this.projectRegistry = projectRegistry ?? createNoopProjectRegistry();
222
248
  this.workspaceRegistry = workspaceRegistry ?? createNoopWorkspaceRegistry();
223
- if (!chatService) {
224
- throw new Error("VoiceAssistantWebSocketServer requires a chat service.");
225
- }
226
- this.chatService = chatService;
227
- if (!loopService) {
228
- throw new Error("VoiceAssistantWebSocketServer requires a loop service.");
229
- }
230
- this.loopService = loopService;
231
- if (!scheduleService) {
232
- throw new Error("VoiceAssistantWebSocketServer requires a schedule service.");
233
- }
234
- this.scheduleService = scheduleService;
235
- if (!checkoutDiffManager) {
236
- throw new Error("VoiceAssistantWebSocketServer requires a checkout diff manager.");
237
- }
238
- this.checkoutDiffManager = checkoutDiffManager;
249
+ const requiredServices = requireWebSocketServices({
250
+ chatService,
251
+ loopService,
252
+ scheduleService,
253
+ checkoutDiffManager,
254
+ });
255
+ this.chatService = requiredServices.chatService;
256
+ this.loopService = requiredServices.loopService;
257
+ this.scheduleService = requiredServices.scheduleService;
258
+ this.checkoutDiffManager = requiredServices.checkoutDiffManager;
239
259
  this.github = github ?? createGitHubService();
240
260
  this.workspaceGitService = workspaceGitService ?? createFallbackWorkspaceGitService();
241
261
  this.downloadTokenStore = downloadTokenStore;
242
262
  this.paseoHome = paseoHome;
243
263
  this.daemonConfigStore = daemonConfigStore;
244
264
  this.mcpBaseUrl = mcpBaseUrl;
245
- this.speech = speech ?? null;
246
- this.terminalManager = terminalManager ?? null;
247
- this.dictation = dictation ?? null;
248
- this.agentProviderRuntimeSettings = agentProviderRuntimeSettings;
249
- this.providerOverrides = providerOverrides;
250
- this.isDev = isDev === true;
265
+ this.assignOptionalServices({
266
+ speech,
267
+ terminalManager,
268
+ dictation,
269
+ agentProviderRuntimeSettings,
270
+ providerOverrides,
271
+ isDev,
272
+ onLifecycleIntent,
273
+ scriptRouteStore,
274
+ scriptRuntimeStore,
275
+ onBranchChanged,
276
+ getDaemonTcpPort,
277
+ getDaemonTcpHost,
278
+ resolveScriptHealth,
279
+ });
251
280
  const providerSnapshotLogger = this.logger.child({ module: "provider-snapshot-manager" });
252
281
  this.providerSnapshotManager = new ProviderSnapshotManager(buildProviderRegistry(providerSnapshotLogger, {
253
282
  runtimeSettings: this.agentProviderRuntimeSettings,
254
283
  providerOverrides: this.providerOverrides,
255
284
  isDev: this.isDev,
256
285
  }), providerSnapshotLogger);
257
- this.onLifecycleIntent = onLifecycleIntent ?? null;
258
- this.scriptRouteStore = scriptRouteStore ?? null;
259
- this.scriptRuntimeStore = scriptRuntimeStore ?? null;
260
- this.onBranchChanged = onBranchChanged ?? null;
261
- this.getDaemonTcpPort = getDaemonTcpPort ?? null;
262
- this.getDaemonTcpHost = getDaemonTcpHost ?? null;
263
- this.resolveScriptHealth = resolveScriptHealth ?? null;
264
286
  this.serverCapabilities = buildServerCapabilities({
265
287
  readiness: this.speech?.getReadiness() ?? null,
266
288
  });
@@ -269,6 +291,15 @@ export class VoiceAssistantWebSocketServer {
269
291
  this.publishSpeechReadiness(snapshot);
270
292
  }) ?? null;
271
293
  this.unsubscribeDaemonConfigChange = this.daemonConfigStore.onChange((config) => {
294
+ this.providerOverrides = applyMutableProviderConfigToOverrides(this.providerOverrides, config.providers);
295
+ const registry = buildProviderRegistry(providerSnapshotLogger, {
296
+ runtimeSettings: this.agentProviderRuntimeSettings,
297
+ providerOverrides: this.providerOverrides,
298
+ isDev: this.isDev,
299
+ });
300
+ const clients = createClientsFromRegistry(registry, providerSnapshotLogger);
301
+ this.providerSnapshotManager.replaceRegistry(registry);
302
+ this.agentManager.updateProviderRegistry({ providerDefinitions: registry, clients });
272
303
  this.broadcastDaemonConfigChanged(config);
273
304
  });
274
305
  const pushLogger = this.logger.child({ module: "push" });
@@ -279,42 +310,67 @@ export class VoiceAssistantWebSocketServer {
279
310
  this.logger.warn({ err, agentId: params.agentId }, "Failed to broadcast agent attention");
280
311
  });
281
312
  });
313
+ this.wss = this.createWebSocketServer(server, wsConfig);
314
+ this.startRuntimeMetricsInterval();
315
+ this.logger.info("WebSocket server initialized on /ws");
316
+ }
317
+ assignOptionalServices(params) {
318
+ this.speech = params.speech ?? null;
319
+ this.terminalManager = params.terminalManager ?? null;
320
+ this.dictation = params.dictation ?? null;
321
+ this.agentProviderRuntimeSettings = params.agentProviderRuntimeSettings;
322
+ this.providerOverrides = params.providerOverrides;
323
+ this.isDev = params.isDev === true;
324
+ this.onLifecycleIntent = params.onLifecycleIntent ?? null;
325
+ this.scriptRouteStore = params.scriptRouteStore ?? null;
326
+ this.scriptRuntimeStore = params.scriptRuntimeStore ?? null;
327
+ this.onBranchChanged = params.onBranchChanged ?? null;
328
+ this.getDaemonTcpPort = params.getDaemonTcpPort ?? null;
329
+ this.getDaemonTcpHost = params.getDaemonTcpHost ?? null;
330
+ this.resolveScriptHealth = params.resolveScriptHealth ?? null;
331
+ }
332
+ createWebSocketServer(server, wsConfig) {
282
333
  const { allowedOrigins, hostnames } = wsConfig;
283
- this.wss = new WebSocketServer({
334
+ const wss = new WebSocketServer({
284
335
  server,
285
336
  path: "/ws",
286
337
  verifyClient: ({ req }, callback) => {
287
- const requestMetadata = extractSocketRequestMetadata(req);
288
- const origin = requestMetadata.origin;
289
- const requestHost = requestMetadata.host ?? null;
290
- if (requestHost && !isHostnameAllowed(requestHost, hostnames)) {
291
- this.incrementRuntimeCounter("hostRejected");
292
- this.logger.warn({ ...requestMetadata, host: requestHost }, "Rejected connection from disallowed host");
293
- callback(false, 403, "Host not allowed");
294
- return;
295
- }
296
- const sameOrigin = !!origin &&
297
- !!requestHost &&
298
- (origin === `http://${requestHost}` || origin === `https://${requestHost}`);
299
- if (!origin || allowedOrigins.has("*") || allowedOrigins.has(origin) || sameOrigin) {
300
- callback(true);
301
- }
302
- else {
303
- this.incrementRuntimeCounter("originRejected");
304
- this.logger.warn({ ...requestMetadata, origin }, "Rejected connection from origin");
305
- callback(false, 403, "Origin not allowed");
306
- }
338
+ this.verifyWsClient(req, allowedOrigins, hostnames, callback);
307
339
  },
308
340
  });
309
- this.wss.on("connection", (ws, request) => {
341
+ wss.on("connection", (ws, request) => {
310
342
  void this.attachSocket(ws, request);
311
343
  });
344
+ return wss;
345
+ }
346
+ startRuntimeMetricsInterval() {
312
347
  const runtimeMetricsInterval = setInterval(() => {
313
348
  this.flushRuntimeMetrics();
314
349
  }, WS_RUNTIME_METRICS_FLUSH_MS);
315
350
  this.runtimeMetricsInterval = runtimeMetricsInterval;
316
351
  runtimeMetricsInterval.unref?.();
317
- this.logger.info("WebSocket server initialized on /ws");
352
+ }
353
+ verifyWsClient(req, allowedOrigins, hostnames, callback) {
354
+ const requestMetadata = extractSocketRequestMetadata(req);
355
+ const origin = requestMetadata.origin;
356
+ const requestHost = requestMetadata.host ?? null;
357
+ if (requestHost && !isHostnameAllowed(requestHost, hostnames)) {
358
+ this.incrementRuntimeCounter("hostRejected");
359
+ this.logger.warn({ ...requestMetadata, host: requestHost }, "Rejected connection from disallowed host");
360
+ callback(false, 403, "Host not allowed");
361
+ return;
362
+ }
363
+ const sameOrigin = !!origin &&
364
+ !!requestHost &&
365
+ (origin === `http://${requestHost}` || origin === `https://${requestHost}`);
366
+ if (!origin || allowedOrigins.has("*") || allowedOrigins.has(origin) || sameOrigin) {
367
+ callback(true);
368
+ }
369
+ else {
370
+ this.incrementRuntimeCounter("originRejected");
371
+ this.logger.warn({ ...requestMetadata, origin }, "Rejected connection from origin");
372
+ callback(false, 403, "Origin not allowed");
373
+ }
318
374
  }
319
375
  broadcast(message) {
320
376
  const payload = JSON.stringify(message);
@@ -678,16 +734,20 @@ export class VoiceAssistantWebSocketServer {
678
734
  this.broadcast(this.createDaemonConfigChangedMessage(config));
679
735
  }
680
736
  bindSocketHandlers(ws) {
681
- ws.on("message", (data) => {
737
+ ws.on("message", (...args) => {
738
+ const data = args[0];
682
739
  void this.handleRawMessage(ws, data);
683
740
  });
684
- ws.on("close", async (code, reason) => {
741
+ ws.on("close", async (...args) => {
742
+ const code = args[0];
743
+ const reason = args[1];
685
744
  await this.detachSocket(ws, {
686
745
  code: typeof code === "number" ? code : undefined,
687
746
  reason,
688
747
  });
689
748
  });
690
- ws.on("error", async (error) => {
749
+ ws.on("error", async (...args) => {
750
+ const error = args[0];
691
751
  const err = error instanceof Error ? error : new Error(String(error));
692
752
  const active = this.sessions.get(ws);
693
753
  const pending = this.pendingConnections.get(ws);
@@ -768,81 +828,126 @@ export class VoiceAssistantWebSocketServer {
768
828
  connection.connectionLogger.trace({ clientId: connection.clientId, totalSessions: this.sessions.size }, logMessage);
769
829
  await connection.session.cleanup();
770
830
  }
831
+ handleInvalidInboundMessage(args) {
832
+ const { ws, parsed, parsedMessage, pendingConnection, activeConnection, log } = args;
833
+ this.incrementRuntimeCounter("validationFailed");
834
+ if (pendingConnection) {
835
+ pendingConnection.connectionLogger.warn({ error: parsedMessage.error.message }, "Rejected pending message before hello");
836
+ this.clearPendingConnection(ws);
837
+ try {
838
+ ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
839
+ }
840
+ catch {
841
+ // ignore close errors
842
+ }
843
+ return;
844
+ }
845
+ const requestInfo = extractRequestInfoFromUnknownWsInbound(parsed);
846
+ const isUnknownSchema = requestInfo?.requestId != null &&
847
+ typeof parsed === "object" &&
848
+ parsed != null &&
849
+ "type" in parsed &&
850
+ parsed.type === "session";
851
+ log.warn({
852
+ clientId: activeConnection?.clientId,
853
+ requestId: requestInfo?.requestId,
854
+ requestType: requestInfo?.requestType,
855
+ error: parsedMessage.error.message,
856
+ }, "WS inbound message validation failed");
857
+ if (requestInfo) {
858
+ this.sendToClient(ws, wrapSessionMessage({
859
+ type: "rpc_error",
860
+ payload: {
861
+ requestId: requestInfo.requestId,
862
+ requestType: requestInfo.requestType,
863
+ error: isUnknownSchema ? "Unknown request schema" : "Invalid message",
864
+ code: isUnknownSchema ? "unknown_schema" : "invalid_message",
865
+ },
866
+ }));
867
+ return;
868
+ }
869
+ const errorMessage = `Invalid message: ${parsedMessage.error.message}`;
870
+ this.sendToClient(ws, wrapSessionMessage({
871
+ type: "status",
872
+ payload: {
873
+ status: "error",
874
+ message: errorMessage,
875
+ },
876
+ }));
877
+ }
878
+ maybeHandleBinaryFrame(params) {
879
+ const { ws, buffer, activeConnection, log } = params;
880
+ const asBytes = asUint8Array(buffer);
881
+ if (!asBytes) {
882
+ return false;
883
+ }
884
+ const frame = decodeTerminalStreamFrame(asBytes);
885
+ if (!frame) {
886
+ return false;
887
+ }
888
+ if (!activeConnection) {
889
+ this.incrementRuntimeCounter("binaryBeforeHelloRejected");
890
+ log.warn("Rejected binary frame before hello");
891
+ this.clearPendingConnection(ws);
892
+ try {
893
+ ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
894
+ }
895
+ catch {
896
+ // ignore close errors
897
+ }
898
+ return true;
899
+ }
900
+ activeConnection.session.handleBinaryFrame(frame);
901
+ return true;
902
+ }
903
+ handlePendingConnectionMessage(params) {
904
+ const { ws, message, pendingConnection } = params;
905
+ if (message.type === "hello") {
906
+ this.handleHello({
907
+ ws,
908
+ message,
909
+ pending: pendingConnection,
910
+ });
911
+ return;
912
+ }
913
+ pendingConnection.connectionLogger.warn({
914
+ messageType: message.type,
915
+ }, "Rejected pending message before hello");
916
+ this.incrementRuntimeCounter("pendingMessageRejectedBeforeHello");
917
+ this.clearPendingConnection(ws);
918
+ try {
919
+ ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
920
+ }
921
+ catch {
922
+ // ignore close errors
923
+ }
924
+ }
771
925
  async handleRawMessage(ws, data) {
772
926
  const activeConnection = this.sessions.get(ws);
773
927
  const pendingConnection = this.pendingConnections.get(ws);
774
928
  const log = activeConnection?.connectionLogger ?? pendingConnection?.connectionLogger ?? this.logger;
775
929
  try {
776
930
  const buffer = bufferFromWsData(data);
777
- const asBytes = asUint8Array(buffer);
778
- if (asBytes) {
779
- const frame = decodeTerminalStreamFrame(asBytes);
780
- if (frame) {
781
- if (!activeConnection) {
782
- this.incrementRuntimeCounter("binaryBeforeHelloRejected");
783
- log.warn("Rejected binary frame before hello");
784
- this.clearPendingConnection(ws);
785
- try {
786
- ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
787
- }
788
- catch {
789
- // ignore close errors
790
- }
791
- return;
792
- }
793
- activeConnection.session.handleBinaryFrame(frame);
794
- return;
795
- }
931
+ const binaryHandled = this.maybeHandleBinaryFrame({
932
+ ws,
933
+ buffer,
934
+ activeConnection,
935
+ log,
936
+ });
937
+ if (binaryHandled) {
938
+ return;
796
939
  }
797
940
  const parsed = JSON.parse(buffer.toString());
798
941
  const parsedMessage = WSInboundMessageSchema.safeParse(parsed);
799
942
  if (!parsedMessage.success) {
800
- this.incrementRuntimeCounter("validationFailed");
801
- if (pendingConnection) {
802
- pendingConnection.connectionLogger.warn({
803
- error: parsedMessage.error.message,
804
- }, "Rejected pending message before hello");
805
- this.clearPendingConnection(ws);
806
- try {
807
- ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
808
- }
809
- catch {
810
- // ignore close errors
811
- }
812
- return;
813
- }
814
- const requestInfo = extractRequestInfoFromUnknownWsInbound(parsed);
815
- const isUnknownSchema = requestInfo?.requestId != null &&
816
- typeof parsed === "object" &&
817
- parsed != null &&
818
- "type" in parsed &&
819
- parsed.type === "session";
820
- log.warn({
821
- clientId: activeConnection?.clientId,
822
- requestId: requestInfo?.requestId,
823
- requestType: requestInfo?.requestType,
824
- error: parsedMessage.error.message,
825
- }, "WS inbound message validation failed");
826
- if (requestInfo) {
827
- this.sendToClient(ws, wrapSessionMessage({
828
- type: "rpc_error",
829
- payload: {
830
- requestId: requestInfo.requestId,
831
- requestType: requestInfo.requestType,
832
- error: isUnknownSchema ? "Unknown request schema" : "Invalid message",
833
- code: isUnknownSchema ? "unknown_schema" : "invalid_message",
834
- },
835
- }));
836
- return;
837
- }
838
- const errorMessage = `Invalid message: ${parsedMessage.error.message}`;
839
- this.sendToClient(ws, wrapSessionMessage({
840
- type: "status",
841
- payload: {
842
- status: "error",
843
- message: errorMessage,
844
- },
845
- }));
943
+ this.handleInvalidInboundMessage({
944
+ ws,
945
+ parsed,
946
+ parsedMessage,
947
+ pendingConnection,
948
+ activeConnection,
949
+ log,
950
+ });
846
951
  return;
847
952
  }
848
953
  const message = parsedMessage.data;
@@ -855,25 +960,11 @@ export class VoiceAssistantWebSocketServer {
855
960
  return;
856
961
  }
857
962
  if (pendingConnection) {
858
- if (message.type === "hello") {
859
- this.handleHello({
860
- ws,
861
- message,
862
- pending: pendingConnection,
863
- });
864
- return;
865
- }
866
- pendingConnection.connectionLogger.warn({
867
- messageType: message.type,
868
- }, "Rejected pending message before hello");
869
- this.incrementRuntimeCounter("pendingMessageRejectedBeforeHello");
870
- this.clearPendingConnection(ws);
871
- try {
872
- ws.close(WS_CLOSE_INVALID_HELLO, "Session message before hello");
873
- }
874
- catch {
875
- // ignore close errors
876
- }
963
+ this.handlePendingConnectionMessage({
964
+ ws,
965
+ message,
966
+ pendingConnection,
967
+ });
877
968
  return;
878
969
  }
879
970
  if (!activeConnection) {
@@ -893,74 +984,85 @@ export class VoiceAssistantWebSocketServer {
893
984
  return;
894
985
  }
895
986
  if (message.type === "session") {
896
- this.recordInboundSessionRequestType(message.message.type);
897
- const startMs = performance.now();
898
- await activeConnection.session.handleMessage(message.message);
899
- const durationMs = performance.now() - startMs;
900
- this.recordRequestLatency(message.message.type, durationMs);
901
- if (durationMs >= SLOW_REQUEST_THRESHOLD_MS) {
902
- activeConnection.connectionLogger.warn({
903
- requestType: message.message.type,
904
- durationMs: Math.round(durationMs),
905
- inflightRequests: activeConnection.session.getRuntimeMetrics().inflightRequests,
906
- }, "ws_slow_request");
907
- }
987
+ await this.dispatchSessionMessage(activeConnection, message);
908
988
  }
909
989
  }
910
990
  catch (error) {
911
- const err = error instanceof Error ? error : new Error(String(error));
912
- let rawPayload = null;
913
- let parsedPayload = null;
991
+ this.handleRawMessageError({ ws, data, error, log });
992
+ }
993
+ }
994
+ async dispatchSessionMessage(activeConnection, message) {
995
+ this.recordInboundSessionRequestType(message.message.type);
996
+ const startMs = performance.now();
997
+ await activeConnection.session.handleMessage(message.message);
998
+ const durationMs = performance.now() - startMs;
999
+ this.recordRequestLatency(message.message.type, durationMs);
1000
+ if (durationMs >= SLOW_REQUEST_THRESHOLD_MS) {
1001
+ activeConnection.connectionLogger.warn({
1002
+ requestType: message.message.type,
1003
+ durationMs: Math.round(durationMs),
1004
+ inflightRequests: activeConnection.session.getRuntimeMetrics().inflightRequests,
1005
+ }, "ws_slow_request");
1006
+ }
1007
+ }
1008
+ handleRawMessageError(params) {
1009
+ const { ws, data, error, log } = params;
1010
+ const err = error instanceof Error ? error : new Error(String(error));
1011
+ const { rawPayload, parsedPayload } = this.decodeRawMessagePayloadForError(data);
1012
+ const trimmedRawPayload = typeof rawPayload === "string" && rawPayload.length > 2000
1013
+ ? `${rawPayload.slice(0, 2000)}... (truncated)`
1014
+ : rawPayload;
1015
+ log.error({
1016
+ err,
1017
+ rawPayload: trimmedRawPayload,
1018
+ parsedPayload,
1019
+ }, "Failed to parse/handle message");
1020
+ if (this.pendingConnections.has(ws)) {
1021
+ this.clearPendingConnection(ws);
914
1022
  try {
915
- const buffer = bufferFromWsData(data);
916
- rawPayload = buffer.toString();
917
- parsedPayload = JSON.parse(rawPayload);
918
- }
919
- catch (payloadError) {
920
- rawPayload = rawPayload ?? "<unreadable>";
921
- parsedPayload = parsedPayload ?? rawPayload;
922
- const payloadErr = payloadError instanceof Error ? payloadError : new Error(String(payloadError));
923
- this.logger.error({ err: payloadErr }, "Failed to decode raw payload");
924
- }
925
- const trimmedRawPayload = typeof rawPayload === "string" && rawPayload.length > 2000
926
- ? `${rawPayload.slice(0, 2000)}... (truncated)`
927
- : rawPayload;
928
- log.error({
929
- err,
930
- rawPayload: trimmedRawPayload,
931
- parsedPayload,
932
- }, "Failed to parse/handle message");
933
- if (this.pendingConnections.has(ws)) {
934
- this.clearPendingConnection(ws);
935
- try {
936
- ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
937
- }
938
- catch {
939
- // ignore close errors
940
- }
941
- return;
1023
+ ws.close(WS_CLOSE_INVALID_HELLO, "Invalid hello");
942
1024
  }
943
- const requestInfo = extractRequestInfoFromUnknownWsInbound(parsedPayload);
944
- if (requestInfo) {
945
- this.sendToClient(ws, wrapSessionMessage({
946
- type: "rpc_error",
947
- payload: {
948
- requestId: requestInfo.requestId,
949
- requestType: requestInfo.requestType,
950
- error: "Invalid message",
951
- code: "invalid_message",
952
- },
953
- }));
954
- return;
1025
+ catch {
1026
+ // ignore close errors
955
1027
  }
1028
+ return;
1029
+ }
1030
+ const requestInfo = extractRequestInfoFromUnknownWsInbound(parsedPayload);
1031
+ if (requestInfo) {
956
1032
  this.sendToClient(ws, wrapSessionMessage({
957
- type: "status",
1033
+ type: "rpc_error",
958
1034
  payload: {
959
- status: "error",
960
- message: `Invalid message: ${err.message}`,
1035
+ requestId: requestInfo.requestId,
1036
+ requestType: requestInfo.requestType,
1037
+ error: "Invalid message",
1038
+ code: "invalid_message",
961
1039
  },
962
1040
  }));
1041
+ return;
1042
+ }
1043
+ this.sendToClient(ws, wrapSessionMessage({
1044
+ type: "status",
1045
+ payload: {
1046
+ status: "error",
1047
+ message: `Invalid message: ${err.message}`,
1048
+ },
1049
+ }));
1050
+ }
1051
+ decodeRawMessagePayloadForError(data) {
1052
+ let rawPayload = null;
1053
+ let parsedPayload = null;
1054
+ try {
1055
+ const buffer = bufferFromWsData(data);
1056
+ rawPayload = buffer.toString();
1057
+ parsedPayload = JSON.parse(rawPayload);
1058
+ }
1059
+ catch (payloadError) {
1060
+ rawPayload = rawPayload ?? "<unreadable>";
1061
+ parsedPayload = parsedPayload ?? rawPayload;
1062
+ const payloadErr = payloadError instanceof Error ? payloadError : new Error(String(payloadError));
1063
+ this.logger.error({ err: payloadErr }, "Failed to decode raw payload");
963
1064
  }
1065
+ return { rawPayload, parsedPayload };
964
1066
  }
965
1067
  incrementRuntimeCounter(counter) {
966
1068
  this.runtimeCounters[counter] += 1;