@webex/contact-center 3.10.0-next.3 → 3.10.0-next.31

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 (103) hide show
  1. package/dist/cc.js +13 -1
  2. package/dist/cc.js.map +1 -1
  3. package/dist/config.js.map +1 -1
  4. package/dist/constants.js.map +1 -1
  5. package/dist/index.js +17 -1
  6. package/dist/index.js.map +1 -1
  7. package/dist/logger-proxy.js.map +1 -1
  8. package/dist/metrics/MetricsManager.js +2 -1
  9. package/dist/metrics/MetricsManager.js.map +1 -1
  10. package/dist/metrics/behavioral-events.js +12 -0
  11. package/dist/metrics/behavioral-events.js.map +1 -1
  12. package/dist/metrics/constants.js +4 -0
  13. package/dist/metrics/constants.js.map +1 -1
  14. package/dist/services/AddressBook.js +2 -3
  15. package/dist/services/AddressBook.js.map +1 -1
  16. package/dist/services/EntryPoint.js +2 -3
  17. package/dist/services/EntryPoint.js.map +1 -1
  18. package/dist/services/Queue.js +2 -3
  19. package/dist/services/Queue.js.map +1 -1
  20. package/dist/services/WebCallingService.js +1 -1
  21. package/dist/services/WebCallingService.js.map +1 -1
  22. package/dist/services/agent/index.js +1 -2
  23. package/dist/services/agent/index.js.map +1 -1
  24. package/dist/services/agent/types.js +10 -0
  25. package/dist/services/agent/types.js.map +1 -1
  26. package/dist/services/config/Util.js.map +1 -1
  27. package/dist/services/config/constants.js.map +1 -1
  28. package/dist/services/config/index.js +1 -1
  29. package/dist/services/config/index.js.map +1 -1
  30. package/dist/services/config/types.js +2 -2
  31. package/dist/services/config/types.js.map +1 -1
  32. package/dist/services/constants.js.map +1 -1
  33. package/dist/services/core/Err.js.map +1 -1
  34. package/dist/services/core/GlobalTypes.js.map +1 -1
  35. package/dist/services/core/Utils.js +92 -74
  36. package/dist/services/core/Utils.js.map +1 -1
  37. package/dist/services/core/WebexRequest.js +1 -2
  38. package/dist/services/core/WebexRequest.js.map +1 -1
  39. package/dist/services/core/aqm-reqs.js +2 -3
  40. package/dist/services/core/aqm-reqs.js.map +1 -1
  41. package/dist/services/core/constants.js +17 -1
  42. package/dist/services/core/constants.js.map +1 -1
  43. package/dist/services/core/types.js.map +1 -1
  44. package/dist/services/core/websocket/WebSocketManager.js +1 -2
  45. package/dist/services/core/websocket/WebSocketManager.js.map +1 -1
  46. package/dist/services/core/websocket/connection-service.js +1 -1
  47. package/dist/services/core/websocket/connection-service.js.map +1 -1
  48. package/dist/services/core/websocket/keepalive.worker.js.map +1 -1
  49. package/dist/services/core/websocket/types.js.map +1 -1
  50. package/dist/services/index.js +1 -1
  51. package/dist/services/index.js.map +1 -1
  52. package/dist/services/task/AutoWrapup.js +1 -1
  53. package/dist/services/task/AutoWrapup.js.map +1 -1
  54. package/dist/services/task/TaskManager.js +175 -62
  55. package/dist/services/task/TaskManager.js.map +1 -1
  56. package/dist/services/task/TaskUtils.js +122 -5
  57. package/dist/services/task/TaskUtils.js.map +1 -1
  58. package/dist/services/task/constants.js +3 -1
  59. package/dist/services/task/constants.js.map +1 -1
  60. package/dist/services/task/contact.js +0 -2
  61. package/dist/services/task/contact.js.map +1 -1
  62. package/dist/services/task/dialer.js.map +1 -1
  63. package/dist/services/task/index.js +50 -59
  64. package/dist/services/task/index.js.map +1 -1
  65. package/dist/services/task/types.js +377 -4
  66. package/dist/services/task/types.js.map +1 -1
  67. package/dist/types/cc.d.ts +6 -0
  68. package/dist/types/index.d.ts +1 -1
  69. package/dist/types/metrics/constants.d.ts +4 -0
  70. package/dist/types/services/config/types.d.ts +4 -4
  71. package/dist/types/services/core/Utils.d.ts +32 -17
  72. package/dist/types/services/core/constants.d.ts +14 -0
  73. package/dist/types/services/task/TaskUtils.d.ts +59 -3
  74. package/dist/types/services/task/constants.d.ts +2 -0
  75. package/dist/types/services/task/types.d.ts +57 -13
  76. package/dist/types.js +5 -0
  77. package/dist/types.js.map +1 -1
  78. package/dist/utils/PageCache.js +1 -1
  79. package/dist/utils/PageCache.js.map +1 -1
  80. package/dist/webex-config.js.map +1 -1
  81. package/dist/webex.js +2 -2
  82. package/dist/webex.js.map +1 -1
  83. package/package.json +9 -9
  84. package/src/cc.ts +12 -0
  85. package/src/index.ts +1 -0
  86. package/src/metrics/behavioral-events.ts +12 -0
  87. package/src/metrics/constants.ts +4 -0
  88. package/src/services/config/types.ts +2 -2
  89. package/src/services/core/Utils.ts +101 -85
  90. package/src/services/core/constants.ts +16 -0
  91. package/src/services/task/TaskManager.ts +201 -41
  92. package/src/services/task/TaskUtils.ts +145 -5
  93. package/src/services/task/constants.ts +2 -0
  94. package/src/services/task/index.ts +54 -89
  95. package/src/services/task/types.ts +60 -13
  96. package/test/unit/spec/cc.ts +1 -0
  97. package/test/unit/spec/metrics/behavioral-events.ts +14 -0
  98. package/test/unit/spec/services/core/Utils.ts +262 -31
  99. package/test/unit/spec/services/task/TaskManager.ts +602 -5
  100. package/test/unit/spec/services/task/TaskUtils.ts +311 -9
  101. package/test/unit/spec/services/task/index.ts +283 -86
  102. package/umd/contact-center.min.js +2 -2
  103. package/umd/contact-center.min.js.map +1 -1
@@ -16,7 +16,7 @@ var _ = _interopRequireDefault(require("."));
16
16
  var _MetricsManager = _interopRequireDefault(require("../../metrics/MetricsManager"));
17
17
  var _constants3 = require("../../metrics/constants");
18
18
  var _TaskUtils = require("./TaskUtils");
19
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
20
20
  /** @internal */
21
21
  class TaskManager extends _events.default {
22
22
  /**
@@ -55,6 +55,9 @@ class TaskManager extends _events.default {
55
55
  getAgentId() {
56
56
  return this.agentId;
57
57
  }
58
+ setWebRtcEnabled(webRtcEnabled) {
59
+ this.webRtcEnabled = webRtcEnabled;
60
+ }
58
61
  handleIncomingWebCall = call => {
59
62
  const currentTask = Object.values(this.taskCollection).find(task => task.data.interaction.mediaType === 'telephony');
60
63
  if (currentTask) {
@@ -106,16 +109,13 @@ class TaskManager extends _events.default {
106
109
  interactionId: payload.data.interactionId
107
110
  });
108
111
 
109
- // Pre-calculate isConferenceInProgress for the initial task data
110
- const simulatedTaskForAgentContact = {
111
- data: {
112
- ...payload.data
113
- }
114
- };
112
+ // Check if auto-answer should happen for this task
113
+ const shouldAutoAnswer = (0, _TaskUtils.shouldAutoAnswerTask)(payload.data, this.agentId, this.webCallingService.loginOption, this.webRtcEnabled);
115
114
  task = new _.default(this.contact, this.webCallingService, {
116
115
  ...payload.data,
117
116
  wrapUpRequired: payload.data.interaction?.participants?.[this.agentId]?.isWrapUp || false,
118
- isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(simulatedTaskForAgentContact)
117
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(payload.data),
118
+ isAutoAnswering: shouldAutoAnswer // Set flag before emitting
119
119
  }, this.wrapupData, this.agentId);
120
120
  this.taskCollection[payload.data.interactionId] = task;
121
121
  // Condition 1: The state is=new i.e it is a incoming task
@@ -138,18 +138,23 @@ class TaskManager extends _events.default {
138
138
  }
139
139
  break;
140
140
  case _types2.CC_EVENTS.AGENT_CONTACT_RESERVED:
141
- task = new _.default(this.contact, this.webCallingService, {
142
- ...payload.data,
143
- isConsulted: false
144
- }, this.wrapupData, this.agentId);
145
- this.taskCollection[payload.data.interactionId] = task;
146
- if (this.webCallingService.loginOption !== _types3.LoginOption.BROWSER || task.data.interaction.mediaType !== _types.MEDIA_CHANNEL.TELEPHONY // for digital channels
147
- ) {
148
- this.emit(_types.TASK_EVENTS.TASK_INCOMING, task);
149
- } else if (this.call) {
150
- this.emit(_types.TASK_EVENTS.TASK_INCOMING, task);
141
+ {
142
+ // Check if auto-answer should happen for this task
143
+ const shouldAutoAnswerReserved = (0, _TaskUtils.shouldAutoAnswerTask)(payload.data, this.agentId, this.webCallingService.loginOption, this.webRtcEnabled);
144
+ task = new _.default(this.contact, this.webCallingService, {
145
+ ...payload.data,
146
+ isConsulted: false,
147
+ isAutoAnswering: shouldAutoAnswerReserved // Set flag before emitting
148
+ }, this.wrapupData, this.agentId);
149
+ this.taskCollection[payload.data.interactionId] = task;
150
+ if (this.webCallingService.loginOption !== _types3.LoginOption.BROWSER || task.data.interaction.mediaType !== _types.MEDIA_CHANNEL.TELEPHONY // for digital channels
151
+ ) {
152
+ this.emit(_types.TASK_EVENTS.TASK_INCOMING, task);
153
+ } else if (this.call) {
154
+ this.emit(_types.TASK_EVENTS.TASK_INCOMING, task);
155
+ }
156
+ break;
151
157
  }
152
- break;
153
158
  case _types2.CC_EVENTS.AGENT_OFFER_CONTACT:
154
159
  // We don't have to emit any event here since this will be result of promise.
155
160
  task = this.updateTaskData(task, payload.data);
@@ -159,17 +164,25 @@ class TaskManager extends _events.default {
159
164
  interactionId: payload.data?.interactionId
160
165
  });
161
166
  this.emit(_types.TASK_EVENTS.TASK_OFFER_CONTACT, task);
167
+
168
+ // Handle auto-answer for offer contact
169
+ this.handleAutoAnswer(task);
162
170
  break;
163
171
  case _types2.CC_EVENTS.AGENT_OUTBOUND_FAILED:
164
- // We don't have to emit any event here since this will be result of promise.
165
- if (task.data) {
166
- this.removeTaskFromCollection(task);
172
+ if (task) {
173
+ task = this.updateTaskData(task, payload.data);
174
+ this.metricsManager.trackEvent(_constants3.METRIC_EVENT_NAMES.TASK_OUTDIAL_FAILED, {
175
+ ..._MetricsManager.default.getCommonTrackingFieldForAQMResponse(payload.data),
176
+ taskId: payload.data.interactionId,
177
+ reason: payload.data.reasonCode || payload.data.reason
178
+ }, ['behavioral', 'operational']);
179
+ _loggerProxy.default.log(`Agent outbound failed for task`, {
180
+ module: _constants.TASK_MANAGER_FILE,
181
+ method: _constants2.METHODS.REGISTER_TASK_LISTENERS,
182
+ interactionId: payload.data.interactionId
183
+ });
184
+ task.emit(_types.TASK_EVENTS.TASK_OUTDIAL_FAILED, payload.data.reason ?? 'UNKNOWN_REASON');
167
185
  }
168
- _loggerProxy.default.log(`Agent outbound failed for task`, {
169
- module: _constants.TASK_MANAGER_FILE,
170
- method: _constants2.METHODS.REGISTER_TASK_LISTENERS,
171
- interactionId: payload.data?.interactionId
172
- });
173
186
  break;
174
187
  case _types2.CC_EVENTS.AGENT_CONTACT_ASSIGNED:
175
188
  task = this.updateTaskData(task, payload.data);
@@ -202,12 +215,20 @@ class TaskManager extends _events.default {
202
215
  break;
203
216
  }
204
217
  case _types2.CC_EVENTS.CONTACT_ENDED:
205
- task = this.updateTaskData(task, {
206
- ...payload.data,
207
- wrapUpRequired: payload.data.interaction.state !== 'new'
208
- });
209
- this.handleTaskCleanup(task);
210
- task.emit(_types.TASK_EVENTS.TASK_END, task);
218
+ // Update task data
219
+ if (task) {
220
+ task = this.updateTaskData(task, {
221
+ ...payload.data,
222
+ wrapUpRequired: payload.data.interaction.state !== 'new' && !(0, _TaskUtils.isSecondaryEpDnAgent)(payload.data.interaction)
223
+ });
224
+
225
+ // Handle cleanup based on whether task should be deleted
226
+ this.handleTaskCleanup(task);
227
+ task?.emit(_types.TASK_EVENTS.TASK_END, task);
228
+ }
229
+ break;
230
+ case _types2.CC_EVENTS.CONTACT_MERGED:
231
+ task = this.handleContactMerged(task, payload.data);
211
232
  break;
212
233
  case _types2.CC_EVENTS.AGENT_CONTACT_HELD:
213
234
  // As soon as the main interaction is held, we need to emit TASK_HOLD
@@ -236,7 +257,6 @@ class TaskManager extends _events.default {
236
257
  ...payload.data,
237
258
  isConsulted: false // This ensures that the task consult status is always reset
238
259
  });
239
-
240
260
  task.emit(_types.TASK_EVENTS.TASK_CONSULT_CREATED, task);
241
261
  break;
242
262
  case _types2.CC_EVENTS.AGENT_OFFER_CONSULT:
@@ -245,8 +265,10 @@ class TaskManager extends _events.default {
245
265
  ...payload.data,
246
266
  isConsulted: true // This ensures that the task is marked as us being requested for a consult
247
267
  });
248
-
249
268
  task.emit(_types.TASK_EVENTS.TASK_OFFER_CONSULT, task);
269
+
270
+ // Handle auto-answer for consult offer
271
+ this.handleAutoAnswer(task);
250
272
  break;
251
273
  case _types2.CC_EVENTS.AGENT_CONSULTING:
252
274
  // Received when agent is in an active consult state
@@ -330,22 +352,13 @@ class TaskManager extends _events.default {
330
352
  } else {
331
353
  this.removeTaskFromCollection(task);
332
354
  }
333
- task?.emit(_types.TASK_EVENTS.TASK_CONFERENCE_ENDED, task);
355
+ task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_ENDED, task);
334
356
  break;
335
357
  case _types2.CC_EVENTS.PARTICIPANT_JOINED_CONFERENCE:
336
358
  {
337
- // Participant joined conference - update task state with participant information and emit event
338
- // Pre-calculate isConferenceInProgress with updated data to avoid double update
339
- const simulatedTaskForJoin = {
340
- ...task,
341
- data: {
342
- ...task.data,
343
- ...payload.data
344
- }
345
- };
346
359
  task = this.updateTaskData(task, {
347
360
  ...payload.data,
348
- isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(simulatedTaskForJoin)
361
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(payload.data)
349
362
  });
350
363
  task.emit(_types.TASK_EVENTS.TASK_PARTICIPANT_JOINED, task);
351
364
  break;
@@ -353,17 +366,10 @@ class TaskManager extends _events.default {
353
366
  case _types2.CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE:
354
367
  {
355
368
  // Conference ended - update task state and emit event
356
- // Pre-calculate isConferenceInProgress with updated data to avoid double update
357
- const simulatedTaskForLeft = {
358
- ...task,
359
- data: {
360
- ...task.data,
361
- ...payload.data
362
- }
363
- };
369
+
364
370
  task = this.updateTaskData(task, {
365
371
  ...payload.data,
366
- isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(simulatedTaskForLeft)
372
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(payload.data)
367
373
  });
368
374
  if ((0, _TaskUtils.checkParticipantNotInInteraction)(task, this.agentId)) {
369
375
  if ((0, _TaskUtils.isParticipantInMainInteraction)(task, this.agentId) || (0, _TaskUtils.isPrimary)(task, this.agentId)) {
@@ -396,13 +402,10 @@ class TaskManager extends _events.default {
396
402
  task = this.updateTaskData(task, payload.data);
397
403
  task.emit(_types.TASK_EVENTS.TASK_CONFERENCE_TRANSFER_FAILED, task);
398
404
  break;
399
- case _types2.CC_EVENTS.CONSULTED_PARTICIPANT_MOVING:
400
- // Participant is being moved/transferred - update task state with movement info
401
- task = this.updateTaskData(task, payload.data);
402
- break;
403
405
  case _types2.CC_EVENTS.PARTICIPANT_POST_CALL_ACTIVITY:
404
406
  // Post-call activity for participant - update task state with activity details
405
407
  task = this.updateTaskData(task, payload.data);
408
+ task.emit(_types.TASK_EVENTS.TASK_POST_CALL_ACTIVITY, task);
406
409
  break;
407
410
  default:
408
411
  break;
@@ -436,6 +439,44 @@ class TaskManager extends _events.default {
436
439
  return task;
437
440
  }
438
441
  }
442
+
443
+ /**
444
+ * Handles CONTACT_MERGED event logic
445
+ * @param task - The task to process
446
+ * @param taskData - The task data from the event payload
447
+ * @returns Updated or newly created task
448
+ * @private
449
+ */
450
+ handleContactMerged(task, taskData) {
451
+ if (taskData.childInteractionId) {
452
+ // remove the child task from collection
453
+ this.removeTaskFromCollection(this.taskCollection[taskData.childInteractionId]);
454
+ }
455
+ if (this.taskCollection[taskData.interactionId]) {
456
+ _loggerProxy.default.log(`Got CONTACT_MERGED: Task already exists in collection`, {
457
+ module: _constants.TASK_MANAGER_FILE,
458
+ method: _constants2.METHODS.REGISTER_TASK_LISTENERS,
459
+ interactionId: taskData.interactionId
460
+ });
461
+ // update the task data
462
+ task = this.updateTaskData(task, taskData);
463
+ } else {
464
+ // Case2 : Task is not present in taskCollection
465
+ _loggerProxy.default.log(`Got CONTACT_MERGED : Creating new task in taskManager`, {
466
+ module: _constants.TASK_MANAGER_FILE,
467
+ method: _constants2.METHODS.REGISTER_TASK_LISTENERS,
468
+ interactionId: taskData.interactionId
469
+ });
470
+ task = new _.default(this.contact, this.webCallingService, {
471
+ ...taskData,
472
+ wrapUpRequired: taskData.interaction?.participants?.[this.agentId]?.isWrapUp || false,
473
+ isConferenceInProgress: (0, _TaskUtils.getIsConferenceInProgress)(taskData)
474
+ }, this.wrapupData, this.agentId);
475
+ this.taskCollection[taskData.interactionId] = task;
476
+ }
477
+ this.emit(_types.TASK_EVENTS.TASK_MERGED, task);
478
+ return task;
479
+ }
439
480
  removeTaskFromCollection(task) {
440
481
  if (task?.data?.interactionId) {
441
482
  delete this.taskCollection[task.data.interactionId];
@@ -446,14 +487,86 @@ class TaskManager extends _events.default {
446
487
  });
447
488
  }
448
489
  }
490
+
491
+ /**
492
+ * Handles auto-answer logic for incoming tasks
493
+ * Automatically accepts tasks when isAutoAnswering flag is set
494
+ * The flag is set during task creation based on:
495
+ * 1. WebRTC calls with auto-answer enabled in agent profile
496
+ * 2. Agent-initiated WebRTC outdial calls
497
+ * 3. Agent-initiated digital outbound (Email/SMS) without previous transfers
498
+ *
499
+ * @param task - The task to auto-answer
500
+ * @private
501
+ */
502
+ async handleAutoAnswer(task) {
503
+ if (!task || !task.data || !task.data.isAutoAnswering) {
504
+ return;
505
+ }
506
+ _loggerProxy.default.info(`Auto-answering task`, {
507
+ module: _constants.TASK_MANAGER_FILE,
508
+ method: 'handleAutoAnswer',
509
+ interactionId: task.data.interactionId
510
+ });
511
+ try {
512
+ await task.accept();
513
+ _loggerProxy.default.info(`Task auto-answered successfully`, {
514
+ module: _constants.TASK_MANAGER_FILE,
515
+ method: 'handleAutoAnswer',
516
+ interactionId: task.data.interactionId
517
+ });
518
+
519
+ // Track successful auto-answer
520
+ this.metricsManager.trackEvent(_constants3.METRIC_EVENT_NAMES.TASK_AUTO_ANSWER_SUCCESS, {
521
+ taskId: task.data.interactionId,
522
+ mediaType: task.data.interaction.mediaType,
523
+ isAutoAnswered: true
524
+ }, ['behavioral', 'operational']);
525
+ // Emit task:autoAnswered event for widgets/UI to react
526
+ task.emit(_types.TASK_EVENTS.TASK_AUTO_ANSWERED, task);
527
+ } catch (error) {
528
+ // Reset isAutoAnswering flag on failure
529
+ task.updateTaskData({
530
+ ...task.data,
531
+ isAutoAnswering: false
532
+ });
533
+ _loggerProxy.default.error(`Failed to auto-answer task`, {
534
+ module: _constants.TASK_MANAGER_FILE,
535
+ method: 'handleAutoAnswer',
536
+ interactionId: task.data.interactionId,
537
+ error
538
+ });
539
+
540
+ // Track auto-answer failure
541
+ this.metricsManager.trackEvent(_constants3.METRIC_EVENT_NAMES.TASK_AUTO_ANSWER_FAILED, {
542
+ taskId: task.data.interactionId,
543
+ mediaType: task.data.interaction.mediaType,
544
+ error: error?.message || 'Unknown error',
545
+ isAutoAnswered: false
546
+ }, ['behavioral', 'operational']);
547
+ }
548
+ }
549
+
550
+ /**
551
+ * Handles cleanup of task resources including Desktop/WebRTC call cleanup and task removal
552
+ * @param task - The task to clean up
553
+ * @private
554
+ */
449
555
  handleTaskCleanup(task) {
556
+ // Clean up Desktop/WebRTC calling resources for browser-based telephony tasks
450
557
  if (this.webCallingService.loginOption === _types3.LoginOption.BROWSER && task.data.interaction.mediaType === 'telephony') {
451
558
  task.unregisterWebCallListeners();
452
559
  this.webCallingService.cleanUpCall();
453
560
  }
454
- if (task.data.interaction.state === 'new') {
455
- // Only remove tasks in 'new' state immediately. For other states,
456
- // retain tasks until they complete wrap-up, unless the task disconnected before being answered.
561
+ const isOutdial = task.data.interaction.outboundType === 'OUTDIAL';
562
+ const isNew = task.data.interaction.state === 'new';
563
+ const needsWrapUp = task.data.agentsPendingWrapUp?.length > 0;
564
+
565
+ // For OUTDIAL: only remove if NOT terminated (user-declined, no wrap-up follows)
566
+ // If terminated, keep task for wrap-up flow (CONTACT_ENDED → AGENT_WRAPUP)
567
+ // For non-OUTDIAL: remove if state is 'new'
568
+ // Always remove if secondary EpDn agent
569
+ if (isNew && !(isOutdial && needsWrapUp) || (0, _TaskUtils.isSecondaryEpDnAgent)(task.data.interaction)) {
457
570
  this.removeTaskFromCollection(task);
458
571
  }
459
572
  }
@@ -1 +1 @@
1
- {"version":3,"names":["_events","_interopRequireDefault","require","_calling","_types","_constants","_constants2","_types2","_types3","_loggerProxy","_","_MetricsManager","_constants3","_TaskUtils","obj","__esModule","default","TaskManager","EventEmitter","constructor","contact","webCallingService","webSocketManager","taskCollection","metricsManager","MetricsManager","getInstance","registerTaskListeners","registerIncomingCallEvent","setWrapupData","wrapupData","setAgentId","agentId","getAgentId","handleIncomingWebCall","call","currentTask","Object","values","find","task","data","interaction","mediaType","mapCallToTask","getCallId","interactionId","LoggerProxy","log","module","TASK_MANAGER_FILE","method","METHODS","HANDLE_INCOMING_WEB_CALL","emit","TASK_EVENTS","TASK_INCOMING","on","LINE_EVENTS","INCOMING_CALL","unregisterIncomingCallEvent","off","event","payload","JSON","parse","type","CC_TASK_EVENTS","includes","info","REGISTER_TASK_LISTENERS","CC_EVENTS","AGENT_CONTACT","simulatedTaskForAgentContact","Task","wrapUpRequired","participants","isWrapUp","isConferenceInProgress","getIsConferenceInProgress","state","TASK_HYDRATE","AGENT_CONTACT_RESERVED","isConsulted","loginOption","LoginOption","BROWSER","MEDIA_CHANNEL","TELEPHONY","AGENT_OFFER_CONTACT","updateTaskData","TASK_OFFER_CONTACT","AGENT_OUTBOUND_FAILED","removeTaskFromCollection","AGENT_CONTACT_ASSIGNED","TASK_ASSIGNED","AGENT_CONTACT_UNASSIGNED","TASK_END","AGENT_CONTACT_OFFER_RONA","AGENT_CONTACT_ASSIGN_FAILED","AGENT_INVITE_FAILED","eventTypeToMetricMap","metricEventName","trackEvent","METRIC_EVENT_NAMES","getCommonTrackingFieldForAQMResponse","taskId","reason","handleTaskCleanup","TASK_REJECT","CONTACT_ENDED","AGENT_CONTACT_HELD","TASK_HOLD","AGENT_CONTACT_UNHELD","TASK_RESUME","AGENT_VTEAM_TRANSFERRED","AGENT_CTQ_CANCEL_FAILED","TASK_CONSULT_QUEUE_FAILED","AGENT_CONSULT_CREATED","TASK_CONSULT_CREATED","AGENT_OFFER_CONSULT","TASK_OFFER_CONSULT","AGENT_CONSULTING","TASK_CONSULT_ACCEPTED","TASK_CONSULTING","AGENT_CONSULT_FAILED","AGENT_CONSULT_ENDED","TASK_CONSULT_END","AGENT_CTQ_CANCELLED","TASK_CONSULT_QUEUE_CANCELLED","AGENT_WRAPUP","AGENT_WRAPPEDUP","cancelAutoWrapupTimer","TASK_WRAPPEDUP","CONTACT_RECORDING_PAUSED","TASK_RECORDING_PAUSED","CONTACT_RECORDING_PAUSE_FAILED","TASK_RECORDING_PAUSE_FAILED","CONTACT_RECORDING_RESUMED","TASK_RECORDING_RESUMED","CONTACT_RECORDING_RESUME_FAILED","TASK_RECORDING_RESUME_FAILED","AGENT_CONSULT_CONFERENCING","TASK_CONFERENCE_ESTABLISHING","AGENT_CONSULT_CONFERENCED","TASK_CONFERENCE_STARTED","AGENT_CONSULT_CONFERENCE_FAILED","TASK_CONFERENCE_FAILED","AGENT_CONSULT_CONFERENCE_ENDED","isPrimary","isParticipantInMainInteraction","TASK_CONFERENCE_ENDED","PARTICIPANT_JOINED_CONFERENCE","simulatedTaskForJoin","TASK_PARTICIPANT_JOINED","PARTICIPANT_LEFT_CONFERENCE","simulatedTaskForLeft","checkParticipantNotInInteraction","TASK_PARTICIPANT_LEFT","PARTICIPANT_LEFT_CONFERENCE_FAILED","TASK_PARTICIPANT_LEFT_FAILED","AGENT_CONSULT_CONFERENCE_END_FAILED","TASK_CONFERENCE_END_FAILED","AGENT_CONFERENCE_TRANSFERRED","TASK_CONFERENCE_TRANSFERRED","AGENT_CONFERENCE_TRANSFER_FAILED","TASK_CONFERENCE_TRANSFER_FAILED","CONSULTED_PARTICIPANT_MOVING","PARTICIPANT_POST_CALL_ACTIVITY","taskData","undefined","warn","UPDATE_TASK_DATA","error","REMOVE_TASK_FROM_COLLECTION","unregisterWebCallListeners","cleanUpCall","getTask","getAllTasks","getTaskManager","taskManager","exports"],"sources":["TaskManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {ICall, LINE_EVENTS} from '@webex/calling';\nimport {WebSocketManager} from '../core/websocket/WebSocketManager';\nimport routingContact from './contact';\nimport WebCallingService from '../WebCallingService';\nimport {ITask, MEDIA_CHANNEL, TASK_EVENTS, TaskData, TaskId} from './types';\nimport {TASK_MANAGER_FILE} from '../../constants';\nimport {METHODS} from './constants';\nimport {CC_EVENTS, CC_TASK_EVENTS, WrapupData} from '../config/types';\nimport {LoginOption} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport Task from '.';\nimport MetricsManager from '../../metrics/MetricsManager';\nimport {METRIC_EVENT_NAMES} from '../../metrics/constants';\nimport {\n checkParticipantNotInInteraction,\n getIsConferenceInProgress,\n isParticipantInMainInteraction,\n isPrimary,\n} from './TaskUtils';\n\n/** @internal */\nexport default class TaskManager extends EventEmitter {\n private call: ICall;\n private contact: ReturnType<typeof routingContact>;\n /**\n * Collection of tasks indexed by TaskId\n * @type {Record<TaskId, ITask>}\n * @private\n */\n private taskCollection: Record<TaskId, ITask>;\n private webCallingService: WebCallingService;\n private webSocketManager: WebSocketManager;\n private metricsManager: MetricsManager;\n private static taskManager;\n private wrapupData: WrapupData;\n private agentId: string;\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n constructor(\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ) {\n super();\n this.contact = contact;\n this.taskCollection = {};\n this.webCallingService = webCallingService;\n this.webSocketManager = webSocketManager;\n this.metricsManager = MetricsManager.getInstance();\n this.registerTaskListeners();\n this.registerIncomingCallEvent();\n }\n\n public setWrapupData(wrapupData: WrapupData) {\n this.wrapupData = wrapupData;\n }\n\n public setAgentId(agentId: string) {\n this.agentId = agentId;\n }\n\n /**\n * Gets the current agent ID\n * @returns {string} The agent ID set for this task manager instance\n * @public\n */\n public getAgentId(): string {\n return this.agentId;\n }\n\n private handleIncomingWebCall = (call: ICall) => {\n const currentTask = Object.values(this.taskCollection).find(\n (task) => task.data.interaction.mediaType === 'telephony'\n );\n\n if (currentTask) {\n this.webCallingService.mapCallToTask(call.getCallId(), currentTask.data.interactionId);\n LoggerProxy.log(`Call mapped to task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.HANDLE_INCOMING_WEB_CALL,\n interactionId: currentTask.data.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_INCOMING, currentTask);\n }\n this.call = call;\n };\n\n public registerIncomingCallEvent() {\n this.webCallingService.on(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n public unregisterIncomingCallEvent() {\n this.webCallingService.off(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n private registerTaskListeners() {\n this.webSocketManager.on('message', (event) => {\n const payload = JSON.parse(event);\n // Re-emit the task events to the task object\n let task: ITask;\n if (payload.data?.type) {\n if (Object.values(CC_TASK_EVENTS).includes(payload.data.type)) {\n task = this.taskCollection[payload.data.interactionId];\n }\n LoggerProxy.info(`Handling task event ${payload.data?.type}`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n switch (payload.data.type) {\n case CC_EVENTS.AGENT_CONTACT:\n // Case1 : Task is already present in taskCollection\n if (this.taskCollection[payload.data.interactionId]) {\n LoggerProxy.log(`Got AGENT_CONTACT: Task already exists in collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n break;\n } else if (!this.taskCollection[payload.data.interactionId]) {\n // Case2 : Task is not present in taskCollection\n LoggerProxy.log(`Got AGENT_CONTACT : Creating new task in taskManager`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n\n // Pre-calculate isConferenceInProgress for the initial task data\n const simulatedTaskForAgentContact = {\n data: {...payload.data},\n } as ITask;\n\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n wrapUpRequired:\n payload.data.interaction?.participants?.[this.agentId]?.isWrapUp || false,\n isConferenceInProgress: getIsConferenceInProgress(simulatedTaskForAgentContact),\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[payload.data.interactionId] = task;\n // Condition 1: The state is=new i.e it is a incoming task\n if (payload.data.interaction.state === 'new') {\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=new, sending TASK_INCOMING event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else {\n // Condition 2: The state is anything else i.e the task was connected\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=${payload.data.interaction.state}, sending TASK_HYDRATE event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_HYDRATE, task);\n }\n }\n break;\n\n case CC_EVENTS.AGENT_CONTACT_RESERVED:\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n isConsulted: false,\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[payload.data.interactionId] = task;\n if (\n this.webCallingService.loginOption !== LoginOption.BROWSER ||\n task.data.interaction.mediaType !== MEDIA_CHANNEL.TELEPHONY // for digital channels\n ) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else if (this.call) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n }\n break;\n case CC_EVENTS.AGENT_OFFER_CONTACT:\n // We don't have to emit any event here since this will be result of promise.\n task = this.updateTaskData(task, payload.data);\n LoggerProxy.log(`Agent offer contact received for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_OFFER_CONTACT, task);\n break;\n case CC_EVENTS.AGENT_OUTBOUND_FAILED:\n // We don't have to emit any event here since this will be result of promise.\n if (task.data) {\n this.removeTaskFromCollection(task);\n }\n LoggerProxy.log(`Agent outbound failed for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n break;\n case CC_EVENTS.AGENT_CONTACT_ASSIGNED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_ASSIGNED, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNASSIGNED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_OFFER_RONA:\n case CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED:\n case CC_EVENTS.AGENT_INVITE_FAILED: {\n task = this.updateTaskData(task, payload.data);\n\n const eventTypeToMetricMap: Record<string, keyof typeof METRIC_EVENT_NAMES> = {\n [CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED]: 'AGENT_CONTACT_ASSIGN_FAILED',\n [CC_EVENTS.AGENT_INVITE_FAILED]: 'AGENT_INVITE_FAILED',\n };\n const metricEventName: keyof typeof METRIC_EVENT_NAMES =\n eventTypeToMetricMap[payload.data.type] || 'AGENT_RONA';\n\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES[metricEventName],\n {\n ...MetricsManager.getCommonTrackingFieldForAQMResponse(payload.data),\n taskId: payload.data.interactionId,\n reason: payload.data.reason,\n },\n ['behavioral', 'operational']\n );\n this.handleTaskCleanup(task);\n task.emit(TASK_EVENTS.TASK_REJECT, payload.data.reason);\n break;\n }\n case CC_EVENTS.CONTACT_ENDED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: payload.data.interaction.state !== 'new',\n });\n this.handleTaskCleanup(task);\n task.emit(TASK_EVENTS.TASK_END, task);\n\n break;\n case CC_EVENTS.AGENT_CONTACT_HELD:\n // As soon as the main interaction is held, we need to emit TASK_HOLD\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_HOLD, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNHELD:\n // As soon as the main interaction is unheld, we need to emit TASK_RESUME\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RESUME, task);\n break;\n case CC_EVENTS.AGENT_VTEAM_TRANSFERRED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCEL_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CREATED:\n // Received when self agent initiates a consult\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: false, // This ensures that the task consult status is always reset\n });\n task.emit(TASK_EVENTS.TASK_CONSULT_CREATED, task);\n break;\n case CC_EVENTS.AGENT_OFFER_CONSULT:\n // Received when other agent sends us a consult offer\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: true, // This ensures that the task is marked as us being requested for a consult\n });\n task.emit(TASK_EVENTS.TASK_OFFER_CONSULT, task);\n break;\n case CC_EVENTS.AGENT_CONSULTING:\n // Received when agent is in an active consult state\n // TODO: Check if we can use backend consult state instead of isConsulted\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // Fire only if you are the agent who received the consult request\n task.emit(TASK_EVENTS.TASK_CONSULT_ACCEPTED, task);\n } else {\n // Fire only if you are the agent who initiated the consult\n task.emit(TASK_EVENTS.TASK_CONSULTING, task);\n }\n break;\n case CC_EVENTS.AGENT_CONSULT_FAILED:\n // This can only be received by the agent who initiated the consult.\n // We need not emit any event here since this will be result of promise\n task = this.updateTaskData(task, payload.data);\n break;\n case CC_EVENTS.AGENT_CONSULT_ENDED:\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // This will be the end state of the task as soon as we end the consult in case of\n // us being offered a consult\n this.removeTaskFromCollection(task);\n }\n task.emit(TASK_EVENTS.TASK_CONSULT_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCELLED:\n // This event is received when the consult using queue is cancelled using API\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_CANCELLED, task);\n break;\n case CC_EVENTS.AGENT_WRAPUP:\n task = this.updateTaskData(task, {...payload.data, wrapUpRequired: true});\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_WRAPPEDUP:\n task.cancelAutoWrapupTimer();\n this.removeTaskFromCollection(task);\n task.emit(TASK_EVENTS.TASK_WRAPPEDUP, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSE_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSE_FAILED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUMED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUMED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUME_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUME_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCING:\n // Conference is being established - update task state and emit establishing event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_ESTABLISHING, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCED:\n // Conference started successfully - update task state and emit event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_STARTED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_FAILED:\n // Conference failed - update task state and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_ENDED:\n // Conference ended - update task state and emit event\n task = this.updateTaskData(task, payload.data);\n if (\n !task ||\n isPrimary(task, this.agentId) ||\n isParticipantInMainInteraction(task, this.agentId)\n ) {\n LoggerProxy.log('Primary or main interaction participant leaving conference');\n } else {\n this.removeTaskFromCollection(task);\n }\n task?.emit(TASK_EVENTS.TASK_CONFERENCE_ENDED, task);\n break;\n case CC_EVENTS.PARTICIPANT_JOINED_CONFERENCE: {\n // Participant joined conference - update task state with participant information and emit event\n // Pre-calculate isConferenceInProgress with updated data to avoid double update\n const simulatedTaskForJoin = {\n ...task,\n data: {...task.data, ...payload.data},\n };\n task = this.updateTaskData(task, {\n ...payload.data,\n isConferenceInProgress: getIsConferenceInProgress(simulatedTaskForJoin),\n });\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_JOINED, task);\n break;\n }\n case CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE: {\n // Conference ended - update task state and emit event\n // Pre-calculate isConferenceInProgress with updated data to avoid double update\n const simulatedTaskForLeft = {\n ...task,\n data: {...task.data, ...payload.data},\n };\n task = this.updateTaskData(task, {\n ...payload.data,\n isConferenceInProgress: getIsConferenceInProgress(simulatedTaskForLeft),\n });\n if (checkParticipantNotInInteraction(task, this.agentId)) {\n if (\n isParticipantInMainInteraction(task, this.agentId) ||\n isPrimary(task, this.agentId)\n ) {\n LoggerProxy.log('Primary or main interaction participant leaving conference');\n } else {\n this.removeTaskFromCollection(task);\n }\n }\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_LEFT, task);\n break;\n }\n case CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE_FAILED:\n // Conference exit failed - update task state and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_LEFT_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_END_FAILED:\n // Conference end failed - update task state with error details and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_END_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONFERENCE_TRANSFERRED:\n // Conference was transferred - update task state and emit transfer success event\n // Note: Backend should provide hasLeft and wrapUpRequired status\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_TRANSFERRED, task);\n break;\n case CC_EVENTS.AGENT_CONFERENCE_TRANSFER_FAILED:\n // Conference transfer failed - update task state with error details and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_TRANSFER_FAILED, task);\n break;\n case CC_EVENTS.CONSULTED_PARTICIPANT_MOVING:\n // Participant is being moved/transferred - update task state with movement info\n task = this.updateTaskData(task, payload.data);\n break;\n case CC_EVENTS.PARTICIPANT_POST_CALL_ACTIVITY:\n // Post-call activity for participant - update task state with activity details\n task = this.updateTaskData(task, payload.data);\n break;\n default:\n break;\n }\n if (task) {\n task.emit(payload.data.type, payload.data);\n }\n }\n });\n }\n\n private updateTaskData(task: ITask, taskData: TaskData): ITask {\n if (!task) {\n return undefined;\n }\n\n if (!taskData?.interactionId) {\n LoggerProxy.warn('Received task update with missing interactionId', {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n });\n }\n\n try {\n const currentTask = task.updateTaskData(taskData);\n this.taskCollection[taskData.interactionId] = currentTask;\n\n return currentTask;\n } catch (error) {\n LoggerProxy.error(`Failed to update task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n interactionId: taskData.interactionId,\n });\n\n return task;\n }\n }\n\n private removeTaskFromCollection(task: ITask) {\n if (task?.data?.interactionId) {\n delete this.taskCollection[task.data.interactionId];\n LoggerProxy.info(`Task removed from collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REMOVE_TASK_FROM_COLLECTION,\n interactionId: task.data.interactionId,\n });\n }\n }\n\n private handleTaskCleanup(task: ITask) {\n if (\n this.webCallingService.loginOption === LoginOption.BROWSER &&\n task.data.interaction.mediaType === 'telephony'\n ) {\n task.unregisterWebCallListeners();\n this.webCallingService.cleanUpCall();\n }\n if (task.data.interaction.state === 'new') {\n // Only remove tasks in 'new' state immediately. For other states,\n // retain tasks until they complete wrap-up, unless the task disconnected before being answered.\n this.removeTaskFromCollection(task);\n }\n }\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getTask = (taskId: string) => {\n return this.taskCollection[taskId];\n };\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getAllTasks = (): Record<TaskId, ITask> => {\n return this.taskCollection;\n };\n\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n public static getTaskManager = (\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ): TaskManager => {\n if (!this.taskManager) {\n this.taskManager = new TaskManager(contact, webCallingService, webSocketManager);\n }\n\n return this.taskManager;\n };\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_events","_interopRequireDefault","require","_calling","_types","_constants","_constants2","_types2","_types3","_loggerProxy","_","_MetricsManager","_constants3","_TaskUtils","e","__esModule","default","TaskManager","EventEmitter","constructor","contact","webCallingService","webSocketManager","taskCollection","metricsManager","MetricsManager","getInstance","registerTaskListeners","registerIncomingCallEvent","setWrapupData","wrapupData","setAgentId","agentId","getAgentId","setWebRtcEnabled","webRtcEnabled","handleIncomingWebCall","call","currentTask","Object","values","find","task","data","interaction","mediaType","mapCallToTask","getCallId","interactionId","LoggerProxy","log","module","TASK_MANAGER_FILE","method","METHODS","HANDLE_INCOMING_WEB_CALL","emit","TASK_EVENTS","TASK_INCOMING","on","LINE_EVENTS","INCOMING_CALL","unregisterIncomingCallEvent","off","event","payload","JSON","parse","type","CC_TASK_EVENTS","includes","info","REGISTER_TASK_LISTENERS","CC_EVENTS","AGENT_CONTACT","shouldAutoAnswer","shouldAutoAnswerTask","loginOption","Task","wrapUpRequired","participants","isWrapUp","isConferenceInProgress","getIsConferenceInProgress","isAutoAnswering","state","TASK_HYDRATE","AGENT_CONTACT_RESERVED","shouldAutoAnswerReserved","isConsulted","LoginOption","BROWSER","MEDIA_CHANNEL","TELEPHONY","AGENT_OFFER_CONTACT","updateTaskData","TASK_OFFER_CONTACT","handleAutoAnswer","AGENT_OUTBOUND_FAILED","trackEvent","METRIC_EVENT_NAMES","TASK_OUTDIAL_FAILED","getCommonTrackingFieldForAQMResponse","taskId","reason","reasonCode","AGENT_CONTACT_ASSIGNED","TASK_ASSIGNED","AGENT_CONTACT_UNASSIGNED","TASK_END","AGENT_CONTACT_OFFER_RONA","AGENT_CONTACT_ASSIGN_FAILED","AGENT_INVITE_FAILED","eventTypeToMetricMap","metricEventName","handleTaskCleanup","TASK_REJECT","CONTACT_ENDED","isSecondaryEpDnAgent","CONTACT_MERGED","handleContactMerged","AGENT_CONTACT_HELD","TASK_HOLD","AGENT_CONTACT_UNHELD","TASK_RESUME","AGENT_VTEAM_TRANSFERRED","AGENT_CTQ_CANCEL_FAILED","TASK_CONSULT_QUEUE_FAILED","AGENT_CONSULT_CREATED","TASK_CONSULT_CREATED","AGENT_OFFER_CONSULT","TASK_OFFER_CONSULT","AGENT_CONSULTING","TASK_CONSULT_ACCEPTED","TASK_CONSULTING","AGENT_CONSULT_FAILED","AGENT_CONSULT_ENDED","removeTaskFromCollection","TASK_CONSULT_END","AGENT_CTQ_CANCELLED","TASK_CONSULT_QUEUE_CANCELLED","AGENT_WRAPUP","AGENT_WRAPPEDUP","cancelAutoWrapupTimer","TASK_WRAPPEDUP","CONTACT_RECORDING_PAUSED","TASK_RECORDING_PAUSED","CONTACT_RECORDING_PAUSE_FAILED","TASK_RECORDING_PAUSE_FAILED","CONTACT_RECORDING_RESUMED","TASK_RECORDING_RESUMED","CONTACT_RECORDING_RESUME_FAILED","TASK_RECORDING_RESUME_FAILED","AGENT_CONSULT_CONFERENCING","TASK_CONFERENCE_ESTABLISHING","AGENT_CONSULT_CONFERENCED","TASK_CONFERENCE_STARTED","AGENT_CONSULT_CONFERENCE_FAILED","TASK_CONFERENCE_FAILED","AGENT_CONSULT_CONFERENCE_ENDED","isPrimary","isParticipantInMainInteraction","TASK_CONFERENCE_ENDED","PARTICIPANT_JOINED_CONFERENCE","TASK_PARTICIPANT_JOINED","PARTICIPANT_LEFT_CONFERENCE","checkParticipantNotInInteraction","TASK_PARTICIPANT_LEFT","PARTICIPANT_LEFT_CONFERENCE_FAILED","TASK_PARTICIPANT_LEFT_FAILED","AGENT_CONSULT_CONFERENCE_END_FAILED","TASK_CONFERENCE_END_FAILED","AGENT_CONFERENCE_TRANSFERRED","TASK_CONFERENCE_TRANSFERRED","AGENT_CONFERENCE_TRANSFER_FAILED","TASK_CONFERENCE_TRANSFER_FAILED","PARTICIPANT_POST_CALL_ACTIVITY","TASK_POST_CALL_ACTIVITY","taskData","undefined","warn","UPDATE_TASK_DATA","error","childInteractionId","TASK_MERGED","REMOVE_TASK_FROM_COLLECTION","accept","TASK_AUTO_ANSWER_SUCCESS","isAutoAnswered","TASK_AUTO_ANSWERED","TASK_AUTO_ANSWER_FAILED","message","unregisterWebCallListeners","cleanUpCall","isOutdial","outboundType","isNew","needsWrapUp","agentsPendingWrapUp","length","getTask","getAllTasks","getTaskManager","taskManager","exports"],"sources":["TaskManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {ICall, LINE_EVENTS} from '@webex/calling';\nimport {WebSocketManager} from '../core/websocket/WebSocketManager';\nimport routingContact from './contact';\nimport WebCallingService from '../WebCallingService';\nimport {ITask, MEDIA_CHANNEL, TASK_EVENTS, TaskData, TaskId} from './types';\nimport {TASK_MANAGER_FILE} from '../../constants';\nimport {METHODS} from './constants';\nimport {CC_EVENTS, CC_TASK_EVENTS, WrapupData} from '../config/types';\nimport {LoginOption} from '../../types';\nimport LoggerProxy from '../../logger-proxy';\nimport Task from '.';\nimport MetricsManager from '../../metrics/MetricsManager';\nimport {METRIC_EVENT_NAMES} from '../../metrics/constants';\nimport {\n checkParticipantNotInInteraction,\n getIsConferenceInProgress,\n isParticipantInMainInteraction,\n isPrimary,\n isSecondaryEpDnAgent,\n shouldAutoAnswerTask,\n} from './TaskUtils';\n\n/** @internal */\nexport default class TaskManager extends EventEmitter {\n private call: ICall;\n private contact: ReturnType<typeof routingContact>;\n /**\n * Collection of tasks indexed by TaskId\n * @type {Record<TaskId, ITask>}\n * @private\n */\n private taskCollection: Record<TaskId, ITask>;\n private webCallingService: WebCallingService;\n private webSocketManager: WebSocketManager;\n private metricsManager: MetricsManager;\n private static taskManager;\n private wrapupData: WrapupData;\n private agentId: string;\n private webRtcEnabled: boolean;\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n constructor(\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ) {\n super();\n this.contact = contact;\n this.taskCollection = {};\n this.webCallingService = webCallingService;\n this.webSocketManager = webSocketManager;\n this.metricsManager = MetricsManager.getInstance();\n this.registerTaskListeners();\n this.registerIncomingCallEvent();\n }\n\n public setWrapupData(wrapupData: WrapupData) {\n this.wrapupData = wrapupData;\n }\n\n public setAgentId(agentId: string) {\n this.agentId = agentId;\n }\n\n /**\n * Gets the current agent ID\n * @returns {string} The agent ID set for this task manager instance\n * @public\n */\n public getAgentId(): string {\n return this.agentId;\n }\n\n public setWebRtcEnabled(webRtcEnabled: boolean) {\n this.webRtcEnabled = webRtcEnabled;\n }\n\n private handleIncomingWebCall = (call: ICall) => {\n const currentTask = Object.values(this.taskCollection).find(\n (task) => task.data.interaction.mediaType === 'telephony'\n );\n\n if (currentTask) {\n this.webCallingService.mapCallToTask(call.getCallId(), currentTask.data.interactionId);\n LoggerProxy.log(`Call mapped to task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.HANDLE_INCOMING_WEB_CALL,\n interactionId: currentTask.data.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_INCOMING, currentTask);\n }\n this.call = call;\n };\n\n public registerIncomingCallEvent() {\n this.webCallingService.on(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n public unregisterIncomingCallEvent() {\n this.webCallingService.off(LINE_EVENTS.INCOMING_CALL, this.handleIncomingWebCall);\n }\n\n private registerTaskListeners() {\n this.webSocketManager.on('message', (event) => {\n const payload = JSON.parse(event);\n // Re-emit the task events to the task object\n let task: ITask;\n if (payload.data?.type) {\n if (Object.values(CC_TASK_EVENTS).includes(payload.data.type)) {\n task = this.taskCollection[payload.data.interactionId];\n }\n LoggerProxy.info(`Handling task event ${payload.data?.type}`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n switch (payload.data.type) {\n case CC_EVENTS.AGENT_CONTACT:\n // Case1 : Task is already present in taskCollection\n if (this.taskCollection[payload.data.interactionId]) {\n LoggerProxy.log(`Got AGENT_CONTACT: Task already exists in collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n break;\n } else if (!this.taskCollection[payload.data.interactionId]) {\n // Case2 : Task is not present in taskCollection\n LoggerProxy.log(`Got AGENT_CONTACT : Creating new task in taskManager`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n\n // Check if auto-answer should happen for this task\n const shouldAutoAnswer = shouldAutoAnswerTask(\n payload.data,\n this.agentId,\n this.webCallingService.loginOption,\n this.webRtcEnabled\n );\n\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n wrapUpRequired:\n payload.data.interaction?.participants?.[this.agentId]?.isWrapUp || false,\n isConferenceInProgress: getIsConferenceInProgress(payload.data),\n isAutoAnswering: shouldAutoAnswer, // Set flag before emitting\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[payload.data.interactionId] = task;\n // Condition 1: The state is=new i.e it is a incoming task\n if (payload.data.interaction.state === 'new') {\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=new, sending TASK_INCOMING event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else {\n // Condition 2: The state is anything else i.e the task was connected\n LoggerProxy.log(\n `Got AGENT_CONTACT for a task with state=${payload.data.interaction.state}, sending TASK_HYDRATE event`,\n {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n }\n );\n this.emit(TASK_EVENTS.TASK_HYDRATE, task);\n }\n }\n break;\n\n case CC_EVENTS.AGENT_CONTACT_RESERVED: {\n // Check if auto-answer should happen for this task\n const shouldAutoAnswerReserved = shouldAutoAnswerTask(\n payload.data,\n this.agentId,\n this.webCallingService.loginOption,\n this.webRtcEnabled\n );\n\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...payload.data,\n isConsulted: false,\n isAutoAnswering: shouldAutoAnswerReserved, // Set flag before emitting\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[payload.data.interactionId] = task;\n if (\n this.webCallingService.loginOption !== LoginOption.BROWSER ||\n task.data.interaction.mediaType !== MEDIA_CHANNEL.TELEPHONY // for digital channels\n ) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n } else if (this.call) {\n this.emit(TASK_EVENTS.TASK_INCOMING, task);\n }\n break;\n }\n case CC_EVENTS.AGENT_OFFER_CONTACT:\n // We don't have to emit any event here since this will be result of promise.\n task = this.updateTaskData(task, payload.data);\n LoggerProxy.log(`Agent offer contact received for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data?.interactionId,\n });\n this.emit(TASK_EVENTS.TASK_OFFER_CONTACT, task);\n\n // Handle auto-answer for offer contact\n this.handleAutoAnswer(task);\n break;\n case CC_EVENTS.AGENT_OUTBOUND_FAILED:\n if (task) {\n task = this.updateTaskData(task, payload.data);\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES.TASK_OUTDIAL_FAILED,\n {\n ...MetricsManager.getCommonTrackingFieldForAQMResponse(payload.data),\n taskId: payload.data.interactionId,\n reason: payload.data.reasonCode || payload.data.reason,\n },\n ['behavioral', 'operational']\n );\n LoggerProxy.log(`Agent outbound failed for task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: payload.data.interactionId,\n });\n task.emit(TASK_EVENTS.TASK_OUTDIAL_FAILED, payload.data.reason ?? 'UNKNOWN_REASON');\n }\n break;\n case CC_EVENTS.AGENT_CONTACT_ASSIGNED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_ASSIGNED, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNASSIGNED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_OFFER_RONA:\n case CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED:\n case CC_EVENTS.AGENT_INVITE_FAILED: {\n task = this.updateTaskData(task, payload.data);\n\n const eventTypeToMetricMap: Record<string, keyof typeof METRIC_EVENT_NAMES> = {\n [CC_EVENTS.AGENT_CONTACT_ASSIGN_FAILED]: 'AGENT_CONTACT_ASSIGN_FAILED',\n [CC_EVENTS.AGENT_INVITE_FAILED]: 'AGENT_INVITE_FAILED',\n };\n const metricEventName: keyof typeof METRIC_EVENT_NAMES =\n eventTypeToMetricMap[payload.data.type] || 'AGENT_RONA';\n\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES[metricEventName],\n {\n ...MetricsManager.getCommonTrackingFieldForAQMResponse(payload.data),\n taskId: payload.data.interactionId,\n reason: payload.data.reason,\n },\n ['behavioral', 'operational']\n );\n this.handleTaskCleanup(task);\n task.emit(TASK_EVENTS.TASK_REJECT, payload.data.reason);\n break;\n }\n case CC_EVENTS.CONTACT_ENDED:\n // Update task data\n if (task) {\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired:\n payload.data.interaction.state !== 'new' &&\n !isSecondaryEpDnAgent(payload.data.interaction),\n });\n\n // Handle cleanup based on whether task should be deleted\n this.handleTaskCleanup(task);\n\n task?.emit(TASK_EVENTS.TASK_END, task);\n }\n break;\n case CC_EVENTS.CONTACT_MERGED:\n task = this.handleContactMerged(task, payload.data);\n break;\n case CC_EVENTS.AGENT_CONTACT_HELD:\n // As soon as the main interaction is held, we need to emit TASK_HOLD\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_HOLD, task);\n break;\n case CC_EVENTS.AGENT_CONTACT_UNHELD:\n // As soon as the main interaction is unheld, we need to emit TASK_RESUME\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RESUME, task);\n break;\n case CC_EVENTS.AGENT_VTEAM_TRANSFERRED:\n task = this.updateTaskData(task, {\n ...payload.data,\n wrapUpRequired: true,\n });\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCEL_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CREATED:\n // Received when self agent initiates a consult\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: false, // This ensures that the task consult status is always reset\n });\n task.emit(TASK_EVENTS.TASK_CONSULT_CREATED, task);\n break;\n case CC_EVENTS.AGENT_OFFER_CONSULT:\n // Received when other agent sends us a consult offer\n task = this.updateTaskData(task, {\n ...payload.data,\n isConsulted: true, // This ensures that the task is marked as us being requested for a consult\n });\n task.emit(TASK_EVENTS.TASK_OFFER_CONSULT, task);\n\n // Handle auto-answer for consult offer\n this.handleAutoAnswer(task);\n break;\n case CC_EVENTS.AGENT_CONSULTING:\n // Received when agent is in an active consult state\n // TODO: Check if we can use backend consult state instead of isConsulted\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // Fire only if you are the agent who received the consult request\n task.emit(TASK_EVENTS.TASK_CONSULT_ACCEPTED, task);\n } else {\n // Fire only if you are the agent who initiated the consult\n task.emit(TASK_EVENTS.TASK_CONSULTING, task);\n }\n break;\n case CC_EVENTS.AGENT_CONSULT_FAILED:\n // This can only be received by the agent who initiated the consult.\n // We need not emit any event here since this will be result of promise\n task = this.updateTaskData(task, payload.data);\n break;\n case CC_EVENTS.AGENT_CONSULT_ENDED:\n task = this.updateTaskData(task, payload.data);\n if (task.data.isConsulted) {\n // This will be the end state of the task as soon as we end the consult in case of\n // us being offered a consult\n this.removeTaskFromCollection(task);\n }\n task.emit(TASK_EVENTS.TASK_CONSULT_END, task);\n break;\n case CC_EVENTS.AGENT_CTQ_CANCELLED:\n // This event is received when the consult using queue is cancelled using API\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONSULT_QUEUE_CANCELLED, task);\n break;\n case CC_EVENTS.AGENT_WRAPUP:\n task = this.updateTaskData(task, {...payload.data, wrapUpRequired: true});\n task.emit(TASK_EVENTS.TASK_END, task);\n break;\n case CC_EVENTS.AGENT_WRAPPEDUP:\n task.cancelAutoWrapupTimer();\n this.removeTaskFromCollection(task);\n task.emit(TASK_EVENTS.TASK_WRAPPEDUP, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_PAUSE_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_PAUSE_FAILED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUMED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUMED, task);\n break;\n case CC_EVENTS.CONTACT_RECORDING_RESUME_FAILED:\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_RECORDING_RESUME_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCING:\n // Conference is being established - update task state and emit establishing event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_ESTABLISHING, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCED:\n // Conference started successfully - update task state and emit event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_STARTED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_FAILED:\n // Conference failed - update task state and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_ENDED:\n // Conference ended - update task state and emit event\n task = this.updateTaskData(task, payload.data);\n if (\n !task ||\n isPrimary(task, this.agentId) ||\n isParticipantInMainInteraction(task, this.agentId)\n ) {\n LoggerProxy.log('Primary or main interaction participant leaving conference');\n } else {\n this.removeTaskFromCollection(task);\n }\n task.emit(TASK_EVENTS.TASK_CONFERENCE_ENDED, task);\n break;\n case CC_EVENTS.PARTICIPANT_JOINED_CONFERENCE: {\n task = this.updateTaskData(task, {\n ...payload.data,\n isConferenceInProgress: getIsConferenceInProgress(payload.data),\n });\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_JOINED, task);\n break;\n }\n case CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE: {\n // Conference ended - update task state and emit event\n\n task = this.updateTaskData(task, {\n ...payload.data,\n isConferenceInProgress: getIsConferenceInProgress(payload.data),\n });\n if (checkParticipantNotInInteraction(task, this.agentId)) {\n if (\n isParticipantInMainInteraction(task, this.agentId) ||\n isPrimary(task, this.agentId)\n ) {\n LoggerProxy.log('Primary or main interaction participant leaving conference');\n } else {\n this.removeTaskFromCollection(task);\n }\n }\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_LEFT, task);\n break;\n }\n case CC_EVENTS.PARTICIPANT_LEFT_CONFERENCE_FAILED:\n // Conference exit failed - update task state and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_PARTICIPANT_LEFT_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONSULT_CONFERENCE_END_FAILED:\n // Conference end failed - update task state with error details and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_END_FAILED, task);\n break;\n case CC_EVENTS.AGENT_CONFERENCE_TRANSFERRED:\n // Conference was transferred - update task state and emit transfer success event\n // Note: Backend should provide hasLeft and wrapUpRequired status\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_TRANSFERRED, task);\n break;\n case CC_EVENTS.AGENT_CONFERENCE_TRANSFER_FAILED:\n // Conference transfer failed - update task state with error details and emit failure event\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_CONFERENCE_TRANSFER_FAILED, task);\n break;\n case CC_EVENTS.PARTICIPANT_POST_CALL_ACTIVITY:\n // Post-call activity for participant - update task state with activity details\n task = this.updateTaskData(task, payload.data);\n task.emit(TASK_EVENTS.TASK_POST_CALL_ACTIVITY, task);\n break;\n default:\n break;\n }\n if (task) {\n task.emit(payload.data.type, payload.data);\n }\n }\n });\n }\n\n private updateTaskData(task: ITask, taskData: TaskData): ITask {\n if (!task) {\n return undefined;\n }\n\n if (!taskData?.interactionId) {\n LoggerProxy.warn('Received task update with missing interactionId', {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n });\n }\n\n try {\n const currentTask = task.updateTaskData(taskData);\n this.taskCollection[taskData.interactionId] = currentTask;\n\n return currentTask;\n } catch (error) {\n LoggerProxy.error(`Failed to update task`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.UPDATE_TASK_DATA,\n interactionId: taskData.interactionId,\n });\n\n return task;\n }\n }\n\n /**\n * Handles CONTACT_MERGED event logic\n * @param task - The task to process\n * @param taskData - The task data from the event payload\n * @returns Updated or newly created task\n * @private\n */\n private handleContactMerged(task: ITask, taskData: TaskData): ITask {\n if (taskData.childInteractionId) {\n // remove the child task from collection\n this.removeTaskFromCollection(this.taskCollection[taskData.childInteractionId]);\n }\n\n if (this.taskCollection[taskData.interactionId]) {\n LoggerProxy.log(`Got CONTACT_MERGED: Task already exists in collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: taskData.interactionId,\n });\n // update the task data\n task = this.updateTaskData(task, taskData);\n } else {\n // Case2 : Task is not present in taskCollection\n LoggerProxy.log(`Got CONTACT_MERGED : Creating new task in taskManager`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REGISTER_TASK_LISTENERS,\n interactionId: taskData.interactionId,\n });\n\n task = new Task(\n this.contact,\n this.webCallingService,\n {\n ...taskData,\n wrapUpRequired: taskData.interaction?.participants?.[this.agentId]?.isWrapUp || false,\n isConferenceInProgress: getIsConferenceInProgress(taskData),\n },\n this.wrapupData,\n this.agentId\n );\n this.taskCollection[taskData.interactionId] = task;\n }\n\n this.emit(TASK_EVENTS.TASK_MERGED, task);\n\n return task;\n }\n\n private removeTaskFromCollection(task: ITask) {\n if (task?.data?.interactionId) {\n delete this.taskCollection[task.data.interactionId];\n LoggerProxy.info(`Task removed from collection`, {\n module: TASK_MANAGER_FILE,\n method: METHODS.REMOVE_TASK_FROM_COLLECTION,\n interactionId: task.data.interactionId,\n });\n }\n }\n\n /**\n * Handles auto-answer logic for incoming tasks\n * Automatically accepts tasks when isAutoAnswering flag is set\n * The flag is set during task creation based on:\n * 1. WebRTC calls with auto-answer enabled in agent profile\n * 2. Agent-initiated WebRTC outdial calls\n * 3. Agent-initiated digital outbound (Email/SMS) without previous transfers\n *\n * @param task - The task to auto-answer\n * @private\n */\n private async handleAutoAnswer(task: ITask): Promise<void> {\n if (!task || !task.data || !task.data.isAutoAnswering) {\n return;\n }\n\n LoggerProxy.info(`Auto-answering task`, {\n module: TASK_MANAGER_FILE,\n method: 'handleAutoAnswer',\n interactionId: task.data.interactionId,\n });\n\n try {\n await task.accept();\n LoggerProxy.info(`Task auto-answered successfully`, {\n module: TASK_MANAGER_FILE,\n method: 'handleAutoAnswer',\n interactionId: task.data.interactionId,\n });\n\n // Track successful auto-answer\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES.TASK_AUTO_ANSWER_SUCCESS,\n {\n taskId: task.data.interactionId,\n mediaType: task.data.interaction.mediaType,\n isAutoAnswered: true,\n },\n ['behavioral', 'operational']\n );\n // Emit task:autoAnswered event for widgets/UI to react\n task.emit(TASK_EVENTS.TASK_AUTO_ANSWERED, task);\n } catch (error) {\n // Reset isAutoAnswering flag on failure\n task.updateTaskData({...task.data, isAutoAnswering: false});\n LoggerProxy.error(`Failed to auto-answer task`, {\n module: TASK_MANAGER_FILE,\n method: 'handleAutoAnswer',\n interactionId: task.data.interactionId,\n error,\n });\n\n // Track auto-answer failure\n this.metricsManager.trackEvent(\n METRIC_EVENT_NAMES.TASK_AUTO_ANSWER_FAILED,\n {\n taskId: task.data.interactionId,\n mediaType: task.data.interaction.mediaType,\n error: error?.message || 'Unknown error',\n isAutoAnswered: false,\n },\n ['behavioral', 'operational']\n );\n }\n }\n\n /**\n * Handles cleanup of task resources including Desktop/WebRTC call cleanup and task removal\n * @param task - The task to clean up\n * @private\n */\n private handleTaskCleanup(task: ITask) {\n // Clean up Desktop/WebRTC calling resources for browser-based telephony tasks\n if (\n this.webCallingService.loginOption === LoginOption.BROWSER &&\n task.data.interaction.mediaType === 'telephony'\n ) {\n task.unregisterWebCallListeners();\n this.webCallingService.cleanUpCall();\n }\n\n const isOutdial = task.data.interaction.outboundType === 'OUTDIAL';\n const isNew = task.data.interaction.state === 'new';\n const needsWrapUp = task.data.agentsPendingWrapUp?.length > 0;\n\n // For OUTDIAL: only remove if NOT terminated (user-declined, no wrap-up follows)\n // If terminated, keep task for wrap-up flow (CONTACT_ENDED → AGENT_WRAPUP)\n // For non-OUTDIAL: remove if state is 'new'\n // Always remove if secondary EpDn agent\n if ((isNew && !(isOutdial && needsWrapUp)) || isSecondaryEpDnAgent(task.data.interaction)) {\n this.removeTaskFromCollection(task);\n }\n }\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getTask = (taskId: string) => {\n return this.taskCollection[taskId];\n };\n\n /**\n * @param taskId - Unique identifier for each task\n */\n public getAllTasks = (): Record<TaskId, ITask> => {\n return this.taskCollection;\n };\n\n /**\n * @param contact - Routing Contact layer. Talks to AQMReq layer to convert events to promises\n * @param webCallingService - Webrtc Service Layer\n * @param webSocketManager - Websocket Manager to maintain websocket connection and keepalives\n */\n public static getTaskManager = (\n contact: ReturnType<typeof routingContact>,\n webCallingService: WebCallingService,\n webSocketManager: WebSocketManager\n ): TaskManager => {\n if (!this.taskManager) {\n this.taskManager = new TaskManager(contact, webCallingService, webSocketManager);\n }\n\n return this.taskManager;\n };\n}\n"],"mappings":"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","ignoreList":[]}