@livekit/agents 1.1.0 → 1.2.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (959) hide show
  1. package/dist/_exceptions.cjs.map +1 -1
  2. package/dist/_exceptions.d.ts.map +1 -1
  3. package/dist/_exceptions.js.map +1 -1
  4. package/dist/audio.cjs +89 -3
  5. package/dist/audio.cjs.map +1 -1
  6. package/dist/audio.d.cts +36 -1
  7. package/dist/audio.d.ts +36 -1
  8. package/dist/audio.d.ts.map +1 -1
  9. package/dist/audio.js +76 -2
  10. package/dist/audio.js.map +1 -1
  11. package/dist/beta/index.cjs +29 -0
  12. package/dist/beta/index.cjs.map +1 -0
  13. package/dist/beta/index.d.cts +2 -0
  14. package/dist/beta/index.d.ts +2 -0
  15. package/dist/beta/index.d.ts.map +1 -0
  16. package/dist/beta/index.js +7 -0
  17. package/dist/beta/index.js.map +1 -0
  18. package/dist/beta/workflows/index.cjs +29 -0
  19. package/dist/beta/workflows/index.cjs.map +1 -0
  20. package/dist/beta/workflows/index.d.cts +2 -0
  21. package/dist/beta/workflows/index.d.ts +2 -0
  22. package/dist/beta/workflows/index.d.ts.map +1 -0
  23. package/dist/beta/workflows/index.js +7 -0
  24. package/dist/beta/workflows/index.js.map +1 -0
  25. package/dist/beta/workflows/task_group.cjs +165 -0
  26. package/dist/beta/workflows/task_group.cjs.map +1 -0
  27. package/dist/beta/workflows/task_group.d.cts +32 -0
  28. package/dist/beta/workflows/task_group.d.ts +32 -0
  29. package/dist/beta/workflows/task_group.d.ts.map +1 -0
  30. package/dist/beta/workflows/task_group.js +141 -0
  31. package/dist/beta/workflows/task_group.js.map +1 -0
  32. package/dist/cli.cjs +44 -46
  33. package/dist/cli.cjs.map +1 -1
  34. package/dist/cli.d.cts +3 -3
  35. package/dist/cli.d.ts +3 -3
  36. package/dist/cli.d.ts.map +1 -1
  37. package/dist/cli.js +45 -47
  38. package/dist/cli.js.map +1 -1
  39. package/dist/connection_pool.cjs +242 -0
  40. package/dist/connection_pool.cjs.map +1 -0
  41. package/dist/connection_pool.d.cts +123 -0
  42. package/dist/connection_pool.d.ts +123 -0
  43. package/dist/connection_pool.d.ts.map +1 -0
  44. package/dist/connection_pool.js +218 -0
  45. package/dist/connection_pool.js.map +1 -0
  46. package/dist/connection_pool.test.cjs +256 -0
  47. package/dist/connection_pool.test.cjs.map +1 -0
  48. package/dist/connection_pool.test.js +255 -0
  49. package/dist/connection_pool.test.js.map +1 -0
  50. package/dist/constants.cjs +30 -0
  51. package/dist/constants.cjs.map +1 -1
  52. package/dist/constants.d.cts +10 -0
  53. package/dist/constants.d.ts +10 -0
  54. package/dist/constants.d.ts.map +1 -1
  55. package/dist/constants.js +20 -0
  56. package/dist/constants.js.map +1 -1
  57. package/dist/cpu.cjs +189 -0
  58. package/dist/cpu.cjs.map +1 -0
  59. package/dist/cpu.d.cts +24 -0
  60. package/dist/cpu.d.ts +24 -0
  61. package/dist/cpu.d.ts.map +1 -0
  62. package/dist/cpu.js +152 -0
  63. package/dist/cpu.js.map +1 -0
  64. package/dist/cpu.test.cjs +227 -0
  65. package/dist/cpu.test.cjs.map +1 -0
  66. package/dist/cpu.test.js +204 -0
  67. package/dist/cpu.test.js.map +1 -0
  68. package/dist/http_server.cjs +9 -6
  69. package/dist/http_server.cjs.map +1 -1
  70. package/dist/http_server.d.cts +5 -1
  71. package/dist/http_server.d.ts +5 -1
  72. package/dist/http_server.d.ts.map +1 -1
  73. package/dist/http_server.js +9 -6
  74. package/dist/http_server.js.map +1 -1
  75. package/dist/index.cjs +24 -9
  76. package/dist/index.cjs.map +1 -1
  77. package/dist/index.d.cts +15 -11
  78. package/dist/index.d.ts +15 -11
  79. package/dist/index.d.ts.map +1 -1
  80. package/dist/index.js +18 -9
  81. package/dist/index.js.map +1 -1
  82. package/dist/inference/api_protos.cjs +70 -2
  83. package/dist/inference/api_protos.cjs.map +1 -1
  84. package/dist/inference/api_protos.d.cts +373 -32
  85. package/dist/inference/api_protos.d.ts +373 -32
  86. package/dist/inference/api_protos.d.ts.map +1 -1
  87. package/dist/inference/api_protos.js +62 -2
  88. package/dist/inference/api_protos.js.map +1 -1
  89. package/dist/inference/index.cjs +8 -0
  90. package/dist/inference/index.cjs.map +1 -1
  91. package/dist/inference/index.d.cts +3 -4
  92. package/dist/inference/index.d.ts +3 -4
  93. package/dist/inference/index.d.ts.map +1 -1
  94. package/dist/inference/index.js +18 -3
  95. package/dist/inference/index.js.map +1 -1
  96. package/dist/inference/interruption/defaults.cjs +81 -0
  97. package/dist/inference/interruption/defaults.cjs.map +1 -0
  98. package/dist/inference/interruption/defaults.d.cts +19 -0
  99. package/dist/inference/interruption/defaults.d.ts +19 -0
  100. package/dist/inference/interruption/defaults.d.ts.map +1 -0
  101. package/dist/inference/interruption/defaults.js +46 -0
  102. package/dist/inference/interruption/defaults.js.map +1 -0
  103. package/dist/inference/interruption/errors.cjs +44 -0
  104. package/dist/inference/interruption/errors.cjs.map +1 -0
  105. package/dist/inference/interruption/errors.d.cts +12 -0
  106. package/dist/inference/interruption/errors.d.ts +12 -0
  107. package/dist/inference/interruption/errors.d.ts.map +1 -0
  108. package/dist/inference/interruption/errors.js +20 -0
  109. package/dist/inference/interruption/errors.js.map +1 -0
  110. package/dist/inference/interruption/http_transport.cjs +163 -0
  111. package/dist/inference/interruption/http_transport.cjs.map +1 -0
  112. package/dist/inference/interruption/http_transport.d.cts +65 -0
  113. package/dist/inference/interruption/http_transport.d.ts +65 -0
  114. package/dist/inference/interruption/http_transport.d.ts.map +1 -0
  115. package/dist/inference/interruption/http_transport.js +137 -0
  116. package/dist/inference/interruption/http_transport.js.map +1 -0
  117. package/dist/inference/interruption/interruption_cache_entry.cjs +58 -0
  118. package/dist/inference/interruption/interruption_cache_entry.cjs.map +1 -0
  119. package/dist/inference/interruption/interruption_cache_entry.d.cts +30 -0
  120. package/dist/inference/interruption/interruption_cache_entry.d.ts +30 -0
  121. package/dist/inference/interruption/interruption_cache_entry.d.ts.map +1 -0
  122. package/dist/inference/interruption/interruption_cache_entry.js +34 -0
  123. package/dist/inference/interruption/interruption_cache_entry.js.map +1 -0
  124. package/dist/inference/interruption/interruption_detector.cjs +198 -0
  125. package/dist/inference/interruption/interruption_detector.cjs.map +1 -0
  126. package/dist/inference/interruption/interruption_detector.d.cts +59 -0
  127. package/dist/inference/interruption/interruption_detector.d.ts +59 -0
  128. package/dist/inference/interruption/interruption_detector.d.ts.map +1 -0
  129. package/dist/inference/interruption/interruption_detector.js +164 -0
  130. package/dist/inference/interruption/interruption_detector.js.map +1 -0
  131. package/dist/inference/interruption/interruption_stream.cjs +368 -0
  132. package/dist/inference/interruption/interruption_stream.cjs.map +1 -0
  133. package/dist/inference/interruption/interruption_stream.d.cts +46 -0
  134. package/dist/inference/interruption/interruption_stream.d.ts +46 -0
  135. package/dist/inference/interruption/interruption_stream.d.ts.map +1 -0
  136. package/dist/inference/interruption/interruption_stream.js +344 -0
  137. package/dist/inference/interruption/interruption_stream.js.map +1 -0
  138. package/dist/inference/interruption/types.cjs +17 -0
  139. package/dist/inference/interruption/types.cjs.map +1 -0
  140. package/dist/inference/interruption/types.d.cts +66 -0
  141. package/dist/inference/interruption/types.d.ts +66 -0
  142. package/dist/inference/interruption/types.d.ts.map +1 -0
  143. package/dist/inference/interruption/types.js +1 -0
  144. package/dist/inference/interruption/types.js.map +1 -0
  145. package/dist/inference/interruption/utils.cjs +130 -0
  146. package/dist/inference/interruption/utils.cjs.map +1 -0
  147. package/dist/inference/interruption/utils.d.cts +41 -0
  148. package/dist/inference/interruption/utils.d.ts +41 -0
  149. package/dist/inference/interruption/utils.d.ts.map +1 -0
  150. package/dist/inference/interruption/utils.js +105 -0
  151. package/dist/inference/interruption/utils.js.map +1 -0
  152. package/dist/inference/interruption/utils.test.cjs +105 -0
  153. package/dist/inference/interruption/utils.test.cjs.map +1 -0
  154. package/dist/inference/interruption/utils.test.js +104 -0
  155. package/dist/inference/interruption/utils.test.js.map +1 -0
  156. package/dist/inference/interruption/ws_transport.cjs +347 -0
  157. package/dist/inference/interruption/ws_transport.cjs.map +1 -0
  158. package/dist/inference/interruption/ws_transport.d.cts +33 -0
  159. package/dist/inference/interruption/ws_transport.d.ts +33 -0
  160. package/dist/inference/interruption/ws_transport.d.ts.map +1 -0
  161. package/dist/inference/interruption/ws_transport.js +313 -0
  162. package/dist/inference/interruption/ws_transport.js.map +1 -0
  163. package/dist/inference/llm.cjs +106 -66
  164. package/dist/inference/llm.cjs.map +1 -1
  165. package/dist/inference/llm.d.cts +65 -43
  166. package/dist/inference/llm.d.ts +65 -43
  167. package/dist/inference/llm.d.ts.map +1 -1
  168. package/dist/inference/llm.js +100 -66
  169. package/dist/inference/llm.js.map +1 -1
  170. package/dist/inference/stt.cjs +319 -170
  171. package/dist/inference/stt.cjs.map +1 -1
  172. package/dist/inference/stt.d.cts +64 -15
  173. package/dist/inference/stt.d.ts +64 -15
  174. package/dist/inference/stt.d.ts.map +1 -1
  175. package/dist/inference/stt.js +319 -170
  176. package/dist/inference/stt.js.map +1 -1
  177. package/dist/inference/stt.test.cjs +218 -0
  178. package/dist/inference/stt.test.cjs.map +1 -0
  179. package/dist/inference/stt.test.js +217 -0
  180. package/dist/inference/stt.test.js.map +1 -0
  181. package/dist/inference/tts.cjs +249 -71
  182. package/dist/inference/tts.cjs.map +1 -1
  183. package/dist/inference/tts.d.cts +94 -17
  184. package/dist/inference/tts.d.ts +94 -17
  185. package/dist/inference/tts.d.ts.map +1 -1
  186. package/dist/inference/tts.js +249 -77
  187. package/dist/inference/tts.js.map +1 -1
  188. package/dist/inference/tts.test.cjs +305 -0
  189. package/dist/inference/tts.test.cjs.map +1 -0
  190. package/dist/inference/tts.test.js +304 -0
  191. package/dist/inference/tts.test.js.map +1 -0
  192. package/dist/inference/utils.cjs +26 -7
  193. package/dist/inference/utils.cjs.map +1 -1
  194. package/dist/inference/utils.d.cts +14 -1
  195. package/dist/inference/utils.d.ts +14 -1
  196. package/dist/inference/utils.d.ts.map +1 -1
  197. package/dist/inference/utils.js +18 -2
  198. package/dist/inference/utils.js.map +1 -1
  199. package/dist/ipc/inference_proc_executor.cjs +6 -3
  200. package/dist/ipc/inference_proc_executor.cjs.map +1 -1
  201. package/dist/ipc/inference_proc_executor.d.ts.map +1 -1
  202. package/dist/ipc/inference_proc_executor.js +6 -3
  203. package/dist/ipc/inference_proc_executor.js.map +1 -1
  204. package/dist/ipc/inference_proc_lazy_main.cjs +13 -1
  205. package/dist/ipc/inference_proc_lazy_main.cjs.map +1 -1
  206. package/dist/ipc/inference_proc_lazy_main.js +13 -1
  207. package/dist/ipc/inference_proc_lazy_main.js.map +1 -1
  208. package/dist/ipc/job_proc_executor.cjs +6 -1
  209. package/dist/ipc/job_proc_executor.cjs.map +1 -1
  210. package/dist/ipc/job_proc_executor.d.ts.map +1 -1
  211. package/dist/ipc/job_proc_executor.js +6 -1
  212. package/dist/ipc/job_proc_executor.js.map +1 -1
  213. package/dist/ipc/job_proc_lazy_main.cjs +89 -17
  214. package/dist/ipc/job_proc_lazy_main.cjs.map +1 -1
  215. package/dist/ipc/job_proc_lazy_main.js +68 -18
  216. package/dist/ipc/job_proc_lazy_main.js.map +1 -1
  217. package/dist/ipc/supervised_proc.cjs +34 -8
  218. package/dist/ipc/supervised_proc.cjs.map +1 -1
  219. package/dist/ipc/supervised_proc.d.cts +8 -0
  220. package/dist/ipc/supervised_proc.d.ts +8 -0
  221. package/dist/ipc/supervised_proc.d.ts.map +1 -1
  222. package/dist/ipc/supervised_proc.js +34 -8
  223. package/dist/ipc/supervised_proc.js.map +1 -1
  224. package/dist/ipc/supervised_proc.test.cjs +145 -0
  225. package/dist/ipc/supervised_proc.test.cjs.map +1 -0
  226. package/dist/ipc/supervised_proc.test.js +122 -0
  227. package/dist/ipc/supervised_proc.test.js.map +1 -0
  228. package/dist/job.cjs +109 -1
  229. package/dist/job.cjs.map +1 -1
  230. package/dist/job.d.cts +14 -0
  231. package/dist/job.d.ts +14 -0
  232. package/dist/job.d.ts.map +1 -1
  233. package/dist/job.js +99 -1
  234. package/dist/job.js.map +1 -1
  235. package/dist/language.cjs +394 -0
  236. package/dist/language.cjs.map +1 -0
  237. package/dist/language.d.cts +15 -0
  238. package/dist/language.d.ts +15 -0
  239. package/dist/language.d.ts.map +1 -0
  240. package/dist/language.js +363 -0
  241. package/dist/language.js.map +1 -0
  242. package/dist/language.test.cjs +43 -0
  243. package/dist/language.test.cjs.map +1 -0
  244. package/dist/language.test.js +49 -0
  245. package/dist/language.test.js.map +1 -0
  246. package/dist/llm/chat_context.cjs +345 -3
  247. package/dist/llm/chat_context.cjs.map +1 -1
  248. package/dist/llm/chat_context.d.cts +86 -2
  249. package/dist/llm/chat_context.d.ts +86 -2
  250. package/dist/llm/chat_context.d.ts.map +1 -1
  251. package/dist/llm/chat_context.js +344 -3
  252. package/dist/llm/chat_context.js.map +1 -1
  253. package/dist/llm/chat_context.test.cjs +692 -0
  254. package/dist/llm/chat_context.test.cjs.map +1 -1
  255. package/dist/llm/chat_context.test.js +692 -0
  256. package/dist/llm/chat_context.test.js.map +1 -1
  257. package/dist/llm/fallback_adapter.cjs +280 -0
  258. package/dist/llm/fallback_adapter.cjs.map +1 -0
  259. package/dist/llm/fallback_adapter.d.cts +73 -0
  260. package/dist/llm/fallback_adapter.d.ts +73 -0
  261. package/dist/llm/fallback_adapter.d.ts.map +1 -0
  262. package/dist/llm/fallback_adapter.js +256 -0
  263. package/dist/llm/fallback_adapter.js.map +1 -0
  264. package/dist/llm/fallback_adapter.test.cjs +176 -0
  265. package/dist/llm/fallback_adapter.test.cjs.map +1 -0
  266. package/dist/llm/fallback_adapter.test.js +175 -0
  267. package/dist/llm/fallback_adapter.test.js.map +1 -0
  268. package/dist/llm/index.cjs +11 -0
  269. package/dist/llm/index.cjs.map +1 -1
  270. package/dist/llm/index.d.cts +4 -3
  271. package/dist/llm/index.d.ts +4 -3
  272. package/dist/llm/index.d.ts.map +1 -1
  273. package/dist/llm/index.js +13 -1
  274. package/dist/llm/index.js.map +1 -1
  275. package/dist/llm/llm.cjs +65 -11
  276. package/dist/llm/llm.cjs.map +1 -1
  277. package/dist/llm/llm.d.cts +13 -2
  278. package/dist/llm/llm.d.ts +13 -2
  279. package/dist/llm/llm.d.ts.map +1 -1
  280. package/dist/llm/llm.js +65 -11
  281. package/dist/llm/llm.js.map +1 -1
  282. package/dist/llm/provider_format/google.cjs +6 -2
  283. package/dist/llm/provider_format/google.cjs.map +1 -1
  284. package/dist/llm/provider_format/google.d.cts +1 -1
  285. package/dist/llm/provider_format/google.d.ts +1 -1
  286. package/dist/llm/provider_format/google.d.ts.map +1 -1
  287. package/dist/llm/provider_format/google.js +6 -2
  288. package/dist/llm/provider_format/google.js.map +1 -1
  289. package/dist/llm/provider_format/google.test.cjs +48 -0
  290. package/dist/llm/provider_format/google.test.cjs.map +1 -1
  291. package/dist/llm/provider_format/google.test.js +54 -1
  292. package/dist/llm/provider_format/google.test.js.map +1 -1
  293. package/dist/llm/provider_format/index.cjs +2 -0
  294. package/dist/llm/provider_format/index.cjs.map +1 -1
  295. package/dist/llm/provider_format/index.d.cts +2 -2
  296. package/dist/llm/provider_format/index.d.ts +2 -2
  297. package/dist/llm/provider_format/index.d.ts.map +1 -1
  298. package/dist/llm/provider_format/index.js +6 -1
  299. package/dist/llm/provider_format/index.js.map +1 -1
  300. package/dist/llm/provider_format/openai.cjs +126 -24
  301. package/dist/llm/provider_format/openai.cjs.map +1 -1
  302. package/dist/llm/provider_format/openai.d.cts +1 -0
  303. package/dist/llm/provider_format/openai.d.ts +1 -0
  304. package/dist/llm/provider_format/openai.d.ts.map +1 -1
  305. package/dist/llm/provider_format/openai.js +124 -23
  306. package/dist/llm/provider_format/openai.js.map +1 -1
  307. package/dist/llm/provider_format/openai.test.cjs +393 -0
  308. package/dist/llm/provider_format/openai.test.cjs.map +1 -1
  309. package/dist/llm/provider_format/openai.test.js +400 -2
  310. package/dist/llm/provider_format/openai.test.js.map +1 -1
  311. package/dist/llm/provider_format/utils.cjs +5 -4
  312. package/dist/llm/provider_format/utils.cjs.map +1 -1
  313. package/dist/llm/provider_format/utils.d.ts.map +1 -1
  314. package/dist/llm/provider_format/utils.js +5 -4
  315. package/dist/llm/provider_format/utils.js.map +1 -1
  316. package/dist/llm/realtime.cjs +3 -0
  317. package/dist/llm/realtime.cjs.map +1 -1
  318. package/dist/llm/realtime.d.cts +15 -1
  319. package/dist/llm/realtime.d.ts +15 -1
  320. package/dist/llm/realtime.d.ts.map +1 -1
  321. package/dist/llm/realtime.js +3 -0
  322. package/dist/llm/realtime.js.map +1 -1
  323. package/dist/llm/remote_chat_context.cjs.map +1 -1
  324. package/dist/llm/remote_chat_context.d.cts +2 -0
  325. package/dist/llm/remote_chat_context.d.ts +2 -0
  326. package/dist/llm/remote_chat_context.d.ts.map +1 -1
  327. package/dist/llm/remote_chat_context.js.map +1 -1
  328. package/dist/llm/tool_context.cjs +50 -2
  329. package/dist/llm/tool_context.cjs.map +1 -1
  330. package/dist/llm/tool_context.d.cts +47 -11
  331. package/dist/llm/tool_context.d.ts +47 -11
  332. package/dist/llm/tool_context.d.ts.map +1 -1
  333. package/dist/llm/tool_context.js +48 -3
  334. package/dist/llm/tool_context.js.map +1 -1
  335. package/dist/llm/tool_context.test.cjs +197 -0
  336. package/dist/llm/tool_context.test.cjs.map +1 -1
  337. package/dist/llm/tool_context.test.js +175 -0
  338. package/dist/llm/tool_context.test.js.map +1 -1
  339. package/dist/llm/utils.cjs +107 -12
  340. package/dist/llm/utils.cjs.map +1 -1
  341. package/dist/llm/utils.d.cts +10 -3
  342. package/dist/llm/utils.d.ts +10 -3
  343. package/dist/llm/utils.d.ts.map +1 -1
  344. package/dist/llm/utils.js +106 -12
  345. package/dist/llm/utils.js.map +1 -1
  346. package/dist/llm/utils.test.cjs +90 -0
  347. package/dist/llm/utils.test.cjs.map +1 -1
  348. package/dist/llm/utils.test.js +98 -2
  349. package/dist/llm/utils.test.js.map +1 -1
  350. package/dist/llm/zod-utils.cjs +102 -0
  351. package/dist/llm/zod-utils.cjs.map +1 -0
  352. package/dist/llm/zod-utils.d.cts +65 -0
  353. package/dist/llm/zod-utils.d.ts +65 -0
  354. package/dist/llm/zod-utils.d.ts.map +1 -0
  355. package/dist/llm/zod-utils.js +64 -0
  356. package/dist/llm/zod-utils.js.map +1 -0
  357. package/dist/llm/zod-utils.test.cjs +472 -0
  358. package/dist/llm/zod-utils.test.cjs.map +1 -0
  359. package/dist/llm/zod-utils.test.js +455 -0
  360. package/dist/llm/zod-utils.test.js.map +1 -0
  361. package/dist/log.cjs +45 -14
  362. package/dist/log.cjs.map +1 -1
  363. package/dist/log.d.cts +8 -1
  364. package/dist/log.d.ts +8 -1
  365. package/dist/log.d.ts.map +1 -1
  366. package/dist/log.js +45 -15
  367. package/dist/log.js.map +1 -1
  368. package/dist/metrics/base.cjs.map +1 -1
  369. package/dist/metrics/base.d.cts +75 -19
  370. package/dist/metrics/base.d.ts +75 -19
  371. package/dist/metrics/base.d.ts.map +1 -1
  372. package/dist/metrics/index.cjs +5 -0
  373. package/dist/metrics/index.cjs.map +1 -1
  374. package/dist/metrics/index.d.cts +2 -1
  375. package/dist/metrics/index.d.ts +2 -1
  376. package/dist/metrics/index.d.ts.map +1 -1
  377. package/dist/metrics/index.js +6 -0
  378. package/dist/metrics/index.js.map +1 -1
  379. package/dist/metrics/model_usage.cjs +189 -0
  380. package/dist/metrics/model_usage.cjs.map +1 -0
  381. package/dist/metrics/model_usage.d.cts +92 -0
  382. package/dist/metrics/model_usage.d.ts +92 -0
  383. package/dist/metrics/model_usage.d.ts.map +1 -0
  384. package/dist/metrics/model_usage.js +164 -0
  385. package/dist/metrics/model_usage.js.map +1 -0
  386. package/dist/metrics/model_usage.test.cjs +474 -0
  387. package/dist/metrics/model_usage.test.cjs.map +1 -0
  388. package/dist/metrics/model_usage.test.js +476 -0
  389. package/dist/metrics/model_usage.test.js.map +1 -0
  390. package/dist/metrics/usage_collector.cjs +5 -2
  391. package/dist/metrics/usage_collector.cjs.map +1 -1
  392. package/dist/metrics/usage_collector.d.cts +10 -1
  393. package/dist/metrics/usage_collector.d.ts +10 -1
  394. package/dist/metrics/usage_collector.d.ts.map +1 -1
  395. package/dist/metrics/usage_collector.js +5 -2
  396. package/dist/metrics/usage_collector.js.map +1 -1
  397. package/dist/metrics/utils.cjs +23 -7
  398. package/dist/metrics/utils.cjs.map +1 -1
  399. package/dist/metrics/utils.d.ts.map +1 -1
  400. package/dist/metrics/utils.js +23 -7
  401. package/dist/metrics/utils.js.map +1 -1
  402. package/dist/stream/deferred_stream.cjs +31 -10
  403. package/dist/stream/deferred_stream.cjs.map +1 -1
  404. package/dist/stream/deferred_stream.d.cts +6 -1
  405. package/dist/stream/deferred_stream.d.ts +6 -1
  406. package/dist/stream/deferred_stream.d.ts.map +1 -1
  407. package/dist/stream/deferred_stream.js +31 -10
  408. package/dist/stream/deferred_stream.js.map +1 -1
  409. package/dist/stream/deferred_stream.test.cjs +2 -2
  410. package/dist/stream/deferred_stream.test.cjs.map +1 -1
  411. package/dist/stream/deferred_stream.test.js +2 -2
  412. package/dist/stream/deferred_stream.test.js.map +1 -1
  413. package/dist/stream/index.cjs +3 -0
  414. package/dist/stream/index.cjs.map +1 -1
  415. package/dist/stream/index.d.cts +1 -0
  416. package/dist/stream/index.d.ts +1 -0
  417. package/dist/stream/index.d.ts.map +1 -1
  418. package/dist/stream/index.js +2 -0
  419. package/dist/stream/index.js.map +1 -1
  420. package/dist/stream/multi_input_stream.cjs +139 -0
  421. package/dist/stream/multi_input_stream.cjs.map +1 -0
  422. package/dist/stream/multi_input_stream.d.cts +55 -0
  423. package/dist/stream/multi_input_stream.d.ts +55 -0
  424. package/dist/stream/multi_input_stream.d.ts.map +1 -0
  425. package/dist/stream/multi_input_stream.js +115 -0
  426. package/dist/stream/multi_input_stream.js.map +1 -0
  427. package/dist/stream/multi_input_stream.test.cjs +344 -0
  428. package/dist/stream/multi_input_stream.test.cjs.map +1 -0
  429. package/dist/stream/multi_input_stream.test.js +343 -0
  430. package/dist/stream/multi_input_stream.test.js.map +1 -0
  431. package/dist/stream/stream_channel.cjs +39 -1
  432. package/dist/stream/stream_channel.cjs.map +1 -1
  433. package/dist/stream/stream_channel.d.cts +5 -2
  434. package/dist/stream/stream_channel.d.ts +5 -2
  435. package/dist/stream/stream_channel.d.ts.map +1 -1
  436. package/dist/stream/stream_channel.js +39 -1
  437. package/dist/stream/stream_channel.js.map +1 -1
  438. package/dist/stream/stream_channel.test.cjs +27 -0
  439. package/dist/stream/stream_channel.test.cjs.map +1 -1
  440. package/dist/stream/stream_channel.test.js +27 -0
  441. package/dist/stream/stream_channel.test.js.map +1 -1
  442. package/dist/stt/stream_adapter.cjs +24 -9
  443. package/dist/stt/stream_adapter.cjs.map +1 -1
  444. package/dist/stt/stream_adapter.d.cts +7 -3
  445. package/dist/stt/stream_adapter.d.ts +7 -3
  446. package/dist/stt/stream_adapter.d.ts.map +1 -1
  447. package/dist/stt/stream_adapter.js +24 -9
  448. package/dist/stt/stream_adapter.js.map +1 -1
  449. package/dist/stt/stt.cjs +94 -19
  450. package/dist/stt/stt.cjs.map +1 -1
  451. package/dist/stt/stt.d.cts +68 -5
  452. package/dist/stt/stt.d.ts +68 -5
  453. package/dist/stt/stt.d.ts.map +1 -1
  454. package/dist/stt/stt.js +96 -21
  455. package/dist/stt/stt.js.map +1 -1
  456. package/dist/telemetry/index.cjs +72 -0
  457. package/dist/telemetry/index.cjs.map +1 -0
  458. package/dist/telemetry/index.d.cts +7 -0
  459. package/dist/telemetry/index.d.ts +7 -0
  460. package/dist/telemetry/index.d.ts.map +1 -0
  461. package/dist/telemetry/index.js +37 -0
  462. package/dist/telemetry/index.js.map +1 -0
  463. package/dist/telemetry/logging.cjs +65 -0
  464. package/dist/telemetry/logging.cjs.map +1 -0
  465. package/dist/telemetry/logging.d.cts +21 -0
  466. package/dist/telemetry/logging.d.ts +21 -0
  467. package/dist/telemetry/logging.d.ts.map +1 -0
  468. package/dist/telemetry/logging.js +40 -0
  469. package/dist/telemetry/logging.js.map +1 -0
  470. package/dist/telemetry/otel_http_exporter.cjs +166 -0
  471. package/dist/telemetry/otel_http_exporter.cjs.map +1 -0
  472. package/dist/telemetry/otel_http_exporter.d.cts +63 -0
  473. package/dist/telemetry/otel_http_exporter.d.ts +63 -0
  474. package/dist/telemetry/otel_http_exporter.d.ts.map +1 -0
  475. package/dist/telemetry/otel_http_exporter.js +142 -0
  476. package/dist/telemetry/otel_http_exporter.js.map +1 -0
  477. package/dist/telemetry/pino_otel_transport.cjs +217 -0
  478. package/dist/telemetry/pino_otel_transport.cjs.map +1 -0
  479. package/dist/telemetry/pino_otel_transport.d.cts +58 -0
  480. package/dist/telemetry/pino_otel_transport.d.ts +58 -0
  481. package/dist/telemetry/pino_otel_transport.d.ts.map +1 -0
  482. package/dist/telemetry/pino_otel_transport.js +189 -0
  483. package/dist/telemetry/pino_otel_transport.js.map +1 -0
  484. package/dist/telemetry/trace_types.cjs +233 -0
  485. package/dist/telemetry/trace_types.cjs.map +1 -0
  486. package/dist/telemetry/trace_types.d.cts +74 -0
  487. package/dist/telemetry/trace_types.d.ts +74 -0
  488. package/dist/telemetry/trace_types.d.ts.map +1 -0
  489. package/dist/telemetry/trace_types.js +141 -0
  490. package/dist/telemetry/trace_types.js.map +1 -0
  491. package/dist/telemetry/traces.cjs +484 -0
  492. package/dist/telemetry/traces.cjs.map +1 -0
  493. package/dist/telemetry/traces.d.cts +116 -0
  494. package/dist/telemetry/traces.d.ts +116 -0
  495. package/dist/telemetry/traces.d.ts.map +1 -0
  496. package/dist/telemetry/traces.js +449 -0
  497. package/dist/telemetry/traces.js.map +1 -0
  498. package/dist/telemetry/utils.cjs +86 -0
  499. package/dist/telemetry/utils.cjs.map +1 -0
  500. package/dist/telemetry/utils.d.cts +5 -0
  501. package/dist/telemetry/utils.d.ts +5 -0
  502. package/dist/telemetry/utils.d.ts.map +1 -0
  503. package/dist/telemetry/utils.js +51 -0
  504. package/dist/telemetry/utils.js.map +1 -0
  505. package/dist/tokenize/basic/sentence.cjs +3 -3
  506. package/dist/tokenize/basic/sentence.cjs.map +1 -1
  507. package/dist/tokenize/basic/sentence.js +3 -3
  508. package/dist/tokenize/basic/sentence.js.map +1 -1
  509. package/dist/tokenize/tokenizer.test.cjs +3 -1
  510. package/dist/tokenize/tokenizer.test.cjs.map +1 -1
  511. package/dist/tokenize/tokenizer.test.js +3 -1
  512. package/dist/tokenize/tokenizer.test.js.map +1 -1
  513. package/dist/transcription.cjs.map +1 -1
  514. package/dist/transcription.d.cts +6 -0
  515. package/dist/transcription.d.ts +6 -0
  516. package/dist/transcription.d.ts.map +1 -1
  517. package/dist/transcription.js.map +1 -1
  518. package/dist/tts/fallback_adapter.cjs +472 -0
  519. package/dist/tts/fallback_adapter.cjs.map +1 -0
  520. package/dist/tts/fallback_adapter.d.cts +110 -0
  521. package/dist/tts/fallback_adapter.d.ts +110 -0
  522. package/dist/tts/fallback_adapter.d.ts.map +1 -0
  523. package/dist/tts/fallback_adapter.js +448 -0
  524. package/dist/tts/fallback_adapter.js.map +1 -0
  525. package/dist/tts/index.cjs +3 -0
  526. package/dist/tts/index.cjs.map +1 -1
  527. package/dist/tts/index.d.cts +1 -0
  528. package/dist/tts/index.d.ts +1 -0
  529. package/dist/tts/index.d.ts.map +1 -1
  530. package/dist/tts/index.js +2 -0
  531. package/dist/tts/index.js.map +1 -1
  532. package/dist/tts/stream_adapter.cjs +25 -8
  533. package/dist/tts/stream_adapter.cjs.map +1 -1
  534. package/dist/tts/stream_adapter.d.cts +6 -3
  535. package/dist/tts/stream_adapter.d.ts +6 -3
  536. package/dist/tts/stream_adapter.d.ts.map +1 -1
  537. package/dist/tts/stream_adapter.js +25 -8
  538. package/dist/tts/stream_adapter.js.map +1 -1
  539. package/dist/tts/tts.cjs +189 -57
  540. package/dist/tts/tts.cjs.map +1 -1
  541. package/dist/tts/tts.d.cts +58 -6
  542. package/dist/tts/tts.d.ts +58 -6
  543. package/dist/tts/tts.d.ts.map +1 -1
  544. package/dist/tts/tts.js +191 -59
  545. package/dist/tts/tts.js.map +1 -1
  546. package/dist/typed_promise.cjs +48 -0
  547. package/dist/typed_promise.cjs.map +1 -0
  548. package/dist/typed_promise.d.cts +24 -0
  549. package/dist/typed_promise.d.ts +24 -0
  550. package/dist/typed_promise.d.ts.map +1 -0
  551. package/dist/typed_promise.js +28 -0
  552. package/dist/typed_promise.js.map +1 -0
  553. package/dist/types.cjs +24 -32
  554. package/dist/types.cjs.map +1 -1
  555. package/dist/types.d.cts +45 -10
  556. package/dist/types.d.ts +45 -10
  557. package/dist/types.d.ts.map +1 -1
  558. package/dist/types.js +20 -30
  559. package/dist/types.js.map +1 -1
  560. package/dist/utils.cjs +124 -28
  561. package/dist/utils.cjs.map +1 -1
  562. package/dist/utils.d.cts +41 -1
  563. package/dist/utils.d.ts +41 -1
  564. package/dist/utils.d.ts.map +1 -1
  565. package/dist/utils.js +119 -27
  566. package/dist/utils.js.map +1 -1
  567. package/dist/utils.test.cjs +73 -1
  568. package/dist/utils.test.cjs.map +1 -1
  569. package/dist/utils.test.js +74 -10
  570. package/dist/utils.test.js.map +1 -1
  571. package/dist/vad.cjs +35 -15
  572. package/dist/vad.cjs.map +1 -1
  573. package/dist/vad.d.cts +15 -5
  574. package/dist/vad.d.ts +15 -5
  575. package/dist/vad.d.ts.map +1 -1
  576. package/dist/vad.js +35 -15
  577. package/dist/vad.js.map +1 -1
  578. package/dist/version.cjs +1 -1
  579. package/dist/version.cjs.map +1 -1
  580. package/dist/version.d.cts +1 -1
  581. package/dist/version.d.ts +1 -1
  582. package/dist/version.d.ts.map +1 -1
  583. package/dist/version.js +1 -1
  584. package/dist/version.js.map +1 -1
  585. package/dist/voice/agent.cjs +258 -35
  586. package/dist/voice/agent.cjs.map +1 -1
  587. package/dist/voice/agent.d.cts +54 -13
  588. package/dist/voice/agent.d.ts +54 -13
  589. package/dist/voice/agent.d.ts.map +1 -1
  590. package/dist/voice/agent.js +254 -34
  591. package/dist/voice/agent.js.map +1 -1
  592. package/dist/voice/agent.test.cjs +314 -0
  593. package/dist/voice/agent.test.cjs.map +1 -1
  594. package/dist/voice/agent.test.js +316 -2
  595. package/dist/voice/agent.test.js.map +1 -1
  596. package/dist/voice/agent_activity.cjs +1116 -385
  597. package/dist/voice/agent_activity.cjs.map +1 -1
  598. package/dist/voice/agent_activity.d.cts +72 -11
  599. package/dist/voice/agent_activity.d.ts +72 -11
  600. package/dist/voice/agent_activity.d.ts.map +1 -1
  601. package/dist/voice/agent_activity.js +1119 -383
  602. package/dist/voice/agent_activity.js.map +1 -1
  603. package/dist/voice/agent_activity.test.cjs +135 -0
  604. package/dist/voice/agent_activity.test.cjs.map +1 -0
  605. package/dist/voice/agent_activity.test.js +134 -0
  606. package/dist/voice/agent_activity.test.js.map +1 -0
  607. package/dist/voice/agent_session.cjs +550 -90
  608. package/dist/voice/agent_session.cjs.map +1 -1
  609. package/dist/voice/agent_session.d.cts +185 -25
  610. package/dist/voice/agent_session.d.ts +185 -25
  611. package/dist/voice/agent_session.d.ts.map +1 -1
  612. package/dist/voice/agent_session.js +556 -91
  613. package/dist/voice/agent_session.js.map +1 -1
  614. package/dist/voice/audio_recognition.cjs +605 -46
  615. package/dist/voice/audio_recognition.cjs.map +1 -1
  616. package/dist/voice/audio_recognition.d.cts +96 -4
  617. package/dist/voice/audio_recognition.d.ts +96 -4
  618. package/dist/voice/audio_recognition.d.ts.map +1 -1
  619. package/dist/voice/audio_recognition.js +611 -47
  620. package/dist/voice/audio_recognition.js.map +1 -1
  621. package/dist/voice/audio_recognition_span.test.cjs +295 -0
  622. package/dist/voice/audio_recognition_span.test.cjs.map +1 -0
  623. package/dist/voice/audio_recognition_span.test.js +299 -0
  624. package/dist/voice/audio_recognition_span.test.js.map +1 -0
  625. package/dist/voice/avatar/datastream_io.cjs +7 -1
  626. package/dist/voice/avatar/datastream_io.cjs.map +1 -1
  627. package/dist/voice/avatar/datastream_io.d.cts +1 -0
  628. package/dist/voice/avatar/datastream_io.d.ts +1 -0
  629. package/dist/voice/avatar/datastream_io.d.ts.map +1 -1
  630. package/dist/voice/avatar/datastream_io.js +7 -1
  631. package/dist/voice/avatar/datastream_io.js.map +1 -1
  632. package/dist/voice/background_audio.cjs +367 -0
  633. package/dist/voice/background_audio.cjs.map +1 -0
  634. package/dist/voice/background_audio.d.cts +123 -0
  635. package/dist/voice/background_audio.d.ts +123 -0
  636. package/dist/voice/background_audio.d.ts.map +1 -0
  637. package/dist/voice/background_audio.js +343 -0
  638. package/dist/voice/background_audio.js.map +1 -0
  639. package/dist/voice/events.cjs +3 -0
  640. package/dist/voice/events.cjs.map +1 -1
  641. package/dist/voice/events.d.cts +16 -9
  642. package/dist/voice/events.d.ts +16 -9
  643. package/dist/voice/events.d.ts.map +1 -1
  644. package/dist/voice/events.js +3 -0
  645. package/dist/voice/events.js.map +1 -1
  646. package/dist/voice/generation.cjs +205 -41
  647. package/dist/voice/generation.cjs.map +1 -1
  648. package/dist/voice/generation.d.cts +21 -5
  649. package/dist/voice/generation.d.ts +21 -5
  650. package/dist/voice/generation.d.ts.map +1 -1
  651. package/dist/voice/generation.js +215 -43
  652. package/dist/voice/generation.js.map +1 -1
  653. package/dist/voice/generation_tools.test.cjs +236 -0
  654. package/dist/voice/generation_tools.test.cjs.map +1 -0
  655. package/dist/voice/generation_tools.test.js +235 -0
  656. package/dist/voice/generation_tools.test.js.map +1 -0
  657. package/dist/voice/index.cjs +33 -2
  658. package/dist/voice/index.cjs.map +1 -1
  659. package/dist/voice/index.d.cts +8 -2
  660. package/dist/voice/index.d.ts +8 -2
  661. package/dist/voice/index.d.ts.map +1 -1
  662. package/dist/voice/index.js +19 -2
  663. package/dist/voice/index.js.map +1 -1
  664. package/dist/voice/interruption_detection.test.cjs +114 -0
  665. package/dist/voice/interruption_detection.test.cjs.map +1 -0
  666. package/dist/voice/interruption_detection.test.js +113 -0
  667. package/dist/voice/interruption_detection.test.js.map +1 -0
  668. package/dist/voice/io.cjs +66 -6
  669. package/dist/voice/io.cjs.map +1 -1
  670. package/dist/voice/io.d.cts +67 -7
  671. package/dist/voice/io.d.ts +67 -7
  672. package/dist/voice/io.d.ts.map +1 -1
  673. package/dist/voice/io.js +62 -5
  674. package/dist/voice/io.js.map +1 -1
  675. package/dist/voice/recorder_io/index.cjs +23 -0
  676. package/dist/voice/recorder_io/index.cjs.map +1 -0
  677. package/dist/voice/recorder_io/index.d.cts +2 -0
  678. package/dist/voice/recorder_io/index.d.ts +2 -0
  679. package/dist/voice/recorder_io/index.d.ts.map +1 -0
  680. package/dist/voice/recorder_io/index.js +2 -0
  681. package/dist/voice/recorder_io/index.js.map +1 -0
  682. package/dist/voice/recorder_io/recorder_io.cjs +607 -0
  683. package/dist/voice/recorder_io/recorder_io.cjs.map +1 -0
  684. package/dist/voice/recorder_io/recorder_io.d.cts +106 -0
  685. package/dist/voice/recorder_io/recorder_io.d.ts +106 -0
  686. package/dist/voice/recorder_io/recorder_io.d.ts.map +1 -0
  687. package/dist/voice/recorder_io/recorder_io.js +573 -0
  688. package/dist/voice/recorder_io/recorder_io.js.map +1 -0
  689. package/dist/voice/remote_session.cjs +922 -0
  690. package/dist/voice/remote_session.cjs.map +1 -0
  691. package/dist/voice/remote_session.d.cts +108 -0
  692. package/dist/voice/remote_session.d.ts +108 -0
  693. package/dist/voice/remote_session.d.ts.map +1 -0
  694. package/dist/voice/remote_session.js +887 -0
  695. package/dist/voice/remote_session.js.map +1 -0
  696. package/dist/voice/report.cjs +88 -0
  697. package/dist/voice/report.cjs.map +1 -0
  698. package/dist/voice/report.d.cts +49 -0
  699. package/dist/voice/report.d.ts +49 -0
  700. package/dist/voice/report.d.ts.map +1 -0
  701. package/dist/voice/report.js +63 -0
  702. package/dist/voice/report.js.map +1 -0
  703. package/dist/voice/report.test.cjs +121 -0
  704. package/dist/voice/report.test.cjs.map +1 -0
  705. package/dist/voice/report.test.js +120 -0
  706. package/dist/voice/report.test.js.map +1 -0
  707. package/dist/voice/room_io/_input.cjs +40 -7
  708. package/dist/voice/room_io/_input.cjs.map +1 -1
  709. package/dist/voice/room_io/_input.d.cts +5 -2
  710. package/dist/voice/room_io/_input.d.ts +5 -2
  711. package/dist/voice/room_io/_input.d.ts.map +1 -1
  712. package/dist/voice/room_io/_input.js +41 -8
  713. package/dist/voice/room_io/_input.js.map +1 -1
  714. package/dist/voice/room_io/_output.cjs +19 -11
  715. package/dist/voice/room_io/_output.cjs.map +1 -1
  716. package/dist/voice/room_io/_output.d.cts +7 -4
  717. package/dist/voice/room_io/_output.d.ts +7 -4
  718. package/dist/voice/room_io/_output.d.ts.map +1 -1
  719. package/dist/voice/room_io/_output.js +20 -12
  720. package/dist/voice/room_io/_output.js.map +1 -1
  721. package/dist/voice/room_io/room_io.cjs +33 -6
  722. package/dist/voice/room_io/room_io.cjs.map +1 -1
  723. package/dist/voice/room_io/room_io.d.cts +29 -9
  724. package/dist/voice/room_io/room_io.d.ts +29 -9
  725. package/dist/voice/room_io/room_io.d.ts.map +1 -1
  726. package/dist/voice/room_io/room_io.js +33 -7
  727. package/dist/voice/room_io/room_io.js.map +1 -1
  728. package/dist/voice/speech_handle.cjs +22 -4
  729. package/dist/voice/speech_handle.cjs.map +1 -1
  730. package/dist/voice/speech_handle.d.cts +17 -2
  731. package/dist/voice/speech_handle.d.ts +17 -2
  732. package/dist/voice/speech_handle.d.ts.map +1 -1
  733. package/dist/voice/speech_handle.js +21 -4
  734. package/dist/voice/speech_handle.js.map +1 -1
  735. package/dist/voice/testing/fake_llm.cjs +127 -0
  736. package/dist/voice/testing/fake_llm.cjs.map +1 -0
  737. package/dist/voice/testing/fake_llm.d.cts +30 -0
  738. package/dist/voice/testing/fake_llm.d.ts +30 -0
  739. package/dist/voice/testing/fake_llm.d.ts.map +1 -0
  740. package/dist/voice/testing/fake_llm.js +103 -0
  741. package/dist/voice/testing/fake_llm.js.map +1 -0
  742. package/dist/voice/testing/index.cjs +57 -0
  743. package/dist/voice/testing/index.cjs.map +1 -0
  744. package/dist/voice/testing/index.d.cts +21 -0
  745. package/dist/voice/testing/index.d.ts +21 -0
  746. package/dist/voice/testing/index.d.ts.map +1 -0
  747. package/dist/voice/testing/index.js +35 -0
  748. package/dist/voice/testing/index.js.map +1 -0
  749. package/dist/voice/testing/run_result.cjs +817 -0
  750. package/dist/voice/testing/run_result.cjs.map +1 -0
  751. package/dist/voice/testing/run_result.d.cts +385 -0
  752. package/dist/voice/testing/run_result.d.ts +385 -0
  753. package/dist/voice/testing/run_result.d.ts.map +1 -0
  754. package/dist/voice/testing/run_result.js +790 -0
  755. package/dist/voice/testing/run_result.js.map +1 -0
  756. package/dist/voice/testing/types.cjs +46 -0
  757. package/dist/voice/testing/types.cjs.map +1 -0
  758. package/dist/voice/testing/types.d.cts +83 -0
  759. package/dist/voice/testing/types.d.ts +83 -0
  760. package/dist/voice/testing/types.d.ts.map +1 -0
  761. package/dist/voice/testing/types.js +19 -0
  762. package/dist/voice/testing/types.js.map +1 -0
  763. package/dist/voice/transcription/synchronizer.cjs +139 -15
  764. package/dist/voice/transcription/synchronizer.cjs.map +1 -1
  765. package/dist/voice/transcription/synchronizer.d.cts +35 -4
  766. package/dist/voice/transcription/synchronizer.d.ts +35 -4
  767. package/dist/voice/transcription/synchronizer.d.ts.map +1 -1
  768. package/dist/voice/transcription/synchronizer.js +143 -16
  769. package/dist/voice/transcription/synchronizer.js.map +1 -1
  770. package/dist/voice/transcription/synchronizer.test.cjs +151 -0
  771. package/dist/voice/transcription/synchronizer.test.cjs.map +1 -0
  772. package/dist/voice/transcription/synchronizer.test.js +150 -0
  773. package/dist/voice/transcription/synchronizer.test.js.map +1 -0
  774. package/dist/voice/turn_config/endpointing.cjs +33 -0
  775. package/dist/voice/turn_config/endpointing.cjs.map +1 -0
  776. package/dist/voice/turn_config/endpointing.d.cts +30 -0
  777. package/dist/voice/turn_config/endpointing.d.ts +30 -0
  778. package/dist/voice/turn_config/endpointing.d.ts.map +1 -0
  779. package/dist/voice/turn_config/endpointing.js +9 -0
  780. package/dist/voice/turn_config/endpointing.js.map +1 -0
  781. package/dist/voice/turn_config/interruption.cjs +37 -0
  782. package/dist/voice/turn_config/interruption.cjs.map +1 -0
  783. package/dist/voice/turn_config/interruption.d.cts +53 -0
  784. package/dist/voice/turn_config/interruption.d.ts +53 -0
  785. package/dist/voice/turn_config/interruption.d.ts.map +1 -0
  786. package/dist/voice/turn_config/interruption.js +13 -0
  787. package/dist/voice/turn_config/interruption.js.map +1 -0
  788. package/dist/voice/turn_config/turn_handling.cjs +35 -0
  789. package/dist/voice/turn_config/turn_handling.cjs.map +1 -0
  790. package/dist/voice/turn_config/turn_handling.d.cts +36 -0
  791. package/dist/voice/turn_config/turn_handling.d.ts +36 -0
  792. package/dist/voice/turn_config/turn_handling.d.ts.map +1 -0
  793. package/dist/voice/turn_config/turn_handling.js +11 -0
  794. package/dist/voice/turn_config/turn_handling.js.map +1 -0
  795. package/dist/voice/turn_config/utils.cjs +157 -0
  796. package/dist/voice/turn_config/utils.cjs.map +1 -0
  797. package/dist/voice/turn_config/utils.d.cts +37 -0
  798. package/dist/voice/turn_config/utils.d.ts +37 -0
  799. package/dist/voice/turn_config/utils.d.ts.map +1 -0
  800. package/dist/voice/turn_config/utils.js +131 -0
  801. package/dist/voice/turn_config/utils.js.map +1 -0
  802. package/dist/voice/turn_config/utils.test.cjs +128 -0
  803. package/dist/voice/turn_config/utils.test.cjs.map +1 -0
  804. package/dist/voice/turn_config/utils.test.js +127 -0
  805. package/dist/voice/turn_config/utils.test.js.map +1 -0
  806. package/dist/voice/utils.cjs +47 -0
  807. package/dist/voice/utils.cjs.map +1 -0
  808. package/dist/voice/utils.d.cts +4 -0
  809. package/dist/voice/utils.d.ts +4 -0
  810. package/dist/voice/utils.d.ts.map +1 -0
  811. package/dist/voice/utils.js +23 -0
  812. package/dist/voice/utils.js.map +1 -0
  813. package/dist/worker.cjs +44 -52
  814. package/dist/worker.cjs.map +1 -1
  815. package/dist/worker.d.cts +18 -8
  816. package/dist/worker.d.ts +18 -8
  817. package/dist/worker.d.ts.map +1 -1
  818. package/dist/worker.js +43 -43
  819. package/dist/worker.js.map +1 -1
  820. package/package.json +35 -13
  821. package/resources/NOTICE +2 -0
  822. package/resources/keyboard-typing.ogg +0 -0
  823. package/resources/keyboard-typing2.ogg +0 -0
  824. package/resources/office-ambience.ogg +0 -0
  825. package/src/_exceptions.ts +5 -0
  826. package/src/audio.ts +132 -1
  827. package/src/beta/index.ts +9 -0
  828. package/src/beta/workflows/index.ts +9 -0
  829. package/src/beta/workflows/task_group.ts +203 -0
  830. package/src/cli.ts +57 -66
  831. package/src/connection_pool.test.ts +346 -0
  832. package/src/connection_pool.ts +307 -0
  833. package/src/constants.ts +14 -0
  834. package/src/cpu.test.ts +239 -0
  835. package/src/cpu.ts +173 -0
  836. package/src/http_server.ts +18 -6
  837. package/src/index.ts +15 -13
  838. package/src/inference/api_protos.ts +85 -2
  839. package/src/inference/index.ts +32 -4
  840. package/src/inference/interruption/defaults.ts +51 -0
  841. package/src/inference/interruption/errors.ts +25 -0
  842. package/src/inference/interruption/http_transport.ts +207 -0
  843. package/src/inference/interruption/interruption_cache_entry.ts +50 -0
  844. package/src/inference/interruption/interruption_detector.ts +204 -0
  845. package/src/inference/interruption/interruption_stream.ts +467 -0
  846. package/src/inference/interruption/types.ts +84 -0
  847. package/src/inference/interruption/utils.test.ts +132 -0
  848. package/src/inference/interruption/utils.ts +137 -0
  849. package/src/inference/interruption/ws_transport.ts +416 -0
  850. package/src/inference/llm.ts +214 -163
  851. package/src/inference/stt.test.ts +253 -0
  852. package/src/inference/stt.ts +449 -208
  853. package/src/inference/tts.test.ts +354 -0
  854. package/src/inference/tts.ts +417 -115
  855. package/src/inference/utils.ts +30 -2
  856. package/src/ipc/inference_proc_executor.ts +11 -3
  857. package/src/ipc/inference_proc_lazy_main.ts +13 -1
  858. package/src/ipc/job_proc_executor.ts +11 -1
  859. package/src/ipc/job_proc_lazy_main.ts +86 -20
  860. package/src/ipc/supervised_proc.test.ts +153 -0
  861. package/src/ipc/supervised_proc.ts +39 -10
  862. package/src/job.ts +120 -1
  863. package/src/language.test.ts +62 -0
  864. package/src/language.ts +380 -0
  865. package/src/llm/__snapshots__/zod-utils.test.ts.snap +559 -0
  866. package/src/llm/chat_context.test.ts +787 -0
  867. package/src/llm/chat_context.ts +493 -2
  868. package/src/llm/fallback_adapter.test.ts +238 -0
  869. package/src/llm/fallback_adapter.ts +394 -0
  870. package/src/llm/index.ts +13 -0
  871. package/src/llm/llm.ts +77 -12
  872. package/src/llm/provider_format/google.test.ts +72 -1
  873. package/src/llm/provider_format/google.ts +10 -6
  874. package/src/llm/provider_format/index.ts +7 -2
  875. package/src/llm/provider_format/openai.test.ts +480 -2
  876. package/src/llm/provider_format/openai.ts +152 -21
  877. package/src/llm/provider_format/utils.ts +11 -5
  878. package/src/llm/realtime.ts +23 -2
  879. package/src/llm/remote_chat_context.ts +2 -2
  880. package/src/llm/tool_context.test.ts +210 -1
  881. package/src/llm/tool_context.ts +115 -17
  882. package/src/llm/utils.test.ts +103 -2
  883. package/src/llm/utils.ts +152 -16
  884. package/src/llm/zod-utils.test.ts +577 -0
  885. package/src/llm/zod-utils.ts +153 -0
  886. package/src/log.ts +71 -19
  887. package/src/metrics/base.ts +78 -19
  888. package/src/metrics/index.ts +12 -0
  889. package/src/metrics/model_usage.test.ts +545 -0
  890. package/src/metrics/model_usage.ts +262 -0
  891. package/src/metrics/usage_collector.ts +14 -3
  892. package/src/metrics/utils.ts +27 -7
  893. package/src/stream/deferred_stream.test.ts +3 -3
  894. package/src/stream/deferred_stream.ts +43 -11
  895. package/src/stream/index.ts +1 -0
  896. package/src/stream/multi_input_stream.test.ts +545 -0
  897. package/src/stream/multi_input_stream.ts +172 -0
  898. package/src/stream/stream_channel.test.ts +37 -0
  899. package/src/stream/stream_channel.ts +43 -3
  900. package/src/stt/stream_adapter.ts +30 -9
  901. package/src/stt/stt.ts +140 -23
  902. package/src/telemetry/index.ts +28 -0
  903. package/src/telemetry/logging.ts +55 -0
  904. package/src/telemetry/otel_http_exporter.ts +218 -0
  905. package/src/telemetry/pino_otel_transport.ts +265 -0
  906. package/src/telemetry/trace_types.ts +109 -0
  907. package/src/telemetry/traces.ts +673 -0
  908. package/src/telemetry/utils.ts +61 -0
  909. package/src/tokenize/basic/sentence.ts +3 -3
  910. package/src/tokenize/tokenizer.test.ts +4 -0
  911. package/src/transcription.ts +6 -0
  912. package/src/tts/fallback_adapter.ts +586 -0
  913. package/src/tts/index.ts +1 -0
  914. package/src/tts/stream_adapter.ts +38 -8
  915. package/src/tts/tts.ts +245 -62
  916. package/src/typed_promise.ts +67 -0
  917. package/src/types.ts +62 -33
  918. package/src/utils.test.ts +90 -10
  919. package/src/utils.ts +178 -33
  920. package/src/vad.ts +42 -18
  921. package/src/version.ts +1 -1
  922. package/src/voice/agent.test.ts +347 -2
  923. package/src/voice/agent.ts +346 -44
  924. package/src/voice/agent_activity.test.ts +194 -0
  925. package/src/voice/agent_activity.ts +1457 -388
  926. package/src/voice/agent_session.ts +817 -112
  927. package/src/voice/audio_recognition.ts +845 -70
  928. package/src/voice/audio_recognition_span.test.ts +341 -0
  929. package/src/voice/avatar/datastream_io.ts +9 -1
  930. package/src/voice/background_audio.ts +494 -0
  931. package/src/voice/events.ts +27 -7
  932. package/src/voice/generation.ts +310 -56
  933. package/src/voice/generation_tools.test.ts +268 -0
  934. package/src/voice/index.ts +17 -3
  935. package/src/voice/interruption_detection.test.ts +151 -0
  936. package/src/voice/io.ts +115 -12
  937. package/src/voice/recorder_io/index.ts +4 -0
  938. package/src/voice/recorder_io/recorder_io.ts +783 -0
  939. package/src/voice/remote_session.ts +1083 -0
  940. package/src/voice/report.test.ts +136 -0
  941. package/src/voice/report.ts +140 -0
  942. package/src/voice/room_io/_input.ts +45 -10
  943. package/src/voice/room_io/_output.ts +26 -14
  944. package/src/voice/room_io/room_io.ts +67 -22
  945. package/src/voice/speech_handle.ts +38 -6
  946. package/src/voice/testing/fake_llm.ts +138 -0
  947. package/src/voice/testing/index.ts +52 -0
  948. package/src/voice/testing/run_result.ts +995 -0
  949. package/src/voice/testing/types.ts +118 -0
  950. package/src/voice/transcription/synchronizer.test.ts +206 -0
  951. package/src/voice/transcription/synchronizer.ts +204 -19
  952. package/src/voice/turn_config/endpointing.ts +33 -0
  953. package/src/voice/turn_config/interruption.ts +56 -0
  954. package/src/voice/turn_config/turn_handling.ts +45 -0
  955. package/src/voice/turn_config/utils.test.ts +148 -0
  956. package/src/voice/turn_config/utils.ts +167 -0
  957. package/src/voice/utils.ts +29 -0
  958. package/src/worker.ts +92 -78
  959. package/src/llm/__snapshots__/utils.test.ts.snap +0 -65
@@ -0,0 +1,476 @@
1
+ import { beforeEach, describe, expect, it } from "vitest";
2
+ import {
3
+ ModelUsageCollector,
4
+ filterZeroValues
5
+ } from "./model_usage.js";
6
+ describe("model_usage", () => {
7
+ describe("filterZeroValues", () => {
8
+ it("should filter out zero values from LLMModelUsage", () => {
9
+ const usage = {
10
+ type: "llm_usage",
11
+ provider: "openai",
12
+ model: "gpt-4o",
13
+ inputTokens: 100,
14
+ inputCachedTokens: 0,
15
+ inputAudioTokens: 0,
16
+ inputCachedAudioTokens: 0,
17
+ inputTextTokens: 0,
18
+ inputCachedTextTokens: 0,
19
+ inputImageTokens: 0,
20
+ inputCachedImageTokens: 0,
21
+ outputTokens: 50,
22
+ outputAudioTokens: 0,
23
+ outputTextTokens: 0,
24
+ sessionDurationMs: 0
25
+ };
26
+ const filtered = filterZeroValues(usage);
27
+ expect(filtered.type).toBe("llm_usage");
28
+ expect(filtered.provider).toBe("openai");
29
+ expect(filtered.model).toBe("gpt-4o");
30
+ expect(filtered.inputTokens).toBe(100);
31
+ expect(filtered.outputTokens).toBe(50);
32
+ expect(filtered.inputCachedTokens).toBeUndefined();
33
+ expect(filtered.inputAudioTokens).toBeUndefined();
34
+ expect(filtered.sessionDurationMs).toBeUndefined();
35
+ });
36
+ it("should filter out zero values from TTSModelUsage", () => {
37
+ const usage = {
38
+ type: "tts_usage",
39
+ provider: "elevenlabs",
40
+ model: "eleven_turbo_v2",
41
+ inputTokens: 0,
42
+ outputTokens: 0,
43
+ charactersCount: 500,
44
+ audioDurationMs: 3e3
45
+ };
46
+ const filtered = filterZeroValues(usage);
47
+ expect(filtered.type).toBe("tts_usage");
48
+ expect(filtered.provider).toBe("elevenlabs");
49
+ expect(filtered.charactersCount).toBe(500);
50
+ expect(filtered.audioDurationMs).toBe(3e3);
51
+ expect(filtered.inputTokens).toBeUndefined();
52
+ expect(filtered.outputTokens).toBeUndefined();
53
+ });
54
+ it("should keep all values when none are zero", () => {
55
+ const usage = {
56
+ type: "stt_usage",
57
+ provider: "deepgram",
58
+ model: "nova-2",
59
+ inputTokens: 10,
60
+ outputTokens: 20,
61
+ audioDurationMs: 5e3
62
+ };
63
+ const filtered = filterZeroValues(usage);
64
+ expect(Object.keys(filtered)).toHaveLength(6);
65
+ expect(filtered).toEqual(usage);
66
+ });
67
+ });
68
+ describe("ModelUsageCollector", () => {
69
+ let collector;
70
+ beforeEach(() => {
71
+ collector = new ModelUsageCollector();
72
+ });
73
+ describe("collect LLM metrics", () => {
74
+ it("should aggregate LLM metrics by provider and model", () => {
75
+ const metrics1 = {
76
+ type: "llm_metrics",
77
+ label: "test",
78
+ requestId: "req1",
79
+ timestamp: Date.now(),
80
+ durationMs: 100,
81
+ ttftMs: 50,
82
+ cancelled: false,
83
+ completionTokens: 100,
84
+ promptTokens: 200,
85
+ promptCachedTokens: 50,
86
+ totalTokens: 300,
87
+ tokensPerSecond: 10,
88
+ metadata: {
89
+ modelProvider: "openai",
90
+ modelName: "gpt-4o"
91
+ }
92
+ };
93
+ const metrics2 = {
94
+ type: "llm_metrics",
95
+ label: "test",
96
+ requestId: "req2",
97
+ timestamp: Date.now(),
98
+ durationMs: 150,
99
+ ttftMs: 60,
100
+ cancelled: false,
101
+ completionTokens: 150,
102
+ promptTokens: 300,
103
+ promptCachedTokens: 75,
104
+ totalTokens: 450,
105
+ tokensPerSecond: 12,
106
+ metadata: {
107
+ modelProvider: "openai",
108
+ modelName: "gpt-4o"
109
+ }
110
+ };
111
+ collector.collect(metrics1);
112
+ collector.collect(metrics2);
113
+ const usage = collector.flatten();
114
+ expect(usage).toHaveLength(1);
115
+ const llmUsage = usage[0];
116
+ expect(llmUsage.type).toBe("llm_usage");
117
+ expect(llmUsage.provider).toBe("openai");
118
+ expect(llmUsage.model).toBe("gpt-4o");
119
+ expect(llmUsage.inputTokens).toBe(500);
120
+ expect(llmUsage.inputCachedTokens).toBe(125);
121
+ expect(llmUsage.outputTokens).toBe(250);
122
+ });
123
+ it("should separate metrics by different providers", () => {
124
+ const openaiMetrics = {
125
+ type: "llm_metrics",
126
+ label: "test",
127
+ requestId: "req1",
128
+ timestamp: Date.now(),
129
+ durationMs: 100,
130
+ ttftMs: 50,
131
+ cancelled: false,
132
+ completionTokens: 100,
133
+ promptTokens: 200,
134
+ promptCachedTokens: 0,
135
+ totalTokens: 300,
136
+ tokensPerSecond: 10,
137
+ metadata: {
138
+ modelProvider: "openai",
139
+ modelName: "gpt-4o"
140
+ }
141
+ };
142
+ const anthropicMetrics = {
143
+ type: "llm_metrics",
144
+ label: "test",
145
+ requestId: "req2",
146
+ timestamp: Date.now(),
147
+ durationMs: 120,
148
+ ttftMs: 55,
149
+ cancelled: false,
150
+ completionTokens: 80,
151
+ promptTokens: 150,
152
+ promptCachedTokens: 0,
153
+ totalTokens: 230,
154
+ tokensPerSecond: 8,
155
+ metadata: {
156
+ modelProvider: "anthropic",
157
+ modelName: "claude-3-5-sonnet"
158
+ }
159
+ };
160
+ collector.collect(openaiMetrics);
161
+ collector.collect(anthropicMetrics);
162
+ const usage = collector.flatten();
163
+ expect(usage).toHaveLength(2);
164
+ const openaiUsage = usage.find(
165
+ (u) => u.type === "llm_usage" && u.provider === "openai"
166
+ );
167
+ const anthropicUsage = usage.find(
168
+ (u) => u.type === "llm_usage" && u.provider === "anthropic"
169
+ );
170
+ expect(openaiUsage.inputTokens).toBe(200);
171
+ expect(openaiUsage.outputTokens).toBe(100);
172
+ expect(anthropicUsage.inputTokens).toBe(150);
173
+ expect(anthropicUsage.outputTokens).toBe(80);
174
+ });
175
+ });
176
+ describe("collect TTS metrics", () => {
177
+ it("should aggregate TTS metrics by provider and model", () => {
178
+ const metrics1 = {
179
+ type: "tts_metrics",
180
+ label: "test",
181
+ requestId: "req1",
182
+ timestamp: Date.now(),
183
+ ttfbMs: 100,
184
+ durationMs: 500,
185
+ audioDurationMs: 3e3,
186
+ cancelled: false,
187
+ charactersCount: 100,
188
+ inputTokens: 10,
189
+ outputTokens: 20,
190
+ streamed: true,
191
+ metadata: {
192
+ modelProvider: "elevenlabs",
193
+ modelName: "eleven_turbo_v2"
194
+ }
195
+ };
196
+ const metrics2 = {
197
+ type: "tts_metrics",
198
+ label: "test",
199
+ requestId: "req2",
200
+ timestamp: Date.now(),
201
+ ttfbMs: 120,
202
+ durationMs: 600,
203
+ audioDurationMs: 4e3,
204
+ cancelled: false,
205
+ charactersCount: 200,
206
+ inputTokens: 15,
207
+ outputTokens: 25,
208
+ streamed: true,
209
+ metadata: {
210
+ modelProvider: "elevenlabs",
211
+ modelName: "eleven_turbo_v2"
212
+ }
213
+ };
214
+ collector.collect(metrics1);
215
+ collector.collect(metrics2);
216
+ const usage = collector.flatten();
217
+ expect(usage).toHaveLength(1);
218
+ const ttsUsage = usage[0];
219
+ expect(ttsUsage.type).toBe("tts_usage");
220
+ expect(ttsUsage.provider).toBe("elevenlabs");
221
+ expect(ttsUsage.model).toBe("eleven_turbo_v2");
222
+ expect(ttsUsage.charactersCount).toBe(300);
223
+ expect(ttsUsage.audioDurationMs).toBe(7e3);
224
+ expect(ttsUsage.inputTokens).toBe(25);
225
+ expect(ttsUsage.outputTokens).toBe(45);
226
+ });
227
+ });
228
+ describe("collect STT metrics", () => {
229
+ it("should aggregate STT metrics by provider and model", () => {
230
+ const metrics1 = {
231
+ type: "stt_metrics",
232
+ label: "test",
233
+ requestId: "req1",
234
+ timestamp: Date.now(),
235
+ durationMs: 0,
236
+ audioDurationMs: 5e3,
237
+ inputTokens: 50,
238
+ outputTokens: 100,
239
+ streamed: true,
240
+ metadata: {
241
+ modelProvider: "deepgram",
242
+ modelName: "nova-2"
243
+ }
244
+ };
245
+ const metrics2 = {
246
+ type: "stt_metrics",
247
+ label: "test",
248
+ requestId: "req2",
249
+ timestamp: Date.now(),
250
+ durationMs: 0,
251
+ audioDurationMs: 3e3,
252
+ inputTokens: 30,
253
+ outputTokens: 60,
254
+ streamed: true,
255
+ metadata: {
256
+ modelProvider: "deepgram",
257
+ modelName: "nova-2"
258
+ }
259
+ };
260
+ collector.collect(metrics1);
261
+ collector.collect(metrics2);
262
+ const usage = collector.flatten();
263
+ expect(usage).toHaveLength(1);
264
+ const sttUsage = usage[0];
265
+ expect(sttUsage.type).toBe("stt_usage");
266
+ expect(sttUsage.provider).toBe("deepgram");
267
+ expect(sttUsage.model).toBe("nova-2");
268
+ expect(sttUsage.audioDurationMs).toBe(8e3);
269
+ expect(sttUsage.inputTokens).toBe(80);
270
+ expect(sttUsage.outputTokens).toBe(160);
271
+ });
272
+ });
273
+ describe("collect realtime model metrics", () => {
274
+ it("should aggregate realtime model metrics with detailed token breakdown", () => {
275
+ const metrics = {
276
+ type: "realtime_model_metrics",
277
+ label: "test",
278
+ requestId: "req1",
279
+ timestamp: Date.now(),
280
+ durationMs: 1e3,
281
+ ttftMs: 100,
282
+ cancelled: false,
283
+ inputTokens: 500,
284
+ outputTokens: 300,
285
+ totalTokens: 800,
286
+ tokensPerSecond: 10,
287
+ sessionDurationMs: 5e3,
288
+ inputTokenDetails: {
289
+ audioTokens: 200,
290
+ textTokens: 250,
291
+ imageTokens: 50,
292
+ cachedTokens: 100,
293
+ cachedTokensDetails: {
294
+ audioTokens: 30,
295
+ textTokens: 50,
296
+ imageTokens: 20
297
+ }
298
+ },
299
+ outputTokenDetails: {
300
+ textTokens: 200,
301
+ audioTokens: 100,
302
+ imageTokens: 0
303
+ },
304
+ metadata: {
305
+ modelProvider: "openai",
306
+ modelName: "gpt-4o-realtime"
307
+ }
308
+ };
309
+ collector.collect(metrics);
310
+ const usage = collector.flatten();
311
+ expect(usage).toHaveLength(1);
312
+ const llmUsage = usage[0];
313
+ expect(llmUsage.type).toBe("llm_usage");
314
+ expect(llmUsage.provider).toBe("openai");
315
+ expect(llmUsage.model).toBe("gpt-4o-realtime");
316
+ expect(llmUsage.inputTokens).toBe(500);
317
+ expect(llmUsage.inputCachedTokens).toBe(100);
318
+ expect(llmUsage.inputAudioTokens).toBe(200);
319
+ expect(llmUsage.inputCachedAudioTokens).toBe(30);
320
+ expect(llmUsage.inputTextTokens).toBe(250);
321
+ expect(llmUsage.inputCachedTextTokens).toBe(50);
322
+ expect(llmUsage.inputImageTokens).toBe(50);
323
+ expect(llmUsage.inputCachedImageTokens).toBe(20);
324
+ expect(llmUsage.outputTokens).toBe(300);
325
+ expect(llmUsage.outputTextTokens).toBe(200);
326
+ expect(llmUsage.outputAudioTokens).toBe(100);
327
+ expect(llmUsage.sessionDurationMs).toBe(5e3);
328
+ });
329
+ });
330
+ describe("mixed metrics collection", () => {
331
+ it("should collect and separate LLM, TTS, and STT metrics", () => {
332
+ const llmMetrics = {
333
+ type: "llm_metrics",
334
+ label: "test",
335
+ requestId: "req1",
336
+ timestamp: Date.now(),
337
+ durationMs: 100,
338
+ ttftMs: 50,
339
+ cancelled: false,
340
+ completionTokens: 100,
341
+ promptTokens: 200,
342
+ promptCachedTokens: 0,
343
+ totalTokens: 300,
344
+ tokensPerSecond: 10,
345
+ metadata: {
346
+ modelProvider: "openai",
347
+ modelName: "gpt-4o"
348
+ }
349
+ };
350
+ const ttsMetrics = {
351
+ type: "tts_metrics",
352
+ label: "test",
353
+ requestId: "req2",
354
+ timestamp: Date.now(),
355
+ ttfbMs: 100,
356
+ durationMs: 500,
357
+ audioDurationMs: 3e3,
358
+ cancelled: false,
359
+ charactersCount: 100,
360
+ streamed: true,
361
+ metadata: {
362
+ modelProvider: "elevenlabs",
363
+ modelName: "eleven_turbo_v2"
364
+ }
365
+ };
366
+ const sttMetrics = {
367
+ type: "stt_metrics",
368
+ label: "test",
369
+ requestId: "req3",
370
+ timestamp: Date.now(),
371
+ durationMs: 0,
372
+ audioDurationMs: 5e3,
373
+ streamed: true,
374
+ metadata: {
375
+ modelProvider: "deepgram",
376
+ modelName: "nova-2"
377
+ }
378
+ };
379
+ collector.collect(llmMetrics);
380
+ collector.collect(ttsMetrics);
381
+ collector.collect(sttMetrics);
382
+ const usage = collector.flatten();
383
+ expect(usage).toHaveLength(3);
384
+ const llmUsage = usage.find((u) => u.type === "llm_usage");
385
+ const ttsUsage = usage.find((u) => u.type === "tts_usage");
386
+ const sttUsage = usage.find((u) => u.type === "stt_usage");
387
+ expect(llmUsage).toBeDefined();
388
+ expect(ttsUsage).toBeDefined();
389
+ expect(sttUsage).toBeDefined();
390
+ });
391
+ });
392
+ describe("flatten returns copies", () => {
393
+ it("should return deep copies of usage objects", () => {
394
+ const metrics = {
395
+ type: "llm_metrics",
396
+ label: "test",
397
+ requestId: "req1",
398
+ timestamp: Date.now(),
399
+ durationMs: 100,
400
+ ttftMs: 50,
401
+ cancelled: false,
402
+ completionTokens: 100,
403
+ promptTokens: 200,
404
+ promptCachedTokens: 0,
405
+ totalTokens: 300,
406
+ tokensPerSecond: 10,
407
+ metadata: {
408
+ modelProvider: "openai",
409
+ modelName: "gpt-4o"
410
+ }
411
+ };
412
+ collector.collect(metrics);
413
+ const usage1 = collector.flatten();
414
+ const usage2 = collector.flatten();
415
+ expect(usage1[0]).toEqual(usage2[0]);
416
+ expect(usage1[0]).not.toBe(usage2[0]);
417
+ usage1[0].inputTokens = 9999;
418
+ expect(usage2[0].inputTokens).toBe(200);
419
+ });
420
+ });
421
+ describe("handles missing metadata", () => {
422
+ it("should use empty strings when metadata is missing", () => {
423
+ const metrics = {
424
+ type: "llm_metrics",
425
+ label: "test",
426
+ requestId: "req1",
427
+ timestamp: Date.now(),
428
+ durationMs: 100,
429
+ ttftMs: 50,
430
+ cancelled: false,
431
+ completionTokens: 100,
432
+ promptTokens: 200,
433
+ promptCachedTokens: 0,
434
+ totalTokens: 300,
435
+ tokensPerSecond: 10
436
+ // No metadata
437
+ };
438
+ collector.collect(metrics);
439
+ const usage = collector.flatten();
440
+ expect(usage).toHaveLength(1);
441
+ const llmUsage = usage[0];
442
+ expect(llmUsage.provider).toBe("");
443
+ expect(llmUsage.model).toBe("");
444
+ });
445
+ });
446
+ describe("ignores VAD and EOU metrics", () => {
447
+ it("should not collect VAD metrics", () => {
448
+ const vadMetrics = {
449
+ type: "vad_metrics",
450
+ label: "test",
451
+ timestamp: Date.now(),
452
+ idleTimeMs: 100,
453
+ inferenceDurationTotalMs: 50,
454
+ inferenceCount: 10
455
+ };
456
+ collector.collect(vadMetrics);
457
+ const usage = collector.flatten();
458
+ expect(usage).toHaveLength(0);
459
+ });
460
+ it("should not collect EOU metrics", () => {
461
+ const eouMetrics = {
462
+ type: "eou_metrics",
463
+ timestamp: Date.now(),
464
+ endOfUtteranceDelayMs: 100,
465
+ transcriptionDelayMs: 50,
466
+ onUserTurnCompletedDelayMs: 30,
467
+ lastSpeakingTimeMs: Date.now()
468
+ };
469
+ collector.collect(eouMetrics);
470
+ const usage = collector.flatten();
471
+ expect(usage).toHaveLength(0);
472
+ });
473
+ });
474
+ });
475
+ });
476
+ //# sourceMappingURL=model_usage.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../src/metrics/model_usage.test.ts"],"sourcesContent":["// SPDX-FileCopyrightText: 2024 LiveKit, Inc.\n//\n// SPDX-License-Identifier: Apache-2.0\nimport { beforeEach, describe, expect, it } from 'vitest';\nimport type { LLMMetrics, RealtimeModelMetrics, STTMetrics, TTSMetrics } from './base.js';\nimport {\n type LLMModelUsage,\n ModelUsageCollector,\n type STTModelUsage,\n type TTSModelUsage,\n filterZeroValues,\n} from './model_usage.js';\n\ndescribe('model_usage', () => {\n describe('filterZeroValues', () => {\n it('should filter out zero values from LLMModelUsage', () => {\n const usage: LLMModelUsage = {\n type: 'llm_usage',\n provider: 'openai',\n model: 'gpt-4o',\n inputTokens: 100,\n inputCachedTokens: 0,\n inputAudioTokens: 0,\n inputCachedAudioTokens: 0,\n inputTextTokens: 0,\n inputCachedTextTokens: 0,\n inputImageTokens: 0,\n inputCachedImageTokens: 0,\n outputTokens: 50,\n outputAudioTokens: 0,\n outputTextTokens: 0,\n sessionDurationMs: 0,\n };\n\n const filtered = filterZeroValues(usage);\n\n expect(filtered.type).toBe('llm_usage');\n expect(filtered.provider).toBe('openai');\n expect(filtered.model).toBe('gpt-4o');\n expect(filtered.inputTokens).toBe(100);\n expect(filtered.outputTokens).toBe(50);\n // Zero values should be filtered out\n expect(filtered.inputCachedTokens).toBeUndefined();\n expect(filtered.inputAudioTokens).toBeUndefined();\n expect(filtered.sessionDurationMs).toBeUndefined();\n });\n\n it('should filter out zero values from TTSModelUsage', () => {\n const usage: TTSModelUsage = {\n type: 'tts_usage',\n provider: 'elevenlabs',\n model: 'eleven_turbo_v2',\n inputTokens: 0,\n outputTokens: 0,\n charactersCount: 500,\n audioDurationMs: 3000,\n };\n\n const filtered = filterZeroValues(usage);\n\n expect(filtered.type).toBe('tts_usage');\n expect(filtered.provider).toBe('elevenlabs');\n expect(filtered.charactersCount).toBe(500);\n expect(filtered.audioDurationMs).toBe(3000);\n expect(filtered.inputTokens).toBeUndefined();\n expect(filtered.outputTokens).toBeUndefined();\n });\n\n it('should keep all values when none are zero', () => {\n const usage: STTModelUsage = {\n type: 'stt_usage',\n provider: 'deepgram',\n model: 'nova-2',\n inputTokens: 10,\n outputTokens: 20,\n audioDurationMs: 5000,\n };\n\n const filtered = filterZeroValues(usage);\n\n expect(Object.keys(filtered)).toHaveLength(6);\n expect(filtered).toEqual(usage);\n });\n });\n\n describe('ModelUsageCollector', () => {\n let collector: ModelUsageCollector;\n\n beforeEach(() => {\n collector = new ModelUsageCollector();\n });\n\n describe('collect LLM metrics', () => {\n it('should aggregate LLM metrics by provider and model', () => {\n const metrics1: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 100,\n ttftMs: 50,\n cancelled: false,\n completionTokens: 100,\n promptTokens: 200,\n promptCachedTokens: 50,\n totalTokens: 300,\n tokensPerSecond: 10,\n metadata: {\n modelProvider: 'openai',\n modelName: 'gpt-4o',\n },\n };\n\n const metrics2: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req2',\n timestamp: Date.now(),\n durationMs: 150,\n ttftMs: 60,\n cancelled: false,\n completionTokens: 150,\n promptTokens: 300,\n promptCachedTokens: 75,\n totalTokens: 450,\n tokensPerSecond: 12,\n metadata: {\n modelProvider: 'openai',\n modelName: 'gpt-4o',\n },\n };\n\n collector.collect(metrics1);\n collector.collect(metrics2);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(1);\n\n const llmUsage = usage[0] as LLMModelUsage;\n expect(llmUsage.type).toBe('llm_usage');\n expect(llmUsage.provider).toBe('openai');\n expect(llmUsage.model).toBe('gpt-4o');\n expect(llmUsage.inputTokens).toBe(500); // 200 + 300\n expect(llmUsage.inputCachedTokens).toBe(125); // 50 + 75\n expect(llmUsage.outputTokens).toBe(250); // 100 + 150\n });\n\n it('should separate metrics by different providers', () => {\n const openaiMetrics: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 100,\n ttftMs: 50,\n cancelled: false,\n completionTokens: 100,\n promptTokens: 200,\n promptCachedTokens: 0,\n totalTokens: 300,\n tokensPerSecond: 10,\n metadata: {\n modelProvider: 'openai',\n modelName: 'gpt-4o',\n },\n };\n\n const anthropicMetrics: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req2',\n timestamp: Date.now(),\n durationMs: 120,\n ttftMs: 55,\n cancelled: false,\n completionTokens: 80,\n promptTokens: 150,\n promptCachedTokens: 0,\n totalTokens: 230,\n tokensPerSecond: 8,\n metadata: {\n modelProvider: 'anthropic',\n modelName: 'claude-3-5-sonnet',\n },\n };\n\n collector.collect(openaiMetrics);\n collector.collect(anthropicMetrics);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(2);\n\n const openaiUsage = usage.find(\n (u) => u.type === 'llm_usage' && u.provider === 'openai',\n ) as LLMModelUsage;\n const anthropicUsage = usage.find(\n (u) => u.type === 'llm_usage' && u.provider === 'anthropic',\n ) as LLMModelUsage;\n\n expect(openaiUsage.inputTokens).toBe(200);\n expect(openaiUsage.outputTokens).toBe(100);\n expect(anthropicUsage.inputTokens).toBe(150);\n expect(anthropicUsage.outputTokens).toBe(80);\n });\n });\n\n describe('collect TTS metrics', () => {\n it('should aggregate TTS metrics by provider and model', () => {\n const metrics1: TTSMetrics = {\n type: 'tts_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n ttfbMs: 100,\n durationMs: 500,\n audioDurationMs: 3000,\n cancelled: false,\n charactersCount: 100,\n inputTokens: 10,\n outputTokens: 20,\n streamed: true,\n metadata: {\n modelProvider: 'elevenlabs',\n modelName: 'eleven_turbo_v2',\n },\n };\n\n const metrics2: TTSMetrics = {\n type: 'tts_metrics',\n label: 'test',\n requestId: 'req2',\n timestamp: Date.now(),\n ttfbMs: 120,\n durationMs: 600,\n audioDurationMs: 4000,\n cancelled: false,\n charactersCount: 200,\n inputTokens: 15,\n outputTokens: 25,\n streamed: true,\n metadata: {\n modelProvider: 'elevenlabs',\n modelName: 'eleven_turbo_v2',\n },\n };\n\n collector.collect(metrics1);\n collector.collect(metrics2);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(1);\n\n const ttsUsage = usage[0] as TTSModelUsage;\n expect(ttsUsage.type).toBe('tts_usage');\n expect(ttsUsage.provider).toBe('elevenlabs');\n expect(ttsUsage.model).toBe('eleven_turbo_v2');\n expect(ttsUsage.charactersCount).toBe(300); // 100 + 200\n expect(ttsUsage.audioDurationMs).toBe(7000); // 3000 + 4000\n expect(ttsUsage.inputTokens).toBe(25); // 10 + 15\n expect(ttsUsage.outputTokens).toBe(45); // 20 + 25\n });\n });\n\n describe('collect STT metrics', () => {\n it('should aggregate STT metrics by provider and model', () => {\n const metrics1: STTMetrics = {\n type: 'stt_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 0,\n audioDurationMs: 5000,\n inputTokens: 50,\n outputTokens: 100,\n streamed: true,\n metadata: {\n modelProvider: 'deepgram',\n modelName: 'nova-2',\n },\n };\n\n const metrics2: STTMetrics = {\n type: 'stt_metrics',\n label: 'test',\n requestId: 'req2',\n timestamp: Date.now(),\n durationMs: 0,\n audioDurationMs: 3000,\n inputTokens: 30,\n outputTokens: 60,\n streamed: true,\n metadata: {\n modelProvider: 'deepgram',\n modelName: 'nova-2',\n },\n };\n\n collector.collect(metrics1);\n collector.collect(metrics2);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(1);\n\n const sttUsage = usage[0] as STTModelUsage;\n expect(sttUsage.type).toBe('stt_usage');\n expect(sttUsage.provider).toBe('deepgram');\n expect(sttUsage.model).toBe('nova-2');\n expect(sttUsage.audioDurationMs).toBe(8000); // 5000 + 3000\n expect(sttUsage.inputTokens).toBe(80); // 50 + 30\n expect(sttUsage.outputTokens).toBe(160); // 100 + 60\n });\n });\n\n describe('collect realtime model metrics', () => {\n it('should aggregate realtime model metrics with detailed token breakdown', () => {\n const metrics: RealtimeModelMetrics = {\n type: 'realtime_model_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 1000,\n ttftMs: 100,\n cancelled: false,\n inputTokens: 500,\n outputTokens: 300,\n totalTokens: 800,\n tokensPerSecond: 10,\n sessionDurationMs: 5000,\n inputTokenDetails: {\n audioTokens: 200,\n textTokens: 250,\n imageTokens: 50,\n cachedTokens: 100,\n cachedTokensDetails: {\n audioTokens: 30,\n textTokens: 50,\n imageTokens: 20,\n },\n },\n outputTokenDetails: {\n textTokens: 200,\n audioTokens: 100,\n imageTokens: 0,\n },\n metadata: {\n modelProvider: 'openai',\n modelName: 'gpt-4o-realtime',\n },\n };\n\n collector.collect(metrics);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(1);\n\n const llmUsage = usage[0] as LLMModelUsage;\n expect(llmUsage.type).toBe('llm_usage');\n expect(llmUsage.provider).toBe('openai');\n expect(llmUsage.model).toBe('gpt-4o-realtime');\n expect(llmUsage.inputTokens).toBe(500);\n expect(llmUsage.inputCachedTokens).toBe(100);\n expect(llmUsage.inputAudioTokens).toBe(200);\n expect(llmUsage.inputCachedAudioTokens).toBe(30);\n expect(llmUsage.inputTextTokens).toBe(250);\n expect(llmUsage.inputCachedTextTokens).toBe(50);\n expect(llmUsage.inputImageTokens).toBe(50);\n expect(llmUsage.inputCachedImageTokens).toBe(20);\n expect(llmUsage.outputTokens).toBe(300);\n expect(llmUsage.outputTextTokens).toBe(200);\n expect(llmUsage.outputAudioTokens).toBe(100);\n expect(llmUsage.sessionDurationMs).toBe(5000);\n });\n });\n\n describe('mixed metrics collection', () => {\n it('should collect and separate LLM, TTS, and STT metrics', () => {\n const llmMetrics: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 100,\n ttftMs: 50,\n cancelled: false,\n completionTokens: 100,\n promptTokens: 200,\n promptCachedTokens: 0,\n totalTokens: 300,\n tokensPerSecond: 10,\n metadata: {\n modelProvider: 'openai',\n modelName: 'gpt-4o',\n },\n };\n\n const ttsMetrics: TTSMetrics = {\n type: 'tts_metrics',\n label: 'test',\n requestId: 'req2',\n timestamp: Date.now(),\n ttfbMs: 100,\n durationMs: 500,\n audioDurationMs: 3000,\n cancelled: false,\n charactersCount: 100,\n streamed: true,\n metadata: {\n modelProvider: 'elevenlabs',\n modelName: 'eleven_turbo_v2',\n },\n };\n\n const sttMetrics: STTMetrics = {\n type: 'stt_metrics',\n label: 'test',\n requestId: 'req3',\n timestamp: Date.now(),\n durationMs: 0,\n audioDurationMs: 5000,\n streamed: true,\n metadata: {\n modelProvider: 'deepgram',\n modelName: 'nova-2',\n },\n };\n\n collector.collect(llmMetrics);\n collector.collect(ttsMetrics);\n collector.collect(sttMetrics);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(3);\n\n const llmUsage = usage.find((u) => u.type === 'llm_usage');\n const ttsUsage = usage.find((u) => u.type === 'tts_usage');\n const sttUsage = usage.find((u) => u.type === 'stt_usage');\n\n expect(llmUsage).toBeDefined();\n expect(ttsUsage).toBeDefined();\n expect(sttUsage).toBeDefined();\n });\n });\n\n describe('flatten returns copies', () => {\n it('should return deep copies of usage objects', () => {\n const metrics: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 100,\n ttftMs: 50,\n cancelled: false,\n completionTokens: 100,\n promptTokens: 200,\n promptCachedTokens: 0,\n totalTokens: 300,\n tokensPerSecond: 10,\n metadata: {\n modelProvider: 'openai',\n modelName: 'gpt-4o',\n },\n };\n\n collector.collect(metrics);\n\n const usage1 = collector.flatten();\n const usage2 = collector.flatten();\n\n // Should be equal values\n expect(usage1[0]).toEqual(usage2[0]);\n\n // But not the same object reference\n expect(usage1[0]).not.toBe(usage2[0]);\n\n // Modifying one shouldn't affect the other\n (usage1[0] as LLMModelUsage).inputTokens = 9999;\n expect((usage2[0] as LLMModelUsage).inputTokens).toBe(200);\n });\n });\n\n describe('handles missing metadata', () => {\n it('should use empty strings when metadata is missing', () => {\n const metrics: LLMMetrics = {\n type: 'llm_metrics',\n label: 'test',\n requestId: 'req1',\n timestamp: Date.now(),\n durationMs: 100,\n ttftMs: 50,\n cancelled: false,\n completionTokens: 100,\n promptTokens: 200,\n promptCachedTokens: 0,\n totalTokens: 300,\n tokensPerSecond: 10,\n // No metadata\n };\n\n collector.collect(metrics);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(1);\n\n const llmUsage = usage[0] as LLMModelUsage;\n expect(llmUsage.provider).toBe('');\n expect(llmUsage.model).toBe('');\n });\n });\n\n describe('ignores VAD and EOU metrics', () => {\n it('should not collect VAD metrics', () => {\n const vadMetrics = {\n type: 'vad_metrics' as const,\n label: 'test',\n timestamp: Date.now(),\n idleTimeMs: 100,\n inferenceDurationTotalMs: 50,\n inferenceCount: 10,\n };\n\n collector.collect(vadMetrics);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(0);\n });\n\n it('should not collect EOU metrics', () => {\n const eouMetrics = {\n type: 'eou_metrics' as const,\n timestamp: Date.now(),\n endOfUtteranceDelayMs: 100,\n transcriptionDelayMs: 50,\n onUserTurnCompletedDelayMs: 30,\n lastSpeakingTimeMs: Date.now(),\n };\n\n collector.collect(eouMetrics);\n\n const usage = collector.flatten();\n expect(usage).toHaveLength(0);\n });\n });\n });\n});\n"],"mappings":"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","names":[]}
@@ -21,15 +21,18 @@ __export(usage_collector_exports, {
21
21
  UsageCollector: () => UsageCollector
22
22
  });
23
23
  module.exports = __toCommonJS(usage_collector_exports);
24
+ var import_log = require("../log.cjs");
24
25
  class UsageCollector {
25
26
  summary;
27
+ logger = (0, import_log.log)();
26
28
  constructor() {
29
+ this.logger.warn("UsageCollector is deprecated. Use ModelUsageCollector instead.");
27
30
  this.summary = {
28
31
  llmPromptTokens: 0,
29
32
  llmPromptCachedTokens: 0,
30
33
  llmCompletionTokens: 0,
31
34
  ttsCharactersCount: 0,
32
- sttAudioDuration: 0
35
+ sttAudioDurationMs: 0
33
36
  };
34
37
  }
35
38
  collect(metrics) {
@@ -44,7 +47,7 @@ class UsageCollector {
44
47
  } else if (metrics.type === "tts_metrics") {
45
48
  this.summary.ttsCharactersCount += metrics.charactersCount;
46
49
  } else if (metrics.type === "stt_metrics") {
47
- this.summary.sttAudioDuration += metrics.audioDuration;
50
+ this.summary.sttAudioDurationMs += metrics.audioDurationMs;
48
51
  }
49
52
  }
50
53
  getSummary() {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/metrics/usage_collector.ts"],"sourcesContent":["// SPDX-FileCopyrightText: 2024 LiveKit, Inc.\n//\n// SPDX-License-Identifier: Apache-2.0\nimport type { AgentMetrics } from './base.js';\n\nexport interface UsageSummary {\n llmPromptTokens: number;\n llmPromptCachedTokens: number;\n llmCompletionTokens: number;\n ttsCharactersCount: number;\n sttAudioDuration: number;\n}\n\nexport class UsageCollector {\n private summary: UsageSummary;\n\n constructor() {\n this.summary = {\n llmPromptTokens: 0,\n llmPromptCachedTokens: 0,\n llmCompletionTokens: 0,\n ttsCharactersCount: 0,\n sttAudioDuration: 0,\n };\n }\n\n collect(metrics: AgentMetrics): void {\n if (metrics.type === 'llm_metrics') {\n this.summary.llmPromptTokens += metrics.promptTokens;\n this.summary.llmPromptCachedTokens += metrics.promptCachedTokens;\n this.summary.llmCompletionTokens += metrics.completionTokens;\n } else if (metrics.type === 'realtime_model_metrics') {\n this.summary.llmPromptTokens += metrics.inputTokens;\n this.summary.llmPromptCachedTokens += metrics.inputTokenDetails.cachedTokens;\n this.summary.llmCompletionTokens += metrics.outputTokens;\n } else if (metrics.type === 'tts_metrics') {\n this.summary.ttsCharactersCount += metrics.charactersCount;\n } else if (metrics.type === 'stt_metrics') {\n this.summary.sttAudioDuration += metrics.audioDuration;\n }\n }\n\n getSummary(): UsageSummary {\n return { ...this.summary };\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAaO,MAAM,eAAe;AAAA,EAClB;AAAA,EAER,cAAc;AACZ,SAAK,UAAU;AAAA,MACb,iBAAiB;AAAA,MACjB,uBAAuB;AAAA,MACvB,qBAAqB;AAAA,MACrB,oBAAoB;AAAA,MACpB,kBAAkB;AAAA,IACpB;AAAA,EACF;AAAA,EAEA,QAAQ,SAA6B;AACnC,QAAI,QAAQ,SAAS,eAAe;AAClC,WAAK,QAAQ,mBAAmB,QAAQ;AACxC,WAAK,QAAQ,yBAAyB,QAAQ;AAC9C,WAAK,QAAQ,uBAAuB,QAAQ;AAAA,IAC9C,WAAW,QAAQ,SAAS,0BAA0B;AACpD,WAAK,QAAQ,mBAAmB,QAAQ;AACxC,WAAK,QAAQ,yBAAyB,QAAQ,kBAAkB;AAChE,WAAK,QAAQ,uBAAuB,QAAQ;AAAA,IAC9C,WAAW,QAAQ,SAAS,eAAe;AACzC,WAAK,QAAQ,sBAAsB,QAAQ;AAAA,IAC7C,WAAW,QAAQ,SAAS,eAAe;AACzC,WAAK,QAAQ,oBAAoB,QAAQ;AAAA,IAC3C;AAAA,EACF;AAAA,EAEA,aAA2B;AACzB,WAAO,EAAE,GAAG,KAAK,QAAQ;AAAA,EAC3B;AACF;","names":[]}
1
+ {"version":3,"sources":["../../src/metrics/usage_collector.ts"],"sourcesContent":["// SPDX-FileCopyrightText: 2024 LiveKit, Inc.\n//\n// SPDX-License-Identifier: Apache-2.0\nimport { log } from '../log.js';\nimport type { AgentMetrics } from './base.js';\n\n/**\n * @deprecated Use LLMModelUsage, TTSModelUsage, or STTModelUsage instead.\n * These new types provide per-model/provider usage aggregation for more detailed tracking.\n */\nexport interface UsageSummary {\n llmPromptTokens: number;\n llmPromptCachedTokens: number;\n llmCompletionTokens: number;\n ttsCharactersCount: number;\n sttAudioDurationMs: number;\n}\n\n/**\n * @deprecated Use ModelUsageCollector instead.\n * ModelUsageCollector provides per-model/provider usage aggregation for more detailed tracking.\n */\nexport class UsageCollector {\n private summary: UsageSummary;\n private logger = log();\n\n constructor() {\n this.logger.warn('UsageCollector is deprecated. Use ModelUsageCollector instead.');\n this.summary = {\n llmPromptTokens: 0,\n llmPromptCachedTokens: 0,\n llmCompletionTokens: 0,\n ttsCharactersCount: 0,\n sttAudioDurationMs: 0,\n };\n }\n\n collect(metrics: AgentMetrics): void {\n if (metrics.type === 'llm_metrics') {\n this.summary.llmPromptTokens += metrics.promptTokens;\n this.summary.llmPromptCachedTokens += metrics.promptCachedTokens;\n this.summary.llmCompletionTokens += metrics.completionTokens;\n } else if (metrics.type === 'realtime_model_metrics') {\n this.summary.llmPromptTokens += metrics.inputTokens;\n this.summary.llmPromptCachedTokens += metrics.inputTokenDetails.cachedTokens;\n this.summary.llmCompletionTokens += metrics.outputTokens;\n } else if (metrics.type === 'tts_metrics') {\n this.summary.ttsCharactersCount += metrics.charactersCount;\n } else if (metrics.type === 'stt_metrics') {\n this.summary.sttAudioDurationMs += metrics.audioDurationMs;\n }\n }\n\n getSummary(): UsageSummary {\n return { ...this.summary };\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAGA,iBAAoB;AAmBb,MAAM,eAAe;AAAA,EAClB;AAAA,EACA,aAAS,gBAAI;AAAA,EAErB,cAAc;AACZ,SAAK,OAAO,KAAK,gEAAgE;AACjF,SAAK,UAAU;AAAA,MACb,iBAAiB;AAAA,MACjB,uBAAuB;AAAA,MACvB,qBAAqB;AAAA,MACrB,oBAAoB;AAAA,MACpB,oBAAoB;AAAA,IACtB;AAAA,EACF;AAAA,EAEA,QAAQ,SAA6B;AACnC,QAAI,QAAQ,SAAS,eAAe;AAClC,WAAK,QAAQ,mBAAmB,QAAQ;AACxC,WAAK,QAAQ,yBAAyB,QAAQ;AAC9C,WAAK,QAAQ,uBAAuB,QAAQ;AAAA,IAC9C,WAAW,QAAQ,SAAS,0BAA0B;AACpD,WAAK,QAAQ,mBAAmB,QAAQ;AACxC,WAAK,QAAQ,yBAAyB,QAAQ,kBAAkB;AAChE,WAAK,QAAQ,uBAAuB,QAAQ;AAAA,IAC9C,WAAW,QAAQ,SAAS,eAAe;AACzC,WAAK,QAAQ,sBAAsB,QAAQ;AAAA,IAC7C,WAAW,QAAQ,SAAS,eAAe;AACzC,WAAK,QAAQ,sBAAsB,QAAQ;AAAA,IAC7C;AAAA,EACF;AAAA,EAEA,aAA2B;AACzB,WAAO,EAAE,GAAG,KAAK,QAAQ;AAAA,EAC3B;AACF;","names":[]}
@@ -1,13 +1,22 @@
1
1
  import type { AgentMetrics } from './base.js';
2
+ /**
3
+ * @deprecated Use LLMModelUsage, TTSModelUsage, or STTModelUsage instead.
4
+ * These new types provide per-model/provider usage aggregation for more detailed tracking.
5
+ */
2
6
  export interface UsageSummary {
3
7
  llmPromptTokens: number;
4
8
  llmPromptCachedTokens: number;
5
9
  llmCompletionTokens: number;
6
10
  ttsCharactersCount: number;
7
- sttAudioDuration: number;
11
+ sttAudioDurationMs: number;
8
12
  }
13
+ /**
14
+ * @deprecated Use ModelUsageCollector instead.
15
+ * ModelUsageCollector provides per-model/provider usage aggregation for more detailed tracking.
16
+ */
9
17
  export declare class UsageCollector {
10
18
  private summary;
19
+ private logger;
11
20
  constructor();
12
21
  collect(metrics: AgentMetrics): void;
13
22
  getSummary(): UsageSummary;
@@ -1,13 +1,22 @@
1
1
  import type { AgentMetrics } from './base.js';
2
+ /**
3
+ * @deprecated Use LLMModelUsage, TTSModelUsage, or STTModelUsage instead.
4
+ * These new types provide per-model/provider usage aggregation for more detailed tracking.
5
+ */
2
6
  export interface UsageSummary {
3
7
  llmPromptTokens: number;
4
8
  llmPromptCachedTokens: number;
5
9
  llmCompletionTokens: number;
6
10
  ttsCharactersCount: number;
7
- sttAudioDuration: number;
11
+ sttAudioDurationMs: number;
8
12
  }
13
+ /**
14
+ * @deprecated Use ModelUsageCollector instead.
15
+ * ModelUsageCollector provides per-model/provider usage aggregation for more detailed tracking.
16
+ */
9
17
  export declare class UsageCollector {
10
18
  private summary;
19
+ private logger;
11
20
  constructor();
12
21
  collect(metrics: AgentMetrics): void;
13
22
  getSummary(): UsageSummary;
@@ -1 +1 @@
1
- {"version":3,"file":"usage_collector.d.ts","sourceRoot":"","sources":["../../src/metrics/usage_collector.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAE9C,MAAM,WAAW,YAAY;IAC3B,eAAe,EAAE,MAAM,CAAC;IACxB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAe;;IAY9B,OAAO,CAAC,OAAO,EAAE,YAAY,GAAG,IAAI;IAgBpC,UAAU,IAAI,YAAY;CAG3B"}
1
+ {"version":3,"file":"usage_collector.d.ts","sourceRoot":"","sources":["../../src/metrics/usage_collector.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,WAAW,CAAC;AAE9C;;;GAGG;AACH,MAAM,WAAW,YAAY;IAC3B,eAAe,EAAE,MAAM,CAAC;IACxB,qBAAqB,EAAE,MAAM,CAAC;IAC9B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,kBAAkB,EAAE,MAAM,CAAC;CAC5B;AAED;;;GAGG;AACH,qBAAa,cAAc;IACzB,OAAO,CAAC,OAAO,CAAe;IAC9B,OAAO,CAAC,MAAM,CAAS;;IAavB,OAAO,CAAC,OAAO,EAAE,YAAY,GAAG,IAAI;IAgBpC,UAAU,IAAI,YAAY;CAG3B"}
@@ -1,12 +1,15 @@
1
+ import { log } from "../log.js";
1
2
  class UsageCollector {
2
3
  summary;
4
+ logger = log();
3
5
  constructor() {
6
+ this.logger.warn("UsageCollector is deprecated. Use ModelUsageCollector instead.");
4
7
  this.summary = {
5
8
  llmPromptTokens: 0,
6
9
  llmPromptCachedTokens: 0,
7
10
  llmCompletionTokens: 0,
8
11
  ttsCharactersCount: 0,
9
- sttAudioDuration: 0
12
+ sttAudioDurationMs: 0
10
13
  };
11
14
  }
12
15
  collect(metrics) {
@@ -21,7 +24,7 @@ class UsageCollector {
21
24
  } else if (metrics.type === "tts_metrics") {
22
25
  this.summary.ttsCharactersCount += metrics.charactersCount;
23
26
  } else if (metrics.type === "stt_metrics") {
24
- this.summary.sttAudioDuration += metrics.audioDuration;
27
+ this.summary.sttAudioDurationMs += metrics.audioDurationMs;
25
28
  }
26
29
  }
27
30
  getSummary() {