@webex/contact-center 0.0.0-next.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (177) hide show
  1. package/README.md +81 -0
  2. package/__mocks__/workerMock.js +15 -0
  3. package/babel.config.js +15 -0
  4. package/dist/cc.js +1416 -0
  5. package/dist/cc.js.map +1 -0
  6. package/dist/config.js +72 -0
  7. package/dist/config.js.map +1 -0
  8. package/dist/constants.js +58 -0
  9. package/dist/constants.js.map +1 -0
  10. package/dist/index.js +142 -0
  11. package/dist/index.js.map +1 -0
  12. package/dist/logger-proxy.js +115 -0
  13. package/dist/logger-proxy.js.map +1 -0
  14. package/dist/metrics/MetricsManager.js +474 -0
  15. package/dist/metrics/MetricsManager.js.map +1 -0
  16. package/dist/metrics/behavioral-events.js +322 -0
  17. package/dist/metrics/behavioral-events.js.map +1 -0
  18. package/dist/metrics/constants.js +134 -0
  19. package/dist/metrics/constants.js.map +1 -0
  20. package/dist/services/WebCallingService.js +323 -0
  21. package/dist/services/WebCallingService.js.map +1 -0
  22. package/dist/services/agent/index.js +177 -0
  23. package/dist/services/agent/index.js.map +1 -0
  24. package/dist/services/agent/types.js +137 -0
  25. package/dist/services/agent/types.js.map +1 -0
  26. package/dist/services/config/Util.js +203 -0
  27. package/dist/services/config/Util.js.map +1 -0
  28. package/dist/services/config/constants.js +221 -0
  29. package/dist/services/config/constants.js.map +1 -0
  30. package/dist/services/config/index.js +607 -0
  31. package/dist/services/config/index.js.map +1 -0
  32. package/dist/services/config/types.js +334 -0
  33. package/dist/services/config/types.js.map +1 -0
  34. package/dist/services/constants.js +117 -0
  35. package/dist/services/constants.js.map +1 -0
  36. package/dist/services/core/Err.js +43 -0
  37. package/dist/services/core/Err.js.map +1 -0
  38. package/dist/services/core/GlobalTypes.js +6 -0
  39. package/dist/services/core/GlobalTypes.js.map +1 -0
  40. package/dist/services/core/Utils.js +126 -0
  41. package/dist/services/core/Utils.js.map +1 -0
  42. package/dist/services/core/WebexRequest.js +96 -0
  43. package/dist/services/core/WebexRequest.js.map +1 -0
  44. package/dist/services/core/aqm-reqs.js +246 -0
  45. package/dist/services/core/aqm-reqs.js.map +1 -0
  46. package/dist/services/core/constants.js +109 -0
  47. package/dist/services/core/constants.js.map +1 -0
  48. package/dist/services/core/types.js +6 -0
  49. package/dist/services/core/types.js.map +1 -0
  50. package/dist/services/core/websocket/WebSocketManager.js +187 -0
  51. package/dist/services/core/websocket/WebSocketManager.js.map +1 -0
  52. package/dist/services/core/websocket/connection-service.js +111 -0
  53. package/dist/services/core/websocket/connection-service.js.map +1 -0
  54. package/dist/services/core/websocket/keepalive.worker.js +94 -0
  55. package/dist/services/core/websocket/keepalive.worker.js.map +1 -0
  56. package/dist/services/core/websocket/types.js +6 -0
  57. package/dist/services/core/websocket/types.js.map +1 -0
  58. package/dist/services/index.js +78 -0
  59. package/dist/services/index.js.map +1 -0
  60. package/dist/services/task/AutoWrapup.js +88 -0
  61. package/dist/services/task/AutoWrapup.js.map +1 -0
  62. package/dist/services/task/TaskManager.js +369 -0
  63. package/dist/services/task/TaskManager.js.map +1 -0
  64. package/dist/services/task/constants.js +58 -0
  65. package/dist/services/task/constants.js.map +1 -0
  66. package/dist/services/task/contact.js +464 -0
  67. package/dist/services/task/contact.js.map +1 -0
  68. package/dist/services/task/dialer.js +60 -0
  69. package/dist/services/task/dialer.js.map +1 -0
  70. package/dist/services/task/index.js +1188 -0
  71. package/dist/services/task/index.js.map +1 -0
  72. package/dist/services/task/types.js +214 -0
  73. package/dist/services/task/types.js.map +1 -0
  74. package/dist/types/cc.d.ts +676 -0
  75. package/dist/types/config.d.ts +66 -0
  76. package/dist/types/constants.d.ts +45 -0
  77. package/dist/types/index.d.ts +178 -0
  78. package/dist/types/logger-proxy.d.ts +71 -0
  79. package/dist/types/metrics/MetricsManager.d.ts +223 -0
  80. package/dist/types/metrics/behavioral-events.d.ts +29 -0
  81. package/dist/types/metrics/constants.d.ts +127 -0
  82. package/dist/types/services/WebCallingService.d.ts +1 -0
  83. package/dist/types/services/agent/index.d.ts +46 -0
  84. package/dist/types/services/agent/types.d.ts +413 -0
  85. package/dist/types/services/config/Util.d.ts +19 -0
  86. package/dist/types/services/config/constants.d.ts +203 -0
  87. package/dist/types/services/config/index.d.ts +171 -0
  88. package/dist/types/services/config/types.d.ts +1113 -0
  89. package/dist/types/services/constants.d.ts +97 -0
  90. package/dist/types/services/core/Err.d.ts +119 -0
  91. package/dist/types/services/core/GlobalTypes.d.ts +33 -0
  92. package/dist/types/services/core/Utils.d.ts +36 -0
  93. package/dist/types/services/core/WebexRequest.d.ts +22 -0
  94. package/dist/types/services/core/aqm-reqs.d.ts +16 -0
  95. package/dist/types/services/core/constants.d.ts +85 -0
  96. package/dist/types/services/core/types.d.ts +47 -0
  97. package/dist/types/services/core/websocket/WebSocketManager.d.ts +34 -0
  98. package/dist/types/services/core/websocket/connection-service.d.ts +27 -0
  99. package/dist/types/services/core/websocket/keepalive.worker.d.ts +2 -0
  100. package/dist/types/services/core/websocket/types.d.ts +37 -0
  101. package/dist/types/services/index.d.ts +52 -0
  102. package/dist/types/services/task/AutoWrapup.d.ts +40 -0
  103. package/dist/types/services/task/TaskManager.d.ts +1 -0
  104. package/dist/types/services/task/constants.d.ts +46 -0
  105. package/dist/types/services/task/contact.d.ts +59 -0
  106. package/dist/types/services/task/dialer.d.ts +28 -0
  107. package/dist/types/services/task/index.d.ts +569 -0
  108. package/dist/types/services/task/types.d.ts +1041 -0
  109. package/dist/types/types.d.ts +452 -0
  110. package/dist/types/webex-config.d.ts +53 -0
  111. package/dist/types/webex.d.ts +7 -0
  112. package/dist/types.js +292 -0
  113. package/dist/types.js.map +1 -0
  114. package/dist/webex-config.js +60 -0
  115. package/dist/webex-config.js.map +1 -0
  116. package/dist/webex.js +99 -0
  117. package/dist/webex.js.map +1 -0
  118. package/jest.config.js +45 -0
  119. package/package.json +83 -0
  120. package/src/cc.ts +1618 -0
  121. package/src/config.ts +65 -0
  122. package/src/constants.ts +51 -0
  123. package/src/index.ts +220 -0
  124. package/src/logger-proxy.ts +110 -0
  125. package/src/metrics/MetricsManager.ts +512 -0
  126. package/src/metrics/behavioral-events.ts +332 -0
  127. package/src/metrics/constants.ts +135 -0
  128. package/src/services/WebCallingService.ts +351 -0
  129. package/src/services/agent/index.ts +149 -0
  130. package/src/services/agent/types.ts +440 -0
  131. package/src/services/config/Util.ts +261 -0
  132. package/src/services/config/constants.ts +249 -0
  133. package/src/services/config/index.ts +743 -0
  134. package/src/services/config/types.ts +1117 -0
  135. package/src/services/constants.ts +111 -0
  136. package/src/services/core/Err.ts +126 -0
  137. package/src/services/core/GlobalTypes.ts +34 -0
  138. package/src/services/core/Utils.ts +132 -0
  139. package/src/services/core/WebexRequest.ts +103 -0
  140. package/src/services/core/aqm-reqs.ts +272 -0
  141. package/src/services/core/constants.ts +106 -0
  142. package/src/services/core/types.ts +48 -0
  143. package/src/services/core/websocket/WebSocketManager.ts +196 -0
  144. package/src/services/core/websocket/connection-service.ts +142 -0
  145. package/src/services/core/websocket/keepalive.worker.js +88 -0
  146. package/src/services/core/websocket/types.ts +40 -0
  147. package/src/services/index.ts +71 -0
  148. package/src/services/task/AutoWrapup.ts +86 -0
  149. package/src/services/task/TaskManager.ts +420 -0
  150. package/src/services/task/constants.ts +52 -0
  151. package/src/services/task/contact.ts +429 -0
  152. package/src/services/task/dialer.ts +52 -0
  153. package/src/services/task/index.ts +1375 -0
  154. package/src/services/task/types.ts +1113 -0
  155. package/src/types.ts +639 -0
  156. package/src/webex-config.ts +54 -0
  157. package/src/webex.js +96 -0
  158. package/test/unit/spec/cc.ts +1985 -0
  159. package/test/unit/spec/metrics/MetricsManager.ts +491 -0
  160. package/test/unit/spec/metrics/behavioral-events.ts +102 -0
  161. package/test/unit/spec/services/WebCallingService.ts +416 -0
  162. package/test/unit/spec/services/agent/index.ts +65 -0
  163. package/test/unit/spec/services/config/index.ts +1035 -0
  164. package/test/unit/spec/services/core/Utils.ts +279 -0
  165. package/test/unit/spec/services/core/WebexRequest.ts +144 -0
  166. package/test/unit/spec/services/core/aqm-reqs.ts +570 -0
  167. package/test/unit/spec/services/core/websocket/WebSocketManager.ts +378 -0
  168. package/test/unit/spec/services/core/websocket/connection-service.ts +178 -0
  169. package/test/unit/spec/services/task/TaskManager.ts +1351 -0
  170. package/test/unit/spec/services/task/contact.ts +204 -0
  171. package/test/unit/spec/services/task/dialer.ts +157 -0
  172. package/test/unit/spec/services/task/index.ts +1474 -0
  173. package/tsconfig.json +6 -0
  174. package/typedoc.json +37 -0
  175. package/typedoc.md +240 -0
  176. package/umd/contact-center.min.js +3 -0
  177. package/umd/contact-center.min.js.map +1 -0
@@ -0,0 +1,109 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.WS_DISCONNECT_ALLOWED = exports.WELCOME_TIMEOUT = exports.TIMEOUT_REQ = exports.RTD_PING_EVENT = exports.PING_API_URL = exports.NOTIFS_RESOLVE_DELAY = exports.METHODS = exports.LOST_CONNECTION_RECOVERY_TIMEOUT = exports.KEEPALIVE_WORKER_INTERVAL = exports.CONNECTIVITY_CHECK_INTERVAL = exports.CLOSE_SOCKET_TIMEOUT_DURATION = exports.CLOSE_SOCKET_TIMEOUT = void 0;
7
+ /**
8
+ * Interval in milliseconds for sending keepalive pings to the worker.
9
+ * @ignore
10
+ */
11
+ const KEEPALIVE_WORKER_INTERVAL = exports.KEEPALIVE_WORKER_INTERVAL = 4000;
12
+
13
+ /**
14
+ * Delay in milliseconds before resolving notification handlers.
15
+ * @ignore
16
+ */
17
+ const NOTIFS_RESOLVE_DELAY = exports.NOTIFS_RESOLVE_DELAY = 1200;
18
+
19
+ /**
20
+ * Timeout duration in milliseconds before forcefully closing a WebSocket connection.
21
+ * @ignore
22
+ */
23
+ const CLOSE_SOCKET_TIMEOUT_DURATION = exports.CLOSE_SOCKET_TIMEOUT_DURATION = 16000;
24
+
25
+ /**
26
+ * API endpoint used for connectivity or health checks.
27
+ * @ignore
28
+ */
29
+ const PING_API_URL = exports.PING_API_URL = '/health';
30
+
31
+ /**
32
+ * Timeout in milliseconds to wait for a welcome message after socket connection.
33
+ * @ignore
34
+ */
35
+ const WELCOME_TIMEOUT = exports.WELCOME_TIMEOUT = 30000;
36
+
37
+ /**
38
+ * Event name used for real-time device (RTD) ping status.
39
+ * @ignore
40
+ */
41
+ const RTD_PING_EVENT = exports.RTD_PING_EVENT = 'rtd-online-status';
42
+
43
+ /**
44
+ * Timeout in milliseconds for individual HTTP requests.
45
+ * @ignore
46
+ */
47
+ const TIMEOUT_REQ = exports.TIMEOUT_REQ = 20000;
48
+
49
+ /**
50
+ * Duration in milliseconds to wait before attempting lost connection recovery.
51
+ * @ignore
52
+ */
53
+ const LOST_CONNECTION_RECOVERY_TIMEOUT = exports.LOST_CONNECTION_RECOVERY_TIMEOUT = 50000;
54
+
55
+ /**
56
+ * Duration in milliseconds after which a WebSocket disconnect is considered allowed or expected.
57
+ * @ignore
58
+ */
59
+ const WS_DISCONNECT_ALLOWED = exports.WS_DISCONNECT_ALLOWED = 8000;
60
+
61
+ /**
62
+ * Interval in milliseconds to check for connectivity status.
63
+ * @ignore
64
+ */
65
+ const CONNECTIVITY_CHECK_INTERVAL = exports.CONNECTIVITY_CHECK_INTERVAL = 5000;
66
+
67
+ /**
68
+ * Timeout in milliseconds for cleanly closing the WebSocket.
69
+ * @ignore
70
+ */
71
+ const CLOSE_SOCKET_TIMEOUT = exports.CLOSE_SOCKET_TIMEOUT = 16000;
72
+
73
+ // Method names for core services
74
+ const METHODS = exports.METHODS = {
75
+ // WebexRequest methods
76
+ REQUEST: 'request',
77
+ UPLOAD_LOGS: 'uploadLogs',
78
+ // Utils methods
79
+ GET_ERROR_DETAILS: 'getErrorDetails',
80
+ GET_COMMON_ERROR_DETAILS: 'getCommonErrorDetails',
81
+ CREATE_ERR_DETAILS_OBJECT: 'createErrDetailsObject',
82
+ // AqmReqs methods
83
+ REQ: 'req',
84
+ REQ_EMPTY: 'reqEmpty',
85
+ MAKE_API_REQUEST: 'makeAPIRequest',
86
+ CREATE_PROMISE: 'createPromise',
87
+ BIND_PRINT: 'bindPrint',
88
+ BIND_CHECK: 'bindCheck',
89
+ ON_MESSAGE: 'onMessage',
90
+ // WebSocketManager methods
91
+ INIT_WEB_SOCKET: 'initWebSocket',
92
+ CLOSE: 'close',
93
+ HANDLE_CONNECTION_LOST: 'handleConnectionLost',
94
+ REGISTER: 'register',
95
+ CONNECT: 'connect',
96
+ WEB_SOCKET_ON_CLOSE_HANDLER: 'webSocketOnCloseHandler',
97
+ // ConnectionService methods
98
+ SETUP_EVENT_LISTENERS: 'setupEventListeners',
99
+ DISPATCH_CONNECTION_EVENT: 'dispatchConnectionEvent',
100
+ CS_HANDLE_CONNECTION_LOST: 'handleConnectionLost',
101
+ CLEAR_TIMER_ON_RESTORE_FAILED: 'clearTimerOnRestoreFailed',
102
+ HANDLE_RESTORE_FAILED: 'handleRestoreFailed',
103
+ UPDATE_CONNECTION_DATA: 'updateConnectionData',
104
+ SET_CONNECTION_PROP: 'setConnectionProp',
105
+ ON_PING: 'onPing',
106
+ HANDLE_SOCKET_CLOSE: 'handleSocketClose',
107
+ ON_SOCKET_CLOSE: 'onSocketClose'
108
+ };
109
+ //# sourceMappingURL=constants.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["KEEPALIVE_WORKER_INTERVAL","exports","NOTIFS_RESOLVE_DELAY","CLOSE_SOCKET_TIMEOUT_DURATION","PING_API_URL","WELCOME_TIMEOUT","RTD_PING_EVENT","TIMEOUT_REQ","LOST_CONNECTION_RECOVERY_TIMEOUT","WS_DISCONNECT_ALLOWED","CONNECTIVITY_CHECK_INTERVAL","CLOSE_SOCKET_TIMEOUT","METHODS","REQUEST","UPLOAD_LOGS","GET_ERROR_DETAILS","GET_COMMON_ERROR_DETAILS","CREATE_ERR_DETAILS_OBJECT","REQ","REQ_EMPTY","MAKE_API_REQUEST","CREATE_PROMISE","BIND_PRINT","BIND_CHECK","ON_MESSAGE","INIT_WEB_SOCKET","CLOSE","HANDLE_CONNECTION_LOST","REGISTER","CONNECT","WEB_SOCKET_ON_CLOSE_HANDLER","SETUP_EVENT_LISTENERS","DISPATCH_CONNECTION_EVENT","CS_HANDLE_CONNECTION_LOST","CLEAR_TIMER_ON_RESTORE_FAILED","HANDLE_RESTORE_FAILED","UPDATE_CONNECTION_DATA","SET_CONNECTION_PROP","ON_PING","HANDLE_SOCKET_CLOSE","ON_SOCKET_CLOSE"],"sources":["constants.ts"],"sourcesContent":["/**\n * Interval in milliseconds for sending keepalive pings to the worker.\n * @ignore\n */\nexport const KEEPALIVE_WORKER_INTERVAL = 4000;\n\n/**\n * Delay in milliseconds before resolving notification handlers.\n * @ignore\n */\nexport const NOTIFS_RESOLVE_DELAY = 1200;\n\n/**\n * Timeout duration in milliseconds before forcefully closing a WebSocket connection.\n * @ignore\n */\nexport const CLOSE_SOCKET_TIMEOUT_DURATION = 16000;\n\n/**\n * API endpoint used for connectivity or health checks.\n * @ignore\n */\nexport const PING_API_URL = '/health';\n\n/**\n * Timeout in milliseconds to wait for a welcome message after socket connection.\n * @ignore\n */\nexport const WELCOME_TIMEOUT = 30000;\n\n/**\n * Event name used for real-time device (RTD) ping status.\n * @ignore\n */\nexport const RTD_PING_EVENT = 'rtd-online-status';\n\n/**\n * Timeout in milliseconds for individual HTTP requests.\n * @ignore\n */\nexport const TIMEOUT_REQ = 20000;\n\n/**\n * Duration in milliseconds to wait before attempting lost connection recovery.\n * @ignore\n */\nexport const LOST_CONNECTION_RECOVERY_TIMEOUT = 50000;\n\n/**\n * Duration in milliseconds after which a WebSocket disconnect is considered allowed or expected.\n * @ignore\n */\nexport const WS_DISCONNECT_ALLOWED = 8000;\n\n/**\n * Interval in milliseconds to check for connectivity status.\n * @ignore\n */\nexport const CONNECTIVITY_CHECK_INTERVAL = 5000;\n\n/**\n * Timeout in milliseconds for cleanly closing the WebSocket.\n * @ignore\n */\nexport const CLOSE_SOCKET_TIMEOUT = 16000;\n\n// Method names for core services\nexport const METHODS = {\n // WebexRequest methods\n REQUEST: 'request',\n UPLOAD_LOGS: 'uploadLogs',\n\n // Utils methods\n GET_ERROR_DETAILS: 'getErrorDetails',\n GET_COMMON_ERROR_DETAILS: 'getCommonErrorDetails',\n CREATE_ERR_DETAILS_OBJECT: 'createErrDetailsObject',\n\n // AqmReqs methods\n REQ: 'req',\n REQ_EMPTY: 'reqEmpty',\n MAKE_API_REQUEST: 'makeAPIRequest',\n CREATE_PROMISE: 'createPromise',\n BIND_PRINT: 'bindPrint',\n BIND_CHECK: 'bindCheck',\n ON_MESSAGE: 'onMessage',\n\n // WebSocketManager methods\n INIT_WEB_SOCKET: 'initWebSocket',\n CLOSE: 'close',\n HANDLE_CONNECTION_LOST: 'handleConnectionLost',\n REGISTER: 'register',\n CONNECT: 'connect',\n WEB_SOCKET_ON_CLOSE_HANDLER: 'webSocketOnCloseHandler',\n\n // ConnectionService methods\n SETUP_EVENT_LISTENERS: 'setupEventListeners',\n DISPATCH_CONNECTION_EVENT: 'dispatchConnectionEvent',\n CS_HANDLE_CONNECTION_LOST: 'handleConnectionLost',\n CLEAR_TIMER_ON_RESTORE_FAILED: 'clearTimerOnRestoreFailed',\n HANDLE_RESTORE_FAILED: 'handleRestoreFailed',\n UPDATE_CONNECTION_DATA: 'updateConnectionData',\n SET_CONNECTION_PROP: 'setConnectionProp',\n ON_PING: 'onPing',\n HANDLE_SOCKET_CLOSE: 'handleSocketClose',\n ON_SOCKET_CLOSE: 'onSocketClose',\n};\n"],"mappings":";;;;;;AAAA;AACA;AACA;AACA;AACO,MAAMA,yBAAyB,GAAAC,OAAA,CAAAD,yBAAA,GAAG,IAAI;;AAE7C;AACA;AACA;AACA;AACO,MAAME,oBAAoB,GAAAD,OAAA,CAAAC,oBAAA,GAAG,IAAI;;AAExC;AACA;AACA;AACA;AACO,MAAMC,6BAA6B,GAAAF,OAAA,CAAAE,6BAAA,GAAG,KAAK;;AAElD;AACA;AACA;AACA;AACO,MAAMC,YAAY,GAAAH,OAAA,CAAAG,YAAA,GAAG,SAAS;;AAErC;AACA;AACA;AACA;AACO,MAAMC,eAAe,GAAAJ,OAAA,CAAAI,eAAA,GAAG,KAAK;;AAEpC;AACA;AACA;AACA;AACO,MAAMC,cAAc,GAAAL,OAAA,CAAAK,cAAA,GAAG,mBAAmB;;AAEjD;AACA;AACA;AACA;AACO,MAAMC,WAAW,GAAAN,OAAA,CAAAM,WAAA,GAAG,KAAK;;AAEhC;AACA;AACA;AACA;AACO,MAAMC,gCAAgC,GAAAP,OAAA,CAAAO,gCAAA,GAAG,KAAK;;AAErD;AACA;AACA;AACA;AACO,MAAMC,qBAAqB,GAAAR,OAAA,CAAAQ,qBAAA,GAAG,IAAI;;AAEzC;AACA;AACA;AACA;AACO,MAAMC,2BAA2B,GAAAT,OAAA,CAAAS,2BAAA,GAAG,IAAI;;AAE/C;AACA;AACA;AACA;AACO,MAAMC,oBAAoB,GAAAV,OAAA,CAAAU,oBAAA,GAAG,KAAK;;AAEzC;AACO,MAAMC,OAAO,GAAAX,OAAA,CAAAW,OAAA,GAAG;EACrB;EACAC,OAAO,EAAE,SAAS;EAClBC,WAAW,EAAE,YAAY;EAEzB;EACAC,iBAAiB,EAAE,iBAAiB;EACpCC,wBAAwB,EAAE,uBAAuB;EACjDC,yBAAyB,EAAE,wBAAwB;EAEnD;EACAC,GAAG,EAAE,KAAK;EACVC,SAAS,EAAE,UAAU;EACrBC,gBAAgB,EAAE,gBAAgB;EAClCC,cAAc,EAAE,eAAe;EAC/BC,UAAU,EAAE,WAAW;EACvBC,UAAU,EAAE,WAAW;EACvBC,UAAU,EAAE,WAAW;EAEvB;EACAC,eAAe,EAAE,eAAe;EAChCC,KAAK,EAAE,OAAO;EACdC,sBAAsB,EAAE,sBAAsB;EAC9CC,QAAQ,EAAE,UAAU;EACpBC,OAAO,EAAE,SAAS;EAClBC,2BAA2B,EAAE,yBAAyB;EAEtD;EACAC,qBAAqB,EAAE,qBAAqB;EAC5CC,yBAAyB,EAAE,yBAAyB;EACpDC,yBAAyB,EAAE,sBAAsB;EACjDC,6BAA6B,EAAE,2BAA2B;EAC1DC,qBAAqB,EAAE,qBAAqB;EAC5CC,sBAAsB,EAAE,sBAAsB;EAC9CC,mBAAmB,EAAE,mBAAmB;EACxCC,OAAO,EAAE,QAAQ;EACjBC,mBAAmB,EAAE,mBAAmB;EACxCC,eAAe,EAAE;AACnB,CAAC"}
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import {HTTP_METHODS, RequestBody, WebexRequestPayload} from '../../types';\nimport * as Err from './Err';\nimport {Msg} from './GlobalTypes';\n\nexport type Pending = {\n check: (msg: Msg) => boolean;\n handle: (msg: Msg) => void;\n alternateBind?: string;\n};\n\nexport type BindType = string | string[] | {[key: string]: BindType};\ninterface Bind {\n type: BindType;\n data?: any;\n}\n\nexport type Timeout = number | 'disabled';\n\nexport type Req<TRes, TErr> = {\n url: string;\n host?: string;\n method?: HTTP_METHODS;\n err?:\n | ((errObj: WebexRequestPayload) => Err.Details<'Service.reqs.generic.failure'>)\n | Err.IdsMessage\n | ((e: WebexRequestPayload) => Err.Message | Err.Details<Err.IdsDetails>);\n notifSuccess: {bind: Bind; msg: TRes};\n notifFail?:\n | {\n bind: Bind;\n errMsg: TErr;\n err: (e: TErr) => Err.Details<Err.IdsDetails>;\n }\n | {\n bind: Bind;\n errId: Err.IdsDetails;\n };\n data?: RequestBody;\n headers?: Record<string, string>;\n timeout?: Timeout;\n notifCancel?: {bind: Bind; msg: TRes};\n};\n\nexport type Conf<TRes, TErr, TReq> = (p: TReq) => Req<TRes, TErr>;\nexport type ConfEmpty<TRes, TErr> = () => Req<TRes, TErr>;\nexport type Res<TRes, TReq> = (p: TReq, cbRes?: CbRes<TRes>) => Promise<TRes>;\nexport type ResEmpty<TRes> = (cbRes?: CbRes<TRes>) => Promise<TRes>;\nexport type CbRes<TRes> = (res: any) => void | TRes;\n"],"mappings":""}
@@ -0,0 +1,187 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.WebSocketManager = void 0;
7
+ var _events = _interopRequireDefault(require("events"));
8
+ var _types = require("../../../types");
9
+ var _constants = require("../../constants");
10
+ var _types2 = require("../../config/types");
11
+ var _loggerProxy = _interopRequireDefault(require("../../../logger-proxy"));
12
+ var _keepalive = _interopRequireDefault(require("./keepalive.worker"));
13
+ var _constants2 = require("../constants");
14
+ var _constants3 = require("../../../constants");
15
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
16
+ /**
17
+ * WebSocketManager handles the WebSocket connection for Contact Center operations.
18
+ * It manages the connection lifecycle, including registration, reconnection, and message handling.
19
+ * It also utilizes a Web Worker to manage keepalive messages and socket closure.
20
+ * @ignore
21
+ */
22
+ class WebSocketManager extends _events.default {
23
+ url = null;
24
+ welcomePromiseResolve = null;
25
+ constructor(options) {
26
+ super();
27
+ const {
28
+ webex
29
+ } = options;
30
+ this.webex = webex;
31
+ this.shouldReconnect = true;
32
+ this.websocket = {};
33
+ this.isSocketClosed = false;
34
+ this.isWelcomeReceived = false;
35
+ this.forceCloseWebSocketOnTimeout = false;
36
+ this.isConnectionLost = false;
37
+ const workerScriptBlob = new Blob([_keepalive.default], {
38
+ type: 'application/javascript'
39
+ });
40
+ this.keepaliveWorker = new Worker(URL.createObjectURL(workerScriptBlob));
41
+ }
42
+ async initWebSocket(options) {
43
+ const connectionConfig = options.body;
44
+ await this.register(connectionConfig);
45
+ return new Promise((resolve, reject) => {
46
+ this.welcomePromiseResolve = resolve;
47
+ this.connect().catch(error => {
48
+ _loggerProxy.default.error(`[WebSocketStatus] | Error in connecting Websocket ${error}`, {
49
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
50
+ method: _constants2.METHODS.INIT_WEB_SOCKET
51
+ });
52
+ reject(error);
53
+ });
54
+ });
55
+ }
56
+ close(shouldReconnect, reason = 'Unknown') {
57
+ if (!this.isSocketClosed && this.shouldReconnect) {
58
+ this.shouldReconnect = shouldReconnect;
59
+ this.websocket.close();
60
+ this.keepaliveWorker.postMessage({
61
+ type: 'terminate'
62
+ });
63
+ _loggerProxy.default.log(`[WebSocketStatus] | event=webSocketClose | WebSocket connection closed manually REASON: ${reason}`, {
64
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
65
+ method: _constants2.METHODS.CLOSE
66
+ });
67
+ }
68
+ }
69
+ handleConnectionLost(event) {
70
+ this.isConnectionLost = event.isConnectionLost;
71
+ }
72
+ async register(connectionConfig) {
73
+ try {
74
+ const subscribeResponse = await this.webex.request({
75
+ service: _constants.WCC_API_GATEWAY,
76
+ resource: _constants.SUBSCRIBE_API,
77
+ method: _types.HTTP_METHODS.POST,
78
+ body: connectionConfig
79
+ });
80
+ this.url = subscribeResponse.body.webSocketUrl;
81
+ } catch (e) {
82
+ _loggerProxy.default.error(`Register API Failed, Request to RoutingNotifs websocket registration API failed ${e}`, {
83
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
84
+ method: _constants2.METHODS.REGISTER
85
+ });
86
+ }
87
+ }
88
+ async connect() {
89
+ if (!this.url) {
90
+ return undefined;
91
+ }
92
+ _loggerProxy.default.log(`[WebSocketStatus] | event=webSocketConnecting | Connecting to WebSocket: ${this.url}`, {
93
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
94
+ method: _constants2.METHODS.CONNECT
95
+ });
96
+ this.websocket = new WebSocket(this.url);
97
+ return new Promise((resolve, reject) => {
98
+ this.websocket.onopen = () => {
99
+ this.isSocketClosed = false;
100
+ this.shouldReconnect = true;
101
+ this.websocket.send(JSON.stringify({
102
+ keepalive: 'true'
103
+ }));
104
+ this.keepaliveWorker.onmessage = keepAliveEvent => {
105
+ if (keepAliveEvent?.data?.type === 'keepalive') {
106
+ this.websocket.send(JSON.stringify({
107
+ keepalive: 'true'
108
+ }));
109
+ }
110
+ if (keepAliveEvent?.data?.type === 'closeSocket' && this.isConnectionLost) {
111
+ this.forceCloseWebSocketOnTimeout = true;
112
+ this.close(true, 'WebSocket did not auto close within 16 secs');
113
+ _loggerProxy.default.error('[webSocketTimeout] | event=webSocketTimeout | WebSocket connection closed forcefully', {
114
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
115
+ method: _constants2.METHODS.CONNECT
116
+ });
117
+ }
118
+ };
119
+ this.keepaliveWorker.postMessage({
120
+ type: 'start',
121
+ intervalDuration: _constants2.KEEPALIVE_WORKER_INTERVAL,
122
+ // Keepalive interval
123
+ isSocketClosed: this.isSocketClosed,
124
+ closeSocketTimeout: _constants2.CLOSE_SOCKET_TIMEOUT // Close socket timeout
125
+ });
126
+ };
127
+
128
+ this.websocket.onerror = event => {
129
+ _loggerProxy.default.error(`[WebSocketStatus] | event=socketConnectionFailed | WebSocket connection failed ${event}`, {
130
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
131
+ method: _constants2.METHODS.CONNECT
132
+ });
133
+ reject();
134
+ };
135
+ this.websocket.onclose = async event => {
136
+ this.webSocketOnCloseHandler(event);
137
+ };
138
+ this.websocket.onmessage = e => {
139
+ this.emit('message', e.data);
140
+ const eventData = JSON.parse(e.data);
141
+ if (eventData.type === _types2.CC_EVENTS.WELCOME) {
142
+ this.isWelcomeReceived = true;
143
+ if (this.welcomePromiseResolve) {
144
+ this.welcomePromiseResolve(eventData.data);
145
+ this.welcomePromiseResolve = null;
146
+ }
147
+ }
148
+ if (eventData.type === 'AGENT_MULTI_LOGIN') {
149
+ this.close(false, 'multiLogin');
150
+ _loggerProxy.default.error('[WebSocketStatus] | event=agentMultiLogin | WebSocket connection closed by agent multiLogin', {
151
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
152
+ method: _constants2.METHODS.CONNECT
153
+ });
154
+ }
155
+ };
156
+ });
157
+ }
158
+
159
+ // eslint-disable-next-line @typescript-eslint/no-unused-vars
160
+ async webSocketOnCloseHandler(event) {
161
+ this.isSocketClosed = true;
162
+ this.keepaliveWorker.postMessage({
163
+ type: 'terminate'
164
+ });
165
+ if (this.shouldReconnect) {
166
+ this.emit('socketClose');
167
+ let issueReason;
168
+ if (this.forceCloseWebSocketOnTimeout) {
169
+ issueReason = 'WebSocket auto close timed out. Forcefully closed websocket.';
170
+ } else {
171
+ const onlineStatus = navigator.onLine;
172
+ _loggerProxy.default.info(`[WebSocketStatus] | desktop online status is ${onlineStatus}`, {
173
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
174
+ method: _constants2.METHODS.WEB_SOCKET_ON_CLOSE_HANDLER
175
+ });
176
+ issueReason = !onlineStatus ? 'network issue' : 'missing keepalive from either desktop or notif service';
177
+ }
178
+ _loggerProxy.default.error(`[WebSocketStatus] | event=webSocketClose | WebSocket connection closed REASON: ${issueReason}`, {
179
+ module: _constants3.WEB_SOCKET_MANAGER_FILE,
180
+ method: _constants2.METHODS.WEB_SOCKET_ON_CLOSE_HANDLER
181
+ });
182
+ this.forceCloseWebSocketOnTimeout = false;
183
+ }
184
+ }
185
+ }
186
+ exports.WebSocketManager = WebSocketManager;
187
+ //# sourceMappingURL=WebSocketManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_events","_interopRequireDefault","require","_types","_constants","_types2","_loggerProxy","_keepalive","_constants2","_constants3","obj","__esModule","default","WebSocketManager","EventEmitter","url","welcomePromiseResolve","constructor","options","webex","shouldReconnect","websocket","isSocketClosed","isWelcomeReceived","forceCloseWebSocketOnTimeout","isConnectionLost","workerScriptBlob","Blob","workerScript","type","keepaliveWorker","Worker","URL","createObjectURL","initWebSocket","connectionConfig","body","register","Promise","resolve","reject","connect","catch","error","LoggerProxy","module","WEB_SOCKET_MANAGER_FILE","method","METHODS","INIT_WEB_SOCKET","close","reason","postMessage","log","CLOSE","handleConnectionLost","event","subscribeResponse","request","service","WCC_API_GATEWAY","resource","SUBSCRIBE_API","HTTP_METHODS","POST","webSocketUrl","e","REGISTER","undefined","CONNECT","WebSocket","onopen","send","JSON","stringify","keepalive","onmessage","keepAliveEvent","data","intervalDuration","KEEPALIVE_WORKER_INTERVAL","closeSocketTimeout","CLOSE_SOCKET_TIMEOUT","onerror","onclose","webSocketOnCloseHandler","emit","eventData","parse","CC_EVENTS","WELCOME","issueReason","onlineStatus","navigator","onLine","info","WEB_SOCKET_ON_CLOSE_HANDLER","exports"],"sources":["WebSocketManager.ts"],"sourcesContent":["import EventEmitter from 'events';\nimport {WebexSDK, SubscribeRequest, HTTP_METHODS} from '../../../types';\nimport {SUBSCRIBE_API, WCC_API_GATEWAY} from '../../constants';\nimport {ConnectionLostDetails} from './types';\nimport {CC_EVENTS, SubscribeResponse, WelcomeResponse} from '../../config/types';\nimport LoggerProxy from '../../../logger-proxy';\nimport workerScript from './keepalive.worker';\nimport {KEEPALIVE_WORKER_INTERVAL, CLOSE_SOCKET_TIMEOUT, METHODS} from '../constants';\nimport {WEB_SOCKET_MANAGER_FILE} from '../../../constants';\n\n/**\n * WebSocketManager handles the WebSocket connection for Contact Center operations.\n * It manages the connection lifecycle, including registration, reconnection, and message handling.\n * It also utilizes a Web Worker to manage keepalive messages and socket closure.\n * @ignore\n */\nexport class WebSocketManager extends EventEmitter {\n private websocket: WebSocket;\n shouldReconnect: boolean;\n isSocketClosed: boolean;\n private isWelcomeReceived: boolean;\n private url: string | null = null;\n private forceCloseWebSocketOnTimeout: boolean;\n private isConnectionLost: boolean;\n private webex: WebexSDK;\n private welcomePromiseResolve:\n | ((value: WelcomeResponse | PromiseLike<WelcomeResponse>) => void)\n | null = null;\n\n private keepaliveWorker: Worker;\n\n constructor(options: {webex: WebexSDK}) {\n super();\n const {webex} = options;\n this.webex = webex;\n this.shouldReconnect = true;\n this.websocket = {} as WebSocket;\n this.isSocketClosed = false;\n this.isWelcomeReceived = false;\n this.forceCloseWebSocketOnTimeout = false;\n this.isConnectionLost = false;\n\n const workerScriptBlob = new Blob([workerScript], {type: 'application/javascript'});\n this.keepaliveWorker = new Worker(URL.createObjectURL(workerScriptBlob));\n }\n\n async initWebSocket(options: {body: SubscribeRequest}): Promise<WelcomeResponse> {\n const connectionConfig = options.body;\n await this.register(connectionConfig);\n\n return new Promise((resolve, reject) => {\n this.welcomePromiseResolve = resolve;\n this.connect().catch((error) => {\n LoggerProxy.error(`[WebSocketStatus] | Error in connecting Websocket ${error}`, {\n module: WEB_SOCKET_MANAGER_FILE,\n method: METHODS.INIT_WEB_SOCKET,\n });\n reject(error);\n });\n });\n }\n\n close(shouldReconnect: boolean, reason = 'Unknown') {\n if (!this.isSocketClosed && this.shouldReconnect) {\n this.shouldReconnect = shouldReconnect;\n this.websocket.close();\n this.keepaliveWorker.postMessage({type: 'terminate'});\n LoggerProxy.log(\n `[WebSocketStatus] | event=webSocketClose | WebSocket connection closed manually REASON: ${reason}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CLOSE}\n );\n }\n }\n\n handleConnectionLost(event: ConnectionLostDetails) {\n this.isConnectionLost = event.isConnectionLost;\n }\n\n private async register(connectionConfig: SubscribeRequest) {\n try {\n const subscribeResponse: SubscribeResponse = await this.webex.request({\n service: WCC_API_GATEWAY,\n resource: SUBSCRIBE_API,\n method: HTTP_METHODS.POST,\n body: connectionConfig,\n });\n this.url = subscribeResponse.body.webSocketUrl;\n } catch (e) {\n LoggerProxy.error(\n `Register API Failed, Request to RoutingNotifs websocket registration API failed ${e}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.REGISTER}\n );\n }\n }\n\n private async connect() {\n if (!this.url) {\n return undefined;\n }\n LoggerProxy.log(\n `[WebSocketStatus] | event=webSocketConnecting | Connecting to WebSocket: ${this.url}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n this.websocket = new WebSocket(this.url);\n\n return new Promise((resolve, reject) => {\n this.websocket.onopen = () => {\n this.isSocketClosed = false;\n this.shouldReconnect = true;\n\n this.websocket.send(JSON.stringify({keepalive: 'true'}));\n this.keepaliveWorker.onmessage = (keepAliveEvent: {data: any}) => {\n if (keepAliveEvent?.data?.type === 'keepalive') {\n this.websocket.send(JSON.stringify({keepalive: 'true'}));\n }\n\n if (keepAliveEvent?.data?.type === 'closeSocket' && this.isConnectionLost) {\n this.forceCloseWebSocketOnTimeout = true;\n this.close(true, 'WebSocket did not auto close within 16 secs');\n LoggerProxy.error(\n '[webSocketTimeout] | event=webSocketTimeout | WebSocket connection closed forcefully',\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n }\n };\n\n this.keepaliveWorker.postMessage({\n type: 'start',\n intervalDuration: KEEPALIVE_WORKER_INTERVAL, // Keepalive interval\n isSocketClosed: this.isSocketClosed,\n closeSocketTimeout: CLOSE_SOCKET_TIMEOUT, // Close socket timeout\n });\n };\n\n this.websocket.onerror = (event: any) => {\n LoggerProxy.error(\n `[WebSocketStatus] | event=socketConnectionFailed | WebSocket connection failed ${event}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n reject();\n };\n\n this.websocket.onclose = async (event: any) => {\n this.webSocketOnCloseHandler(event);\n };\n\n this.websocket.onmessage = (e: MessageEvent) => {\n this.emit('message', e.data);\n const eventData = JSON.parse(e.data);\n\n if (eventData.type === CC_EVENTS.WELCOME) {\n this.isWelcomeReceived = true;\n if (this.welcomePromiseResolve) {\n this.welcomePromiseResolve(eventData.data as WelcomeResponse);\n this.welcomePromiseResolve = null;\n }\n }\n\n if (eventData.type === 'AGENT_MULTI_LOGIN') {\n this.close(false, 'multiLogin');\n LoggerProxy.error(\n '[WebSocketStatus] | event=agentMultiLogin | WebSocket connection closed by agent multiLogin',\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.CONNECT}\n );\n }\n };\n });\n }\n\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n private async webSocketOnCloseHandler(event: any) {\n this.isSocketClosed = true;\n this.keepaliveWorker.postMessage({type: 'terminate'});\n if (this.shouldReconnect) {\n this.emit('socketClose');\n let issueReason;\n if (this.forceCloseWebSocketOnTimeout) {\n issueReason = 'WebSocket auto close timed out. Forcefully closed websocket.';\n } else {\n const onlineStatus = navigator.onLine;\n LoggerProxy.info(`[WebSocketStatus] | desktop online status is ${onlineStatus}`, {\n module: WEB_SOCKET_MANAGER_FILE,\n method: METHODS.WEB_SOCKET_ON_CLOSE_HANDLER,\n });\n issueReason = !onlineStatus\n ? 'network issue'\n : 'missing keepalive from either desktop or notif service';\n }\n LoggerProxy.error(\n `[WebSocketStatus] | event=webSocketClose | WebSocket connection closed REASON: ${issueReason}`,\n {module: WEB_SOCKET_MANAGER_FILE, method: METHODS.WEB_SOCKET_ON_CLOSE_HANDLER}\n );\n this.forceCloseWebSocketOnTimeout = false;\n }\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,111 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.ConnectionService = void 0;
7
+ var _events = require("events");
8
+ var _loggerProxy = _interopRequireDefault(require("../../../logger-proxy"));
9
+ var _constants = require("../constants");
10
+ var _constants2 = require("../../../constants");
11
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
12
+ class ConnectionService extends _events.EventEmitter {
13
+ connectionProp = {
14
+ lostConnectionRecoveryTimeout: _constants.LOST_CONNECTION_RECOVERY_TIMEOUT
15
+ };
16
+ wsDisconnectAllowed = _constants.WS_DISCONNECT_ALLOWED;
17
+ constructor(options) {
18
+ super();
19
+ this.webSocketManager = options.webSocketManager;
20
+ this.subscribeRequest = options.subscribeRequest;
21
+ this.isConnectionLost = false;
22
+ this.isRestoreFailed = false;
23
+ this.isSocketReconnected = false;
24
+ this.isKeepAlive = false;
25
+ this.setupEventListeners();
26
+ }
27
+ setupEventListeners() {
28
+ this.webSocketManager.on('message', this.onPing.bind(this));
29
+ this.webSocketManager.on('socketClose', this.onSocketClose.bind(this));
30
+ }
31
+ dispatchConnectionEvent(socketReconnected = false) {
32
+ const event = {
33
+ isConnectionLost: this.isConnectionLost,
34
+ isRestoreFailed: this.isRestoreFailed,
35
+ isSocketReconnected: !this.webSocketManager.isSocketClosed && (socketReconnected || this.isSocketReconnected),
36
+ isKeepAlive: this.isKeepAlive
37
+ };
38
+ this.webSocketManager.handleConnectionLost(event);
39
+ _loggerProxy.default.info(`Dispatching connection event`, {
40
+ module: _constants2.CONNECTION_SERVICE_FILE,
41
+ method: _constants.METHODS.DISPATCH_CONNECTION_EVENT
42
+ });
43
+ this.emit('connectionLost', event);
44
+ }
45
+ handleConnectionLost = () => {
46
+ this.isConnectionLost = true;
47
+ this.dispatchConnectionEvent();
48
+ };
49
+ clearTimerOnRestoreFailed = async () => {
50
+ if (this.reconnectInterval) {
51
+ clearInterval(this.reconnectInterval);
52
+ }
53
+ };
54
+ handleRestoreFailed = async () => {
55
+ this.isRestoreFailed = true;
56
+ this.webSocketManager.shouldReconnect = false;
57
+ this.dispatchConnectionEvent();
58
+ await this.clearTimerOnRestoreFailed();
59
+ };
60
+ updateConnectionData = () => {
61
+ this.isRestoreFailed = false;
62
+ this.isConnectionLost = false;
63
+ this.isSocketReconnected = false;
64
+ };
65
+ setConnectionProp(prop) {
66
+ this.connectionProp = prop;
67
+ }
68
+ onPing = event => {
69
+ const parsedEvent = JSON.parse(event);
70
+ if (this.reconnectingTimer) {
71
+ clearTimeout(this.reconnectingTimer);
72
+ }
73
+ if (this.restoreTimer) {
74
+ clearTimeout(this.restoreTimer);
75
+ }
76
+ this.isKeepAlive = parsedEvent.keepalive === 'true';
77
+ if ((this.isConnectionLost && !this.isRestoreFailed || this.isKeepAlive) && !this.isSocketReconnected) {
78
+ this.updateConnectionData();
79
+ this.dispatchConnectionEvent();
80
+ } else if (this.isSocketReconnected && this.isKeepAlive) {
81
+ this.updateConnectionData();
82
+ this.dispatchConnectionEvent(true);
83
+ }
84
+ this.reconnectingTimer = setTimeout(this.handleConnectionLost, this.wsDisconnectAllowed);
85
+ this.restoreTimer = setTimeout(this.handleRestoreFailed, this.connectionProp && this.connectionProp.lostConnectionRecoveryTimeout);
86
+ };
87
+ handleSocketClose = async () => {
88
+ _loggerProxy.default.info(`event=socketConnectionRetry | Trying to reconnect to websocket`, {
89
+ module: _constants2.CONNECTION_SERVICE_FILE,
90
+ method: _constants.METHODS.HANDLE_SOCKET_CLOSE
91
+ });
92
+ const onlineStatus = navigator.onLine;
93
+ if (onlineStatus) {
94
+ await this.webSocketManager.initWebSocket({
95
+ body: this.subscribeRequest
96
+ });
97
+ await this.clearTimerOnRestoreFailed();
98
+ this.isSocketReconnected = true;
99
+ } else {
100
+ throw new Error('event=socketConnectionRetry | browser network not available');
101
+ }
102
+ };
103
+ onSocketClose = () => {
104
+ this.clearTimerOnRestoreFailed();
105
+ this.reconnectInterval = setInterval(async () => {
106
+ await this.handleSocketClose();
107
+ }, _constants.CONNECTIVITY_CHECK_INTERVAL);
108
+ };
109
+ }
110
+ exports.ConnectionService = ConnectionService;
111
+ //# sourceMappingURL=connection-service.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["_events","require","_loggerProxy","_interopRequireDefault","_constants","_constants2","obj","__esModule","default","ConnectionService","EventEmitter","connectionProp","lostConnectionRecoveryTimeout","LOST_CONNECTION_RECOVERY_TIMEOUT","wsDisconnectAllowed","WS_DISCONNECT_ALLOWED","constructor","options","webSocketManager","subscribeRequest","isConnectionLost","isRestoreFailed","isSocketReconnected","isKeepAlive","setupEventListeners","on","onPing","bind","onSocketClose","dispatchConnectionEvent","socketReconnected","event","isSocketClosed","handleConnectionLost","LoggerProxy","info","module","CONNECTION_SERVICE_FILE","method","METHODS","DISPATCH_CONNECTION_EVENT","emit","clearTimerOnRestoreFailed","reconnectInterval","clearInterval","handleRestoreFailed","shouldReconnect","updateConnectionData","setConnectionProp","prop","parsedEvent","JSON","parse","reconnectingTimer","clearTimeout","restoreTimer","keepalive","setTimeout","handleSocketClose","HANDLE_SOCKET_CLOSE","onlineStatus","navigator","onLine","initWebSocket","body","Error","setInterval","CONNECTIVITY_CHECK_INTERVAL","exports"],"sources":["connection-service.ts"],"sourcesContent":["import {EventEmitter} from 'events';\nimport {WebSocketManager} from './WebSocketManager';\nimport LoggerProxy from '../../../logger-proxy';\nimport {ConnectionServiceOptions, ConnectionLostDetails, ConnectionProp} from './types';\nimport {\n LOST_CONNECTION_RECOVERY_TIMEOUT,\n WS_DISCONNECT_ALLOWED,\n CONNECTIVITY_CHECK_INTERVAL,\n METHODS,\n} from '../constants';\nimport {CONNECTION_SERVICE_FILE} from '../../../constants';\nimport {SubscribeRequest} from '../../../types';\n\nexport class ConnectionService extends EventEmitter {\n private connectionProp: ConnectionProp = {\n lostConnectionRecoveryTimeout: LOST_CONNECTION_RECOVERY_TIMEOUT,\n };\n\n private wsDisconnectAllowed = WS_DISCONNECT_ALLOWED;\n private reconnectingTimer: ReturnType<typeof setTimeout>;\n private restoreTimer: ReturnType<typeof setTimeout>;\n private isConnectionLost: boolean;\n private isRestoreFailed: boolean;\n private isSocketReconnected: boolean;\n private isKeepAlive: boolean;\n private reconnectInterval: ReturnType<typeof setInterval>;\n private webSocketManager: WebSocketManager;\n private subscribeRequest: SubscribeRequest;\n\n constructor(options: ConnectionServiceOptions) {\n super();\n this.webSocketManager = options.webSocketManager;\n this.subscribeRequest = options.subscribeRequest;\n\n this.isConnectionLost = false;\n this.isRestoreFailed = false;\n this.isSocketReconnected = false;\n this.isKeepAlive = false;\n\n this.setupEventListeners();\n }\n\n private setupEventListeners() {\n this.webSocketManager.on('message', this.onPing.bind(this));\n this.webSocketManager.on('socketClose', this.onSocketClose.bind(this));\n }\n\n private dispatchConnectionEvent(socketReconnected = false): void {\n const event: ConnectionLostDetails = {\n isConnectionLost: this.isConnectionLost,\n isRestoreFailed: this.isRestoreFailed,\n isSocketReconnected:\n !this.webSocketManager.isSocketClosed && (socketReconnected || this.isSocketReconnected),\n isKeepAlive: this.isKeepAlive,\n };\n this.webSocketManager.handleConnectionLost(event);\n LoggerProxy.info(`Dispatching connection event`, {\n module: CONNECTION_SERVICE_FILE,\n method: METHODS.DISPATCH_CONNECTION_EVENT,\n });\n this.emit('connectionLost', event);\n }\n\n private handleConnectionLost = (): void => {\n this.isConnectionLost = true;\n this.dispatchConnectionEvent();\n };\n\n private clearTimerOnRestoreFailed = async () => {\n if (this.reconnectInterval) {\n clearInterval(this.reconnectInterval);\n }\n };\n\n private handleRestoreFailed = async () => {\n this.isRestoreFailed = true;\n this.webSocketManager.shouldReconnect = false;\n this.dispatchConnectionEvent();\n await this.clearTimerOnRestoreFailed();\n };\n\n private updateConnectionData = (): void => {\n this.isRestoreFailed = false;\n this.isConnectionLost = false;\n this.isSocketReconnected = false;\n };\n\n public setConnectionProp(prop: ConnectionProp): void {\n this.connectionProp = prop;\n }\n\n private onPing = (event: any): void => {\n const parsedEvent = JSON.parse(event);\n if (this.reconnectingTimer) {\n clearTimeout(this.reconnectingTimer);\n }\n if (this.restoreTimer) {\n clearTimeout(this.restoreTimer);\n }\n this.isKeepAlive = parsedEvent.keepalive === 'true';\n\n if (\n ((this.isConnectionLost && !this.isRestoreFailed) || this.isKeepAlive) &&\n !this.isSocketReconnected\n ) {\n this.updateConnectionData();\n this.dispatchConnectionEvent();\n } else if (this.isSocketReconnected && this.isKeepAlive) {\n this.updateConnectionData();\n this.dispatchConnectionEvent(true);\n }\n\n this.reconnectingTimer = setTimeout(this.handleConnectionLost, this.wsDisconnectAllowed);\n this.restoreTimer = setTimeout(\n this.handleRestoreFailed,\n this.connectionProp && this.connectionProp.lostConnectionRecoveryTimeout\n );\n };\n\n private handleSocketClose = async (): Promise<void> => {\n LoggerProxy.info(`event=socketConnectionRetry | Trying to reconnect to websocket`, {\n module: CONNECTION_SERVICE_FILE,\n method: METHODS.HANDLE_SOCKET_CLOSE,\n });\n const onlineStatus = navigator.onLine;\n if (onlineStatus) {\n await this.webSocketManager.initWebSocket({body: this.subscribeRequest});\n await this.clearTimerOnRestoreFailed();\n this.isSocketReconnected = true;\n } else {\n throw new Error('event=socketConnectionRetry | browser network not available');\n }\n };\n\n private onSocketClose = (): void => {\n this.clearTimerOnRestoreFailed();\n\n this.reconnectInterval = setInterval(async () => {\n await this.handleSocketClose();\n }, CONNECTIVITY_CHECK_INTERVAL);\n };\n}\n"],"mappings":"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"}
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+ // TODO: Try to find alternative to using Blob and script here
8
+ const workerScript = `
9
+ console.log("*** Keepalive Worker Thread ***");
10
+ let intervalId, intervalDuration, timeOutId, isSocketClosed, closeSocketTimeout;
11
+ let initialised = false;
12
+ let initiateWebSocketClosure = false;
13
+
14
+ const resetOfflineHandler = function () {
15
+ if (timeOutId) {
16
+ initialised = false;
17
+ clearTimeout(timeOutId);
18
+ timeOutId = null;
19
+ }
20
+ };
21
+
22
+ const checkOnlineStatus = function () {
23
+ const onlineStatus = navigator.onLine;
24
+ console.log(
25
+ \`[WebSocketStatus] event=checkOnlineStatus | online status=\`,
26
+ onlineStatus
27
+ );
28
+ return onlineStatus;
29
+ };
30
+
31
+ // Checks network status and if it's offline then force closes WebSocket
32
+ const checkNetworkStatus = function () {
33
+ const onlineStatus = checkOnlineStatus();
34
+ postMessage({ type: "keepalive", onlineStatus });
35
+ if (!onlineStatus && !initialised) {
36
+ initialised = true;
37
+ // Sets a timeout of 16s, checks if socket didn't close then it closes forcefully
38
+ timeOutId = setTimeout(() => {
39
+ if (!isSocketClosed) {
40
+ initiateWebSocketClosure = true;
41
+ postMessage({ type: "closeSocket" });
42
+ }
43
+ }, closeSocketTimeout);
44
+ }
45
+
46
+ if (onlineStatus && initialised) {
47
+ initialised = false;
48
+ }
49
+
50
+ if (initiateWebSocketClosure) {
51
+ initiateWebSocketClosure = false;
52
+ clearTimeout(timeOutId);
53
+ timeOutId = null;
54
+ }
55
+ };
56
+
57
+ addEventListener("message", (event) => {
58
+ if (event.data?.type === "start") {
59
+ intervalDuration = event.data?.intervalDuration || 4000;
60
+ closeSocketTimeout = event.data?.closeSocketTimeout || 5000;
61
+ console.log("event=Websocket startWorker | keepalive Worker started");
62
+ intervalId = setInterval(
63
+ (checkIfSocketClosed) => {
64
+ checkNetworkStatus();
65
+ isSocketClosed = checkIfSocketClosed;
66
+ },
67
+ intervalDuration,
68
+ event.data?.isSocketClosed
69
+ );
70
+
71
+ resetOfflineHandler();
72
+ }
73
+
74
+ if (event.data?.type === "terminate" && intervalId) {
75
+ console.log("event=Websocket terminateWorker | keepalive Worker stopped");
76
+ clearInterval(intervalId);
77
+ intervalId = null;
78
+ resetOfflineHandler();
79
+ }
80
+ });
81
+
82
+ // Listen for online and offline events
83
+ self.addEventListener('online', () => {
84
+ console.log('Network status: online');
85
+ checkNetworkStatus();
86
+ });
87
+
88
+ self.addEventListener('offline', () => {
89
+ console.log('Network status: offline');
90
+ checkNetworkStatus();
91
+ });
92
+ `;
93
+ var _default = exports.default = workerScript;
94
+ //# sourceMappingURL=keepalive.worker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["workerScript","_default","exports","default"],"sources":["keepalive.worker.js"],"sourcesContent":["// TODO: Try to find alternative to using Blob and script here\nconst workerScript = `\nconsole.log(\"*** Keepalive Worker Thread ***\");\nlet intervalId, intervalDuration, timeOutId, isSocketClosed, closeSocketTimeout;\nlet initialised = false;\nlet initiateWebSocketClosure = false;\n\nconst resetOfflineHandler = function () {\n if (timeOutId) {\n initialised = false;\n clearTimeout(timeOutId);\n timeOutId = null;\n }\n};\n\nconst checkOnlineStatus = function () {\n const onlineStatus = navigator.onLine;\n console.log(\n \\`[WebSocketStatus] event=checkOnlineStatus | online status=\\`,\n onlineStatus\n );\n return onlineStatus;\n};\n\n// Checks network status and if it's offline then force closes WebSocket\nconst checkNetworkStatus = function () {\n const onlineStatus = checkOnlineStatus();\n postMessage({ type: \"keepalive\", onlineStatus });\n if (!onlineStatus && !initialised) {\n initialised = true;\n // Sets a timeout of 16s, checks if socket didn't close then it closes forcefully\n timeOutId = setTimeout(() => {\n if (!isSocketClosed) {\n initiateWebSocketClosure = true;\n postMessage({ type: \"closeSocket\" });\n }\n }, closeSocketTimeout);\n }\n\n if (onlineStatus && initialised) {\n initialised = false;\n }\n\n if (initiateWebSocketClosure) {\n initiateWebSocketClosure = false;\n clearTimeout(timeOutId);\n timeOutId = null;\n }\n};\n\naddEventListener(\"message\", (event) => {\n if (event.data?.type === \"start\") {\n intervalDuration = event.data?.intervalDuration || 4000;\n closeSocketTimeout = event.data?.closeSocketTimeout || 5000;\n console.log(\"event=Websocket startWorker | keepalive Worker started\");\n intervalId = setInterval(\n (checkIfSocketClosed) => {\n checkNetworkStatus();\n isSocketClosed = checkIfSocketClosed;\n },\n intervalDuration,\n event.data?.isSocketClosed\n );\n\n resetOfflineHandler();\n }\n\n if (event.data?.type === \"terminate\" && intervalId) {\n console.log(\"event=Websocket terminateWorker | keepalive Worker stopped\");\n clearInterval(intervalId);\n intervalId = null;\n resetOfflineHandler();\n }\n});\n\n// Listen for online and offline events\nself.addEventListener('online', () => {\n console.log('Network status: online');\n checkNetworkStatus();\n});\n\nself.addEventListener('offline', () => {\n console.log('Network status: offline');\n checkNetworkStatus();\n});\n`;\n\nexport default workerScript;\n"],"mappings":";;;;;;AAAA;AACA,MAAMA,YAAY,GAAI;AACtB;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA,CAAC;AAAC,IAAAC,QAAA,GAAAC,OAAA,CAAAC,OAAA,GAEaH,YAAY"}
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":[],"sources":["types.ts"],"sourcesContent":["import {SubscribeRequest} from '../../../types';\nimport {WebSocketManager} from './WebSocketManager';\n\n/**\n * Options for initializing a connection service.\n * @typedef ConnectionServiceOptions\n * @property {WebSocketManager} webSocketManager - The WebSocket manager instance.\n * @property {SubscribeRequest} subscribeRequest - The subscribe request payload.\n * @ignore\n */\nexport type ConnectionServiceOptions = {\n webSocketManager: WebSocketManager;\n subscribeRequest: SubscribeRequest;\n};\n\n/**\n * Details about the state of a lost connection and recovery attempts.\n * @typedef ConnectionLostDetails\n * @property {boolean} isConnectionLost - Indicates if the connection is currently lost.\n * @property {boolean} isRestoreFailed - Indicates if restoring the connection has failed.\n * @property {boolean} isSocketReconnected - Indicates if the socket has been reconnected.\n * @property {boolean} isKeepAlive - Indicates if the keep-alive mechanism is active.\n * @ignore\n */\nexport type ConnectionLostDetails = {\n isConnectionLost: boolean;\n isRestoreFailed: boolean;\n isSocketReconnected: boolean;\n isKeepAlive: boolean;\n};\n\n/**\n * Properties for connection configuration.\n * @typedef ConnectionProp\n * @property {number} lostConnectionRecoveryTimeout - Timeout in milliseconds for lost connection recovery.\n * @ignore\n */\nexport type ConnectionProp = {\n lostConnectionRecoveryTimeout: number;\n};\n"],"mappings":""}