@webex/plugin-meetings 2.60.0-next.1 → 2.60.0-next.10

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 (185) hide show
  1. package/dist/annotation/annotation.types.d.ts +42 -0
  2. package/dist/annotation/constants.d.ts +31 -0
  3. package/dist/annotation/index.d.ts +117 -0
  4. package/dist/breakouts/breakout.d.ts +8 -0
  5. package/dist/breakouts/breakout.js +1 -1
  6. package/dist/breakouts/collection.d.ts +5 -0
  7. package/dist/breakouts/edit-lock-error.d.ts +15 -0
  8. package/dist/breakouts/events.d.ts +8 -0
  9. package/dist/breakouts/index.d.ts +5 -0
  10. package/dist/breakouts/index.js +1 -1
  11. package/dist/breakouts/request.d.ts +22 -0
  12. package/dist/breakouts/utils.d.ts +15 -0
  13. package/dist/common/browser-detection.d.ts +9 -0
  14. package/dist/common/collection.d.ts +48 -0
  15. package/dist/common/config.d.ts +2 -0
  16. package/dist/common/errors/captcha-error.d.ts +15 -0
  17. package/dist/common/errors/intent-to-join.d.ts +16 -0
  18. package/dist/common/errors/join-meeting.d.ts +17 -0
  19. package/dist/common/errors/media.d.ts +15 -0
  20. package/dist/common/errors/no-meeting-info.d.ts +14 -0
  21. package/dist/common/errors/parameter.d.ts +15 -0
  22. package/dist/common/errors/password-error.d.ts +15 -0
  23. package/dist/common/errors/permission.d.ts +14 -0
  24. package/dist/common/errors/reclaim-host-role-errors.d.ts +60 -0
  25. package/dist/common/errors/reconnection-in-progress.d.ts +9 -0
  26. package/dist/common/errors/reconnection.d.ts +15 -0
  27. package/dist/common/errors/stats.d.ts +15 -0
  28. package/dist/common/errors/webex-errors.d.ts +93 -0
  29. package/dist/common/errors/webex-meetings-error.d.ts +20 -0
  30. package/dist/common/events/events-scope.d.ts +17 -0
  31. package/dist/common/events/events.d.ts +12 -0
  32. package/dist/common/events/trigger-proxy.d.ts +2 -0
  33. package/dist/common/events/util.d.ts +2 -0
  34. package/dist/common/logs/logger-config.d.ts +2 -0
  35. package/dist/common/logs/logger-proxy.d.ts +2 -0
  36. package/dist/common/logs/request.d.ts +36 -0
  37. package/dist/common/queue.d.ts +34 -0
  38. package/dist/config.d.ts +71 -0
  39. package/dist/constants.d.ts +1072 -0
  40. package/dist/constants.js +1 -1
  41. package/dist/constants.js.map +1 -1
  42. package/dist/controls-options-manager/constants.d.ts +4 -0
  43. package/dist/controls-options-manager/enums.d.ts +15 -0
  44. package/dist/controls-options-manager/enums.js +2 -1
  45. package/dist/controls-options-manager/enums.js.map +1 -1
  46. package/dist/controls-options-manager/index.d.ts +136 -0
  47. package/dist/controls-options-manager/types.d.ts +43 -0
  48. package/dist/controls-options-manager/util.d.ts +1 -0
  49. package/dist/index.d.ts +7 -0
  50. package/dist/interpretation/collection.d.ts +5 -0
  51. package/dist/interpretation/index.d.ts +5 -0
  52. package/dist/interpretation/index.js +1 -1
  53. package/dist/interpretation/siLanguage.d.ts +5 -0
  54. package/dist/interpretation/siLanguage.js +1 -1
  55. package/dist/locus-info/controlsUtils.d.ts +2 -0
  56. package/dist/locus-info/embeddedAppsUtils.d.ts +2 -0
  57. package/dist/locus-info/fullState.d.ts +2 -0
  58. package/dist/locus-info/hostUtils.d.ts +2 -0
  59. package/dist/locus-info/index.d.ts +322 -0
  60. package/dist/locus-info/infoUtils.d.ts +2 -0
  61. package/dist/locus-info/mediaSharesUtils.d.ts +2 -0
  62. package/dist/locus-info/parser.d.ts +272 -0
  63. package/dist/locus-info/parser.js +5 -5
  64. package/dist/locus-info/parser.js.map +1 -1
  65. package/dist/locus-info/selfUtils.d.ts +2 -0
  66. package/dist/media/index.d.ts +34 -0
  67. package/dist/media/index.js +6 -5
  68. package/dist/media/index.js.map +1 -1
  69. package/dist/media/properties.d.ts +93 -0
  70. package/dist/media/util.d.ts +2 -0
  71. package/dist/mediaQualityMetrics/config.d.ts +237 -0
  72. package/dist/mediaQualityMetrics/config.js +1 -202
  73. package/dist/mediaQualityMetrics/config.js.map +1 -1
  74. package/dist/meeting/in-meeting-actions.d.ts +167 -0
  75. package/dist/meeting/in-meeting-actions.js +4 -0
  76. package/dist/meeting/in-meeting-actions.js.map +1 -1
  77. package/dist/meeting/index.d.ts +1719 -0
  78. package/dist/meeting/index.js +288 -155
  79. package/dist/meeting/index.js.map +1 -1
  80. package/dist/meeting/locusMediaRequest.d.ts +74 -0
  81. package/dist/meeting/muteState.d.ts +184 -0
  82. package/dist/meeting/request.d.ts +290 -0
  83. package/dist/meeting/request.type.d.ts +11 -0
  84. package/dist/meeting/state.d.ts +9 -0
  85. package/dist/meeting/util.d.ts +103 -0
  86. package/dist/meeting-info/collection.d.ts +20 -0
  87. package/dist/meeting-info/index.d.ts +69 -0
  88. package/dist/meeting-info/meeting-info-v2.d.ts +123 -0
  89. package/dist/meeting-info/meeting-info-v2.js +3 -0
  90. package/dist/meeting-info/meeting-info-v2.js.map +1 -1
  91. package/dist/meeting-info/request.d.ts +22 -0
  92. package/dist/meeting-info/util.d.ts +2 -0
  93. package/dist/meeting-info/utilv2.d.ts +2 -0
  94. package/dist/meeting-info/utilv2.js +14 -29
  95. package/dist/meeting-info/utilv2.js.map +1 -1
  96. package/dist/meetings/collection.d.ts +40 -0
  97. package/dist/meetings/collection.js +17 -0
  98. package/dist/meetings/collection.js.map +1 -1
  99. package/dist/meetings/index.d.ts +378 -0
  100. package/dist/meetings/index.js +30 -9
  101. package/dist/meetings/index.js.map +1 -1
  102. package/dist/meetings/meetings.types.d.ts +4 -0
  103. package/dist/meetings/request.d.ts +27 -0
  104. package/dist/meetings/util.d.ts +18 -0
  105. package/dist/member/index.d.ts +160 -0
  106. package/dist/member/member.types.d.ts +11 -0
  107. package/dist/member/types.d.ts +32 -0
  108. package/dist/member/util.d.ts +2 -0
  109. package/dist/members/collection.d.ts +29 -0
  110. package/dist/members/index.d.ts +353 -0
  111. package/dist/members/request.d.ts +114 -0
  112. package/dist/members/types.d.ts +25 -0
  113. package/dist/members/util.d.ts +215 -0
  114. package/dist/metrics/constants.d.ts +68 -0
  115. package/dist/metrics/constants.js +3 -0
  116. package/dist/metrics/constants.js.map +1 -1
  117. package/dist/metrics/index.d.ts +45 -0
  118. package/dist/multistream/mediaRequestManager.d.ts +118 -0
  119. package/dist/multistream/receiveSlot.d.ts +68 -0
  120. package/dist/multistream/receiveSlotManager.d.ts +56 -0
  121. package/dist/multistream/remoteMedia.d.ts +72 -0
  122. package/dist/multistream/remoteMediaGroup.d.ts +47 -0
  123. package/dist/multistream/remoteMediaManager.d.ts +285 -0
  124. package/dist/multistream/sendSlotManager.d.ts +61 -0
  125. package/dist/networkQualityMonitor/index.d.ts +70 -0
  126. package/dist/personal-meeting-room/index.d.ts +47 -0
  127. package/dist/personal-meeting-room/request.d.ts +14 -0
  128. package/dist/personal-meeting-room/util.d.ts +2 -0
  129. package/dist/reachability/index.d.ts +194 -0
  130. package/dist/reachability/request.d.ts +39 -0
  131. package/dist/reactions/constants.d.ts +3 -0
  132. package/dist/reactions/reactions.d.ts +4 -0
  133. package/dist/reactions/reactions.type.d.ts +52 -0
  134. package/dist/reconnection-manager/index.d.ts +136 -0
  135. package/dist/reconnection-manager/index.js +27 -28
  136. package/dist/reconnection-manager/index.js.map +1 -1
  137. package/dist/recording-controller/enums.d.ts +7 -0
  138. package/dist/recording-controller/index.d.ts +207 -0
  139. package/dist/recording-controller/util.d.ts +14 -0
  140. package/dist/roap/index.d.ts +78 -0
  141. package/dist/roap/request.d.ts +41 -0
  142. package/dist/roap/turnDiscovery.d.ts +92 -0
  143. package/dist/rtcMetrics/constants.d.ts +4 -0
  144. package/dist/rtcMetrics/index.d.ts +54 -0
  145. package/dist/rtcMetrics/index.js +25 -0
  146. package/dist/rtcMetrics/index.js.map +1 -1
  147. package/dist/statsAnalyzer/global.d.ts +36 -0
  148. package/dist/statsAnalyzer/index.d.ts +191 -0
  149. package/dist/statsAnalyzer/index.js +53 -146
  150. package/dist/statsAnalyzer/index.js.map +1 -1
  151. package/dist/statsAnalyzer/mqaUtil.d.ts +24 -0
  152. package/dist/statsAnalyzer/mqaUtil.js +11 -12
  153. package/dist/statsAnalyzer/mqaUtil.js.map +1 -1
  154. package/dist/transcription/index.d.ts +64 -0
  155. package/dist/webinar/collection.d.ts +16 -0
  156. package/dist/webinar/index.d.ts +5 -0
  157. package/dist/webinar/index.js +1 -1
  158. package/package.json +26 -27
  159. package/src/constants.ts +10 -4
  160. package/src/controls-options-manager/enums.ts +2 -0
  161. package/src/locus-info/parser.ts +6 -6
  162. package/src/media/index.ts +5 -5
  163. package/src/mediaQualityMetrics/config.ts +0 -135
  164. package/src/meeting/in-meeting-actions.ts +8 -0
  165. package/src/meeting/index.ts +263 -125
  166. package/src/meeting-info/meeting-info-v2.ts +4 -0
  167. package/src/meeting-info/utilv2.ts +6 -19
  168. package/src/meetings/collection.ts +13 -0
  169. package/src/meetings/index.ts +28 -10
  170. package/src/metrics/constants.ts +3 -0
  171. package/src/reconnection-manager/index.ts +63 -68
  172. package/src/rtcMetrics/index.ts +24 -0
  173. package/src/statsAnalyzer/index.ts +68 -216
  174. package/src/statsAnalyzer/mqaUtil.ts +17 -22
  175. package/test/unit/spec/media/index.ts +20 -4
  176. package/test/unit/spec/meeting/in-meeting-actions.ts +4 -0
  177. package/test/unit/spec/meeting/index.js +1376 -189
  178. package/test/unit/spec/meeting/muteState.js +2 -1
  179. package/test/unit/spec/meeting-info/meetinginfov2.js +28 -0
  180. package/test/unit/spec/meetings/collection.js +12 -0
  181. package/test/unit/spec/meetings/index.js +382 -118
  182. package/test/unit/spec/member/util.js +0 -31
  183. package/test/unit/spec/reconnection-manager/index.js +42 -12
  184. package/test/unit/spec/rtcMetrics/index.ts +20 -0
  185. package/test/unit/spec/stats-analyzer/index.js +12 -2
@@ -0,0 +1,272 @@
1
+ import SortedQueue from '../common/queue';
2
+ type LocusDeltaDto = {
3
+ url: string;
4
+ baseSequence: {
5
+ rangeStart: number;
6
+ rangeEnd: number;
7
+ entries: number[];
8
+ };
9
+ sequence: {
10
+ rangeStart: number;
11
+ rangeEnd: number;
12
+ entries: number[];
13
+ };
14
+ syncUrl: string;
15
+ };
16
+ /**
17
+ * Locus Delta Parser
18
+ * @private
19
+ * https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Delta-Events
20
+ */
21
+ export default class Parser {
22
+ status: 'IDLE' | 'PAUSED' | 'WORKING' | 'BLOCKED';
23
+ static loci: {
24
+ EQ: string;
25
+ GT: string;
26
+ LT: string;
27
+ DESYNC: string;
28
+ USE_INCOMING: string;
29
+ USE_CURRENT: string;
30
+ WAIT: string;
31
+ ERROR: string;
32
+ LOCUS_URL_CHANGED: string;
33
+ };
34
+ queue: SortedQueue<LocusDeltaDto>;
35
+ workingCopy: any;
36
+ syncTimer?: ReturnType<typeof setTimeout>;
37
+ /**
38
+ * @constructs Parser
39
+ */
40
+ constructor();
41
+ /**
42
+ * Returns a debug string representing a locus delta - useful for logging
43
+ *
44
+ * @param {LocusDeltaDto} locus Locus delta
45
+ * @returns {string}
46
+ */
47
+ static locus2string(locus: LocusDeltaDto): string;
48
+ /**
49
+ * Checks if two sequences overlap in time,
50
+ * the sequence with the higher minimum value is greater.
51
+ * Chooses sequence with most recent data.
52
+ * @param {Types~Locus} current
53
+ * @param {Types~Locus} incoming
54
+ * @returns {string} loci comparison state
55
+ */
56
+ static checkSequenceOverlap(current: any, incoming: any): any;
57
+ /**
58
+ * Checks if two sequences have unequal ranges.
59
+ * Chooses sequence with most larger range.
60
+ * @param {Types~Locus} current
61
+ * @param {Types~Locus} incoming
62
+ * @returns {object} loci comparison
63
+ */
64
+ static checkUnequalRanges(current: any, incoming: any): any;
65
+ /**
66
+ * Checks if either sequences has unique entries.
67
+ * Entries are considered unique if they do not overlap
68
+ * with other Loci sequences or range values.
69
+ * Chooses sequence with the unique entries.
70
+ * @param {Types~Locus} current
71
+ * @param {Types~Locus} incoming
72
+ * @returns {string} loci comparison state
73
+ */
74
+ static checkForUniqueEntries(current: any, incoming: any): any;
75
+ /**
76
+ * Checks both Locus Delta objects to see if they are
77
+ * out of sync with one another. If so sends a DESYNC
78
+ * request to the server.
79
+ * @param {Types~Locus} current
80
+ * @param {Types~Locus} incoming
81
+ * @returns {string} loci comparison state
82
+ */
83
+ static checkIfOutOfSync(current: any, incoming: any): any;
84
+ /**
85
+ * Compares two loci to determine which one contains the most recent state
86
+ * @instance
87
+ * @memberof Locus
88
+ * @param {Types~Locus} current
89
+ * @param {Types~Locus} incoming
90
+ * @returns {string} loci comparison state
91
+ */
92
+ static compare(current: any, incoming: any): string;
93
+ /**
94
+ * Compares two loci sequences (with delta params) and indicates what action
95
+ * to take.
96
+ * @instance
97
+ * @memberof Locus
98
+ * @param {Types~Locus} current
99
+ * @param {Types~Locus} incoming
100
+ * @private
101
+ * @returns {string} loci comparison state
102
+ */
103
+ private static compareDelta;
104
+ /**
105
+ * Compares Locus sequences - it should be called only for full Locus DTOs, not deltas
106
+ *
107
+ * @param {Types~Locus} current Current working copy
108
+ * @param {Types~Locus} incomingFullDto New Full Locus DTO
109
+ * @returns {string} either Parser.loci.USE_INCOMING or Parser.loci.USE_CURRENT
110
+ */
111
+ static compareFullDtoSequence(current: any, incomingFullDto: any): string;
112
+ /**
113
+ * Returns true if the incoming full locus DTO is newer than the current working copy
114
+ *
115
+ * @param {Types~Locus} incomingFullDto New Full Locus DTO
116
+ * @returns {string} either Parser.loci.USE_INCOMING or Parser.loci.USE_CURRENT
117
+ */
118
+ isNewFullLocus(incomingFullDto: any): boolean;
119
+ /**
120
+ * Compares Locus sequences
121
+ * @param {Types~Locus} current Current working copy
122
+ * @param {Types~Locus} incoming New Locus delta
123
+ * @returns {string}
124
+ */
125
+ static compareSequence(current: any, incoming: any): any;
126
+ /**
127
+ * Transates the result of a sequence comparison into an intended behavior
128
+ * @param {string} result
129
+ * @returns {string} Locus comparison action
130
+ */
131
+ static compareToAction(result: string): string;
132
+ /**
133
+ * Extracts a loci comparison from a string of data.
134
+ * @param {string} lociComparisonResult Comparison result with extra data
135
+ * @returns {string} Comparison of EQ, LT, GT, or DESYNC.
136
+ */
137
+ static extractComparisonState(lociComparisonResult: string): string;
138
+ /**
139
+ * @typedef {object} LociMetadata
140
+ * @property {number} start - Starting sequence number
141
+ * @property {number} end - Ending sequence number
142
+ * @property {number} first - First sequence number
143
+ * @property {number} last - Last sequence number
144
+ * @property {number} min - Minimum sequence number
145
+ * @property {number} max - Maximum sequence number
146
+ * @property {number} entries - Loci sequence entries
147
+ */
148
+ /**
149
+ * Metadata for Locus delta
150
+ * @param {Array.<number>} sequence Locus delta sequence
151
+ * @returns {LociMetadata} Locus Delta Metadata
152
+ */
153
+ static getMetaData(sequence: any): {
154
+ start: any;
155
+ end: any;
156
+ first: any;
157
+ last: any;
158
+ min: any;
159
+ max: any;
160
+ entries: any;
161
+ };
162
+ /**
163
+ * Compares two Locus delta objects and notes unique
164
+ * values contained within baseLoci.
165
+ * @param {LociMetadata} baseLoci
166
+ * @param {LociMetadata} otherLoci
167
+ * @returns {Array.<number>} List of unique sequences
168
+ */
169
+ static getUniqueSequences(baseLoci: any, otherLoci: any): number[];
170
+ /**
171
+ * Returns an array of numbers outside of a given range.
172
+ * @param {Array.<number>} list Array to filter
173
+ * @param {number} rangeStart Start of range
174
+ * @param {number} rangeEnd End of range
175
+ * @returns {Array.<number>} Array of numbers sorted ASC
176
+ */
177
+ static getNumbersOutOfRange(list: Array<number>, rangeStart: number, rangeEnd: number): number[];
178
+ /**
179
+ * Checks if newLoci or workingCopy is invalid.
180
+ * @param {Types~Locus} newLoci
181
+ * @returns {boolean}
182
+ */
183
+ isValidLocus(newLoci: any): boolean;
184
+ /**
185
+ * Determines if a paricular locus's sequence is empty
186
+ * @param {Types~Locus} locus
187
+ * @returns {bool}
188
+ */
189
+ static isSequenceEmpty(locus: any): boolean;
190
+ /**
191
+ * Determines if an object has basic
192
+ * structure of a locus object.
193
+ * @param {Types~Locus} loci
194
+ * @returns {boolean}
195
+ */
196
+ static isLoci(loci: any): boolean;
197
+ /**
198
+ * Processes next event in queue,
199
+ * if queue is empty sets status to idle.
200
+ * @returns {undefined}
201
+ */
202
+ nextEvent(): void;
203
+ /**
204
+ * Function handler for delta actions,
205
+ * is set by instance callee.
206
+ * @param {string} action Locus delta action
207
+ * @param {Types~Locus} locus Locus delta
208
+ * @returns {undefined}
209
+ */
210
+ onDeltaAction(action: string, locus: any): void;
211
+ /**
212
+ * Event handler for locus delta events
213
+ * @param {Types~Locus} loci Locus Delta
214
+ * @returns {undefined}
215
+ */
216
+ onDeltaEvent(loci: any): void;
217
+ /**
218
+ * Appends new data onto a string of existing data.
219
+ * @param {string} newData
220
+ * @param {string} oldData
221
+ * @returns {string}
222
+ */
223
+ static packComparisonResult(newData: string, oldData: string): string;
224
+ /**
225
+ * Pause locus processing
226
+ * @returns {undefined}
227
+ */
228
+ pause(): void;
229
+ /**
230
+ * Triggers a sync with Locus
231
+ *
232
+ * @param {string} reason used just for logging
233
+ * @returns {undefined}
234
+ */
235
+ private triggerSync;
236
+ /**
237
+ * Starts a timer with a random delay. When that timer expires we will do a sync.
238
+ *
239
+ * The main purpose of this timer is to handle a case when we get some out-of-order deltas,
240
+ * so we start waiting to receive the missing delta. If that delta never arrives, this timer
241
+ * will trigger a sync with Locus.
242
+ *
243
+ * @returns {undefined}
244
+ */
245
+ private startSyncTimer;
246
+ /**
247
+ * Stops the timer for triggering a sync
248
+ *
249
+ * @returns {undefined}
250
+ */
251
+ private stopSyncTimer;
252
+ /**
253
+ * Processes next locus delta in the queue,
254
+ * continues until the queue is empty
255
+ * or cleared.
256
+ * @returns {undefined}
257
+ */
258
+ processDeltaEvent(): void;
259
+ /**
260
+ * Resume from a paused state
261
+ * @returns {undefined}
262
+ */
263
+ resume(): void;
264
+ /**
265
+ * Gets related debug info for given error code
266
+ * @param {string} debugCode Debug code
267
+ * @param {string} comparison Locus comparison string
268
+ * @returns {object} Debug message
269
+ */
270
+ static getDebugMessage(debugCode: string, comparison: string): any;
271
+ }
272
+ export {};
@@ -59,7 +59,7 @@ var Parser = exports.default = /*#__PURE__*/function () {
59
59
  this.status = 'IDLE';
60
60
  this.onDeltaAction = null;
61
61
  this.workingCopy = null;
62
- this.syncTimer = null;
62
+ this.syncTimer = undefined;
63
63
  }
64
64
 
65
65
  /**
@@ -231,10 +231,10 @@ var Parser = exports.default = /*#__PURE__*/function () {
231
231
  key: "startSyncTimer",
232
232
  value: function startSyncTimer() {
233
233
  var _this = this;
234
- if (this.syncTimer === null) {
234
+ if (this.syncTimer === undefined) {
235
235
  var timeout = OOO_DELTA_WAIT_TIME + Math.random() * OOO_DELTA_WAIT_TIME_RANDOM_DELAY;
236
236
  this.syncTimer = setTimeout(function () {
237
- _this.syncTimer = null;
237
+ _this.syncTimer = undefined;
238
238
  _this.triggerSync('timer expired, blocked on out-of-order delta');
239
239
  }, timeout);
240
240
  }
@@ -248,9 +248,9 @@ var Parser = exports.default = /*#__PURE__*/function () {
248
248
  }, {
249
249
  key: "stopSyncTimer",
250
250
  value: function stopSyncTimer() {
251
- if (this.syncTimer !== null) {
251
+ if (this.syncTimer !== undefined) {
252
252
  clearTimeout(this.syncTimer);
253
- this.syncTimer = null;
253
+ this.syncTimer = undefined;
254
254
  }
255
255
  }
256
256
 
@@ -1 +1 @@
1
- {"version":3,"names":["_lodash","require","_queue","_interopRequireDefault","_loggerProxy","_metrics","_constants","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_templateObject9","_templateObject10","MAX_OOO_DELTA_COUNT","OOO_DELTA_WAIT_TIME","OOO_DELTA_WAIT_TIME_RANDOM_DELAY","Parser","exports","default","_classCallCheck2","_defineProperty2","deltaCompareFunc","left","right","_Parser$loci","loci","LT","GT","extract","extractComparisonState","isSequenceEmpty","result","compareSequence","baseSequence","queue","SortedQueue","status","onDeltaAction","workingCopy","syncTimer","_createClass2","key","value","isNewFullLocus","incomingFullDto","isLoci","LoggerProxy","logger","info","comparisonResult","compareFullDtoSequence","USE_INCOMING","isValidLocus","newLoci","isValid","nextEvent","size","processDeltaEvent","action","locus","onDeltaEvent","enqueue","triggerSync","pause","reason","concat","stopSyncTimer","DESYNC","startSyncTimer","_this","timeout","Math","random","setTimeout","clearTimeout","_Parser$loci2","WAIT","LOCUS_URL_CHANGED","dequeue","compare","lociComparison","debug","needToWait","locus2string","resume","_locus$sequence","sequence","entries","length","at","checkSequenceOverlap","current","incoming","comparison","min","max","checkUnequalRanges","currentIsNotUnique","unique","incomingIsNotUnique","currentTotalRange","end","incomingTotalRange","EQ","checkForUniqueEntries","currentIsUnique","incomingIsUnique","checkIfOutOfSync","currentUniqueMin","incomingUniqueMin","currentHasNoRange","start","incomingHasNoRange","neitherSeqHasRange","hasUniqOverlap","list","some","seq","currentUniqOverlap","incomingUniqOverlap","debugInfo","pack","packComparisonResult","compareDelta","compareToAction","_Parser$loci3","url","Metrics","sendBehavioralMetric","BEHAVIORAL_METRICS","LOCUS_DELTA_OUT_OF_ORDER","stack","Error","slice","USE_CURRENT","local","getMetaData","delta","getUniqueSequences","rules","_i","_rules","rule","ERROR","_Parser$loci4","lociComparisonResult","split","first","last","rangeStart","rangeEnd","baseLoci","otherLoci","diff","difference","getNumbersOutOfRange","output","filter","num","sort","a","b","_sequence$entries","hasEmptyEntries","hasEmptyRange","hasProp","prop","Object","prototype","hasOwnProperty","call","newData","oldData","getDebugMessage","debugCode","mStr","strings","join","replace","resolutionMap","debugMap","SO001","title","description","_taggedTemplateLiteral2","logic","SO002","UR001","UR002","UR003","UE001","UE002","OOS001","OOS002","OOS003","debugObj","resolution"],"sources":["parser.ts"],"sourcesContent":["import {difference} from 'lodash';\n\nimport SortedQueue from '../common/queue';\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nimport Metrics from '../metrics';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\n\nconst MAX_OOO_DELTA_COUNT = 5; // when we receive an out-of-order delta and the queue builds up to MAX_OOO_DELTA_COUNT, we do a sync with Locus\nconst OOO_DELTA_WAIT_TIME = 10000; // [ms] minimum wait time before we do a sync if we get out-of-order deltas\nconst OOO_DELTA_WAIT_TIME_RANDOM_DELAY = 5000; // [ms] max random delay added to OOO_DELTA_WAIT_TIME\n\ntype LocusDeltaDto = {\n url: string;\n baseSequence: {\n rangeStart: number;\n rangeEnd: number;\n entries: number[];\n };\n sequence: {\n rangeStart: number;\n rangeEnd: number;\n entries: number[];\n };\n syncUrl: string;\n};\n\n/**\n * Locus Delta Parser\n * @private\n * https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Delta-Events\n */\nexport default class Parser {\n // processing status\n status:\n | 'IDLE' // not doing anything\n | 'PAUSED' // paused, because we are doing a sync\n | 'WORKING' // processing a delta event\n | 'BLOCKED'; // received an out-of-order delta, so waiting for the missing one\n\n // loci comparison states\n static loci = {\n EQ: 'EQUAL',\n GT: 'GREATER_THAN',\n LT: 'LESS_THAN',\n DESYNC: 'DESYNC',\n USE_INCOMING: 'USE_INCOMING',\n USE_CURRENT: 'USE_CURRENT',\n WAIT: 'WAIT',\n ERROR: 'ERROR',\n LOCUS_URL_CHANGED: 'LOCUS_URL_CHANGED',\n };\n\n queue: SortedQueue<LocusDeltaDto>;\n workingCopy: any;\n syncTimer: null | number | NodeJS.Timeout;\n\n /**\n * @constructs Parser\n */\n constructor() {\n const deltaCompareFunc = (left: LocusDeltaDto, right: LocusDeltaDto) => {\n const {LT, GT} = Parser.loci;\n const {extractComparisonState: extract} = Parser;\n\n if (Parser.isSequenceEmpty(left)) {\n return -1;\n }\n if (Parser.isSequenceEmpty(right)) {\n return 1;\n }\n const result = extract(Parser.compareSequence(left.baseSequence, right.baseSequence));\n\n if (result === LT) {\n return -1;\n }\n if (result === GT) {\n return 1;\n }\n\n return 0;\n };\n\n this.queue = new SortedQueue<LocusDeltaDto>(deltaCompareFunc);\n this.status = 'IDLE';\n this.onDeltaAction = null;\n this.workingCopy = null;\n this.syncTimer = null;\n }\n\n /**\n * Returns a debug string representing a locus delta - useful for logging\n *\n * @param {LocusDeltaDto} locus Locus delta\n * @returns {string}\n */\n static locus2string(locus: LocusDeltaDto) {\n if (!locus.sequence?.entries) {\n return 'invalid';\n }\n\n return locus.sequence.entries.length ? `seq=${locus.sequence.entries.at(-1)}` : 'empty';\n }\n\n /**\n * Checks if two sequences overlap in time,\n * the sequence with the higher minimum value is greater.\n * Chooses sequence with most recent data.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static checkSequenceOverlap(current, incoming) {\n let comparison = null;\n\n // if earliest working copy sequence is more recent than last incoming sequence\n if (current.min > incoming.max) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:SO001`;\n }\n // if last working copy sequence is before the earliest incoming sequence\n else if (current.max < incoming.min) {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:SO002`;\n }\n\n // if no match above, defaults to null\n return comparison;\n }\n\n /**\n * Checks if two sequences have unequal ranges.\n * Chooses sequence with most larger range.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {object} loci comparison\n */\n static checkUnequalRanges(current, incoming) {\n let comparison = null;\n const currentIsNotUnique = current.unique.length === 0;\n const incomingIsNotUnique = incoming.unique.length === 0;\n const currentTotalRange = current.end - current.min;\n const incomingTotalRange = incoming.end - incoming.min;\n\n // no unique values for both loci\n if (currentIsNotUnique && incomingIsNotUnique) {\n // current working copy loci has a larger range\n if (currentTotalRange > incomingTotalRange) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:UR001`;\n }\n // incoming delta loci has a larger range\n else if (currentTotalRange < incomingTotalRange) {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:UR002`;\n } else {\n // with no unique entries and with ranges either absent or\n // of the same size, the sequences are considered equal.\n comparison = `${Parser.loci.EQ}:UR003`;\n }\n }\n\n return comparison;\n }\n\n /**\n * Checks if either sequences has unique entries.\n * Entries are considered unique if they do not overlap\n * with other Loci sequences or range values.\n * Chooses sequence with the unique entries.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static checkForUniqueEntries(current, incoming) {\n let comparison = null;\n const currentIsUnique = current.unique.length > 0;\n const incomingIsUnique = incoming.unique.length > 0;\n\n // current has unique entries and incoming does not\n if (currentIsUnique && !incomingIsUnique) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:UE001`;\n }\n // current has no unique entries but incoming does\n else if (!currentIsUnique && incomingIsUnique) {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:UE002`;\n }\n\n return comparison;\n }\n\n /**\n * Checks both Locus Delta objects to see if they are\n * out of sync with one another. If so sends a DESYNC\n * request to the server.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static checkIfOutOfSync(current, incoming) {\n let comparison = null;\n const currentUniqueMin = current.unique[0];\n const incomingUniqueMin = incoming.unique[0];\n\n const currentHasNoRange = !current.start && !current.end;\n const incomingHasNoRange = !incoming.start && !incoming.end;\n const neitherSeqHasRange = currentHasNoRange && incomingHasNoRange;\n\n const hasUniqOverlap = (list, min, max) => list.some((seq) => min < seq && seq < max);\n // current unique entries overlap the total range of incoming\n const currentUniqOverlap = hasUniqOverlap(current.unique, incoming.min, incoming.max);\n // vice-versa, incoming unique entries overlap the total range of current\n const incomingUniqOverlap = hasUniqOverlap(incoming.unique, current.min, current.max);\n\n if (neitherSeqHasRange || currentUniqOverlap || incomingUniqOverlap) {\n // outputs string indicating which condition occurred. ex: 0,1,0\n const debugInfo = `${+neitherSeqHasRange},${+currentUniqOverlap},${+incomingUniqOverlap}`;\n\n // send DESYNC to server\n comparison = `${Parser.loci.DESYNC}:OOS001:${debugInfo}`;\n } else if (currentUniqueMin > incomingUniqueMin) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:OOS002`;\n } else {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:OOS003`;\n }\n\n return comparison;\n }\n\n /**\n * Compares two loci to determine which one contains the most recent state\n * @instance\n * @memberof Locus\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static compare(current, incoming) {\n const {isSequenceEmpty} = Parser;\n const {extractComparisonState: extract} = Parser;\n const {packComparisonResult: pack} = Parser;\n\n if (isSequenceEmpty(current) || isSequenceEmpty(incoming)) {\n return pack(Parser.loci.USE_INCOMING, 'C001');\n }\n\n if (incoming.baseSequence) {\n return pack(Parser.compareDelta(current, incoming), 'C002');\n }\n\n const result = Parser.compareSequence(current.sequence, incoming.sequence);\n const action = Parser.compareToAction(extract(result));\n\n return pack(action, result);\n }\n\n /**\n * Compares two loci sequences (with delta params) and indicates what action\n * to take.\n * @instance\n * @memberof Locus\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @private\n * @returns {string} loci comparison state\n */\n private static compareDelta(current, incoming) {\n const {LT, GT, EQ, DESYNC, USE_INCOMING, WAIT, LOCUS_URL_CHANGED} = Parser.loci;\n\n const {extractComparisonState: extract} = Parser;\n const {packComparisonResult: pack} = Parser;\n\n const result = Parser.compareSequence(current.sequence, incoming.sequence);\n let comparison = extract(result);\n\n if (comparison !== LT) {\n return pack(Parser.compareToAction(comparison), result);\n }\n\n if (incoming.url !== current.url) {\n // when moving to/from a breakout session, the locus URL will change and also\n // the baseSequence, making incoming and current incomparable, so use a\n // unique comparison state\n return pack(LOCUS_URL_CHANGED, result);\n }\n\n comparison = Parser.compareSequence(current.sequence, incoming.baseSequence);\n\n switch (extract(comparison)) {\n case GT:\n case EQ:\n comparison = USE_INCOMING;\n break;\n\n case LT:\n if (extract(Parser.compareSequence(incoming.baseSequence, incoming.sequence)) === EQ) {\n // special case where Locus sends a delta with baseSequence === sequence to trigger a sync,\n // because the delta event is too large to be sent over mercury connection\n comparison = DESYNC;\n } else {\n // the incoming locus has baseSequence from the future, so it is out-of-order,\n // we are missing 1 or more locus that should be in front of it, we need to wait for it\n comparison = WAIT;\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.LOCUS_DELTA_OUT_OF_ORDER, {\n stack: new Error().stack,\n });\n }\n break;\n default:\n comparison = DESYNC;\n }\n\n return pack(comparison, result);\n }\n\n /**\n * Compares Locus sequences - it should be called only for full Locus DTOs, not deltas\n *\n * @param {Types~Locus} current Current working copy\n * @param {Types~Locus} incomingFullDto New Full Locus DTO\n * @returns {string} either Parser.loci.USE_INCOMING or Parser.loci.USE_CURRENT\n */\n static compareFullDtoSequence(current, incomingFullDto) {\n if (Parser.isSequenceEmpty(current) || Parser.isSequenceEmpty(incomingFullDto)) {\n return Parser.loci.USE_INCOMING;\n }\n\n // the sequence.entries list will always contain at least 1 entry\n // https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Sequence-Comparison-Algorithm\n\n return incomingFullDto.sequence.entries.slice(-1)[0] > current.sequence.entries.slice(-1)[0]\n ? Parser.loci.USE_INCOMING\n : Parser.loci.USE_CURRENT;\n }\n\n /**\n * Returns true if the incoming full locus DTO is newer than the current working copy\n *\n * @param {Types~Locus} incomingFullDto New Full Locus DTO\n * @returns {string} either Parser.loci.USE_INCOMING or Parser.loci.USE_CURRENT\n */\n isNewFullLocus(incomingFullDto) {\n if (!Parser.isLoci(incomingFullDto)) {\n LoggerProxy.logger.info('Locus-info:parser#isNewFullLocus --> Ignoring non-locus object.');\n\n return false;\n }\n\n if (!this.workingCopy) {\n // we don't have a working copy yet, so any full locus is better than nothing\n return true;\n }\n\n const comparisonResult = Parser.compareFullDtoSequence(this.workingCopy, incomingFullDto);\n\n return comparisonResult === Parser.loci.USE_INCOMING;\n }\n\n /**\n * Compares Locus sequences\n * @param {Types~Locus} current Current working copy\n * @param {Types~Locus} incoming New Locus delta\n * @returns {string}\n */\n static compareSequence(current, incoming) {\n // Locus sequence comparison rules in order of priority.\n // https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Sequence-Comparison-Algorithm\n\n const local: any = Parser.getMetaData(current);\n const delta: any = Parser.getMetaData(incoming);\n\n // update loci metadata\n local.unique = Parser.getUniqueSequences(local, delta);\n delta.unique = Parser.getUniqueSequences(delta, local);\n\n // Locus sequence comparison rules\n // order matters\n const rules = [\n Parser.checkSequenceOverlap,\n Parser.checkUnequalRanges,\n Parser.checkForUniqueEntries,\n Parser.checkIfOutOfSync,\n ];\n\n for (const rule of rules) {\n // Rule only returns a value if the rule applies,\n // otherwise returns null.\n const result = rule(local, delta);\n\n if (result) {\n return result;\n }\n }\n\n // error, none of rules above applied\n // should never get here as last rule\n // should be catch all.\n return Parser.loci.ERROR;\n }\n\n /**\n * Transates the result of a sequence comparison into an intended behavior\n * @param {string} result\n * @returns {string} Locus comparison action\n */\n static compareToAction(result: string) {\n const {DESYNC, EQ, ERROR, GT, LT, USE_CURRENT, USE_INCOMING} = Parser.loci;\n\n let action = ERROR;\n\n switch (result) {\n case EQ:\n case GT:\n action = USE_CURRENT;\n break;\n case LT:\n action = USE_INCOMING;\n break;\n case DESYNC:\n action = DESYNC;\n break;\n default:\n LoggerProxy.logger.info(\n `Locus-info:parser#compareToAction --> Error: ${result} is not a recognized sequence comparison result.`\n );\n }\n\n return action;\n }\n\n /**\n * Extracts a loci comparison from a string of data.\n * @param {string} lociComparisonResult Comparison result with extra data\n * @returns {string} Comparison of EQ, LT, GT, or DESYNC.\n */\n static extractComparisonState(lociComparisonResult: string) {\n return lociComparisonResult.split(':')[0];\n }\n\n /**\n * @typedef {object} LociMetadata\n * @property {number} start - Starting sequence number\n * @property {number} end - Ending sequence number\n * @property {number} first - First sequence number\n * @property {number} last - Last sequence number\n * @property {number} min - Minimum sequence number\n * @property {number} max - Maximum sequence number\n * @property {number} entries - Loci sequence entries\n */\n\n /**\n * Metadata for Locus delta\n * @param {Array.<number>} sequence Locus delta sequence\n * @returns {LociMetadata} Locus Delta Metadata\n */\n static getMetaData(sequence: any) {\n const {entries} = sequence;\n const first = entries[0];\n const last = entries.slice(-1)[0];\n\n // rangeStart or rangeEnd is 0 if a range doesn't exist\n const start = sequence.rangeStart;\n const end = sequence.rangeEnd;\n\n // sequence data\n return {\n start,\n end,\n first,\n last,\n // Rule is: rangeStart <= rangeEnd <= min(entries)\n min: start || first,\n // Grab last entry if exist else default to rangeEnd\n max: last || end,\n // keep reference to actual sequence entries\n entries,\n };\n }\n\n /**\n * Compares two Locus delta objects and notes unique\n * values contained within baseLoci.\n * @param {LociMetadata} baseLoci\n * @param {LociMetadata} otherLoci\n * @returns {Array.<number>} List of unique sequences\n */\n static getUniqueSequences(baseLoci: any, otherLoci: any) {\n const diff: any = difference(baseLoci.entries, otherLoci.entries);\n\n const {start, end} = otherLoci;\n\n return Parser.getNumbersOutOfRange(diff, start, end);\n }\n\n /**\n * Returns an array of numbers outside of a given range.\n * @param {Array.<number>} list Array to filter\n * @param {number} rangeStart Start of range\n * @param {number} rangeEnd End of range\n * @returns {Array.<number>} Array of numbers sorted ASC\n */\n static getNumbersOutOfRange(list: Array<number>, rangeStart: number, rangeEnd: number) {\n // Collect all numbers if number is outside of specified range\n const output = list.filter((num) => num < rangeStart || num > rangeEnd);\n\n // sort ascending\n return output.sort((a, b) => a - b);\n }\n\n /**\n * Checks if newLoci or workingCopy is invalid.\n * @param {Types~Locus} newLoci\n * @returns {boolean}\n */\n isValidLocus(newLoci) {\n let isValid = false;\n const {isLoci} = Parser;\n\n // one or both objects are not locus delta events\n if (!isLoci(this.workingCopy) || !isLoci(newLoci)) {\n LoggerProxy.logger.info(\n 'Locus-info:parser#processDeltaEvent --> Ignoring non-locus object. workingCopy:',\n this.workingCopy,\n 'newLoci:',\n newLoci\n );\n } else {\n isValid = true;\n }\n\n return isValid;\n }\n\n /**\n * Determines if a paricular locus's sequence is empty\n * @param {Types~Locus} locus\n * @returns {bool}\n */\n static isSequenceEmpty(locus) {\n const {sequence} = locus;\n const hasEmptyEntries = !sequence.entries?.length;\n const hasEmptyRange = sequence.rangeStart === 0 && sequence.rangeEnd === 0;\n\n return hasEmptyEntries && hasEmptyRange;\n }\n\n /**\n * Determines if an object has basic\n * structure of a locus object.\n * @param {Types~Locus} loci\n * @returns {boolean}\n */\n static isLoci(loci) {\n if (!loci || !loci.sequence) {\n return false;\n }\n const hasProp = (prop) => Object.prototype.hasOwnProperty.call(loci.sequence, prop);\n\n if (hasProp('rangeStart') && hasProp('rangeEnd')) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Processes next event in queue,\n * if queue is empty sets status to idle.\n * @returns {undefined}\n */\n nextEvent() {\n if (this.status === 'PAUSED') {\n LoggerProxy.logger.info('Locus-info:parser#nextEvent --> Locus parser paused.');\n\n return;\n }\n\n if (this.status === 'BLOCKED') {\n LoggerProxy.logger.info(\n 'Locus-info:parser#nextEvent --> Locus parser blocked by out-of-order delta.'\n );\n\n return;\n }\n\n // continue processing until queue is empty\n if (this.queue.size() > 0) {\n this.processDeltaEvent();\n } else {\n this.status = 'IDLE';\n }\n }\n\n /**\n * Function handler for delta actions,\n * is set by instance callee.\n * @param {string} action Locus delta action\n * @param {Types~Locus} locus Locus delta\n * @returns {undefined}\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n onDeltaAction(action: string, locus) {}\n\n /**\n * Event handler for locus delta events\n * @param {Types~Locus} loci Locus Delta\n * @returns {undefined}\n */\n onDeltaEvent(loci) {\n // enqueue the new loci\n this.queue.enqueue(loci);\n\n if (this.onDeltaAction) {\n if (this.status === 'BLOCKED') {\n if (this.queue.size() > MAX_OOO_DELTA_COUNT) {\n this.triggerSync('queue too big, blocked on out-of-order delta');\n } else {\n this.processDeltaEvent();\n }\n } else if (this.status === 'IDLE') {\n // Update status, ensure we only process one event at a time.\n this.status = 'WORKING';\n\n this.processDeltaEvent();\n }\n }\n }\n\n /**\n * Appends new data onto a string of existing data.\n * @param {string} newData\n * @param {string} oldData\n * @returns {string}\n */\n static packComparisonResult(newData: string, oldData: string) {\n return `${newData}:${oldData}`;\n }\n\n /**\n * Pause locus processing\n * @returns {undefined}\n */\n pause() {\n this.status = 'PAUSED';\n LoggerProxy.logger.info('Locus-info:parser#pause --> Locus parser paused.');\n }\n\n /**\n * Triggers a sync with Locus\n *\n * @param {string} reason used just for logging\n * @returns {undefined}\n */\n private triggerSync(reason: string) {\n LoggerProxy.logger.info(`Locus-info:parser#triggerSync --> doing sync, reason: ${reason}`);\n this.stopSyncTimer();\n this.pause();\n this.onDeltaAction(Parser.loci.DESYNC, this.workingCopy);\n }\n\n /**\n * Starts a timer with a random delay. When that timer expires we will do a sync.\n *\n * The main purpose of this timer is to handle a case when we get some out-of-order deltas,\n * so we start waiting to receive the missing delta. If that delta never arrives, this timer\n * will trigger a sync with Locus.\n *\n * @returns {undefined}\n */\n private startSyncTimer() {\n if (this.syncTimer === null) {\n const timeout = OOO_DELTA_WAIT_TIME + Math.random() * OOO_DELTA_WAIT_TIME_RANDOM_DELAY;\n\n this.syncTimer = setTimeout(() => {\n this.syncTimer = null;\n this.triggerSync('timer expired, blocked on out-of-order delta');\n }, timeout);\n }\n }\n\n /**\n * Stops the timer for triggering a sync\n *\n * @returns {undefined}\n */\n private stopSyncTimer() {\n if (this.syncTimer !== null) {\n clearTimeout(this.syncTimer);\n this.syncTimer = null;\n }\n }\n\n /**\n * Processes next locus delta in the queue,\n * continues until the queue is empty\n * or cleared.\n * @returns {undefined}\n */\n processDeltaEvent() {\n const {DESYNC, USE_INCOMING, WAIT, LOCUS_URL_CHANGED} = Parser.loci;\n const {extractComparisonState: extract} = Parser;\n const newLoci = this.queue.dequeue();\n\n if (!this.isValidLocus(newLoci)) {\n this.nextEvent();\n\n return;\n }\n\n const result = Parser.compare(this.workingCopy, newLoci);\n const lociComparison = extract(result);\n\n // limited debugging, use chrome extension\n // for full debugging.\n LoggerProxy.logger.debug(`Locus-info:parser#processDeltaEvent --> Locus Debug: ${result}`);\n\n let needToWait = false;\n\n switch (lociComparison) {\n case DESYNC:\n // wait for desync response\n this.pause();\n break;\n\n case USE_INCOMING:\n case LOCUS_URL_CHANGED:\n // update working copy for future comparisons.\n // Note: The working copy of parser gets updated in .onFullLocus()\n // and here when USE_INCOMING or LOCUS_URL_CHANGED locus.\n this.workingCopy = newLoci;\n break;\n\n case WAIT:\n // we've taken newLoci from the front of the queue, so put it back there as we have to wait\n // for the one that should be in front of it, before we can process it\n this.queue.enqueue(newLoci);\n needToWait = true;\n break;\n\n default:\n break;\n }\n\n if (needToWait) {\n this.status = 'BLOCKED';\n this.startSyncTimer();\n } else {\n this.stopSyncTimer();\n\n if (this.status === 'BLOCKED') {\n // we are not blocked anymore\n this.status = 'WORKING';\n\n LoggerProxy.logger.info(\n `Locus-info:parser#processDeltaEvent --> received delta that we were waiting for ${Parser.locus2string(\n newLoci\n )}, not blocked anymore`\n );\n }\n }\n\n if (this.onDeltaAction) {\n LoggerProxy.logger.info(\n `Locus-info:parser#processDeltaEvent --> Locus Delta ${Parser.locus2string(\n newLoci\n )}, Action: ${lociComparison}`\n );\n\n this.onDeltaAction(lociComparison, newLoci);\n }\n\n this.nextEvent();\n }\n\n /**\n * Resume from a paused state\n * @returns {undefined}\n */\n resume() {\n LoggerProxy.logger.info('Locus-info:parser#resume --> Locus parser resumed.');\n this.status = 'WORKING';\n this.nextEvent();\n }\n\n /**\n * Gets related debug info for given error code\n * @param {string} debugCode Debug code\n * @param {string} comparison Locus comparison string\n * @returns {object} Debug message\n */\n static getDebugMessage(debugCode: string, comparison: string) {\n // removes extra spaces from multiline string\n const mStr = (strings) => strings.join('').replace(/\\s{2,}/g, ' ');\n\n const resolutionMap = {\n EQ: `${Parser.loci.LT}: is equal (current == incoming).`,\n LT: `${Parser.loci.LT}: choose right side (incoming).`,\n GT: `${Parser.loci.GT}: choose left side (current).`,\n };\n\n const debugMap = {\n SO001: {\n title: 'checkSequenceOverlap-001',\n description: mStr`Occurs if earliest working copy sequence is more \\\n recent than last incoming sequence.`,\n logic: 'current.min > incoming.max',\n },\n\n SO002: {\n title: 'checkSequenceOverlap-002',\n description: mStr`Occurs if last working copy sequence is before the \\\n earliest incoming sequence.`,\n logic: 'current.max < incoming.min',\n },\n\n UR001: {\n title: 'checkUnequalRanges-001',\n description: mStr`Occurs if there are no unique values for both loci, \\\n and the current working copy loci has a larger range.`,\n logic: 'currentTotalRange > incomingTotalRange',\n },\n\n UR002: {\n title: 'checkUnequalRanges-002',\n description: mStr`Occurs if there are no unique values for both loci, \\\n and the incoming delta loci has a larger range.`,\n logic: 'currentTotalRange < incomingTotalRange',\n },\n\n UR003: {\n title: 'checkUnequalRanges-003',\n description: mStr`Occurs if there are no unique values for both loci, \\\n and with ranges either absent or of the same size, the sequences \\\n are considered equal.`,\n logic: 'currentTotalRange == incomingTotalRange',\n },\n\n UE001: {\n title: 'checkForUniqueEntries-001',\n description: mStr`Occurs if current loci has unique entries and \\\n incoming does not. Entries are considered unique if they \\\n do not overlap with other Loci sequences or range values.`,\n logic: 'currentIsUnique && !incomingIsUnique',\n },\n\n UE002: {\n title: 'checkForUniqueEntries-002',\n description: mStr`Occurs if current has no unique entries but \\\n incoming does. Entries are considered unique if they \\\n do not overlap with other Loci sequences or range values.`,\n logic: '!currentIsUnique && incomingIsUnique',\n },\n\n OOS001: {\n title: 'checkIfOutOfSync-001',\n description: mStr`Occurs if neither sequence has a range, or \\\n if the current loci unique entries overlap the total range of the \\\n incoming sequence, or if the incoming unique entries overlap \\\n the total range of current sequence.`,\n logic: 'neitherSeqHasRange || currentUniqOverlap || incomingUniqOverlap',\n },\n\n OOS002: {\n title: 'checkIfOutOfSync-002',\n description: mStr`Occurs if the minimum value from sequences that are \\\n unique to the current loci is greater than the minimum value from \\\n sequences that are unique to the incoming loci.`,\n logic: 'currentUniqueMin > incomingUniqueMin',\n },\n\n OOS003: {\n title: 'checkIfOutOfSync-003',\n description: mStr`Occurs if none of the comparison rules applied. \\\n It is a catch all.`,\n logic: 'else (catch all)',\n },\n };\n\n const debugObj = debugMap[debugCode];\n\n debugObj.title = `Debug: ${debugObj.title}`;\n debugObj.resolution = resolutionMap[comparison];\n\n return debugObj;\n }\n}\n"],"mappings":"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"}
1
+ {"version":3,"names":["_lodash","require","_queue","_interopRequireDefault","_loggerProxy","_metrics","_constants","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_templateObject9","_templateObject10","MAX_OOO_DELTA_COUNT","OOO_DELTA_WAIT_TIME","OOO_DELTA_WAIT_TIME_RANDOM_DELAY","Parser","exports","default","_classCallCheck2","_defineProperty2","deltaCompareFunc","left","right","_Parser$loci","loci","LT","GT","extract","extractComparisonState","isSequenceEmpty","result","compareSequence","baseSequence","queue","SortedQueue","status","onDeltaAction","workingCopy","syncTimer","undefined","_createClass2","key","value","isNewFullLocus","incomingFullDto","isLoci","LoggerProxy","logger","info","comparisonResult","compareFullDtoSequence","USE_INCOMING","isValidLocus","newLoci","isValid","nextEvent","size","processDeltaEvent","action","locus","onDeltaEvent","enqueue","triggerSync","pause","reason","concat","stopSyncTimer","DESYNC","startSyncTimer","_this","timeout","Math","random","setTimeout","clearTimeout","_Parser$loci2","WAIT","LOCUS_URL_CHANGED","dequeue","compare","lociComparison","debug","needToWait","locus2string","resume","_locus$sequence","sequence","entries","length","at","checkSequenceOverlap","current","incoming","comparison","min","max","checkUnequalRanges","currentIsNotUnique","unique","incomingIsNotUnique","currentTotalRange","end","incomingTotalRange","EQ","checkForUniqueEntries","currentIsUnique","incomingIsUnique","checkIfOutOfSync","currentUniqueMin","incomingUniqueMin","currentHasNoRange","start","incomingHasNoRange","neitherSeqHasRange","hasUniqOverlap","list","some","seq","currentUniqOverlap","incomingUniqOverlap","debugInfo","pack","packComparisonResult","compareDelta","compareToAction","_Parser$loci3","url","Metrics","sendBehavioralMetric","BEHAVIORAL_METRICS","LOCUS_DELTA_OUT_OF_ORDER","stack","Error","slice","USE_CURRENT","local","getMetaData","delta","getUniqueSequences","rules","_i","_rules","rule","ERROR","_Parser$loci4","lociComparisonResult","split","first","last","rangeStart","rangeEnd","baseLoci","otherLoci","diff","difference","getNumbersOutOfRange","output","filter","num","sort","a","b","_sequence$entries","hasEmptyEntries","hasEmptyRange","hasProp","prop","Object","prototype","hasOwnProperty","call","newData","oldData","getDebugMessage","debugCode","mStr","strings","join","replace","resolutionMap","debugMap","SO001","title","description","_taggedTemplateLiteral2","logic","SO002","UR001","UR002","UR003","UE001","UE002","OOS001","OOS002","OOS003","debugObj","resolution"],"sources":["parser.ts"],"sourcesContent":["import {difference} from 'lodash';\n\nimport SortedQueue from '../common/queue';\nimport LoggerProxy from '../common/logs/logger-proxy';\n\nimport Metrics from '../metrics';\nimport BEHAVIORAL_METRICS from '../metrics/constants';\n\nconst MAX_OOO_DELTA_COUNT = 5; // when we receive an out-of-order delta and the queue builds up to MAX_OOO_DELTA_COUNT, we do a sync with Locus\nconst OOO_DELTA_WAIT_TIME = 10000; // [ms] minimum wait time before we do a sync if we get out-of-order deltas\nconst OOO_DELTA_WAIT_TIME_RANDOM_DELAY = 5000; // [ms] max random delay added to OOO_DELTA_WAIT_TIME\n\ntype LocusDeltaDto = {\n url: string;\n baseSequence: {\n rangeStart: number;\n rangeEnd: number;\n entries: number[];\n };\n sequence: {\n rangeStart: number;\n rangeEnd: number;\n entries: number[];\n };\n syncUrl: string;\n};\n\n/**\n * Locus Delta Parser\n * @private\n * https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Delta-Events\n */\nexport default class Parser {\n // processing status\n status:\n | 'IDLE' // not doing anything\n | 'PAUSED' // paused, because we are doing a sync\n | 'WORKING' // processing a delta event\n | 'BLOCKED'; // received an out-of-order delta, so waiting for the missing one\n\n // loci comparison states\n static loci = {\n EQ: 'EQUAL',\n GT: 'GREATER_THAN',\n LT: 'LESS_THAN',\n DESYNC: 'DESYNC',\n USE_INCOMING: 'USE_INCOMING',\n USE_CURRENT: 'USE_CURRENT',\n WAIT: 'WAIT',\n ERROR: 'ERROR',\n LOCUS_URL_CHANGED: 'LOCUS_URL_CHANGED',\n };\n\n queue: SortedQueue<LocusDeltaDto>;\n workingCopy: any;\n syncTimer?: ReturnType<typeof setTimeout>;\n\n /**\n * @constructs Parser\n */\n constructor() {\n const deltaCompareFunc = (left: LocusDeltaDto, right: LocusDeltaDto) => {\n const {LT, GT} = Parser.loci;\n const {extractComparisonState: extract} = Parser;\n\n if (Parser.isSequenceEmpty(left)) {\n return -1;\n }\n if (Parser.isSequenceEmpty(right)) {\n return 1;\n }\n const result = extract(Parser.compareSequence(left.baseSequence, right.baseSequence));\n\n if (result === LT) {\n return -1;\n }\n if (result === GT) {\n return 1;\n }\n\n return 0;\n };\n\n this.queue = new SortedQueue<LocusDeltaDto>(deltaCompareFunc);\n this.status = 'IDLE';\n this.onDeltaAction = null;\n this.workingCopy = null;\n this.syncTimer = undefined;\n }\n\n /**\n * Returns a debug string representing a locus delta - useful for logging\n *\n * @param {LocusDeltaDto} locus Locus delta\n * @returns {string}\n */\n static locus2string(locus: LocusDeltaDto) {\n if (!locus.sequence?.entries) {\n return 'invalid';\n }\n\n return locus.sequence.entries.length ? `seq=${locus.sequence.entries.at(-1)}` : 'empty';\n }\n\n /**\n * Checks if two sequences overlap in time,\n * the sequence with the higher minimum value is greater.\n * Chooses sequence with most recent data.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static checkSequenceOverlap(current, incoming) {\n let comparison = null;\n\n // if earliest working copy sequence is more recent than last incoming sequence\n if (current.min > incoming.max) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:SO001`;\n }\n // if last working copy sequence is before the earliest incoming sequence\n else if (current.max < incoming.min) {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:SO002`;\n }\n\n // if no match above, defaults to null\n return comparison;\n }\n\n /**\n * Checks if two sequences have unequal ranges.\n * Chooses sequence with most larger range.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {object} loci comparison\n */\n static checkUnequalRanges(current, incoming) {\n let comparison = null;\n const currentIsNotUnique = current.unique.length === 0;\n const incomingIsNotUnique = incoming.unique.length === 0;\n const currentTotalRange = current.end - current.min;\n const incomingTotalRange = incoming.end - incoming.min;\n\n // no unique values for both loci\n if (currentIsNotUnique && incomingIsNotUnique) {\n // current working copy loci has a larger range\n if (currentTotalRange > incomingTotalRange) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:UR001`;\n }\n // incoming delta loci has a larger range\n else if (currentTotalRange < incomingTotalRange) {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:UR002`;\n } else {\n // with no unique entries and with ranges either absent or\n // of the same size, the sequences are considered equal.\n comparison = `${Parser.loci.EQ}:UR003`;\n }\n }\n\n return comparison;\n }\n\n /**\n * Checks if either sequences has unique entries.\n * Entries are considered unique if they do not overlap\n * with other Loci sequences or range values.\n * Chooses sequence with the unique entries.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static checkForUniqueEntries(current, incoming) {\n let comparison = null;\n const currentIsUnique = current.unique.length > 0;\n const incomingIsUnique = incoming.unique.length > 0;\n\n // current has unique entries and incoming does not\n if (currentIsUnique && !incomingIsUnique) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:UE001`;\n }\n // current has no unique entries but incoming does\n else if (!currentIsUnique && incomingIsUnique) {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:UE002`;\n }\n\n return comparison;\n }\n\n /**\n * Checks both Locus Delta objects to see if they are\n * out of sync with one another. If so sends a DESYNC\n * request to the server.\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static checkIfOutOfSync(current, incoming) {\n let comparison = null;\n const currentUniqueMin = current.unique[0];\n const incomingUniqueMin = incoming.unique[0];\n\n const currentHasNoRange = !current.start && !current.end;\n const incomingHasNoRange = !incoming.start && !incoming.end;\n const neitherSeqHasRange = currentHasNoRange && incomingHasNoRange;\n\n const hasUniqOverlap = (list, min, max) => list.some((seq) => min < seq && seq < max);\n // current unique entries overlap the total range of incoming\n const currentUniqOverlap = hasUniqOverlap(current.unique, incoming.min, incoming.max);\n // vice-versa, incoming unique entries overlap the total range of current\n const incomingUniqOverlap = hasUniqOverlap(incoming.unique, current.min, current.max);\n\n if (neitherSeqHasRange || currentUniqOverlap || incomingUniqOverlap) {\n // outputs string indicating which condition occurred. ex: 0,1,0\n const debugInfo = `${+neitherSeqHasRange},${+currentUniqOverlap},${+incomingUniqOverlap}`;\n\n // send DESYNC to server\n comparison = `${Parser.loci.DESYNC}:OOS001:${debugInfo}`;\n } else if (currentUniqueMin > incomingUniqueMin) {\n // choose left side (current)\n comparison = `${Parser.loci.GT}:OOS002`;\n } else {\n // choose right side (incoming)\n comparison = `${Parser.loci.LT}:OOS003`;\n }\n\n return comparison;\n }\n\n /**\n * Compares two loci to determine which one contains the most recent state\n * @instance\n * @memberof Locus\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @returns {string} loci comparison state\n */\n static compare(current, incoming) {\n const {isSequenceEmpty} = Parser;\n const {extractComparisonState: extract} = Parser;\n const {packComparisonResult: pack} = Parser;\n\n if (isSequenceEmpty(current) || isSequenceEmpty(incoming)) {\n return pack(Parser.loci.USE_INCOMING, 'C001');\n }\n\n if (incoming.baseSequence) {\n return pack(Parser.compareDelta(current, incoming), 'C002');\n }\n\n const result = Parser.compareSequence(current.sequence, incoming.sequence);\n const action = Parser.compareToAction(extract(result));\n\n return pack(action, result);\n }\n\n /**\n * Compares two loci sequences (with delta params) and indicates what action\n * to take.\n * @instance\n * @memberof Locus\n * @param {Types~Locus} current\n * @param {Types~Locus} incoming\n * @private\n * @returns {string} loci comparison state\n */\n private static compareDelta(current, incoming) {\n const {LT, GT, EQ, DESYNC, USE_INCOMING, WAIT, LOCUS_URL_CHANGED} = Parser.loci;\n\n const {extractComparisonState: extract} = Parser;\n const {packComparisonResult: pack} = Parser;\n\n const result = Parser.compareSequence(current.sequence, incoming.sequence);\n let comparison = extract(result);\n\n if (comparison !== LT) {\n return pack(Parser.compareToAction(comparison), result);\n }\n\n if (incoming.url !== current.url) {\n // when moving to/from a breakout session, the locus URL will change and also\n // the baseSequence, making incoming and current incomparable, so use a\n // unique comparison state\n return pack(LOCUS_URL_CHANGED, result);\n }\n\n comparison = Parser.compareSequence(current.sequence, incoming.baseSequence);\n\n switch (extract(comparison)) {\n case GT:\n case EQ:\n comparison = USE_INCOMING;\n break;\n\n case LT:\n if (extract(Parser.compareSequence(incoming.baseSequence, incoming.sequence)) === EQ) {\n // special case where Locus sends a delta with baseSequence === sequence to trigger a sync,\n // because the delta event is too large to be sent over mercury connection\n comparison = DESYNC;\n } else {\n // the incoming locus has baseSequence from the future, so it is out-of-order,\n // we are missing 1 or more locus that should be in front of it, we need to wait for it\n comparison = WAIT;\n\n Metrics.sendBehavioralMetric(BEHAVIORAL_METRICS.LOCUS_DELTA_OUT_OF_ORDER, {\n stack: new Error().stack,\n });\n }\n break;\n default:\n comparison = DESYNC;\n }\n\n return pack(comparison, result);\n }\n\n /**\n * Compares Locus sequences - it should be called only for full Locus DTOs, not deltas\n *\n * @param {Types~Locus} current Current working copy\n * @param {Types~Locus} incomingFullDto New Full Locus DTO\n * @returns {string} either Parser.loci.USE_INCOMING or Parser.loci.USE_CURRENT\n */\n static compareFullDtoSequence(current, incomingFullDto) {\n if (Parser.isSequenceEmpty(current) || Parser.isSequenceEmpty(incomingFullDto)) {\n return Parser.loci.USE_INCOMING;\n }\n\n // the sequence.entries list will always contain at least 1 entry\n // https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Sequence-Comparison-Algorithm\n\n return incomingFullDto.sequence.entries.slice(-1)[0] > current.sequence.entries.slice(-1)[0]\n ? Parser.loci.USE_INCOMING\n : Parser.loci.USE_CURRENT;\n }\n\n /**\n * Returns true if the incoming full locus DTO is newer than the current working copy\n *\n * @param {Types~Locus} incomingFullDto New Full Locus DTO\n * @returns {string} either Parser.loci.USE_INCOMING or Parser.loci.USE_CURRENT\n */\n isNewFullLocus(incomingFullDto) {\n if (!Parser.isLoci(incomingFullDto)) {\n LoggerProxy.logger.info('Locus-info:parser#isNewFullLocus --> Ignoring non-locus object.');\n\n return false;\n }\n\n if (!this.workingCopy) {\n // we don't have a working copy yet, so any full locus is better than nothing\n return true;\n }\n\n const comparisonResult = Parser.compareFullDtoSequence(this.workingCopy, incomingFullDto);\n\n return comparisonResult === Parser.loci.USE_INCOMING;\n }\n\n /**\n * Compares Locus sequences\n * @param {Types~Locus} current Current working copy\n * @param {Types~Locus} incoming New Locus delta\n * @returns {string}\n */\n static compareSequence(current, incoming) {\n // Locus sequence comparison rules in order of priority.\n // https://sqbu-github.cisco.com/WebExSquared/cloud-apps/wiki/Locus-Sequence-Comparison-Algorithm\n\n const local: any = Parser.getMetaData(current);\n const delta: any = Parser.getMetaData(incoming);\n\n // update loci metadata\n local.unique = Parser.getUniqueSequences(local, delta);\n delta.unique = Parser.getUniqueSequences(delta, local);\n\n // Locus sequence comparison rules\n // order matters\n const rules = [\n Parser.checkSequenceOverlap,\n Parser.checkUnequalRanges,\n Parser.checkForUniqueEntries,\n Parser.checkIfOutOfSync,\n ];\n\n for (const rule of rules) {\n // Rule only returns a value if the rule applies,\n // otherwise returns null.\n const result = rule(local, delta);\n\n if (result) {\n return result;\n }\n }\n\n // error, none of rules above applied\n // should never get here as last rule\n // should be catch all.\n return Parser.loci.ERROR;\n }\n\n /**\n * Transates the result of a sequence comparison into an intended behavior\n * @param {string} result\n * @returns {string} Locus comparison action\n */\n static compareToAction(result: string) {\n const {DESYNC, EQ, ERROR, GT, LT, USE_CURRENT, USE_INCOMING} = Parser.loci;\n\n let action = ERROR;\n\n switch (result) {\n case EQ:\n case GT:\n action = USE_CURRENT;\n break;\n case LT:\n action = USE_INCOMING;\n break;\n case DESYNC:\n action = DESYNC;\n break;\n default:\n LoggerProxy.logger.info(\n `Locus-info:parser#compareToAction --> Error: ${result} is not a recognized sequence comparison result.`\n );\n }\n\n return action;\n }\n\n /**\n * Extracts a loci comparison from a string of data.\n * @param {string} lociComparisonResult Comparison result with extra data\n * @returns {string} Comparison of EQ, LT, GT, or DESYNC.\n */\n static extractComparisonState(lociComparisonResult: string) {\n return lociComparisonResult.split(':')[0];\n }\n\n /**\n * @typedef {object} LociMetadata\n * @property {number} start - Starting sequence number\n * @property {number} end - Ending sequence number\n * @property {number} first - First sequence number\n * @property {number} last - Last sequence number\n * @property {number} min - Minimum sequence number\n * @property {number} max - Maximum sequence number\n * @property {number} entries - Loci sequence entries\n */\n\n /**\n * Metadata for Locus delta\n * @param {Array.<number>} sequence Locus delta sequence\n * @returns {LociMetadata} Locus Delta Metadata\n */\n static getMetaData(sequence: any) {\n const {entries} = sequence;\n const first = entries[0];\n const last = entries.slice(-1)[0];\n\n // rangeStart or rangeEnd is 0 if a range doesn't exist\n const start = sequence.rangeStart;\n const end = sequence.rangeEnd;\n\n // sequence data\n return {\n start,\n end,\n first,\n last,\n // Rule is: rangeStart <= rangeEnd <= min(entries)\n min: start || first,\n // Grab last entry if exist else default to rangeEnd\n max: last || end,\n // keep reference to actual sequence entries\n entries,\n };\n }\n\n /**\n * Compares two Locus delta objects and notes unique\n * values contained within baseLoci.\n * @param {LociMetadata} baseLoci\n * @param {LociMetadata} otherLoci\n * @returns {Array.<number>} List of unique sequences\n */\n static getUniqueSequences(baseLoci: any, otherLoci: any) {\n const diff: any = difference(baseLoci.entries, otherLoci.entries);\n\n const {start, end} = otherLoci;\n\n return Parser.getNumbersOutOfRange(diff, start, end);\n }\n\n /**\n * Returns an array of numbers outside of a given range.\n * @param {Array.<number>} list Array to filter\n * @param {number} rangeStart Start of range\n * @param {number} rangeEnd End of range\n * @returns {Array.<number>} Array of numbers sorted ASC\n */\n static getNumbersOutOfRange(list: Array<number>, rangeStart: number, rangeEnd: number) {\n // Collect all numbers if number is outside of specified range\n const output = list.filter((num) => num < rangeStart || num > rangeEnd);\n\n // sort ascending\n return output.sort((a, b) => a - b);\n }\n\n /**\n * Checks if newLoci or workingCopy is invalid.\n * @param {Types~Locus} newLoci\n * @returns {boolean}\n */\n isValidLocus(newLoci) {\n let isValid = false;\n const {isLoci} = Parser;\n\n // one or both objects are not locus delta events\n if (!isLoci(this.workingCopy) || !isLoci(newLoci)) {\n LoggerProxy.logger.info(\n 'Locus-info:parser#processDeltaEvent --> Ignoring non-locus object. workingCopy:',\n this.workingCopy,\n 'newLoci:',\n newLoci\n );\n } else {\n isValid = true;\n }\n\n return isValid;\n }\n\n /**\n * Determines if a paricular locus's sequence is empty\n * @param {Types~Locus} locus\n * @returns {bool}\n */\n static isSequenceEmpty(locus) {\n const {sequence} = locus;\n const hasEmptyEntries = !sequence.entries?.length;\n const hasEmptyRange = sequence.rangeStart === 0 && sequence.rangeEnd === 0;\n\n return hasEmptyEntries && hasEmptyRange;\n }\n\n /**\n * Determines if an object has basic\n * structure of a locus object.\n * @param {Types~Locus} loci\n * @returns {boolean}\n */\n static isLoci(loci) {\n if (!loci || !loci.sequence) {\n return false;\n }\n const hasProp = (prop) => Object.prototype.hasOwnProperty.call(loci.sequence, prop);\n\n if (hasProp('rangeStart') && hasProp('rangeEnd')) {\n return true;\n }\n\n return false;\n }\n\n /**\n * Processes next event in queue,\n * if queue is empty sets status to idle.\n * @returns {undefined}\n */\n nextEvent() {\n if (this.status === 'PAUSED') {\n LoggerProxy.logger.info('Locus-info:parser#nextEvent --> Locus parser paused.');\n\n return;\n }\n\n if (this.status === 'BLOCKED') {\n LoggerProxy.logger.info(\n 'Locus-info:parser#nextEvent --> Locus parser blocked by out-of-order delta.'\n );\n\n return;\n }\n\n // continue processing until queue is empty\n if (this.queue.size() > 0) {\n this.processDeltaEvent();\n } else {\n this.status = 'IDLE';\n }\n }\n\n /**\n * Function handler for delta actions,\n * is set by instance callee.\n * @param {string} action Locus delta action\n * @param {Types~Locus} locus Locus delta\n * @returns {undefined}\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n onDeltaAction(action: string, locus) {}\n\n /**\n * Event handler for locus delta events\n * @param {Types~Locus} loci Locus Delta\n * @returns {undefined}\n */\n onDeltaEvent(loci) {\n // enqueue the new loci\n this.queue.enqueue(loci);\n\n if (this.onDeltaAction) {\n if (this.status === 'BLOCKED') {\n if (this.queue.size() > MAX_OOO_DELTA_COUNT) {\n this.triggerSync('queue too big, blocked on out-of-order delta');\n } else {\n this.processDeltaEvent();\n }\n } else if (this.status === 'IDLE') {\n // Update status, ensure we only process one event at a time.\n this.status = 'WORKING';\n\n this.processDeltaEvent();\n }\n }\n }\n\n /**\n * Appends new data onto a string of existing data.\n * @param {string} newData\n * @param {string} oldData\n * @returns {string}\n */\n static packComparisonResult(newData: string, oldData: string) {\n return `${newData}:${oldData}`;\n }\n\n /**\n * Pause locus processing\n * @returns {undefined}\n */\n pause() {\n this.status = 'PAUSED';\n LoggerProxy.logger.info('Locus-info:parser#pause --> Locus parser paused.');\n }\n\n /**\n * Triggers a sync with Locus\n *\n * @param {string} reason used just for logging\n * @returns {undefined}\n */\n private triggerSync(reason: string) {\n LoggerProxy.logger.info(`Locus-info:parser#triggerSync --> doing sync, reason: ${reason}`);\n this.stopSyncTimer();\n this.pause();\n this.onDeltaAction(Parser.loci.DESYNC, this.workingCopy);\n }\n\n /**\n * Starts a timer with a random delay. When that timer expires we will do a sync.\n *\n * The main purpose of this timer is to handle a case when we get some out-of-order deltas,\n * so we start waiting to receive the missing delta. If that delta never arrives, this timer\n * will trigger a sync with Locus.\n *\n * @returns {undefined}\n */\n private startSyncTimer() {\n if (this.syncTimer === undefined) {\n const timeout = OOO_DELTA_WAIT_TIME + Math.random() * OOO_DELTA_WAIT_TIME_RANDOM_DELAY;\n\n this.syncTimer = setTimeout(() => {\n this.syncTimer = undefined;\n this.triggerSync('timer expired, blocked on out-of-order delta');\n }, timeout);\n }\n }\n\n /**\n * Stops the timer for triggering a sync\n *\n * @returns {undefined}\n */\n private stopSyncTimer() {\n if (this.syncTimer !== undefined) {\n clearTimeout(this.syncTimer);\n this.syncTimer = undefined;\n }\n }\n\n /**\n * Processes next locus delta in the queue,\n * continues until the queue is empty\n * or cleared.\n * @returns {undefined}\n */\n processDeltaEvent() {\n const {DESYNC, USE_INCOMING, WAIT, LOCUS_URL_CHANGED} = Parser.loci;\n const {extractComparisonState: extract} = Parser;\n const newLoci = this.queue.dequeue();\n\n if (!this.isValidLocus(newLoci)) {\n this.nextEvent();\n\n return;\n }\n\n const result = Parser.compare(this.workingCopy, newLoci);\n const lociComparison = extract(result);\n\n // limited debugging, use chrome extension\n // for full debugging.\n LoggerProxy.logger.debug(`Locus-info:parser#processDeltaEvent --> Locus Debug: ${result}`);\n\n let needToWait = false;\n\n switch (lociComparison) {\n case DESYNC:\n // wait for desync response\n this.pause();\n break;\n\n case USE_INCOMING:\n case LOCUS_URL_CHANGED:\n // update working copy for future comparisons.\n // Note: The working copy of parser gets updated in .onFullLocus()\n // and here when USE_INCOMING or LOCUS_URL_CHANGED locus.\n this.workingCopy = newLoci;\n break;\n\n case WAIT:\n // we've taken newLoci from the front of the queue, so put it back there as we have to wait\n // for the one that should be in front of it, before we can process it\n this.queue.enqueue(newLoci);\n needToWait = true;\n break;\n\n default:\n break;\n }\n\n if (needToWait) {\n this.status = 'BLOCKED';\n this.startSyncTimer();\n } else {\n this.stopSyncTimer();\n\n if (this.status === 'BLOCKED') {\n // we are not blocked anymore\n this.status = 'WORKING';\n\n LoggerProxy.logger.info(\n `Locus-info:parser#processDeltaEvent --> received delta that we were waiting for ${Parser.locus2string(\n newLoci\n )}, not blocked anymore`\n );\n }\n }\n\n if (this.onDeltaAction) {\n LoggerProxy.logger.info(\n `Locus-info:parser#processDeltaEvent --> Locus Delta ${Parser.locus2string(\n newLoci\n )}, Action: ${lociComparison}`\n );\n\n this.onDeltaAction(lociComparison, newLoci);\n }\n\n this.nextEvent();\n }\n\n /**\n * Resume from a paused state\n * @returns {undefined}\n */\n resume() {\n LoggerProxy.logger.info('Locus-info:parser#resume --> Locus parser resumed.');\n this.status = 'WORKING';\n this.nextEvent();\n }\n\n /**\n * Gets related debug info for given error code\n * @param {string} debugCode Debug code\n * @param {string} comparison Locus comparison string\n * @returns {object} Debug message\n */\n static getDebugMessage(debugCode: string, comparison: string) {\n // removes extra spaces from multiline string\n const mStr = (strings) => strings.join('').replace(/\\s{2,}/g, ' ');\n\n const resolutionMap = {\n EQ: `${Parser.loci.LT}: is equal (current == incoming).`,\n LT: `${Parser.loci.LT}: choose right side (incoming).`,\n GT: `${Parser.loci.GT}: choose left side (current).`,\n };\n\n const debugMap = {\n SO001: {\n title: 'checkSequenceOverlap-001',\n description: mStr`Occurs if earliest working copy sequence is more \\\n recent than last incoming sequence.`,\n logic: 'current.min > incoming.max',\n },\n\n SO002: {\n title: 'checkSequenceOverlap-002',\n description: mStr`Occurs if last working copy sequence is before the \\\n earliest incoming sequence.`,\n logic: 'current.max < incoming.min',\n },\n\n UR001: {\n title: 'checkUnequalRanges-001',\n description: mStr`Occurs if there are no unique values for both loci, \\\n and the current working copy loci has a larger range.`,\n logic: 'currentTotalRange > incomingTotalRange',\n },\n\n UR002: {\n title: 'checkUnequalRanges-002',\n description: mStr`Occurs if there are no unique values for both loci, \\\n and the incoming delta loci has a larger range.`,\n logic: 'currentTotalRange < incomingTotalRange',\n },\n\n UR003: {\n title: 'checkUnequalRanges-003',\n description: mStr`Occurs if there are no unique values for both loci, \\\n and with ranges either absent or of the same size, the sequences \\\n are considered equal.`,\n logic: 'currentTotalRange == incomingTotalRange',\n },\n\n UE001: {\n title: 'checkForUniqueEntries-001',\n description: mStr`Occurs if current loci has unique entries and \\\n incoming does not. Entries are considered unique if they \\\n do not overlap with other Loci sequences or range values.`,\n logic: 'currentIsUnique && !incomingIsUnique',\n },\n\n UE002: {\n title: 'checkForUniqueEntries-002',\n description: mStr`Occurs if current has no unique entries but \\\n incoming does. Entries are considered unique if they \\\n do not overlap with other Loci sequences or range values.`,\n logic: '!currentIsUnique && incomingIsUnique',\n },\n\n OOS001: {\n title: 'checkIfOutOfSync-001',\n description: mStr`Occurs if neither sequence has a range, or \\\n if the current loci unique entries overlap the total range of the \\\n incoming sequence, or if the incoming unique entries overlap \\\n the total range of current sequence.`,\n logic: 'neitherSeqHasRange || currentUniqOverlap || incomingUniqOverlap',\n },\n\n OOS002: {\n title: 'checkIfOutOfSync-002',\n description: mStr`Occurs if the minimum value from sequences that are \\\n unique to the current loci is greater than the minimum value from \\\n sequences that are unique to the incoming loci.`,\n logic: 'currentUniqueMin > incomingUniqueMin',\n },\n\n OOS003: {\n title: 'checkIfOutOfSync-003',\n description: mStr`Occurs if none of the comparison rules applied. \\\n It is a catch all.`,\n logic: 'else (catch all)',\n },\n };\n\n const debugObj = debugMap[debugCode];\n\n debugObj.title = `Debug: ${debugObj.title}`;\n debugObj.resolution = resolutionMap[comparison];\n\n return debugObj;\n }\n}\n"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ declare const SelfUtils: any;
2
+ export default SelfUtils;
@@ -0,0 +1,34 @@
1
+ /*!
2
+ * Copyright (c) 2015-2020 Cisco Systems, Inc. See LICENSE file.
3
+ */
4
+ import { type MultistreamConnectionConfig } from '@webex/internal-media-core';
5
+ export type BundlePolicy = MultistreamConnectionConfig['bundlePolicy'];
6
+ /**
7
+ * MediaDirection
8
+ * @typedef {Object} MediaDirection
9
+ * @property {boolean} sendAudio
10
+ * @property {boolean} receiveAudio
11
+ * @property {boolean} sendVideo
12
+ * @property {boolean} receiveVideo
13
+ * @property {boolean} sendShare
14
+ * @property {boolean} receiveShare
15
+ */
16
+ /**
17
+ * SendOptions
18
+ * @typedef {Object} SendOptions
19
+ * @property sendAudio
20
+ * @property sendVideo
21
+ * @property sendShare
22
+ * @property isSharing
23
+ * @property {Object} sharePreferences
24
+ */
25
+ /**
26
+ *
27
+ * @public
28
+ * @export
29
+ * Mimic browser APIs as "the ultimate browser".
30
+ * Handles the quirks of each browser.
31
+ * Extends and enhances adapter.js, i.e., the "media" file from the web client.
32
+ */
33
+ declare const Media: any;
34
+ export default Media;
@@ -112,6 +112,7 @@ Media.getDirection = function (forceSendRecv, receive, send) {
112
112
  * @returns {RoapMediaConnection | MultistreamRoapMediaConnection}
113
113
  */
114
114
  Media.createMediaConnection = function (isMultistream, debugId, webex, meetingId, correlationId, options) {
115
+ var _audioStream$outputSt, _videoStream$outputSt, _shareVideoStream$out, _shareAudioStream$out;
115
116
  var mediaProperties = options.mediaProperties,
116
117
  remoteQualityLevel = options.remoteQualityLevel,
117
118
  enableRtx = options.enableRtx,
@@ -171,10 +172,10 @@ Media.createMediaConnection = function (isMultistream, debugId, webex, meetingId
171
172
  }, {
172
173
  // TODO: RoapMediaConnection is not ready to use stream classes yet, so we pass the raw MediaStreamTrack for now SPARK-460530
173
174
  localTracks: {
174
- audio: audioStream === null || audioStream === void 0 ? void 0 : audioStream.outputTrack,
175
- video: videoStream === null || videoStream === void 0 ? void 0 : videoStream.outputTrack,
176
- screenShareVideo: shareVideoStream === null || shareVideoStream === void 0 ? void 0 : shareVideoStream.outputTrack,
177
- screenShareAudio: shareAudioStream === null || shareAudioStream === void 0 ? void 0 : shareAudioStream.outputTrack // TODO: add type for screenShareAudio in internal-media-core SPARK-446923
175
+ audio: audioStream === null || audioStream === void 0 ? void 0 : (_audioStream$outputSt = audioStream.outputStream) === null || _audioStream$outputSt === void 0 ? void 0 : _audioStream$outputSt.getTracks()[0],
176
+ video: videoStream === null || videoStream === void 0 ? void 0 : (_videoStream$outputSt = videoStream.outputStream) === null || _videoStream$outputSt === void 0 ? void 0 : _videoStream$outputSt.getTracks()[0],
177
+ screenShareVideo: shareVideoStream === null || shareVideoStream === void 0 ? void 0 : (_shareVideoStream$out = shareVideoStream.outputStream) === null || _shareVideoStream$out === void 0 ? void 0 : _shareVideoStream$out.getTracks()[0],
178
+ screenShareAudio: shareAudioStream === null || shareAudioStream === void 0 ? void 0 : (_shareAudioStream$out = shareAudioStream.outputStream) === null || _shareAudioStream$out === void 0 ? void 0 : _shareAudioStream$out.getTracks()[0] // TODO: add type for screenShareAudio in internal-media-core SPARK-446923
178
179
  },
179
180
 
180
181
  direction: {
@@ -335,7 +336,7 @@ Media.stopStream = function (stream) {
335
336
  try {
336
337
  stream.stop();
337
338
  } catch (e) {
338
- _loggerProxy.default.logger.error("Media:index#stopStream --> Unable to stop the stream with ready state of the output track => ".concat(stream.outputTrack.readyState, " & input track => ").concat(stream.inputTrack.readyState, ", error: ").concat(e));
339
+ _loggerProxy.default.logger.error("Media:index#stopStream --> Unable to stop the stream with ready state => ".concat(stream.readyState, ", error: ").concat(e));
339
340
  }
340
341
  });
341
342
  };