@hivegpt/hiveai-angular 0.0.587 → 0.0.589

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 (65) hide show
  1. package/README.md +0 -26
  2. package/bundles/hivegpt-hiveai-angular.umd.js +538 -3623
  3. package/bundles/hivegpt-hiveai-angular.umd.js.map +1 -1
  4. package/bundles/hivegpt-hiveai-angular.umd.min.js +1 -1
  5. package/bundles/hivegpt-hiveai-angular.umd.min.js.map +1 -1
  6. package/esm2015/hivegpt-hiveai-angular.js +5 -8
  7. package/esm2015/lib/components/NotificationSocket.js +22 -29
  8. package/esm2015/lib/components/bot.service.js +12 -18
  9. package/esm2015/lib/components/chat-drawer/chat-drawer.component.js +214 -2429
  10. package/esm2015/lib/components/chatbot/chatbot.component.js +5 -9
  11. package/esm2015/lib/components/conversation.service.js +5 -13
  12. package/esm2015/lib/components/socket-service.service.js +11 -21
  13. package/esm2015/lib/components/translations/translation.service.js +36 -38
  14. package/esm2015/lib/components/voice-agent/components/voice-agent-modal/voice-agent-modal.component.js +17 -35
  15. package/esm2015/lib/components/voice-agent/services/audio-analyzer.service.js +5 -11
  16. package/esm2015/lib/components/voice-agent/services/voice-agent.service.js +142 -215
  17. package/esm2015/lib/components/voice-agent/voice-agent.module.js +2 -10
  18. package/esm2015/lib/components/voice-agent/voice-modal-tokens.js +1 -1
  19. package/esm2015/lib/models/chat.js +2 -0
  20. package/esm2015/lib/utils/utils.js +2 -4
  21. package/esm2015/public-api.js +3 -2
  22. package/fesm2015/hivegpt-hiveai-angular.js +462 -3389
  23. package/fesm2015/hivegpt-hiveai-angular.js.map +1 -1
  24. package/hivegpt-hiveai-angular.d.ts +4 -7
  25. package/hivegpt-hiveai-angular.d.ts.map +1 -1
  26. package/hivegpt-hiveai-angular.metadata.json +1 -1
  27. package/lib/components/NotificationSocket.d.ts +3 -1
  28. package/lib/components/NotificationSocket.d.ts.map +1 -1
  29. package/lib/components/bot.service.d.ts +2 -1
  30. package/lib/components/bot.service.d.ts.map +1 -1
  31. package/lib/components/chat-drawer/chat-drawer.component.d.ts +52 -285
  32. package/lib/components/chat-drawer/chat-drawer.component.d.ts.map +1 -1
  33. package/lib/components/chatbot/chatbot.component.d.ts +1 -8
  34. package/lib/components/chatbot/chatbot.component.d.ts.map +1 -1
  35. package/lib/components/conversation.service.d.ts +2 -8
  36. package/lib/components/conversation.service.d.ts.map +1 -1
  37. package/lib/components/socket-service.service.d.ts +4 -3
  38. package/lib/components/socket-service.service.d.ts.map +1 -1
  39. package/lib/components/translations/translation.service.d.ts.map +1 -1
  40. package/lib/components/voice-agent/components/voice-agent-modal/voice-agent-modal.component.d.ts +4 -10
  41. package/lib/components/voice-agent/components/voice-agent-modal/voice-agent-modal.component.d.ts.map +1 -1
  42. package/lib/components/voice-agent/services/audio-analyzer.service.d.ts +0 -5
  43. package/lib/components/voice-agent/services/audio-analyzer.service.d.ts.map +1 -1
  44. package/lib/components/voice-agent/services/voice-agent.service.d.ts +9 -34
  45. package/lib/components/voice-agent/services/voice-agent.service.d.ts.map +1 -1
  46. package/lib/components/voice-agent/voice-agent.module.d.ts +0 -4
  47. package/lib/components/voice-agent/voice-agent.module.d.ts.map +1 -1
  48. package/lib/components/voice-agent/voice-modal-tokens.d.ts +0 -4
  49. package/lib/components/voice-agent/voice-modal-tokens.d.ts.map +1 -1
  50. package/lib/models/chat.d.ts +134 -0
  51. package/lib/models/chat.d.ts.map +1 -0
  52. package/lib/utils/utils.d.ts +1 -1
  53. package/lib/utils/utils.d.ts.map +1 -1
  54. package/package.json +2 -4
  55. package/public-api.d.ts +2 -1
  56. package/public-api.d.ts.map +1 -1
  57. package/esm2015/lib/components/voice-agent/services/daily-voice-client.service.js +0 -326
  58. package/esm2015/lib/components/voice-agent/services/websocket-voice-client.service.js +0 -95
  59. package/esm2015/lib/services/platform-token-refresh.service.js +0 -173
  60. package/lib/components/voice-agent/services/daily-voice-client.service.d.ts +0 -70
  61. package/lib/components/voice-agent/services/daily-voice-client.service.d.ts.map +0 -1
  62. package/lib/components/voice-agent/services/websocket-voice-client.service.d.ts +0 -49
  63. package/lib/components/voice-agent/services/websocket-voice-client.service.d.ts.map +0 -1
  64. package/lib/services/platform-token-refresh.service.d.ts +0 -59
  65. package/lib/services/platform-token-refresh.service.d.ts.map +0 -1
@@ -1,37 +1,18 @@
1
1
  import { __awaiter } from "tslib";
2
- import { isPlatformBrowser } from '@angular/common';
3
- import { Inject, Injectable, PLATFORM_ID } from '@angular/core';
4
- import { BehaviorSubject, combineLatest, Subject, Subscription, } from 'rxjs';
5
- import { filter, take, takeUntil } from 'rxjs/operators';
6
- import { PlatformTokenRefreshService } from '../../../services/platform-token-refresh.service';
2
+ import { Injectable } from '@angular/core';
3
+ import { BehaviorSubject, Subject } from 'rxjs';
4
+ import { PipecatClient, RTVIEvent, } from '@pipecat-ai/client-js';
5
+ import { WebSocketTransport } from '@pipecat-ai/websocket-transport';
7
6
  import { AudioAnalyzerService } from './audio-analyzer.service';
8
- import { WebSocketVoiceClientService } from './websocket-voice-client.service';
9
- import { DailyVoiceClientService } from './daily-voice-client.service';
10
7
  import * as i0 from "@angular/core";
11
8
  import * as i1 from "./audio-analyzer.service";
12
- import * as i2 from "./websocket-voice-client.service";
13
- import * as i3 from "./daily-voice-client.service";
14
- import * as i4 from "../../../services/platform-token-refresh.service";
15
- /**
16
- * Voice agent orchestrator. Coordinates WebSocket (signaling) and Daily.js (WebRTC audio).
17
- *
18
- * CRITICAL: This service must NEVER use Socket.IO or ngx-socket-io. Voice flow uses only:
19
- * - Native WebSocket (WebSocketVoiceClientService) for signaling (room_created, transcripts)
20
- * - Daily.js (DailyVoiceClientService) for WebRTC audio. Audio does NOT flow over WebSocket.
21
- *
22
- * - Maintains callState, statusText, duration, isMicMuted, isUserSpeaking, audioLevels
23
- * - Uses WebSocket for room_created and transcripts only (no audio)
24
- * - Uses Daily.js for all audio, mic, and real-time speaking detection
25
- */
26
9
  export class VoiceAgentService {
27
- constructor(audioAnalyzer, wsClient, dailyClient, platformTokenRefresh,
28
- /** `Object` not `object` — ngc metadata collection rejects the `object` type in DI params. */
29
- platformId) {
10
+ constructor(audioAnalyzer) {
30
11
  this.audioAnalyzer = audioAnalyzer;
31
- this.wsClient = wsClient;
32
- this.dailyClient = dailyClient;
33
- this.platformTokenRefresh = platformTokenRefresh;
34
- this.platformId = platformId;
12
+ this.client = null;
13
+ this.transport = null;
14
+ this.userMediaStream = null;
15
+ this.botAudioElement = null;
35
16
  this.callStateSubject = new BehaviorSubject('idle');
36
17
  this.statusTextSubject = new BehaviorSubject('');
37
18
  this.durationSubject = new BehaviorSubject('00:00');
@@ -42,9 +23,6 @@ export class VoiceAgentService {
42
23
  this.botTranscriptSubject = new Subject();
43
24
  this.callStartTime = 0;
44
25
  this.durationInterval = null;
45
- this.subscriptions = new Subscription();
46
- this.destroy$ = new Subject();
47
- this.hasAutoUnmutedAfterFirstAudio = false;
48
26
  this.callState$ = this.callStateSubject.asObservable();
49
27
  this.statusText$ = this.statusTextSubject.asObservable();
50
28
  this.duration$ = this.durationSubject.asObservable();
@@ -53,29 +31,45 @@ export class VoiceAgentService {
53
31
  this.audioLevels$ = this.audioLevelsSubject.asObservable();
54
32
  this.userTranscript$ = this.userTranscriptSubject.asObservable();
55
33
  this.botTranscript$ = this.botTranscriptSubject.asObservable();
56
- // Waveform visualization only - do NOT use for speaking state
57
- this.subscriptions.add(this.audioAnalyzer.audioLevels$.subscribe((levels) => this.audioLevelsSubject.next(levels)));
58
- }
59
- ngOnDestroy() {
60
- this.destroy$.next();
61
- this.subscriptions.unsubscribe();
62
- this.disconnect();
34
+ this.audioAnalyzer.audioLevels$.subscribe(levels => {
35
+ this.audioLevelsSubject.next(levels);
36
+ });
37
+ this.audioAnalyzer.isUserSpeaking$.subscribe(isSpeaking => {
38
+ this.isUserSpeakingSubject.next(isSpeaking);
39
+ if (isSpeaking && this.callStateSubject.value === 'connected') {
40
+ this.callStateSubject.next('listening');
41
+ }
42
+ else if (!isSpeaking && this.callStateSubject.value === 'listening') {
43
+ this.callStateSubject.next('connected');
44
+ }
45
+ });
63
46
  }
64
47
  /** Reset to idle state (e.g. when modal opens so user can click Start Call). */
65
48
  resetToIdle() {
66
49
  if (this.callStateSubject.value === 'idle')
67
50
  return;
68
- this.stopDurationTimer();
51
+ if (this.durationInterval) {
52
+ clearInterval(this.durationInterval);
53
+ this.durationInterval = null;
54
+ }
69
55
  this.audioAnalyzer.stop();
70
- this.wsClient.disconnect();
71
- // Fire-and-forget: Daily disconnect is async; connect() will await if needed
72
- void this.dailyClient.disconnect();
56
+ this.client = null;
57
+ this.transport = null;
58
+ if (this.userMediaStream) {
59
+ this.userMediaStream.getTracks().forEach(track => track.stop());
60
+ this.userMediaStream = null;
61
+ }
62
+ if (this.botAudioElement) {
63
+ this.botAudioElement.pause();
64
+ this.botAudioElement.srcObject = null;
65
+ this.botAudioElement = null;
66
+ }
73
67
  this.callStateSubject.next('idle');
74
68
  this.statusTextSubject.next('');
75
69
  this.durationSubject.next('0:00');
76
- this.hasAutoUnmutedAfterFirstAudio = false;
77
70
  }
78
- connect(apiUrl, token, botId, conversationId, apiKey, eventToken, eventId, eventUrl, domainAuthority, usersApiUrl) {
71
+ connect(apiUrl, token, botId, conversationId, apiKey, eventToken, eventUrl, domainAuthority) {
72
+ var _a;
79
73
  return __awaiter(this, void 0, void 0, function* () {
80
74
  if (this.callStateSubject.value !== 'idle') {
81
75
  console.warn('Call already in progress');
@@ -84,97 +78,48 @@ export class VoiceAgentService {
84
78
  try {
85
79
  this.callStateSubject.next('connecting');
86
80
  this.statusTextSubject.next('Connecting...');
87
- // Request mic permission before provisioning backend room flow.
88
- yield this.dailyClient.ensureMicrophoneAccess();
89
- let accessToken = token;
90
- // Align with chat drawer token handling: always delegate to
91
- // PlatformTokenRefreshService when we have a usersApiUrl, so it can
92
- // fall back to stored tokens even if the caller passed an empty token.
93
- if (usersApiUrl && isPlatformBrowser(this.platformId)) {
94
- try {
95
- const ensured = yield this.platformTokenRefresh
96
- .ensureValidAccessToken(token, usersApiUrl)
97
- .pipe(take(1))
98
- .toPromise();
99
- if (ensured === null || ensured === void 0 ? void 0 : ensured.accessToken) {
100
- accessToken = ensured.accessToken;
101
- }
102
- }
103
- catch (e) {
104
- console.warn('[HiveGpt Voice] Token refresh before connect failed', e);
105
- }
106
- }
107
81
  const baseUrl = apiUrl.replace(/\/$/, '');
108
- const postUrl = `${baseUrl}/ai/ask-voice`;
109
- const headers = {
110
- 'Content-Type': 'application/json',
111
- Authorization: `Bearer ${accessToken}`,
112
- 'x-api-key': apiKey,
113
- 'hive-bot-id': botId,
114
- 'domain-authority': domainAuthority,
115
- eventUrl,
116
- eventId,
117
- eventToken,
118
- 'ngrok-skip-browser-warning': 'true',
119
- };
120
- // POST to get ws_url for signaling
121
- const res = yield fetch(postUrl, {
122
- method: 'POST',
82
+ const connectUrl = `${baseUrl}/ai/ask-voice`;
83
+ const headers = new Headers();
84
+ headers.set('Authorization', `Bearer ${token}`);
85
+ // Do not set Content-Type here — the Pipecat client already sets "application/json" once; adding it again produces "application/json, application/json"
86
+ headers.set('domain-authority', domainAuthority);
87
+ headers.set('eventtoken', eventToken);
88
+ headers.set('eventurl', eventUrl);
89
+ headers.set('hive-bot-id', botId);
90
+ headers.set('x-api-key', apiKey);
91
+ const startBotParams = {
92
+ endpoint: connectUrl,
123
93
  headers,
124
- body: JSON.stringify({
94
+ requestData: {
125
95
  bot_id: botId,
126
96
  conversation_id: conversationId,
127
97
  voice: 'alloy',
128
- }),
98
+ },
99
+ };
100
+ this.transport = new WebSocketTransport();
101
+ this.client = new PipecatClient({
102
+ transport: this.transport,
103
+ enableMic: true,
104
+ enableCam: false,
129
105
  });
130
- if (!res.ok) {
131
- throw new Error(`HTTP ${res.status}`);
132
- }
133
- const json = yield res.json();
134
- const wsUrl = json === null || json === void 0 ? void 0 : json.rn_ws_url;
135
- if (!wsUrl || typeof wsUrl !== 'string') {
136
- throw new Error('No ws_url in response');
106
+ this.setupEventHandlers();
107
+ this.botAudioElement = new Audio();
108
+ this.botAudioElement.autoplay = true;
109
+ yield this.client.startBotAndConnect(startBotParams);
110
+ const tracks = this.client.tracks();
111
+ if ((_a = tracks === null || tracks === void 0 ? void 0 : tracks.local) === null || _a === void 0 ? void 0 : _a.audio) {
112
+ this.userMediaStream = new MediaStream([tracks.local.audio]);
113
+ this.audioAnalyzer.start(this.userMediaStream);
137
114
  }
138
- // Subscribe to room_created BEFORE connecting to avoid race
139
- this.wsClient.roomCreated$
140
- .pipe(take(1), takeUntil(this.destroy$))
141
- .subscribe((roomUrl) => __awaiter(this, void 0, void 0, function* () {
142
- try {
143
- yield this.onRoomCreated(roomUrl);
144
- }
145
- catch (err) {
146
- console.error('Daily join failed:', err);
147
- if (this.isMicPermissionError(err)) {
148
- yield this.cleanupMediaAndSignal();
149
- this.callStateSubject.next('idle');
150
- this.durationSubject.next('0:00');
151
- this.statusTextSubject.next('Microphone permission is required');
152
- return;
153
- }
154
- this.callStateSubject.next('ended');
155
- this.statusTextSubject.next('Connection failed');
156
- yield this.disconnect();
157
- }
158
- }));
159
- // Forward transcripts from WebSocket
160
- this.subscriptions.add(this.wsClient.userTranscript$
161
- .pipe(takeUntil(this.destroy$))
162
- .subscribe((t) => this.userTranscriptSubject.next(t)));
163
- this.subscriptions.add(this.wsClient.botTranscript$
164
- .pipe(takeUntil(this.destroy$))
165
- .subscribe((t) => this.botTranscriptSubject.next(t)));
166
- // Connect signaling WebSocket (no audio over WS)
167
- this.wsClient.connect(wsUrl);
115
+ this.isMicMutedSubject.next(!this.client.isMicEnabled);
116
+ this.callStateSubject.next('connected');
117
+ this.statusTextSubject.next('Connected');
118
+ this.callStartTime = Date.now();
119
+ this.startDurationTimer();
168
120
  }
169
121
  catch (error) {
170
122
  console.error('Error connecting voice agent:', error);
171
- if (this.isMicPermissionError(error)) {
172
- yield this.cleanupMediaAndSignal();
173
- this.callStateSubject.next('idle');
174
- this.durationSubject.next('0:00');
175
- this.statusTextSubject.next('Microphone permission is required');
176
- return;
177
- }
178
123
  this.callStateSubject.next('ended');
179
124
  yield this.disconnect();
180
125
  this.statusTextSubject.next('Connection failed');
@@ -182,74 +127,83 @@ export class VoiceAgentService {
182
127
  }
183
128
  });
184
129
  }
185
- onRoomCreated(roomUrl) {
130
+ disconnect() {
186
131
  return __awaiter(this, void 0, void 0, function* () {
187
- // Connect Daily.js for WebRTC audio
188
- yield this.dailyClient.connect(roomUrl);
189
- this.hasAutoUnmutedAfterFirstAudio = false;
190
- // Waveform: use local mic stream from Daily client
191
- this.dailyClient.localStream$
192
- .pipe(filter((s) => s != null), take(1))
193
- .subscribe((stream) => {
194
- this.audioAnalyzer.start(stream);
195
- });
196
- this.subscriptions.add(this.dailyClient.userSpeaking$.subscribe((s) => this.isUserSpeakingSubject.next(s)));
197
- this.subscriptions.add(combineLatest([
198
- this.dailyClient.speaking$,
199
- this.dailyClient.userSpeaking$,
200
- ]).subscribe(([bot, user]) => {
201
- const current = this.callStateSubject.value;
202
- if (current === 'connecting' && !bot) {
203
- return;
204
- }
205
- if (current === 'connecting' && bot) {
206
- this.callStartTime = Date.now();
207
- this.startDurationTimer();
208
- this.callStateSubject.next('talking');
209
- return;
210
- }
211
- if (user) {
212
- this.callStateSubject.next('listening');
132
+ try {
133
+ if (this.durationInterval) {
134
+ clearInterval(this.durationInterval);
135
+ this.durationInterval = null;
213
136
  }
214
- else if (bot) {
215
- this.callStateSubject.next('talking');
137
+ this.audioAnalyzer.stop();
138
+ if (this.client) {
139
+ yield this.client.disconnect();
140
+ this.client = null;
216
141
  }
217
- else if (current === 'talking' || current === 'listening') {
218
- this.callStateSubject.next('connected');
142
+ this.transport = null;
143
+ if (this.userMediaStream) {
144
+ this.userMediaStream.getTracks().forEach(track => track.stop());
145
+ this.userMediaStream = null;
219
146
  }
220
- }));
221
- this.subscriptions.add(this.dailyClient.micMuted$.subscribe((muted) => this.isMicMutedSubject.next(muted)));
222
- // One-time auto-unmute after first remote audio frame starts playing.
223
- // This keeps initial capture muted until bot audio is heard, then restores normal mic flow.
224
- this.subscriptions.add(this.dailyClient.firstRemoteAudioFrame$
225
- .pipe(filter((hasFirstFrame) => hasFirstFrame), take(1))
226
- .subscribe(() => {
227
- if (this.hasAutoUnmutedAfterFirstAudio)
228
- return;
229
- this.hasAutoUnmutedAfterFirstAudio = true;
230
- if (this.isMicMutedSubject.value) {
231
- this.dailyClient.setMuted(false);
147
+ if (this.botAudioElement) {
148
+ this.botAudioElement.pause();
149
+ this.botAudioElement.srcObject = null;
150
+ this.botAudioElement = null;
232
151
  }
233
- }));
234
- this.statusTextSubject.next('Connecting...');
152
+ this.callStateSubject.next('ended');
153
+ this.statusTextSubject.next('Call Ended');
154
+ // Keep current duration so "Call Ended" state can show it (e.g. "Call Ended 1:04")
155
+ }
156
+ catch (error) {
157
+ console.error('Error disconnecting voice agent:', error);
158
+ }
235
159
  });
236
160
  }
237
- disconnect() {
238
- return __awaiter(this, void 0, void 0, function* () {
239
- this.stopDurationTimer();
240
- this.audioAnalyzer.stop();
241
- // Daily first, then WebSocket
242
- yield this.dailyClient.disconnect();
243
- this.wsClient.disconnect();
161
+ toggleMic() {
162
+ if (!this.client)
163
+ return;
164
+ const newState = !this.client.isMicEnabled;
165
+ this.client.enableMic(newState);
166
+ this.isMicMutedSubject.next(!newState);
167
+ }
168
+ setupEventHandlers() {
169
+ if (!this.client)
170
+ return;
171
+ this.client.on(RTVIEvent.BotStartedSpeaking, () => {
172
+ this.callStateSubject.next('talking');
173
+ });
174
+ this.client.on(RTVIEvent.BotStoppedSpeaking, () => {
175
+ if (this.callStateSubject.value === 'talking') {
176
+ this.callStateSubject.next('connected');
177
+ }
178
+ });
179
+ this.client.on(RTVIEvent.TrackStarted, (track, participant) => {
180
+ if (this.botAudioElement && participant && !participant.local && track.kind === 'audio') {
181
+ const stream = new MediaStream([track]);
182
+ this.botAudioElement.srcObject = stream;
183
+ this.botAudioElement.play().catch(console.error);
184
+ }
185
+ });
186
+ this.client.on(RTVIEvent.UserTranscript, (data) => {
187
+ var _a;
188
+ this.userTranscriptSubject.next({
189
+ text: data.text,
190
+ final: (_a = data.final) !== null && _a !== void 0 ? _a : false,
191
+ });
192
+ });
193
+ this.client.on(RTVIEvent.BotTranscript, (data) => {
194
+ if (data === null || data === void 0 ? void 0 : data.text) {
195
+ this.botTranscriptSubject.next(data.text);
196
+ }
197
+ });
198
+ this.client.on(RTVIEvent.Error, () => {
199
+ this.statusTextSubject.next('Error occurred');
200
+ });
201
+ this.client.on(RTVIEvent.Disconnected, () => {
244
202
  this.callStateSubject.next('ended');
245
- this.statusTextSubject.next('Call Ended');
246
- this.hasAutoUnmutedAfterFirstAudio = false;
203
+ this.statusTextSubject.next('Disconnected');
204
+ this.disconnect();
247
205
  });
248
206
  }
249
- toggleMic() {
250
- const current = this.isMicMutedSubject.value;
251
- this.dailyClient.setMuted(!current);
252
- }
253
207
  startDurationTimer() {
254
208
  const updateDuration = () => {
255
209
  if (this.callStartTime > 0) {
@@ -259,44 +213,17 @@ export class VoiceAgentService {
259
213
  this.durationSubject.next(`${minutes}:${String(seconds).padStart(2, '0')}`);
260
214
  }
261
215
  };
262
- updateDuration();
216
+ updateDuration(); // show 0:00 immediately
263
217
  this.durationInterval = setInterval(updateDuration, 1000);
264
218
  }
265
- stopDurationTimer() {
266
- if (this.durationInterval) {
267
- clearInterval(this.durationInterval);
268
- this.durationInterval = null;
269
- }
270
- }
271
- isMicPermissionError(error) {
272
- if (!error || typeof error !== 'object')
273
- return false;
274
- const maybe = error;
275
- return (maybe.name === 'NotAllowedError' ||
276
- maybe.name === 'PermissionDeniedError' ||
277
- maybe.name === 'SecurityError');
278
- }
279
- cleanupMediaAndSignal() {
280
- return __awaiter(this, void 0, void 0, function* () {
281
- this.stopDurationTimer();
282
- this.audioAnalyzer.stop();
283
- yield this.dailyClient.disconnect();
284
- this.wsClient.disconnect();
285
- this.hasAutoUnmutedAfterFirstAudio = false;
286
- });
287
- }
288
219
  }
289
- VoiceAgentService.ɵprov = i0.ɵɵdefineInjectable({ factory: function VoiceAgentService_Factory() { return new VoiceAgentService(i0.ɵɵinject(i1.AudioAnalyzerService), i0.ɵɵinject(i2.WebSocketVoiceClientService), i0.ɵɵinject(i3.DailyVoiceClientService), i0.ɵɵinject(i4.PlatformTokenRefreshService), i0.ɵɵinject(i0.PLATFORM_ID)); }, token: VoiceAgentService, providedIn: "root" });
220
+ VoiceAgentService.ɵprov = i0.ɵɵdefineInjectable({ factory: function VoiceAgentService_Factory() { return new VoiceAgentService(i0.ɵɵinject(i1.AudioAnalyzerService)); }, token: VoiceAgentService, providedIn: "root" });
290
221
  VoiceAgentService.decorators = [
291
222
  { type: Injectable, args: [{
292
- providedIn: 'root',
223
+ providedIn: 'root'
293
224
  },] }
294
225
  ];
295
226
  VoiceAgentService.ctorParameters = () => [
296
- { type: AudioAnalyzerService },
297
- { type: WebSocketVoiceClientService },
298
- { type: DailyVoiceClientService },
299
- { type: PlatformTokenRefreshService },
300
- { type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
227
+ { type: AudioAnalyzerService }
301
228
  ];
302
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"voice-agent.service.js","sourceRoot":"/Users/rohitthakur/hive-gpt/HiveAI-Packages/Angular/projects/hivegpt/eventsgpt-angular/src/","sources":["lib/components/voice-agent/services/voice-agent.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { isPlatformBrowser } from '@angular/common';\nimport { Inject, Injectable, OnDestroy, PLATFORM_ID } from '@angular/core';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  Observable,\n  Subject,\n  Subscription,\n} from 'rxjs';\nimport { filter, take, takeUntil } from 'rxjs/operators';\nimport { PlatformTokenRefreshService } from '../../../services/platform-token-refresh.service';\nimport { AudioAnalyzerService } from './audio-analyzer.service';\nimport { WebSocketVoiceClientService } from './websocket-voice-client.service';\nimport { DailyVoiceClientService } from './daily-voice-client.service';\n\nexport type CallState =\n  | 'idle'\n  | 'connecting'\n  | 'connected'\n  | 'listening'\n  | 'talking'\n  | 'ended';\n\nexport interface TranscriptData {\n  text: string;\n  final: boolean;\n}\n\n/**\n * Voice agent orchestrator. Coordinates WebSocket (signaling) and Daily.js (WebRTC audio).\n *\n * CRITICAL: This service must NEVER use Socket.IO or ngx-socket-io. Voice flow uses only:\n * - Native WebSocket (WebSocketVoiceClientService) for signaling (room_created, transcripts)\n * - Daily.js (DailyVoiceClientService) for WebRTC audio. Audio does NOT flow over WebSocket.\n *\n * - Maintains callState, statusText, duration, isMicMuted, isUserSpeaking, audioLevels\n * - Uses WebSocket for room_created and transcripts only (no audio)\n * - Uses Daily.js for all audio, mic, and real-time speaking detection\n */\n@Injectable({\n  providedIn: 'root',\n})\nexport class VoiceAgentService implements OnDestroy {\n  private callStateSubject = new BehaviorSubject<CallState>('idle');\n  private statusTextSubject = new BehaviorSubject<string>('');\n  private durationSubject = new BehaviorSubject<string>('00:00');\n  private isMicMutedSubject = new BehaviorSubject<boolean>(false);\n  private isUserSpeakingSubject = new BehaviorSubject<boolean>(false);\n  private audioLevelsSubject = new BehaviorSubject<number[]>([]);\n  private userTranscriptSubject = new Subject<TranscriptData>();\n  private botTranscriptSubject = new Subject<string>();\n\n  private callStartTime = 0;\n  private durationInterval: ReturnType<typeof setInterval> | null = null;\n\n  private subscriptions = new Subscription();\n  private destroy$ = new Subject<void>();\n  private hasAutoUnmutedAfterFirstAudio = false;\n\n  callState$: Observable<CallState> = this.callStateSubject.asObservable();\n  statusText$: Observable<string> = this.statusTextSubject.asObservable();\n  duration$: Observable<string> = this.durationSubject.asObservable();\n  isMicMuted$: Observable<boolean> = this.isMicMutedSubject.asObservable();\n  isUserSpeaking$: Observable<boolean> =\n    this.isUserSpeakingSubject.asObservable();\n  audioLevels$: Observable<number[]> = this.audioLevelsSubject.asObservable();\n  userTranscript$: Observable<TranscriptData> =\n    this.userTranscriptSubject.asObservable();\n  botTranscript$: Observable<string> = this.botTranscriptSubject.asObservable();\n\n  constructor(\n    private audioAnalyzer: AudioAnalyzerService,\n    private wsClient: WebSocketVoiceClientService,\n    private dailyClient: DailyVoiceClientService,\n    private platformTokenRefresh: PlatformTokenRefreshService,\n    /** `Object` not `object` — ngc metadata collection rejects the `object` type in DI params. */\n    @Inject(PLATFORM_ID) private platformId: Object,\n  ) {\n    // Waveform visualization only - do NOT use for speaking state\n    this.subscriptions.add(\n      this.audioAnalyzer.audioLevels$.subscribe((levels) =>\n        this.audioLevelsSubject.next(levels),\n      ),\n    );\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.subscriptions.unsubscribe();\n    this.disconnect();\n  }\n\n  /** Reset to idle state (e.g. when modal opens so user can click Start Call). */\n  resetToIdle(): void {\n    if (this.callStateSubject.value === 'idle') return;\n    this.stopDurationTimer();\n    this.audioAnalyzer.stop();\n    this.wsClient.disconnect();\n    // Fire-and-forget: Daily disconnect is async; connect() will await if needed\n    void this.dailyClient.disconnect();\n    this.callStateSubject.next('idle');\n    this.statusTextSubject.next('');\n    this.durationSubject.next('0:00');\n    this.hasAutoUnmutedAfterFirstAudio = false;\n  }\n\n  async connect(\n    apiUrl: string,\n    token: string,\n    botId: string,\n    conversationId: string,\n    apiKey: string,\n    eventToken: string,\n    eventId: string,\n    eventUrl: string,\n    domainAuthority: string,\n    usersApiUrl?: string,\n  ): Promise<void> {\n    if (this.callStateSubject.value !== 'idle') {\n      console.warn('Call already in progress');\n      return;\n    }\n\n    try {\n      this.callStateSubject.next('connecting');\n      this.statusTextSubject.next('Connecting...');\n\n      // Request mic permission before provisioning backend room flow.\n      await this.dailyClient.ensureMicrophoneAccess();\n\n      let accessToken = token;\n      // Align with chat drawer token handling: always delegate to\n      // PlatformTokenRefreshService when we have a usersApiUrl, so it can\n      // fall back to stored tokens even if the caller passed an empty token.\n      if (usersApiUrl && isPlatformBrowser(this.platformId)) {\n        try {\n          const ensured = await this.platformTokenRefresh\n            .ensureValidAccessToken(token, usersApiUrl)\n            .pipe(take(1))\n            .toPromise();\n          if (ensured?.accessToken) {\n            accessToken = ensured.accessToken;\n          }\n        } catch (e) {\n          console.warn(\n            '[HiveGpt Voice] Token refresh before connect failed',\n            e,\n          );\n        }\n      }\n\n      const baseUrl = apiUrl.replace(/\\/$/, '');\n      const postUrl = `${baseUrl}/ai/ask-voice`;\n\n      const headers: Record<string, string> = {\n        'Content-Type': 'application/json',\n        Authorization: `Bearer ${accessToken}`,\n        'x-api-key': apiKey,\n        'hive-bot-id': botId,\n        'domain-authority': domainAuthority,\n        eventUrl,\n        eventId,\n        eventToken,\n        'ngrok-skip-browser-warning': 'true',\n      };\n\n      // POST to get ws_url for signaling\n      const res = await fetch(postUrl, {\n        method: 'POST',\n        headers,\n        body: JSON.stringify({\n          bot_id: botId,\n          conversation_id: conversationId,\n          voice: 'alloy',\n        }),\n      });\n\n      if (!res.ok) {\n        throw new Error(`HTTP ${res.status}`);\n      }\n\n      const json = await res.json();\n      const wsUrl = json?.rn_ws_url;\n      if (!wsUrl || typeof wsUrl !== 'string') {\n        throw new Error('No ws_url in response');\n      }\n\n      // Subscribe to room_created BEFORE connecting to avoid race\n      this.wsClient.roomCreated$\n        .pipe(take(1), takeUntil(this.destroy$))\n        .subscribe(async (roomUrl) => {\n          try {\n            await this.onRoomCreated(roomUrl);\n          } catch (err) {\n            console.error('Daily join failed:', err);\n            if (this.isMicPermissionError(err)) {\n              await this.cleanupMediaAndSignal();\n              this.callStateSubject.next('idle');\n              this.durationSubject.next('0:00');\n              this.statusTextSubject.next('Microphone permission is required');\n              return;\n            }\n            this.callStateSubject.next('ended');\n            this.statusTextSubject.next('Connection failed');\n            await this.disconnect();\n          }\n        });\n\n      // Forward transcripts from WebSocket\n      this.subscriptions.add(\n        this.wsClient.userTranscript$\n          .pipe(takeUntil(this.destroy$))\n          .subscribe((t) => this.userTranscriptSubject.next(t)),\n      );\n      this.subscriptions.add(\n        this.wsClient.botTranscript$\n          .pipe(takeUntil(this.destroy$))\n          .subscribe((t) => this.botTranscriptSubject.next(t)),\n      );\n\n      // Connect signaling WebSocket (no audio over WS)\n      this.wsClient.connect(wsUrl);\n    } catch (error) {\n      console.error('Error connecting voice agent:', error);\n      if (this.isMicPermissionError(error)) {\n        await this.cleanupMediaAndSignal();\n        this.callStateSubject.next('idle');\n        this.durationSubject.next('0:00');\n        this.statusTextSubject.next('Microphone permission is required');\n        return;\n      }\n      this.callStateSubject.next('ended');\n      await this.disconnect();\n      this.statusTextSubject.next('Connection failed');\n      throw error;\n    }\n  }\n\n  private async onRoomCreated(roomUrl: string): Promise<void> {\n    // Connect Daily.js for WebRTC audio\n    await this.dailyClient.connect(roomUrl);\n    this.hasAutoUnmutedAfterFirstAudio = false;\n\n    // Waveform: use local mic stream from Daily client\n    this.dailyClient.localStream$\n      .pipe(\n        filter((s): s is MediaStream => s != null),\n        take(1),\n      )\n      .subscribe((stream) => {\n        this.audioAnalyzer.start(stream);\n      });\n\n    this.subscriptions.add(\n      this.dailyClient.userSpeaking$.subscribe((s) =>\n        this.isUserSpeakingSubject.next(s),\n      ),\n    );\n    this.subscriptions.add(\n      combineLatest([\n        this.dailyClient.speaking$,\n        this.dailyClient.userSpeaking$,\n      ]).subscribe(([bot, user]) => {\n        const current = this.callStateSubject.value;\n        if (current === 'connecting' && !bot) {\n          return;\n        }\n        if (current === 'connecting' && bot) {\n          this.callStartTime = Date.now();\n          this.startDurationTimer();\n          this.callStateSubject.next('talking');\n          return;\n        }\n        if (user) {\n          this.callStateSubject.next('listening');\n        } else if (bot) {\n          this.callStateSubject.next('talking');\n        } else if (current === 'talking' || current === 'listening') {\n          this.callStateSubject.next('connected');\n        }\n      }),\n    );\n\n    this.subscriptions.add(\n      this.dailyClient.micMuted$.subscribe((muted) =>\n        this.isMicMutedSubject.next(muted),\n      ),\n    );\n\n    // One-time auto-unmute after first remote audio frame starts playing.\n    // This keeps initial capture muted until bot audio is heard, then restores normal mic flow.\n    this.subscriptions.add(\n      this.dailyClient.firstRemoteAudioFrame$\n        .pipe(\n          filter((hasFirstFrame) => hasFirstFrame),\n          take(1),\n        )\n        .subscribe(() => {\n          if (this.hasAutoUnmutedAfterFirstAudio) return;\n          this.hasAutoUnmutedAfterFirstAudio = true;\n          if (this.isMicMutedSubject.value) {\n            this.dailyClient.setMuted(false);\n          }\n        }),\n    );\n\n    this.statusTextSubject.next('Connecting...');\n  }\n\n  async disconnect(): Promise<void> {\n    this.stopDurationTimer();\n    this.audioAnalyzer.stop();\n\n    // Daily first, then WebSocket\n    await this.dailyClient.disconnect();\n    this.wsClient.disconnect();\n\n    this.callStateSubject.next('ended');\n    this.statusTextSubject.next('Call Ended');\n    this.hasAutoUnmutedAfterFirstAudio = false;\n  }\n\n  toggleMic(): void {\n    const current = this.isMicMutedSubject.value;\n    this.dailyClient.setMuted(!current);\n  }\n\n  private startDurationTimer(): void {\n    const updateDuration = () => {\n      if (this.callStartTime > 0) {\n        const elapsed = Math.floor((Date.now() - this.callStartTime) / 1000);\n        const minutes = Math.floor(elapsed / 60);\n        const seconds = elapsed % 60;\n        this.durationSubject.next(\n          `${minutes}:${String(seconds).padStart(2, '0')}`,\n        );\n      }\n    };\n    updateDuration();\n    this.durationInterval = setInterval(updateDuration, 1000);\n  }\n\n  private stopDurationTimer(): void {\n    if (this.durationInterval) {\n      clearInterval(this.durationInterval);\n      this.durationInterval = null;\n    }\n  }\n\n  private isMicPermissionError(error: unknown): boolean {\n    if (!error || typeof error !== 'object') return false;\n    const maybe = error as { name?: string };\n    return (\n      maybe.name === 'NotAllowedError' ||\n      maybe.name === 'PermissionDeniedError' ||\n      maybe.name === 'SecurityError'\n    );\n  }\n\n  private async cleanupMediaAndSignal(): Promise<void> {\n    this.stopDurationTimer();\n    this.audioAnalyzer.stop();\n    await this.dailyClient.disconnect();\n    this.wsClient.disconnect();\n    this.hasAutoUnmutedAfterFirstAudio = false;\n  }\n}\n"]}
229
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"voice-agent.service.js","sourceRoot":"/Users/rohitthakur/hive-gpt/HiveAI-Packages/Angular/projects/hivegpt/eventsgpt-angular/src/","sources":["lib/components/voice-agent/services/voice-agent.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport {\n  PipecatClient,\n  RTVIEvent,\n  APIRequest,\n} from '@pipecat-ai/client-js';\nimport { WebSocketTransport } from '@pipecat-ai/websocket-transport';\nimport { AudioAnalyzerService } from './audio-analyzer.service';\n\nexport type CallState = 'idle' | 'connecting' | 'connected' | 'talking' | 'listening' | 'ended';\n\nexport interface TranscriptData {\n  text: string;\n  final: boolean;\n}\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class VoiceAgentService {\n  private client: PipecatClient | null = null;\n  private transport: InstanceType<typeof WebSocketTransport> | null = null;\n  private userMediaStream: MediaStream | null = null;\n  private botAudioElement: HTMLAudioElement | null = null;\n\n  private callStateSubject = new BehaviorSubject<CallState>('idle');\n  private statusTextSubject = new BehaviorSubject<string>('');\n  private durationSubject = new BehaviorSubject<string>('00:00');\n  private isMicMutedSubject = new BehaviorSubject<boolean>(false);\n  private isUserSpeakingSubject = new BehaviorSubject<boolean>(false);\n  private audioLevelsSubject = new BehaviorSubject<number[]>([]);\n  private userTranscriptSubject = new Subject<TranscriptData>();\n  private botTranscriptSubject = new Subject<string>();\n\n  private callStartTime: number = 0;\n  private durationInterval: ReturnType<typeof setInterval> | null = null;\n\n  callState$: Observable<CallState> = this.callStateSubject.asObservable();\n  statusText$: Observable<string> = this.statusTextSubject.asObservable();\n  duration$: Observable<string> = this.durationSubject.asObservable();\n  isMicMuted$: Observable<boolean> = this.isMicMutedSubject.asObservable();\n  isUserSpeaking$: Observable<boolean> = this.isUserSpeakingSubject.asObservable();\n  audioLevels$: Observable<number[]> = this.audioLevelsSubject.asObservable();\n  userTranscript$: Observable<TranscriptData> = this.userTranscriptSubject.asObservable();\n  botTranscript$: Observable<string> = this.botTranscriptSubject.asObservable();\n\n  /** Reset to idle state (e.g. when modal opens so user can click Start Call). */\n  resetToIdle(): void {\n    if (this.callStateSubject.value === 'idle') return;\n    if (this.durationInterval) {\n      clearInterval(this.durationInterval);\n      this.durationInterval = null;\n    }\n    this.audioAnalyzer.stop();\n    this.client = null;\n    this.transport = null;\n    if (this.userMediaStream) {\n      this.userMediaStream.getTracks().forEach(track => track.stop());\n      this.userMediaStream = null;\n    }\n    if (this.botAudioElement) {\n      this.botAudioElement.pause();\n      this.botAudioElement.srcObject = null;\n      this.botAudioElement = null;\n    }\n    this.callStateSubject.next('idle');\n    this.statusTextSubject.next('');\n    this.durationSubject.next('0:00');\n  }\n\n  constructor(private audioAnalyzer: AudioAnalyzerService) {\n    this.audioAnalyzer.audioLevels$.subscribe(levels => {\n      this.audioLevelsSubject.next(levels);\n    });\n\n    this.audioAnalyzer.isUserSpeaking$.subscribe(isSpeaking => {\n      this.isUserSpeakingSubject.next(isSpeaking);\n      if (isSpeaking && this.callStateSubject.value === 'connected') {\n        this.callStateSubject.next('listening');\n      } else if (!isSpeaking && this.callStateSubject.value === 'listening') {\n        this.callStateSubject.next('connected');\n      }\n    });\n  }\n\n  async connect(\n    apiUrl: string,\n    token: string,\n    botId: string,\n    conversationId: string,\n    apiKey: string,\n    eventToken: string,\n    eventUrl: string,\n    domainAuthority: string\n  ): Promise<void> {\n    if (this.callStateSubject.value !== 'idle') {\n      console.warn('Call already in progress');\n      return;\n    }\n\n    try {\n      this.callStateSubject.next('connecting');\n      this.statusTextSubject.next('Connecting...');\n\n      const baseUrl = apiUrl.replace(/\\/$/, '');\n      const connectUrl = `${baseUrl}/ai/ask-voice`;\n\n      const headers = new Headers();\n      headers.set('Authorization', `Bearer ${token}`);\n      // Do not set Content-Type here — the Pipecat client already sets \"application/json\" once; adding it again produces \"application/json, application/json\"\n      headers.set('domain-authority', domainAuthority);\n      headers.set('eventtoken', eventToken);\n      headers.set('eventurl', eventUrl);\n      headers.set('hive-bot-id', botId);\n      headers.set('x-api-key', apiKey);\n\n      const startBotParams: APIRequest = {\n        endpoint: connectUrl,\n        headers,\n        requestData: {\n          bot_id: botId,\n          conversation_id: conversationId,\n          voice: 'alloy',\n        },\n      };\n\n      this.transport = new WebSocketTransport();\n      this.client = new PipecatClient({\n        transport: this.transport,\n        enableMic: true,\n        enableCam: false,\n      });\n\n      this.setupEventHandlers();\n\n      this.botAudioElement = new Audio();\n      this.botAudioElement.autoplay = true;\n\n      await this.client.startBotAndConnect(startBotParams);\n\n      const tracks = this.client.tracks();\n      if (tracks?.local?.audio) {\n        this.userMediaStream = new MediaStream([tracks.local.audio]);\n        this.audioAnalyzer.start(this.userMediaStream);\n      }\n\n      this.isMicMutedSubject.next(!this.client.isMicEnabled);\n      this.callStateSubject.next('connected');\n      this.statusTextSubject.next('Connected');\n      this.callStartTime = Date.now();\n      this.startDurationTimer();\n    } catch (error) {\n      console.error('Error connecting voice agent:', error);\n      this.callStateSubject.next('ended');\n      await this.disconnect();\n      this.statusTextSubject.next('Connection failed');\n      throw error;\n    }\n  }\n\n  async disconnect(): Promise<void> {\n    try {\n      if (this.durationInterval) {\n        clearInterval(this.durationInterval);\n        this.durationInterval = null;\n      }\n\n      this.audioAnalyzer.stop();\n\n      if (this.client) {\n        await this.client.disconnect();\n        this.client = null;\n      }\n\n      this.transport = null;\n\n      if (this.userMediaStream) {\n        this.userMediaStream.getTracks().forEach(track => track.stop());\n        this.userMediaStream = null;\n      }\n\n      if (this.botAudioElement) {\n        this.botAudioElement.pause();\n        this.botAudioElement.srcObject = null;\n        this.botAudioElement = null;\n      }\n\n      this.callStateSubject.next('ended');\n      this.statusTextSubject.next('Call Ended');\n      // Keep current duration so \"Call Ended\" state can show it (e.g. \"Call Ended 1:04\")\n    } catch (error) {\n      console.error('Error disconnecting voice agent:', error);\n    }\n  }\n\n  toggleMic(): void {\n    if (!this.client) return;\n    const newState = !this.client.isMicEnabled;\n    this.client.enableMic(newState);\n    this.isMicMutedSubject.next(!newState);\n  }\n\n  private setupEventHandlers(): void {\n    if (!this.client) return;\n\n    this.client.on(RTVIEvent.BotStartedSpeaking, () => {\n      this.callStateSubject.next('talking');\n    });\n\n    this.client.on(RTVIEvent.BotStoppedSpeaking, () => {\n      if (this.callStateSubject.value === 'talking') {\n        this.callStateSubject.next('connected');\n      }\n    });\n\n    this.client.on(RTVIEvent.TrackStarted, (track: MediaStreamTrack, participant?: { local?: boolean }) => {\n      if (this.botAudioElement && participant && !participant.local && track.kind === 'audio') {\n        const stream = new MediaStream([track]);\n        this.botAudioElement.srcObject = stream;\n        this.botAudioElement.play().catch(console.error);\n      }\n    });\n\n    this.client.on(RTVIEvent.UserTranscript, (data: { text: string; final?: boolean }) => {\n      this.userTranscriptSubject.next({\n        text: data.text,\n        final: data.final ?? false,\n      });\n    });\n\n    this.client.on(RTVIEvent.BotTranscript, (data: { text?: string }) => {\n      if (data?.text) {\n        this.botTranscriptSubject.next(data.text);\n      }\n    });\n\n    this.client.on(RTVIEvent.Error, () => {\n      this.statusTextSubject.next('Error occurred');\n    });\n\n    this.client.on(RTVIEvent.Disconnected, () => {\n      this.callStateSubject.next('ended');\n      this.statusTextSubject.next('Disconnected');\n      this.disconnect();\n    });\n  }\n\n  private startDurationTimer(): void {\n    const updateDuration = () => {\n      if (this.callStartTime > 0) {\n        const elapsed = Math.floor((Date.now() - this.callStartTime) / 1000);\n        const minutes = Math.floor(elapsed / 60);\n        const seconds = elapsed % 60;\n        this.durationSubject.next(\n          `${minutes}:${String(seconds).padStart(2, '0')}`\n        );\n      }\n    };\n    updateDuration(); // show 0:00 immediately\n    this.durationInterval = setInterval(updateDuration, 1000);\n  }\n}\n"]}
@@ -3,12 +3,6 @@ import { CommonModule } from '@angular/common';
3
3
  import { VoiceAgentModalComponent } from './components/voice-agent-modal/voice-agent-modal.component';
4
4
  import { VoiceAgentService } from './services/voice-agent.service';
5
5
  import { AudioAnalyzerService } from './services/audio-analyzer.service';
6
- import { WebSocketVoiceClientService } from './services/websocket-voice-client.service';
7
- import { DailyVoiceClientService } from './services/daily-voice-client.service';
8
- /**
9
- * Voice agent module. Uses native WebSocket + Daily.js only.
10
- * Does NOT use Socket.IO or ngx-socket-io.
11
- */
12
6
  export class VoiceAgentModule {
13
7
  }
14
8
  VoiceAgentModule.decorators = [
@@ -21,13 +15,11 @@ VoiceAgentModule.decorators = [
21
15
  ],
22
16
  providers: [
23
17
  VoiceAgentService,
24
- AudioAnalyzerService,
25
- WebSocketVoiceClientService,
26
- DailyVoiceClientService
18
+ AudioAnalyzerService
27
19
  ],
28
20
  exports: [
29
21
  VoiceAgentModalComponent
30
22
  ]
31
23
  },] }
32
24
  ];
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9pY2UtYWdlbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2hpdHRoYWt1ci9oaXZlLWdwdC9IaXZlQUktUGFja2FnZXMvQW5ndWxhci9wcm9qZWN0cy9oaXZlZ3B0L2V2ZW50c2dwdC1hbmd1bGFyL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3ZvaWNlLWFnZW50L3ZvaWNlLWFnZW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUN0RyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQUN6RSxPQUFPLEVBQUUsMkJBQTJCLEVBQUUsTUFBTSwyQ0FBMkMsQ0FBQztBQUN4RixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUVoRjs7O0dBR0c7QUFrQkgsTUFBTSxPQUFPLGdCQUFnQjs7O1lBakI1QixRQUFRLFNBQUM7Z0JBQ1IsWUFBWSxFQUFFO29CQUNaLHdCQUF3QjtpQkFDekI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLFlBQVk7aUJBQ2I7Z0JBQ0QsU0FBUyxFQUFFO29CQUNULGlCQUFpQjtvQkFDakIsb0JBQW9CO29CQUNwQiwyQkFBMkI7b0JBQzNCLHVCQUF1QjtpQkFDeEI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNQLHdCQUF3QjtpQkFDekI7YUFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgVm9pY2VBZ2VudE1vZGFsQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3ZvaWNlLWFnZW50LW1vZGFsL3ZvaWNlLWFnZW50LW1vZGFsLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBWb2ljZUFnZW50U2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvdm9pY2UtYWdlbnQuc2VydmljZSc7XG5pbXBvcnQgeyBBdWRpb0FuYWx5emVyU2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvYXVkaW8tYW5hbHl6ZXIuc2VydmljZSc7XG5pbXBvcnQgeyBXZWJTb2NrZXRWb2ljZUNsaWVudFNlcnZpY2UgfSBmcm9tICcuL3NlcnZpY2VzL3dlYnNvY2tldC12b2ljZS1jbGllbnQuc2VydmljZSc7XG5pbXBvcnQgeyBEYWlseVZvaWNlQ2xpZW50U2VydmljZSB9IGZyb20gJy4vc2VydmljZXMvZGFpbHktdm9pY2UtY2xpZW50LnNlcnZpY2UnO1xuXG4vKipcbiAqIFZvaWNlIGFnZW50IG1vZHVsZS4gVXNlcyBuYXRpdmUgV2ViU29ja2V0ICsgRGFpbHkuanMgb25seS5cbiAqIERvZXMgTk9UIHVzZSBTb2NrZXQuSU8gb3Igbmd4LXNvY2tldC1pby5cbiAqL1xuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgVm9pY2VBZ2VudE1vZGFsQ29tcG9uZW50XG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGVcbiAgXSxcbiAgcHJvdmlkZXJzOiBbXG4gICAgVm9pY2VBZ2VudFNlcnZpY2UsXG4gICAgQXVkaW9BbmFseXplclNlcnZpY2UsXG4gICAgV2ViU29ja2V0Vm9pY2VDbGllbnRTZXJ2aWNlLFxuICAgIERhaWx5Vm9pY2VDbGllbnRTZXJ2aWNlXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBWb2ljZUFnZW50TW9kYWxDb21wb25lbnRcbiAgXVxufSlcbmV4cG9ydCBjbGFzcyBWb2ljZUFnZW50TW9kdWxlIHsgfVxuIl19
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9pY2UtYWdlbnQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2hpdHRoYWt1ci9oaXZlLWdwdC9IaXZlQUktUGFja2FnZXMvQW5ndWxhci9wcm9qZWN0cy9oaXZlZ3B0L2V2ZW50c2dwdC1hbmd1bGFyL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3ZvaWNlLWFnZW50L3ZvaWNlLWFnZW50Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUN0RyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQWlCekUsTUFBTSxPQUFPLGdCQUFnQjs7O1lBZjVCLFFBQVEsU0FBQztnQkFDUixZQUFZLEVBQUU7b0JBQ1osd0JBQXdCO2lCQUN6QjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsWUFBWTtpQkFDYjtnQkFDRCxTQUFTLEVBQUU7b0JBQ1QsaUJBQWlCO29CQUNqQixvQkFBb0I7aUJBQ3JCO2dCQUNELE9BQU8sRUFBRTtvQkFDUCx3QkFBd0I7aUJBQ3pCO2FBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFZvaWNlQWdlbnRNb2RhbENvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy92b2ljZS1hZ2VudC1tb2RhbC92b2ljZS1hZ2VudC1tb2RhbC5jb21wb25lbnQnO1xuaW1wb3J0IHsgVm9pY2VBZ2VudFNlcnZpY2UgfSBmcm9tICcuL3NlcnZpY2VzL3ZvaWNlLWFnZW50LnNlcnZpY2UnO1xuaW1wb3J0IHsgQXVkaW9BbmFseXplclNlcnZpY2UgfSBmcm9tICcuL3NlcnZpY2VzL2F1ZGlvLWFuYWx5emVyLnNlcnZpY2UnO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBWb2ljZUFnZW50TW9kYWxDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZVxuICBdLFxuICBwcm92aWRlcnM6IFtcbiAgICBWb2ljZUFnZW50U2VydmljZSxcbiAgICBBdWRpb0FuYWx5emVyU2VydmljZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgVm9pY2VBZ2VudE1vZGFsQ29tcG9uZW50XG4gIF1cbn0pXG5leHBvcnQgY2xhc3MgVm9pY2VBZ2VudE1vZHVsZSB7IH1cbiJdfQ==
@@ -1,4 +1,4 @@
1
1
  import { InjectionToken } from '@angular/core';
2
2
  export const VOICE_MODAL_CONFIG = new InjectionToken('VOICE_MODAL_CONFIG');
3
3
  export const VOICE_MODAL_CLOSE_CALLBACK = new InjectionToken('VOICE_MODAL_CLOSE_CALLBACK');
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9pY2UtbW9kYWwtdG9rZW5zLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2hpdHRoYWt1ci9oaXZlLWdwdC9IaXZlQUktUGFja2FnZXMvQW5ndWxhci9wcm9qZWN0cy9oaXZlZ3B0L2V2ZW50c2dwdC1hbmd1bGFyL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3ZvaWNlLWFnZW50L3ZvaWNlLW1vZGFsLXRva2Vucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBb0IvQyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FBbUIsb0JBQW9CLENBQUMsQ0FBQztBQUM3RixNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxJQUFJLGNBQWMsQ0FBYSw0QkFBNEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBWb2ljZU1vZGFsQ29uZmlnIHtcbiAgYXBpVXJsOiBzdHJpbmc7XG4gIHRva2VuOiBzdHJpbmc7XG4gIGJvdElkOiBzdHJpbmc7XG4gIGNvbnZlcnNhdGlvbklkOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xuICBldmVudFRva2VuOiBzdHJpbmc7XG4gIC8qKiBFdmVudCBzY29wZSBpZCAoc2FtZSBhcyBob3N0IGBldmVudElkYCAvIEFQSSBgZXZlbnRzLzpldmVudElkLy4uLmApLiAqL1xuICBldmVudElkOiBzdHJpbmc7XG4gIGV2ZW50VXJsOiBzdHJpbmc7XG4gIGRvbWFpbkF1dGhvcml0eTogc3RyaW5nO1xuICBhZ2VudE5hbWU6IHN0cmluZztcbiAgYWdlbnRSb2xlOiBzdHJpbmc7XG4gIGFnZW50QXZhdGFyPzogc3RyaW5nO1xuICAvKiogU2FtZSBiYXNlIGFzIGhvc3QgYFVTRVJTX0FQSWAgKGUuZy4gYGh0dHBzOi8vZXMtdXNlci5zb2NpYWwyNy5jb20vYXBpYCkgZm9yIHByb2FjdGl2ZSB0b2tlbiByZWZyZXNoLiAqL1xuICB1c2Vyc0FwaVVybD86IHN0cmluZztcbn1cblxuZXhwb3J0IGNvbnN0IFZPSUNFX01PREFMX0NPTkZJRyA9IG5ldyBJbmplY3Rpb25Ub2tlbjxWb2ljZU1vZGFsQ29uZmlnPignVk9JQ0VfTU9EQUxfQ09ORklHJyk7XG5leHBvcnQgY29uc3QgVk9JQ0VfTU9EQUxfQ0xPU0VfQ0FMTEJBQ0sgPSBuZXcgSW5qZWN0aW9uVG9rZW48KCkgPT4gdm9pZD4oJ1ZPSUNFX01PREFMX0NMT1NFX0NBTExCQUNLJyk7XG4iXX0=
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidm9pY2UtbW9kYWwtdG9rZW5zLmpzIiwic291cmNlUm9vdCI6Ii9Vc2Vycy9yb2hpdHRoYWt1ci9oaXZlLWdwdC9IaXZlQUktUGFja2FnZXMvQW5ndWxhci9wcm9qZWN0cy9oaXZlZ3B0L2V2ZW50c2dwdC1hbmd1bGFyL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9jb21wb25lbnRzL3ZvaWNlLWFnZW50L3ZvaWNlLW1vZGFsLXRva2Vucy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBZ0IvQyxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxJQUFJLGNBQWMsQ0FBbUIsb0JBQW9CLENBQUMsQ0FBQztBQUM3RixNQUFNLENBQUMsTUFBTSwwQkFBMEIsR0FBRyxJQUFJLGNBQWMsQ0FBYSw0QkFBNEIsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0IGludGVyZmFjZSBWb2ljZU1vZGFsQ29uZmlnIHtcbiAgYXBpVXJsOiBzdHJpbmc7XG4gIHRva2VuOiBzdHJpbmc7XG4gIGJvdElkOiBzdHJpbmc7XG4gIGNvbnZlcnNhdGlvbklkOiBzdHJpbmc7XG4gIGFwaUtleTogc3RyaW5nO1xuICBldmVudFRva2VuOiBzdHJpbmc7XG4gIGV2ZW50VXJsOiBzdHJpbmc7XG4gIGRvbWFpbkF1dGhvcml0eTogc3RyaW5nO1xuICBhZ2VudE5hbWU6IHN0cmluZztcbiAgYWdlbnRSb2xlOiBzdHJpbmc7XG4gIGFnZW50QXZhdGFyPzogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgVk9JQ0VfTU9EQUxfQ09ORklHID0gbmV3IEluamVjdGlvblRva2VuPFZvaWNlTW9kYWxDb25maWc+KCdWT0lDRV9NT0RBTF9DT05GSUcnKTtcbmV4cG9ydCBjb25zdCBWT0lDRV9NT0RBTF9DTE9TRV9DQUxMQkFDSyA9IG5ldyBJbmplY3Rpb25Ub2tlbjwoKSA9PiB2b2lkPignVk9JQ0VfTU9EQUxfQ0xPU0VfQ0FMTEJBQ0snKTtcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hhdC5qcyIsInNvdXJjZVJvb3QiOiIvVXNlcnMvcm9oaXR0aGFrdXIvaGl2ZS1ncHQvSGl2ZUFJLVBhY2thZ2VzL0FuZ3VsYXIvcHJvamVjdHMvaGl2ZWdwdC9ldmVudHNncHQtYW5ndWxhci9zcmMvIiwic291cmNlcyI6WyJsaWIvbW9kZWxzL2NoYXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgQ2hhdE1lc3NhZ2Uge1xuICBfaWQ/OiBzdHJpbmc7XG4gIHR5cGU6ICd1c2VyJyB8ICdhaScgfCAnc3VnZ2VzdGlvbnMnO1xuICBtZXNzYWdlPzogYW55O1xuICB0aW1lPzogc3RyaW5nO1xuICBjb3BpZWQ/OiBib29sZWFuO1xuICBpc0NvbGxhcHNlZFRydWU/OiBib29sZWFuO1xuICBsaWtlZD86IGJvb2xlYW47XG4gIHVubGlrZWQ/OiBib29sZWFuO1xuICBpc0ZlZWRiYWNrTXNnPzogYm9vbGVhbjtcbiAgaXNFZGl0b3I/OiBib29sZWFuO1xuICBhY3Rpb24/OiBBaUZvcm1hdHRlZERhdGE7XG4gIHN1Z2dlc3Rpb25zPzogc3RyaW5nW107XG4gIHNvdXJjZXNMaXN0PzogV2ViUmVzdWx0W107XG4gIGRpc3BsYXllZFNvdXJjZXM/OiBXZWJSZXN1bHRbXTtcbiAgcmVtYWluaW5nU291cmNlcz86IFdlYlJlc3VsdFtdO1xuICBzZWFyY2hUZXJtcz86IHN0cmluZ1tdO1xuICBncmFwaHM/OiBhbnlbXTtcbiAgZXhlY3V0aW9uR3JhcGhzPzogYW55W107XG4gIHJlbGF0ZWRMaXN0SXRlbXM/OiBzdHJpbmdbXTtcbiAgc2hvd1dvcmtmbG93RXhlY3V0aW9uTG9hZGVyPzogYm9vbGVhbjtcbiAgV29ya2Zsb3dFeGVjdXRpb25JZD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBXZWJSZXN1bHQge1xuICB0aXRsZT86IHN0cmluZztcbiAgZGVzYz86IHN0cmluZztcbiAgbGluaz86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBaUZvcm1hdHRlZERhdGEge1xuICBzZWN0aW9uX2lkPzogc3RyaW5nO1xuICBjb250ZW50PzogYW55O1xuICBtZXNzYWdlPzogc3RyaW5nO1xuICBpc19vcGVuX3BhZ2U/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQm90Q29uZmlnIHtcbiAgTmFtZTogc3RyaW5nO1xuICBJY29uOiBzdHJpbmc7XG4gIFNraWxsczogc3RyaW5nO1xuICBHcmVldGluZzogc3RyaW5nO1xuICBOZWdhdGl2ZVJlc3BvbnNlcz86IHN0cmluZ1tdO1xuICBRdWlja1Byb21wdHM/OiBRdWlja1Byb21wdFtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFF1aWNrUHJvbXB0IHtcbiAgdGV4dD86IHN0cmluZztcbiAgbGFiZWw/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2hhdEhpc3Rvcnkge1xuICBNZXNzYWdlcz86IENoYXRIaXN0b3J5TWVzc2FnZVtdO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIENoYXRIaXN0b3J5TWVzc2FnZSB7XG4gIF9pZD86IHN0cmluZztcbiAgVHlwZTogJ3VzZXInIHwgJ2FpJztcbiAgVGV4dDogc3RyaW5nO1xuICBJbnNlcnRUaW1lc3RhbXA6IHN0cmluZztcbiAgV2ViTGlua3M/OiBXZWJSZXN1bHRbXTtcbiAgU2VhcmNoVGVybXM/OiBzdHJpbmdbXTtcbiAgR3JhcGhzPzogYW55W107XG4gIEV4ZWN1dGlvbkdyYXBocz86IGFueVtdO1xuICBXb3JrZmxvd0V4ZWN1dGlvbklkPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFza1JlcXVlc3RCb2R5IHtcbiAgdXNlcl9xdWVzdGlvbjogc3RyaW5nO1xuICB1c2VyX2lkOiBzdHJpbmc7XG4gIGJvdF9pZDogc3RyaW5nO1xuICBtZXNzYWdlX2lkOiBzdHJpbmc7XG4gIHNlc3Npb25faWQ6IHN0cmluZztcbiAgYWdlbnRzOiBzdHJpbmdbXTtcbiAgY29udmVyc2F0aW9uX2lkOiBzdHJpbmc7XG4gIGZpcnN0X25hbWU6IHN0cmluZztcbiAgbGFzdF9uYW1lOiBzdHJpbmc7XG4gIHdvcmtmbG93X2lkPzogc3RyaW5nO1xuICB3b3JrZmxvd19pbnB1dHM/OiBhbnk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV29ya2Zsb3dBY3Rpb24ge1xuICBOYW1lOiBzdHJpbmc7XG4gIE91dHB1dD86IHN0cmluZztcbiAgSW5zZXJ0VGltZVN0YW1wPzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFdvcmtmbG93IHtcbiAgX2lkPzogc3RyaW5nO1xuICBOYW1lOiBzdHJpbmc7XG4gIEFjdGlvbnM6IFdvcmtmbG93QWN0aW9uW107XG4gIFRyaWdnZXI/OiB7XG4gICAgSW5wdXRTY2hlbWE/OiBXb3JrZmxvd0lucHV0W107XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV29ya2Zsb3dJbnB1dCB7XG4gIElucHV0SWQ6IHN0cmluZztcbiAgTGFiZWw/OiBzdHJpbmc7XG4gIFZhbHVlPzogc3RyaW5nO1xuICBSZXF1aXJlZD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgV29ya2Zsb3dFeGVjdXRpb25EZXRhaWxzIHtcbiAgQWN0aW9uczogV29ya2Zsb3dBY3Rpb25bXTtcbiAgSW5wdXRzPzogYW55O1xuICB3b3JrZmxvd0lucHV0cz86IGFueTtcbiAgV29ya2Zsb3dOYW1lPzogc3RyaW5nO1xuICBJbnNlcnRUaW1lU3RhbXA/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWdlbnQge1xuICBpZDogc3RyaW5nO1xuICBuYW1lPzogc3RyaW5nO1xuICBzZWxlY3RlZDogYm9vbGVhbjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFbnZpcm9ubWVudENvbmZpZyB7XG4gIFVTRVJTX0FQSTogc3RyaW5nO1xuICBCQVNFX1VSTDogc3RyaW5nO1xuICBBR0VOVFNfQVBJOiBzdHJpbmc7XG4gIEFQSV9LRVk/OiBzdHJpbmc7XG4gIFNvY2tldFVybD86IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTb2NrZXROb3RpZmljYXRpb24ge1xuICBtPzoge1xuICAgIE90aGVyRmllbGRzPzoge1xuICAgICAgd29ya2Zsb3dfaWQ/OiBzdHJpbmc7XG4gICAgICBwZXJjZW50YWdlPzogbnVtYmVyO1xuICAgICAgb3V0cHV0Pzogc3RyaW5nO1xuICAgICAgYWN0aW9uX25hbWU/OiBzdHJpbmc7XG4gICAgICBjdXJyZW50X2FjdGlvbl9uYW1lPzogc3RyaW5nO1xuICAgICAgd29ya2Zsb3dfZXhlY3V0aW9uX2lkPzogc3RyaW5nO1xuICAgICAgdGltZV9zdGFtcD86IHN0cmluZztcbiAgICAgIGNvbnZlcnNhdGlvbl9pZD86IHN0cmluZztcbiAgICAgIGJvdF9pZD86IHN0cmluZztcbiAgICAgIG1lc3NhZ2VfaWQ/OiBzdHJpbmc7XG4gICAgICBhbnN3ZXI/OiBzdHJpbmc7XG4gICAgICB3ZWJfcmVzdWx0cz86IFdlYlJlc3VsdFtdO1xuICAgICAgc2VhcmNoX3Jlc3VsdHM/OiBzdHJpbmdbXTtcbiAgICAgIGdyYXBocz86IGFueVtdO1xuICAgICAgZXhlY3V0aW9uX2dyYXBocz86IGFueVtdO1xuICAgICAgc3VnZ2VzdGlvbnM/OiBzdHJpbmdbXTtcbiAgICB9O1xuICB9O1xufVxuIl19