@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
@@ -0,0 +1,414 @@
1
+ import { MaybeThenable, IMetadata, ISplitFiltersValidation } from '../dtos/types';
2
+ import { ILogger } from '../logger/types';
3
+ import { EventDataType, HttpErrors, HttpLatencies, ImpressionDataType, LastSync, Method, MethodExceptions, MethodLatencies, OperationType, StoredEventWithMetadata, StoredImpressionWithMetadata, StreamingEvent, UniqueKeysPayloadCs, UniqueKeysPayloadSs } from '../sync/submitters/types';
4
+ import { SplitIO, ImpressionDTO, SDKMode } from '../types';
5
+ /**
6
+ * Interface of a pluggable storage wrapper.
7
+ */
8
+ export interface IPluggableStorageWrapper {
9
+ /** Key-Value operations */
10
+ /**
11
+ * Get the value of given `key`.
12
+ *
13
+ * @function get
14
+ * @param {string} key Item to retrieve
15
+ * @returns {Promise<string | null>} A promise that resolves with the element value associated with the specified `key`,
16
+ * or null if the key does not exist. The promise rejects if the operation fails.
17
+ */
18
+ get: (key: string) => Promise<string | null>;
19
+ /**
20
+ * Add or update an item with a specified `key` and `value`.
21
+ *
22
+ * @function set
23
+ * @param {string} key Item to update
24
+ * @param {string} value Value to set
25
+ * @returns {Promise<void>} A promise that resolves if the operation success, whether the key was added or updated.
26
+ * The promise rejects if the operation fails.
27
+ */
28
+ set: (key: string, value: string) => Promise<boolean | void>;
29
+ /**
30
+ * Add or update an item with a specified `key` and `value`.
31
+ *
32
+ * @function getAndSet
33
+ * @param {string} key Item to update
34
+ * @param {string} value Value to set
35
+ * @returns {Promise<string | null>} A promise that resolves with the previous value associated to the given `key`, or null if not set.
36
+ * The promise rejects if the operation fails.
37
+ */
38
+ getAndSet: (key: string, value: string) => Promise<string | null>;
39
+ /**
40
+ * Removes the specified item by `key`.
41
+ *
42
+ * @function del
43
+ * @param {string} key Item to delete
44
+ * @returns {Promise<void>} A promise that resolves if the operation success, whether the key existed and was removed or it didn't exist.
45
+ * The promise rejects if the operation fails, for example, if there is a connection error.
46
+ */
47
+ del: (key: string) => Promise<boolean | void>;
48
+ /**
49
+ * Returns all keys matching the given prefix.
50
+ *
51
+ * @function getKeysByPrefix
52
+ * @param {string} prefix String prefix to match
53
+ * @returns {Promise<string[]>} A promise that resolves with the list of keys that match the given `prefix`.
54
+ * The promise rejects if the operation fails.
55
+ */
56
+ getKeysByPrefix: (prefix: string) => Promise<string[]>;
57
+ /**
58
+ * Returns the values of all given `keys`.
59
+ *
60
+ * @function getMany
61
+ * @param {string[]} keys List of keys to retrieve
62
+ * @returns {Promise<(string | null)[]>} A promise that resolves with the list of items associated with the specified list of `keys`.
63
+ * For every key that does not hold a string value or does not exist, null is returned. The promise rejects if the operation fails.
64
+ */
65
+ getMany: (keys: string[]) => Promise<(string | null)[]>;
66
+ /** Integer operations */
67
+ /**
68
+ * Increments in 1 the given `key` value or set it to 1 if the value doesn't exist.
69
+ *
70
+ * @function incr
71
+ * @param {string} key Key to increment
72
+ * @returns {Promise<number>} A promise that resolves with the value of key after the increment. The promise rejects if the operation fails,
73
+ * for example, if there is a connection error or the key contains a string that can not be represented as integer.
74
+ */
75
+ incr: (key: string) => Promise<number>;
76
+ /**
77
+ * Decrements in 1 the given `key` value or set it to -1 if the value doesn't exist.
78
+ *
79
+ * @function decr
80
+ * @param {string} key Key to decrement
81
+ * @returns {Promise<number>} A promise that resolves with the value of key after the decrement. The promise rejects if the operation fails,
82
+ * for example, if there is a connection error or the key contains a string that can not be represented as integer.
83
+ */
84
+ decr: (key: string) => Promise<number>;
85
+ /** Queue operations */
86
+ /**
87
+ * Inserts given items at the tail of `key` list. If `key` does not exist, an empty list is created before pushing the items.
88
+ *
89
+ * @function pushItems
90
+ * @param {string} key List key
91
+ * @param {string[]} items List of items to push
92
+ * @returns {Promise<void>} A promise that resolves if the operation success.
93
+ * The promise rejects if the operation fails, for example, if there is a connection error or the key holds a value that is not a list.
94
+ */
95
+ pushItems: (key: string, items: string[]) => Promise<void>;
96
+ /**
97
+ * Removes and returns the first `count` items from a list. If `key` does not exist, an empty list is items is returned.
98
+ *
99
+ * @function popItems
100
+ * @param {string} key List key
101
+ * @param {number} count Number of items to pop
102
+ * @returns {Promise<string[]>} A promise that resolves with the list of removed items from the list, or an empty array when key does not exist.
103
+ * The promise rejects if the operation fails, for example, if there is a connection error or the key holds a value that is not a list.
104
+ */
105
+ popItems: (key: string, count: number) => Promise<string[]>;
106
+ /**
107
+ * Returns the count of items in a list, or 0 if `key` does not exist.
108
+ *
109
+ * @function getItemsCount
110
+ * @param {string} key List key
111
+ * @returns {Promise<number>} A promise that resolves with the number of items at the `key` list, or 0 when `key` does not exist.
112
+ * The promise rejects if the operation fails, for example, if there is a connection error or the key holds a value that is not a list.
113
+ */
114
+ getItemsCount: (key: string) => Promise<number>;
115
+ /** Set operations */
116
+ /**
117
+ * Returns if item is a member of a set.
118
+ *
119
+ * @function itemContains
120
+ * @param {string} key Set key
121
+ * @param {string} item Item value
122
+ * @returns {Promise<boolean>} A promise that resolves with true boolean value if `item` is a member of the set stored at `key`,
123
+ * or false if it is not a member or `key` set does not exist. The promise rejects if the operation fails, for example,
124
+ * if there is a connection error or the key holds a value that is not a set.
125
+ */
126
+ itemContains: (key: string, item: string) => Promise<boolean>;
127
+ /**
128
+ * Add the specified `items` to the set stored at `key`. Those items that are already part of the set are ignored.
129
+ * If key does not exist, an empty set is created before adding the items.
130
+ *
131
+ * @function addItems
132
+ * @param {string} key Set key
133
+ * @param {string} items Items to add
134
+ * @returns {Promise<boolean | void>} A promise that resolves if the operation success.
135
+ * The promise rejects if the operation fails, for example, if there is a connection error or the key holds a value that is not a set.
136
+ */
137
+ addItems: (key: string, items: string[]) => Promise<boolean | void>;
138
+ /**
139
+ * Remove the specified `items` from the set stored at `key`. Those items that are not part of the set are ignored.
140
+ *
141
+ * @function removeItems
142
+ * @param {string} key Set key
143
+ * @param {string} items Items to remove
144
+ * @returns {Promise<boolean | void>} A promise that resolves if the operation success. If key does not exist, the promise also resolves.
145
+ * The promise rejects if the operation fails, for example, if there is a connection error or the key holds a value that is not a set.
146
+ */
147
+ removeItems: (key: string, items: string[]) => Promise<boolean | void>;
148
+ /**
149
+ * Returns all the items of the `key` set.
150
+ *
151
+ * @function getItems
152
+ * @param {string} key Set key
153
+ * @returns {Promise<string[]>} A promise that resolves with the list of items. If key does not exist, the result is an empty list.
154
+ * The promise rejects if the operation fails, for example, if there is a connection error or the key holds a value that is not a set.
155
+ */
156
+ getItems: (key: string) => Promise<string[]>;
157
+ /** Control operations */
158
+ /**
159
+ * Connects to the underlying storage.
160
+ * It is meant for storages that requires to be connected to some database or server. Otherwise it can just return a resolved promise.
161
+ * Note: will be called once on SplitFactory instantiation and once per each shared client instantiation.
162
+ *
163
+ * @function connect
164
+ * @returns {Promise<void>} A promise that resolves when the wrapper successfully connect to the underlying storage.
165
+ * The promise rejects with the corresponding error if the wrapper fails to connect.
166
+ */
167
+ connect: () => Promise<void>;
168
+ /**
169
+ * Disconnects from the underlying storage.
170
+ * It is meant for storages that requires to be closed, in order to release resources. Otherwise it can just return a resolved promise.
171
+ * Note: will be called once on SplitFactory main client destroy.
172
+ *
173
+ * @function disconnect
174
+ * @returns {Promise<void>} A promise that resolves when the operation ends.
175
+ * The promise never rejects.
176
+ */
177
+ disconnect: () => Promise<void>;
178
+ }
179
+ /** Splits cache */
180
+ export interface ISplitsCacheBase {
181
+ addSplits(entries: [string, string][]): MaybeThenable<boolean[] | void>;
182
+ removeSplits(names: string[]): MaybeThenable<boolean[] | void>;
183
+ getSplit(name: string): MaybeThenable<string | null>;
184
+ getSplits(names: string[]): MaybeThenable<Record<string, string | null>>;
185
+ setChangeNumber(changeNumber: number): MaybeThenable<boolean | void>;
186
+ getChangeNumber(): MaybeThenable<number>;
187
+ getAll(): MaybeThenable<string[]>;
188
+ getSplitNames(): MaybeThenable<string[]>;
189
+ trafficTypeExists(trafficType: string): MaybeThenable<boolean>;
190
+ usesSegments(): MaybeThenable<boolean>;
191
+ clear(): MaybeThenable<boolean | void>;
192
+ checkCache(): MaybeThenable<boolean>;
193
+ killLocally(name: string, defaultTreatment: string, changeNumber: number): MaybeThenable<boolean>;
194
+ }
195
+ export interface ISplitsCacheSync extends ISplitsCacheBase {
196
+ addSplits(entries: [string, string][]): boolean[];
197
+ removeSplits(names: string[]): boolean[];
198
+ getSplit(name: string): string | null;
199
+ getSplits(names: string[]): Record<string, string | null>;
200
+ setChangeNumber(changeNumber: number): boolean;
201
+ getChangeNumber(): number;
202
+ getAll(): string[];
203
+ getSplitNames(): string[];
204
+ trafficTypeExists(trafficType: string): boolean;
205
+ usesSegments(): boolean;
206
+ clear(): void;
207
+ checkCache(): boolean;
208
+ killLocally(name: string, defaultTreatment: string, changeNumber: number): boolean;
209
+ }
210
+ export interface ISplitsCacheAsync extends ISplitsCacheBase {
211
+ addSplits(entries: [string, string][]): Promise<boolean[] | void>;
212
+ removeSplits(names: string[]): Promise<boolean[] | void>;
213
+ getSplit(name: string): Promise<string | null>;
214
+ getSplits(names: string[]): Promise<Record<string, string | null>>;
215
+ setChangeNumber(changeNumber: number): Promise<boolean | void>;
216
+ getChangeNumber(): Promise<number>;
217
+ getAll(): Promise<string[]>;
218
+ getSplitNames(): Promise<string[]>;
219
+ trafficTypeExists(trafficType: string): Promise<boolean>;
220
+ usesSegments(): Promise<boolean>;
221
+ clear(): Promise<boolean | void>;
222
+ checkCache(): Promise<boolean>;
223
+ killLocally(name: string, defaultTreatment: string, changeNumber: number): Promise<boolean>;
224
+ }
225
+ /** Segments cache */
226
+ export interface ISegmentsCacheBase {
227
+ addToSegment(name: string, segmentKeys: string[]): MaybeThenable<boolean | void>;
228
+ removeFromSegment(name: string, segmentKeys: string[]): MaybeThenable<boolean | void>;
229
+ isInSegment(name: string, key?: string): MaybeThenable<boolean>;
230
+ registerSegments(names: string[]): MaybeThenable<boolean | void>;
231
+ getRegisteredSegments(): MaybeThenable<string[]>;
232
+ setChangeNumber(name: string, changeNumber: number): MaybeThenable<boolean | void>;
233
+ getChangeNumber(name: string): MaybeThenable<number>;
234
+ clear(): MaybeThenable<boolean | void>;
235
+ }
236
+ export interface ISegmentsCacheSync extends ISegmentsCacheBase {
237
+ addToSegment(name: string, segmentKeys?: string[]): boolean;
238
+ removeFromSegment(name: string, segmentKeys?: string[]): boolean;
239
+ isInSegment(name: string, key?: string): boolean;
240
+ registerSegments(names: string[]): boolean;
241
+ getRegisteredSegments(): string[];
242
+ getKeysCount(): number;
243
+ setChangeNumber(name: string, changeNumber: number): boolean;
244
+ getChangeNumber(name: string): number;
245
+ resetSegments(names: string[]): boolean;
246
+ clear(): void;
247
+ }
248
+ export interface ISegmentsCacheAsync extends ISegmentsCacheBase {
249
+ addToSegment(name: string, segmentKeys: string[]): Promise<boolean | void>;
250
+ removeFromSegment(name: string, segmentKeys: string[]): Promise<boolean | void>;
251
+ isInSegment(name: string, key: string): Promise<boolean>;
252
+ registerSegments(names: string[]): Promise<boolean | void>;
253
+ getRegisteredSegments(): Promise<string[]>;
254
+ setChangeNumber(name: string, changeNumber: number): Promise<boolean | void>;
255
+ getChangeNumber(name: string): Promise<number>;
256
+ clear(): Promise<boolean | void>;
257
+ }
258
+ /** Recorder storages (impressions, events and telemetry) */
259
+ export interface IImpressionsCacheBase {
260
+ track(data: ImpressionDTO[]): MaybeThenable<void>;
261
+ }
262
+ export interface IEventsCacheBase {
263
+ track(data: SplitIO.EventData, size?: number): MaybeThenable<boolean>;
264
+ }
265
+ /** Impressions and events cache for standalone mode (sync) */
266
+ export interface IRecorderCacheProducerSync<T> {
267
+ isEmpty(): boolean;
268
+ clear(): void;
269
+ pop(toMerge?: T): T;
270
+ }
271
+ export interface IImpressionsCacheSync extends IImpressionsCacheBase, IRecorderCacheProducerSync<ImpressionDTO[]> {
272
+ track(data: ImpressionDTO[]): void;
273
+ setOnFullQueueCb(cb: () => void): void;
274
+ }
275
+ export interface IEventsCacheSync extends IEventsCacheBase, IRecorderCacheProducerSync<SplitIO.EventData[]> {
276
+ track(data: SplitIO.EventData, size?: number): boolean;
277
+ setOnFullQueueCb(cb: () => void): void;
278
+ }
279
+ /** Impressions and events cache for consumer and producer mode (async) */
280
+ export interface IRecorderCacheProducerAsync<T> {
281
+ count(): Promise<number>;
282
+ drop(count?: number): Promise<void>;
283
+ popNWithMetadata(count: number): Promise<T>;
284
+ }
285
+ export interface IImpressionsCacheAsync extends IImpressionsCacheBase, IRecorderCacheProducerAsync<StoredImpressionWithMetadata[]> {
286
+ track(data: ImpressionDTO[]): Promise<void>;
287
+ }
288
+ export interface IEventsCacheAsync extends IEventsCacheBase, IRecorderCacheProducerAsync<StoredEventWithMetadata[]> {
289
+ track(data: SplitIO.EventData, size?: number): Promise<boolean>;
290
+ }
291
+ /**
292
+ * Impression counts cache for impressions dedup in standalone and producer mode.
293
+ * Only in memory. Named `ImpressionsCounter` in spec.
294
+ */
295
+ export interface IImpressionCountsCacheSync extends IRecorderCacheProducerSync<Record<string, number>> {
296
+ track(featureName: string, timeFrame: number, amount: number): void;
297
+ isEmpty(): boolean;
298
+ pop(toMerge?: Record<string, number>): Record<string, number>;
299
+ }
300
+ export interface IUniqueKeysCacheBase {
301
+ track(key: string, value: string): void;
302
+ isEmpty(): boolean;
303
+ pop(): UniqueKeysPayloadSs | UniqueKeysPayloadCs;
304
+ setOnFullQueueCb(cb: () => void): void;
305
+ clear(): void;
306
+ }
307
+ /**
308
+ * Telemetry storage interface for standalone and partial consumer modes.
309
+ * Methods are sync because data is stored in memory.
310
+ */
311
+ export interface ITelemetryInitConsumerSync {
312
+ getTimeUntilReady(): number | undefined;
313
+ getTimeUntilReadyFromCache(): number | undefined;
314
+ getNonReadyUsage(): number;
315
+ }
316
+ export interface ITelemetryRuntimeConsumerSync {
317
+ getImpressionStats(type: ImpressionDataType): number;
318
+ getEventStats(type: EventDataType): number;
319
+ getLastSynchronization(): LastSync;
320
+ popHttpErrors(): HttpErrors;
321
+ popHttpLatencies(): HttpLatencies;
322
+ popAuthRejections(): number;
323
+ popTokenRefreshes(): number;
324
+ popStreamingEvents(): Array<StreamingEvent>;
325
+ popTags(): Array<string> | undefined;
326
+ getSessionLength(): number | undefined;
327
+ }
328
+ export interface ITelemetryEvaluationConsumerSync {
329
+ popExceptions(): MethodExceptions;
330
+ popLatencies(): MethodLatencies;
331
+ }
332
+ export interface ITelemetryStorageConsumerSync extends ITelemetryInitConsumerSync, ITelemetryRuntimeConsumerSync, ITelemetryEvaluationConsumerSync {
333
+ }
334
+ export interface ITelemetryInitProducerSync {
335
+ recordTimeUntilReady(ms: number): void;
336
+ recordTimeUntilReadyFromCache(ms: number): void;
337
+ recordNonReadyUsage(): void;
338
+ }
339
+ export interface ITelemetryRuntimeProducerSync {
340
+ addTag(tag: string): void;
341
+ recordImpressionStats(type: ImpressionDataType, count: number): void;
342
+ recordEventStats(type: EventDataType, count: number): void;
343
+ recordSuccessfulSync(resource: OperationType, timeMs: number): void;
344
+ recordHttpError(resource: OperationType, status: number): void;
345
+ recordHttpLatency(resource: OperationType, latencyMs: number): void;
346
+ recordAuthRejections(): void;
347
+ recordTokenRefreshes(): void;
348
+ recordStreamingEvents(streamingEvent: StreamingEvent): void;
349
+ recordSessionLength(ms: number): void;
350
+ }
351
+ export interface ITelemetryEvaluationProducerSync {
352
+ recordLatency(method: Method, latencyMs: number): void;
353
+ recordException(method: Method): void;
354
+ }
355
+ export interface ITelemetryStorageProducerSync extends ITelemetryInitProducerSync, ITelemetryRuntimeProducerSync, ITelemetryEvaluationProducerSync {
356
+ }
357
+ export interface ITelemetryCacheSync extends ITelemetryStorageConsumerSync, ITelemetryStorageProducerSync {
358
+ }
359
+ /**
360
+ * Telemetry storage interface for consumer mode.
361
+ * Methods are async because data is stored in Redis or a pluggable storage.
362
+ */
363
+ export interface ITelemetryEvaluationConsumerAsync {
364
+ popExceptions(): Promise<MethodExceptions>;
365
+ popLatencies(): Promise<MethodLatencies>;
366
+ }
367
+ export interface ITelemetryEvaluationProducerAsync {
368
+ recordLatency(method: Method, latencyMs: number): Promise<any>;
369
+ recordException(method: Method): Promise<any>;
370
+ }
371
+ export interface ITelemetryCacheAsync extends ITelemetryEvaluationProducerAsync {
372
+ }
373
+ /**
374
+ * Storages
375
+ */
376
+ export interface IStorageBase<TSplitsCache extends ISplitsCacheBase, TSegmentsCache extends ISegmentsCacheBase, TImpressionsCache extends IImpressionsCacheBase, TImpressionsCountCache extends IImpressionCountsCacheSync, TEventsCache extends IEventsCacheBase, TTelemetryCache extends ITelemetryCacheSync | ITelemetryCacheAsync, TUniqueKeysCache extends IUniqueKeysCacheBase> {
377
+ splits: TSplitsCache;
378
+ segments: TSegmentsCache;
379
+ impressions: TImpressionsCache;
380
+ impressionCounts?: TImpressionsCountCache;
381
+ events: TEventsCache;
382
+ telemetry?: TTelemetryCache;
383
+ uniqueKeys?: TUniqueKeysCache;
384
+ destroy(): void | Promise<void>;
385
+ shared?: (matchingKey: string, onReadyCb: (error?: any) => void) => this;
386
+ }
387
+ export interface IStorageSync extends IStorageBase<ISplitsCacheSync, ISegmentsCacheSync, IImpressionsCacheSync, IImpressionCountsCacheSync, IEventsCacheSync, ITelemetryCacheSync, IUniqueKeysCacheBase> {
388
+ }
389
+ export interface IStorageAsync extends IStorageBase<ISplitsCacheAsync, ISegmentsCacheAsync, IImpressionsCacheAsync | IImpressionsCacheSync, IImpressionCountsCacheSync, IEventsCacheAsync | IEventsCacheSync, ITelemetryCacheAsync, IUniqueKeysCacheBase> {
390
+ }
391
+ /** StorageFactory */
392
+ export declare type DataLoader = (storage: IStorageSync, matchingKey: string) => void;
393
+ export interface IStorageFactoryParams {
394
+ log: ILogger;
395
+ impressionsQueueSize?: number;
396
+ uniqueKeysCacheSize?: number;
397
+ eventsQueueSize?: number;
398
+ optimize?: boolean;
399
+ mode: SDKMode;
400
+ impressionsMode?: string;
401
+ matchingKey?: string;
402
+ splitFiltersValidation?: ISplitFiltersValidation;
403
+ onReadyCb: (error?: any) => void;
404
+ metadata: IMetadata;
405
+ }
406
+ export declare type StorageType = 'MEMORY' | 'LOCALSTORAGE' | 'REDIS' | 'PLUGGABLE';
407
+ export declare type IStorageSyncFactory = {
408
+ readonly type: StorageType;
409
+ (params: IStorageFactoryParams): IStorageSync;
410
+ };
411
+ export declare type IStorageAsyncFactory = {
412
+ type: StorageType;
413
+ (params: IStorageFactoryParams): IStorageAsync;
414
+ };
@@ -0,0 +1,2 @@
1
+ import { SplitIO } from '../../types';
2
+ export declare function LocalhostFromFile(): SplitIO.LocalhostFactory;
@@ -0,0 +1,2 @@
1
+ import { SplitIO } from '../../types';
2
+ export declare function LocalhostFromObject(): SplitIO.LocalhostFactory;
@@ -0,0 +1,7 @@
1
+ import { ISplitCondition } from '../../../dtos/types';
2
+ export interface IMockSplitEntry {
3
+ treatment: string;
4
+ keys?: string[];
5
+ config?: string;
6
+ }
7
+ export declare function parseCondition(data: IMockSplitEntry): ISplitCondition;
@@ -0,0 +1,2 @@
1
+ import { ISplitsParser } from './types';
2
+ export declare function splitsParserFromFileFactory(): ISplitsParser;
@@ -0,0 +1,3 @@
1
+ import { ISplitPartial } from '../../../dtos/types';
2
+ import { ISettings } from '../../../types';
3
+ export declare function splitsParserFromSettingsFactory(): (settings: ISettings) => false | Record<string, ISplitPartial>;
@@ -0,0 +1,3 @@
1
+ import { ISplitPartial } from '../../../dtos/types';
2
+ import { ISettings } from '../../../types';
3
+ export declare type ISplitsParser = (settings: ISettings) => false | Record<string, ISplitPartial>;
@@ -0,0 +1,10 @@
1
+ import { ISyncManagerCS } from '../types';
2
+ import { ISplitsParser } from './splitsParser/types';
3
+ import { ISdkFactoryContextSync } from '../../sdkFactory/types';
4
+ /**
5
+ * Offline SyncManager factory.
6
+ * Can be used for server-side API, and client-side API with or without multiple clients.
7
+ *
8
+ * @param splitsParser e.g., `splitsParserFromFile`, `splitsParserFromSettings`.
9
+ */
10
+ export declare function syncManagerOfflineFactory(splitsParserFactory: () => ISplitsParser): (params: ISdkFactoryContextSync) => ISyncManagerCS;
@@ -0,0 +1,17 @@
1
+ import { IReadinessManager } from '../../../readiness/types';
2
+ import { ISplitsCacheSync } from '../../../storages/types';
3
+ import { ISplitsParser } from '../splitsParser/types';
4
+ import { ISyncTask } from '../../types';
5
+ import { ISettings } from '../../../types';
6
+ /**
7
+ * Offline equivalent of `splitChangesUpdaterFactory`
8
+ */
9
+ export declare function fromObjectUpdaterFactory(splitsParser: ISplitsParser, storage: {
10
+ splits: ISplitsCacheSync;
11
+ }, readiness: IReadinessManager, settings: ISettings): () => Promise<boolean>;
12
+ /**
13
+ * PollingManager in Offline mode
14
+ */
15
+ export declare function fromObjectSyncTaskFactory(splitsParser: ISplitsParser, storage: {
16
+ splits: ISplitsCacheSync;
17
+ }, readiness: IReadinessManager, settings: ISettings): ISyncTask<[], boolean>;
@@ -0,0 +1,7 @@
1
+ import { IFetchMySegments } from '../../../services/types';
2
+ import { IMySegmentsFetcher } from './types';
3
+ /**
4
+ * Factory of MySegments fetcher.
5
+ * MySegments fetcher is a wrapper around `mySegments` API service that parses the response and handle errors.
6
+ */
7
+ export declare function mySegmentsFetcherFactory(fetchMySegments: IFetchMySegments): IMySegmentsFetcher;
@@ -0,0 +1,7 @@
1
+ import { IFetchSegmentChanges } from '../../../services/types';
2
+ import { ISegmentChangesFetcher } from './types';
3
+ /**
4
+ * Factory of SegmentChanges fetcher.
5
+ * SegmentChanges fetcher is a wrapper around `segmentChanges` API service that parses the response and handle errors and retries.
6
+ */
7
+ export declare function segmentChangesFetcherFactory(fetchSegmentChanges: IFetchSegmentChanges): ISegmentChangesFetcher;
@@ -0,0 +1,7 @@
1
+ import { IFetchSplitChanges } from '../../../services/types';
2
+ import { ISplitChangesFetcher } from './types';
3
+ /**
4
+ * Factory of SplitChanges fetcher.
5
+ * SplitChanges fetcher is a wrapper around `splitChanges` API service that parses the response and handle errors.
6
+ */
7
+ export declare function splitChangesFetcherFactory(fetchSplitChanges: IFetchSplitChanges): ISplitChangesFetcher;
@@ -0,0 +1,5 @@
1
+ import { ISplitChangesResponse, ISegmentChangesResponse } from '../../../dtos/types';
2
+ import { IResponse } from '../../../services/types';
3
+ export declare type ISplitChangesFetcher = (since: number, noCache?: boolean, till?: number, decorator?: (promise: Promise<IResponse>) => Promise<IResponse>) => Promise<ISplitChangesResponse>;
4
+ export declare type ISegmentChangesFetcher = (since: number, segmentName: string, noCache?: boolean, till?: number, decorator?: (promise: Promise<ISegmentChangesResponse[]>) => Promise<ISegmentChangesResponse[]>) => Promise<ISegmentChangesResponse[]>;
5
+ export declare type IMySegmentsFetcher = (userMatchingKey: string, noCache?: boolean, decorator?: (promise: Promise<IResponse>) => Promise<IResponse>) => Promise<string[]>;
@@ -0,0 +1,7 @@
1
+ import { IPollingManagerCS } from './types';
2
+ import { ISdkFactoryContextSync } from '../../sdkFactory/types';
3
+ /**
4
+ * Expose start / stop mechanism for polling data from services.
5
+ * For client-side API with multiple clients.
6
+ */
7
+ export declare function pollingManagerCSFactory(params: ISdkFactoryContextSync): IPollingManagerCS;
@@ -0,0 +1,6 @@
1
+ import { IPollingManager } from './types';
2
+ import { ISdkFactoryContextSync } from '../../sdkFactory/types';
3
+ /**
4
+ * Expose start / stop mechanism for pulling data from services.
5
+ */
6
+ export declare function pollingManagerSSFactory(params: ISdkFactoryContextSync): IPollingManager;
@@ -0,0 +1,9 @@
1
+ import { IStorageSync } from '../../../storages/types';
2
+ import { IReadinessManager } from '../../../readiness/types';
3
+ import { IMySegmentsSyncTask } from '../types';
4
+ import { IFetchMySegments } from '../../../services/types';
5
+ import { ISettings } from '../../../types';
6
+ /**
7
+ * Creates a sync task that periodically executes a `mySegmentsUpdater` task
8
+ */
9
+ export declare function mySegmentsSyncTaskFactory(fetchMySegments: IFetchMySegments, storage: IStorageSync, readiness: IReadinessManager, settings: ISettings, matchingKey: string): IMySegmentsSyncTask;
@@ -0,0 +1,9 @@
1
+ import { IStorageSync } from '../../../storages/types';
2
+ import { IReadinessManager } from '../../../readiness/types';
3
+ import { ISegmentsSyncTask } from '../types';
4
+ import { IFetchSegmentChanges } from '../../../services/types';
5
+ import { ISettings } from '../../../types';
6
+ /**
7
+ * Creates a sync task that periodically executes a `segmentChangesUpdater` task
8
+ */
9
+ export declare function segmentsSyncTaskFactory(fetchSegmentChanges: IFetchSegmentChanges, storage: IStorageSync, readiness: IReadinessManager, settings: ISettings): ISegmentsSyncTask;
@@ -0,0 +1,9 @@
1
+ import { IStorageSync } from '../../../storages/types';
2
+ import { IReadinessManager } from '../../../readiness/types';
3
+ import { ISplitsSyncTask } from '../types';
4
+ import { IFetchSplitChanges } from '../../../services/types';
5
+ import { ISettings } from '../../../types';
6
+ /**
7
+ * Creates a sync task that periodically executes a `splitChangesUpdater` task
8
+ */
9
+ export declare function splitsSyncTaskFactory(fetchSplitChanges: IFetchSplitChanges, storage: IStorageSync, readiness: IReadinessManager, settings: ISettings, isClientSide?: boolean): ISplitsSyncTask;
@@ -0,0 +1,26 @@
1
+ import { IReadinessManager } from '../../readiness/types';
2
+ import { IStorageSync } from '../../storages/types';
3
+ import { ITask, ISyncTask } from '../types';
4
+ export interface ISplitsSyncTask extends ISyncTask<[noCache?: boolean, till?: number], boolean> {
5
+ }
6
+ export interface ISegmentsSyncTask extends ISyncTask<[fetchOnlyNew?: boolean, segmentName?: string, noCache?: boolean, till?: number], boolean> {
7
+ }
8
+ export declare type MySegmentsData = string[] | {
9
+ name: string;
10
+ add: boolean;
11
+ };
12
+ export interface IMySegmentsSyncTask extends ISyncTask<[segmentsData?: MySegmentsData, noCache?: boolean], boolean> {
13
+ }
14
+ export interface IPollingManager extends ITask {
15
+ syncAll(): Promise<any>;
16
+ splitsSyncTask: ISplitsSyncTask;
17
+ segmentsSyncTask: ISyncTask;
18
+ }
19
+ /**
20
+ * PollingManager for client-side with support for multiple clients
21
+ */
22
+ export interface IPollingManagerCS extends IPollingManager {
23
+ add(matchingKey: string, readiness: IReadinessManager, storage: IStorageSync): IMySegmentsSyncTask;
24
+ remove(matchingKey: string): void;
25
+ get(matchingKey: string): IMySegmentsSyncTask | undefined;
26
+ }
@@ -0,0 +1,13 @@
1
+ import { IMySegmentsFetcher } from '../fetchers/types';
2
+ import { ISegmentsCacheSync, ISplitsCacheSync } from '../../../storages/types';
3
+ import { ISegmentsEventEmitter } from '../../../readiness/types';
4
+ import { ILogger } from '../../../logger/types';
5
+ declare type IMySegmentsUpdater = (segmentList?: string[], noCache?: boolean) => Promise<boolean>;
6
+ /**
7
+ * factory of MySegments updater, a task that:
8
+ * - fetches mySegments using `mySegmentsFetcher`
9
+ * - updates `mySegmentsCache`
10
+ * - uses `segmentsEventEmitter` to emit events related to segments data updates
11
+ */
12
+ export declare function mySegmentsUpdaterFactory(log: ILogger, mySegmentsFetcher: IMySegmentsFetcher, splitsCache: ISplitsCacheSync, mySegmentsCache: ISegmentsCacheSync, segmentsEventEmitter: ISegmentsEventEmitter, requestTimeoutBeforeReady: number, retriesOnFailureBeforeReady: number, matchingKey: string): IMySegmentsUpdater;
13
+ export {};
@@ -0,0 +1,18 @@
1
+ import { ISegmentChangesFetcher } from '../fetchers/types';
2
+ import { ISegmentsCacheBase } from '../../../storages/types';
3
+ import { IReadinessManager } from '../../../readiness/types';
4
+ import { ILogger } from '../../../logger/types';
5
+ declare type ISegmentChangesUpdater = (fetchOnlyNew?: boolean, segmentName?: string, noCache?: boolean, till?: number) => Promise<boolean>;
6
+ /**
7
+ * Factory of SegmentChanges updater, a task that:
8
+ * - fetches segment changes using `segmentChangesFetcher`
9
+ * - updates `segmentsCache`
10
+ * - uses `segmentsEventEmitter` to emit events related to segments data updates
11
+ *
12
+ * @param log logger instance
13
+ * @param segmentChangesFetcher fetcher of `/segmentChanges`
14
+ * @param segments segments storage, with sync or async methods
15
+ * @param readiness optional readiness manager. Not required for synchronizer or producer mode.
16
+ */
17
+ export declare function segmentChangesUpdaterFactory(log: ILogger, segmentChangesFetcher: ISegmentChangesFetcher, segments: ISegmentsCacheBase, readiness?: IReadinessManager): ISegmentChangesUpdater;
18
+ export {};