@splitsoftware/splitio-commons 1.6.2-rc.4 → 1.6.2-rc.5

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 (475) hide show
  1. package/cjs/consent/sdkUserConsent.js +2 -2
  2. package/cjs/listeners/browser.js +2 -1
  3. package/cjs/logger/constants.js +2 -1
  4. package/cjs/sdkClient/clientAttributesDecoration.js +1 -1
  5. package/cjs/sdkFactory/index.js +23 -6
  6. package/cjs/services/splitApi.js +20 -1
  7. package/cjs/storages/KeyBuilderSS.js +6 -0
  8. package/cjs/storages/inLocalStorage/index.js +4 -0
  9. package/cjs/storages/inMemory/AttributesCacheInMemory.js +1 -1
  10. package/cjs/storages/inMemory/ImpressionCountsCacheInMemory.js +12 -1
  11. package/cjs/storages/inMemory/InMemoryStorage.js +5 -1
  12. package/cjs/storages/inMemory/InMemoryStorageCS.js +5 -1
  13. package/cjs/storages/inMemory/uniqueKeysCacheInMemory.js +73 -0
  14. package/cjs/storages/inMemory/uniqueKeysCacheInMemoryCS.js +78 -0
  15. package/cjs/storages/inRedis/ImpressionCountsCacheInRedis.js +46 -0
  16. package/cjs/storages/inRedis/constants.js +4 -1
  17. package/cjs/storages/inRedis/index.js +15 -1
  18. package/cjs/storages/inRedis/uniqueKeysCacheInRedis.js +55 -0
  19. package/cjs/sync/submitters/submitterManager.js +3 -0
  20. package/cjs/sync/submitters/telemetrySubmitter.js +1 -0
  21. package/cjs/sync/submitters/uniqueKeysSubmitter.js +26 -0
  22. package/cjs/trackers/impressionsTracker.js +22 -41
  23. package/cjs/trackers/strategy/strategyDebug.js +25 -0
  24. package/cjs/trackers/strategy/strategyNone.js +29 -0
  25. package/cjs/trackers/strategy/strategyOptimized.js +34 -0
  26. package/cjs/trackers/uniqueKeysTracker.js +31 -0
  27. package/cjs/types.js +2 -0
  28. package/cjs/utils/constants/index.js +4 -2
  29. package/cjs/utils/key/index.js +1 -1
  30. package/cjs/utils/settingsValidation/impressionsMode.js +2 -2
  31. package/cjs/utils/settingsValidation/index.js +3 -1
  32. package/esm/consent/sdkUserConsent.js +2 -2
  33. package/esm/listeners/browser.js +3 -2
  34. package/esm/logger/constants.js +1 -0
  35. package/esm/sdkClient/clientAttributesDecoration.js +1 -1
  36. package/esm/sdkFactory/index.js +23 -6
  37. package/esm/services/splitApi.js +20 -1
  38. package/esm/storages/KeyBuilderSS.js +6 -0
  39. package/esm/storages/inLocalStorage/index.js +5 -1
  40. package/esm/storages/inMemory/AttributesCacheInMemory.js +1 -1
  41. package/esm/storages/inMemory/ImpressionCountsCacheInMemory.js +12 -1
  42. package/esm/storages/inMemory/InMemoryStorage.js +6 -2
  43. package/esm/storages/inMemory/InMemoryStorageCS.js +6 -2
  44. package/esm/storages/inMemory/uniqueKeysCacheInMemory.js +70 -0
  45. package/esm/storages/inMemory/uniqueKeysCacheInMemoryCS.js +75 -0
  46. package/esm/storages/inRedis/ImpressionCountsCacheInRedis.js +43 -0
  47. package/esm/storages/inRedis/constants.js +3 -0
  48. package/esm/storages/inRedis/index.js +16 -2
  49. package/esm/storages/inRedis/uniqueKeysCacheInRedis.js +52 -0
  50. package/esm/sync/submitters/submitterManager.js +3 -0
  51. package/esm/sync/submitters/telemetrySubmitter.js +2 -1
  52. package/esm/sync/submitters/uniqueKeysSubmitter.js +22 -0
  53. package/esm/trackers/impressionsTracker.js +22 -41
  54. package/esm/trackers/strategy/strategyDebug.js +21 -0
  55. package/esm/trackers/strategy/strategyNone.js +25 -0
  56. package/esm/trackers/strategy/strategyOptimized.js +30 -0
  57. package/esm/trackers/uniqueKeysTracker.js +27 -0
  58. package/esm/types.js +1 -0
  59. package/esm/utils/constants/index.js +2 -0
  60. package/esm/utils/key/index.js +1 -1
  61. package/esm/utils/settingsValidation/impressionsMode.js +3 -3
  62. package/esm/utils/settingsValidation/index.js +3 -1
  63. package/package.json +5 -4
  64. package/src/consent/sdkUserConsent.ts +5 -6
  65. package/src/dtos/types.ts +8 -0
  66. package/src/evaluator/Engine.ts +3 -3
  67. package/src/evaluator/combiners/and.ts +1 -1
  68. package/src/evaluator/combiners/ifelseif.ts +3 -3
  69. package/src/evaluator/condition/engineUtils.ts +1 -1
  70. package/src/evaluator/condition/index.ts +6 -6
  71. package/src/evaluator/index.ts +10 -10
  72. package/src/evaluator/matchers/all.ts +1 -1
  73. package/src/evaluator/matchers/between.ts +1 -1
  74. package/src/evaluator/matchers/boolean.ts +1 -1
  75. package/src/evaluator/matchers/cont_all.ts +1 -1
  76. package/src/evaluator/matchers/cont_any.ts +1 -1
  77. package/src/evaluator/matchers/cont_str.ts +1 -1
  78. package/src/evaluator/matchers/dependency.ts +1 -1
  79. package/src/evaluator/matchers/eq.ts +1 -1
  80. package/src/evaluator/matchers/eq_set.ts +1 -1
  81. package/src/evaluator/matchers/ew.ts +1 -1
  82. package/src/evaluator/matchers/gte.ts +1 -1
  83. package/src/evaluator/matchers/index.ts +1 -1
  84. package/src/evaluator/matchers/lte.ts +1 -1
  85. package/src/evaluator/matchers/part_of.ts +1 -1
  86. package/src/evaluator/matchers/segment.ts +1 -1
  87. package/src/evaluator/matchers/string.ts +1 -1
  88. package/src/evaluator/matchers/sw.ts +1 -1
  89. package/src/evaluator/matchers/whitelist.ts +1 -1
  90. package/src/evaluator/parser/index.ts +3 -3
  91. package/src/evaluator/types.ts +6 -6
  92. package/src/evaluator/value/index.ts +4 -4
  93. package/src/evaluator/value/sanitize.ts +4 -4
  94. package/src/integrations/ga/GaToSplit.ts +6 -6
  95. package/src/integrations/ga/SplitToGa.ts +10 -10
  96. package/src/integrations/ga/types.ts +4 -4
  97. package/src/integrations/pluggable.ts +3 -3
  98. package/src/integrations/types.ts +2 -2
  99. package/src/listeners/browser.ts +3 -2
  100. package/src/logger/constants.ts +1 -0
  101. package/src/logger/index.ts +3 -3
  102. package/src/logger/sdkLogger.ts +2 -1
  103. package/src/logger/types.ts +16 -0
  104. package/src/readiness/sdkReadinessManager.ts +1 -1
  105. package/src/readiness/types.ts +9 -2
  106. package/src/sdkClient/client.ts +13 -13
  107. package/src/sdkClient/clientAttributesDecoration.ts +13 -13
  108. package/src/sdkClient/clientCS.ts +4 -3
  109. package/src/sdkClient/clientInputValidation.ts +15 -15
  110. package/src/sdkClient/sdkClient.ts +2 -2
  111. package/src/sdkClient/sdkClientMethod.ts +2 -2
  112. package/src/sdkClient/sdkClientMethodCS.ts +9 -9
  113. package/src/sdkClient/sdkClientMethodCSWithTT.ts +9 -9
  114. package/src/sdkFactory/index.ts +28 -8
  115. package/src/sdkFactory/types.ts +11 -8
  116. package/src/sdkManager/index.ts +5 -5
  117. package/src/services/splitApi.ts +22 -1
  118. package/src/services/types.ts +6 -0
  119. package/src/storages/KeyBuilderSS.ts +8 -0
  120. package/src/storages/dataLoader.ts +2 -2
  121. package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +1 -1
  122. package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +2 -2
  123. package/src/storages/inLocalStorage/index.ts +6 -4
  124. package/src/storages/inMemory/AttributesCacheInMemory.ts +12 -13
  125. package/src/storages/inMemory/EventsCacheInMemory.ts +4 -4
  126. package/src/storages/inMemory/ImpressionCountsCacheInMemory.ts +16 -1
  127. package/src/storages/inMemory/InMemoryStorage.ts +5 -2
  128. package/src/storages/inMemory/InMemoryStorageCS.ts +6 -2
  129. package/src/storages/inMemory/uniqueKeysCacheInMemory.ts +82 -0
  130. package/src/storages/inMemory/uniqueKeysCacheInMemoryCS.ts +88 -0
  131. package/src/storages/inRedis/EventsCacheInRedis.ts +4 -4
  132. package/src/storages/inRedis/ImpressionCountsCacheInRedis.ts +48 -0
  133. package/src/storages/inRedis/ImpressionsCacheInRedis.ts +1 -1
  134. package/src/storages/inRedis/RedisAdapter.ts +1 -1
  135. package/src/storages/inRedis/SegmentsCacheInRedis.ts +1 -1
  136. package/src/storages/inRedis/SplitsCacheInRedis.ts +1 -1
  137. package/src/storages/inRedis/TelemetryCacheInRedis.ts +1 -1
  138. package/src/storages/inRedis/constants.ts +3 -0
  139. package/src/storages/inRedis/index.ts +14 -6
  140. package/src/storages/inRedis/uniqueKeysCacheInRedis.ts +61 -0
  141. package/src/storages/pluggable/EventsCachePluggable.ts +4 -4
  142. package/src/storages/pluggable/ImpressionsCachePluggable.ts +1 -1
  143. package/src/storages/pluggable/SegmentsCachePluggable.ts +1 -1
  144. package/src/storages/pluggable/SplitsCachePluggable.ts +1 -1
  145. package/src/storages/pluggable/TelemetryCachePluggable.ts +1 -1
  146. package/src/storages/pluggable/index.ts +3 -3
  147. package/src/storages/pluggable/wrapperAdapter.ts +1 -1
  148. package/src/storages/types.ts +45 -50
  149. package/src/sync/offline/LocalhostFromObject.ts +4 -4
  150. package/src/sync/offline/splitsParser/splitsParserFromSettings.ts +8 -8
  151. package/src/sync/polling/updaters/mySegmentsUpdater.ts +1 -1
  152. package/src/sync/polling/updaters/segmentChangesUpdater.ts +1 -1
  153. package/src/sync/polling/updaters/splitChangesUpdater.ts +1 -1
  154. package/src/sync/streaming/SSEHandler/index.ts +1 -1
  155. package/src/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.ts +1 -1
  156. package/src/sync/streaming/UpdateWorkers/SplitsUpdateWorker.ts +1 -1
  157. package/src/sync/submitters/submitter.ts +1 -1
  158. package/src/sync/submitters/submitterManager.ts +2 -0
  159. package/src/sync/submitters/telemetrySubmitter.ts +4 -3
  160. package/src/sync/submitters/types.ts +22 -3
  161. package/src/sync/submitters/uniqueKeysSubmitter.ts +35 -0
  162. package/src/sync/syncTask.ts +1 -1
  163. package/src/trackers/eventTracker.ts +3 -3
  164. package/src/trackers/impressionsTracker.ts +30 -51
  165. package/src/trackers/strategy/strategyDebug.ts +28 -0
  166. package/src/trackers/strategy/strategyNone.ts +34 -0
  167. package/src/trackers/strategy/strategyOptimized.ts +42 -0
  168. package/src/trackers/types.ts +30 -4
  169. package/src/trackers/uniqueKeysTracker.ts +37 -0
  170. package/src/types.ts +1265 -0
  171. package/src/utils/constants/index.ts +3 -1
  172. package/src/utils/inputValidation/apiKey.ts +1 -1
  173. package/src/utils/inputValidation/attribute.ts +1 -1
  174. package/src/utils/inputValidation/attributes.ts +3 -3
  175. package/src/utils/inputValidation/event.ts +1 -1
  176. package/src/utils/inputValidation/eventProperties.ts +3 -3
  177. package/src/utils/inputValidation/eventValue.ts +1 -1
  178. package/src/utils/inputValidation/isOperational.ts +1 -1
  179. package/src/utils/inputValidation/key.ts +3 -3
  180. package/src/utils/inputValidation/preloadedData.ts +3 -3
  181. package/src/utils/inputValidation/split.ts +1 -1
  182. package/src/utils/inputValidation/splitExistance.ts +1 -1
  183. package/src/utils/inputValidation/splits.ts +1 -1
  184. package/src/utils/inputValidation/trafficType.ts +1 -1
  185. package/src/utils/inputValidation/trafficTypeExistance.ts +1 -1
  186. package/src/utils/key/index.ts +9 -9
  187. package/src/utils/settingsValidation/consent.ts +2 -1
  188. package/src/utils/settingsValidation/impressionsMode.ts +6 -6
  189. package/src/utils/settingsValidation/index.ts +4 -1
  190. package/src/utils/settingsValidation/integrations/common.ts +1 -1
  191. package/src/utils/settingsValidation/integrations/configurable.ts +1 -1
  192. package/src/utils/settingsValidation/integrations/pluggable.ts +2 -1
  193. package/src/utils/settingsValidation/localhost/builtin.ts +2 -1
  194. package/src/utils/settingsValidation/localhost/pluggable.ts +2 -1
  195. package/src/utils/settingsValidation/logger/builtinLogger.ts +2 -1
  196. package/src/utils/settingsValidation/logger/pluggableLogger.ts +2 -1
  197. package/src/utils/settingsValidation/splitFilters.ts +9 -7
  198. package/src/utils/settingsValidation/storage/storageCS.ts +2 -1
  199. package/types/consent/index.d.ts +2 -0
  200. package/types/consent/sdkUserConsent.d.ts +13 -0
  201. package/types/dtos/types.d.ts +172 -0
  202. package/types/evaluator/Engine.d.ts +15 -0
  203. package/types/evaluator/combiners/and.d.ts +4 -0
  204. package/types/evaluator/combiners/ifelseif.d.ts +3 -0
  205. package/types/evaluator/condition/engineUtils.d.ts +11 -0
  206. package/types/evaluator/condition/index.d.ts +6 -0
  207. package/types/evaluator/convertions/index.d.ts +2 -0
  208. package/types/evaluator/index.d.ts +7 -0
  209. package/types/evaluator/matchers/all.d.ts +2 -0
  210. package/types/evaluator/matchers/between.d.ts +3 -0
  211. package/types/evaluator/matchers/boolean.d.ts +2 -0
  212. package/types/evaluator/matchers/cont_all.d.ts +2 -0
  213. package/types/evaluator/matchers/cont_any.d.ts +2 -0
  214. package/types/evaluator/matchers/cont_str.d.ts +2 -0
  215. package/types/evaluator/matchers/dependency.d.ts +5 -0
  216. package/types/evaluator/matchers/eq.d.ts +2 -0
  217. package/types/evaluator/matchers/eq_set.d.ts +2 -0
  218. package/types/evaluator/matchers/ew.d.ts +2 -0
  219. package/types/evaluator/matchers/gte.d.ts +2 -0
  220. package/types/evaluator/matchers/index.d.ts +7 -0
  221. package/types/evaluator/matchers/lte.d.ts +2 -0
  222. package/types/evaluator/matchers/matcherTypes.d.ts +10 -0
  223. package/types/evaluator/matchers/part_of.d.ts +2 -0
  224. package/types/evaluator/matchers/segment.d.ts +6 -0
  225. package/types/evaluator/matchers/string.d.ts +2 -0
  226. package/types/evaluator/matchers/sw.d.ts +2 -0
  227. package/types/evaluator/matchers/whitelist.d.ts +3 -0
  228. package/types/evaluator/matchersTransform/index.d.ts +6 -0
  229. package/types/evaluator/matchersTransform/segment.d.ts +5 -0
  230. package/types/evaluator/matchersTransform/set.d.ts +5 -0
  231. package/types/evaluator/matchersTransform/unaryNumeric.d.ts +5 -0
  232. package/types/evaluator/matchersTransform/whitelist.d.ts +5 -0
  233. package/types/evaluator/parser/index.d.ts +5 -0
  234. package/types/evaluator/treatments/index.d.ts +8 -0
  235. package/types/evaluator/types.d.ts +28 -0
  236. package/types/evaluator/value/index.d.ts +7 -0
  237. package/types/evaluator/value/sanitize.d.ts +7 -0
  238. package/types/index.d.ts +5 -0
  239. package/types/integrations/browser.d.ts +12 -0
  240. package/types/integrations/ga/GaToSplit.d.ts +40 -0
  241. package/types/integrations/ga/GoogleAnalyticsToSplit.d.ts +3 -0
  242. package/types/integrations/ga/SplitToGa.d.ts +34 -0
  243. package/types/integrations/ga/SplitToGoogleAnalytics.d.ts +3 -0
  244. package/types/integrations/ga/types.d.ts +148 -0
  245. package/types/integrations/pluggable.d.ts +11 -0
  246. package/types/integrations/types.d.ts +17 -0
  247. package/types/listeners/browser.d.ts +40 -0
  248. package/types/listeners/node.d.ts +22 -0
  249. package/types/listeners/types.d.ts +4 -0
  250. package/types/logger/browser/DebugLogger.d.ts +2 -0
  251. package/types/logger/browser/ErrorLogger.d.ts +2 -0
  252. package/types/logger/browser/InfoLogger.d.ts +2 -0
  253. package/types/logger/browser/WarnLogger.d.ts +2 -0
  254. package/types/logger/constants.d.ts +142 -0
  255. package/types/logger/index.d.ts +22 -0
  256. package/types/logger/messages/debug.d.ts +1 -0
  257. package/types/logger/messages/error.d.ts +1 -0
  258. package/types/logger/messages/info.d.ts +1 -0
  259. package/types/logger/messages/warn.d.ts +1 -0
  260. package/types/logger/sdkLogger.d.ts +8 -0
  261. package/types/logger/types.d.ts +17 -0
  262. package/types/readiness/constants.d.ts +7 -0
  263. package/types/readiness/readinessManager.d.ts +6 -0
  264. package/types/readiness/sdkReadinessManager.d.ts +11 -0
  265. package/types/readiness/types.d.ts +60 -0
  266. package/types/sdkClient/client.d.ts +6 -0
  267. package/types/sdkClient/clientAttributesDecoration.d.ts +51 -0
  268. package/types/sdkClient/clientCS.d.ts +10 -0
  269. package/types/sdkClient/clientInputValidation.d.ts +7 -0
  270. package/types/sdkClient/sdkClient.d.ts +6 -0
  271. package/types/sdkClient/sdkClientMethod.d.ts +6 -0
  272. package/types/sdkClient/sdkClientMethodCS.d.ts +7 -0
  273. package/types/sdkClient/sdkClientMethodCSWithTT.d.ts +8 -0
  274. package/types/sdkClient/types.d.ts +18 -0
  275. package/types/sdkFactory/index.d.ts +6 -0
  276. package/types/sdkFactory/types.d.ts +82 -0
  277. package/types/sdkManager/index.d.ts +5 -0
  278. package/types/services/splitApi.d.ts +11 -0
  279. package/types/services/splitHttpClient.d.ts +10 -0
  280. package/types/services/types.d.ts +54 -0
  281. package/types/storages/AbstractSegmentsCacheSync.d.ts +55 -0
  282. package/types/storages/AbstractSplitsCacheAsync.d.ts +36 -0
  283. package/types/storages/AbstractSplitsCacheSync.d.ts +42 -0
  284. package/types/storages/KeyBuilder.d.ts +14 -0
  285. package/types/storages/KeyBuilderCS.d.ts +16 -0
  286. package/types/storages/KeyBuilderSS.d.ts +17 -0
  287. package/types/storages/dataLoader.d.ts +10 -0
  288. package/types/storages/findLatencyIndex.d.ts +7 -0
  289. package/types/storages/inLocalStorage/MySegmentsCacheInLocal.d.ts +25 -0
  290. package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +51 -0
  291. package/types/storages/inLocalStorage/constants.d.ts +2 -0
  292. package/types/storages/inLocalStorage/index.d.ts +8 -0
  293. package/types/storages/inMemory/AttributesCacheInMemory.d.ts +43 -0
  294. package/types/storages/inMemory/CountsCacheInMemory.d.ts +20 -0
  295. package/types/storages/inMemory/EventsCacheInMemory.d.ts +35 -0
  296. package/types/storages/inMemory/ImpressionCountsCacheInMemory.d.ts +28 -0
  297. package/types/storages/inMemory/ImpressionsCacheInMemory.d.ts +30 -0
  298. package/types/storages/inMemory/InMemoryStorage.d.ts +10 -0
  299. package/types/storages/inMemory/InMemoryStorageCS.d.ts +10 -0
  300. package/types/storages/inMemory/LatenciesCacheInMemory.d.ts +20 -0
  301. package/types/storages/inMemory/MySegmentsCacheInMemory.d.ts +22 -0
  302. package/types/storages/inMemory/SegmentsCacheInMemory.d.ts +19 -0
  303. package/types/storages/inMemory/SplitsCacheInMemory.d.ts +20 -0
  304. package/types/storages/inMemory/TelemetryCacheInMemory.d.ts +53 -0
  305. package/types/storages/inMemory/uniqueKeysCacheInMemory.d.ts +35 -0
  306. package/types/storages/inMemory/uniqueKeysCacheInMemoryCS.d.ts +37 -0
  307. package/types/storages/inRedis/CountsCacheInRedis.d.ts +9 -0
  308. package/types/storages/inRedis/EventsCacheInRedis.d.ts +32 -0
  309. package/types/storages/inRedis/ImpressionCountsCacheInRedis.d.ts +13 -0
  310. package/types/storages/inRedis/ImpressionsCacheInRedis.d.ts +18 -0
  311. package/types/storages/inRedis/LatenciesCacheInRedis.d.ts +9 -0
  312. package/types/storages/inRedis/RedisAdapter.d.ts +24 -0
  313. package/types/storages/inRedis/SegmentsCacheInRedis.d.ts +18 -0
  314. package/types/storages/inRedis/SplitsCacheInRedis.d.ts +91 -0
  315. package/types/storages/inRedis/TelemetryCacheInRedis.d.ts +20 -0
  316. package/types/storages/inRedis/constants.d.ts +4 -0
  317. package/types/storages/inRedis/index.d.ts +10 -0
  318. package/types/storages/inRedis/uniqueKeysCacheInRedis.d.ts +14 -0
  319. package/types/storages/metadataBuilder.d.ts +3 -0
  320. package/types/storages/pluggable/EventsCachePluggable.d.ts +38 -0
  321. package/types/storages/pluggable/ImpressionsCachePluggable.d.ts +35 -0
  322. package/types/storages/pluggable/SegmentsCachePluggable.d.ts +54 -0
  323. package/types/storages/pluggable/SplitsCachePluggable.d.ts +89 -0
  324. package/types/storages/pluggable/TelemetryCachePluggable.d.ts +18 -0
  325. package/types/storages/pluggable/constants.d.ts +1 -0
  326. package/types/storages/pluggable/inMemoryWrapper.d.ts +13 -0
  327. package/types/storages/pluggable/index.d.ts +9 -0
  328. package/types/storages/pluggable/wrapperAdapter.d.ts +12 -0
  329. package/types/storages/types.d.ts +414 -0
  330. package/types/sync/offline/LocalhostFromFile.d.ts +2 -0
  331. package/types/sync/offline/LocalhostFromObject.d.ts +2 -0
  332. package/types/sync/offline/splitsParser/parseCondition.d.ts +7 -0
  333. package/types/sync/offline/splitsParser/splitsParserFromFile.d.ts +2 -0
  334. package/types/sync/offline/splitsParser/splitsParserFromSettings.d.ts +3 -0
  335. package/types/sync/offline/splitsParser/types.d.ts +3 -0
  336. package/types/sync/offline/syncManagerOffline.d.ts +10 -0
  337. package/types/sync/offline/syncTasks/fromObjectSyncTask.d.ts +17 -0
  338. package/types/sync/polling/fetchers/mySegmentsFetcher.d.ts +7 -0
  339. package/types/sync/polling/fetchers/segmentChangesFetcher.d.ts +7 -0
  340. package/types/sync/polling/fetchers/splitChangesFetcher.d.ts +7 -0
  341. package/types/sync/polling/fetchers/types.d.ts +5 -0
  342. package/types/sync/polling/pollingManagerCS.d.ts +7 -0
  343. package/types/sync/polling/pollingManagerSS.d.ts +6 -0
  344. package/types/sync/polling/syncTasks/mySegmentsSyncTask.d.ts +9 -0
  345. package/types/sync/polling/syncTasks/segmentsSyncTask.d.ts +9 -0
  346. package/types/sync/polling/syncTasks/splitsSyncTask.d.ts +9 -0
  347. package/types/sync/polling/types.d.ts +26 -0
  348. package/types/sync/polling/updaters/mySegmentsUpdater.d.ts +13 -0
  349. package/types/sync/polling/updaters/segmentChangesUpdater.d.ts +18 -0
  350. package/types/sync/polling/updaters/splitChangesUpdater.d.ts +39 -0
  351. package/types/sync/streaming/AuthClient/index.d.ts +12 -0
  352. package/types/sync/streaming/AuthClient/types.d.ts +17 -0
  353. package/types/sync/streaming/SSEClient/index.d.ts +34 -0
  354. package/types/sync/streaming/SSEClient/types.d.ts +11 -0
  355. package/types/sync/streaming/SSEHandler/NotificationKeeper.d.ts +14 -0
  356. package/types/sync/streaming/SSEHandler/NotificationParser.d.ts +20 -0
  357. package/types/sync/streaming/SSEHandler/index.d.ts +11 -0
  358. package/types/sync/streaming/SSEHandler/types.d.ts +67 -0
  359. package/types/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.d.ts +6 -0
  360. package/types/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.d.ts +8 -0
  361. package/types/sync/streaming/UpdateWorkers/SplitsUpdateWorker.d.ts +12 -0
  362. package/types/sync/streaming/UpdateWorkers/constants.d.ts +3 -0
  363. package/types/sync/streaming/UpdateWorkers/types.d.ts +4 -0
  364. package/types/sync/streaming/constants.d.ts +34 -0
  365. package/types/sync/streaming/mySegmentsV2utils.d.ts +27 -0
  366. package/types/sync/streaming/pushManager.d.ts +9 -0
  367. package/types/sync/streaming/types.d.ts +35 -0
  368. package/types/sync/submitters/eventsSubmitter.d.ts +5 -0
  369. package/types/sync/submitters/eventsSyncTask.d.ts +8 -0
  370. package/types/sync/submitters/impressionCountsSubmitter.d.ts +10 -0
  371. package/types/sync/submitters/impressionCountsSubmitterInRedis.d.ts +5 -0
  372. package/types/sync/submitters/impressionCountsSyncTask.d.ts +13 -0
  373. package/types/sync/submitters/impressionsSubmitter.d.ts +11 -0
  374. package/types/sync/submitters/impressionsSyncTask.d.ts +14 -0
  375. package/types/sync/submitters/metricsSyncTask.d.ts +12 -0
  376. package/types/sync/submitters/submitter.d.ts +12 -0
  377. package/types/sync/submitters/submitterManager.d.ts +3 -0
  378. package/types/sync/submitters/submitterSyncTask.d.ts +10 -0
  379. package/types/sync/submitters/telemetrySubmitter.d.ts +25 -0
  380. package/types/sync/submitters/types.d.ts +194 -0
  381. package/types/sync/submitters/uniqueKeysSubmitter.d.ts +5 -0
  382. package/types/sync/submitters/uniqueKeysSubmitterInRedis.d.ts +5 -0
  383. package/types/sync/syncManagerOnline.d.ts +13 -0
  384. package/types/sync/syncTask.d.ts +13 -0
  385. package/types/sync/syncTaskComposite.d.ts +5 -0
  386. package/types/sync/types.d.ts +43 -0
  387. package/types/trackers/eventTracker.d.ts +10 -0
  388. package/types/trackers/filter/bloomFilter.d.ts +10 -0
  389. package/types/trackers/filter/dictionaryFilter.d.ts +8 -0
  390. package/types/trackers/filter/types.d.ts +5 -0
  391. package/types/trackers/impressionObserver/ImpressionObserver.d.ts +8 -0
  392. package/types/trackers/impressionObserver/buildKey.d.ts +2 -0
  393. package/types/trackers/impressionObserver/impressionObserverCS.d.ts +4 -0
  394. package/types/trackers/impressionObserver/impressionObserverSS.d.ts +4 -0
  395. package/types/trackers/impressionObserver/types.d.ts +4 -0
  396. package/types/trackers/impressionObserver/utils.d.ts +13 -0
  397. package/types/trackers/impressionsTracker.d.ts +13 -0
  398. package/types/trackers/strategy/strategyDebug.d.ts +9 -0
  399. package/types/trackers/strategy/strategyNone.d.ts +10 -0
  400. package/types/trackers/strategy/strategyOptimized.d.ts +11 -0
  401. package/types/trackers/telemetryTracker.d.ts +3 -0
  402. package/types/trackers/types.d.ts +57 -0
  403. package/types/trackers/uniqueKeysTracker.d.ts +13 -0
  404. package/types/types.d.ts +1263 -0
  405. package/types/utils/Backoff.d.ts +25 -0
  406. package/types/utils/LRUCache/LinkedList.d.ts +34 -0
  407. package/types/utils/LRUCache/index.d.ts +16 -0
  408. package/types/utils/MinEventEmitter.d.ts +12 -0
  409. package/types/utils/MinEvents.d.ts +4 -0
  410. package/types/utils/base64/index.d.ts +30 -0
  411. package/types/utils/constants/browser.d.ts +3 -0
  412. package/types/utils/constants/index.d.ts +64 -0
  413. package/types/utils/decompress/index.d.ts +16 -0
  414. package/types/utils/env/isLocalStorageAvailable.d.ts +1 -0
  415. package/types/utils/env/isNode.d.ts +5 -0
  416. package/types/utils/inputValidation/apiKey.d.ts +7 -0
  417. package/types/utils/inputValidation/attribute.d.ts +2 -0
  418. package/types/utils/inputValidation/attributes.d.ts +4 -0
  419. package/types/utils/inputValidation/event.d.ts +2 -0
  420. package/types/utils/inputValidation/eventProperties.d.ts +6 -0
  421. package/types/utils/inputValidation/eventValue.d.ts +2 -0
  422. package/types/utils/inputValidation/index.d.ts +13 -0
  423. package/types/utils/inputValidation/isOperational.d.ts +4 -0
  424. package/types/utils/inputValidation/key.d.ts +3 -0
  425. package/types/utils/inputValidation/preloadedData.d.ts +3 -0
  426. package/types/utils/inputValidation/split.d.ts +2 -0
  427. package/types/utils/inputValidation/splitExistance.d.ts +7 -0
  428. package/types/utils/inputValidation/splits.d.ts +2 -0
  429. package/types/utils/inputValidation/trafficType.d.ts +2 -0
  430. package/types/utils/inputValidation/trafficTypeExistance.d.ts +9 -0
  431. package/types/utils/jwt/index.d.ts +5 -0
  432. package/types/utils/jwt/types.d.ts +5 -0
  433. package/types/utils/key/index.d.ts +8 -0
  434. package/types/utils/labels/index.d.ts +7 -0
  435. package/types/utils/lang/binarySearch.d.ts +9 -0
  436. package/types/utils/lang/getFnName.d.ts +4 -0
  437. package/types/utils/lang/getGlobal.d.ts +4 -0
  438. package/types/utils/lang/index.d.ts +105 -0
  439. package/types/utils/lang/maps.d.ts +55 -0
  440. package/types/utils/lang/objectAssign.d.ts +3 -0
  441. package/types/utils/lang/sets.d.ts +60 -0
  442. package/types/utils/murmur3/common.d.ts +12 -0
  443. package/types/utils/murmur3/legacy.d.ts +2 -0
  444. package/types/utils/murmur3/murmur3.d.ts +2 -0
  445. package/types/utils/murmur3/murmur3_128.d.ts +6 -0
  446. package/types/utils/murmur3/murmur3_128_x86.d.ts +7 -0
  447. package/types/utils/murmur3/murmur3_64.d.ts +10 -0
  448. package/types/utils/murmur3/utfx.d.ts +27 -0
  449. package/types/utils/promise/thenable.d.ts +1 -0
  450. package/types/utils/promise/timeout.d.ts +1 -0
  451. package/types/utils/promise/wrapper.d.ts +21 -0
  452. package/types/utils/settingsValidation/consent.d.ts +6 -0
  453. package/types/utils/settingsValidation/impressionsMode.d.ts +3 -0
  454. package/types/utils/settingsValidation/index.d.ts +52 -0
  455. package/types/utils/settingsValidation/integrations/common.d.ts +14 -0
  456. package/types/utils/settingsValidation/integrations/configurable.d.ts +13 -0
  457. package/types/utils/settingsValidation/integrations/pluggable.d.ts +13 -0
  458. package/types/utils/settingsValidation/localhost/builtin.d.ts +16 -0
  459. package/types/utils/settingsValidation/localhost/pluggable.d.ts +16 -0
  460. package/types/utils/settingsValidation/logger/builtinLogger.d.ts +10 -0
  461. package/types/utils/settingsValidation/logger/commons.d.ts +9 -0
  462. package/types/utils/settingsValidation/logger/pluggableLogger.d.ts +11 -0
  463. package/types/utils/settingsValidation/mode.d.ts +1 -0
  464. package/types/utils/settingsValidation/runtime.d.ts +2 -0
  465. package/types/utils/settingsValidation/splitFilters.d.ts +16 -0
  466. package/types/utils/settingsValidation/storage/storageCS.d.ts +21 -0
  467. package/types/utils/settingsValidation/types.d.ts +32 -0
  468. package/types/utils/settingsValidation/url.d.ts +10 -0
  469. package/types/utils/time/index.d.ts +4 -0
  470. package/types/utils/timeTracker/index.d.ts +70 -0
  471. package/types/utils/timeTracker/now/browser.d.ts +1 -0
  472. package/types/utils/timeTracker/now/node.d.ts +1 -0
  473. package/types/utils/timeTracker/timer.d.ts +1 -0
  474. package/src/logger/.DS_Store +0 -0
  475. package/src/types.d.ts +0 -1581
@@ -39,8 +39,8 @@ function createUserConsentAPI(params) {
39
39
  if (events.clear)
40
40
  events.clear(); // @ts-ignore
41
41
  if (impressions.clear)
42
- impressions.clear();
43
- if (impressionCounts)
42
+ impressions.clear(); // @ts-ignore
43
+ if (impressionCounts && impressionCounts.clear)
44
44
  impressionCounts.clear();
45
45
  }
46
46
  }
@@ -74,9 +74,10 @@ var BrowserSignalListener = /** @class */ (function () {
74
74
  // Flush impressions & events data if there is user consent
75
75
  if ((0, consent_1.isConsentGranted)(this.settings)) {
76
76
  var eventsUrl = this.settings.urls.events;
77
+ var sim = this.settings.sync.impressionsMode;
77
78
  var extraMetadata = {
78
79
  // sim stands for Sync/Split Impressions Mode
79
- sim: this.settings.sync.impressionsMode === constants_1.OPTIMIZED ? constants_1.OPTIMIZED : constants_1.DEBUG
80
+ sim: sim === constants_1.OPTIMIZED ? constants_1.OPTIMIZED : sim === constants_1.DEBUG ? constants_1.DEBUG : constants_1.NONE
80
81
  };
81
82
  this._flushData(eventsUrl + '/testImpressions/beacon', this.storage.impressions, this.serviceApi.postTestImpressionsBulk, this.fromImpressionsCollector, extraMetadata);
82
83
  this._flushData(eventsUrl + '/events/beacon', this.storage.events, this.serviceApi.postEventsBulk);
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SYNC_SPLITS_FETCH_RETRY = exports.POLLING_STOP = exports.POLLING_START = exports.POLLING_SMART_PAUSING = exports.NEW_FACTORY = exports.NEW_SHARED_CLIENT = exports.IMPRESSION_QUEUEING = exports.IMPRESSION = exports.CLIENT_READY = exports.CLIENT_READY_FROM_CACHE = exports.SETTINGS_SPLITS_FILTER = exports.SYNC_TASK_STOP = exports.SYNC_TASK_EXECUTE = exports.SYNC_TASK_START = exports.STREAMING_NEW_MESSAGE = exports.SYNC_SPLITS_SEGMENTS = exports.SYNC_SPLITS_REMOVED = exports.SYNC_SPLITS_NEW = exports.SYNC_SPLITS_FETCH = exports.SYNC_OFFLINE_DATA = exports.RETRIEVE_MANAGER = exports.RETRIEVE_CLIENT_EXISTING = exports.RETRIEVE_CLIENT_DEFAULT = exports.CLEANUP_DEREGISTERING = exports.CLEANUP_REGISTERING = exports.ENGINE_SANITIZE = exports.ENGINE_VALUE = exports.ENGINE_MATCHER_WHITELIST = exports.ENGINE_MATCHER_STARTS_WITH = exports.ENGINE_MATCHER_STRING_INVALID = exports.ENGINE_MATCHER_STRING = exports.ENGINE_MATCHER_SEGMENT = exports.ENGINE_MATCHER_PART_OF = exports.ENGINE_MATCHER_LESS = exports.ENGINE_MATCHER_GREATER = exports.ENGINE_MATCHER_ENDS_WITH = exports.ENGINE_MATCHER_EQUAL_TO_SET = exports.ENGINE_MATCHER_EQUAL = exports.ENGINE_MATCHER_DEPENDENCY_PRE = exports.ENGINE_MATCHER_DEPENDENCY = exports.ENGINE_MATCHER_CONTAINS_STRING = exports.ENGINE_MATCHER_CONTAINS_ANY = exports.ENGINE_MATCHER_CONTAINS_ALL = exports.ENGINE_MATCHER_BOOLEAN = exports.ENGINE_MATCHER_BETWEEN = exports.ENGINE_MATCHER_ALL = exports.ENGINE_BUCKET = exports.ENGINE_COMBINER_IFELSEIF_NO_TREATMENT = exports.ENGINE_COMBINER_IFELSEIF = exports.ENGINE_COMBINER_AND = void 0;
4
4
  exports.ERROR_EVENT_TYPE_FORMAT = exports.ERROR_EVENTS_TRACKER = exports.ERROR_IMPRESSIONS_LISTENER = exports.ERROR_IMPRESSIONS_TRACKER = exports.ERROR_STREAMING_AUTH = exports.ERROR_STREAMING_SSE = exports.ERROR_SYNC_OFFLINE_LOADING = exports.ERROR_CLIENT_CANNOT_GET_READY = exports.ERROR_CLIENT_LISTENER = exports.ERROR_LOGLEVEL_INVALID = exports.ERROR_ENGINE_COMBINER_IFELSEIF = exports.STREAMING_PARSING_MY_SEGMENTS_UPDATE_V2 = exports.WARN_API_KEY = exports.WARN_SPLITS_FILTER_EMPTY = exports.WARN_SPLITS_FILTER_INVALID = exports.WARN_SPLITS_FILTER_IGNORED = exports.WARN_INTEGRATION_INVALID = exports.WARN_NOT_EXISTENT_TT = exports.WARN_LOWERCASE_TRAFFIC_TYPE = exports.WARN_NOT_EXISTENT_SPLIT = exports.WARN_TRIMMING = exports.WARN_CONVERTING = exports.WARN_TRIMMING_PROPERTIES = exports.WARN_SETTING_NULL = exports.SUBMITTERS_PUSH_RETRY = exports.SUBMITTERS_PUSH_FAILS = exports.STREAMING_FALLBACK = exports.STREAMING_PARSING_MESSAGE_FAILS = exports.STREAMING_PARSING_ERROR_FAILS = exports.SYNC_SPLITS_FETCH_FAILS = exports.SYNC_MYSEGMENTS_FETCH_RETRY = exports.CLIENT_NOT_READY = exports.CLIENT_NO_LISTENER = exports.ENGINE_VALUE_NO_ATTRIBUTES = exports.ENGINE_VALUE_INVALID = exports.USER_CONSENT_INITIAL = exports.USER_CONSENT_NOT_UPDATED = exports.USER_CONSENT_UPDATED = exports.IMPRESSIONS_TRACKER_SUCCESS = exports.EVENTS_TRACKER_SUCCESS = exports.SYNC_STOP_POLLING = exports.SYNC_CONTINUE_POLLING = exports.SYNC_START_POLLING = exports.SUBMITTERS_PUSH = exports.SUBMITTERS_PUSH_FULL_QUEUE = exports.STREAMING_DISCONNECTING = exports.STREAMING_DISABLED = exports.STREAMING_CONNECTING = exports.STREAMING_RECONNECT = exports.STREAMING_REFRESH_TOKEN = void 0;
5
- exports.LOG_PREFIX_CLEANUP = exports.LOG_PREFIX_EVENTS_TRACKER = exports.LOG_PREFIX_IMPRESSIONS_TRACKER = exports.LOG_PREFIX_SYNC_SUBMITTERS = exports.LOG_PREFIX_SYNC_POLLING = exports.LOG_PREFIX_SYNC_MYSEGMENTS = exports.LOG_PREFIX_SYNC_SEGMENTS = exports.LOG_PREFIX_SYNC_SPLITS = exports.LOG_PREFIX_SYNC_STREAMING = exports.LOG_PREFIX_SYNC_OFFLINE = exports.LOG_PREFIX_SYNC_MANAGER = exports.LOG_PREFIX_SYNC = exports.LOG_PREFIX_ENGINE_VALUE = exports.LOG_PREFIX_ENGINE_MATCHER = exports.LOG_PREFIX_ENGINE_COMBINER = exports.LOG_PREFIX_ENGINE = exports.LOG_PREFIX_INSTANTIATION = exports.LOG_PREFIX_SETTINGS = exports.ERROR_MIN_CONFIG_PARAM = exports.ERROR_NOT_BOOLEAN = exports.ERROR_STORAGE_INVALID = exports.ERROR_LOCALHOST_MODULE_REQUIRED = exports.ERROR_HTTP = exports.ERROR_INVALID_CONFIG_PARAM = exports.ERROR_EMPTY_ARRAY = exports.ERROR_EMPTY = exports.ERROR_INVALID = exports.ERROR_INVALID_KEY_OBJECT = exports.ERROR_TOO_LONG = exports.ERROR_NULL = exports.ERROR_CLIENT_DESTROYED = exports.ERROR_NOT_FINITE = exports.ERROR_SIZE_EXCEEDED = exports.ERROR_NOT_PLAIN_OBJECT = void 0;
5
+ exports.LOG_PREFIX_CLEANUP = exports.LOG_PREFIX_UNIQUE_KEYS_TRACKER = exports.LOG_PREFIX_EVENTS_TRACKER = exports.LOG_PREFIX_IMPRESSIONS_TRACKER = exports.LOG_PREFIX_SYNC_SUBMITTERS = exports.LOG_PREFIX_SYNC_POLLING = exports.LOG_PREFIX_SYNC_MYSEGMENTS = exports.LOG_PREFIX_SYNC_SEGMENTS = exports.LOG_PREFIX_SYNC_SPLITS = exports.LOG_PREFIX_SYNC_STREAMING = exports.LOG_PREFIX_SYNC_OFFLINE = exports.LOG_PREFIX_SYNC_MANAGER = exports.LOG_PREFIX_SYNC = exports.LOG_PREFIX_ENGINE_VALUE = exports.LOG_PREFIX_ENGINE_MATCHER = exports.LOG_PREFIX_ENGINE_COMBINER = exports.LOG_PREFIX_ENGINE = exports.LOG_PREFIX_INSTANTIATION = exports.LOG_PREFIX_SETTINGS = exports.ERROR_MIN_CONFIG_PARAM = exports.ERROR_NOT_BOOLEAN = exports.ERROR_STORAGE_INVALID = exports.ERROR_LOCALHOST_MODULE_REQUIRED = exports.ERROR_HTTP = exports.ERROR_INVALID_CONFIG_PARAM = exports.ERROR_EMPTY_ARRAY = exports.ERROR_EMPTY = exports.ERROR_INVALID = exports.ERROR_INVALID_KEY_OBJECT = exports.ERROR_TOO_LONG = exports.ERROR_NULL = exports.ERROR_CLIENT_DESTROYED = exports.ERROR_NOT_FINITE = exports.ERROR_SIZE_EXCEEDED = exports.ERROR_NOT_PLAIN_OBJECT = void 0;
6
6
  /**
7
7
  * Message codes used to trim string log messages from commons and client-side API modules,
8
8
  * in order to reduce the minimal SDK size for Browser and eventually other client-side environments.
@@ -144,4 +144,5 @@ exports.LOG_PREFIX_SYNC_POLLING = exports.LOG_PREFIX_SYNC + ':polling-manager: '
144
144
  exports.LOG_PREFIX_SYNC_SUBMITTERS = exports.LOG_PREFIX_SYNC + ':submitter: ';
145
145
  exports.LOG_PREFIX_IMPRESSIONS_TRACKER = 'impressions-tracker: ';
146
146
  exports.LOG_PREFIX_EVENTS_TRACKER = 'events-tracker: ';
147
+ exports.LOG_PREFIX_UNIQUE_KEYS_TRACKER = 'unique-keys-tracker: ';
147
148
  exports.LOG_PREFIX_CLEANUP = 'cleanup: ';
@@ -47,7 +47,7 @@ function clientAttributesDecoration(log, client) {
47
47
  * Add an attribute to client's in memory attributes storage
48
48
  *
49
49
  * @param {string} attributeName Attrinute name
50
- * @param {AttributeType} attributeValue Attribute value
50
+ * @param {string, number, boolean, list} attributeValue Attribute value
51
51
  * @returns {boolean} true if the attribute was stored and false otherways
52
52
  */
53
53
  setAttribute: function (attributeName, attributeValue) {
@@ -13,11 +13,16 @@ var constants_1 = require("../logger/constants");
13
13
  var metadataBuilder_1 = require("../storages/metadataBuilder");
14
14
  var constants_2 = require("../readiness/constants");
15
15
  var objectAssign_1 = require("../utils/lang/objectAssign");
16
+ var strategyDebug_1 = require("../trackers/strategy/strategyDebug");
17
+ var strategyOptimized_1 = require("../trackers/strategy/strategyOptimized");
18
+ var strategyNone_1 = require("../trackers/strategy/strategyNone");
19
+ var uniqueKeysTracker_1 = require("../trackers/uniqueKeysTracker");
20
+ var constants_3 = require("../utils/constants");
16
21
  /**
17
22
  * Modular SDK factory
18
23
  */
19
24
  function sdkFactory(params) {
20
- var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory;
25
+ var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory, filterAdapterFactory = params.filterAdapterFactory;
21
26
  var log = settings.log;
22
27
  // @TODO handle non-recoverable errors, such as, global `fetch` not available, invalid API Key, etc.
23
28
  // On non-recoverable errors, we should mark the SDK as destroyed and not start synchronization.
@@ -29,13 +34,14 @@ function sdkFactory(params) {
29
34
  var storageFactoryParams = {
30
35
  impressionsQueueSize: settings.scheduler.impressionsQueueSize,
31
36
  eventsQueueSize: settings.scheduler.eventsQueueSize,
37
+ uniqueKeysCacheSize: settings.scheduler.uniqueKeysCacheSize,
32
38
  optimize: (0, utils_1.shouldBeOptimized)(settings),
33
39
  // ATM, only used by InLocalStorage
34
40
  matchingKey: (0, key_1.getMatching)(settings.core.key),
35
- // @ts-ignore
36
41
  splitFiltersValidation: settings.sync.__splitFiltersValidation,
37
42
  // ATM, only used by PluggableStorage
38
43
  mode: settings.mode,
44
+ impressionsMode: settings.sync.impressionsMode,
39
45
  // Callback used to emit SDK_READY in consumer mode, where `syncManagerFactory` is undefined,
40
46
  // or partial consumer mode, where it only has submitters, and therefore it doesn't emit readiness events.
41
47
  onReadyCb: function (error) {
@@ -50,14 +56,25 @@ function sdkFactory(params) {
50
56
  var storage = storageFactory(storageFactoryParams);
51
57
  // @TODO add support for dataloader: `if (params.dataLoader) params.dataLoader(storage);`
52
58
  var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage });
53
- // trackers
54
- var observer = impressionsObserverFactory && impressionsObserverFactory();
55
- var impressionsTracker = (0, impressionsTracker_1.impressionsTrackerFactory)(settings, storage.impressions, integrationsManager, observer, storage.impressionCounts, storage.telemetry);
59
+ var observer = impressionsObserverFactory();
60
+ var uniqueKeysTracker = storageFactoryParams.impressionsMode === constants_3.NONE ? (0, uniqueKeysTracker_1.uniqueKeysTrackerFactory)(log, storage.uniqueKeys, filterAdapterFactory && filterAdapterFactory()) : undefined;
61
+ var strategy;
62
+ switch (storageFactoryParams.impressionsMode) {
63
+ case constants_3.OPTIMIZED:
64
+ strategy = (0, strategyOptimized_1.strategyOptimizedFactory)(observer, storage.impressionCounts);
65
+ break;
66
+ case constants_3.NONE:
67
+ strategy = (0, strategyNone_1.strategyNoneFactory)(storage.impressionCounts, uniqueKeysTracker);
68
+ break;
69
+ default:
70
+ strategy = (0, strategyDebug_1.strategyDebugFactory)(observer);
71
+ }
72
+ var impressionsTracker = (0, impressionsTracker_1.impressionsTrackerFactory)(settings, storage.impressions, strategy, integrationsManager, storage.telemetry);
56
73
  var eventTracker = (0, eventTracker_1.eventTrackerFactory)(settings, storage.events, integrationsManager, storage.telemetry);
57
74
  var telemetryTracker = (0, telemetryTracker_1.telemetryTrackerFactory)(storage.telemetry, platform.now);
58
75
  // splitApi is used by SyncManager and Browser signal listener
59
76
  var splitApi = splitApiFactory && splitApiFactory(settings, platform, telemetryTracker);
60
- var ctx = { splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
77
+ var ctx = { splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, uniqueKeysTracker: uniqueKeysTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
61
78
  var syncManager = syncManagerFactory && syncManagerFactory(ctx);
62
79
  ctx.syncManager = syncManager;
63
80
  var signalListener = SignalListener && new SignalListener(syncManager, settings, storage, splitApi);
@@ -16,7 +16,6 @@ function userKeyToQueryParam(userKey) {
16
16
  */
17
17
  function splitApiFactory(settings, platform, telemetryTracker) {
18
18
  var urls = settings.urls;
19
- // @ts-ignore
20
19
  var filterQueryString = settings.sync.__splitFiltersValidation && settings.sync.__splitFiltersValidation.queryString;
21
20
  var SplitSDKImpressionsMode = settings.sync.impressionsMode;
22
21
  var splitHttpClient = (0, splitHttpClient_1.splitHttpClientFactory)(settings, platform.getFetch, platform.getOptions);
@@ -91,6 +90,26 @@ function splitApiFactory(settings, platform, telemetryTracker) {
91
90
  var url = urls.events + "/testImpressions/count";
92
91
  return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(constants_1.IMPRESSIONS_COUNT));
93
92
  },
93
+ /**
94
+ * Post unique keys for client side.
95
+ *
96
+ * @param body unique keys payload
97
+ * @param headers Optionals headers to overwrite default ones. For example, it is used in producer mode to overwrite metadata headers.
98
+ */
99
+ postUniqueKeysBulkCs: function (body, headers) {
100
+ var url = urls.telemetry + "/v1/keys/cs";
101
+ return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(constants_1.TELEMETRY));
102
+ },
103
+ /**
104
+ * Post unique keys for server side.
105
+ *
106
+ * @param body unique keys payload
107
+ * @param headers Optionals headers to overwrite default ones. For example, it is used in producer mode to overwrite metadata headers.
108
+ */
109
+ postUniqueKeysBulkSs: function (body, headers) {
110
+ var url = urls.telemetry + "/v1/keys/ss";
111
+ return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(constants_1.TELEMETRY));
112
+ },
94
113
  postMetricsConfig: function (body) {
95
114
  var url = urls.telemetry + "/v1/metrics/config";
96
115
  return splitHttpClient(url, { method: 'POST', body: body }, telemetryTracker.trackHttp(constants_1.TELEMETRY), true);
@@ -23,6 +23,12 @@ var KeyBuilderSS = /** @class */ (function (_super) {
23
23
  KeyBuilderSS.prototype.buildImpressionsKey = function () {
24
24
  return this.prefix + ".impressions";
25
25
  };
26
+ KeyBuilderSS.prototype.buildImpressionsCountKey = function () {
27
+ return this.prefix + ".impressions.count";
28
+ };
29
+ KeyBuilderSS.prototype.buildUniqueKeysKey = function () {
30
+ return this.prefix + ".uniquekeys";
31
+ };
26
32
  KeyBuilderSS.prototype.buildEventsKey = function () {
27
33
  return this.prefix + ".events";
28
34
  };
@@ -16,6 +16,7 @@ var InMemoryStorageCS_1 = require("../inMemory/InMemoryStorageCS");
16
16
  var constants_1 = require("./constants");
17
17
  var constants_2 = require("../../utils/constants");
18
18
  var TelemetryCacheInMemory_1 = require("../inMemory/TelemetryCacheInMemory");
19
+ var uniqueKeysCacheInMemoryCS_1 = require("../inMemory/uniqueKeysCacheInMemoryCS");
19
20
  /**
20
21
  * InLocal storage factory for standalone client-side SplitFactory
21
22
  */
@@ -38,12 +39,15 @@ function InLocalStorage(options) {
38
39
  impressionCounts: params.optimize ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
39
40
  events: new EventsCacheInMemory_1.EventsCacheInMemory(params.eventsQueueSize),
40
41
  telemetry: params.mode !== constants_2.LOCALHOST_MODE && (0, TelemetryCacheInMemory_1.shouldRecordTelemetry)() ? new TelemetryCacheInMemory_1.TelemetryCacheInMemory() : undefined,
42
+ uniqueKeys: params.impressionsMode === constants_2.NONE ? new uniqueKeysCacheInMemoryCS_1.UniqueKeysCacheInMemoryCS() : undefined,
41
43
  destroy: function () {
44
+ var _a;
42
45
  this.splits = new SplitsCacheInMemory_1.SplitsCacheInMemory();
43
46
  this.segments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
44
47
  this.impressions.clear();
45
48
  this.impressionCounts && this.impressionCounts.clear();
46
49
  this.events.clear();
50
+ (_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
47
51
  },
48
52
  // When using shared instanciation with MEMORY we reuse everything but segments (they are customer per key).
49
53
  shared: function (matchingKey) {
@@ -39,7 +39,7 @@ var AttributesCacheInMemory = /** @class */ (function () {
39
39
  /**
40
40
  * Retrieve the full attributes map
41
41
  *
42
- * @returns {Map<string, AttributeType>} stored attributes
42
+ * @returns {Map<string, Object>} stored attributes
43
43
  */
44
44
  AttributesCacheInMemory.prototype.getAll = function () {
45
45
  return this.attributesCache;
@@ -2,9 +2,13 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ImpressionCountsCacheInMemory = void 0;
4
4
  var time_1 = require("../../utils/time");
5
+ var constants_1 = require("../inRedis/constants");
5
6
  var ImpressionCountsCacheInMemory = /** @class */ (function () {
6
- function ImpressionCountsCacheInMemory() {
7
+ function ImpressionCountsCacheInMemory(impressionCountsCacheSize) {
8
+ if (impressionCountsCacheSize === void 0) { impressionCountsCacheSize = constants_1.DEFAULT_CACHE_SIZE; }
7
9
  this.cache = {};
10
+ this.cacheSize = 0;
11
+ this.maxStorage = impressionCountsCacheSize;
8
12
  }
9
13
  /**
10
14
  * Builds key to be stored in the cache with the featureName and the timeFrame truncated.
@@ -19,6 +23,13 @@ var ImpressionCountsCacheInMemory = /** @class */ (function () {
19
23
  var key = this._makeKey(featureName, timeFrame);
20
24
  var currentAmount = this.cache[key];
21
25
  this.cache[key] = currentAmount ? currentAmount + amount : amount;
26
+ if (this.onFullQueue) {
27
+ this.cacheSize = this.cacheSize + amount;
28
+ if (this.cacheSize >= this.maxStorage) {
29
+ this.onFullQueue();
30
+ this.cacheSize = 0;
31
+ }
32
+ }
22
33
  };
23
34
  /**
24
35
  * Pop the collected data, used as payload for posting.
@@ -8,6 +8,7 @@ var EventsCacheInMemory_1 = require("./EventsCacheInMemory");
8
8
  var ImpressionCountsCacheInMemory_1 = require("./ImpressionCountsCacheInMemory");
9
9
  var constants_1 = require("../../utils/constants");
10
10
  var TelemetryCacheInMemory_1 = require("./TelemetryCacheInMemory");
11
+ var uniqueKeysCacheInMemory_1 = require("./uniqueKeysCacheInMemory");
11
12
  /**
12
13
  * InMemory storage factory for standalone server-side SplitFactory
13
14
  *
@@ -18,16 +19,19 @@ function InMemoryStorageFactory(params) {
18
19
  splits: new SplitsCacheInMemory_1.SplitsCacheInMemory(),
19
20
  segments: new SegmentsCacheInMemory_1.SegmentsCacheInMemory(),
20
21
  impressions: new ImpressionsCacheInMemory_1.ImpressionsCacheInMemory(params.impressionsQueueSize),
21
- impressionCounts: params.optimize ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
22
+ impressionCounts: params.impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
22
23
  events: new EventsCacheInMemory_1.EventsCacheInMemory(params.eventsQueueSize),
23
24
  telemetry: params.mode !== constants_1.LOCALHOST_MODE ? new TelemetryCacheInMemory_1.TelemetryCacheInMemory() : undefined,
25
+ uniqueKeys: params.impressionsMode === constants_1.NONE ? new uniqueKeysCacheInMemory_1.UniqueKeysCacheInMemory(params.uniqueKeysCacheSize) : undefined,
24
26
  // When using MEMORY we should clean all the caches to leave them empty
25
27
  destroy: function () {
28
+ var _a;
26
29
  this.splits.clear();
27
30
  this.segments.clear();
28
31
  this.impressions.clear();
29
32
  this.impressionCounts && this.impressionCounts.clear();
30
33
  this.events.clear();
34
+ (_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
31
35
  }
32
36
  };
33
37
  }
@@ -8,6 +8,7 @@ var EventsCacheInMemory_1 = require("./EventsCacheInMemory");
8
8
  var ImpressionCountsCacheInMemory_1 = require("./ImpressionCountsCacheInMemory");
9
9
  var constants_1 = require("../../utils/constants");
10
10
  var TelemetryCacheInMemory_1 = require("./TelemetryCacheInMemory");
11
+ var uniqueKeysCacheInMemoryCS_1 = require("./uniqueKeysCacheInMemoryCS");
11
12
  /**
12
13
  * InMemory storage factory for standalone client-side SplitFactory
13
14
  *
@@ -18,16 +19,19 @@ function InMemoryStorageCSFactory(params) {
18
19
  splits: new SplitsCacheInMemory_1.SplitsCacheInMemory(),
19
20
  segments: new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory(),
20
21
  impressions: new ImpressionsCacheInMemory_1.ImpressionsCacheInMemory(params.impressionsQueueSize),
21
- impressionCounts: params.optimize ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
22
+ impressionCounts: params.impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
22
23
  events: new EventsCacheInMemory_1.EventsCacheInMemory(params.eventsQueueSize),
23
24
  telemetry: params.mode !== constants_1.LOCALHOST_MODE && (0, TelemetryCacheInMemory_1.shouldRecordTelemetry)() ? new TelemetryCacheInMemory_1.TelemetryCacheInMemory() : undefined,
25
+ uniqueKeys: params.impressionsMode === constants_1.NONE ? new uniqueKeysCacheInMemoryCS_1.UniqueKeysCacheInMemoryCS(params.uniqueKeysCacheSize) : undefined,
24
26
  // When using MEMORY we should clean all the caches to leave them empty
25
27
  destroy: function () {
28
+ var _a;
26
29
  this.splits.clear();
27
30
  this.segments.clear();
28
31
  this.impressions.clear();
29
32
  this.impressionCounts && this.impressionCounts.clear();
30
33
  this.events.clear();
34
+ (_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
31
35
  },
32
36
  // When using shared instanciation with MEMORY we reuse everything but segments (they are unique per key)
33
37
  shared: function () {
@@ -0,0 +1,73 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UniqueKeysCacheInMemory = void 0;
4
+ var sets_1 = require("../../utils/lang/sets");
5
+ var constants_1 = require("../inRedis/constants");
6
+ var UniqueKeysCacheInMemory = /** @class */ (function () {
7
+ function UniqueKeysCacheInMemory(uniqueKeysQueueSize) {
8
+ if (uniqueKeysQueueSize === void 0) { uniqueKeysQueueSize = constants_1.DEFAULT_CACHE_SIZE; }
9
+ this.uniqueTrackerSize = 0;
10
+ this.maxStorage = uniqueKeysQueueSize;
11
+ this.uniqueKeysTracker = {};
12
+ }
13
+ UniqueKeysCacheInMemory.prototype.setOnFullQueueCb = function (cb) {
14
+ this.onFullQueue = cb;
15
+ };
16
+ /**
17
+ * Store unique keys in sequential order
18
+ * key: string = feature name.
19
+ * value: Set<string> = set of unique keys.
20
+ */
21
+ UniqueKeysCacheInMemory.prototype.track = function (key, featureName) {
22
+ if (!this.uniqueKeysTracker[featureName])
23
+ this.uniqueKeysTracker[featureName] = new sets_1._Set();
24
+ var tracker = this.uniqueKeysTracker[featureName];
25
+ if (!tracker.has(key)) {
26
+ tracker.add(key);
27
+ this.uniqueTrackerSize++;
28
+ }
29
+ if (this.uniqueTrackerSize >= this.maxStorage && this.onFullQueue) {
30
+ this.uniqueTrackerSize = 0;
31
+ this.onFullQueue();
32
+ }
33
+ };
34
+ /**
35
+ * Clear the data stored on the cache.
36
+ */
37
+ UniqueKeysCacheInMemory.prototype.clear = function () {
38
+ this.uniqueKeysTracker = {};
39
+ };
40
+ /**
41
+ * Pop the collected data, used as payload for posting.
42
+ */
43
+ UniqueKeysCacheInMemory.prototype.pop = function () {
44
+ var data = this.uniqueKeysTracker;
45
+ this.uniqueKeysTracker = {};
46
+ return this.fromUniqueKeysCollector(data);
47
+ };
48
+ /**
49
+ * Check if the cache is empty.
50
+ */
51
+ UniqueKeysCacheInMemory.prototype.isEmpty = function () {
52
+ return Object.keys(this.uniqueKeysTracker).length === 0;
53
+ };
54
+ /**
55
+ * Converts `uniqueKeys` data from cache into request payload for SS.
56
+ */
57
+ UniqueKeysCacheInMemory.prototype.fromUniqueKeysCollector = function (uniqueKeys) {
58
+ var payload = [];
59
+ var featureNames = Object.keys(uniqueKeys);
60
+ for (var i = 0; i < featureNames.length; i++) {
61
+ var featureName = featureNames[i];
62
+ var featureKeys = (0, sets_1.setToArray)(uniqueKeys[featureName]);
63
+ var uniqueKeysPayload = {
64
+ f: featureName,
65
+ ks: featureKeys
66
+ };
67
+ payload.push(uniqueKeysPayload);
68
+ }
69
+ return { keys: payload };
70
+ };
71
+ return UniqueKeysCacheInMemory;
72
+ }());
73
+ exports.UniqueKeysCacheInMemory = UniqueKeysCacheInMemory;
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UniqueKeysCacheInMemoryCS = void 0;
4
+ var sets_1 = require("../../utils/lang/sets");
5
+ var constants_1 = require("../inRedis/constants");
6
+ var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
7
+ /**
8
+ *
9
+ * @param impressionsQueueSize number of queued impressions to call onFullQueueCb.
10
+ * Default value is 0, that means no maximum value, in case we want to avoid this being triggered.
11
+ */
12
+ function UniqueKeysCacheInMemoryCS(uniqueKeysQueueSize) {
13
+ if (uniqueKeysQueueSize === void 0) { uniqueKeysQueueSize = constants_1.DEFAULT_CACHE_SIZE; }
14
+ this.uniqueTrackerSize = 0;
15
+ this.maxStorage = uniqueKeysQueueSize;
16
+ this.uniqueKeysTracker = {};
17
+ }
18
+ UniqueKeysCacheInMemoryCS.prototype.setOnFullQueueCb = function (cb) {
19
+ this.onFullQueue = cb;
20
+ };
21
+ /**
22
+ * Store unique keys in sequential order
23
+ * key: string = key.
24
+ * value: HashSet<string> = set of split names.
25
+ */
26
+ UniqueKeysCacheInMemoryCS.prototype.track = function (key, featureName) {
27
+ if (!this.uniqueKeysTracker[key])
28
+ this.uniqueKeysTracker[key] = new sets_1._Set();
29
+ var tracker = this.uniqueKeysTracker[key];
30
+ if (!tracker.has(featureName)) {
31
+ tracker.add(featureName);
32
+ this.uniqueTrackerSize++;
33
+ }
34
+ if (this.uniqueTrackerSize >= this.maxStorage && this.onFullQueue) {
35
+ this.uniqueTrackerSize = 0;
36
+ this.onFullQueue();
37
+ }
38
+ };
39
+ /**
40
+ * Clear the data stored on the cache.
41
+ */
42
+ UniqueKeysCacheInMemoryCS.prototype.clear = function () {
43
+ this.uniqueKeysTracker = {};
44
+ };
45
+ /**
46
+ * Pop the collected data, used as payload for posting.
47
+ */
48
+ UniqueKeysCacheInMemoryCS.prototype.pop = function () {
49
+ var data = this.uniqueKeysTracker;
50
+ this.uniqueKeysTracker = {};
51
+ return this.fromUniqueKeysCollector(data);
52
+ };
53
+ /**
54
+ * Check if the cache is empty.
55
+ */
56
+ UniqueKeysCacheInMemoryCS.prototype.isEmpty = function () {
57
+ return Object.keys(this.uniqueKeysTracker).length === 0;
58
+ };
59
+ /**
60
+ * Converts `uniqueKeys` data from cache into request payload.
61
+ */
62
+ UniqueKeysCacheInMemoryCS.prototype.fromUniqueKeysCollector = function (uniqueKeys) {
63
+ var payload = [];
64
+ var featureKeys = Object.keys(uniqueKeys);
65
+ for (var k = 0; k < featureKeys.length; k++) {
66
+ var featureKey = featureKeys[k];
67
+ var featureNames = (0, sets_1.setToArray)(uniqueKeys[featureKey]);
68
+ var uniqueKeysPayload = {
69
+ k: featureKey,
70
+ fs: featureNames
71
+ };
72
+ payload.push(uniqueKeysPayload);
73
+ }
74
+ return { keys: payload };
75
+ };
76
+ return UniqueKeysCacheInMemoryCS;
77
+ }());
78
+ exports.UniqueKeysCacheInMemoryCS = UniqueKeysCacheInMemoryCS;
@@ -0,0 +1,46 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.ImpressionCountsCacheInRedis = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var ImpressionCountsCacheInMemory_1 = require("../inMemory/ImpressionCountsCacheInMemory");
6
+ var constants_1 = require("./constants");
7
+ var ImpressionCountsCacheInRedis = /** @class */ (function (_super) {
8
+ (0, tslib_1.__extends)(ImpressionCountsCacheInRedis, _super);
9
+ function ImpressionCountsCacheInRedis(log, key, redis, impressionCountsCacheSize) {
10
+ var _this = _super.call(this, impressionCountsCacheSize) || this;
11
+ _this.log = log;
12
+ _this.key = key;
13
+ _this.redis = redis;
14
+ _this.onFullQueue = function () { _this.postImpressionCountsInRedis(); };
15
+ return _this;
16
+ }
17
+ ImpressionCountsCacheInRedis.prototype.postImpressionCountsInRedis = function () {
18
+ var _this = this;
19
+ var counts = this.pop();
20
+ var keys = Object.keys(counts);
21
+ var pipeline = this.redis.pipeline();
22
+ keys.forEach(function (key) {
23
+ pipeline.hincrby(_this.key, key, counts[key]);
24
+ });
25
+ return pipeline.exec()
26
+ .then(function (data) {
27
+ // If this is the creation of the key on Redis, set the expiration for it in 3600 seconds.
28
+ if (data.length && data.length === keys.length) {
29
+ return _this.redis.expire(_this.key, constants_1.TTL_REFRESH);
30
+ }
31
+ })
32
+ .catch(function (err) {
33
+ _this.log.error(constants_1.LOG_PREFIX + "Error in impression counts pipeline: " + err + ".");
34
+ return false;
35
+ });
36
+ };
37
+ ImpressionCountsCacheInRedis.prototype.start = function (refreshRate) {
38
+ if (refreshRate === void 0) { refreshRate = constants_1.REFRESH_RATE; }
39
+ this.handle = setInterval(this.postImpressionCountsInRedis.bind(this), refreshRate);
40
+ };
41
+ ImpressionCountsCacheInRedis.prototype.stop = function () {
42
+ clearInterval(this.handle);
43
+ };
44
+ return ImpressionCountsCacheInRedis;
45
+ }(ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory));
46
+ exports.ImpressionCountsCacheInRedis = ImpressionCountsCacheInRedis;
@@ -1,4 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.LOG_PREFIX = void 0;
3
+ exports.TTL_REFRESH = exports.REFRESH_RATE = exports.DEFAULT_CACHE_SIZE = exports.LOG_PREFIX = void 0;
4
4
  exports.LOG_PREFIX = 'storage:redis: ';
5
+ exports.DEFAULT_CACHE_SIZE = 30000;
6
+ exports.REFRESH_RATE = 300000; // 300.000 ms = start after 5 mins
7
+ exports.TTL_REFRESH = 3600; // 1hr
@@ -10,6 +10,8 @@ var ImpressionsCacheInRedis_1 = require("./ImpressionsCacheInRedis");
10
10
  var EventsCacheInRedis_1 = require("./EventsCacheInRedis");
11
11
  var constants_1 = require("../../utils/constants");
12
12
  var TelemetryCacheInRedis_1 = require("./TelemetryCacheInRedis");
13
+ var uniqueKeysCacheInRedis_1 = require("./uniqueKeysCacheInRedis");
14
+ var ImpressionCountsCacheInRedis_1 = require("./ImpressionCountsCacheInRedis");
13
15
  /**
14
16
  * InRedis storage factory for consumer server-side SplitFactory, that uses `Ioredis` Redis client for Node.
15
17
  * @see {@link https://www.npmjs.com/package/ioredis}
@@ -18,13 +20,19 @@ function InRedisStorage(options) {
18
20
  if (options === void 0) { options = {}; }
19
21
  var prefix = (0, KeyBuilder_1.validatePrefix)(options.prefix);
20
22
  function InRedisStorageFactory(_a) {
21
- var log = _a.log, metadata = _a.metadata, onReadyCb = _a.onReadyCb;
23
+ var log = _a.log, metadata = _a.metadata, onReadyCb = _a.onReadyCb, impressionsMode = _a.impressionsMode;
22
24
  var keys = new KeyBuilderSS_1.KeyBuilderSS(prefix, metadata);
23
25
  var redisClient = new RedisAdapter_1.RedisAdapter(log, options.options || {});
24
26
  var telemetry = new TelemetryCacheInRedis_1.TelemetryCacheInRedis(log, keys, redisClient);
27
+ var impressionCountsCache = impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInRedis_1.ImpressionCountsCacheInRedis(log, keys.buildImpressionsCountKey(), redisClient) : undefined;
28
+ var uniqueKeysCache = impressionsMode === constants_1.NONE ? new uniqueKeysCacheInRedis_1.UniqueKeysCacheInRedis(log, keys.buildUniqueKeysKey(), redisClient) : undefined;
25
29
  // subscription to Redis connect event in order to emit SDK_READY event on consumer mode
26
30
  redisClient.on('connect', function () {
27
31
  onReadyCb();
32
+ if (impressionCountsCache)
33
+ impressionCountsCache.start();
34
+ if (uniqueKeysCache)
35
+ uniqueKeysCache.start();
28
36
  // Synchronize config
29
37
  telemetry.recordConfig();
30
38
  });
@@ -32,12 +40,18 @@ function InRedisStorage(options) {
32
40
  splits: new SplitsCacheInRedis_1.SplitsCacheInRedis(log, keys, redisClient),
33
41
  segments: new SegmentsCacheInRedis_1.SegmentsCacheInRedis(log, keys, redisClient),
34
42
  impressions: new ImpressionsCacheInRedis_1.ImpressionsCacheInRedis(log, keys.buildImpressionsKey(), redisClient, metadata),
43
+ impressionCounts: impressionCountsCache,
35
44
  events: new EventsCacheInRedis_1.EventsCacheInRedis(log, keys.buildEventsKey(), redisClient, metadata),
36
45
  telemetry: telemetry,
46
+ uniqueKeys: uniqueKeysCache,
37
47
  // When using REDIS we should:
38
48
  // 1- Disconnect from the storage
39
49
  destroy: function () {
40
50
  redisClient.disconnect();
51
+ if (impressionCountsCache)
52
+ impressionCountsCache.stop();
53
+ if (uniqueKeysCache)
54
+ uniqueKeysCache.stop();
41
55
  // @TODO check that caches works as expected when redisClient is disconnected
42
56
  }
43
57
  };
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.UniqueKeysCacheInRedis = void 0;
4
+ var tslib_1 = require("tslib");
5
+ var uniqueKeysCacheInMemory_1 = require("../inMemory/uniqueKeysCacheInMemory");
6
+ var sets_1 = require("../../utils/lang/sets");
7
+ var constants_1 = require("./constants");
8
+ var constants_2 = require("./constants");
9
+ var UniqueKeysCacheInRedis = /** @class */ (function (_super) {
10
+ (0, tslib_1.__extends)(UniqueKeysCacheInRedis, _super);
11
+ function UniqueKeysCacheInRedis(log, key, redis, uniqueKeysQueueSize) {
12
+ if (uniqueKeysQueueSize === void 0) { uniqueKeysQueueSize = constants_1.DEFAULT_CACHE_SIZE; }
13
+ var _this = _super.call(this, uniqueKeysQueueSize) || this;
14
+ _this.log = log;
15
+ _this.key = key;
16
+ _this.redis = redis;
17
+ _this.onFullQueue = function () { _this.postUniqueKeysInRedis(); };
18
+ return _this;
19
+ }
20
+ UniqueKeysCacheInRedis.prototype.postUniqueKeysInRedis = function () {
21
+ var _this = this;
22
+ var pipeline = this.redis.pipeline();
23
+ var featureNames = Object.keys(this.uniqueKeysTracker);
24
+ for (var i = 0; i < featureNames.length; i++) {
25
+ var featureName = featureNames[i];
26
+ var featureKeys = (0, sets_1.setToArray)(this.uniqueKeysTracker[featureName]);
27
+ var uniqueKeysPayload = {
28
+ f: featureName,
29
+ ks: featureKeys
30
+ };
31
+ pipeline.rpush(this.key, JSON.stringify(uniqueKeysPayload));
32
+ }
33
+ this.clear();
34
+ return pipeline.exec()
35
+ .then(function (data) {
36
+ // If this is the creation of the key on Redis, set the expiration for it in 3600 seconds.
37
+ if (data.length && data.length === featureNames.length) {
38
+ return _this.redis.expire(_this.key, constants_1.TTL_REFRESH);
39
+ }
40
+ })
41
+ .catch(function (err) {
42
+ _this.log.error(constants_2.LOG_PREFIX + "Error in uniqueKeys pipeline: " + err + ".");
43
+ return false;
44
+ });
45
+ };
46
+ UniqueKeysCacheInRedis.prototype.start = function (refreshRate) {
47
+ if (refreshRate === void 0) { refreshRate = constants_1.REFRESH_RATE; }
48
+ this.handle = setInterval(this.postUniqueKeysInRedis.bind(this), refreshRate);
49
+ };
50
+ UniqueKeysCacheInRedis.prototype.stop = function () {
51
+ clearInterval(this.handle);
52
+ };
53
+ return UniqueKeysCacheInRedis;
54
+ }(uniqueKeysCacheInMemory_1.UniqueKeysCacheInMemory));
55
+ exports.UniqueKeysCacheInRedis = UniqueKeysCacheInRedis;
@@ -5,6 +5,7 @@ var eventsSubmitter_1 = require("./eventsSubmitter");
5
5
  var impressionsSubmitter_1 = require("./impressionsSubmitter");
6
6
  var impressionCountsSubmitter_1 = require("./impressionCountsSubmitter");
7
7
  var telemetrySubmitter_1 = require("./telemetrySubmitter");
8
+ var uniqueKeysSubmitter_1 = require("./uniqueKeysSubmitter");
8
9
  function submitterManagerFactory(params) {
9
10
  var submitters = [
10
11
  (0, impressionsSubmitter_1.impressionsSubmitterFactory)(params),
@@ -14,6 +15,8 @@ function submitterManagerFactory(params) {
14
15
  if (impressionCountsSubmitter)
15
16
  submitters.push(impressionCountsSubmitter);
16
17
  var telemetrySubmitter = (0, telemetrySubmitter_1.telemetrySubmitterFactory)(params);
18
+ if (params.uniqueKeysTracker)
19
+ submitters.push((0, uniqueKeysSubmitter_1.uniqueKeysSubmitterFactory)(params));
17
20
  return {
18
21
  // `onlyTelemetry` true if SDK is created with userConsent not GRANTED
19
22
  start: function (onlyTelemetry) {
@@ -50,6 +50,7 @@ var OPERATION_MODE_MAP = (_a = {},
50
50
  var IMPRESSIONS_MODE_MAP = (_b = {},
51
51
  _b[constants_1.OPTIMIZED] = constants_1.OPTIMIZED_ENUM,
52
52
  _b[constants_1.DEBUG] = constants_1.DEBUG_ENUM,
53
+ _b[constants_1.NONE] = constants_1.NONE_ENUM,
53
54
  _b);
54
55
  var USER_CONSENT_MAP = (_c = {},
55
56
  _c[constants_1.CONSENT_UNKNOWN] = 1,