@absolutejs/voice 0.0.22-beta.45 → 0.0.22-beta.450

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 (329) hide show
  1. package/README.md +4269 -603
  2. package/dist/agent.d.ts +67 -5
  3. package/dist/agentSquadContract.d.ts +98 -0
  4. package/dist/angular/index.d.ts +22 -3
  5. package/dist/angular/index.js +4660 -1140
  6. package/dist/angular/voice-agent-squad-status.service.d.ts +12 -0
  7. package/dist/angular/voice-call-debugger.service.d.ts +12 -0
  8. package/dist/angular/voice-campaign-dialer-proof.service.d.ts +14 -0
  9. package/dist/angular/voice-controller.service.d.ts +3 -1
  10. package/dist/angular/voice-delivery-runtime.component.d.ts +17 -0
  11. package/dist/angular/voice-delivery-runtime.service.d.ts +16 -0
  12. package/dist/angular/voice-live-ops.service.d.ts +11 -0
  13. package/dist/angular/voice-ops-action-center.service.d.ts +13 -0
  14. package/dist/angular/voice-ops-status.component.d.ts +15 -0
  15. package/dist/angular/voice-ops-status.service.d.ts +12 -0
  16. package/dist/angular/voice-platform-coverage.service.d.ts +12 -0
  17. package/dist/angular/voice-profile-comparison.service.d.ts +12 -0
  18. package/dist/angular/voice-proof-trends.service.d.ts +12 -0
  19. package/dist/angular/voice-provider-capabilities.service.d.ts +12 -0
  20. package/dist/angular/voice-provider-contracts.service.d.ts +12 -0
  21. package/dist/angular/voice-provider-status.service.d.ts +2 -2
  22. package/dist/angular/voice-readiness-failures.service.d.ts +13 -0
  23. package/dist/angular/voice-routing-status.service.d.ts +11 -0
  24. package/dist/angular/voice-session-snapshot.service.d.ts +13 -0
  25. package/dist/angular/voice-stream.service.d.ts +4 -1
  26. package/dist/angular/voice-trace-timeline.service.d.ts +12 -0
  27. package/dist/angular/voice-turn-latency.service.d.ts +13 -0
  28. package/dist/angular/voice-turn-quality.service.d.ts +12 -0
  29. package/dist/angular/voice-workflow-status.service.d.ts +12 -0
  30. package/dist/assistant.d.ts +11 -11
  31. package/dist/assistantHealth.d.ts +6 -6
  32. package/dist/assistantMemory.d.ts +3 -3
  33. package/dist/audioConditioning.d.ts +1 -1
  34. package/dist/audit.d.ts +131 -0
  35. package/dist/auditDeliveryRoutes.d.ts +85 -0
  36. package/dist/auditExport.d.ts +34 -0
  37. package/dist/auditRoutes.d.ts +66 -0
  38. package/dist/auditSinks.d.ts +151 -0
  39. package/dist/bargeInRoutes.d.ts +56 -0
  40. package/dist/browserCallProfiles.d.ts +120 -0
  41. package/dist/browserMediaRoutes.d.ts +62 -0
  42. package/dist/callDebugger.d.ts +66 -0
  43. package/dist/campaign.d.ts +794 -0
  44. package/dist/campaignDialers.d.ts +111 -0
  45. package/dist/client/actions.d.ts +95 -1
  46. package/dist/client/agentSquadStatus.d.ts +37 -0
  47. package/dist/client/agentSquadStatusWidget.d.ts +24 -0
  48. package/dist/client/audioPlayer.d.ts +2 -2
  49. package/dist/client/bargeInMonitor.d.ts +7 -0
  50. package/dist/client/browserMedia.d.ts +8 -0
  51. package/dist/client/callDebugger.d.ts +19 -0
  52. package/dist/client/callDebuggerWidget.d.ts +30 -0
  53. package/dist/client/campaignDialerProof.d.ts +23 -0
  54. package/dist/client/connection.d.ts +4 -3
  55. package/dist/client/controller.d.ts +1 -1
  56. package/dist/client/createVoiceStream.d.ts +1 -1
  57. package/dist/client/deliveryRuntime.d.ts +34 -0
  58. package/dist/client/deliveryRuntimeWidget.d.ts +37 -0
  59. package/dist/client/duplex.d.ts +2 -2
  60. package/dist/client/htmx.d.ts +1 -1
  61. package/dist/client/htmxBootstrap.js +964 -14
  62. package/dist/client/index.d.ts +96 -9
  63. package/dist/client/index.js +9953 -44
  64. package/dist/client/liveOps.d.ts +22 -0
  65. package/dist/client/liveOpsWidget.d.ts +23 -0
  66. package/dist/client/liveTurnLatency.d.ts +41 -0
  67. package/dist/client/microphone.d.ts +4 -4
  68. package/dist/client/opsActionCenter.d.ts +54 -0
  69. package/dist/client/opsActionCenterWidget.d.ts +29 -0
  70. package/dist/client/opsActionHistory.d.ts +19 -0
  71. package/dist/client/opsActionHistoryWidget.d.ts +11 -0
  72. package/dist/client/opsStatus.d.ts +19 -0
  73. package/dist/client/opsStatusWidget.d.ts +40 -0
  74. package/dist/client/platformCoverage.d.ts +19 -0
  75. package/dist/client/platformCoverageWidget.d.ts +37 -0
  76. package/dist/client/profileComparison.d.ts +19 -0
  77. package/dist/client/profileComparisonWidget.d.ts +41 -0
  78. package/dist/client/profileSwitchRecommendation.d.ts +19 -0
  79. package/dist/client/profileSwitchRecommendationWidget.d.ts +12 -0
  80. package/dist/client/proofTrends.d.ts +19 -0
  81. package/dist/client/proofTrendsWidget.d.ts +37 -0
  82. package/dist/client/providerCapabilities.d.ts +19 -0
  83. package/dist/client/providerCapabilitiesWidget.d.ts +32 -0
  84. package/dist/client/providerContracts.d.ts +19 -0
  85. package/dist/client/providerContractsWidget.d.ts +37 -0
  86. package/dist/client/providerSimulationControls.d.ts +33 -0
  87. package/dist/client/providerSimulationControlsWidget.d.ts +20 -0
  88. package/dist/client/providerStatus.d.ts +1 -1
  89. package/dist/client/providerStatusWidget.d.ts +32 -0
  90. package/dist/client/readinessFailures.d.ts +19 -0
  91. package/dist/client/readinessFailuresWidget.d.ts +42 -0
  92. package/dist/client/routingStatus.d.ts +19 -0
  93. package/dist/client/routingStatusWidget.d.ts +32 -0
  94. package/dist/client/sessionSnapshot.d.ts +21 -0
  95. package/dist/client/sessionSnapshotWidget.d.ts +33 -0
  96. package/dist/client/store.d.ts +1 -1
  97. package/dist/client/traceTimeline.d.ts +19 -0
  98. package/dist/client/traceTimelineWidget.d.ts +36 -0
  99. package/dist/client/turnLatency.d.ts +22 -0
  100. package/dist/client/turnLatencyWidget.d.ts +33 -0
  101. package/dist/client/turnQuality.d.ts +19 -0
  102. package/dist/client/turnQualityWidget.d.ts +32 -0
  103. package/dist/client/workflowStatus.d.ts +19 -0
  104. package/dist/competitiveCoverage.d.ts +141 -0
  105. package/dist/correction.d.ts +2 -2
  106. package/dist/dataControl.d.ts +180 -0
  107. package/dist/deliveryRuntime.d.ts +158 -0
  108. package/dist/deliverySinkRoutes.d.ts +117 -0
  109. package/dist/demoReadyRoutes.d.ts +98 -0
  110. package/dist/diagnosticsRoutes.d.ts +2 -2
  111. package/dist/evalRoutes.d.ts +11 -4
  112. package/dist/fileStore.d.ts +19 -7
  113. package/dist/generated/htmxBootstrapBundle.d.ts +1 -0
  114. package/dist/guardrails.d.ts +128 -0
  115. package/dist/handoff.d.ts +6 -6
  116. package/dist/handoffHealth.d.ts +5 -5
  117. package/dist/htmx.d.ts +1 -1
  118. package/dist/incidentBundle.d.ts +119 -0
  119. package/dist/incidentTimeline.d.ts +259 -0
  120. package/dist/index.d.ts +216 -70
  121. package/dist/index.js +35935 -6781
  122. package/dist/latencySlo.d.ts +56 -0
  123. package/dist/liveLatency.d.ts +78 -0
  124. package/dist/liveOps.d.ts +190 -0
  125. package/dist/logger.d.ts +1 -1
  126. package/dist/mediaPipelineRoutes.d.ts +117 -0
  127. package/dist/memoryStore.d.ts +1 -1
  128. package/dist/modelAdapters.d.ts +59 -7
  129. package/dist/observabilityExport.d.ts +501 -0
  130. package/dist/openaiTTS.d.ts +18 -0
  131. package/dist/operationalStatus.d.ts +87 -0
  132. package/dist/operationsRecord.d.ts +351 -0
  133. package/dist/ops.d.ts +12 -12
  134. package/dist/opsActionAuditRoutes.d.ts +99 -0
  135. package/dist/opsConsoleRoutes.d.ts +8 -5
  136. package/dist/opsPresets.d.ts +2 -2
  137. package/dist/opsRecovery.d.ts +137 -0
  138. package/dist/opsRuntime.d.ts +6 -6
  139. package/dist/opsSinks.d.ts +13 -13
  140. package/dist/opsStatus.d.ts +76 -0
  141. package/dist/opsStatusRoutes.d.ts +33 -0
  142. package/dist/opsWebhook.d.ts +6 -6
  143. package/dist/outcomeContract.d.ts +146 -0
  144. package/dist/outcomeRecipes.d.ts +4 -4
  145. package/dist/phoneAgent.d.ts +139 -0
  146. package/dist/phoneAgentProductionSmoke.d.ts +115 -0
  147. package/dist/platformCoverage.d.ts +91 -0
  148. package/dist/plugin.d.ts +2 -2
  149. package/dist/postCallAnalysis.d.ts +98 -0
  150. package/dist/postgresStore.d.ts +17 -6
  151. package/dist/presets.d.ts +3 -3
  152. package/dist/productionReadiness.d.ts +739 -0
  153. package/dist/profileSwitchRecommendation.d.ts +350 -0
  154. package/dist/proofAssertions.d.ts +32 -0
  155. package/dist/proofPack.d.ts +206 -0
  156. package/dist/proofRunner.d.ts +79 -0
  157. package/dist/proofTrends.d.ts +716 -0
  158. package/dist/providerAdapters.d.ts +16 -5
  159. package/dist/providerCapabilities.d.ts +92 -0
  160. package/dist/providerDecisionTraces.d.ts +130 -0
  161. package/dist/providerHealth.d.ts +3 -3
  162. package/dist/providerOrchestration.d.ts +109 -0
  163. package/dist/providerRouterTraces.d.ts +35 -0
  164. package/dist/providerRoutingContract.d.ts +71 -0
  165. package/dist/providerSlo.d.ts +142 -0
  166. package/dist/providerStackRecommendations.d.ts +187 -0
  167. package/dist/qualityRoutes.d.ts +4 -4
  168. package/dist/queue.d.ts +23 -14
  169. package/dist/react/VoiceAgentSquadStatus.d.ts +5 -0
  170. package/dist/react/VoiceCallDebuggerLaunch.d.ts +6 -0
  171. package/dist/react/VoiceDeliveryRuntime.d.ts +7 -0
  172. package/dist/react/VoiceOpsActionCenter.d.ts +5 -0
  173. package/dist/react/VoiceOpsStatus.d.ts +6 -0
  174. package/dist/react/VoicePlatformCoverage.d.ts +6 -0
  175. package/dist/react/VoiceProfileComparison.d.ts +6 -0
  176. package/dist/react/VoiceProfileSwitchRecommendation.d.ts +6 -0
  177. package/dist/react/VoiceProofTrends.d.ts +6 -0
  178. package/dist/react/VoiceProviderCapabilities.d.ts +6 -0
  179. package/dist/react/VoiceProviderContracts.d.ts +6 -0
  180. package/dist/react/VoiceProviderSimulationControls.d.ts +5 -0
  181. package/dist/react/VoiceProviderStatus.d.ts +6 -0
  182. package/dist/react/VoiceReadinessFailures.d.ts +6 -0
  183. package/dist/react/VoiceRoutingStatus.d.ts +6 -0
  184. package/dist/react/VoiceSessionSnapshot.d.ts +6 -0
  185. package/dist/react/VoiceTraceTimeline.d.ts +6 -0
  186. package/dist/react/VoiceTurnLatency.d.ts +6 -0
  187. package/dist/react/VoiceTurnQuality.d.ts +6 -0
  188. package/dist/react/index.d.ts +43 -3
  189. package/dist/react/index.js +10698 -32
  190. package/dist/react/useVoiceAgentSquadStatus.d.ts +8 -0
  191. package/dist/react/useVoiceCallDebugger.d.ts +8 -0
  192. package/dist/react/useVoiceCampaignDialerProof.d.ts +10 -0
  193. package/dist/react/useVoiceController.d.ts +4 -1
  194. package/dist/react/useVoiceDeliveryRuntime.d.ts +13 -0
  195. package/dist/react/useVoiceLiveOps.d.ts +9 -0
  196. package/dist/react/useVoiceOpsActionCenter.d.ts +11 -0
  197. package/dist/react/useVoiceOpsStatus.d.ts +8 -0
  198. package/dist/react/useVoicePlatformCoverage.d.ts +8 -0
  199. package/dist/react/useVoiceProfileComparison.d.ts +8 -0
  200. package/dist/react/useVoiceProfileSwitchRecommendation.d.ts +8 -0
  201. package/dist/react/useVoiceProofTrends.d.ts +8 -0
  202. package/dist/react/useVoiceProviderCapabilities.d.ts +8 -0
  203. package/dist/react/useVoiceProviderContracts.d.ts +8 -0
  204. package/dist/react/useVoiceProviderSimulationControls.d.ts +10 -0
  205. package/dist/react/useVoiceProviderStatus.d.ts +1 -1
  206. package/dist/react/useVoiceReadinessFailures.d.ts +8 -0
  207. package/dist/react/useVoiceRoutingStatus.d.ts +8 -0
  208. package/dist/react/useVoiceSessionSnapshot.d.ts +9 -0
  209. package/dist/react/useVoiceStream.d.ts +4 -1
  210. package/dist/react/useVoiceTraceTimeline.d.ts +8 -0
  211. package/dist/react/useVoiceTurnLatency.d.ts +9 -0
  212. package/dist/react/useVoiceTurnQuality.d.ts +8 -0
  213. package/dist/react/useVoiceWorkflowStatus.d.ts +8 -0
  214. package/dist/readinessProfiles.d.ts +45 -0
  215. package/dist/realtimeChannel.d.ts +136 -0
  216. package/dist/realtimeProviderContracts.d.ts +133 -0
  217. package/dist/reconnectContract.d.ts +176 -0
  218. package/dist/resilienceRoutes.d.ts +45 -5
  219. package/dist/routing.d.ts +1 -1
  220. package/dist/runtimeOps.d.ts +3 -3
  221. package/dist/s3Store.d.ts +3 -3
  222. package/dist/session.d.ts +1 -1
  223. package/dist/sessionReplay.d.ts +19 -7
  224. package/dist/sessionSnapshot.d.ts +109 -0
  225. package/dist/simulationSuite.d.ts +143 -0
  226. package/dist/sloCalibration.d.ts +185 -0
  227. package/dist/sqliteStore.d.ts +17 -6
  228. package/dist/store.d.ts +1 -1
  229. package/dist/svelte/createVoiceAgentSquadStatus.d.ts +9 -0
  230. package/dist/svelte/createVoiceCallDebugger.d.ts +12 -0
  231. package/dist/svelte/createVoiceCampaignDialerProof.d.ts +9 -0
  232. package/dist/svelte/createVoiceDeliveryRuntime.d.ts +11 -0
  233. package/dist/svelte/createVoiceLiveOps.d.ts +13 -0
  234. package/dist/svelte/createVoiceOpsActionCenter.d.ts +10 -0
  235. package/dist/svelte/createVoiceOpsStatus.d.ts +9 -0
  236. package/dist/svelte/createVoicePlatformCoverage.d.ts +7 -0
  237. package/dist/svelte/createVoiceProfileComparison.d.ts +7 -0
  238. package/dist/svelte/createVoiceProofTrends.d.ts +7 -0
  239. package/dist/svelte/createVoiceProviderCapabilities.d.ts +10 -0
  240. package/dist/svelte/createVoiceProviderContracts.d.ts +10 -0
  241. package/dist/svelte/createVoiceProviderSimulationControls.d.ts +11 -0
  242. package/dist/svelte/createVoiceProviderStatus.d.ts +4 -2
  243. package/dist/svelte/createVoiceReadinessFailures.d.ts +7 -0
  244. package/dist/svelte/createVoiceRoutingStatus.d.ts +10 -0
  245. package/dist/svelte/createVoiceSessionSnapshot.d.ts +13 -0
  246. package/dist/svelte/createVoiceStream.d.ts +1 -1
  247. package/dist/svelte/createVoiceTraceTimeline.d.ts +10 -0
  248. package/dist/svelte/createVoiceTurnLatency.d.ts +11 -0
  249. package/dist/svelte/createVoiceTurnQuality.d.ts +10 -0
  250. package/dist/svelte/createVoiceWorkflowStatus.d.ts +8 -0
  251. package/dist/svelte/index.d.ts +23 -3
  252. package/dist/svelte/index.js +6436 -460
  253. package/dist/telephony/contract.d.ts +61 -0
  254. package/dist/telephony/matrix.d.ts +97 -0
  255. package/dist/telephony/plivo.d.ts +303 -0
  256. package/dist/telephony/response.d.ts +1 -1
  257. package/dist/telephony/security.d.ts +182 -0
  258. package/dist/telephony/telnyx.d.ts +291 -0
  259. package/dist/telephony/twilio.d.ts +147 -13
  260. package/dist/telephonyMediaRoutes.d.ts +72 -0
  261. package/dist/telephonyOutcome.d.ts +273 -0
  262. package/dist/testing/accuracy.d.ts +1 -1
  263. package/dist/testing/benchmark.d.ts +9 -9
  264. package/dist/testing/corrected.d.ts +5 -5
  265. package/dist/testing/duplex.d.ts +3 -3
  266. package/dist/testing/fixtures.d.ts +3 -3
  267. package/dist/testing/index.d.ts +13 -13
  268. package/dist/testing/index.js +5425 -185
  269. package/dist/testing/ioProviderSimulator.d.ts +5 -5
  270. package/dist/testing/providerSimulator.d.ts +5 -5
  271. package/dist/testing/review.d.ts +4 -4
  272. package/dist/testing/sessionBenchmark.d.ts +3 -3
  273. package/dist/testing/stt.d.ts +3 -3
  274. package/dist/testing/telephony.d.ts +25 -0
  275. package/dist/testing/tts.d.ts +1 -1
  276. package/dist/toolContract.d.ts +161 -0
  277. package/dist/toolRuntime.d.ts +50 -0
  278. package/dist/trace.d.ts +46 -7
  279. package/dist/traceDeliveryRoutes.d.ts +86 -0
  280. package/dist/traceTimeline.d.ts +97 -0
  281. package/dist/turnDetection.d.ts +1 -1
  282. package/dist/turnLatency.d.ts +95 -0
  283. package/dist/turnProfiles.d.ts +2 -2
  284. package/dist/turnQuality.d.ts +94 -0
  285. package/dist/types.d.ts +236 -80
  286. package/dist/voiceMonitoring.d.ts +444 -0
  287. package/dist/vue/VoiceCallDebuggerLaunch.d.ts +68 -0
  288. package/dist/vue/VoiceDeliveryRuntime.d.ts +30 -0
  289. package/dist/vue/VoiceOpsActionCenter.d.ts +13 -0
  290. package/dist/vue/VoiceOpsStatus.d.ts +30 -0
  291. package/dist/vue/VoicePlatformCoverage.d.ts +23 -0
  292. package/dist/vue/VoiceProofTrends.d.ts +21 -0
  293. package/dist/vue/VoiceProviderCapabilities.d.ts +51 -0
  294. package/dist/vue/VoiceProviderContracts.d.ts +21 -0
  295. package/dist/vue/VoiceProviderSimulationControls.d.ts +88 -0
  296. package/dist/vue/VoiceProviderStatus.d.ts +51 -0
  297. package/dist/vue/VoiceReadinessFailures.d.ts +21 -0
  298. package/dist/vue/VoiceRoutingStatus.d.ts +51 -0
  299. package/dist/vue/VoiceSessionSnapshot.d.ts +68 -0
  300. package/dist/vue/VoiceTurnLatency.d.ts +69 -0
  301. package/dist/vue/VoiceTurnQuality.d.ts +51 -0
  302. package/dist/vue/index.d.ts +38 -3
  303. package/dist/vue/index.js +10142 -56
  304. package/dist/vue/useVoiceAgentSquadStatus.d.ts +9 -0
  305. package/dist/vue/useVoiceCallDebugger.d.ts +10 -0
  306. package/dist/vue/useVoiceCampaignDialerProof.d.ts +11 -0
  307. package/dist/vue/useVoiceController.d.ts +4 -2
  308. package/dist/vue/useVoiceDeliveryRuntime.d.ts +13 -0
  309. package/dist/vue/useVoiceLiveOps.d.ts +9 -0
  310. package/dist/vue/useVoiceOpsActionCenter.d.ts +11 -0
  311. package/dist/vue/useVoiceOpsStatus.d.ts +9 -0
  312. package/dist/vue/useVoicePlatformCoverage.d.ts +9 -0
  313. package/dist/vue/useVoiceProfileComparison.d.ts +9 -0
  314. package/dist/vue/useVoiceProofTrends.d.ts +9 -0
  315. package/dist/vue/useVoiceProviderCapabilities.d.ts +9 -0
  316. package/dist/vue/useVoiceProviderContracts.d.ts +9 -0
  317. package/dist/vue/useVoiceProviderSimulationControls.d.ts +24 -0
  318. package/dist/vue/useVoiceProviderStatus.d.ts +3 -3
  319. package/dist/vue/useVoiceReadinessFailures.d.ts +943 -0
  320. package/dist/vue/useVoiceRoutingStatus.d.ts +8 -0
  321. package/dist/vue/useVoiceSessionSnapshot.d.ts +10 -0
  322. package/dist/vue/useVoiceStream.d.ts +5 -2
  323. package/dist/vue/useVoiceTraceTimeline.d.ts +9 -0
  324. package/dist/vue/useVoiceTurnLatency.d.ts +10 -0
  325. package/dist/vue/useVoiceTurnQuality.d.ts +9 -0
  326. package/dist/vue/useVoiceWorkflowStatus.d.ts +9 -0
  327. package/dist/workflowContract.d.ts +91 -0
  328. package/fixtures/manifest.json +356 -197
  329. package/package.json +260 -256
@@ -0,0 +1 @@
1
+ export declare const HTMX_BOOTSTRAP_BUNDLE = "var Ue=(e)=>{if(typeof e!==\"string\")return e;return document.querySelector(e)},Ne=(e,n,t,o)=>{let r=n??e.getAttribute(\"hx-get\")??\"\";if(!r)return\"\";let i=new URL(r,window.location.origin);if(o)i.searchParams.set(t,o);else i.searchParams.delete(t);return`${i.pathname}${i.search}${i.hash}`},de=(e,n)=>{if(typeof window>\"u\"||typeof document>\"u\")return()=>{};let t=Ue(n.element);if(!t)return()=>{};let o=n.eventName??\"voice-refresh\",r=n.sessionQueryParam??\"sessionId\",i=()=>{let l=window,g=Ne(t,n.route,r,e.sessionId);if(g)t.setAttribute(\"hx-get\",g);l.htmx?.process?.(t),l.htmx?.trigger?.(t,o)},c=e.subscribe(i);return i(),()=>{c()}};var He=(e)=>Math.max(-1,Math.min(1,e)),Ge=(e)=>{let n=new Int16Array(e.length);for(let t=0;t<e.length;t+=1){let o=He(e[t]??0);n[t]=o<0?o*32768:o*32767}return new Uint8Array(n.buffer)},Be=(e)=>{let n=e instanceof Uint8Array?e:new Uint8Array(e);if(n.byteLength<2)return 0;let t=new Int16Array(n.buffer,n.byteOffset,Math.floor(n.byteLength/2));if(t.length===0)return 0;let o=0;for(let r of t){let i=r/32768;o+=i*i}return Math.min(1,Math.max(0,Math.sqrt(o/t.length)*5.5))},We=(e,n,t)=>{if(n===t)return e;let o=n/t,r=Math.round(e.length/o),i=new Float32Array(r),c=0,l=0;while(c<i.length){let g=Math.round((c+1)*o),y=0,d=0;for(let h=l;h<g&&h<e.length;h+=1)y+=e[h]??0,d+=1;i[c]=d>0?y/d:0,c+=1,l=g}return i},ge=(e)=>{let n=null,t=null,o=null,r=null;return{start:async()=>{if(typeof navigator>\"u\"||!navigator.mediaDevices?.getUserMedia)throw Error(\"Browser microphone capture requires navigator.mediaDevices.getUserMedia.\");let l=(typeof window<\"u\"?window.AudioContext??window.webkitAudioContext:void 0)??AudioContext;if(!l)throw Error(\"Browser microphone capture requires AudioContext support.\");r=await navigator.mediaDevices.getUserMedia({audio:{channelCount:e.channelCount??1}}),n=new l,t=n.createMediaStreamSource(r),o=n.createScriptProcessor(4096,1,1),o.onaudioprocess=(g)=>{let y=g.inputBuffer.getChannelData(0),d=We(y,n?.sampleRate??48000,e.sampleRateHz??16000),h=Ge(d);e.onLevel?.(Be(h)),e.onAudio(h)},t.connect(o),o.connect(n.destination)},stop:()=>{o?.disconnect(),t?.disconnect(),r?.getTracks().forEach((l)=>l.stop()),n?.close(),e.onLevel?.(0),n=null,r=null,o=null,t=null}}};var ee=(e)=>{if(typeof e===\"string\"&&e.trim())return e;if(e instanceof Error&&e.message.trim())return e.message;if(e&&typeof e===\"object\"){let n=e;for(let t of[\"message\",\"reason\",\"description\"]){let o=n[t];if(typeof o===\"string\"&&o.trim())return o}if(\"error\"in n)return ee(n.error);if(\"cause\"in n)return ee(n.cause);try{return JSON.stringify(e)}catch{}}return\"Unexpected error\"},Ae=(e)=>{switch(e.type){case\"audio\":return{chunk:Uint8Array.from(atob(e.chunkBase64),(n)=>n.charCodeAt(0)),format:e.format,receivedAt:e.receivedAt,turnId:e.turnId,type:\"audio\"};case\"assistant\":return{text:e.text,type:\"assistant\"};case\"complete\":return{sessionId:e.sessionId,type:\"complete\"};case\"connection\":return{reconnect:e.reconnect,type:\"connection\"};case\"call_lifecycle\":return{event:e.event,sessionId:e.sessionId,type:\"call_lifecycle\"};case\"error\":return{message:ee(e.message),type:\"error\"};case\"final\":return{transcript:e.transcript,type:\"final\"};case\"partial\":return{transcript:e.transcript,type:\"partial\"};case\"replay\":return{assistantTexts:e.assistantTexts,call:e.call,partial:e.partial,scenarioId:e.scenarioId,sessionId:e.sessionId,sessionMetadata:e.sessionMetadata,status:e.status,turns:e.turns,type:\"replay\"};case\"session\":return{sessionId:e.sessionId,sessionMetadata:e.sessionMetadata,scenarioId:e.scenarioId,status:e.status,type:\"session\"};case\"turn\":return{turn:e.turn,type:\"turn\"};default:return null}};var H=(e,n,t,o)=>{e.push({code:t,message:o,severity:n})};var $e=(e)=>e.length===0?void 0:e.reduce((n,t)=>n+t,0)/e.length,K=(e)=>e.length===0?void 0:Math.max(...e);var b=(e,n)=>{let t=e[n];return typeof t===\"number\"&&Number.isFinite(t)?t:void 0},Z=(e,n)=>{let t=e[n];return typeof t===\"boolean\"?t:void 0},D=(e,n)=>{let t=e[n];return typeof t===\"string\"?t:void 0},ne=(e)=>String(e.id??D(e,\"ssrc\")??b(e,\"ssrc\")??D(e,\"trackIdentifier\")??D(e,\"mid\")??\"unknown\"),he=(e)=>e===void 0?void 0:e*1000;var ke=(e)=>{let n={};for(let[t,o]of Object.entries(e))if(o===null||typeof o===\"boolean\"||typeof o===\"number\"||typeof o===\"string\")n[t]=o;return n};var ye=(e={})=>{let n=e.stats??[],t=[],o=n.filter((s)=>s.type===\"inbound-rtp\"&&D(s,\"kind\")!==\"video\"),r=n.filter((s)=>s.type===\"outbound-rtp\"&&D(s,\"kind\")!==\"video\"),i=n.filter((s)=>s.type===\"candidate-pair\"),c=n.filter((s)=>(s.type===\"track\"||s.type===\"media-source\")&&D(s,\"kind\")===\"audio\"),l=i.filter((s)=>Z(s,\"selected\")===!0||Z(s,\"nominated\")===!0||D(s,\"state\")===\"succeeded\").length,g=c.filter((s)=>D(s,\"readyState\")!==\"ended\"&&D(s,\"trackState\")!==\"ended\"&&Z(s,\"ended\")!==!0).length,y=c.filter((s)=>D(s,\"readyState\")===\"ended\"||D(s,\"trackState\")===\"ended\"||Z(s,\"ended\")===!0).length,d=o.reduce((s,S)=>s+(b(S,\"packetsReceived\")??0),0),h=r.reduce((s,S)=>s+(b(S,\"packetsSent\")??0),0),a=[...o,...r].reduce((s,S)=>s+Math.max(0,b(S,\"packetsLost\")??0),0),M=d+a,C=M===0?0:a/M,I=o.reduce((s,S)=>s+(b(S,\"bytesReceived\")??0),0),w=r.reduce((s,S)=>s+(b(S,\"bytesSent\")??0),0),R=K(i.map((s)=>he(b(s,\"currentRoundTripTime\")??b(s,\"roundTripTime\"))).filter((s)=>s!==void 0)),u=K([...o,...r].map((s)=>he(b(s,\"jitter\"))).filter((s)=>s!==void 0)),O=K(o.map((s)=>{let S=b(s,\"jitterBufferDelay\"),L=b(s,\"jitterBufferEmittedCount\");return S!==void 0&&L!==void 0&&L>0?S/L*1000:void 0}).filter((s)=>s!==void 0)),U=c.map((s)=>b(s,\"audioLevel\")).filter((s)=>s!==void 0);if(e.requireConnectedCandidatePair&&i.length>0&&l===0)H(t,\"error\",\"media.webrtc_candidate_pair_missing\",\"No active WebRTC candidate pair was observed.\");if(e.requireLiveAudioTrack&&g===0)H(t,\"error\",\"media.webrtc_audio_track_missing\",\"No live WebRTC audio track was observed.\");if(e.maxPacketLossRatio!==void 0&&C>e.maxPacketLossRatio)H(t,\"warning\",\"media.webrtc_packet_loss\",`Observed WebRTC packet loss ratio ${String(C)} above ${String(e.maxPacketLossRatio)}.`);if(e.maxRoundTripTimeMs!==void 0&&R!==void 0&&R>e.maxRoundTripTimeMs)H(t,\"warning\",\"media.webrtc_round_trip_time\",`Observed WebRTC RTT ${String(R)}ms above ${String(e.maxRoundTripTimeMs)}ms.`);if(e.maxJitterMs!==void 0&&u!==void 0&&u>e.maxJitterMs)H(t,\"warning\",\"media.webrtc_jitter\",`Observed WebRTC jitter ${String(u)}ms above ${String(e.maxJitterMs)}ms.`);return{activeCandidatePairs:l,audioLevelAverage:$e(U),bytesReceived:I,bytesSent:w,checkedAt:Date.now(),endedAudioTracks:y,inboundPackets:d,issues:t,jitterBufferDelayMs:O,jitterMs:u,liveAudioTracks:g,outboundPackets:h,packetLossRatio:C,packetsLost:a,roundTripTimeMs:R,status:t.some((s)=>s.severity===\"error\")?\"fail\":t.length>0?\"warn\":\"pass\",totalStats:n.length}},Ce=async(e)=>{return[...(await e.peerConnection.getStats(e.selector??null)).values()].map(ke)};var fe=(e={})=>{let n=e.stats??[],t=e.previousStats??[],o=[],r=new Map(t.map((a)=>[ne(a),a])),c=n.filter((a)=>(a.type===\"inbound-rtp\"||a.type===\"outbound-rtp\")&&D(a,\"kind\")!==\"video\"&&D(a,\"mediaType\")!==\"video\").map((a)=>{let M=a.type===\"outbound-rtp\"?\"outbound\":\"inbound\",C=M===\"outbound\"?\"packetsSent\":\"packetsReceived\",I=M===\"outbound\"?\"bytesSent\":\"bytesReceived\",w=r.get(ne(a)),R=b(a,C),u=w?b(w,C):void 0,O=b(a,I),U=w?b(w,I):void 0,s=a.timestamp!==void 0&&w?.timestamp!==void 0?a.timestamp-w.timestamp:void 0;return{bytesDelta:O!==void 0&&U!==void 0?O-U:void 0,currentPackets:R,direction:M,id:ne(a),packetDelta:R!==void 0&&u!==void 0?R-u:void 0,previousPackets:u,timeDeltaMs:s}}),l=c.filter((a)=>a.direction===\"inbound\"),g=c.filter((a)=>a.direction===\"outbound\"),y=K(c.map((a)=>a.timeDeltaMs).filter((a)=>a!==void 0)),d=l.filter((a)=>e.maxInboundPacketStallMs!==void 0&&a.timeDeltaMs!==void 0&&a.timeDeltaMs>=e.maxInboundPacketStallMs&&a.packetDelta!==void 0&&a.packetDelta<=0).length,h=g.filter((a)=>e.maxOutboundPacketStallMs!==void 0&&a.timeDeltaMs!==void 0&&a.timeDeltaMs>=e.maxOutboundPacketStallMs&&a.packetDelta!==void 0&&a.packetDelta<=0).length;if(e.requireInboundAudio&&l.length===0)H(o,\"error\",\"media.webrtc_inbound_audio_missing\",\"No inbound WebRTC audio RTP stream was observed.\");if(e.requireOutboundAudio&&g.length===0)H(o,\"error\",\"media.webrtc_outbound_audio_missing\",\"No outbound WebRTC audio RTP stream was observed.\");if(e.maxGapMs!==void 0&&y!==void 0&&y>e.maxGapMs)H(o,\"warning\",\"media.webrtc_stream_gap\",`Observed WebRTC stream sample gap ${String(y)}ms above ${String(e.maxGapMs)}ms.`);if(d>0)H(o,\"error\",\"media.webrtc_inbound_stalled\",`${String(d)} inbound WebRTC audio stream(s) stopped receiving packets.`);if(h>0)H(o,\"error\",\"media.webrtc_outbound_stalled\",`${String(h)} outbound WebRTC audio stream(s) stopped sending packets.`);return{checkedAt:Date.now(),inboundAudioStreams:l.length,issues:o,maxObservedGapMs:y,outboundAudioStreams:g.length,stalledInboundStreams:d,stalledOutboundStreams:h,status:o.some((a)=>a.severity===\"error\")?\"fail\":o.length>0?\"warn\":\"pass\",streams:c,totalStats:n.length}};var qe=\"/api/voice/browser-media\",Xe=5000,ze=async(e)=>e.peerConnection??await e.getPeerConnection?.()??null,Ye=async(e,n)=>{let t=n.fetch??globalThis.fetch;if(!t)return;await t(n.path??qe,{body:JSON.stringify(e),headers:{\"Content-Type\":\"application/json\"},keepalive:!0,method:\"POST\"})},Te=(e)=>{let n=null,t=[],o=async()=>{let c=await ze(e);if(!c)return;let l=await Ce({peerConnection:c}),g=ye({...e,stats:l}),y=e.continuity===!1?void 0:fe({...e.continuity,previousStats:t,stats:l}),d={at:Date.now(),continuity:y,report:g,scenarioId:e.getScenarioId?.()??null,sessionId:e.getSessionId?.()??null};return t=l,e.onReport?.(d),await Ye(d,e),d},r=()=>{o().catch((c)=>{e.onError?.(c)})},i=()=>{if(n)clearInterval(n),n=null};return{close:i,reportOnce:o,start:()=>{if(n)return;r(),n=setInterval(r,e.intervalMs??Xe)},stop:i}};var B=()=>{},Je=()=>B,Qe={callControl:B,close:B,endTurn:B,getReadyState:()=>3,getScenarioId:()=>\"\",getSessionId:()=>\"\",send:B,sendAudio:B,simulateDisconnect:B,start:()=>{},subscribe:Je},Ze=()=>crypto.randomUUID(),Ke=(e,n,t)=>{let{hostname:o,port:r,protocol:i}=window.location,c=i===\"https:\"?\"wss:\":\"ws:\",l=r?`:${r}`:\"\",g=new URL(`${c}//${o}${l}${e}`);if(g.searchParams.set(\"sessionId\",n),t)g.searchParams.set(\"scenarioId\",t);return g.toString()},me=(e)=>{if(!e||typeof e!==\"object\"||!(\"type\"in e))return!1;switch(e.type){case\"audio\":case\"assistant\":case\"call_lifecycle\":case\"complete\":case\"connection\":case\"error\":case\"final\":case\"partial\":case\"pong\":case\"replay\":case\"session\":case\"turn\":return!0;default:return!1}},je=(e)=>{if(typeof e.data!==\"string\")return null;try{let n=JSON.parse(e.data);return me(n)?n:null}catch{return null}},Se=(e,n={})=>{if(typeof window>\"u\")return Qe;let t=new Set,o=n.reconnect!==!1,r=n.maxReconnectAttempts??10,i=n.pingInterval??30000,c={isConnected:!1,pendingMessages:[],scenarioId:n.scenarioId??null,pingInterval:null,reconnectAttempts:0,reconnectTimeout:null,sessionId:n.sessionId??Ze(),ws:null},l=(s)=>{t.forEach((S)=>S(s))},g=()=>{if(c.pingInterval)clearInterval(c.pingInterval),c.pingInterval=null;if(c.reconnectTimeout)clearTimeout(c.reconnectTimeout),c.reconnectTimeout=null},y=()=>{if(c.ws?.readyState!==1)return;while(c.pendingMessages.length>0){let s=c.pendingMessages.shift();if(s!==void 0)c.ws.send(s)}},d=()=>{let s=Date.now()+500;c.reconnectAttempts+=1,l({reconnect:{attempts:c.reconnectAttempts,lastDisconnectAt:Date.now(),maxAttempts:r,nextAttemptAt:s,status:\"reconnecting\"},type:\"connection\"}),c.reconnectTimeout=setTimeout(()=>{if(c.reconnectAttempts>r){l({reconnect:{attempts:c.reconnectAttempts,maxAttempts:r,status:\"exhausted\"},type:\"connection\"});return}h()},500)},h=()=>{let s=new WebSocket(Ke(e,c.sessionId,c.scenarioId));s.binaryType=\"arraybuffer\",s.onopen=()=>{let S=c.reconnectAttempts>0;if(c.isConnected=!0,y(),S)l({reconnect:{attempts:c.reconnectAttempts,lastResumedAt:Date.now(),maxAttempts:r,status:\"resumed\"},type:\"connection\"}),c.reconnectAttempts=0;t.forEach((L)=>L({scenarioId:c.scenarioId??void 0,sessionId:c.sessionId,status:\"active\",type:\"session\"})),c.pingInterval=setInterval(()=>{if(s.readyState===1)s.send(JSON.stringify({type:\"ping\"}))},i)},s.onmessage=(S)=>{let L=je(S);if(!L)return;if(L.type===\"session\")c.sessionId=L.sessionId,c.scenarioId=L.scenarioId??c.scenarioId;t.forEach((X)=>X(L))},s.onclose=(S)=>{if(c.isConnected=!1,g(),o&&S.code!==1000&&c.reconnectAttempts<r)d();else if(o&&S.code!==1000)l({reconnect:{attempts:c.reconnectAttempts,lastDisconnectAt:Date.now(),maxAttempts:r,status:\"exhausted\"},type:\"connection\"})},c.ws=s},a=(s)=>{if(c.ws?.readyState===1){c.ws.send(s);return}c.pendingMessages.push(s)},M=(s)=>{a(JSON.stringify(s))},C=(s={})=>{if(s.sessionId)c.sessionId=s.sessionId;if(s.scenarioId)c.scenarioId=s.scenarioId;M({type:\"start\",sessionId:c.sessionId,scenarioId:c.scenarioId??void 0})},I=(s)=>{a(s)},w=()=>{M({type:\"end_turn\"})},R=(s)=>{M({...s,type:\"call_control\"})},u=()=>{if(g(),c.ws)c.ws.close(1000),c.ws=null;c.isConnected=!1,t.clear()},O=()=>{if(c.ws?.readyState===1)c.ws.close(4000,\"absolutejs-voice-reconnect-proof\")},U=(s)=>{return t.add(s),()=>{t.delete(s)}};return h(),{callControl:R,close:u,endTurn:w,getReadyState:()=>c.ws?.readyState??3,getScenarioId:()=>c.scenarioId??\"\",getSessionId:()=>c.sessionId,send:M,sendAudio:I,simulateDisconnect:O,start:C,subscribe:U}};var ve=()=>({attempts:0,maxAttempts:0,status:\"idle\"}),Fe=()=>({assistantAudio:[],assistantTexts:[],call:null,error:null,isConnected:!1,sessionMetadata:null,scenarioId:null,partial:\"\",reconnect:ve(),sessionId:null,status:\"idle\",turns:[]}),Me=()=>{let e=Fe(),n=new Set,t=()=>{n.forEach((r)=>r())};return{dispatch:(r)=>{switch(r.type){case\"audio\":e={...e,assistantAudio:[...e.assistantAudio,{chunk:r.chunk,format:r.format,receivedAt:r.receivedAt,turnId:r.turnId}]};break;case\"assistant\":e={...e,assistantTexts:[...e.assistantTexts,r.text]};break;case\"complete\":e={...e,sessionId:r.sessionId,status:\"completed\"};break;case\"call_lifecycle\":e={...e,call:{...e.call,disposition:r.event.type===\"end\"?r.event.disposition:e.call?.disposition,endedAt:r.event.type===\"end\"?r.event.at:e.call?.endedAt,events:[...e.call?.events??[],r.event],lastEventAt:r.event.at,startedAt:e.call?.startedAt??r.event.at},sessionId:r.sessionId};break;case\"connected\":e={...e,isConnected:!0,reconnect:e.reconnect.status===\"reconnecting\"?{...e.reconnect,lastResumedAt:Date.now(),nextAttemptAt:void 0,status:\"resumed\"}:e.reconnect};break;case\"connection\":e={...e,reconnect:r.reconnect};break;case\"disconnected\":e={...e,isConnected:!1};break;case\"error\":e={...e,error:r.message};break;case\"final\":e={...e,partial:r.transcript.text,turns:e.turns.map((i)=>i)};break;case\"partial\":e={...e,partial:r.transcript.text};break;case\"replay\":e={...e,assistantTexts:[...r.assistantTexts],call:r.call??null,error:null,isConnected:r.status===\"active\",partial:r.partial,reconnect:e.reconnect.status===\"reconnecting\"?{...e.reconnect,lastResumedAt:Date.now(),nextAttemptAt:void 0,status:\"resumed\"}:e.reconnect,scenarioId:r.scenarioId??e.scenarioId,sessionId:r.sessionId,sessionMetadata:r.sessionMetadata??e.sessionMetadata,status:r.status,turns:[...r.turns]};break;case\"session\":e={...e,error:null,scenarioId:r.scenarioId??e.scenarioId,isConnected:r.status===\"active\",sessionId:r.sessionId,sessionMetadata:r.sessionMetadata??e.sessionMetadata,status:r.status};break;case\"turn\":e={...e,partial:\"\",turns:[...e.turns,r.turn]};break}t()},getServerSnapshot:()=>e,getSnapshot:()=>e,subscribe:(r)=>{return n.add(r),()=>{n.delete(r)}}}};var Ie=(e,n={})=>{let t=Se(e,n),o=Me(),r=n.browserMedia&&typeof window<\"u\"?Te({...n.browserMedia,getScenarioId:()=>n.browserMedia?n.browserMedia.getScenarioId?.()??t.getScenarioId():t.getScenarioId(),getSessionId:()=>n.browserMedia?n.browserMedia.getSessionId?.()??t.getSessionId():t.getSessionId()}):null,i=new Set,c=(d)=>Promise.resolve().then(()=>{if(!d?.sessionId&&!d?.scenarioId)return;t.start(d),r?.start()}),l=()=>{i.forEach((d)=>d())},g=()=>{if(!n.reconnectReportPath||typeof fetch>\"u\")return;let d=o.getSnapshot(),h=JSON.stringify({at:Date.now(),reconnect:d.reconnect,scenarioId:d.scenarioId,sessionId:t.getSessionId(),turnIds:d.turns.map((a)=>a.id)});fetch(n.reconnectReportPath,{body:h,headers:{\"Content-Type\":\"application/json\"},keepalive:!0,method:\"POST\"}).catch(()=>{})},y=t.subscribe((d)=>{let h=Ae(d);if(h){if(o.dispatch(h),d.type===\"connection\")g();l()}});return{callControl(d){t.callControl(d)},close(){y(),r?.close(),t.close(),o.dispatch({type:\"disconnected\"}),l()},endTurn(){t.endTurn()},get error(){return o.getSnapshot().error},getServerSnapshot(){return o.getServerSnapshot()},getSnapshot(){return o.getSnapshot()},get isConnected(){return o.getSnapshot().isConnected},get scenarioId(){return o.getSnapshot().scenarioId},get sessionMetadata(){return o.getSnapshot().sessionMetadata},start:c,get partial(){return o.getSnapshot().partial},get reconnect(){return o.getSnapshot().reconnect},get sessionId(){return t.getSessionId()},get status(){return o.getSnapshot().status},get turns(){return o.getSnapshot().turns},get assistantTexts(){return o.getSnapshot().assistantTexts},get assistantAudio(){return o.getSnapshot().assistantAudio},get call(){return o.getSnapshot().call},sendAudio(d){t.sendAudio(d)},simulateDisconnect(){t.simulateDisconnect()},subscribe(d){return i.add(d),()=>{i.delete(d)}}}};var Ve=(e)=>{if(!e||e.enabled===!1)return;return{enabled:!0,maxGain:e.maxGain??3,noiseGateAttenuation:e.noiseGateAttenuation??0.15,noiseGateThreshold:e.noiseGateThreshold??0.006,targetLevel:e.targetLevel??0.08}};var pe={balanced:{qualityProfile:\"general\",silenceMs:1400,speechThreshold:0.012,transcriptStabilityMs:1000},fast:{qualityProfile:\"general\",silenceMs:700,speechThreshold:0.015,transcriptStabilityMs:450},\"long-form\":{qualityProfile:\"general\",silenceMs:2200,speechThreshold:0.01,transcriptStabilityMs:1500}},en={general:{},\"accent-heavy\":{silenceMs:1200,speechThreshold:0.01,transcriptStabilityMs:1200},\"noisy-room\":{silenceMs:2000,speechThreshold:0.02,transcriptStabilityMs:1600},\"short-command\":{silenceMs:500,speechThreshold:0.016,transcriptStabilityMs:420}};var we=(e)=>{let n=e?.profile??\"fast\",t=e?.qualityProfile??\"general\",o=pe[n],r=en[t];return{profile:n,qualityProfile:t,silenceMs:e?.silenceMs??r.silenceMs??o.silenceMs,speechThreshold:e?.speechThreshold??r.speechThreshold??o.speechThreshold,transcriptStabilityMs:e?.transcriptStabilityMs??r.transcriptStabilityMs??o.transcriptStabilityMs}};var nn={chat:{audioConditioning:{enabled:!0,maxGain:2.5,noiseGateAttenuation:0,noiseGateThreshold:0.004,targetLevel:0.08},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:10,pingInterval:30000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"short-command\",profile:\"balanced\"}},default:{capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:10,pingInterval:30000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"general\",profile:\"fast\"}},dictation:{audioConditioning:{enabled:!0,maxGain:2.25,noiseGateAttenuation:0.05,noiseGateThreshold:0.003,targetLevel:0.08},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:12,pingInterval:30000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"accent-heavy\",profile:\"long-form\"}},\"guided-intake\":{audioConditioning:{enabled:!0,maxGain:2.5,noiseGateAttenuation:0,noiseGateThreshold:0.004,targetLevel:0.08},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:12,pingInterval:30000,reconnect:!0},sttLifecycle:\"turn-scoped\",turnDetection:{qualityProfile:\"accent-heavy\",profile:\"long-form\"}},\"noisy-room\":{audioConditioning:{enabled:!0,maxGain:3,noiseGateAttenuation:0.12,noiseGateThreshold:0.006,targetLevel:0.085},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:14,pingInterval:45000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"noisy-room\",profile:\"long-form\",silenceMs:2100,speechThreshold:0.02,transcriptStabilityMs:1650}},\"pstn-balanced\":{audioConditioning:{enabled:!0,maxGain:2.8,noiseGateAttenuation:0.07,noiseGateThreshold:0.005,targetLevel:0.08},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:14,pingInterval:45000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"noisy-room\",profile:\"long-form\",silenceMs:660,speechThreshold:0.012,transcriptStabilityMs:300}},\"pstn-fast\":{audioConditioning:{enabled:!0,maxGain:2.75,noiseGateAttenuation:0.06,noiseGateThreshold:0.005,targetLevel:0.08},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:14,pingInterval:45000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"noisy-room\",profile:\"long-form\",silenceMs:620,speechThreshold:0.012,transcriptStabilityMs:280}},reliability:{audioConditioning:{enabled:!0,maxGain:2.9,noiseGateAttenuation:0.08,noiseGateThreshold:0.005,targetLevel:0.08},capture:{channelCount:1,sampleRateHz:16000},connection:{maxReconnectAttempts:14,pingInterval:45000,reconnect:!0},sttLifecycle:\"continuous\",turnDetection:{qualityProfile:\"noisy-room\",profile:\"long-form\"}}},Le=(e=\"default\")=>{let n=nn[e];return{audioConditioning:Ve(n.audioConditioning),capture:{channelCount:n.capture?.channelCount??1,sampleRateHz:n.capture?.sampleRateHz??16000},connection:{...n.connection},name:e,sttLifecycle:n.sttLifecycle??\"continuous\",turnDetection:we(n.turnDetection)}};var on=(e)=>({assistantAudio:[...e.assistantAudio],assistantTexts:[...e.assistantTexts],call:e.call,error:e.error,isConnected:e.isConnected,isRecording:!1,partial:e.partial,reconnect:e.reconnect,recordingError:null,sessionId:e.sessionId,sessionMetadata:e.sessionMetadata,scenarioId:e.scenarioId,status:e.status,turns:[...e.turns]}),m=(e,n={})=>{let t=Le(n.preset),o=Ie(e,{...t.connection,...n.connection}),r=null,i=on(o),c=new Set,l=()=>{for(let C of c)C()},g=()=>{if(i={...i,assistantAudio:[...o.assistantAudio],assistantTexts:[...o.assistantTexts],call:o.call,error:o.error,isConnected:o.isConnected,partial:o.partial,reconnect:o.reconnect,sessionId:o.sessionId,sessionMetadata:o.sessionMetadata,scenarioId:o.scenarioId,status:o.status,turns:[...o.turns]},n.autoStopOnComplete!==!1&&i.status===\"completed\"&&i.isRecording)r?.stop(),r=null,i={...i,isRecording:!1};l()},y=o.subscribe(g);g();let d=()=>{if(r)return r;return r=ge({channelCount:n.capture?.channelCount??t.capture.channelCount,onLevel:n.capture?.onLevel,onAudio:(C)=>{if(n.capture?.onAudio){n.capture.onAudio(C,o.sendAudio);return}o.sendAudio(C)},sampleRateHz:n.capture?.sampleRateHz??t.capture.sampleRateHz}),r},h=()=>{r?.stop(),r=null,i={...i,isRecording:!1},l()},a=async()=>{if(i.isRecording)return;try{i={...i,recordingError:null},l(),await d().start(),i={...i,isRecording:!0},l()}catch(C){throw r=null,i={...i,isRecording:!1,recordingError:C instanceof Error?C.message:String(C)},l(),C}};return{bindHTMX(C){return de(o,C)},callControl:(C)=>o.callControl(C),close:()=>{y(),h(),o.close()},endTurn:()=>o.endTurn(),get error(){return i.error},getServerSnapshot:()=>i,getSnapshot:()=>i,get isConnected(){return i.isConnected},get isRecording(){return i.isRecording},get partial(){return i.partial},get recordingError(){return i.recordingError},get reconnect(){return i.reconnect},sendAudio:(C)=>o.sendAudio(C),simulateDisconnect:()=>o.simulateDisconnect(),get sessionId(){return i.sessionId},get sessionMetadata(){return i.sessionMetadata},get scenarioId(){return i.scenarioId},startRecording:a,get status(){return i.status},stopRecording:h,subscribe:(C)=>{return c.add(C),()=>{c.delete(C)}},toggleRecording:async()=>{if(i.isRecording){h();return}await a()},get turns(){return i.turns},get assistantTexts(){return i.assistantTexts},get assistantAudio(){return i.assistantAudio},get call(){return i.call}}};var tn=()=>({activeSourceCount:0,error:null,isActive:!1,isPlaying:!1,lastInterruptLatencyMs:void 0,lastPlaybackStopLatencyMs:void 0,processedChunkCount:0,queuedChunkCount:0}),cn=()=>{if(typeof window>\"u\")return typeof AudioContext>\"u\"?void 0:AudioContext;return window.AudioContext??window.webkitAudioContext},rn=(e,n)=>{let t=n.format;if(t.container!==\"raw\"||t.encoding!==\"pcm_s16le\")throw Error(`Unsupported assistant audio format: ${t.container}/${t.encoding}`);let o=n.chunk,r=Math.max(1,t.channels),i=Math.floor(o.byteLength/2),c=Math.max(1,Math.floor(i/r)),l=e.createBuffer(r,c,t.sampleRateHz),g=new DataView(o.buffer,o.byteOffset,o.byteLength);for(let y=0;y<r;y+=1){let d=l.getChannelData(y);for(let h=0;h<c;h+=1){let M=(h*r+y)*2;if(M+1>=o.byteLength){d[h]=0;continue}d[h]=g.getInt16(M,!0)/32768}}return l},j=(e,n={})=>{let t=new Set,o=new Set,r=(n.lookaheadMs??15)/1000,i=tn(),c=null,l=null,g=0,y=Promise.resolve(),d=null,h=null,a=null,M=null,C=()=>{for(let A of t)A()},I=(A)=>{i={...i,...A},C()},w=()=>{if(i.error!==null)I({error:null})},R=()=>{if(M!==null)clearTimeout(M),M=null},u=(A)=>{R(),d=null,I({activeSourceCount:o.size,isPlaying:!1,lastInterruptLatencyMs:A,lastPlaybackStopLatencyMs:i.lastPlaybackStopLatencyMs??A}),a?.(),a=null,h=null},O=(A)=>{if(!A)return 0;return Math.max(0,((A.baseLatency??0)+(A.outputLatency??0))*1000)},U=(A)=>{if(!l)return;let f=1;if(l.gain.setValueAtTime){l.gain.setValueAtTime(f,A?.currentTime??0);return}l.gain.value=f},s=(A)=>{if(!l)return;let f=0;if(l.gain.setValueAtTime){l.gain.setValueAtTime(f,A?.currentTime??0);return}l.gain.value=f},S=()=>{if(d===null||o.size>0)return;u(Date.now()-d)},L=async()=>{if(c)return c;if(n.createAudioContext)c=n.createAudioContext();else{let A=cn();if(!A)throw Error(\"Assistant audio playback requires AudioContext support.\");c=new A}if(c.createGain)l=c.createGain(),l.connect?.(c.destination);return g=c.currentTime,c},X=async(A)=>{let f=await L(),E=rn(f,A),V=f.createBufferSource();V.buffer=E,V.connect(l??f.destination),V.onended=()=>{o.delete(V),V.disconnect?.(),I({activeSourceCount:o.size,isPlaying:o.size>0&&i.isActive}),S()};let Y=Math.max(f.currentTime+r,g);g=Y+E.duration,o.add(V),I({activeSourceCount:o.size,isPlaying:!0}),V.start(Y)},_=(A)=>{for(let f of[...o])f.stop?.();if(g=c?c.currentTime:0,A?.forceClear){for(let f of o)f.disconnect?.();o.clear(),S()}},W=async()=>{if(!i.isActive)return;let A=e.assistantAudio.slice(i.processedChunkCount);if(A.length===0)return;try{w();for(let f of A)await X(f);I({processedChunkCount:e.assistantAudio.length,queuedChunkCount:i.queuedChunkCount+A.length})}catch(f){I({error:f instanceof Error?f.message:String(f)})}},P=()=>{return y=y.then(()=>W(),()=>W()),y},$=e.subscribe(()=>{if(n.autoStart&&!i.isActive&&e.assistantAudio.length>0){N.start();return}if(i.isActive)P()}),N={close:async()=>{if($(),_({forceClear:!0}),R(),a?.(),a=null,h=null,d=null,c&&c.state!==\"closed\")await c.close();c=null,l?.disconnect?.(),l=null,g=0,I({activeSourceCount:0,isActive:!1,isPlaying:!1})},get activeSourceCount(){return i.activeSourceCount},get error(){return i.error},getSnapshot:()=>i,get isActive(){return i.isActive},get isPlaying(){return i.isPlaying},interrupt:async()=>{let A=Date.now(),f=await L();d=A,s(f);let E=Date.now()-A+O(f);if(I({isActive:!1,isPlaying:o.size>0,lastPlaybackStopLatencyMs:E}),o.size===0){u(E);return}if(!h)h=new Promise((V)=>{a=V});R(),M=setTimeout(()=>{for(let V of o)V.disconnect?.();o.clear(),u(Date.now()-A)},250),_(),await h},get lastInterruptLatencyMs(){return i.lastInterruptLatencyMs},get lastPlaybackStopLatencyMs(){return i.lastPlaybackStopLatencyMs},pause:async()=>{if(!c){I({activeSourceCount:0,isActive:!1,isPlaying:!1});return}await c.suspend(),I({activeSourceCount:o.size,isActive:!1,isPlaying:!1})},get processedChunkCount(){return i.processedChunkCount},get queuedChunkCount(){return i.queuedChunkCount},start:async()=>{try{w();let A=await L();if(U(A),A.state===\"suspended\")await A.resume();I({activeSourceCount:o.size,isActive:!0,isPlaying:A.state===\"running\"}),await P()}catch(A){throw I({error:A instanceof Error?A.message:String(A),isActive:!1,isPlaying:!1}),A}},subscribe:(A)=>{return t.add(A),()=>{t.delete(A)}}};return N};var sn=()=>`barge-in:${Date.now()}:${crypto.randomUUID?.()??Math.random().toString(36).slice(2)}`,ln=(e,n)=>{let t=e.filter((c)=>c.status===\"stopped\"),o=t.map((c)=>c.latencyMs).filter((c)=>typeof c===\"number\"),r=t.filter((c)=>typeof c.latencyMs===\"number\"&&c.latencyMs>n).length,i=t.length-r;return{averageLatencyMs:o.length>0?Math.round(o.reduce((c,l)=>c+l,0)/o.length):void 0,events:[...e],failed:r,lastEvent:e.at(-1),passed:i,status:e.length===0?\"empty\":r>0?\"fail\":t.length===0?\"warn\":\"pass\",thresholdMs:n,total:t.length}},ue=(e={})=>{let n=new Set,t=e.thresholdMs??250,o=e.fetch??globalThis.fetch,r=[],i=()=>{for(let g of n)g()},c=(g)=>{if(!e.path||typeof o!==\"function\")return;o(e.path,{body:JSON.stringify(g),headers:{\"Content-Type\":\"application/json\"},method:\"POST\"}).catch(()=>{})},l=(g,y)=>{let d={at:Date.now(),id:sn(),latencyMs:y.latencyMs,playbackStopLatencyMs:y.playbackStopLatencyMs,reason:y.reason,sessionId:y.sessionId,status:g,thresholdMs:t};return r.push(d),c(d),i(),d};return{getSnapshot:()=>ln(r,t),recordRequested:(g)=>l(\"requested\",g),recordSkipped:(g)=>l(\"skipped\",g),recordStopped:(g)=>l(\"stopped\",g),subscribe:(g)=>{return n.add(g),()=>{n.delete(g)}}}};var an=0.08,dn=(e,n={})=>(n.enabled??!0)&&e>=(n.interruptThreshold??an),oe=(e,n,t={})=>{let o=e.partial,r=(c)=>{if(!n.isPlaying||t.enabled===!1){t.monitor?.recordSkipped({reason:c,sessionId:e.sessionId});return}t.monitor?.recordRequested({reason:c,sessionId:e.sessionId}),n.interrupt().then(()=>{t.monitor?.recordStopped({latencyMs:n.lastInterruptLatencyMs,playbackStopLatencyMs:n.lastPlaybackStopLatencyMs,reason:c,sessionId:e.sessionId})})},i=e.subscribe(()=>{if(t.interruptOnPartial===!1){o=e.partial;return}if(!o&&e.partial)r(\"partial-transcript\");o=e.partial});return{close:()=>{i()},handleLevel:(c)=>{if(dn(c,t))r(\"input-level\")},sendAudio:(c)=>{r(\"manual-audio\"),e.sendAudio(c)}}};var se=48,gn=320,An=88,hn=\"Guided test\",yn=\"General recording\",Cn=\"Pick a scenario to begin the demo.\",fn=\"I can walk you through a short guided voice test.\",Tn=\"I can capture one freeform recording and confirm that it landed.\",Sn=\"Choose a scenario to begin. Guided test asks follow-up prompts. General recording just captures what you say.\",Mn=\"Click Start general recording to capture one freeform answer.\",_e=\"Speak freely. When you pause, the recording will be captured.\",re=\"Recording saved. Start again if you want another capture.\",Ee=\"Guided test complete. Review the saved summary below.\",Pe=\"All prompts are covered. You can stop the microphone or keep speaking for extra detail.\",In=\"Ready. Start guided test or general recording to begin.\",Vn=\"Live. Answer the prompt, then click Stop microphone when finished.\",Re=[\"Start with a quick introduction about who you are.\",\"Now describe what you are trying to do or test.\",\"Finish with any detail that feels blocked, risky, or unclear.\"],De=(e,n,t)=>Math.min(t,Math.max(n,e)),q=(e)=>e.replaceAll(\"&\",\"&amp;\").replaceAll(\"<\",\"&lt;\").replaceAll(\">\",\"&gt;\").replaceAll('\"',\"&quot;\").replaceAll(\"'\",\"&#39;\"),te=(e,n)=>{let t=e[n];if(typeof t===\"string\"&&t.trim())return t;return null},ie=(e)=>{if(typeof e===\"string\"&&e.trim())return e;if(e instanceof Error&&e.message.trim())return e.message;if(e&&typeof e===\"object\"){let n=e,t=te(n,\"message\")??te(n,\"reason\")??te(n,\"description\");if(t)return t;if(\"error\"in n)return ie(n.error);if(\"cause\"in n)return ie(n.cause);try{return JSON.stringify(e)}catch{}}return\"Unexpected error\"},wn=(e)=>{let n=[e.status];if(e.attempts>0||e.maxAttempts>0)n.push(`${e.attempts}/${e.maxAttempts} attempts`);if(e.nextAttemptAt){let t=Math.max(0,e.nextAttemptAt-Date.now());n.push(`retry in ${Math.ceil(t/100)/10}s`)}return n.join(\" \u00B7 \")},v=(e=se)=>Array.from({length:e},()=>0),be=(e,n,t=se)=>{let o=e.slice(-(t-1));o.push(De(n,0,1));while(o.length<t)o.unshift(0);return o},Ln=(e,n=gn,t=An)=>{let o=e.length>1?e:v(se),r=n/(o.length-1),i=t/2,c=t*0.34;if(Math.max(...o,0)<=0.015)return`M 0 ${i} L ${n} ${i}`;let g=o.map((d,h)=>{let a=h*0.76,M=Math.sin(a)*0.78+Math.sin(a*0.41)*0.22,C=d*c,I=r*h,w=De(i+M*C,8,t-8);return{x:I,y:w}});if(g.length===0)return`M 0 ${i} L ${n} ${i}`;let y=`M ${g[0]?.x??0} ${g[0]?.y??i}`;for(let d=1;d<g.length;d+=1){let h=g[d-1],a=g[d];if(!h||!a)continue;let M=(h.x+a.x)/2;y+=` Q ${M} ${h.y} ${a.x} ${a.y}`}return y},un=(e)=>{if(!e)return Re;try{let n=JSON.parse(e);if(Array.isArray(n)){let t=n.filter((o)=>typeof o===\"string\").map((o)=>o.trim()).filter(Boolean);if(t.length>0)return t}}catch{}return Re},ce=(e)=>{if(!e)return;let n=Number(e);return Number.isFinite(n)?n:void 0},Rn=(e,n,t)=>{let o=n?document.querySelector(n):e.querySelector(n??\"\");return o instanceof t?o:null},x=(e,n,t,o)=>{let r=n?document.querySelector(n):null;if(r instanceof t)return r;let i=e.querySelector(`#${o}`);if(i instanceof t)return i;throw Error(`Voice HTMX bootstrap could not find the required element \"${o}\".`)},bn=(e)=>{if(!e.mode)return Cn;if(!e.hasStarted)return e.mode===\"guided\"?fn:Tn;if(e.status===\"completed\")return e.mode===\"guided\"?Ee:re;if(e.mode===\"general\")return _e;return e.guidedPrompts[e.turnCount]??Pe},_n=(e)=>{if(!e.mode)return Sn;if(e.status===\"completed\")return e.mode===\"guided\"?Ee:re;if(!e.hasStarted)return e.mode===\"guided\"?`Click Start guided test to begin. First prompt: ${e.guidedPrompts[0]??\"Answer the first prompt.\"}`:Mn;if(e.mode===\"general\")return e.turnCount===0?_e:re;return e.guidedPrompts[e.turnCount]??Pe},En=(e)=>{let n=e.dataset.voiceGuidedPath,t=e.dataset.voiceGeneralPath;if(!n||!t)throw Error(\"Voice HTMX bootstrap requires data-voice-guided-path and data-voice-general-path.\");let o=un(e.dataset.voiceGuidedPrompts),r=e.dataset.voiceGuidedLabel??hn,i=e.dataset.voiceGeneralLabel??yn,c=e.dataset.voiceReconnectReportPath,l=e.dataset.voiceBargeInPath,g=l?ue({path:l,thresholdMs:ce(e.dataset.voiceBargeInThresholdMs)}):null,y=ce(e.dataset.voiceBargeInRecentWindowMs)??4000,d=ce(e.dataset.voiceBargeInSpeechThreshold)??0.04,h=x(document,e.dataset.voiceSync,HTMLElement,\"voice-htmx-sync\"),a=x(e,e.dataset.voiceConnection,HTMLElement,\"metric-connection\"),M=x(e,e.dataset.voiceError,HTMLElement,\"status-error\"),C=x(e,e.dataset.voiceMicrophone,HTMLElement,\"status-mic\"),I=x(e,e.dataset.voicePrompt,HTMLElement,\"status-prompt\"),w=Rn(e,e.dataset.voiceReconnect,HTMLElement),R=x(e,e.dataset.voiceChat,HTMLElement,\"chat-list\"),u=x(e,e.dataset.voiceStartGuided,HTMLButtonElement,\"start-guided\"),O=x(e,e.dataset.voiceStartGeneral,HTMLButtonElement,\"start-general\"),U=x(e,e.dataset.voiceStop,HTMLButtonElement,\"stop-mic\"),s=x(e,e.dataset.voiceMonitor,HTMLElement,\"voice-monitor\"),S=x(e,e.dataset.voiceMonitorCopy,HTMLElement,\"voice-monitor-copy\"),L=x(e,e.dataset.voiceWaveGlow,SVGPathElement,\"voice-wave-glow\"),X=x(e,e.dataset.voiceWavePath,SVGPathElement,\"voice-wave-path\"),_=null,W={general:!1,guided:!1},P=!1,$=null,N=v(),A=null,f=null,E=m(n,{capture:{onAudio:(T,G)=>{if(A){A.sendAudio(T);return}G(T)},onLevel:(T)=>{A?.handleLevel(T),N=be(N,T),F()}},connection:{reconnectReportPath:c},preset:\"guided-intake\"}),V=m(t,{capture:{onAudio:(T,G)=>{if(f){f.sendAudio(T);return}G(T)},onLevel:(T)=>{f?.handleLevel(T),N=be(N,T),F()}},connection:{reconnectReportPath:c},preset:\"dictation\"}),Y=E.bindHTMX({element:h}),xe=V.bindHTMX({element:h}),J=j(E),Q=j(V);A=oe(E,J,{interruptThreshold:d,monitor:g??void 0}),f=oe(V,Q,{interruptThreshold:d,monitor:g??void 0});let z=()=>_===\"general\"?V:E,Dn=()=>_===\"general\"?Q:J,F=()=>{let T=Ln(N);L.setAttribute(\"d\",T),X.setAttribute(\"d\",T),S.innerHTML=`<span class=\"voice-live-dot\"></span>${P?\"Microphone live\":\"Microphone idle\"}`,S.classList.toggle(\"is-live\",P),s.classList.toggle(\"is-live\",P)},k=()=>{let T=z(),G=(_?W[_]:!1)||T.turns.length>0,ae=T.status;if(a.textContent=T.isConnected?\"Connected\":\"Waiting\",M.textContent=$||T.error||\"None\",w)w.textContent=wn(T.reconnect);C.textContent=P?Vn:In,I.textContent=_n({guidedPrompts:o,hasStarted:G,mode:_,status:ae,turnCount:T.turns.length}),u.hidden=P,O.hidden=P,U.hidden=!P,R.innerHTML=`<article class=\"voice-chat-message assistant\">\n <div class=\"voice-chat-role\">${q(_===\"general\"?i:_===\"guided\"?r:\"Voice demo\")}</div>\n <p class=\"voice-turn-text\">${q(bn({generalLabel:i,guidedLabel:r,guidedPrompts:o,hasStarted:G,mode:_,status:ae,turnCount:T.turns.length}))}</p>\n</article>${T.turns.map((p)=>`<div class=\"voice-chat-stack\">\n <article class=\"voice-chat-message user\">\n <div class=\"voice-chat-role\">You</div>\n <p class=\"voice-turn-text\">${q(p.text)}</p>\n </article>\n ${p.assistantText?`<article class=\"voice-chat-message assistant\">\n <div class=\"voice-chat-role\">${q(_===\"general\"?i:_===\"guided\"?r:\"Guide\")}</div>\n <p class=\"voice-turn-text\">${q(p.assistantText)}</p>\n </article>`:\"\"}\n</div>`).join(\"\")}${T.partial?`<article class=\"voice-chat-message user pending\">\n <div class=\"voice-chat-role\">Speaking</div>\n <p class=\"voice-turn-text\">${q(T.partial)}</p>\n</article>`:\"\"}`,F()},Oe=()=>{z().stopRecording(),P=!1,$=null,N=v(),k()},le=async(T)=>{_=T,W={...W,[T]:!0};try{await z().startRecording(),$=null,P=!0,k()}catch(G){z().stopRecording(),P=!1,N=v(),$=ie(G),k()}};E.subscribe(()=>{if(E.assistantAudio.length>0)J.start().catch(()=>{});k()}),V.subscribe(()=>{if(V.assistantAudio.length>0)Q.start().catch(()=>{});k()}),u.addEventListener(\"click\",()=>{le(\"guided\")}),O.addEventListener(\"click\",()=>{le(\"general\")}),U.addEventListener(\"click\",()=>{Oe()}),e.addEventListener(\"absolute-voice-simulate-disconnect\",()=>{z().simulateDisconnect()}),window.addEventListener(\"beforeunload\",()=>{E.stopRecording(),V.stopRecording(),A?.close(),f?.close(),J.close(),Q.close(),Y(),xe(),E.close(),V.close()}),k()},Pn=()=>{if(typeof window>\"u\"||typeof document>\"u\")return;let e=Array.from(document.querySelectorAll(\"[data-voice-htmx]\"));for(let n of e)if(n instanceof HTMLElement)En(n)};Pn();export{Pn as initVoiceHTMX};\n";
@@ -0,0 +1,128 @@
1
+ import { Elysia } from "elysia";
2
+ import type { VoiceAgentTool } from "./agent";
3
+ import type { VoiceTraceEventStore } from "./trace";
4
+ import type { VoiceOnTurnObjectHandler, VoiceRouteResult, VoiceSessionRecord } from "./types";
5
+ import type { VoiceAssistantGuardrails } from "./assistant";
6
+ export type VoiceGuardrailStage = "assistant-output" | "handoff" | "model-input" | "tool-input" | "tool-output" | "transcript";
7
+ export type VoiceGuardrailSeverity = "block" | "warn";
8
+ export type VoiceGuardrailStatus = "blocked" | "pass" | "warn";
9
+ export type VoiceGuardrailRule = {
10
+ action?: VoiceGuardrailSeverity;
11
+ description?: string;
12
+ id: string;
13
+ label?: string;
14
+ match: RegExp | string | ((input: VoiceGuardrailEvaluationInput) => boolean | Promise<boolean>);
15
+ redactWith?: string;
16
+ stages?: VoiceGuardrailStage[];
17
+ };
18
+ export type VoiceGuardrailEvaluationInput = {
19
+ content?: unknown;
20
+ metadata?: Record<string, unknown>;
21
+ sessionId?: string;
22
+ stage: VoiceGuardrailStage;
23
+ turnId?: string;
24
+ };
25
+ export type VoiceGuardrailFinding = {
26
+ action: VoiceGuardrailSeverity;
27
+ description?: string;
28
+ label: string;
29
+ ruleId: string;
30
+ stage: VoiceGuardrailStage;
31
+ };
32
+ export type VoiceGuardrailDecision = {
33
+ allowed: boolean;
34
+ checkedAt: number;
35
+ content?: unknown;
36
+ findings: VoiceGuardrailFinding[];
37
+ redactedContent?: unknown;
38
+ sessionId?: string;
39
+ stage: VoiceGuardrailStage;
40
+ status: VoiceGuardrailStatus;
41
+ turnId?: string;
42
+ };
43
+ export type VoiceGuardrailPolicy = {
44
+ defaultAction?: VoiceGuardrailSeverity;
45
+ id: string;
46
+ label?: string;
47
+ rules: VoiceGuardrailRule[];
48
+ };
49
+ export type VoiceGuardrailReport = {
50
+ checkedAt: number;
51
+ decisions: VoiceGuardrailDecision[];
52
+ failed: number;
53
+ policies: Array<{
54
+ id: string;
55
+ label?: string;
56
+ rules: number;
57
+ }>;
58
+ status: "fail" | "pass" | "warn";
59
+ summary: {
60
+ blocked: number;
61
+ passed: number;
62
+ warned: number;
63
+ };
64
+ total: number;
65
+ };
66
+ export type VoiceGuardrailRoutesOptions = {
67
+ headers?: HeadersInit;
68
+ name?: string;
69
+ path?: string;
70
+ policies?: VoiceGuardrailPolicy[];
71
+ source?: ((input: VoiceGuardrailEvaluationInput) => Promise<VoiceGuardrailDecision | VoiceGuardrailReport> | VoiceGuardrailDecision | VoiceGuardrailReport) | VoiceGuardrailDecision | VoiceGuardrailReport;
72
+ trace?: VoiceTraceEventStore;
73
+ };
74
+ export type VoiceGuardrailRuntimeBlockInput<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = Parameters<VoiceOnTurnObjectHandler<TContext, TSession, TResult>>[0] & {
75
+ decision: VoiceGuardrailDecision;
76
+ stage: VoiceGuardrailStage;
77
+ };
78
+ export type VoiceGuardrailRuntimeOptions<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = {
79
+ blockResult?: (input: VoiceGuardrailRuntimeBlockInput<TContext, TSession, TResult>) => Promise<VoiceRouteResult<TResult>> | VoiceRouteResult<TResult>;
80
+ name?: string;
81
+ policies: VoiceGuardrailPolicy[];
82
+ trace?: VoiceTraceEventStore;
83
+ };
84
+ export type VoiceGuardrailRuntime<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = {
85
+ assistantGuardrails: VoiceAssistantGuardrails<TContext, TSession, TResult>;
86
+ evaluate: (input: VoiceGuardrailEvaluationInput) => Promise<VoiceGuardrailDecision>;
87
+ wrapTool: <TArgs extends Record<string, unknown>, TToolResult>(tool: VoiceAgentTool<TContext, TSession, TArgs, TToolResult, TResult>) => VoiceAgentTool<TContext, TSession, TArgs, TToolResult, TResult>;
88
+ wrapTools: (tools: Array<VoiceAgentTool<TContext, TSession, Record<string, unknown>, unknown, TResult>>) => Array<VoiceAgentTool<TContext, TSession, Record<string, unknown>, unknown, TResult>>;
89
+ };
90
+ export declare const evaluateVoiceGuardrailPolicy: (policy: VoiceGuardrailPolicy, input: VoiceGuardrailEvaluationInput) => Promise<VoiceGuardrailDecision>;
91
+ export declare const buildVoiceGuardrailReport: (input?: {
92
+ decisions: VoiceGuardrailDecision[];
93
+ policies?: VoiceGuardrailPolicy[];
94
+ }) => VoiceGuardrailReport;
95
+ export declare const createVoiceGuardrailPolicy: (policy: VoiceGuardrailPolicy) => VoiceGuardrailPolicy;
96
+ export declare const createVoiceGuardrailRuntime: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown>(options: VoiceGuardrailRuntimeOptions<TContext, TSession, TResult>) => VoiceGuardrailRuntime<TContext, TSession, TResult>;
97
+ export declare const voiceGuardrailPolicyPresets: {
98
+ supportSafeDefaults: VoiceGuardrailPolicy;
99
+ };
100
+ export declare const renderVoiceGuardrailMarkdown: (report: VoiceGuardrailReport) => string;
101
+ export declare const createVoiceGuardrailRoutes: (options?: VoiceGuardrailRoutesOptions) => Elysia<"", {
102
+ decorator: {};
103
+ store: {};
104
+ derive: {};
105
+ resolve: {};
106
+ }, {
107
+ typebox: {};
108
+ error: {};
109
+ }, {
110
+ schema: {};
111
+ standaloneSchema: {};
112
+ macro: {};
113
+ macroFn: {};
114
+ parser: {};
115
+ response: {};
116
+ }, {}, {
117
+ derive: {};
118
+ resolve: {};
119
+ schema: {};
120
+ standaloneSchema: {};
121
+ response: {};
122
+ }, {
123
+ derive: {};
124
+ resolve: {};
125
+ schema: {};
126
+ standaloneSchema: {};
127
+ response: {};
128
+ }>;
package/dist/handoff.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { VoiceHandoffAction, VoiceHandoffAdapter, VoiceHandoffConfig, VoiceHandoffDeliveryStore, VoiceHandoffInput, VoiceHandoffResult, VoiceSessionRecord, StoredVoiceHandoffDelivery } from './types';
1
+ import type { VoiceHandoffAction, VoiceHandoffAdapter, VoiceHandoffConfig, VoiceHandoffDeliveryStore, VoiceHandoffInput, VoiceHandoffResult, VoiceSessionRecord, StoredVoiceHandoffDelivery } from "./types";
2
2
  type MaybePromise<T> = T | Promise<T>;
3
3
  export type VoiceHandoffDelivery = VoiceHandoffResult & {
4
4
  adapterId: string;
@@ -8,16 +8,16 @@ export type VoiceHandoffDeliveryRecord<TContext = unknown, TSession extends Voic
8
8
  export type VoiceHandoffFanoutResult = {
9
9
  action: VoiceHandoffAction;
10
10
  deliveries: Record<string, VoiceHandoffDelivery>;
11
- status: VoiceHandoffResult['status'];
11
+ status: VoiceHandoffResult["status"];
12
12
  };
13
- export type VoiceHandoffDeliveryRecordInput<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = Omit<VoiceHandoffInput<TContext, TSession, TResult>, 'api'> & {
13
+ export type VoiceHandoffDeliveryRecordInput<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = Omit<VoiceHandoffInput<TContext, TSession, TResult>, "api"> & {
14
14
  id?: string;
15
15
  };
16
16
  export type VoiceQueuedHandoffDeliveryOptions<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = {
17
17
  adapters: VoiceHandoffAdapter<TContext, TSession, TResult>[];
18
- api: VoiceHandoffInput<TContext, TSession, TResult>['api'];
18
+ api: VoiceHandoffInput<TContext, TSession, TResult>["api"];
19
19
  delivery: VoiceHandoffDeliveryRecord<TContext, TSession, TResult>;
20
- failMode?: VoiceHandoffConfig<TContext, TSession, TResult>['failMode'];
20
+ failMode?: VoiceHandoffConfig<TContext, TSession, TResult>["failMode"];
21
21
  };
22
22
  export type VoiceWebhookHandoffAdapterOptions<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = {
23
23
  actions?: VoiceHandoffAction[];
@@ -26,7 +26,7 @@ export type VoiceWebhookHandoffAdapterOptions<TContext = unknown, TSession exten
26
26
  headers?: Record<string, string>;
27
27
  id: string;
28
28
  kind?: string;
29
- method?: 'POST' | 'PUT' | 'PATCH';
29
+ method?: "POST" | "PUT" | "PATCH";
30
30
  signingSecret?: string;
31
31
  timeoutMs?: number;
32
32
  url: string;
@@ -1,6 +1,6 @@
1
- import { Elysia } from 'elysia';
2
- import type { StoredVoiceTraceEvent, VoiceTraceEventStore } from './trace';
3
- export type VoiceHandoffHealthStatus = 'delivered' | 'failed' | 'skipped';
1
+ import { Elysia } from "elysia";
2
+ import type { StoredVoiceTraceEvent, VoiceTraceEventStore } from "./trace";
3
+ export type VoiceHandoffHealthStatus = "delivered" | "failed" | "skipped";
4
4
  export type VoiceHandoffHealthDelivery = {
5
5
  adapterId: string;
6
6
  adapterKind?: string;
@@ -31,8 +31,8 @@ export type VoiceHandoffHealthSummaryOptions = {
31
31
  events?: StoredVoiceTraceEvent[];
32
32
  limit?: number;
33
33
  q?: string;
34
- replayHref?: false | string | ((event: Omit<VoiceHandoffHealthEvent, 'replayHref'>) => string);
35
- status?: VoiceHandoffHealthStatus | 'all';
34
+ replayHref?: false | string | ((event: Omit<VoiceHandoffHealthEvent, "replayHref">) => string);
35
+ status?: VoiceHandoffHealthStatus | "all";
36
36
  store?: VoiceTraceEventStore;
37
37
  };
38
38
  export type VoiceHandoffHealthHTMLHandlerOptions = VoiceHandoffHealthSummaryOptions & {
package/dist/htmx.d.ts CHANGED
@@ -1,4 +1,4 @@
1
- import type { VoiceHTMXConfig, VoiceHTMXRenderConfig, VoiceHTMXRenderInput, VoiceHTMXTargets, VoiceSessionRecord } from './types';
1
+ import type { VoiceHTMXConfig, VoiceHTMXRenderConfig, VoiceHTMXRenderInput, VoiceHTMXTargets, VoiceSessionRecord } from "./types";
2
2
  type ResolvedVoiceHTMXRenderConfig<TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown> = Required<VoiceHTMXRenderConfig<TSession, TResult>>;
3
3
  export declare const resolveVoiceHTMXTargets: (custom?: Partial<VoiceHTMXTargets>) => VoiceHTMXTargets;
4
4
  export declare const resolveVoiceHTMXRenderers: <TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown>(custom?: VoiceHTMXConfig<TSession, TResult>) => ResolvedVoiceHTMXRenderConfig<TSession, TResult>;
@@ -0,0 +1,119 @@
1
+ import { Elysia } from "elysia";
2
+ import { type VoiceOperationsRecord, type VoiceOperationsRecordOptions } from "./operationsRecord";
3
+ import type { VoiceIncidentRecoveryOutcomeReport } from "./incidentTimeline";
4
+ import { type VoiceTraceRedactionConfig } from "./trace";
5
+ export type VoiceIncidentBundleFormat = "json" | "markdown";
6
+ export type VoiceIncidentBundle = {
7
+ auditMarkdown?: string;
8
+ exportedAt: number;
9
+ formatVersion: 1;
10
+ markdown: string;
11
+ record: VoiceOperationsRecord;
12
+ recoveryOutcomes?: VoiceIncidentRecoveryOutcomeReport;
13
+ redacted: boolean;
14
+ sessionId: string;
15
+ summary: VoiceIncidentBundleSummary;
16
+ traceMarkdown: string;
17
+ };
18
+ export type StoredVoiceIncidentBundleArtifact = {
19
+ bundle: VoiceIncidentBundle;
20
+ createdAt: number;
21
+ expiresAt?: number;
22
+ id: string;
23
+ metadata?: Record<string, unknown>;
24
+ redacted: boolean;
25
+ sessionId: string;
26
+ };
27
+ export type VoiceIncidentBundleStoreFilter = {
28
+ expiredAt?: number;
29
+ sessionId?: string;
30
+ };
31
+ export type VoiceIncidentBundleStore<TArtifact extends StoredVoiceIncidentBundleArtifact = StoredVoiceIncidentBundleArtifact> = {
32
+ get: (id: string) => Promise<TArtifact | undefined> | TArtifact | undefined;
33
+ list: (filter?: VoiceIncidentBundleStoreFilter) => Promise<TArtifact[]> | TArtifact[];
34
+ remove: (id: string) => Promise<void> | void;
35
+ set: (id: string, artifact: TArtifact) => Promise<void> | void;
36
+ };
37
+ export type VoiceIncidentBundleSummary = {
38
+ auditEvents: number;
39
+ durationMs?: number;
40
+ errors: number;
41
+ handoffs: number;
42
+ providers: string[];
43
+ sessionId: string;
44
+ status: VoiceOperationsRecord["status"];
45
+ tools: number;
46
+ traceEvents: number;
47
+ turns: number;
48
+ };
49
+ export type VoiceIncidentBundleOptions = VoiceOperationsRecordOptions & {
50
+ redact?: VoiceTraceRedactionConfig;
51
+ recoveryOutcomes?: VoiceIncidentRecoveryOutcomeReport;
52
+ title?: string;
53
+ };
54
+ export type VoiceIncidentBundleRoutesOptions = Omit<VoiceIncidentBundleOptions, "sessionId"> & {
55
+ headers?: HeadersInit;
56
+ markdownPath?: false | string;
57
+ name?: string;
58
+ path?: string;
59
+ };
60
+ export type VoiceIncidentBundleArtifactOptions = {
61
+ createdAt?: number;
62
+ expiresAt?: number;
63
+ id?: string;
64
+ metadata?: Record<string, unknown>;
65
+ ttlMs?: number;
66
+ };
67
+ export type VoiceIncidentBundleRetentionOptions = {
68
+ before?: number;
69
+ beforeOrAt?: number;
70
+ dryRun?: boolean;
71
+ expiredAt?: number;
72
+ keepNewest?: number;
73
+ limit?: number;
74
+ store: VoiceIncidentBundleStore;
75
+ };
76
+ export type VoiceIncidentBundleRetentionReport = {
77
+ deleted: StoredVoiceIncidentBundleArtifact[];
78
+ deletedCount: number;
79
+ deletedIds: string[];
80
+ dryRun: boolean;
81
+ scannedCount: number;
82
+ };
83
+ export declare const createVoiceMemoryIncidentBundleStore: <TArtifact extends StoredVoiceIncidentBundleArtifact = StoredVoiceIncidentBundleArtifact>() => VoiceIncidentBundleStore<TArtifact>;
84
+ export declare const createStoredVoiceIncidentBundleArtifact: (bundle: VoiceIncidentBundle, options?: VoiceIncidentBundleArtifactOptions) => StoredVoiceIncidentBundleArtifact;
85
+ export declare const saveVoiceIncidentBundleArtifact: (input: {
86
+ bundle: VoiceIncidentBundle;
87
+ options?: VoiceIncidentBundleArtifactOptions;
88
+ store: VoiceIncidentBundleStore;
89
+ }) => Promise<StoredVoiceIncidentBundleArtifact>;
90
+ export declare const pruneVoiceIncidentBundleArtifacts: (options: VoiceIncidentBundleRetentionOptions) => Promise<VoiceIncidentBundleRetentionReport>;
91
+ export declare const buildVoiceIncidentBundle: (options: VoiceIncidentBundleOptions) => Promise<VoiceIncidentBundle>;
92
+ export declare const createVoiceIncidentBundleRoutes: (options: VoiceIncidentBundleRoutesOptions) => Elysia<"", {
93
+ decorator: {};
94
+ store: {};
95
+ derive: {};
96
+ resolve: {};
97
+ }, {
98
+ typebox: {};
99
+ error: {};
100
+ }, {
101
+ schema: {};
102
+ standaloneSchema: {};
103
+ macro: {};
104
+ macroFn: {};
105
+ parser: {};
106
+ response: {};
107
+ }, {}, {
108
+ derive: {};
109
+ resolve: {};
110
+ schema: {};
111
+ standaloneSchema: {};
112
+ response: {};
113
+ }, {
114
+ derive: {};
115
+ resolve: {};
116
+ schema: {};
117
+ standaloneSchema: {};
118
+ response: {};
119
+ }>;