@absolutejs/voice 0.0.22-beta.9 → 0.0.22-beta.90

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 (114) hide show
  1. package/README.md +205 -0
  2. package/dist/agent.d.ts +2 -0
  3. package/dist/angular/index.d.ts +6 -0
  4. package/dist/angular/index.js +833 -43
  5. package/dist/angular/voice-app-kit-status.service.d.ts +12 -0
  6. package/dist/angular/voice-ops-status.component.d.ts +15 -0
  7. package/dist/angular/voice-provider-capabilities.service.d.ts +12 -0
  8. package/dist/angular/voice-provider-status.service.d.ts +12 -0
  9. package/dist/angular/voice-routing-status.service.d.ts +11 -0
  10. package/dist/angular/voice-stream.service.d.ts +2 -0
  11. package/dist/angular/voice-turn-quality.service.d.ts +12 -0
  12. package/dist/angular/voice-workflow-status.service.d.ts +12 -0
  13. package/dist/appKit.d.ts +98 -0
  14. package/dist/assistantHealth.d.ts +81 -0
  15. package/dist/client/actions.d.ts +22 -0
  16. package/dist/client/appKitStatus.d.ts +19 -0
  17. package/dist/client/connection.d.ts +3 -0
  18. package/dist/client/htmxBootstrap.js +44 -2
  19. package/dist/client/index.d.ts +26 -0
  20. package/dist/client/index.js +1290 -2
  21. package/dist/client/opsStatusWidget.d.ts +40 -0
  22. package/dist/client/providerCapabilities.d.ts +19 -0
  23. package/dist/client/providerCapabilitiesWidget.d.ts +32 -0
  24. package/dist/client/providerSimulationControls.d.ts +33 -0
  25. package/dist/client/providerSimulationControlsWidget.d.ts +20 -0
  26. package/dist/client/providerStatus.d.ts +19 -0
  27. package/dist/client/providerStatusWidget.d.ts +32 -0
  28. package/dist/client/routingStatus.d.ts +19 -0
  29. package/dist/client/routingStatusWidget.d.ts +28 -0
  30. package/dist/client/turnQuality.d.ts +19 -0
  31. package/dist/client/turnQualityWidget.d.ts +32 -0
  32. package/dist/client/workflowStatus.d.ts +19 -0
  33. package/dist/diagnosticsRoutes.d.ts +44 -0
  34. package/dist/evalRoutes.d.ts +213 -0
  35. package/dist/handoff.d.ts +54 -0
  36. package/dist/handoffHealth.d.ts +94 -0
  37. package/dist/index.d.ts +62 -7
  38. package/dist/index.js +10382 -2574
  39. package/dist/modelAdapters.d.ts +75 -0
  40. package/dist/openaiTTS.d.ts +18 -0
  41. package/dist/opsConsoleRoutes.d.ts +77 -0
  42. package/dist/opsWebhook.d.ts +126 -0
  43. package/dist/outcomeContract.d.ts +112 -0
  44. package/dist/postgresStore.d.ts +2 -0
  45. package/dist/productionReadiness.d.ts +111 -0
  46. package/dist/providerAdapters.d.ts +48 -0
  47. package/dist/providerCapabilities.d.ts +92 -0
  48. package/dist/providerHealth.d.ts +79 -0
  49. package/dist/qualityRoutes.d.ts +76 -0
  50. package/dist/queue.d.ts +61 -0
  51. package/dist/react/VoiceOpsStatus.d.ts +6 -0
  52. package/dist/react/VoiceProviderCapabilities.d.ts +6 -0
  53. package/dist/react/VoiceProviderSimulationControls.d.ts +5 -0
  54. package/dist/react/VoiceProviderStatus.d.ts +6 -0
  55. package/dist/react/VoiceRoutingStatus.d.ts +6 -0
  56. package/dist/react/VoiceTurnQuality.d.ts +6 -0
  57. package/dist/react/index.d.ts +13 -0
  58. package/dist/react/index.js +1884 -11
  59. package/dist/react/useVoiceAppKitStatus.d.ts +8 -0
  60. package/dist/react/useVoiceController.d.ts +2 -0
  61. package/dist/react/useVoiceProviderCapabilities.d.ts +8 -0
  62. package/dist/react/useVoiceProviderSimulationControls.d.ts +10 -0
  63. package/dist/react/useVoiceProviderStatus.d.ts +8 -0
  64. package/dist/react/useVoiceRoutingStatus.d.ts +8 -0
  65. package/dist/react/useVoiceStream.d.ts +2 -0
  66. package/dist/react/useVoiceTurnQuality.d.ts +8 -0
  67. package/dist/react/useVoiceWorkflowStatus.d.ts +8 -0
  68. package/dist/resilienceRoutes.d.ts +142 -0
  69. package/dist/sessionReplay.d.ts +175 -0
  70. package/dist/sqliteStore.d.ts +2 -0
  71. package/dist/svelte/createVoiceAppKitStatus.d.ts +8 -0
  72. package/dist/svelte/createVoiceOpsStatus.d.ts +9 -0
  73. package/dist/svelte/createVoiceProviderCapabilities.d.ts +10 -0
  74. package/dist/svelte/createVoiceProviderSimulationControls.d.ts +11 -0
  75. package/dist/svelte/createVoiceProviderStatus.d.ts +10 -0
  76. package/dist/svelte/createVoiceRoutingStatus.d.ts +10 -0
  77. package/dist/svelte/createVoiceTurnQuality.d.ts +10 -0
  78. package/dist/svelte/createVoiceWorkflowStatus.d.ts +8 -0
  79. package/dist/svelte/index.d.ts +8 -0
  80. package/dist/svelte/index.js +1330 -3
  81. package/dist/telephony/contract.d.ts +61 -0
  82. package/dist/telephony/matrix.d.ts +97 -0
  83. package/dist/telephony/plivo.d.ts +254 -0
  84. package/dist/telephony/telnyx.d.ts +247 -0
  85. package/dist/telephony/twilio.d.ts +132 -0
  86. package/dist/telephonyOutcome.d.ts +201 -0
  87. package/dist/testing/index.d.ts +2 -0
  88. package/dist/testing/index.js +2543 -14
  89. package/dist/testing/ioProviderSimulator.d.ts +41 -0
  90. package/dist/testing/providerSimulator.d.ts +44 -0
  91. package/dist/toolContract.d.ts +130 -0
  92. package/dist/toolRuntime.d.ts +50 -0
  93. package/dist/trace.d.ts +1 -1
  94. package/dist/traceTimeline.d.ts +93 -0
  95. package/dist/turnQuality.d.ts +94 -0
  96. package/dist/types.d.ts +84 -2
  97. package/dist/vue/VoiceOpsStatus.d.ts +30 -0
  98. package/dist/vue/VoiceProviderCapabilities.d.ts +51 -0
  99. package/dist/vue/VoiceProviderSimulationControls.d.ts +88 -0
  100. package/dist/vue/VoiceProviderStatus.d.ts +51 -0
  101. package/dist/vue/VoiceRoutingStatus.d.ts +51 -0
  102. package/dist/vue/VoiceTurnQuality.d.ts +51 -0
  103. package/dist/vue/index.d.ts +13 -0
  104. package/dist/vue/index.js +1934 -25
  105. package/dist/vue/useVoiceAppKitStatus.d.ts +9 -0
  106. package/dist/vue/useVoiceProviderCapabilities.d.ts +9 -0
  107. package/dist/vue/useVoiceProviderSimulationControls.d.ts +24 -0
  108. package/dist/vue/useVoiceProviderStatus.d.ts +9 -0
  109. package/dist/vue/useVoiceRoutingStatus.d.ts +8 -0
  110. package/dist/vue/useVoiceStream.d.ts +2 -0
  111. package/dist/vue/useVoiceTurnQuality.d.ts +9 -0
  112. package/dist/vue/useVoiceWorkflowStatus.d.ts +9 -0
  113. package/dist/workflowContract.d.ts +91 -0
  114. package/package.json +1 -1
@@ -29,11 +29,86 @@ export type GeminiVoiceAssistantModelOptions = {
29
29
  baseUrl?: string;
30
30
  fetch?: typeof fetch;
31
31
  maxOutputTokens?: number;
32
+ maxRetries?: number;
32
33
  model?: string;
33
34
  onUsage?: (usage: Record<string, unknown>) => Promise<void> | void;
34
35
  temperature?: number;
35
36
  };
37
+ export type VoiceProviderRouterEvent<TProvider extends string = string> = {
38
+ at: number;
39
+ attempt: number;
40
+ elapsedMs: number;
41
+ error?: string;
42
+ fallbackProvider?: TProvider;
43
+ latencyBudgetMs?: number;
44
+ provider: TProvider;
45
+ providerHealth?: VoiceProviderRouterProviderHealth<TProvider>;
46
+ rateLimited?: boolean;
47
+ recovered?: boolean;
48
+ selectedProvider: TProvider;
49
+ suppressionRemainingMs?: number;
50
+ suppressedUntil?: number;
51
+ status: 'error' | 'fallback' | 'success';
52
+ timedOut?: boolean;
53
+ };
54
+ export type VoiceProviderRouterFallbackMode = 'never' | 'provider-error' | 'rate-limit';
55
+ export type VoiceProviderRouterStrategy = 'balanced' | 'ordered' | 'prefer-cheapest' | 'prefer-fastest' | 'prefer-selected' | 'quality-first';
56
+ export type VoiceProviderRouterPolicyPreset = 'balanced' | 'cost-cap' | 'cost-first' | 'latency-first' | 'quality-first';
57
+ export type VoiceProviderRouterPolicyWeights = {
58
+ cost?: number;
59
+ latencyMs?: number;
60
+ priority?: number;
61
+ quality?: number;
62
+ };
63
+ export type VoiceProviderRouterPolicy<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TProvider extends string = string> = VoiceProviderRouterStrategy | VoiceProviderRouterPolicyPreset | {
64
+ allowProviders?: readonly TProvider[] | ((input: VoiceAgentModelInput<TContext, TSession>) => readonly TProvider[] | Promise<readonly TProvider[]>);
65
+ fallbackMode?: VoiceProviderRouterFallbackMode;
66
+ maxCost?: number;
67
+ maxLatencyMs?: number;
68
+ minQuality?: number;
69
+ scoreProvider?: (provider: TProvider, profile: VoiceProviderRouterProviderProfile | undefined) => number;
70
+ strategy?: VoiceProviderRouterStrategy;
71
+ weights?: VoiceProviderRouterPolicyWeights;
72
+ };
73
+ export type VoiceProviderRouterProviderProfile = {
74
+ cost?: number;
75
+ latencyMs?: number;
76
+ priority?: number;
77
+ quality?: number;
78
+ timeoutMs?: number;
79
+ };
80
+ export declare const resolveVoiceProviderRoutingPolicyPreset: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TProvider extends string = string>(preset: VoiceProviderRouterPolicyPreset, options?: Omit<Extract<VoiceProviderRouterPolicy<TContext, TSession, TProvider>, Record<string, unknown>>, "strategy">) => Extract<VoiceProviderRouterPolicy<TContext, TSession, TProvider>, Record<string, unknown>>;
81
+ export type VoiceProviderRouterHealthOptions = {
82
+ cooldownMs?: number;
83
+ failureThreshold?: number;
84
+ now?: () => number;
85
+ rateLimitCooldownMs?: number;
86
+ };
87
+ export type VoiceProviderRouterProviderHealth<TProvider extends string = string> = {
88
+ consecutiveFailures: number;
89
+ lastFailureAt?: number;
90
+ lastRateLimitedAt?: number;
91
+ provider: TProvider;
92
+ status: 'healthy' | 'suppressed';
93
+ suppressedUntil?: number;
94
+ };
95
+ export type VoiceProviderRouterOptions<TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown, TProvider extends string = string> = {
96
+ allowProviders?: readonly TProvider[] | ((input: VoiceAgentModelInput<TContext, TSession>) => readonly TProvider[] | Promise<readonly TProvider[]>);
97
+ fallback?: TProvider[] | ((input: VoiceAgentModelInput<TContext, TSession>) => readonly TProvider[] | Promise<readonly TProvider[]>);
98
+ fallbackMode?: VoiceProviderRouterFallbackMode;
99
+ isProviderError?: (error: unknown, provider: TProvider) => boolean;
100
+ isRateLimitError?: (error: unknown, provider: TProvider) => boolean;
101
+ isTimeoutError?: (error: unknown, provider: TProvider) => boolean;
102
+ onProviderEvent?: (event: VoiceProviderRouterEvent<TProvider>, input: VoiceAgentModelInput<TContext, TSession>) => Promise<void> | void;
103
+ policy?: VoiceProviderRouterPolicy<TContext, TSession, TProvider>;
104
+ providerHealth?: boolean | VoiceProviderRouterHealthOptions;
105
+ providerProfiles?: Partial<Record<TProvider, VoiceProviderRouterProviderProfile>>;
106
+ timeoutMs?: number;
107
+ providers: Partial<Record<TProvider, VoiceAgentModel<TContext, TSession, TResult>>>;
108
+ selectProvider?: (input: VoiceAgentModelInput<TContext, TSession>) => TProvider | undefined | Promise<TProvider | undefined>;
109
+ };
36
110
  export declare const createJSONVoiceAssistantModel: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown>(options: VoiceJSONAssistantModelOptions<TContext, TSession, TResult>) => VoiceAgentModel<TContext, TSession, TResult>;
111
+ export declare const createVoiceProviderRouter: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown, TProvider extends string = string>(options: VoiceProviderRouterOptions<TContext, TSession, TResult, TProvider>) => VoiceAgentModel<TContext, TSession, TResult>;
37
112
  export declare const createOpenAIVoiceAssistantModel: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown>(options: OpenAIVoiceAssistantModelOptions) => VoiceAgentModel<TContext, TSession, TResult>;
38
113
  export declare const createAnthropicVoiceAssistantModel: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown>(options: AnthropicVoiceAssistantModelOptions) => VoiceAgentModel<TContext, TSession, TResult>;
39
114
  export declare const createGeminiVoiceAssistantModel: <TContext = unknown, TSession extends VoiceSessionRecord = VoiceSessionRecord, TResult = unknown>(options: GeminiVoiceAssistantModelOptions) => VoiceAgentModel<TContext, TSession, TResult>;
@@ -0,0 +1,18 @@
1
+ import type { TTSAdapter, TTSAdapterOpenOptions, VoiceLexiconEntry } from './types';
2
+ export type OpenAIVoiceTTSVoice = 'alloy' | 'ash' | 'ballad' | 'cedar' | 'coral' | 'echo' | 'fable' | 'marin' | 'nova' | 'onyx' | 'sage' | 'shimmer' | 'verse' | (string & {});
3
+ export type OpenAIVoiceTTSOptions = {
4
+ apiKey: string;
5
+ baseUrl?: string;
6
+ fetch?: typeof fetch;
7
+ instructions?: string | ((input: {
8
+ lexicon?: VoiceLexiconEntry[];
9
+ sessionId: string;
10
+ text: string;
11
+ }) => Promise<string | undefined> | string | undefined);
12
+ model?: 'gpt-4o-mini-tts' | 'tts-1' | 'tts-1-hd' | (string & {});
13
+ speed?: number;
14
+ voice?: OpenAIVoiceTTSVoice | {
15
+ id: string;
16
+ };
17
+ };
18
+ export declare const createOpenAIVoiceTTS: (options: OpenAIVoiceTTSOptions) => TTSAdapter<TTSAdapterOpenOptions>;
@@ -0,0 +1,77 @@
1
+ import { Elysia } from 'elysia';
2
+ import { type VoiceQualityReport } from './qualityRoutes';
3
+ import { type VoiceRoutingEvent } from './resilienceRoutes';
4
+ import { type VoiceSessionListItem } from './sessionReplay';
5
+ import { summarizeVoiceTrace, type VoiceTraceEventStore } from './trace';
6
+ export type VoiceOpsConsoleLink = {
7
+ description?: string;
8
+ href: string;
9
+ label: string;
10
+ statusHref?: string;
11
+ };
12
+ export type VoiceOpsConsoleReport = {
13
+ checkedAt: number;
14
+ eventCount: number;
15
+ handoffs: {
16
+ failed: number;
17
+ total: number;
18
+ };
19
+ links: VoiceOpsConsoleLink[];
20
+ providers: {
21
+ degraded: number;
22
+ healthy: number;
23
+ total: number;
24
+ };
25
+ quality: VoiceQualityReport;
26
+ recentRoutingEvents: VoiceRoutingEvent[];
27
+ recentSessions: VoiceSessionListItem[];
28
+ sessions: {
29
+ failed: number;
30
+ healthy: number;
31
+ total: number;
32
+ };
33
+ trace: ReturnType<typeof summarizeVoiceTrace>;
34
+ };
35
+ export type VoiceOpsConsoleRoutesOptions = {
36
+ headers?: HeadersInit;
37
+ links?: VoiceOpsConsoleLink[];
38
+ llmProviders?: readonly string[];
39
+ name?: string;
40
+ path?: string;
41
+ store: VoiceTraceEventStore;
42
+ sttProviders?: readonly string[];
43
+ title?: string;
44
+ ttsProviders?: readonly string[];
45
+ };
46
+ export declare const buildVoiceOpsConsoleReport: (options: VoiceOpsConsoleRoutesOptions) => Promise<VoiceOpsConsoleReport>;
47
+ export declare const renderVoiceOpsConsoleHTML: (report: VoiceOpsConsoleReport, options?: {
48
+ title?: string;
49
+ }) => string;
50
+ export declare const createVoiceOpsConsoleRoutes: (options: VoiceOpsConsoleRoutesOptions) => Elysia<"", {
51
+ decorator: {};
52
+ store: {};
53
+ derive: {};
54
+ resolve: {};
55
+ }, {
56
+ typebox: {};
57
+ error: {};
58
+ }, {
59
+ schema: {};
60
+ standaloneSchema: {};
61
+ macro: {};
62
+ macroFn: {};
63
+ parser: {};
64
+ response: {};
65
+ }, {}, {
66
+ derive: {};
67
+ resolve: {};
68
+ schema: {};
69
+ standaloneSchema: {};
70
+ response: {};
71
+ }, {
72
+ derive: {};
73
+ resolve: {};
74
+ schema: {};
75
+ standaloneSchema: {};
76
+ response: {};
77
+ }>;
@@ -0,0 +1,126 @@
1
+ import { Elysia } from 'elysia';
2
+ import type { StoredVoiceIntegrationEvent, VoiceIntegrationEventType } from './ops';
3
+ import type { VoiceIntegrationHTTPSinkOptions, VoiceIntegrationSink } from './opsSinks';
4
+ type MaybePromise<T> = T | Promise<T>;
5
+ export type VoiceOpsWebhookLinkResolver = string | ((input: {
6
+ event: StoredVoiceIntegrationEvent;
7
+ }) => MaybePromise<string | undefined>);
8
+ export type VoiceOpsWebhookEntity = {
9
+ disposition?: string;
10
+ outcome?: string;
11
+ priority?: string;
12
+ queue?: string;
13
+ reviewId?: string;
14
+ scenarioId?: string;
15
+ sessionId?: string;
16
+ status?: string;
17
+ target?: string;
18
+ taskId?: string;
19
+ };
20
+ export type VoiceOpsWebhookEnvelope = {
21
+ entity: VoiceOpsWebhookEntity;
22
+ event: {
23
+ createdAt: number;
24
+ id: string;
25
+ payload: Record<string, unknown>;
26
+ type: VoiceIntegrationEventType;
27
+ };
28
+ links?: {
29
+ event?: string;
30
+ replay?: string;
31
+ review?: string;
32
+ task?: string;
33
+ };
34
+ schemaVersion: 1;
35
+ source: 'absolutejs-voice';
36
+ };
37
+ export type VoiceOpsWebhookSinkOptions = Omit<VoiceIntegrationHTTPSinkOptions<VoiceOpsWebhookEnvelope>, 'body'> & {
38
+ baseUrl?: string;
39
+ eventHref?: VoiceOpsWebhookLinkResolver;
40
+ replayHref?: VoiceOpsWebhookLinkResolver;
41
+ reviewHref?: VoiceOpsWebhookLinkResolver;
42
+ taskHref?: VoiceOpsWebhookLinkResolver;
43
+ };
44
+ export type VoiceOpsWebhookVerificationResult = {
45
+ ok: true;
46
+ } | {
47
+ ok: false;
48
+ reason: 'invalid-signature' | 'missing-secret' | 'missing-signature' | 'missing-timestamp' | 'stale-timestamp' | 'unsupported-algorithm';
49
+ };
50
+ export type VoiceOpsWebhookReceiverRoutesOptions = {
51
+ onEnvelope?: (input: {
52
+ envelope: VoiceOpsWebhookEnvelope;
53
+ request: Request;
54
+ }) => MaybePromise<void>;
55
+ path?: string;
56
+ signingSecret?: string;
57
+ toleranceMs?: number;
58
+ };
59
+ export declare const createVoiceOpsWebhookEnvelope: (input: {
60
+ baseUrl?: string;
61
+ event: StoredVoiceIntegrationEvent;
62
+ eventHref?: VoiceOpsWebhookLinkResolver;
63
+ replayHref?: VoiceOpsWebhookLinkResolver;
64
+ reviewHref?: VoiceOpsWebhookLinkResolver;
65
+ taskHref?: VoiceOpsWebhookLinkResolver;
66
+ }) => Promise<VoiceOpsWebhookEnvelope>;
67
+ export declare const createVoiceOpsWebhookSink: (options: VoiceOpsWebhookSinkOptions) => VoiceIntegrationSink;
68
+ export declare const verifyVoiceOpsWebhookSignature: (input: {
69
+ body: string;
70
+ now?: number;
71
+ secret?: string;
72
+ signature?: string | null;
73
+ timestamp?: string | null;
74
+ toleranceMs?: number;
75
+ }) => Promise<VoiceOpsWebhookVerificationResult>;
76
+ export declare const createVoiceOpsWebhookReceiverRoutes: (options?: VoiceOpsWebhookReceiverRoutesOptions) => Elysia<"", {
77
+ decorator: {};
78
+ store: {};
79
+ derive: {};
80
+ resolve: {};
81
+ }, {
82
+ typebox: {};
83
+ error: {};
84
+ }, {
85
+ schema: {};
86
+ standaloneSchema: {};
87
+ macro: {};
88
+ macroFn: {};
89
+ parser: {};
90
+ response: {};
91
+ }, {
92
+ [x: string]: {
93
+ post: {
94
+ body: unknown;
95
+ params: {};
96
+ query: unknown;
97
+ headers: unknown;
98
+ response: {
99
+ 200: {
100
+ ok: boolean;
101
+ reason: "invalid-signature" | "missing-secret" | "missing-signature" | "missing-timestamp" | "stale-timestamp" | "unsupported-algorithm";
102
+ eventId?: undefined;
103
+ type?: undefined;
104
+ } | {
105
+ eventId: string;
106
+ ok: boolean;
107
+ type: VoiceIntegrationEventType;
108
+ reason?: undefined;
109
+ };
110
+ };
111
+ };
112
+ };
113
+ }, {
114
+ derive: {};
115
+ resolve: {};
116
+ schema: {};
117
+ standaloneSchema: {};
118
+ response: {};
119
+ }, {
120
+ derive: {};
121
+ resolve: {};
122
+ schema: {};
123
+ standaloneSchema: {};
124
+ response: {};
125
+ }>;
126
+ export {};
@@ -0,0 +1,112 @@
1
+ import { Elysia } from 'elysia';
2
+ import type { StoredVoiceHandoffDelivery, VoiceCallDisposition, VoiceHandoffAction, VoiceHandoffDeliveryStore, VoiceSessionRecord, VoiceSessionStore } from './types';
3
+ import type { StoredVoiceIntegrationEvent, StoredVoiceOpsTask, VoiceIntegrationEventType } from './ops';
4
+ import type { StoredVoiceCallReviewArtifact } from './testing/review';
5
+ export type VoiceOutcomeContractStatus = 'pass' | 'fail';
6
+ export type VoiceOutcomeContractDefinition = {
7
+ description?: string;
8
+ expectedDisposition?: VoiceCallDisposition;
9
+ id: string;
10
+ label?: string;
11
+ minSessions?: number;
12
+ minTasks?: number;
13
+ requireHandoffActions?: VoiceHandoffAction[];
14
+ requireIntegrationEvents?: VoiceIntegrationEventType[];
15
+ requireReview?: boolean;
16
+ requireTask?: boolean;
17
+ scenarioId?: string;
18
+ };
19
+ export type VoiceOutcomeContractIssue = {
20
+ code: string;
21
+ message: string;
22
+ };
23
+ export type VoiceOutcomeContractReport = {
24
+ contractId: string;
25
+ description?: string;
26
+ issues: VoiceOutcomeContractIssue[];
27
+ label?: string;
28
+ matched: {
29
+ handoffs: number;
30
+ integrationEvents: number;
31
+ reviews: number;
32
+ sessions: number;
33
+ tasks: number;
34
+ };
35
+ pass: boolean;
36
+ };
37
+ export type VoiceOutcomeContractSuiteReport = {
38
+ checkedAt: number;
39
+ contracts: VoiceOutcomeContractReport[];
40
+ failed: number;
41
+ passed: number;
42
+ status: VoiceOutcomeContractStatus;
43
+ total: number;
44
+ };
45
+ type ListStore<T> = {
46
+ list: () => Promise<T[]> | T[];
47
+ };
48
+ export type VoiceOutcomeContractOptions<TSession extends VoiceSessionRecord = VoiceSessionRecord> = {
49
+ contracts: VoiceOutcomeContractDefinition[];
50
+ events?: StoredVoiceIntegrationEvent[] | ListStore<StoredVoiceIntegrationEvent>;
51
+ handoffs?: StoredVoiceHandoffDelivery[] | VoiceHandoffDeliveryStore;
52
+ reviews?: StoredVoiceCallReviewArtifact[] | ListStore<StoredVoiceCallReviewArtifact>;
53
+ sessions?: TSession[] | VoiceSessionStore<TSession>;
54
+ tasks?: StoredVoiceOpsTask[] | ListStore<StoredVoiceOpsTask>;
55
+ };
56
+ export type VoiceOutcomeContractHTMLHandlerOptions<TSession extends VoiceSessionRecord = VoiceSessionRecord> = VoiceOutcomeContractOptions<TSession> & {
57
+ headers?: HeadersInit;
58
+ render?: (report: VoiceOutcomeContractSuiteReport) => string | Promise<string>;
59
+ title?: string;
60
+ };
61
+ export type VoiceOutcomeContractRoutesOptions<TSession extends VoiceSessionRecord = VoiceSessionRecord> = VoiceOutcomeContractHTMLHandlerOptions<TSession> & {
62
+ htmlPath?: false | string;
63
+ name?: string;
64
+ path?: string;
65
+ };
66
+ export declare const runVoiceOutcomeContractSuite: <TSession extends VoiceSessionRecord = VoiceSessionRecord>(options: VoiceOutcomeContractOptions<TSession>) => Promise<VoiceOutcomeContractSuiteReport>;
67
+ export declare const renderVoiceOutcomeContractHTML: (report: VoiceOutcomeContractSuiteReport, options?: {
68
+ title?: string;
69
+ }) => string;
70
+ export declare const createVoiceOutcomeContractJSONHandler: <TSession extends VoiceSessionRecord = VoiceSessionRecord>(options: VoiceOutcomeContractOptions<TSession>) => () => Promise<VoiceOutcomeContractSuiteReport>;
71
+ export declare const createVoiceOutcomeContractHTMLHandler: <TSession extends VoiceSessionRecord = VoiceSessionRecord>(options: VoiceOutcomeContractHTMLHandlerOptions<TSession>) => () => Promise<Response>;
72
+ export declare const createVoiceOutcomeContractRoutes: <TSession extends VoiceSessionRecord = VoiceSessionRecord>(options: VoiceOutcomeContractRoutesOptions<TSession>) => Elysia<"", {
73
+ decorator: {};
74
+ store: {};
75
+ derive: {};
76
+ resolve: {};
77
+ }, {
78
+ typebox: {};
79
+ error: {};
80
+ }, {
81
+ schema: {};
82
+ standaloneSchema: {};
83
+ macro: {};
84
+ macroFn: {};
85
+ parser: {};
86
+ response: {};
87
+ }, {
88
+ [x: string]: {
89
+ get: {
90
+ body: unknown;
91
+ params: {};
92
+ query: unknown;
93
+ headers: unknown;
94
+ response: {
95
+ 200: VoiceOutcomeContractSuiteReport;
96
+ };
97
+ };
98
+ };
99
+ }, {
100
+ derive: {};
101
+ resolve: {};
102
+ schema: {};
103
+ standaloneSchema: {};
104
+ response: {};
105
+ }, {
106
+ derive: {};
107
+ resolve: {};
108
+ schema: {};
109
+ standaloneSchema: {};
110
+ response: {};
111
+ }>;
112
+ export {};
@@ -1,6 +1,7 @@
1
1
  import { type StoredVoiceTraceEvent, type VoiceTraceSinkDeliveryRecord, type VoiceTraceSinkDeliveryStore, type VoiceTraceEventStore } from './trace';
2
2
  import type { StoredVoiceIntegrationEvent, StoredVoiceExternalObjectMap, StoredVoiceOpsTask, VoiceExternalObjectMapStore, VoiceIntegrationEventStore, VoiceOpsTaskStore } from './ops';
3
3
  import type { StoredVoiceCallReviewArtifact, VoiceCallReviewStore } from './testing/review';
4
+ import type { VoiceTelephonyWebhookIdempotencyStore } from './telephonyOutcome';
4
5
  import type { VoiceSessionRecord, VoiceSessionStore } from './types';
5
6
  export type VoicePostgresClient = {
6
7
  unsafe: <TRow extends Record<string, unknown> = Record<string, unknown>>(query: string, parameters?: unknown[]) => Promise<TRow[]>;
@@ -28,4 +29,5 @@ export declare const createVoicePostgresIntegrationEventStore: <TEvent extends S
28
29
  export declare const createVoicePostgresExternalObjectMapStore: <TMapping extends StoredVoiceExternalObjectMap = StoredVoiceExternalObjectMap>(options: VoicePostgresStoreOptions) => VoiceExternalObjectMapStore<TMapping>;
29
30
  export declare const createVoicePostgresTraceEventStore: <TEvent extends StoredVoiceTraceEvent = StoredVoiceTraceEvent>(options: VoicePostgresStoreOptions) => VoiceTraceEventStore<TEvent>;
30
31
  export declare const createVoicePostgresTraceSinkDeliveryStore: <TDelivery extends VoiceTraceSinkDeliveryRecord = VoiceTraceSinkDeliveryRecord>(options: VoicePostgresStoreOptions) => VoiceTraceSinkDeliveryStore<TDelivery>;
32
+ export declare const createVoicePostgresTelephonyWebhookIdempotencyStore: <TResult = unknown>(options: VoicePostgresStoreOptions) => VoiceTelephonyWebhookIdempotencyStore<TResult>;
31
33
  export declare const createVoicePostgresRuntimeStorage: <TSession extends VoiceSessionRecord = VoiceSessionRecord, TReview extends StoredVoiceCallReviewArtifact = StoredVoiceCallReviewArtifact, TTask extends StoredVoiceOpsTask = StoredVoiceOpsTask, TEvent extends StoredVoiceIntegrationEvent = StoredVoiceIntegrationEvent, TMapping extends StoredVoiceExternalObjectMap = StoredVoiceExternalObjectMap, TTrace extends StoredVoiceTraceEvent = StoredVoiceTraceEvent, TTraceDelivery extends VoiceTraceSinkDeliveryRecord = VoiceTraceSinkDeliveryRecord>(options: VoicePostgresStoreOptions) => VoicePostgresRuntimeStorage<TSession, TReview, TTask, TEvent, TMapping, TTrace, TTraceDelivery>;
@@ -0,0 +1,111 @@
1
+ import { Elysia } from 'elysia';
2
+ import { type VoiceTelephonyCarrierMatrixInput } from './telephony/matrix';
3
+ import type { VoiceTraceEventStore } from './trace';
4
+ export type VoiceProductionReadinessStatus = 'fail' | 'pass' | 'warn';
5
+ export type VoiceProductionReadinessAction = {
6
+ description?: string;
7
+ href: string;
8
+ label: string;
9
+ method?: 'GET' | 'POST';
10
+ };
11
+ export type VoiceProductionReadinessCheck = {
12
+ actions?: VoiceProductionReadinessAction[];
13
+ detail?: string;
14
+ href?: string;
15
+ label: string;
16
+ status: VoiceProductionReadinessStatus;
17
+ value?: number | string;
18
+ };
19
+ export type VoiceProductionReadinessReport = {
20
+ checkedAt: number;
21
+ checks: VoiceProductionReadinessCheck[];
22
+ links: {
23
+ carriers?: string;
24
+ handoffs?: string;
25
+ handoffRetry?: string;
26
+ quality?: string;
27
+ resilience?: string;
28
+ sessions?: string;
29
+ };
30
+ status: VoiceProductionReadinessStatus;
31
+ summary: {
32
+ carriers?: {
33
+ failing: number;
34
+ providers: number;
35
+ ready: number;
36
+ status: VoiceProductionReadinessStatus;
37
+ warnings: number;
38
+ };
39
+ handoffs: {
40
+ failed: number;
41
+ total: number;
42
+ };
43
+ providers: {
44
+ degraded: number;
45
+ total: number;
46
+ };
47
+ quality: {
48
+ status: 'fail' | 'pass';
49
+ };
50
+ routing: {
51
+ events: number;
52
+ sessions: number;
53
+ };
54
+ sessions: {
55
+ failed: number;
56
+ total: number;
57
+ };
58
+ };
59
+ };
60
+ export type VoiceProductionReadinessRoutesOptions = {
61
+ carriers?: false | readonly VoiceTelephonyCarrierMatrixInput[] | ((input: {
62
+ query: Record<string, unknown>;
63
+ request: Request;
64
+ }) => Promise<readonly VoiceTelephonyCarrierMatrixInput[]> | readonly VoiceTelephonyCarrierMatrixInput[]);
65
+ headers?: HeadersInit;
66
+ htmlPath?: false | string;
67
+ links?: VoiceProductionReadinessReport['links'];
68
+ llmProviders?: readonly string[];
69
+ name?: string;
70
+ path?: string;
71
+ render?: (report: VoiceProductionReadinessReport) => string | Promise<string>;
72
+ store: VoiceTraceEventStore;
73
+ sttProviders?: readonly string[];
74
+ title?: string;
75
+ ttsProviders?: readonly string[];
76
+ };
77
+ export declare const buildVoiceProductionReadinessReport: (options: VoiceProductionReadinessRoutesOptions, input?: {
78
+ query?: Record<string, unknown>;
79
+ request?: Request;
80
+ }) => Promise<VoiceProductionReadinessReport>;
81
+ export declare const renderVoiceProductionReadinessHTML: (report: VoiceProductionReadinessReport, options?: {
82
+ title?: string;
83
+ }) => string;
84
+ export declare const createVoiceProductionReadinessRoutes: (options: VoiceProductionReadinessRoutesOptions) => Elysia<"", {
85
+ decorator: {};
86
+ store: {};
87
+ derive: {};
88
+ resolve: {};
89
+ }, {
90
+ typebox: {};
91
+ error: {};
92
+ }, {
93
+ schema: {};
94
+ standaloneSchema: {};
95
+ macro: {};
96
+ macroFn: {};
97
+ parser: {};
98
+ response: {};
99
+ }, {}, {
100
+ derive: {};
101
+ resolve: {};
102
+ schema: {};
103
+ standaloneSchema: {};
104
+ response: {};
105
+ }, {
106
+ derive: {};
107
+ resolve: {};
108
+ schema: {};
109
+ standaloneSchema: {};
110
+ response: {};
111
+ }>;
@@ -0,0 +1,48 @@
1
+ import type { STTAdapter, STTAdapterOpenOptions, TTSAdapter, TTSAdapterOpenOptions } from './types';
2
+ import type { VoiceProviderRouterHealthOptions, VoiceProviderRouterProviderHealth, VoiceProviderRouterProviderProfile, VoiceProviderRouterPolicyPreset, VoiceProviderRouterPolicyWeights, VoiceProviderRouterStrategy } from './modelAdapters';
3
+ type MaybePromise<T> = T | Promise<T>;
4
+ type VoiceIOProviderKind = 'stt' | 'tts';
5
+ type VoiceIOProviderStatus = 'error' | 'fallback' | 'success';
6
+ export type VoiceIOProviderRouterEvent<TProvider extends string = string> = {
7
+ at: number;
8
+ attempt: number;
9
+ elapsedMs: number;
10
+ error?: string;
11
+ fallbackProvider?: TProvider;
12
+ kind: VoiceIOProviderKind;
13
+ latencyBudgetMs?: number;
14
+ operation: 'open' | 'send';
15
+ provider: TProvider;
16
+ providerHealth?: VoiceProviderRouterProviderHealth<TProvider>;
17
+ selectedProvider: TProvider;
18
+ status: VoiceIOProviderStatus;
19
+ suppressionRemainingMs?: number;
20
+ suppressedUntil?: number;
21
+ timedOut?: boolean;
22
+ };
23
+ export type VoiceIOProviderRouterPolicyConfig<TOpenOptions = unknown, TProvider extends string = string> = {
24
+ allowProviders?: readonly TProvider[] | ((input: TOpenOptions) => MaybePromise<readonly TProvider[]>);
25
+ maxCost?: number;
26
+ maxLatencyMs?: number;
27
+ minQuality?: number;
28
+ scoreProvider?: (provider: TProvider, profile: VoiceProviderRouterProviderProfile | undefined) => number;
29
+ strategy?: VoiceProviderRouterStrategy;
30
+ weights?: VoiceProviderRouterPolicyWeights;
31
+ };
32
+ export type VoiceIOProviderRouterPolicy<TOpenOptions = unknown, TProvider extends string = string> = VoiceProviderRouterStrategy | VoiceProviderRouterPolicyPreset | VoiceIOProviderRouterPolicyConfig<TOpenOptions, TProvider>;
33
+ export type VoiceIOProviderRouterOptions<TProvider extends string, TAdapter, TOpenOptions> = {
34
+ adapters: Partial<Record<TProvider, TAdapter>>;
35
+ fallback?: readonly TProvider[] | ((input: TOpenOptions) => MaybePromise<readonly TProvider[]>);
36
+ isProviderError?: (error: unknown, provider: TProvider) => boolean;
37
+ onProviderEvent?: (event: VoiceIOProviderRouterEvent<TProvider>, input: TOpenOptions) => Promise<void> | void;
38
+ policy?: VoiceIOProviderRouterPolicy<TOpenOptions, TProvider>;
39
+ providerHealth?: boolean | VoiceProviderRouterHealthOptions;
40
+ providerProfiles?: Partial<Record<TProvider, VoiceProviderRouterProviderProfile>>;
41
+ selectProvider?: (input: TOpenOptions) => MaybePromise<TProvider | undefined>;
42
+ timeoutMs?: number;
43
+ };
44
+ export type VoiceSTTProviderRouterOptions<TProvider extends string = string, TOptions extends STTAdapterOpenOptions = STTAdapterOpenOptions> = VoiceIOProviderRouterOptions<TProvider, STTAdapter<TOptions>, TOptions>;
45
+ export type VoiceTTSProviderRouterOptions<TProvider extends string = string, TOptions extends TTSAdapterOpenOptions = TTSAdapterOpenOptions> = VoiceIOProviderRouterOptions<TProvider, TTSAdapter<TOptions>, TOptions>;
46
+ export declare const createVoiceSTTProviderRouter: <TProvider extends string = string, TOptions extends STTAdapterOpenOptions = STTAdapterOpenOptions>(options: VoiceSTTProviderRouterOptions<TProvider, TOptions>) => STTAdapter<TOptions>;
47
+ export declare const createVoiceTTSProviderRouter: <TProvider extends string = string, TOptions extends TTSAdapterOpenOptions = TTSAdapterOpenOptions>(options: VoiceTTSProviderRouterOptions<TProvider, TOptions>) => TTSAdapter<TOptions>;
48
+ export {};