@livekit/agents 0.7.8 → 1.0.0-next.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (627) hide show
  1. package/dist/_exceptions.cjs +109 -0
  2. package/dist/_exceptions.cjs.map +1 -0
  3. package/dist/_exceptions.d.cts +64 -0
  4. package/dist/_exceptions.d.ts +64 -0
  5. package/dist/_exceptions.d.ts.map +1 -0
  6. package/dist/_exceptions.js +80 -0
  7. package/dist/_exceptions.js.map +1 -0
  8. package/dist/audio.cjs +10 -3
  9. package/dist/audio.cjs.map +1 -1
  10. package/dist/audio.d.cts +2 -0
  11. package/dist/audio.d.ts +2 -0
  12. package/dist/audio.d.ts.map +1 -1
  13. package/dist/audio.js +8 -2
  14. package/dist/audio.js.map +1 -1
  15. package/dist/cli.cjs +25 -0
  16. package/dist/cli.cjs.map +1 -1
  17. package/dist/cli.d.ts.map +1 -1
  18. package/dist/cli.js +25 -0
  19. package/dist/cli.js.map +1 -1
  20. package/dist/constants.cjs +6 -0
  21. package/dist/constants.cjs.map +1 -1
  22. package/dist/constants.d.cts +2 -0
  23. package/dist/constants.d.ts +2 -0
  24. package/dist/constants.d.ts.map +1 -1
  25. package/dist/constants.js +4 -0
  26. package/dist/constants.js.map +1 -1
  27. package/dist/http_server.cjs.map +1 -1
  28. package/dist/http_server.d.cts +1 -0
  29. package/dist/http_server.d.ts +1 -0
  30. package/dist/http_server.d.ts.map +1 -1
  31. package/dist/http_server.js.map +1 -1
  32. package/dist/index.cjs +27 -20
  33. package/dist/index.cjs.map +1 -1
  34. package/dist/index.d.cts +13 -10
  35. package/dist/index.d.ts +13 -10
  36. package/dist/index.d.ts.map +1 -1
  37. package/dist/index.js +15 -11
  38. package/dist/index.js.map +1 -1
  39. package/dist/inference_runner.cjs +0 -1
  40. package/dist/inference_runner.cjs.map +1 -1
  41. package/dist/inference_runner.d.cts +2 -3
  42. package/dist/inference_runner.d.ts +2 -3
  43. package/dist/inference_runner.d.ts.map +1 -1
  44. package/dist/inference_runner.js +0 -1
  45. package/dist/inference_runner.js.map +1 -1
  46. package/dist/ipc/inference_proc_executor.cjs +2 -2
  47. package/dist/ipc/inference_proc_executor.cjs.map +1 -1
  48. package/dist/ipc/inference_proc_executor.js +2 -2
  49. package/dist/ipc/inference_proc_executor.js.map +1 -1
  50. package/dist/ipc/job_executor.cjs.map +1 -1
  51. package/dist/ipc/job_executor.js.map +1 -1
  52. package/dist/ipc/job_proc_executor.cjs +1 -0
  53. package/dist/ipc/job_proc_executor.cjs.map +1 -1
  54. package/dist/ipc/job_proc_executor.js +1 -0
  55. package/dist/ipc/job_proc_executor.js.map +1 -1
  56. package/dist/ipc/job_proc_lazy_main.cjs +1 -1
  57. package/dist/ipc/job_proc_lazy_main.cjs.map +1 -1
  58. package/dist/ipc/job_proc_lazy_main.js +1 -1
  59. package/dist/ipc/job_proc_lazy_main.js.map +1 -1
  60. package/dist/ipc/supervised_proc.d.cts +1 -1
  61. package/dist/ipc/supervised_proc.d.ts +1 -1
  62. package/dist/ipc/supervised_proc.d.ts.map +1 -1
  63. package/dist/job.cjs +14 -2
  64. package/dist/job.cjs.map +1 -1
  65. package/dist/job.d.cts +8 -0
  66. package/dist/job.d.ts +8 -0
  67. package/dist/job.d.ts.map +1 -1
  68. package/dist/job.js +12 -1
  69. package/dist/job.js.map +1 -1
  70. package/dist/llm/chat_context.cjs +332 -82
  71. package/dist/llm/chat_context.cjs.map +1 -1
  72. package/dist/llm/chat_context.d.cts +152 -48
  73. package/dist/llm/chat_context.d.ts +152 -48
  74. package/dist/llm/chat_context.d.ts.map +1 -1
  75. package/dist/llm/chat_context.js +327 -81
  76. package/dist/llm/chat_context.js.map +1 -1
  77. package/dist/llm/chat_context.test.cjs +380 -0
  78. package/dist/llm/chat_context.test.cjs.map +1 -0
  79. package/dist/llm/chat_context.test.js +385 -0
  80. package/dist/llm/chat_context.test.js.map +1 -0
  81. package/dist/llm/index.cjs +37 -8
  82. package/dist/llm/index.cjs.map +1 -1
  83. package/dist/llm/index.d.cts +7 -3
  84. package/dist/llm/index.d.ts +7 -3
  85. package/dist/llm/index.d.ts.map +1 -1
  86. package/dist/llm/index.js +39 -9
  87. package/dist/llm/index.js.map +1 -1
  88. package/dist/llm/llm.cjs +98 -33
  89. package/dist/llm/llm.cjs.map +1 -1
  90. package/dist/llm/llm.d.cts +50 -24
  91. package/dist/llm/llm.d.ts +50 -24
  92. package/dist/llm/llm.d.ts.map +1 -1
  93. package/dist/llm/llm.js +99 -33
  94. package/dist/llm/llm.js.map +1 -1
  95. package/dist/llm/provider_format/google.cjs +128 -0
  96. package/dist/llm/provider_format/google.cjs.map +1 -0
  97. package/dist/llm/provider_format/google.d.cts +6 -0
  98. package/dist/llm/provider_format/google.d.ts +6 -0
  99. package/dist/llm/provider_format/google.d.ts.map +1 -0
  100. package/dist/llm/provider_format/google.js +104 -0
  101. package/dist/llm/provider_format/google.js.map +1 -0
  102. package/dist/llm/provider_format/google.test.cjs +676 -0
  103. package/dist/llm/provider_format/google.test.cjs.map +1 -0
  104. package/dist/llm/provider_format/google.test.js +675 -0
  105. package/dist/llm/provider_format/google.test.js.map +1 -0
  106. package/dist/llm/provider_format/index.cjs +40 -0
  107. package/dist/llm/provider_format/index.cjs.map +1 -0
  108. package/dist/llm/provider_format/index.d.cts +4 -0
  109. package/dist/llm/provider_format/index.d.ts +4 -0
  110. package/dist/llm/provider_format/index.d.ts.map +1 -0
  111. package/dist/llm/provider_format/index.js +16 -0
  112. package/dist/llm/provider_format/index.js.map +1 -0
  113. package/dist/llm/provider_format/openai.cjs +116 -0
  114. package/dist/llm/provider_format/openai.cjs.map +1 -0
  115. package/dist/llm/provider_format/openai.d.cts +3 -0
  116. package/dist/llm/provider_format/openai.d.ts +3 -0
  117. package/dist/llm/provider_format/openai.d.ts.map +1 -0
  118. package/dist/llm/provider_format/openai.js +92 -0
  119. package/dist/llm/provider_format/openai.js.map +1 -0
  120. package/dist/llm/provider_format/openai.test.cjs +490 -0
  121. package/dist/llm/provider_format/openai.test.cjs.map +1 -0
  122. package/dist/llm/provider_format/openai.test.js +489 -0
  123. package/dist/llm/provider_format/openai.test.js.map +1 -0
  124. package/dist/llm/provider_format/utils.cjs +146 -0
  125. package/dist/llm/provider_format/utils.cjs.map +1 -0
  126. package/dist/llm/provider_format/utils.d.cts +38 -0
  127. package/dist/llm/provider_format/utils.d.ts +38 -0
  128. package/dist/llm/provider_format/utils.d.ts.map +1 -0
  129. package/dist/llm/provider_format/utils.js +122 -0
  130. package/dist/llm/provider_format/utils.js.map +1 -0
  131. package/dist/llm/realtime.cjs +77 -0
  132. package/dist/llm/realtime.cjs.map +1 -0
  133. package/dist/llm/realtime.d.cts +98 -0
  134. package/dist/llm/realtime.d.ts +98 -0
  135. package/dist/llm/realtime.d.ts.map +1 -0
  136. package/dist/llm/realtime.js +52 -0
  137. package/dist/llm/realtime.js.map +1 -0
  138. package/dist/llm/remote_chat_context.cjs +112 -0
  139. package/dist/llm/remote_chat_context.cjs.map +1 -0
  140. package/dist/llm/remote_chat_context.d.cts +23 -0
  141. package/dist/llm/remote_chat_context.d.ts +23 -0
  142. package/dist/llm/remote_chat_context.d.ts.map +1 -0
  143. package/dist/llm/remote_chat_context.js +88 -0
  144. package/dist/llm/remote_chat_context.js.map +1 -0
  145. package/dist/llm/remote_chat_context.test.cjs +225 -0
  146. package/dist/llm/remote_chat_context.test.cjs.map +1 -0
  147. package/dist/llm/remote_chat_context.test.js +224 -0
  148. package/dist/llm/remote_chat_context.test.js.map +1 -0
  149. package/dist/llm/tool_context.cjs +111 -0
  150. package/dist/llm/tool_context.cjs.map +1 -0
  151. package/dist/llm/tool_context.d.cts +125 -0
  152. package/dist/llm/tool_context.d.ts +125 -0
  153. package/dist/llm/tool_context.d.ts.map +1 -0
  154. package/dist/llm/tool_context.js +80 -0
  155. package/dist/llm/tool_context.js.map +1 -0
  156. package/dist/llm/tool_context.test.cjs +162 -0
  157. package/dist/llm/tool_context.test.cjs.map +1 -0
  158. package/dist/llm/tool_context.test.js +161 -0
  159. package/dist/llm/tool_context.test.js.map +1 -0
  160. package/dist/llm/tool_context.type.test.cjs +92 -0
  161. package/dist/llm/tool_context.type.test.cjs.map +1 -0
  162. package/dist/llm/tool_context.type.test.js +91 -0
  163. package/dist/llm/tool_context.type.test.js.map +1 -0
  164. package/dist/llm/utils.cjs +260 -0
  165. package/dist/llm/utils.cjs.map +1 -0
  166. package/dist/llm/utils.d.cts +42 -0
  167. package/dist/llm/utils.d.ts +42 -0
  168. package/dist/llm/utils.d.ts.map +1 -0
  169. package/dist/llm/utils.js +223 -0
  170. package/dist/llm/utils.js.map +1 -0
  171. package/dist/llm/utils.test.cjs +513 -0
  172. package/dist/llm/utils.test.cjs.map +1 -0
  173. package/dist/llm/utils.test.js +490 -0
  174. package/dist/llm/utils.test.js.map +1 -0
  175. package/dist/metrics/base.cjs +0 -27
  176. package/dist/metrics/base.cjs.map +1 -1
  177. package/dist/metrics/base.d.cts +105 -63
  178. package/dist/metrics/base.d.ts +105 -63
  179. package/dist/metrics/base.d.ts.map +1 -1
  180. package/dist/metrics/base.js +0 -19
  181. package/dist/metrics/base.js.map +1 -1
  182. package/dist/metrics/index.cjs +0 -3
  183. package/dist/metrics/index.cjs.map +1 -1
  184. package/dist/metrics/index.d.cts +2 -3
  185. package/dist/metrics/index.d.ts +2 -3
  186. package/dist/metrics/index.d.ts.map +1 -1
  187. package/dist/metrics/index.js +0 -2
  188. package/dist/metrics/index.js.map +1 -1
  189. package/dist/metrics/usage_collector.cjs +17 -12
  190. package/dist/metrics/usage_collector.cjs.map +1 -1
  191. package/dist/metrics/usage_collector.d.cts +3 -2
  192. package/dist/metrics/usage_collector.d.ts +3 -2
  193. package/dist/metrics/usage_collector.d.ts.map +1 -1
  194. package/dist/metrics/usage_collector.js +17 -12
  195. package/dist/metrics/usage_collector.js.map +1 -1
  196. package/dist/metrics/utils.cjs +22 -59
  197. package/dist/metrics/utils.cjs.map +1 -1
  198. package/dist/metrics/utils.d.cts +1 -8
  199. package/dist/metrics/utils.d.ts +1 -8
  200. package/dist/metrics/utils.d.ts.map +1 -1
  201. package/dist/metrics/utils.js +22 -52
  202. package/dist/metrics/utils.js.map +1 -1
  203. package/dist/multimodal/index.cjs +0 -2
  204. package/dist/multimodal/index.cjs.map +1 -1
  205. package/dist/multimodal/index.d.cts +0 -1
  206. package/dist/multimodal/index.d.ts +0 -1
  207. package/dist/multimodal/index.d.ts.map +1 -1
  208. package/dist/multimodal/index.js +0 -1
  209. package/dist/multimodal/index.js.map +1 -1
  210. package/dist/plugin.cjs +24 -8
  211. package/dist/plugin.cjs.map +1 -1
  212. package/dist/plugin.d.cts +18 -4
  213. package/dist/plugin.d.ts +18 -4
  214. package/dist/plugin.d.ts.map +1 -1
  215. package/dist/plugin.js +22 -7
  216. package/dist/plugin.js.map +1 -1
  217. package/dist/stream/deferred_stream.cjs +98 -0
  218. package/dist/stream/deferred_stream.cjs.map +1 -0
  219. package/dist/stream/deferred_stream.d.cts +27 -0
  220. package/dist/stream/deferred_stream.d.ts +27 -0
  221. package/dist/stream/deferred_stream.d.ts.map +1 -0
  222. package/dist/stream/deferred_stream.js +73 -0
  223. package/dist/stream/deferred_stream.js.map +1 -0
  224. package/dist/stream/deferred_stream.test.cjs +527 -0
  225. package/dist/stream/deferred_stream.test.cjs.map +1 -0
  226. package/dist/stream/deferred_stream.test.js +526 -0
  227. package/dist/stream/deferred_stream.test.js.map +1 -0
  228. package/dist/stream/identity_transform.cjs +42 -0
  229. package/dist/stream/identity_transform.cjs.map +1 -0
  230. package/dist/stream/identity_transform.d.cts +6 -0
  231. package/dist/stream/identity_transform.d.ts +6 -0
  232. package/dist/stream/identity_transform.d.ts.map +1 -0
  233. package/dist/stream/identity_transform.js +18 -0
  234. package/dist/stream/identity_transform.js.map +1 -0
  235. package/dist/stream/identity_transform.test.cjs +125 -0
  236. package/dist/stream/identity_transform.test.cjs.map +1 -0
  237. package/dist/stream/identity_transform.test.js +124 -0
  238. package/dist/stream/identity_transform.test.js.map +1 -0
  239. package/dist/stream/index.cjs +38 -0
  240. package/dist/stream/index.cjs.map +1 -0
  241. package/dist/stream/index.d.cts +5 -0
  242. package/dist/stream/index.d.ts +5 -0
  243. package/dist/stream/index.d.ts.map +1 -0
  244. package/dist/stream/index.js +11 -0
  245. package/dist/stream/index.js.map +1 -0
  246. package/dist/stream/merge_readable_streams.cjs +59 -0
  247. package/dist/stream/merge_readable_streams.cjs.map +1 -0
  248. package/dist/stream/merge_readable_streams.d.cts +4 -0
  249. package/dist/stream/merge_readable_streams.d.ts +4 -0
  250. package/dist/stream/merge_readable_streams.d.ts.map +1 -0
  251. package/dist/stream/merge_readable_streams.js +35 -0
  252. package/dist/stream/merge_readable_streams.js.map +1 -0
  253. package/dist/stream/stream_channel.cjs +47 -0
  254. package/dist/stream/stream_channel.cjs.map +1 -0
  255. package/dist/stream/stream_channel.d.cts +9 -0
  256. package/dist/stream/stream_channel.d.ts +9 -0
  257. package/dist/stream/stream_channel.d.ts.map +1 -0
  258. package/dist/stream/stream_channel.js +23 -0
  259. package/dist/stream/stream_channel.js.map +1 -0
  260. package/dist/stream/stream_channel.test.cjs +97 -0
  261. package/dist/stream/stream_channel.test.cjs.map +1 -0
  262. package/dist/stream/stream_channel.test.js +96 -0
  263. package/dist/stream/stream_channel.test.js.map +1 -0
  264. package/dist/stt/stream_adapter.cjs +3 -4
  265. package/dist/stt/stream_adapter.cjs.map +1 -1
  266. package/dist/stt/stream_adapter.d.cts +1 -0
  267. package/dist/stt/stream_adapter.d.ts +1 -0
  268. package/dist/stt/stream_adapter.d.ts.map +1 -1
  269. package/dist/stt/stream_adapter.js +3 -4
  270. package/dist/stt/stream_adapter.js.map +1 -1
  271. package/dist/stt/stt.cjs +101 -10
  272. package/dist/stt/stt.cjs.map +1 -1
  273. package/dist/stt/stt.d.cts +26 -5
  274. package/dist/stt/stt.d.ts +26 -5
  275. package/dist/stt/stt.d.ts.map +1 -1
  276. package/dist/stt/stt.js +102 -11
  277. package/dist/stt/stt.js.map +1 -1
  278. package/dist/tokenize/basic/basic.cjs +10 -5
  279. package/dist/tokenize/basic/basic.cjs.map +1 -1
  280. package/dist/tokenize/basic/basic.d.cts +7 -1
  281. package/dist/tokenize/basic/basic.d.ts +7 -1
  282. package/dist/tokenize/basic/basic.d.ts.map +1 -1
  283. package/dist/tokenize/basic/basic.js +10 -5
  284. package/dist/tokenize/basic/basic.js.map +1 -1
  285. package/dist/tokenize/basic/sentence.cjs +14 -6
  286. package/dist/tokenize/basic/sentence.cjs.map +1 -1
  287. package/dist/tokenize/basic/sentence.d.cts +1 -1
  288. package/dist/tokenize/basic/sentence.d.ts +1 -1
  289. package/dist/tokenize/basic/sentence.d.ts.map +1 -1
  290. package/dist/tokenize/basic/sentence.js +14 -6
  291. package/dist/tokenize/basic/sentence.js.map +1 -1
  292. package/dist/tokenize/token_stream.cjs +5 -3
  293. package/dist/tokenize/token_stream.cjs.map +1 -1
  294. package/dist/tokenize/token_stream.d.cts +1 -0
  295. package/dist/tokenize/token_stream.d.ts +1 -0
  296. package/dist/tokenize/token_stream.d.ts.map +1 -1
  297. package/dist/tokenize/token_stream.js +6 -4
  298. package/dist/tokenize/token_stream.js.map +1 -1
  299. package/dist/transcription.cjs +1 -2
  300. package/dist/transcription.cjs.map +1 -1
  301. package/dist/transcription.d.ts.map +1 -1
  302. package/dist/transcription.js +2 -3
  303. package/dist/transcription.js.map +1 -1
  304. package/dist/tts/index.cjs +2 -4
  305. package/dist/tts/index.cjs.map +1 -1
  306. package/dist/tts/index.d.cts +1 -1
  307. package/dist/tts/index.d.ts +1 -1
  308. package/dist/tts/index.d.ts.map +1 -1
  309. package/dist/tts/index.js +1 -3
  310. package/dist/tts/index.js.map +1 -1
  311. package/dist/tts/stream_adapter.cjs +26 -13
  312. package/dist/tts/stream_adapter.cjs.map +1 -1
  313. package/dist/tts/stream_adapter.d.cts +1 -1
  314. package/dist/tts/stream_adapter.d.ts +1 -1
  315. package/dist/tts/stream_adapter.d.ts.map +1 -1
  316. package/dist/tts/stream_adapter.js +27 -14
  317. package/dist/tts/stream_adapter.js.map +1 -1
  318. package/dist/tts/tts.cjs +157 -25
  319. package/dist/tts/tts.cjs.map +1 -1
  320. package/dist/tts/tts.d.cts +29 -5
  321. package/dist/tts/tts.d.ts +29 -5
  322. package/dist/tts/tts.d.ts.map +1 -1
  323. package/dist/tts/tts.js +157 -24
  324. package/dist/tts/tts.js.map +1 -1
  325. package/dist/types.cjs +60 -0
  326. package/dist/types.cjs.map +1 -0
  327. package/dist/types.d.cts +13 -0
  328. package/dist/types.d.ts +13 -0
  329. package/dist/types.d.ts.map +1 -0
  330. package/dist/types.js +35 -0
  331. package/dist/types.js.map +1 -0
  332. package/dist/utils.cjs +281 -27
  333. package/dist/utils.cjs.map +1 -1
  334. package/dist/utils.d.cts +134 -9
  335. package/dist/utils.d.ts +134 -9
  336. package/dist/utils.d.ts.map +1 -1
  337. package/dist/utils.js +265 -26
  338. package/dist/utils.js.map +1 -1
  339. package/dist/utils.test.cjs +492 -0
  340. package/dist/utils.test.cjs.map +1 -0
  341. package/dist/utils.test.js +498 -0
  342. package/dist/utils.test.js.map +1 -0
  343. package/dist/vad.cjs +76 -20
  344. package/dist/vad.cjs.map +1 -1
  345. package/dist/vad.d.cts +25 -5
  346. package/dist/vad.d.ts +25 -5
  347. package/dist/vad.d.ts.map +1 -1
  348. package/dist/vad.js +76 -20
  349. package/dist/vad.js.map +1 -1
  350. package/dist/voice/agent.cjs +245 -0
  351. package/dist/voice/agent.cjs.map +1 -0
  352. package/dist/voice/agent.d.cts +78 -0
  353. package/dist/voice/agent.d.ts +78 -0
  354. package/dist/voice/agent.d.ts.map +1 -0
  355. package/dist/voice/agent.js +220 -0
  356. package/dist/voice/agent.js.map +1 -0
  357. package/dist/voice/agent.test.cjs +61 -0
  358. package/dist/voice/agent.test.cjs.map +1 -0
  359. package/dist/voice/agent.test.js +60 -0
  360. package/dist/voice/agent.test.js.map +1 -0
  361. package/dist/voice/agent_activity.cjs +1453 -0
  362. package/dist/voice/agent_activity.cjs.map +1 -0
  363. package/dist/voice/agent_activity.d.cts +94 -0
  364. package/dist/voice/agent_activity.d.ts +94 -0
  365. package/dist/voice/agent_activity.d.ts.map +1 -0
  366. package/dist/voice/agent_activity.js +1449 -0
  367. package/dist/voice/agent_activity.js.map +1 -0
  368. package/dist/voice/agent_session.cjs +312 -0
  369. package/dist/voice/agent_session.cjs.map +1 -0
  370. package/dist/voice/agent_session.d.cts +121 -0
  371. package/dist/voice/agent_session.d.ts +121 -0
  372. package/dist/voice/agent_session.d.ts.map +1 -0
  373. package/dist/voice/agent_session.js +295 -0
  374. package/dist/voice/agent_session.js.map +1 -0
  375. package/dist/voice/audio_recognition.cjs +375 -0
  376. package/dist/voice/audio_recognition.cjs.map +1 -0
  377. package/dist/voice/audio_recognition.d.cts +80 -0
  378. package/dist/voice/audio_recognition.d.ts +80 -0
  379. package/dist/voice/audio_recognition.d.ts.map +1 -0
  380. package/dist/voice/audio_recognition.js +351 -0
  381. package/dist/voice/audio_recognition.js.map +1 -0
  382. package/dist/voice/events.cjs +145 -0
  383. package/dist/voice/events.cjs.map +1 -0
  384. package/dist/voice/events.d.cts +124 -0
  385. package/dist/voice/events.d.ts +124 -0
  386. package/dist/voice/events.d.ts.map +1 -0
  387. package/dist/voice/events.js +110 -0
  388. package/dist/voice/events.js.map +1 -0
  389. package/dist/voice/generation.cjs +700 -0
  390. package/dist/voice/generation.cjs.map +1 -0
  391. package/dist/voice/generation.d.cts +115 -0
  392. package/dist/voice/generation.d.ts +115 -0
  393. package/dist/voice/generation.d.ts.map +1 -0
  394. package/dist/voice/generation.js +672 -0
  395. package/dist/voice/generation.js.map +1 -0
  396. package/dist/voice/index.cjs +40 -0
  397. package/dist/voice/index.cjs.map +1 -0
  398. package/dist/voice/index.d.cts +5 -0
  399. package/dist/voice/index.d.ts +5 -0
  400. package/dist/voice/index.d.ts.map +1 -0
  401. package/dist/voice/index.js +11 -0
  402. package/dist/voice/index.js.map +1 -0
  403. package/dist/voice/io.cjs +245 -0
  404. package/dist/voice/io.cjs.map +1 -0
  405. package/dist/voice/io.d.cts +101 -0
  406. package/dist/voice/io.d.ts +101 -0
  407. package/dist/voice/io.d.ts.map +1 -0
  408. package/dist/voice/io.js +217 -0
  409. package/dist/voice/io.js.map +1 -0
  410. package/dist/voice/room_io/_input.cjs +121 -0
  411. package/dist/voice/room_io/_input.cjs.map +1 -0
  412. package/dist/voice/room_io/_input.d.cts +24 -0
  413. package/dist/voice/room_io/_input.d.ts +24 -0
  414. package/dist/voice/room_io/_input.d.ts.map +1 -0
  415. package/dist/voice/room_io/_input.js +102 -0
  416. package/dist/voice/room_io/_input.js.map +1 -0
  417. package/dist/voice/room_io/_output.cjs +358 -0
  418. package/dist/voice/room_io/_output.cjs.map +1 -0
  419. package/dist/voice/room_io/_output.d.cts +75 -0
  420. package/dist/voice/room_io/_output.d.ts +75 -0
  421. package/dist/voice/room_io/_output.d.ts.map +1 -0
  422. package/dist/voice/room_io/_output.js +342 -0
  423. package/dist/voice/room_io/_output.js.map +1 -0
  424. package/dist/voice/room_io/index.cjs +25 -0
  425. package/dist/voice/room_io/index.cjs.map +1 -0
  426. package/dist/voice/room_io/index.d.cts +3 -0
  427. package/dist/voice/room_io/index.d.ts +3 -0
  428. package/dist/voice/room_io/index.d.ts.map +1 -0
  429. package/dist/voice/room_io/index.js +3 -0
  430. package/dist/voice/room_io/index.js.map +1 -0
  431. package/dist/voice/room_io/room_io.cjs +370 -0
  432. package/dist/voice/room_io/room_io.cjs.map +1 -0
  433. package/dist/voice/room_io/room_io.d.cts +73 -0
  434. package/dist/voice/room_io/room_io.d.ts +73 -0
  435. package/dist/voice/room_io/room_io.d.ts.map +1 -0
  436. package/dist/voice/room_io/room_io.js +361 -0
  437. package/dist/voice/room_io/room_io.js.map +1 -0
  438. package/dist/{pipeline/index.cjs → voice/run_context.cjs} +16 -11
  439. package/dist/voice/run_context.cjs.map +1 -0
  440. package/dist/voice/run_context.d.cts +12 -0
  441. package/dist/voice/run_context.d.ts +12 -0
  442. package/dist/voice/run_context.d.ts.map +1 -0
  443. package/dist/voice/run_context.js +14 -0
  444. package/dist/voice/run_context.js.map +1 -0
  445. package/dist/voice/speech_handle.cjs +105 -0
  446. package/dist/voice/speech_handle.cjs.map +1 -0
  447. package/dist/voice/speech_handle.d.cts +46 -0
  448. package/dist/voice/speech_handle.d.ts +46 -0
  449. package/dist/voice/speech_handle.d.ts.map +1 -0
  450. package/dist/voice/speech_handle.js +81 -0
  451. package/dist/voice/speech_handle.js.map +1 -0
  452. package/dist/voice/transcription/_utils.cjs +45 -0
  453. package/dist/voice/transcription/_utils.cjs.map +1 -0
  454. package/dist/voice/transcription/_utils.d.cts +3 -0
  455. package/dist/voice/transcription/_utils.d.ts +3 -0
  456. package/dist/voice/transcription/_utils.d.ts.map +1 -0
  457. package/dist/voice/transcription/_utils.js +21 -0
  458. package/dist/voice/transcription/_utils.js.map +1 -0
  459. package/dist/voice/transcription/index.cjs +23 -0
  460. package/dist/voice/transcription/index.cjs.map +1 -0
  461. package/dist/voice/transcription/index.d.cts +2 -0
  462. package/dist/voice/transcription/index.d.ts +2 -0
  463. package/dist/voice/transcription/index.d.ts.map +1 -0
  464. package/dist/voice/transcription/index.js +2 -0
  465. package/dist/voice/transcription/index.js.map +1 -0
  466. package/dist/voice/transcription/synchronizer.cjs +380 -0
  467. package/dist/voice/transcription/synchronizer.cjs.map +1 -0
  468. package/dist/voice/transcription/synchronizer.d.cts +86 -0
  469. package/dist/voice/transcription/synchronizer.d.ts +86 -0
  470. package/dist/voice/transcription/synchronizer.d.ts.map +1 -0
  471. package/dist/voice/transcription/synchronizer.js +355 -0
  472. package/dist/voice/transcription/synchronizer.js.map +1 -0
  473. package/dist/worker.cjs +22 -4
  474. package/dist/worker.cjs.map +1 -1
  475. package/dist/worker.d.cts +1 -1
  476. package/dist/worker.d.ts +1 -1
  477. package/dist/worker.d.ts.map +1 -1
  478. package/dist/worker.js +22 -4
  479. package/dist/worker.js.map +1 -1
  480. package/package.json +9 -2
  481. package/src/_exceptions.ts +137 -0
  482. package/src/audio.ts +12 -1
  483. package/src/cli.ts +37 -0
  484. package/src/constants.ts +2 -0
  485. package/src/http_server.ts +1 -0
  486. package/src/index.ts +13 -10
  487. package/src/inference_runner.ts +2 -3
  488. package/src/ipc/inference_proc_executor.ts +2 -2
  489. package/src/ipc/job_executor.ts +1 -1
  490. package/src/ipc/job_proc_executor.ts +1 -1
  491. package/src/ipc/job_proc_lazy_main.ts +1 -1
  492. package/src/job.ts +18 -0
  493. package/src/llm/__snapshots__/chat_context.test.ts.snap +527 -0
  494. package/src/llm/__snapshots__/tool_context.test.ts.snap +177 -0
  495. package/src/llm/__snapshots__/utils.test.ts.snap +65 -0
  496. package/src/llm/chat_context.test.ts +450 -0
  497. package/src/llm/chat_context.ts +501 -103
  498. package/src/llm/index.ts +53 -18
  499. package/src/llm/llm.ts +149 -50
  500. package/src/llm/provider_format/google.test.ts +772 -0
  501. package/src/llm/provider_format/google.ts +130 -0
  502. package/src/llm/provider_format/index.ts +23 -0
  503. package/src/llm/provider_format/openai.test.ts +581 -0
  504. package/src/llm/provider_format/openai.ts +118 -0
  505. package/src/llm/provider_format/utils.ts +183 -0
  506. package/src/llm/realtime.ts +151 -0
  507. package/src/llm/remote_chat_context.test.ts +290 -0
  508. package/src/llm/remote_chat_context.ts +114 -0
  509. package/src/llm/tool_context.test.ts +198 -0
  510. package/src/llm/tool_context.ts +259 -0
  511. package/src/llm/tool_context.type.test.ts +115 -0
  512. package/src/llm/utils.test.ts +670 -0
  513. package/src/llm/utils.ts +324 -0
  514. package/src/metrics/base.ts +110 -78
  515. package/src/metrics/index.ts +3 -9
  516. package/src/metrics/usage_collector.ts +19 -13
  517. package/src/metrics/utils.ts +24 -69
  518. package/src/multimodal/index.ts +0 -1
  519. package/src/plugin.ts +26 -8
  520. package/src/stream/deferred_stream.test.ts +755 -0
  521. package/src/stream/deferred_stream.ts +110 -0
  522. package/src/stream/identity_transform.test.ts +179 -0
  523. package/src/stream/identity_transform.ts +18 -0
  524. package/src/stream/index.ts +7 -0
  525. package/src/stream/merge_readable_streams.ts +40 -0
  526. package/src/stream/stream_channel.test.ts +129 -0
  527. package/src/stream/stream_channel.ts +32 -0
  528. package/src/stt/stream_adapter.ts +3 -5
  529. package/src/stt/stt.ts +135 -17
  530. package/src/tokenize/basic/basic.ts +13 -5
  531. package/src/tokenize/basic/sentence.ts +20 -6
  532. package/src/tokenize/token_stream.ts +7 -4
  533. package/src/transcription.ts +2 -3
  534. package/src/tts/index.ts +0 -1
  535. package/src/tts/stream_adapter.ts +42 -16
  536. package/src/tts/tts.ts +203 -21
  537. package/src/types.ts +42 -0
  538. package/src/utils.test.ts +658 -0
  539. package/src/utils.ts +375 -44
  540. package/src/vad.ts +90 -22
  541. package/src/voice/agent.test.ts +80 -0
  542. package/src/voice/agent.ts +332 -0
  543. package/src/voice/agent_activity.ts +1913 -0
  544. package/src/voice/agent_session.ts +460 -0
  545. package/src/voice/audio_recognition.ts +474 -0
  546. package/src/voice/events.ts +252 -0
  547. package/src/voice/generation.ts +881 -0
  548. package/src/voice/index.ts +7 -0
  549. package/src/voice/io.ts +304 -0
  550. package/src/voice/room_io/_input.ts +144 -0
  551. package/src/voice/room_io/_output.ts +436 -0
  552. package/src/voice/room_io/index.ts +5 -0
  553. package/src/voice/room_io/room_io.ts +495 -0
  554. package/src/voice/run_context.ts +20 -0
  555. package/src/voice/speech_handle.ts +104 -0
  556. package/src/voice/transcription/_utils.ts +25 -0
  557. package/src/voice/transcription/index.ts +4 -0
  558. package/src/voice/transcription/synchronizer.ts +478 -0
  559. package/src/worker.ts +22 -2
  560. package/dist/llm/function_context.cjs +0 -103
  561. package/dist/llm/function_context.cjs.map +0 -1
  562. package/dist/llm/function_context.d.cts +0 -47
  563. package/dist/llm/function_context.d.ts +0 -47
  564. package/dist/llm/function_context.d.ts.map +0 -1
  565. package/dist/llm/function_context.js +0 -78
  566. package/dist/llm/function_context.js.map +0 -1
  567. package/dist/llm/function_context.test.cjs +0 -218
  568. package/dist/llm/function_context.test.cjs.map +0 -1
  569. package/dist/llm/function_context.test.js +0 -217
  570. package/dist/llm/function_context.test.js.map +0 -1
  571. package/dist/multimodal/multimodal_agent.cjs +0 -451
  572. package/dist/multimodal/multimodal_agent.cjs.map +0 -1
  573. package/dist/multimodal/multimodal_agent.d.cts +0 -48
  574. package/dist/multimodal/multimodal_agent.d.ts +0 -48
  575. package/dist/multimodal/multimodal_agent.d.ts.map +0 -1
  576. package/dist/multimodal/multimodal_agent.js +0 -425
  577. package/dist/multimodal/multimodal_agent.js.map +0 -1
  578. package/dist/pipeline/agent_output.cjs +0 -197
  579. package/dist/pipeline/agent_output.cjs.map +0 -1
  580. package/dist/pipeline/agent_output.d.cts +0 -33
  581. package/dist/pipeline/agent_output.d.ts +0 -33
  582. package/dist/pipeline/agent_output.d.ts.map +0 -1
  583. package/dist/pipeline/agent_output.js +0 -172
  584. package/dist/pipeline/agent_output.js.map +0 -1
  585. package/dist/pipeline/agent_playout.cjs +0 -175
  586. package/dist/pipeline/agent_playout.cjs.map +0 -1
  587. package/dist/pipeline/agent_playout.d.cts +0 -40
  588. package/dist/pipeline/agent_playout.d.ts +0 -40
  589. package/dist/pipeline/agent_playout.d.ts.map +0 -1
  590. package/dist/pipeline/agent_playout.js +0 -139
  591. package/dist/pipeline/agent_playout.js.map +0 -1
  592. package/dist/pipeline/human_input.cjs +0 -171
  593. package/dist/pipeline/human_input.cjs.map +0 -1
  594. package/dist/pipeline/human_input.d.cts +0 -30
  595. package/dist/pipeline/human_input.d.ts +0 -30
  596. package/dist/pipeline/human_input.d.ts.map +0 -1
  597. package/dist/pipeline/human_input.js +0 -146
  598. package/dist/pipeline/human_input.js.map +0 -1
  599. package/dist/pipeline/index.cjs.map +0 -1
  600. package/dist/pipeline/index.d.cts +0 -2
  601. package/dist/pipeline/index.d.ts +0 -2
  602. package/dist/pipeline/index.d.ts.map +0 -1
  603. package/dist/pipeline/index.js +0 -11
  604. package/dist/pipeline/index.js.map +0 -1
  605. package/dist/pipeline/pipeline_agent.cjs +0 -849
  606. package/dist/pipeline/pipeline_agent.cjs.map +0 -1
  607. package/dist/pipeline/pipeline_agent.d.cts +0 -150
  608. package/dist/pipeline/pipeline_agent.d.ts +0 -150
  609. package/dist/pipeline/pipeline_agent.d.ts.map +0 -1
  610. package/dist/pipeline/pipeline_agent.js +0 -826
  611. package/dist/pipeline/pipeline_agent.js.map +0 -1
  612. package/dist/pipeline/speech_handle.cjs +0 -176
  613. package/dist/pipeline/speech_handle.cjs.map +0 -1
  614. package/dist/pipeline/speech_handle.d.cts +0 -37
  615. package/dist/pipeline/speech_handle.d.ts +0 -37
  616. package/dist/pipeline/speech_handle.d.ts.map +0 -1
  617. package/dist/pipeline/speech_handle.js +0 -152
  618. package/dist/pipeline/speech_handle.js.map +0 -1
  619. package/src/llm/function_context.test.ts +0 -248
  620. package/src/llm/function_context.ts +0 -142
  621. package/src/multimodal/multimodal_agent.ts +0 -555
  622. package/src/pipeline/agent_output.ts +0 -219
  623. package/src/pipeline/agent_playout.ts +0 -192
  624. package/src/pipeline/human_input.ts +0 -188
  625. package/src/pipeline/index.ts +0 -15
  626. package/src/pipeline/pipeline_agent.ts +0 -1185
  627. package/src/pipeline/speech_handle.ts +0 -201
@@ -1,147 +1,545 @@
1
- // SPDX-FileCopyrightText: 2024 LiveKit, Inc.
1
+ // SPDX-FileCopyrightText: 2025 LiveKit, Inc.
2
2
  //
3
3
  // SPDX-License-Identifier: Apache-2.0
4
4
  import type { AudioFrame, VideoFrame } from '@livekit/rtc-node';
5
- import type { CallableFunctionResult, FunctionCallInfo } from './function_context.js';
5
+ import { createImmutableArray, shortuuid } from '../utils.js';
6
+ import { type ProviderFormat, toChatCtx } from './provider_format/index.js';
7
+ import type { JSONObject, JSONValue, ToolContext } from './tool_context.js';
6
8
 
7
- export enum ChatRole {
8
- SYSTEM,
9
- USER,
10
- ASSISTANT,
11
- TOOL,
12
- }
9
+ export type ChatRole = 'developer' | 'system' | 'user' | 'assistant';
10
+ export interface ImageContent {
11
+ id: string;
12
+
13
+ type: 'image_content';
13
14
 
14
- export interface ChatImage {
15
+ /**
16
+ * Either a string URL or a VideoFrame object.
17
+ */
15
18
  image: string | VideoFrame;
19
+
20
+ inferenceDetail: 'auto' | 'high' | 'low';
21
+
16
22
  inferenceWidth?: number;
23
+
17
24
  inferenceHeight?: number;
18
- /**
19
- * @internal
20
- * Used by LLM implementations to store a processed version of the image for later use.
21
- */
22
- cache: { [id: string | number | symbol]: any };
25
+
26
+ mimeType?: string;
27
+
28
+ _cache: Record<any, any>; // eslint-disable-line @typescript-eslint/no-explicit-any
23
29
  }
24
30
 
25
- export interface ChatAudio {
26
- frame: AudioFrame | AudioFrame[];
31
+ export interface AudioContent {
32
+ type: 'audio_content';
33
+
34
+ frame: AudioFrame[];
35
+
36
+ transcript?: string;
37
+ }
38
+
39
+ export type ChatContent = ImageContent | AudioContent | string;
40
+
41
+ export function createImageContent(params: {
42
+ image: string | VideoFrame;
43
+ id?: string;
44
+ inferenceDetail?: 'auto' | 'high' | 'low';
45
+ inferenceWidth?: number;
46
+ inferenceHeight?: number;
47
+ mimeType?: string;
48
+ }): ImageContent {
49
+ const {
50
+ image,
51
+ id = shortuuid('img_'),
52
+ inferenceDetail = 'auto',
53
+ inferenceWidth,
54
+ inferenceHeight,
55
+ mimeType,
56
+ } = params;
57
+
58
+ return {
59
+ id,
60
+ type: 'image_content',
61
+ image,
62
+ inferenceDetail,
63
+ inferenceWidth,
64
+ inferenceHeight,
65
+ mimeType,
66
+ _cache: {},
67
+ };
27
68
  }
28
69
 
29
- export type ChatContent = string | ChatImage | ChatAudio;
70
+ export function createAudioContent(params: {
71
+ frame: AudioFrame[];
72
+ transcript?: string;
73
+ }): AudioContent {
74
+ const { frame, transcript } = params;
30
75
 
31
- const defaultCreateChatMessage = {
32
- text: '',
33
- images: [],
34
- role: ChatRole.SYSTEM,
35
- };
76
+ return {
77
+ type: 'audio_content',
78
+ frame,
79
+ transcript,
80
+ };
81
+ }
36
82
 
37
83
  export class ChatMessage {
84
+ readonly id: string;
85
+
86
+ readonly type = 'message' as const;
87
+
38
88
  readonly role: ChatRole;
39
- readonly id?: string;
40
- readonly name?: string;
41
- readonly content?: ChatContent | ChatContent[];
42
- readonly toolCalls?: FunctionCallInfo[];
43
- readonly toolCallId?: string;
44
- readonly toolException?: Error;
45
-
46
- /** @internal */
47
- constructor({
48
- role,
49
- id,
50
- name,
51
- content,
52
- toolCalls,
53
- toolCallId,
54
- toolException,
55
- }: {
89
+
90
+ content: ChatContent[];
91
+
92
+ interrupted: boolean;
93
+
94
+ hash?: Uint8Array;
95
+
96
+ createdAt: number;
97
+
98
+ constructor(params: {
56
99
  role: ChatRole;
100
+ content: ChatContent[] | string;
57
101
  id?: string;
58
- name?: string;
59
- content?: ChatContent | ChatContent[];
60
- toolCalls?: FunctionCallInfo[];
61
- toolCallId?: string;
62
- toolException?: Error;
102
+ interrupted?: boolean;
103
+ createdAt?: number;
63
104
  }) {
105
+ const {
106
+ role,
107
+ content,
108
+ id = shortuuid('item_'),
109
+ interrupted = false,
110
+ createdAt = Date.now(),
111
+ } = params;
112
+ this.id = id;
64
113
  this.role = role;
114
+ this.content = Array.isArray(content) ? content : [content];
115
+ this.interrupted = interrupted;
116
+ this.createdAt = createdAt;
117
+ }
118
+
119
+ static create(params: {
120
+ role: ChatRole;
121
+ content: ChatContent[] | string;
122
+ id?: string;
123
+ interrupted?: boolean;
124
+ createdAt?: number;
125
+ }) {
126
+ return new ChatMessage(params);
127
+ }
128
+
129
+ /**
130
+ * Returns a single string with all text parts of the message joined by new
131
+ * lines. If no string content is present, returns `null`.
132
+ */
133
+ get textContent(): string | undefined {
134
+ const parts = this.content.filter((c): c is string => typeof c === 'string');
135
+ return parts.length > 0 ? parts.join('\n') : undefined;
136
+ }
137
+
138
+ toJSONContent(): JSONValue[] {
139
+ return this.content.map((c) => {
140
+ if (typeof c === 'string') {
141
+ return c as JSONValue;
142
+ } else if (c.type === 'image_content') {
143
+ return {
144
+ id: c.id,
145
+ type: c.type,
146
+ image: c.image,
147
+ inferenceDetail: c.inferenceDetail,
148
+ inferenceWidth: c.inferenceWidth,
149
+ inferenceHeight: c.inferenceHeight,
150
+ mimeType: c.mimeType,
151
+ } as JSONObject;
152
+ } else {
153
+ return {
154
+ type: c.type,
155
+ transcript: c.transcript,
156
+ } as JSONObject;
157
+ }
158
+ });
159
+ }
160
+
161
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
162
+ toJSON(excludeTimestamp: boolean = false): JSONValue {
163
+ const result: JSONValue = {
164
+ id: this.id,
165
+ type: this.type,
166
+ role: this.role,
167
+ content: this.toJSONContent(),
168
+ interrupted: this.interrupted,
169
+ };
170
+
171
+ if (!excludeTimestamp) {
172
+ result.createdAt = this.createdAt;
173
+ }
174
+
175
+ return result;
176
+ }
177
+ }
178
+
179
+ export class FunctionCall {
180
+ readonly id: string;
181
+
182
+ readonly type = 'function_call' as const;
183
+
184
+ callId: string;
185
+
186
+ args: string;
187
+
188
+ name: string;
189
+
190
+ createdAt: number;
191
+
192
+ constructor(params: {
193
+ callId: string;
194
+ name: string;
195
+ args: string;
196
+ id?: string;
197
+ createdAt?: number;
198
+ }) {
199
+ const { callId, name, args, id = shortuuid('item_'), createdAt = Date.now() } = params;
65
200
  this.id = id;
201
+ this.callId = callId;
202
+ this.args = args;
66
203
  this.name = name;
67
- this.content = content;
68
- this.toolCalls = toolCalls;
69
- this.toolCallId = toolCallId;
70
- this.toolException = toolException;
204
+ this.createdAt = createdAt;
205
+ }
206
+
207
+ static create(params: {
208
+ callId: string;
209
+ name: string;
210
+ args: string;
211
+ id?: string;
212
+ createdAt?: number;
213
+ }) {
214
+ return new FunctionCall(params);
71
215
  }
72
216
 
73
- static createToolFromFunctionResult(func: CallableFunctionResult): ChatMessage {
74
- if (!func.result && !func.error) {
75
- throw new TypeError('CallableFunctionResult must include result or error');
217
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
218
+ toJSON(excludeTimestamp: boolean = false): JSONValue {
219
+ const result: JSONValue = {
220
+ id: this.id,
221
+ type: this.type,
222
+ callId: this.callId,
223
+ name: this.name,
224
+ args: this.args,
225
+ };
226
+
227
+ if (!excludeTimestamp) {
228
+ result.createdAt = this.createdAt;
76
229
  }
77
230
 
78
- return new ChatMessage({
79
- role: ChatRole.TOOL,
80
- name: func.name,
81
- content: func.result || `Error: ${func.error}`,
82
- toolCallId: func.toolCallId,
83
- toolException: func.error,
84
- });
231
+ return result;
85
232
  }
233
+ }
86
234
 
87
- static createToolCalls(toolCalls: FunctionCallInfo[], text = '') {
88
- return new ChatMessage({
89
- role: ChatRole.ASSISTANT,
90
- toolCalls,
91
- content: text,
92
- });
235
+ export class FunctionCallOutput {
236
+ readonly id: string;
237
+
238
+ readonly type = 'function_call_output' as const;
239
+
240
+ name = '';
241
+
242
+ callId: string;
243
+
244
+ output: string;
245
+
246
+ isError: boolean;
247
+
248
+ createdAt: number;
249
+
250
+ constructor(params: {
251
+ callId: string;
252
+ output: string;
253
+ isError: boolean;
254
+ id?: string;
255
+ createdAt?: number;
256
+ name?: string;
257
+ }) {
258
+ const {
259
+ callId,
260
+ output,
261
+ isError,
262
+ id = shortuuid('item_'),
263
+ createdAt = Date.now(),
264
+ name = '',
265
+ } = params;
266
+ this.id = id;
267
+ this.callId = callId;
268
+ this.output = output;
269
+ this.isError = isError;
270
+ this.name = name;
271
+ this.createdAt = createdAt;
93
272
  }
94
273
 
95
- static create(
96
- options: Partial<{
97
- text?: string;
98
- images: ChatImage[];
99
- role: ChatRole;
100
- }>,
101
- ): ChatMessage {
102
- const { text, images, role } = { ...defaultCreateChatMessage, ...options };
103
-
104
- if (!images.length) {
105
- return new ChatMessage({
106
- role,
107
- content: text,
108
- });
109
- } else {
110
- return new ChatMessage({
111
- role,
112
- content: [...(text ? [text] : []), ...images],
113
- });
114
- }
274
+ static create(params: {
275
+ callId: string;
276
+ output: string;
277
+ isError: boolean;
278
+ id?: string;
279
+ createdAt?: number;
280
+ name?: string;
281
+ }) {
282
+ return new FunctionCallOutput(params);
115
283
  }
116
284
 
117
- /** Returns a structured clone of this message. */
118
- copy(): ChatMessage {
119
- return new ChatMessage({
120
- role: this.role,
285
+ toJSON(excludeTimestamp: boolean = false): JSONValue {
286
+ const result: JSONValue = {
121
287
  id: this.id,
288
+ type: this.type,
122
289
  name: this.name,
123
- content: this.content,
124
- toolCalls: this.toolCalls,
125
- toolCallId: this.toolCallId,
126
- toolException: this.toolException,
127
- });
290
+ callId: this.callId,
291
+ output: this.output,
292
+ isError: this.isError,
293
+ };
294
+
295
+ if (!excludeTimestamp) {
296
+ result.createdAt = this.createdAt;
297
+ }
298
+
299
+ return result;
128
300
  }
129
301
  }
130
302
 
303
+ export type ChatItem = ChatMessage | FunctionCall | FunctionCallOutput;
304
+
131
305
  export class ChatContext {
132
- messages: ChatMessage[] = [];
133
- metadata: { [id: string]: any } = {};
306
+ protected _items: ChatItem[];
307
+
308
+ constructor(items?: ChatItem[]) {
309
+ this._items = items ? items : [];
310
+ }
311
+
312
+ static empty(): ChatContext {
313
+ return new ChatContext([]);
314
+ }
315
+
316
+ get items(): ChatItem[] {
317
+ return this._items;
318
+ }
319
+
320
+ set items(items: ChatItem[]) {
321
+ this._items = items;
322
+ }
323
+
324
+ /**
325
+ * Add a new message to the context and return it.
326
+ */
327
+ addMessage(params: {
328
+ role: ChatRole;
329
+ content: ChatContent[] | string;
330
+ id?: string;
331
+ interrupted?: boolean;
332
+ createdAt?: number;
333
+ }): ChatMessage {
334
+ const msg = new ChatMessage(params);
335
+ if (params.createdAt !== undefined) {
336
+ const idx = this.findInsertionIndex(params.createdAt);
337
+ this._items.splice(idx, 0, msg);
338
+ } else {
339
+ this._items.push(msg);
340
+ }
341
+ return msg;
342
+ }
343
+
344
+ /**
345
+ * Insert a single item or multiple items based on their `createdAt` field so
346
+ * that the array keeps its chronological order.
347
+ */
348
+ insert(item: ChatItem | ChatItem[]): void {
349
+ const arr = Array.isArray(item) ? item : [item];
350
+ for (const it of arr) {
351
+ const idx = this.findInsertionIndex(it.createdAt);
352
+ this._items.splice(idx, 0, it);
353
+ }
354
+ }
355
+
356
+ getById(itemId: string): ChatItem | undefined {
357
+ return this._items.find((i) => i.id === itemId);
358
+ }
359
+
360
+ indexById(itemId: string): number | undefined {
361
+ const idx = this._items.findIndex((i) => i.id === itemId);
362
+ return idx !== -1 ? idx : undefined;
363
+ }
364
+
365
+ copy(
366
+ options: {
367
+ excludeFunctionCall?: boolean;
368
+ excludeInstructions?: boolean;
369
+ excludeEmptyMessage?: boolean;
370
+ toolCtx?: ToolContext<any>; // eslint-disable-line @typescript-eslint/no-explicit-any
371
+ } = {},
372
+ ): ChatContext {
373
+ const {
374
+ excludeFunctionCall = false,
375
+ excludeInstructions = false,
376
+ excludeEmptyMessage = false,
377
+ toolCtx,
378
+ } = options;
379
+ const items: ChatItem[] = [];
380
+
381
+ const isToolCallOrOutput = (item: ChatItem): item is FunctionCall | FunctionCallOutput =>
382
+ ['function_call', 'function_call_output'].includes(item.type);
383
+ const isChatMessage = (item: ChatItem): item is ChatMessage => item.type === 'message';
384
+
385
+ for (const item of this._items) {
386
+ if (excludeFunctionCall && isToolCallOrOutput(item)) {
387
+ continue;
388
+ }
389
+
390
+ if (
391
+ excludeInstructions &&
392
+ isChatMessage(item) &&
393
+ ['system', 'developer'].includes(item.role)
394
+ ) {
395
+ continue;
396
+ }
397
+
398
+ if (excludeEmptyMessage && isChatMessage(item) && item.content.length === 0) {
399
+ continue;
400
+ }
401
+
402
+ if (toolCtx !== undefined && isToolCallOrOutput(item) && toolCtx[item.name] === undefined) {
403
+ continue;
404
+ }
134
405
 
135
- append(msg: { text?: string; images?: ChatImage[]; role: ChatRole }): ChatContext {
136
- this.messages.push(ChatMessage.create(msg));
406
+ items.push(item);
407
+ }
408
+
409
+ return new ChatContext(items);
410
+ }
411
+
412
+ truncate(maxItems: number): ChatContext {
413
+ if (maxItems <= 0) return this;
414
+
415
+ const instructions = this._items.find((i) => i.type === 'message' && i.role === 'system') as
416
+ | ChatMessage
417
+ | undefined;
418
+
419
+ let newItems = this._items.slice(-maxItems);
420
+
421
+ // Ensure the first item is not a function-call artefact.
422
+ while (
423
+ newItems.length > 0 &&
424
+ ['function_call', 'function_call_output'].includes(newItems[0]!.type)
425
+ ) {
426
+ newItems.shift();
427
+ }
428
+
429
+ if (instructions) {
430
+ // At this point `instructions` is defined, so it is safe to pass to `includes`.
431
+ if (!newItems.includes(instructions)) {
432
+ newItems = [instructions, ...newItems];
433
+ }
434
+ }
435
+
436
+ // replace the items in place to keep the reference
437
+ this._items.splice(0, this._items.length, ...newItems);
137
438
  return this;
138
439
  }
139
440
 
140
- /** Returns a structured clone of this context. */
141
- copy(): ChatContext {
142
- const ctx = new ChatContext();
143
- ctx.messages.push(...this.messages.map((msg) => msg.copy()));
144
- ctx.metadata = structuredClone(this.metadata);
145
- return ctx;
441
+ toJSON(
442
+ options: {
443
+ excludeImage?: boolean;
444
+ excludeAudio?: boolean;
445
+ excludeTimestamp?: boolean;
446
+ excludeFunctionCall?: boolean;
447
+ } = {},
448
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
449
+ ): JSONObject {
450
+ const {
451
+ excludeImage = true,
452
+ excludeAudio = true,
453
+ excludeTimestamp = true,
454
+ excludeFunctionCall = false,
455
+ } = options;
456
+
457
+ const items: ChatItem[] = [];
458
+
459
+ for (const item of this._items) {
460
+ let processedItem = item;
461
+
462
+ if (excludeFunctionCall && ['function_call', 'function_call_output'].includes(item.type)) {
463
+ continue;
464
+ }
465
+
466
+ if (item.type === 'message') {
467
+ processedItem = ChatMessage.create({
468
+ role: item.role,
469
+ content: item.content,
470
+ id: item.id,
471
+ interrupted: item.interrupted,
472
+ createdAt: item.createdAt,
473
+ });
474
+
475
+ // Filter content based on options
476
+ if (excludeImage) {
477
+ processedItem.content = processedItem.content.filter((c) => {
478
+ return !(typeof c === 'object' && c.type === 'image_content');
479
+ });
480
+ }
481
+
482
+ if (excludeAudio) {
483
+ processedItem.content = processedItem.content.filter((c) => {
484
+ return !(typeof c === 'object' && c.type === 'audio_content');
485
+ });
486
+ }
487
+ }
488
+
489
+ items.push(processedItem);
490
+ }
491
+
492
+ return {
493
+ items: items.map((item) => item.toJSON(excludeTimestamp)),
494
+ };
495
+ }
496
+
497
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
498
+ async toProviderFormat(format: ProviderFormat, injectDummyUserMessage: boolean = true) {
499
+ return await toChatCtx(format, this, injectDummyUserMessage);
500
+ }
501
+
502
+ /**
503
+ * Internal helper used by `truncate` & `addMessage` to find the correct
504
+ * insertion index for a timestamp so the list remains sorted.
505
+ */
506
+ private findInsertionIndex(createdAt: number): number {
507
+ for (let i = this._items.length - 1; i >= 0; i -= 1) {
508
+ const item = this._items[i];
509
+ if (item!.createdAt <= createdAt) {
510
+ return i + 1;
511
+ }
512
+ }
513
+ return 0;
514
+ }
515
+
516
+ /**
517
+ * Indicates whether the context is read-only
518
+ */
519
+ get readonly(): boolean {
520
+ return false;
521
+ }
522
+ }
523
+
524
+ export class ReadonlyChatContext extends ChatContext {
525
+ static readonly errorMsg =
526
+ 'Please use .copy() and agent.update_chat_ctx() to modify the chat context.';
527
+
528
+ constructor(items: ChatItem[]) {
529
+ super(createImmutableArray(items, ReadonlyChatContext.errorMsg));
530
+ }
531
+
532
+ get items(): ChatItem[] {
533
+ return this._items;
534
+ }
535
+
536
+ set items(items: ChatItem[]) {
537
+ throw new Error(
538
+ `Cannot set items on a read-only chat context. ${ReadonlyChatContext.errorMsg}`,
539
+ );
540
+ }
541
+
542
+ get readonly(): boolean {
543
+ return true;
146
544
  }
147
545
  }