@splitsoftware/splitio 10.17.3-rc.2 → 10.17.3

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 (759) hide show
  1. package/CHANGES.txt +4 -0
  2. package/es/client/attributesDecoration.js +116 -0
  3. package/es/client/browser.js +39 -0
  4. package/es/client/client.js +155 -0
  5. package/es/client/inputValidation.js +117 -0
  6. package/es/client/node.js +6 -0
  7. package/es/{factory → client}/package.json +0 -0
  8. package/es/engine/combiners/and.js +54 -0
  9. package/es/engine/combiners/ifelseif.js +73 -0
  10. package/es/engine/condition/index.js +62 -0
  11. package/es/engine/convertions/index.js +29 -0
  12. package/es/engine/engine/index.js +60 -0
  13. package/es/engine/engine/legacy.js +77 -0
  14. package/es/engine/engine/murmur3/common.js +40 -0
  15. package/es/engine/engine/murmur3/murmur3.js +83 -0
  16. package/es/engine/engine/murmur3/murmur3_128.js +250 -0
  17. package/es/engine/engine/murmur3/murmur3_128_x86.js +183 -0
  18. package/es/engine/engine/murmur3/murmur3_64.js +52 -0
  19. package/es/engine/engine/murmur3/utfx.js +112 -0
  20. package/es/engine/evaluator/index.js +111 -0
  21. package/es/engine/index.js +112 -0
  22. package/es/engine/matchers/all.js +32 -0
  23. package/es/engine/matchers/between.js +35 -0
  24. package/es/engine/matchers/boolean.js +35 -0
  25. package/es/engine/matchers/cont_all.js +51 -0
  26. package/es/engine/matchers/cont_any.js +47 -0
  27. package/es/engine/matchers/cont_str.js +38 -0
  28. package/es/engine/matchers/dependency.js +50 -0
  29. package/es/engine/matchers/eq.js +35 -0
  30. package/es/engine/matchers/eq_set.js +49 -0
  31. package/es/engine/matchers/ew.js +38 -0
  32. package/es/engine/matchers/gte.js +35 -0
  33. package/es/engine/matchers/index.js +65 -0
  34. package/es/engine/matchers/lte.js +35 -0
  35. package/es/engine/matchers/part_of.js +49 -0
  36. package/es/engine/matchers/segment.js +39 -0
  37. package/es/engine/matchers/string.js +44 -0
  38. package/es/engine/matchers/sw.js +38 -0
  39. package/es/engine/matchers/types.js +48 -0
  40. package/es/engine/matchers/whitelist.js +36 -0
  41. package/es/engine/parser/index.js +69 -0
  42. package/es/engine/parser/segments.js +22 -0
  43. package/es/engine/transforms/matcherGroup.js +43 -0
  44. package/es/engine/transforms/matchers.js +109 -0
  45. package/es/engine/transforms/segment.js +28 -0
  46. package/es/engine/transforms/set.js +20 -0
  47. package/es/engine/transforms/unaryNumeric.js +20 -0
  48. package/es/engine/transforms/whitelist.js +22 -0
  49. package/es/engine/treatments/index.js +67 -0
  50. package/es/engine/value/index.js +54 -0
  51. package/es/engine/value/sanitize.js +125 -0
  52. package/es/events/index.js +65 -0
  53. package/es/factory/offline.js +50 -0
  54. package/es/factory/online.js +113 -0
  55. package/es/impressions/counter.js +52 -0
  56. package/es/impressions/hasher/buildKey.js +3 -0
  57. package/es/impressions/hasher/hashImpression128.js +5 -0
  58. package/es/impressions/hasher/hashImpression32.js +5 -0
  59. package/es/impressions/observer/browser.js +9 -0
  60. package/es/impressions/observer/node.js +9 -0
  61. package/es/impressions/observer/observer.js +21 -0
  62. package/es/{platform/getEventSource → impressions/observer}/package.json +0 -0
  63. package/es/index.js +132 -1
  64. package/es/integrations/browser.js +62 -0
  65. package/es/integrations/ga/GaToSplit.js +246 -0
  66. package/es/integrations/ga/SplitToGa.js +127 -0
  67. package/es/integrations/node.js +3 -0
  68. package/es/{platform/getFetch → integrations}/package.json +0 -0
  69. package/es/listeners/browser.js +157 -0
  70. package/es/listeners/node.js +65 -0
  71. package/es/{platform → listeners}/package.json +0 -0
  72. package/es/manager/index.js +104 -0
  73. package/es/metrics/Collectors.js +100 -0
  74. package/es/metrics/index.js +157 -0
  75. package/es/producer/browser/Partial.js +103 -0
  76. package/es/producer/browser.js +70 -0
  77. package/es/producer/fetcher/MySegments.js +47 -0
  78. package/es/producer/fetcher/SegmentChanges.js +52 -0
  79. package/es/producer/fetcher/SplitChanges.js +46 -0
  80. package/es/producer/node.js +130 -0
  81. package/es/producer/offline/browser.js +26 -0
  82. package/es/producer/offline/node.js +26 -0
  83. package/es/{settings → producer/offline}/package.json +0 -0
  84. package/{lib/factory → es/producer}/package.json +0 -0
  85. package/es/producer/task.js +50 -0
  86. package/es/producer/updater/MySegments.js +108 -0
  87. package/es/producer/updater/SegmentChanges.js +135 -0
  88. package/es/producer/updater/SplitChanges.js +131 -0
  89. package/es/producer/updater/SplitChangesFromFeatures.js +21 -0
  90. package/es/producer/updater/SplitChangesFromFileSystem.js +21 -0
  91. package/es/producer/updater/SplitChangesFromObject.js +73 -0
  92. package/es/readiness/index.js +123 -0
  93. package/es/readiness/statusManager.js +114 -0
  94. package/es/services/auth/auth.js +25 -0
  95. package/es/services/auth/index.js +2 -0
  96. package/es/services/events/bulk.js +22 -0
  97. package/es/services/events/index.js +17 -0
  98. package/{src/platform → es/services}/getEventSource/browser.js +2 -2
  99. package/es/{platform → services}/getEventSource/node.js +1 -1
  100. package/{lib/platform → es/services}/getEventSource/package.json +0 -0
  101. package/es/{platform → services}/getFetch/browser.js +1 -1
  102. package/es/{platform → services}/getFetch/node.js +1 -1
  103. package/{lib/platform → es/services}/getFetch/package.json +0 -0
  104. package/es/services/impressions/bulk.js +26 -0
  105. package/es/services/impressions/count.js +7 -0
  106. package/es/services/impressions/dto.js +73 -0
  107. package/es/services/impressions/index.js +17 -0
  108. package/es/services/impressions/post.js +22 -0
  109. package/es/services/metrics/counters.js +24 -0
  110. package/es/services/metrics/dto.js +38 -0
  111. package/es/services/metrics/index.js +17 -0
  112. package/es/services/metrics/times.js +24 -0
  113. package/es/services/mySegments/get.js +26 -0
  114. package/es/services/mySegments/index.js +17 -0
  115. package/es/services/request/index.js +43 -0
  116. package/es/services/request/options/browser.js +18 -0
  117. package/es/{platform → services}/request/options/node.js +2 -2
  118. package/{lib/platform → es/services/request/options}/package.json +0 -0
  119. package/es/services/segmentChanges/get.js +21 -0
  120. package/es/services/segmentChanges/index.js +17 -0
  121. package/es/services/splitChanges/get.js +19 -0
  122. package/es/services/splitChanges/index.js +17 -0
  123. package/es/services/splitChanges/offline/browser.js +63 -0
  124. package/es/services/splitChanges/offline/node.js +176 -0
  125. package/{lib/settings → es/services/splitChanges/offline}/package.json +0 -0
  126. package/es/services/splitChanges/offline/parseCondition.js +43 -0
  127. package/es/services/transport/index.js +51 -0
  128. package/es/storage/AttributesCache/InMemory.js +85 -0
  129. package/es/storage/BaseMetricsAsyncCache.js +23 -0
  130. package/es/storage/CountCache/InMemory.js +48 -0
  131. package/es/storage/CountCache/InRedis.js +42 -0
  132. package/es/storage/EventsCache/InMemory.js +109 -0
  133. package/es/storage/EventsCache/InRedis.js +65 -0
  134. package/es/storage/ImpressionsCache/InMemory.js +71 -0
  135. package/es/storage/ImpressionsCache/InRedis.js +73 -0
  136. package/es/storage/Keys.js +125 -0
  137. package/es/storage/KeysLocalStorage.js +58 -0
  138. package/es/storage/LatencyCache/InMemory.js +56 -0
  139. package/es/storage/LatencyCache/InRedis.js +44 -0
  140. package/es/storage/LatencyCache/findIndex.js +2 -0
  141. package/es/storage/Meta.js +7 -0
  142. package/es/storage/RedisAdapter.js +198 -0
  143. package/es/storage/SegmentCache/InLocalStorage/index.js +162 -0
  144. package/es/storage/SegmentCache/InMemory/browser.js +107 -0
  145. package/es/storage/SegmentCache/InMemory/node.js +82 -0
  146. package/{src/factory → es/storage/SegmentCache/InMemory}/package.json +0 -0
  147. package/es/storage/SegmentCache/InRedis/index.js +81 -0
  148. package/es/storage/SplitCache/InLocalStorage.js +332 -0
  149. package/es/storage/SplitCache/InMemory.js +162 -0
  150. package/es/storage/SplitCache/InRedis.js +214 -0
  151. package/es/storage/SplitCache/killLocally.js +35 -0
  152. package/es/storage/browser.js +101 -0
  153. package/es/storage/node.js +81 -0
  154. package/{src/platform/getEventSource → es/storage}/package.json +0 -0
  155. package/es/sync/AuthClient/index.js +34 -0
  156. package/es/sync/PushManager/index.js +315 -0
  157. package/es/sync/PushManager/mySegmentsV2utils.js +76 -0
  158. package/es/sync/PushManager/pushRequirements/browser.js +23 -0
  159. package/es/sync/PushManager/pushRequirements/node.js +18 -0
  160. package/{src/platform/getFetch → es/sync/PushManager/pushRequirements}/package.json +0 -0
  161. package/es/sync/SSEClient/index.js +93 -0
  162. package/es/sync/SSEHandler/NotificationKeeper.js +97 -0
  163. package/es/sync/SSEHandler/NotificationParser.js +31 -0
  164. package/es/sync/SSEHandler/index.js +110 -0
  165. package/es/sync/SegmentUpdateWorker/browser.js +74 -0
  166. package/es/sync/SegmentUpdateWorker/node.js +79 -0
  167. package/{src/platform → es/sync/SegmentUpdateWorker}/package.json +0 -0
  168. package/es/sync/SplitUpdateWorker/index.js +86 -0
  169. package/es/sync/browser.js +125 -0
  170. package/es/sync/constants.js +42 -0
  171. package/es/sync/node.js +60 -0
  172. package/{src/settings → es/sync}/package.json +0 -0
  173. package/es/trackers/event.js +53 -0
  174. package/es/trackers/impressions.js +132 -0
  175. package/es/umd.js +1 -2
  176. package/es/utils/backoff/index.js +51 -0
  177. package/es/utils/base64/browser.js +19 -0
  178. package/es/utils/base64/node.js +19 -0
  179. package/es/utils/base64/package.json +4 -0
  180. package/es/utils/binarySearch/index.js +50 -0
  181. package/es/utils/constants/index.js +38 -0
  182. package/es/utils/context/constants.js +30 -0
  183. package/es/utils/context/index.js +101 -0
  184. package/es/utils/decompress/index.js +476 -0
  185. package/es/utils/fn/repeat.js +58 -0
  186. package/es/utils/inputValidation/apiKey.js +39 -0
  187. package/es/utils/inputValidation/attribute.js +22 -0
  188. package/es/utils/inputValidation/attributes.js +19 -0
  189. package/es/utils/inputValidation/event.js +23 -0
  190. package/es/utils/inputValidation/eventProperties.js +69 -0
  191. package/es/utils/inputValidation/eventValue.js +9 -0
  192. package/es/utils/inputValidation/index.js +11 -0
  193. package/es/utils/inputValidation/isOperational.js +14 -0
  194. package/es/utils/inputValidation/key.js +50 -0
  195. package/es/utils/inputValidation/split.js +47 -0
  196. package/es/utils/inputValidation/splitFilters.js +121 -0
  197. package/es/utils/inputValidation/splits.js +27 -0
  198. package/es/utils/inputValidation/trafficType.js +55 -0
  199. package/es/utils/jwt/hashUserKey.js +11 -0
  200. package/es/utils/jwt/index.js +14 -0
  201. package/es/utils/key/factory.js +38 -0
  202. package/es/utils/key/parser.js +34 -0
  203. package/es/utils/labels/index.js +7 -0
  204. package/es/utils/lang/Errors.js +41 -0
  205. package/es/utils/lang/Sets.js +114 -0
  206. package/es/utils/lang/index.js +305 -0
  207. package/es/utils/localstorage/isAvailable.js +26 -0
  208. package/es/utils/logger/LoggerFactory.js +86 -0
  209. package/es/utils/logger/index.js +97 -0
  210. package/es/utils/lrucache/linkedlist.js +122 -0
  211. package/es/utils/lrucache/lru.spec.js +24 -0
  212. package/es/utils/lrucache/lrucache.js +80 -0
  213. package/es/utils/now/browser.js +27 -0
  214. package/es/utils/now/node.js +19 -0
  215. package/es/utils/now/package.json +4 -0
  216. package/es/utils/promise/thenable.js +3 -0
  217. package/es/utils/promise/timeout.js +34 -0
  218. package/es/utils/promise/wrapper.js +58 -0
  219. package/es/{settings → utils/settings}/defaults/browser.js +2 -5
  220. package/es/{settings → utils/settings}/defaults/node.js +2 -5
  221. package/es/utils/settings/defaults/package.json +4 -0
  222. package/es/utils/settings/impressionsMode.js +16 -0
  223. package/es/utils/settings/index.js +194 -0
  224. package/es/utils/settings/integrations/browser.js +8 -0
  225. package/es/utils/settings/integrations/common.js +30 -0
  226. package/es/utils/settings/integrations/node.js +7 -0
  227. package/es/utils/settings/integrations/package.json +4 -0
  228. package/es/utils/settings/language/browser.js +16 -0
  229. package/es/utils/settings/language/node.js +16 -0
  230. package/es/utils/settings/language/package.json +4 -0
  231. package/es/utils/settings/mode.js +10 -0
  232. package/es/utils/settings/runtime/browser.js +21 -0
  233. package/es/{settings → utils/settings}/runtime/node.js +4 -6
  234. package/es/utils/settings/runtime/package.json +4 -0
  235. package/es/{settings → utils/settings}/storage/browser.js +17 -16
  236. package/es/{settings → utils/settings}/storage/node.js +16 -25
  237. package/es/utils/settings/storage/package.json +4 -0
  238. package/es/utils/splits/usesSegments.js +21 -0
  239. package/es/utils/time/index.js +8 -0
  240. package/es/utils/timeTracker/index.js +216 -0
  241. package/es/utils/timeTracker/timer.js +25 -0
  242. package/lib/client/attributesDecoration.js +128 -0
  243. package/lib/client/browser.js +50 -0
  244. package/lib/client/client.js +174 -0
  245. package/lib/client/inputValidation.js +129 -0
  246. package/lib/client/node.js +14 -0
  247. package/lib/client/package.json +4 -0
  248. package/lib/engine/combiners/and.js +65 -0
  249. package/lib/engine/combiners/ifelseif.js +88 -0
  250. package/lib/engine/condition/index.js +76 -0
  251. package/lib/engine/convertions/index.js +36 -0
  252. package/lib/engine/engine/index.js +71 -0
  253. package/lib/engine/engine/legacy.js +83 -0
  254. package/lib/engine/engine/murmur3/common.js +52 -0
  255. package/lib/engine/engine/murmur3/murmur3.js +90 -0
  256. package/lib/engine/engine/murmur3/murmur3_128.js +256 -0
  257. package/lib/engine/engine/murmur3/murmur3_128_x86.js +189 -0
  258. package/lib/engine/engine/murmur3/murmur3_64.js +57 -0
  259. package/lib/engine/engine/murmur3/utfx.js +121 -0
  260. package/lib/engine/evaluator/index.js +129 -0
  261. package/lib/engine/index.js +128 -0
  262. package/lib/engine/matchers/all.js +41 -0
  263. package/lib/engine/matchers/between.js +44 -0
  264. package/lib/engine/matchers/boolean.js +44 -0
  265. package/lib/engine/matchers/cont_all.js +61 -0
  266. package/lib/engine/matchers/cont_any.js +57 -0
  267. package/lib/engine/matchers/cont_str.js +48 -0
  268. package/lib/engine/matchers/dependency.js +60 -0
  269. package/lib/engine/matchers/eq.js +44 -0
  270. package/lib/engine/matchers/eq_set.js +59 -0
  271. package/lib/engine/matchers/ew.js +48 -0
  272. package/lib/engine/matchers/gte.js +44 -0
  273. package/lib/engine/matchers/index.js +90 -0
  274. package/lib/engine/matchers/lte.js +44 -0
  275. package/lib/engine/matchers/part_of.js +59 -0
  276. package/lib/engine/matchers/segment.js +49 -0
  277. package/lib/engine/matchers/string.js +53 -0
  278. package/lib/engine/matchers/sw.js +48 -0
  279. package/lib/engine/matchers/types.js +57 -0
  280. package/lib/engine/matchers/whitelist.js +46 -0
  281. package/lib/engine/parser/index.js +84 -0
  282. package/lib/engine/parser/segments.js +28 -0
  283. package/lib/engine/transforms/matcherGroup.js +54 -0
  284. package/lib/engine/transforms/matchers.js +124 -0
  285. package/lib/engine/transforms/segment.js +34 -0
  286. package/lib/engine/transforms/set.js +26 -0
  287. package/lib/engine/transforms/unaryNumeric.js +26 -0
  288. package/lib/engine/transforms/whitelist.js +28 -0
  289. package/lib/engine/treatments/index.js +73 -0
  290. package/lib/engine/value/index.js +64 -0
  291. package/lib/engine/value/sanitize.js +137 -0
  292. package/lib/events/index.js +80 -0
  293. package/lib/factory/offline.js +62 -0
  294. package/lib/factory/online.js +129 -0
  295. package/lib/impressions/counter.js +61 -0
  296. package/lib/impressions/hasher/buildKey.js +8 -0
  297. package/lib/impressions/hasher/hashImpression128.js +12 -0
  298. package/lib/impressions/hasher/hashImpression32.js +14 -0
  299. package/lib/impressions/observer/browser.js +19 -0
  300. package/lib/impressions/observer/node.js +19 -0
  301. package/lib/impressions/observer/observer.js +29 -0
  302. package/lib/impressions/observer/package.json +4 -0
  303. package/lib/index.js +151 -3
  304. package/lib/integrations/browser.js +72 -0
  305. package/lib/integrations/ga/GaToSplit.js +267 -0
  306. package/lib/integrations/ga/SplitToGa.js +138 -0
  307. package/lib/integrations/node.js +9 -0
  308. package/lib/integrations/package.json +4 -0
  309. package/lib/listeners/browser.js +173 -0
  310. package/lib/listeners/node.js +74 -0
  311. package/lib/listeners/package.json +4 -0
  312. package/lib/manager/index.js +115 -0
  313. package/lib/metrics/Collectors.js +118 -0
  314. package/lib/metrics/index.js +182 -0
  315. package/lib/producer/browser/Partial.js +114 -0
  316. package/lib/producer/browser.js +82 -0
  317. package/lib/producer/fetcher/MySegments.js +59 -0
  318. package/lib/producer/fetcher/SegmentChanges.js +62 -0
  319. package/lib/producer/fetcher/SplitChanges.js +58 -0
  320. package/lib/producer/node.js +142 -0
  321. package/lib/producer/offline/browser.js +35 -0
  322. package/lib/producer/offline/node.js +35 -0
  323. package/lib/producer/offline/package.json +4 -0
  324. package/lib/producer/package.json +4 -0
  325. package/lib/producer/task.js +61 -0
  326. package/lib/producer/updater/MySegments.js +119 -0
  327. package/lib/producer/updater/SegmentChanges.js +148 -0
  328. package/lib/producer/updater/SplitChanges.js +145 -0
  329. package/lib/producer/updater/SplitChangesFromFeatures.js +30 -0
  330. package/lib/producer/updater/SplitChangesFromFileSystem.js +30 -0
  331. package/lib/producer/updater/SplitChangesFromObject.js +84 -0
  332. package/lib/readiness/index.js +132 -0
  333. package/lib/readiness/statusManager.js +124 -0
  334. package/lib/services/auth/auth.js +32 -0
  335. package/lib/services/auth/index.js +11 -0
  336. package/lib/services/events/bulk.js +31 -0
  337. package/lib/services/events/index.js +26 -0
  338. package/lib/{platform → services}/getEventSource/browser.js +1 -1
  339. package/lib/{platform → services}/getEventSource/node.js +1 -1
  340. package/lib/services/getEventSource/package.json +4 -0
  341. package/lib/{platform → services}/getFetch/browser.js +1 -1
  342. package/lib/{platform → services}/getFetch/node.js +1 -1
  343. package/lib/services/getFetch/package.json +4 -0
  344. package/lib/services/impressions/bulk.js +36 -0
  345. package/lib/services/impressions/count.js +16 -0
  346. package/lib/services/impressions/dto.js +81 -0
  347. package/lib/services/impressions/index.js +26 -0
  348. package/lib/services/impressions/post.js +31 -0
  349. package/lib/services/metrics/counters.js +33 -0
  350. package/lib/services/metrics/dto.js +46 -0
  351. package/lib/services/metrics/index.js +26 -0
  352. package/lib/services/metrics/times.js +33 -0
  353. package/lib/services/mySegments/get.js +35 -0
  354. package/lib/services/mySegments/index.js +26 -0
  355. package/lib/services/request/index.js +53 -0
  356. package/lib/services/request/options/browser.js +23 -0
  357. package/lib/{platform → services}/request/options/node.js +2 -2
  358. package/lib/services/request/options/package.json +4 -0
  359. package/lib/services/segmentChanges/get.js +29 -0
  360. package/lib/services/segmentChanges/index.js +26 -0
  361. package/lib/services/splitChanges/get.js +27 -0
  362. package/lib/services/splitChanges/index.js +26 -0
  363. package/lib/services/splitChanges/offline/browser.js +71 -0
  364. package/lib/services/splitChanges/offline/node.js +189 -0
  365. package/lib/services/splitChanges/offline/package.json +4 -0
  366. package/lib/services/splitChanges/offline/parseCondition.js +49 -0
  367. package/lib/services/transport/index.js +62 -0
  368. package/lib/storage/AttributesCache/InMemory.js +93 -0
  369. package/lib/storage/BaseMetricsAsyncCache.js +28 -0
  370. package/lib/storage/CountCache/InMemory.js +54 -0
  371. package/lib/storage/CountCache/InRedis.js +50 -0
  372. package/lib/storage/EventsCache/InMemory.js +118 -0
  373. package/lib/storage/EventsCache/InRedis.js +74 -0
  374. package/lib/storage/ImpressionsCache/InMemory.js +77 -0
  375. package/lib/storage/ImpressionsCache/InRedis.js +79 -0
  376. package/lib/storage/Keys.js +132 -0
  377. package/lib/storage/KeysLocalStorage.js +69 -0
  378. package/lib/storage/LatencyCache/InMemory.js +64 -0
  379. package/lib/storage/LatencyCache/InRedis.js +53 -0
  380. package/lib/storage/LatencyCache/findIndex.js +12 -0
  381. package/lib/storage/Meta.js +12 -0
  382. package/lib/storage/RedisAdapter.js +212 -0
  383. package/lib/storage/SegmentCache/InLocalStorage/index.js +171 -0
  384. package/lib/storage/SegmentCache/InMemory/browser.js +113 -0
  385. package/lib/storage/SegmentCache/InMemory/node.js +89 -0
  386. package/lib/storage/SegmentCache/InMemory/package.json +4 -0
  387. package/lib/storage/SegmentCache/InRedis/index.js +87 -0
  388. package/lib/storage/SplitCache/InLocalStorage.js +344 -0
  389. package/lib/storage/SplitCache/InMemory.js +172 -0
  390. package/lib/storage/SplitCache/InRedis.js +224 -0
  391. package/lib/storage/SplitCache/killLocally.js +42 -0
  392. package/lib/storage/browser.js +122 -0
  393. package/lib/storage/node.js +104 -0
  394. package/lib/storage/package.json +4 -0
  395. package/lib/sync/AuthClient/index.js +44 -0
  396. package/lib/sync/PushManager/index.js +340 -0
  397. package/lib/sync/PushManager/mySegmentsV2utils.js +87 -0
  398. package/lib/sync/PushManager/pushRequirements/browser.js +30 -0
  399. package/lib/sync/PushManager/pushRequirements/node.js +25 -0
  400. package/lib/sync/PushManager/pushRequirements/package.json +4 -0
  401. package/lib/sync/SSEClient/index.js +101 -0
  402. package/lib/sync/SSEHandler/NotificationKeeper.js +104 -0
  403. package/lib/sync/SSEHandler/NotificationParser.js +39 -0
  404. package/lib/sync/SSEHandler/index.js +121 -0
  405. package/lib/sync/SegmentUpdateWorker/browser.js +81 -0
  406. package/lib/sync/SegmentUpdateWorker/node.js +86 -0
  407. package/lib/sync/SegmentUpdateWorker/package.json +4 -0
  408. package/lib/sync/SplitUpdateWorker/index.js +93 -0
  409. package/lib/sync/browser.js +139 -0
  410. package/lib/sync/constants.js +59 -0
  411. package/lib/sync/node.js +71 -0
  412. package/lib/sync/package.json +4 -0
  413. package/lib/trackers/event.js +64 -0
  414. package/lib/trackers/impressions.js +146 -0
  415. package/lib/umd.js +0 -1
  416. package/lib/utils/backoff/index.js +57 -0
  417. package/lib/utils/base64/browser.js +26 -0
  418. package/lib/utils/base64/node.js +26 -0
  419. package/lib/utils/base64/package.json +4 -0
  420. package/lib/utils/binarySearch/index.js +56 -0
  421. package/lib/utils/constants/index.js +60 -0
  422. package/lib/utils/context/constants.js +49 -0
  423. package/lib/utils/context/index.js +111 -0
  424. package/lib/utils/decompress/index.js +483 -0
  425. package/lib/utils/fn/repeat.js +64 -0
  426. package/lib/utils/inputValidation/apiKey.js +51 -0
  427. package/lib/utils/inputValidation/attribute.js +32 -0
  428. package/lib/utils/inputValidation/attributes.js +32 -0
  429. package/lib/utils/inputValidation/event.js +33 -0
  430. package/lib/utils/inputValidation/eventProperties.js +78 -0
  431. package/lib/utils/inputValidation/eventValue.js +19 -0
  432. package/lib/utils/inputValidation/index.js +48 -0
  433. package/lib/utils/inputValidation/isOperational.js +25 -0
  434. package/lib/utils/inputValidation/key.js +59 -0
  435. package/lib/utils/inputValidation/split.js +60 -0
  436. package/lib/utils/inputValidation/splitFilters.js +134 -0
  437. package/lib/utils/inputValidation/splits.js +38 -0
  438. package/lib/utils/inputValidation/trafficType.js +68 -0
  439. package/lib/utils/jwt/hashUserKey.js +19 -0
  440. package/lib/utils/jwt/index.js +19 -0
  441. package/lib/utils/key/factory.js +46 -0
  442. package/lib/utils/key/parser.js +42 -0
  443. package/lib/utils/labels/index.js +18 -0
  444. package/lib/utils/lang/Errors.js +58 -0
  445. package/lib/utils/lang/Sets.js +127 -0
  446. package/lib/utils/lang/index.js +350 -0
  447. package/lib/utils/localstorage/isAvailable.js +31 -0
  448. package/lib/utils/logger/LoggerFactory.js +98 -0
  449. package/lib/utils/logger/index.js +109 -0
  450. package/lib/utils/lrucache/linkedlist.js +132 -0
  451. package/lib/utils/lrucache/lru.spec.js +30 -0
  452. package/lib/utils/lrucache/lrucache.js +88 -0
  453. package/lib/utils/now/browser.js +33 -0
  454. package/lib/utils/now/node.js +24 -0
  455. package/lib/utils/now/package.json +4 -0
  456. package/lib/utils/promise/thenable.js +10 -0
  457. package/lib/utils/promise/timeout.js +40 -0
  458. package/lib/utils/promise/wrapper.js +63 -0
  459. package/{src → lib/utils}/settings/defaults/browser.js +6 -6
  460. package/{src → lib/utils}/settings/defaults/node.js +6 -6
  461. package/lib/utils/settings/defaults/package.json +4 -0
  462. package/lib/utils/settings/impressionsMode.js +26 -0
  463. package/lib/utils/settings/index.js +214 -0
  464. package/lib/utils/settings/integrations/browser.js +17 -0
  465. package/lib/utils/settings/integrations/common.js +40 -0
  466. package/lib/utils/settings/integrations/node.js +13 -0
  467. package/lib/utils/settings/integrations/package.json +4 -0
  468. package/lib/utils/settings/language/browser.js +22 -0
  469. package/lib/utils/settings/language/node.js +22 -0
  470. package/lib/utils/settings/language/package.json +4 -0
  471. package/lib/utils/settings/mode.js +16 -0
  472. package/lib/utils/settings/runtime/browser.js +26 -0
  473. package/lib/{settings → utils/settings}/runtime/node.js +5 -7
  474. package/lib/utils/settings/runtime/package.json +4 -0
  475. package/lib/{settings → utils/settings}/storage/browser.js +24 -20
  476. package/lib/{settings → utils/settings}/storage/node.js +17 -26
  477. package/lib/utils/settings/storage/package.json +4 -0
  478. package/lib/utils/splits/usesSegments.js +27 -0
  479. package/lib/utils/time/index.js +12 -0
  480. package/lib/utils/timeTracker/index.js +213 -0
  481. package/lib/utils/timeTracker/timer.js +33 -0
  482. package/package.json +16 -20
  483. package/src/client/attributesDecoration.js +112 -0
  484. package/src/client/browser.js +41 -0
  485. package/src/client/client.js +131 -0
  486. package/src/client/inputValidation.js +130 -0
  487. package/src/client/node.js +8 -0
  488. package/src/client/package.json +4 -0
  489. package/src/engine/combiners/and.js +55 -0
  490. package/src/engine/combiners/ifelseif.js +74 -0
  491. package/src/engine/condition/index.js +65 -0
  492. package/src/engine/convertions/index.js +22 -0
  493. package/src/engine/engine/index.js +63 -0
  494. package/src/engine/engine/legacy.js +66 -0
  495. package/src/engine/engine/murmur3/common.js +54 -0
  496. package/src/engine/engine/murmur3/murmur3.js +79 -0
  497. package/src/engine/engine/murmur3/murmur3_128.js +273 -0
  498. package/src/engine/engine/murmur3/murmur3_128_x86.js +188 -0
  499. package/src/engine/engine/murmur3/murmur3_64.js +34 -0
  500. package/src/engine/engine/murmur3/utfx.js +111 -0
  501. package/src/engine/evaluator/index.js +148 -0
  502. package/src/engine/index.js +123 -0
  503. package/src/engine/matchers/all.js +29 -0
  504. package/src/engine/matchers/between.js +30 -0
  505. package/src/engine/matchers/boolean.js +29 -0
  506. package/src/engine/matchers/cont_all.js +40 -0
  507. package/src/engine/matchers/cont_any.js +35 -0
  508. package/src/engine/matchers/cont_str.js +31 -0
  509. package/src/engine/matchers/dependency.js +52 -0
  510. package/src/engine/matchers/eq.js +30 -0
  511. package/src/engine/matchers/eq_set.js +37 -0
  512. package/src/engine/matchers/ew.js +31 -0
  513. package/src/engine/matchers/gte.js +30 -0
  514. package/src/engine/matchers/index.js +71 -0
  515. package/src/engine/matchers/lte.js +30 -0
  516. package/src/engine/matchers/part_of.js +37 -0
  517. package/src/engine/matchers/segment.js +41 -0
  518. package/src/engine/matchers/string.js +39 -0
  519. package/src/engine/matchers/sw.js +31 -0
  520. package/src/engine/matchers/types.js +52 -0
  521. package/src/engine/matchers/whitelist.js +30 -0
  522. package/src/engine/parser/index.js +79 -0
  523. package/src/engine/parser/segments.js +31 -0
  524. package/src/engine/transforms/matcherGroup.js +45 -0
  525. package/src/engine/transforms/matchers.js +118 -0
  526. package/src/engine/transforms/segment.js +23 -0
  527. package/src/engine/transforms/set.js +20 -0
  528. package/src/engine/transforms/unaryNumeric.js +20 -0
  529. package/src/engine/transforms/whitelist.js +22 -0
  530. package/src/engine/treatments/index.js +67 -0
  531. package/src/engine/value/index.js +53 -0
  532. package/src/engine/value/sanitize.js +117 -0
  533. package/src/events/index.js +62 -0
  534. package/src/factory/offline.js +60 -0
  535. package/src/factory/online.js +127 -0
  536. package/src/impressions/counter.js +43 -0
  537. package/src/impressions/hasher/buildKey.js +3 -0
  538. package/src/impressions/hasher/hashImpression128.js +6 -0
  539. package/src/impressions/hasher/hashImpression32.js +6 -0
  540. package/src/impressions/observer/browser.js +8 -0
  541. package/src/impressions/observer/node.js +8 -0
  542. package/src/impressions/observer/observer.js +17 -0
  543. package/src/impressions/observer/package.json +4 -0
  544. package/src/index.js +140 -1
  545. package/src/integrations/browser.js +57 -0
  546. package/src/integrations/ga/GaToSplit.js +278 -0
  547. package/src/integrations/ga/SplitToGa.js +125 -0
  548. package/src/integrations/node.js +4 -0
  549. package/src/integrations/package.json +4 -0
  550. package/src/listeners/browser.js +137 -0
  551. package/src/listeners/node.js +59 -0
  552. package/src/listeners/package.json +4 -0
  553. package/src/manager/index.js +103 -0
  554. package/src/metrics/Collectors.js +77 -0
  555. package/src/metrics/index.js +174 -0
  556. package/src/producer/browser/Partial.js +104 -0
  557. package/src/producer/browser.js +82 -0
  558. package/src/producer/fetcher/MySegments.js +40 -0
  559. package/src/producer/fetcher/SegmentChanges.js +52 -0
  560. package/src/producer/fetcher/SplitChanges.js +39 -0
  561. package/src/producer/node.js +142 -0
  562. package/src/producer/offline/browser.js +28 -0
  563. package/src/producer/offline/node.js +28 -0
  564. package/src/producer/offline/package.json +4 -0
  565. package/src/producer/package.json +4 -0
  566. package/src/producer/task.js +57 -0
  567. package/src/producer/updater/MySegments.js +104 -0
  568. package/src/producer/updater/SegmentChanges.js +126 -0
  569. package/src/producer/updater/SplitChanges.js +138 -0
  570. package/src/producer/updater/SplitChangesFromFeatures.js +23 -0
  571. package/src/producer/updater/SplitChangesFromFileSystem.js +23 -0
  572. package/src/producer/updater/SplitChangesFromObject.js +81 -0
  573. package/src/readiness/index.js +125 -0
  574. package/src/readiness/statusManager.js +121 -0
  575. package/src/services/auth/auth.js +21 -0
  576. package/src/services/auth/index.js +3 -0
  577. package/src/services/events/bulk.js +23 -0
  578. package/src/services/events/index.js +18 -0
  579. package/{es/platform → src/services}/getEventSource/browser.js +1 -1
  580. package/src/{platform → services}/getEventSource/node.js +2 -2
  581. package/src/services/getEventSource/package.json +4 -0
  582. package/src/{platform → services}/getFetch/browser.js +2 -2
  583. package/src/{platform → services}/getFetch/node.js +1 -1
  584. package/src/services/getFetch/package.json +4 -0
  585. package/src/services/impressions/bulk.js +26 -0
  586. package/src/services/impressions/count.js +8 -0
  587. package/src/services/impressions/dto.js +71 -0
  588. package/src/services/impressions/index.js +18 -0
  589. package/src/services/impressions/post.js +23 -0
  590. package/src/services/metrics/counters.js +25 -0
  591. package/src/services/metrics/dto.js +44 -0
  592. package/src/services/metrics/index.js +18 -0
  593. package/src/services/metrics/times.js +25 -0
  594. package/src/services/mySegments/get.js +27 -0
  595. package/src/services/mySegments/index.js +18 -0
  596. package/src/services/request/index.js +43 -0
  597. package/src/services/request/options/browser.js +18 -0
  598. package/src/{platform → services}/request/options/node.js +2 -2
  599. package/src/services/request/options/package.json +4 -0
  600. package/src/services/segmentChanges/get.js +20 -0
  601. package/src/services/segmentChanges/index.js +18 -0
  602. package/src/services/splitChanges/get.js +20 -0
  603. package/src/services/splitChanges/index.js +18 -0
  604. package/src/services/splitChanges/offline/browser.js +66 -0
  605. package/src/services/splitChanges/offline/node.js +190 -0
  606. package/src/services/splitChanges/offline/package.json +4 -0
  607. package/src/services/splitChanges/offline/parseCondition.js +52 -0
  608. package/src/services/transport/index.js +44 -0
  609. package/src/storage/AttributesCache/InMemory.js +76 -0
  610. package/src/storage/BaseMetricsAsyncCache.js +14 -0
  611. package/src/storage/CountCache/InMemory.js +48 -0
  612. package/src/storage/CountCache/InRedis.js +32 -0
  613. package/src/storage/EventsCache/InMemory.js +99 -0
  614. package/src/storage/EventsCache/InRedis.js +62 -0
  615. package/src/storage/ImpressionsCache/InMemory.js +62 -0
  616. package/src/storage/ImpressionsCache/InRedis.js +65 -0
  617. package/src/storage/Keys.js +122 -0
  618. package/src/storage/KeysLocalStorage.js +52 -0
  619. package/src/storage/LatencyCache/InMemory.js +56 -0
  620. package/src/storage/LatencyCache/InRedis.js +35 -0
  621. package/src/storage/LatencyCache/findIndex.js +7 -0
  622. package/src/storage/Meta.js +7 -0
  623. package/src/storage/RedisAdapter.js +170 -0
  624. package/src/storage/SegmentCache/InLocalStorage/index.js +140 -0
  625. package/src/storage/SegmentCache/InMemory/browser.js +99 -0
  626. package/src/storage/SegmentCache/InMemory/node.js +84 -0
  627. package/src/storage/SegmentCache/InMemory/package.json +4 -0
  628. package/src/storage/SegmentCache/InRedis/index.js +71 -0
  629. package/src/storage/SplitCache/InLocalStorage.js +324 -0
  630. package/src/storage/SplitCache/InMemory.js +145 -0
  631. package/src/storage/SplitCache/InRedis.js +187 -0
  632. package/src/storage/SplitCache/killLocally.js +33 -0
  633. package/src/storage/browser.js +110 -0
  634. package/src/storage/node.js +83 -0
  635. package/src/storage/package.json +4 -0
  636. package/src/sync/AuthClient/index.js +31 -0
  637. package/src/sync/PushManager/index.js +328 -0
  638. package/src/sync/PushManager/mySegmentsV2utils.js +76 -0
  639. package/src/sync/PushManager/pushRequirements/browser.js +20 -0
  640. package/src/sync/PushManager/pushRequirements/node.js +16 -0
  641. package/src/sync/PushManager/pushRequirements/package.json +4 -0
  642. package/src/sync/SSEClient/index.js +92 -0
  643. package/src/sync/SSEHandler/NotificationKeeper.js +90 -0
  644. package/src/sync/SSEHandler/NotificationParser.js +35 -0
  645. package/src/sync/SSEHandler/index.js +110 -0
  646. package/src/sync/SegmentUpdateWorker/browser.js +67 -0
  647. package/src/sync/SegmentUpdateWorker/node.js +73 -0
  648. package/src/sync/SegmentUpdateWorker/package.json +4 -0
  649. package/src/sync/SplitUpdateWorker/index.js +79 -0
  650. package/src/sync/browser.js +130 -0
  651. package/src/sync/constants.js +43 -0
  652. package/src/sync/node.js +66 -0
  653. package/src/sync/package.json +4 -0
  654. package/src/trackers/event.js +47 -0
  655. package/src/trackers/impressions.js +123 -0
  656. package/src/umd.js +0 -1
  657. package/src/utils/backoff/index.js +46 -0
  658. package/src/utils/base64/browser.js +19 -0
  659. package/src/utils/base64/node.js +19 -0
  660. package/src/utils/base64/package.json +4 -0
  661. package/src/utils/binarySearch/index.js +50 -0
  662. package/src/utils/constants/index.js +41 -0
  663. package/src/utils/context/constants.js +18 -0
  664. package/src/utils/context/index.js +84 -0
  665. package/src/utils/decompress/index.js +428 -0
  666. package/src/utils/fn/repeat.js +48 -0
  667. package/src/utils/inputValidation/apiKey.js +42 -0
  668. package/src/utils/inputValidation/attribute.js +22 -0
  669. package/src/utils/inputValidation/attributes.js +26 -0
  670. package/src/utils/inputValidation/event.js +23 -0
  671. package/src/utils/inputValidation/eventProperties.js +65 -0
  672. package/src/utils/inputValidation/eventValue.js +11 -0
  673. package/src/utils/inputValidation/index.js +11 -0
  674. package/src/utils/inputValidation/isOperational.js +16 -0
  675. package/src/utils/inputValidation/key.js +53 -0
  676. package/src/utils/inputValidation/split.js +42 -0
  677. package/src/utils/inputValidation/splitFilters.js +108 -0
  678. package/src/utils/inputValidation/splits.js +21 -0
  679. package/src/utils/inputValidation/trafficType.js +58 -0
  680. package/src/utils/jwt/hashUserKey.js +11 -0
  681. package/src/utils/jwt/index.js +15 -0
  682. package/src/utils/key/factory.js +34 -0
  683. package/src/utils/key/parser.js +34 -0
  684. package/src/utils/labels/index.js +7 -0
  685. package/src/utils/lang/Errors.js +19 -0
  686. package/src/utils/lang/Sets.js +94 -0
  687. package/src/utils/lang/index.js +291 -0
  688. package/src/utils/localstorage/isAvailable.js +26 -0
  689. package/src/utils/logger/LoggerFactory.js +90 -0
  690. package/src/utils/logger/index.js +93 -0
  691. package/src/utils/lrucache/linkedlist.js +116 -0
  692. package/src/utils/lrucache/lru.spec.js +26 -0
  693. package/src/utils/lrucache/lrucache.js +49 -0
  694. package/src/utils/now/browser.js +29 -0
  695. package/src/utils/now/node.js +21 -0
  696. package/src/utils/now/package.json +4 -0
  697. package/src/utils/promise/thenable.js +1 -0
  698. package/src/utils/promise/timeout.js +38 -0
  699. package/src/utils/promise/wrapper.js +60 -0
  700. package/{lib → src/utils}/settings/defaults/browser.js +3 -13
  701. package/{lib → src/utils}/settings/defaults/node.js +2 -12
  702. package/src/utils/settings/defaults/package.json +4 -0
  703. package/src/utils/settings/impressionsMode.js +15 -0
  704. package/src/utils/settings/index.js +217 -0
  705. package/src/utils/settings/integrations/browser.js +8 -0
  706. package/src/utils/settings/integrations/common.js +32 -0
  707. package/src/{settings → utils/settings}/integrations/node.js +3 -1
  708. package/src/utils/settings/integrations/package.json +4 -0
  709. package/src/utils/settings/language/browser.js +17 -0
  710. package/src/utils/settings/language/node.js +17 -0
  711. package/src/utils/settings/language/package.json +4 -0
  712. package/src/utils/settings/mode.js +12 -0
  713. package/src/utils/settings/runtime/browser.js +22 -0
  714. package/src/{settings → utils/settings}/runtime/node.js +6 -9
  715. package/src/utils/settings/runtime/package.json +4 -0
  716. package/src/{settings → utils/settings}/storage/browser.js +18 -13
  717. package/src/{settings → utils/settings}/storage/node.js +14 -19
  718. package/src/utils/settings/storage/package.json +4 -0
  719. package/src/utils/splits/usesSegments.js +17 -0
  720. package/src/utils/time/index.js +8 -0
  721. package/src/utils/timeTracker/index.js +223 -0
  722. package/src/utils/timeTracker/timer.js +27 -0
  723. package/types/splitio.d.ts +5 -22
  724. package/client/package.json +0 -5
  725. package/es/factory/browser.js +0 -58
  726. package/es/factory/node.js +0 -59
  727. package/es/platform/EventEmitter.js +0 -412
  728. package/es/platform/browser.js +0 -10
  729. package/es/platform/node.js +0 -12
  730. package/es/settings/browser.js +0 -18
  731. package/es/settings/defaults/version.js +0 -1
  732. package/es/settings/integrations/browser.js +0 -5
  733. package/es/settings/integrations/node.js +0 -5
  734. package/es/settings/node.js +0 -20
  735. package/lib/factory/browser.js +0 -79
  736. package/lib/factory/node.js +0 -78
  737. package/lib/platform/EventEmitter.js +0 -417
  738. package/lib/platform/browser.js +0 -21
  739. package/lib/platform/node.js +0 -26
  740. package/lib/settings/browser.js +0 -30
  741. package/lib/settings/defaults/version.js +0 -6
  742. package/lib/settings/integrations/browser.js +0 -14
  743. package/lib/settings/integrations/node.js +0 -12
  744. package/lib/settings/node.js +0 -33
  745. package/server/package.json +0 -5
  746. package/src/.DS_Store +0 -0
  747. package/src/factory/browser.js +0 -74
  748. package/src/factory/node.js +0 -71
  749. package/src/platform/.DS_Store +0 -0
  750. package/src/platform/EventEmitter.js +0 -443
  751. package/src/platform/browser.js +0 -12
  752. package/src/platform/node.js +0 -14
  753. package/src/settings/.DS_Store +0 -0
  754. package/src/settings/browser.js +0 -18
  755. package/src/settings/defaults/version.js +0 -1
  756. package/src/settings/integrations/browser.js +0 -6
  757. package/src/settings/node.js +0 -20
  758. package/types/client/index.d.ts +0 -14
  759. package/types/server/index.d.ts +0 -20
@@ -0,0 +1,328 @@
1
+ import EventEmitter from 'events';
2
+ import objectAssign from 'object-assign';
3
+
4
+ import authenticate from '../AuthClient';
5
+ import { checkPushRequirements } from './pushRequirements';
6
+ import SegmentUpdateWorker from '../SegmentUpdateWorker';
7
+ import SplitUpdateWorker from '../SplitUpdateWorker';
8
+ import SSEClient from '../SSEClient';
9
+ import SSEHandlerFactory from '../SSEHandler';
10
+
11
+ import Backoff from '../../utils/backoff';
12
+ import { hashUserKey } from '../../utils/jwt/hashUserKey';
13
+ import logFactory from '../../utils/logger';
14
+ import { SECONDS_BEFORE_EXPIRATION, PUSH_SUBSYSTEM_DOWN, PUSH_SUBSYSTEM_UP, PUSH_NONRETRYABLE_ERROR, PUSH_RETRYABLE_ERROR, SPLIT_KILL, SPLIT_UPDATE, SEGMENT_UPDATE, MY_SEGMENTS_UPDATE, MY_SEGMENTS_UPDATE_V2, ControlTypes } from '../constants';
15
+ import { parseBitmap, parseKeyList, isInBitmap } from './mySegmentsV2utils';
16
+ import { forOwn } from '../../utils/lang';
17
+ import { _Set } from '../../utils/lang/Sets';
18
+ import { hash64 } from '../../engine/engine/murmur3/murmur3_64';
19
+
20
+ const log = logFactory('splitio-sync:push-manager');
21
+
22
+ // const UnboundedFetchRequest = 0;
23
+ const BoundedFetchRequest = 1;
24
+ const KeyList = 2;
25
+ const SegmentRemoval = 3;
26
+
27
+ function fallbackWarning(notificationType, e) {
28
+ return `Fetching MySegments due to an error processing ${notificationType} notification: ${e}`;
29
+ }
30
+
31
+ /**
32
+ * Factory of the push mode manager.
33
+ *
34
+ * @param {Object} context context of main client.
35
+ * @param {Object | undefined} clientContexts map of user keys to client contexts to handle sync of MySegments. undefined for node.
36
+ */
37
+ export default function PushManagerFactory(context, clientContexts /* undefined for node */) {
38
+
39
+ // No return a PushManager if PUSH mode is not supported.
40
+ if (!checkPushRequirements(log)) return;
41
+
42
+ const pushEmitter = new EventEmitter();
43
+ const { splits: splitsEventEmitter } = context.get(context.constants.READINESS);
44
+ const settings = context.get(context.constants.SETTINGS);
45
+ const storage = context.get(context.constants.STORAGE);
46
+ const sseClient = SSEClient.getInstance(settings, clientContexts ? false : true);
47
+ const sseHandler = SSEHandlerFactory(pushEmitter);
48
+ sseClient.setEventHandler(sseHandler);
49
+
50
+ // map of hashes to user keys, to dispatch MY_SEGMENTS_UPDATE events to the corresponding MySegmentsUpdateWorker
51
+ const userKeyHashes = {};
52
+ // map of user keys to their corresponding hash64 and MySegmentsUpdateWorker.
53
+ // Hash64 is used to process MY_SEGMENTS_UPDATE_V2 events and dispatch actions to the corresponding worker.
54
+ const clients = {};
55
+
56
+ // variable used on browser to reconnect only when a new client was added, saving some authentication and sse connections.
57
+ let connectForNewClient = false;
58
+ // flag that indicates if `disconnectPush` was called, either by the SyncManager (when the client is destroyed) or by a PUSH_NONRETRYABLE_ERROR error
59
+ let disconnected;
60
+
61
+ /** PushManager functions related to initialization */
62
+
63
+ const connectPushRetryBackoff = new Backoff(connectPush, settings.scheduler.pushRetryBackoffBase);
64
+
65
+ let timeoutIdTokenRefresh;
66
+ let timeoutIdSseOpen;
67
+
68
+ function scheduleTokenRefreshAndSse(authData) {
69
+ // clear scheduled tasks if exist
70
+ if (timeoutIdTokenRefresh) clearTimeout(timeoutIdTokenRefresh);
71
+ if (timeoutIdSseOpen) clearTimeout(timeoutIdSseOpen);
72
+
73
+ // Set token refresh 10 minutes before expirationTime - issuedAt
74
+ const decodedToken = authData.decodedToken;
75
+ const refreshTokenDelay = decodedToken.exp - decodedToken.iat - SECONDS_BEFORE_EXPIRATION;
76
+ // Default connDelay of 60 secs
77
+ const connDelay = typeof authData.connDelay === 'number' && authData.connDelay >= 0 ? authData.connDelay : 60;
78
+
79
+ log.info(`Refreshing streaming token in ${refreshTokenDelay} seconds, and connecting streaming in ${connDelay} seconds`);
80
+
81
+ timeoutIdTokenRefresh = setTimeout(connectPush, refreshTokenDelay * 1000);
82
+
83
+ timeoutIdSseOpen = setTimeout(() => {
84
+ // halt if disconnected
85
+ if (disconnected) return;
86
+ sseClient.open(authData);
87
+ }, connDelay * 1000);
88
+ }
89
+
90
+ function connectPush() {
91
+ // Halt connecting in case `stop/disconnectPush` has been called
92
+ if (disconnected) return;
93
+ log.info(`${disconnected === undefined ? 'Connecting' : 'Re-connecting'} to push streaming.`);
94
+ disconnected = false;
95
+
96
+ const userKeys = clientContexts ? Object.keys(clientContexts) : undefined;
97
+ authenticate(settings, userKeys).then(
98
+ function (authData) {
99
+ if (disconnected) return;
100
+
101
+ // 'pushEnabled: false' is handled as a PUSH_NONRETRYABLE_ERROR instead of PUSH_SUBSYSTEM_DOWN, in order to
102
+ // close the sseClient in case the org has been bloqued while the instance was connected to streaming
103
+ if (!authData.pushEnabled) {
104
+ log.info('Streaming is not available. Switching to polling mode.');
105
+ pushEmitter.emit(PUSH_NONRETRYABLE_ERROR);
106
+ return;
107
+ }
108
+
109
+ // don't open SSE connection if a new shared client was added, since it means that a new authentication is taking place
110
+ if (userKeys && userKeys.length < Object.keys(clientContexts).length) return;
111
+
112
+ // Schedule SSE connection and refresh token
113
+ scheduleTokenRefreshAndSse(authData);
114
+ }
115
+ ).catch(
116
+ function (error) {
117
+ if (disconnected) return;
118
+
119
+ log.error(`Failed to authenticate for streaming. Error: ${error.message}.`);
120
+
121
+ // Handle 4XX HTTP errors: 401 (invalid API Key) or 400 (using incorrect API Key, i.e., client-side API Key on server-side)
122
+ if (error.statusCode >= 400 && error.statusCode < 500) {
123
+ pushEmitter.emit(PUSH_NONRETRYABLE_ERROR);
124
+ return;
125
+ }
126
+
127
+ // Handle other HTTP and network errors as recoverable errors
128
+ pushEmitter.emit(PUSH_RETRYABLE_ERROR);
129
+ }
130
+ );
131
+ }
132
+
133
+ // close SSE connection and cancel scheduled tasks
134
+ function disconnectPush() {
135
+ // Halt disconnecting, just to avoid redundant logs if called multiple times
136
+ if (disconnected) return;
137
+ disconnected = true;
138
+
139
+ sseClient.close();
140
+ log.info('Disconnecting from push streaming.');
141
+
142
+ if (timeoutIdTokenRefresh) clearTimeout(timeoutIdTokenRefresh);
143
+ if (timeoutIdSseOpen) clearTimeout(timeoutIdSseOpen);
144
+ connectPushRetryBackoff.reset();
145
+
146
+ stopWorkers();
147
+ }
148
+
149
+ pushEmitter.on(PUSH_SUBSYSTEM_DOWN, stopWorkers);
150
+
151
+ // Only required when streaming connects after a PUSH_RETRYABLE_ERROR.
152
+ // Otherwise it is unnecessary (e.g, STREAMING_RESUMED).
153
+ pushEmitter.on(PUSH_SUBSYSTEM_UP, () => {
154
+ connectPushRetryBackoff.reset();
155
+ stopWorkers();
156
+ });
157
+
158
+ /** Fallbacking without retry due to STREAMING_DISABLED control event, 'pushEnabled: false', and non-recoverable SSE and Authentication errors */
159
+
160
+ pushEmitter.on(PUSH_NONRETRYABLE_ERROR, function handleNonRetryableError() {
161
+ // Note: `stopWorkers` is been called twice, but it is not harmful
162
+ disconnectPush();
163
+ pushEmitter.emit(PUSH_SUBSYSTEM_DOWN); // no harm if polling already
164
+ });
165
+
166
+ /** Fallbacking with retry due to recoverable SSE and Authentication errors */
167
+
168
+ pushEmitter.on(PUSH_RETRYABLE_ERROR, function handleRetryableError() { // HTTP or network error in SSE connection
169
+ // SSE connection is closed to avoid repeated errors due to retries
170
+ sseClient.close();
171
+
172
+ // retry streaming reconnect with backoff algorithm
173
+ let delayInMillis = connectPushRetryBackoff.scheduleCall();
174
+
175
+ log.info(`Attempting to reconnect in ${delayInMillis / 1000} seconds.`);
176
+
177
+ pushEmitter.emit(PUSH_SUBSYSTEM_DOWN); // no harm if polling already
178
+ });
179
+
180
+ /** STREAMING_RESET notification. Unlike a PUSH_RETRYABLE_ERROR, it doesn't emit PUSH_SUBSYSTEM_DOWN to fallback polling */
181
+
182
+ pushEmitter.on(ControlTypes.STREAMING_RESET, function handleStreamingReset() {
183
+ if (disconnected) return; // should never happen
184
+
185
+ // Minimum required clean-up.
186
+ // `disconnectPush` cannot be called because it sets `disconnected` and thus `connectPush` will not execute
187
+ if (timeoutIdTokenRefresh) clearTimeout(timeoutIdTokenRefresh);
188
+
189
+ connectPush();
190
+ });
191
+
192
+ /** Functions related to synchronization (Queues and Workers in the spec) */
193
+
194
+ const producer = context.get(context.constants.PRODUCER);
195
+ const splitUpdateWorker = new SplitUpdateWorker(storage.splits, producer, splitsEventEmitter);
196
+ let segmentUpdateWorker; // used in Node
197
+
198
+ // cancel scheduled fetch retries of Split, Segment, and MySegment Update Workers
199
+ function stopWorkers() {
200
+ splitUpdateWorker.backoff.reset();
201
+ if (segmentUpdateWorker) segmentUpdateWorker.backoff.reset();
202
+ forOwn(clients, ({ worker }) => worker.backoff.reset());
203
+ }
204
+
205
+ pushEmitter.on(SPLIT_KILL, splitUpdateWorker.killSplit);
206
+ pushEmitter.on(SPLIT_UPDATE, splitUpdateWorker.put);
207
+
208
+ if (clientContexts) { // browser
209
+ pushEmitter.on(MY_SEGMENTS_UPDATE, function handleMySegmentsUpdate(parsedData, channel) {
210
+ const userKeyHash = channel.split('_')[2];
211
+ const userKey = userKeyHashes[userKeyHash];
212
+ if (userKey && clientContexts[userKey]) { // check context since it can be undefined if client has been destroyed
213
+ const mySegmentSync = clientContexts[userKey].get(context.constants.MY_SEGMENTS_CHANGE_WORKER, true);
214
+ mySegmentSync && mySegmentSync.put(
215
+ parsedData.changeNumber,
216
+ parsedData.includesPayload ? parsedData.segmentList ? parsedData.segmentList : [] : undefined);
217
+ }
218
+ });
219
+
220
+ pushEmitter.on(MY_SEGMENTS_UPDATE_V2, function handleMySegmentsUpdate(parsedData) {
221
+ switch (parsedData.u) {
222
+ case BoundedFetchRequest: {
223
+ let bitmap;
224
+ try {
225
+ bitmap = parseBitmap(parsedData.d, parsedData.c);
226
+ } catch (e) {
227
+ log.warn(fallbackWarning('BoundedFetchRequest', e));
228
+ break;
229
+ }
230
+
231
+ forOwn(clients, ({ hash64, worker }) => {
232
+ if (isInBitmap(bitmap, hash64.hex)) {
233
+ worker.put(parsedData.changeNumber); // fetch mySegments
234
+ }
235
+ });
236
+ return;
237
+ }
238
+ case KeyList: {
239
+ let keyList, added, removed;
240
+ try {
241
+ keyList = parseKeyList(parsedData.d, parsedData.c);
242
+ added = new _Set(keyList.a);
243
+ removed = new _Set(keyList.r);
244
+ } catch (e) {
245
+ log.warn(fallbackWarning('KeyList', e));
246
+ break;
247
+ }
248
+
249
+ forOwn(clients, ({ hash64, worker }) => {
250
+ const add = added.has(hash64.dec) ? true : removed.has(hash64.dec) ? false : undefined;
251
+ if (add !== undefined) {
252
+ worker.put(parsedData.changeNumber, {
253
+ name: parsedData.segmentName,
254
+ add
255
+ });
256
+ }
257
+ });
258
+ return;
259
+ }
260
+ case SegmentRemoval:
261
+ if (!parsedData.segmentName) {
262
+ log.warn(fallbackWarning('SegmentRemoval', 'No segment name was provided'));
263
+ break;
264
+ }
265
+
266
+ forOwn(clients, ({ worker }) => {
267
+ worker.put(parsedData.changeNumber, {
268
+ name: parsedData.segmentName,
269
+ add: false
270
+ });
271
+ });
272
+ return;
273
+ }
274
+
275
+ // `UpdateStrategy.UnboundedFetchRequest` and fallbacks of other cases
276
+ forOwn(clients, ({ worker }) => {
277
+ worker.put(parsedData.changeNumber);
278
+ });
279
+ });
280
+
281
+ } else { // node
282
+ segmentUpdateWorker = new SegmentUpdateWorker(storage.segments, producer);
283
+ pushEmitter.on(SEGMENT_UPDATE, segmentUpdateWorker.put);
284
+ }
285
+
286
+ return objectAssign(
287
+ // Expose Event Emitter functionality and Event constants
288
+ Object.create(pushEmitter),
289
+ {
290
+ // Expose functionality for starting and stoping push mode:
291
+ stop: disconnectPush, // `handleNonRetryableError` cannot be used as `stop`, because it emits PUSH_SUBSYSTEM_DOWN event, which start polling.
292
+
293
+ // used in node
294
+ start: connectPush,
295
+
296
+ // used in browser
297
+ startNewClient(userKey, context) {
298
+ const hash = hashUserKey(userKey);
299
+ const storage = context.get(context.constants.STORAGE);
300
+ const producer = context.get(context.constants.PRODUCER);
301
+
302
+ if (!userKeyHashes[hash]) {
303
+ userKeyHashes[hash] = userKey;
304
+ connectForNewClient = true; // we must reconnect on start, to listen the channel for the new user key
305
+ }
306
+ const mySegmentSync = new SegmentUpdateWorker(storage.segments, producer);
307
+ clients[userKey] = { worker: mySegmentSync, hash64: hash64(userKey) };
308
+ context.put(context.constants.MY_SEGMENTS_CHANGE_WORKER, mySegmentSync);
309
+
310
+ // Reconnects in case of a new client.
311
+ // Run in next event-loop cycle to save authentication calls
312
+ // in case the user is creating several clients in the current cycle.
313
+ setTimeout(function checkForReconnect() {
314
+ if (connectForNewClient) {
315
+ connectForNewClient = false;
316
+ connectPush();
317
+ }
318
+ }, 0);
319
+
320
+ },
321
+ removeClient(userKey) {
322
+ const hash = hashUserKey(userKey);
323
+ delete userKeyHashes[hash];
324
+ delete clients[userKey];
325
+ }
326
+ }
327
+ );
328
+ }
@@ -0,0 +1,76 @@
1
+ import { algorithms } from '../../utils/decompress';
2
+ import { decodeFromBase64 } from '../../utils/base64';
3
+
4
+ const GZIP = 1;
5
+ const ZLIB = 2;
6
+
7
+ function Uint8ArrayToString(myUint8Arr) {
8
+ return String.fromCharCode.apply(null, myUint8Arr);
9
+ }
10
+
11
+ function StringToUint8Array(myString) {
12
+ const charCodes = myString.split('').map((e) => e.charCodeAt());
13
+ return new Uint8Array(charCodes);
14
+ }
15
+
16
+ /**
17
+ * Decode and decompress 'data' with 'compression' algorithm
18
+ *
19
+ * @param {string} data
20
+ * @param {number} compression 1 GZIP, 2 ZLIB
21
+ * @returns {Uint8Array}
22
+ * @throws if data string cannot be decoded, decompressed or the provided compression value is invalid (not 1 or 2)
23
+ */
24
+ function decompress(data, compression) {
25
+ let compressData = decodeFromBase64(data);
26
+ const binData = StringToUint8Array(compressData);
27
+
28
+ if (typeof algorithms === 'string') throw new Error(algorithms);
29
+ if (compression === GZIP) return algorithms.gunzipSync(binData);
30
+ if (compression === ZLIB) return algorithms.unzlibSync(binData);
31
+ throw new Error(`Invalid compression algorithm #${compression}`);
32
+ }
33
+
34
+ /**
35
+ * Decode, decompress and parse the provided 'data' into a KeyList object
36
+ *
37
+ * @param {string} data
38
+ * @param {number} compression
39
+ * @returns {{a?: string[], r?: string[] }}
40
+ * @throws if data string cannot be decoded, decompressed or parsed
41
+ */
42
+ export function parseKeyList(data, compression) {
43
+ const binKeyList = decompress(data, compression);
44
+ const strKeyList = Uint8ArrayToString(binKeyList);
45
+
46
+ // replace numbers to strings, to avoid losing precision
47
+ return JSON.parse(strKeyList.replace(/\d+/g, '"$&"'));
48
+ }
49
+
50
+ /**
51
+ * Decode, decompress and parse the provided 'data' into a Bitmap object
52
+ *
53
+ * @param {string} data
54
+ * @param {number} compression
55
+ * @returns {Uint8Array}
56
+ * @throws if data string cannot be decoded or decompressed
57
+ */
58
+ export function parseBitmap(data, compression) {
59
+ return decompress(data, compression);
60
+ }
61
+
62
+ /**
63
+ * Check if the 'bitmap' bit at 'hash64hex' position is 1
64
+ *
65
+ * @param {Uint8Array} bitmap
66
+ * @param {string} hash64hex 16-chars string, representing a number in hexa
67
+ * @returns {boolean}
68
+ */
69
+ export function isInBitmap(bitmap, hash64hex) {
70
+ // using the lowest 32 bits as index, to avoid losing precision when converting to number
71
+ const index = parseInt(hash64hex.slice(8), 16) % (bitmap.length * 8);
72
+
73
+ const internal = Math.floor(index / 8);
74
+ const offset = index % 8;
75
+ return (bitmap[internal] & 1 << offset) > 0;
76
+ }
@@ -0,0 +1,20 @@
1
+ import getEventSource from '../../../services/getEventSource/browser';
2
+
3
+ /**
4
+ * Check if the JS environment has the necessary features to run in PUSH mode,
5
+ * i.e., EventSource, base64 encoder and decoder.
6
+ *
7
+ * @return {boolean} if push is supported
8
+ */
9
+ export function checkPushRequirements(logger) {
10
+ const esReference = getEventSource();
11
+ if (!esReference) {
12
+ logger.warn('EventSource API is not available. Falling back to polling mode.');
13
+ return false;
14
+ }
15
+ if (typeof atob !== 'function' || typeof btoa !== 'function') {
16
+ logger.warn('"atob" and "btoa" functions for Base64 encoding are not available. Falling back to polling mode.');
17
+ return false;
18
+ }
19
+ return true;
20
+ }
@@ -0,0 +1,16 @@
1
+ import getEventSource from '../../../services/getEventSource/node';
2
+
3
+ /**
4
+ * Check if the Node environment has the necessary features to run in PUSH mode,
5
+ * i.e., EventSource, base64 encoder and decoder.
6
+ *
7
+ * @return {boolean} if push is supported
8
+ */
9
+ export function checkPushRequirements(logger) {
10
+ const esReference = getEventSource();
11
+ if (!esReference) {
12
+ logger.warn('EventSource API is not available. Falling back to polling mode.');
13
+ return false;
14
+ }
15
+ return true;
16
+ }
@@ -0,0 +1,4 @@
1
+ {
2
+ "main": "./node.js",
3
+ "browser": "./browser.js"
4
+ }
@@ -0,0 +1,92 @@
1
+ import getEventSource from '../../services/getEventSource';
2
+
3
+ const VERSION = '1.1';
4
+
5
+ const CONTROL_CHANNEL_REGEX = /^control_/;
6
+
7
+ /**
8
+ * Build metadata headers for SSE connection.
9
+ *
10
+ * @param {Object} settings Validated settings.
11
+ */
12
+ function buildSSEHeaders(settings) {
13
+ const headers = {
14
+ SplitSDKClientKey: settings.core.authorizationKey.slice(-4),
15
+ SplitSDKVersion: settings.version,
16
+ };
17
+
18
+ // ip and hostname are false if IPAddressesEnabled is false
19
+ const { ip, hostname } = settings.runtime;
20
+ if (ip) headers['SplitSDKMachineIP'] = ip;
21
+ if (hostname) headers['SplitSDKMachineName'] = hostname;
22
+
23
+ return headers;
24
+ }
25
+
26
+ export default class SSEClient {
27
+
28
+ /**
29
+ * Returns a SSEClient instance, or undefined if EventSource is not available.
30
+ * @param {Object} settings Validated SDK settings.
31
+ * @param {boolean} useHeaders True for Node and false for Browser, used to send metadata as headers or query params respectively.
32
+ */
33
+ static getInstance(settings, useHeaders) {
34
+ const EventSource = getEventSource();
35
+ if (EventSource)
36
+ return new SSEClient(EventSource, settings, useHeaders);
37
+ }
38
+
39
+ // Instance properties:
40
+ // streamingUrl: string
41
+ // EventSource: EventSource constructor
42
+ // connection: EventSource | undefined
43
+ // handler: EventHandler for open, close, error and messages events
44
+
45
+ constructor(EventSource, settings, useHeaders) {
46
+ this.EventSource = EventSource;
47
+ this.streamingUrl = settings.url('/sse');
48
+ this.useHeaders = useHeaders;
49
+ this.headers = buildSSEHeaders(settings);
50
+ }
51
+
52
+ setEventHandler(handler) {
53
+ this.handler = handler;
54
+ }
55
+
56
+ /**
57
+ * Open the connection with a given authToken
58
+ *
59
+ * @param {Object} authToken
60
+ * @throws {TypeError} Will throw an error if `authToken` is undefined
61
+ */
62
+ open(authToken) {
63
+ this.close(); // it closes connection if previously opened
64
+
65
+ const channelsQueryParam = Object.keys(authToken.channels).map(
66
+ function (channel) {
67
+ const params = CONTROL_CHANNEL_REGEX.test(channel) ? '[?occupancy=metrics.publishers]' : '';
68
+ return encodeURIComponent(params + channel);
69
+ }
70
+ ).join(',');
71
+ const url = `${this.streamingUrl}?channels=${channelsQueryParam}&accessToken=${authToken.token}&v=${VERSION}&heartbeats=true`; // same results using `&heartbeats=false`
72
+
73
+ this.connection = new this.EventSource(
74
+ // For Browser, SplitSDKClientKey and SplitSDKClientKey headers are passed as query params,
75
+ // because native EventSource implementations for browser doesn't support headers.
76
+ this.useHeaders ? url : url + `&SplitSDKVersion=${this.headers.SplitSDKVersion}&SplitSDKClientKey=${this.headers.SplitSDKClientKey}`,
77
+ // For Node, metadata headers are passed because 'eventsource' package supports them.
78
+ this.useHeaders ? { headers: this.headers } : undefined
79
+ );
80
+
81
+ if (this.handler) { // no need to check if SSEClient is used only by PushManager
82
+ this.connection.onopen = this.handler.handleOpen;
83
+ this.connection.onmessage = this.handler.handleMessage;
84
+ this.connection.onerror = this.handler.handleError;
85
+ }
86
+ }
87
+
88
+ /** Close connection */
89
+ close() {
90
+ if (this.connection) this.connection.close();
91
+ }
92
+ }
@@ -0,0 +1,90 @@
1
+ import { PUSH_SUBSYSTEM_UP, PUSH_SUBSYSTEM_DOWN, PUSH_NONRETRYABLE_ERROR, ControlTypes } from '../constants';
2
+
3
+ const CONTROL_CHANNEL_REGEXS = [/control_pri$/, /control_sec$/];
4
+
5
+ export default function notificationKeeperFactory(feedbackLoopEmitter) {
6
+
7
+ let channels = CONTROL_CHANNEL_REGEXS.map(regex => ({
8
+ regex,
9
+ hasPublishers: true, // keep track of publishers presence per channel, in order to compute `hasPublishers`. Init with true, to emit PUSH_SUBSYSTEM_UP if initial OCCUPANCY notifications have 0 publishers
10
+ oTime: -1, // keep track of most recent occupancy notification timestamp per channel
11
+ cTime: -1 // keep track of most recent control notification timestamp per channel
12
+ }));
13
+
14
+ // false if the number of publishers is equal to 0 in all regions
15
+ let hasPublishers = true;
16
+
17
+ // false if last CONTROL event was STREAMING_PAUSED or STREAMING_DISABLED
18
+ let hasResumed = true;
19
+
20
+ function getHasPublishers() { // computes the value of `hasPublishers`
21
+ return channels.some(c => c.hasPublishers);
22
+ }
23
+
24
+ return {
25
+ handleOpen() {
26
+ feedbackLoopEmitter.emit(PUSH_SUBSYSTEM_UP);
27
+ },
28
+
29
+ isStreamingUp() {
30
+ return hasResumed && hasPublishers;
31
+ },
32
+
33
+ handleOccupancyEvent(publishers, channel, timestamp) {
34
+ for (let i = 0; i < channels.length; i++) {
35
+ const c = channels[i];
36
+ if (c.regex.test(channel)) {
37
+ if (timestamp > c.oTime) {
38
+ c.oTime = timestamp;
39
+ c.hasPublishers = publishers !== 0;
40
+ const hasPublishersNow = getHasPublishers();
41
+ if (hasResumed) {
42
+ if (!hasPublishersNow && hasPublishers) {
43
+ feedbackLoopEmitter.emit(PUSH_SUBSYSTEM_DOWN);
44
+ } else if (hasPublishersNow && !hasPublishers) {
45
+ feedbackLoopEmitter.emit(PUSH_SUBSYSTEM_UP);
46
+ }
47
+ // nothing to do when hasResumed === false:
48
+ // streaming is already down for `!hasPublishersNow`, and cannot be up for `hasPublishersNow`
49
+ }
50
+ hasPublishers = hasPublishersNow;
51
+ }
52
+ return;
53
+ }
54
+ }
55
+ },
56
+
57
+ handleControlEvent(controlType, channel, timestamp) {
58
+ /* STREAMING_RESET event is handled by PushManager directly since it doesn't require
59
+ * tracking timestamp and state like OCCUPANCY or CONTROL. It also ignores previous
60
+ * OCCUPANCY and CONTROL notifications, and whether PUSH_SUBSYSTEM_DOWN has been emitted or not */
61
+ if (controlType === ControlTypes.STREAMING_RESET) {
62
+ feedbackLoopEmitter.emit(controlType);
63
+ return;
64
+ }
65
+
66
+ for (let i = 0; i < channels.length; i++) {
67
+ const c = channels[i];
68
+ if (c.regex.test(channel)) {
69
+ if (timestamp > c.cTime) {
70
+ c.cTime = timestamp;
71
+ if (controlType === ControlTypes.STREAMING_DISABLED) {
72
+ feedbackLoopEmitter.emit(PUSH_NONRETRYABLE_ERROR);
73
+ } else if (hasPublishers) {
74
+ if (controlType === ControlTypes.STREAMING_PAUSED && hasResumed) {
75
+ feedbackLoopEmitter.emit(PUSH_SUBSYSTEM_DOWN);
76
+ } else if (controlType === ControlTypes.STREAMING_RESUMED && !hasResumed) {
77
+ feedbackLoopEmitter.emit(PUSH_SUBSYSTEM_UP);
78
+ }
79
+ // nothing to do when hasPublishers === false:
80
+ // streaming is already down for `STREAMING_PAUSED`, and cannot be up for `STREAMING_RESUMED`
81
+ }
82
+ hasResumed = controlType === ControlTypes.STREAMING_RESUMED;
83
+ }
84
+ return;
85
+ }
86
+ }
87
+ },
88
+
89
+ };
90
+ }
@@ -0,0 +1,35 @@
1
+ import { OCCUPANCY } from '../constants';
2
+ import { isString } from '../../utils/lang';
3
+
4
+ /**
5
+ * Parses the `data` JSON string, if exists, of a given SSE error notifications.
6
+ * HTTP errors handled by Ably (e.g., 400 due to invalid token, 401 due to expired token, 500) have the `data` property.
7
+ * Other network and HTTP errors do not have this property.
8
+ *
9
+ * @param {Object} error
10
+ * @throws {SyntaxError} if `error.data` is an invalid JSON string
11
+ */
12
+ export function errorParser(error) {
13
+ if (isString(error.data))
14
+ error.parsedData = JSON.parse(error.data); // cannot assign to read only property 'data'
15
+
16
+ return error;
17
+ }
18
+
19
+ /**
20
+ * Parses the `data` JSON string of a given SSE message notifications.
21
+ * Also assigns the type OCCUPANCY, if it corresponds, so that all supported messages (e.g., SPLIT_UPDATE, CONTROL) have a type.
22
+ *
23
+ * @param {Object} message
24
+ * @throws {SyntaxError} if `message.data` or `JSON.parse(message.data).data` are invalid JSON strings
25
+ */
26
+ export function messageParser(message) {
27
+ const messageData = JSON.parse(message.data);
28
+ messageData.parsedData = JSON.parse(messageData.data);
29
+
30
+ // set the event type to OCCUPANCY, to handle all events uniformely
31
+ if (messageData.name && messageData.name === '[meta]occupancy')
32
+ messageData.parsedData.type = OCCUPANCY;
33
+
34
+ return messageData;
35
+ }