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

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 (433) hide show
  1. package/cjs/listeners/browser.js +1 -2
  2. package/cjs/logger/constants.js +1 -2
  3. package/cjs/sdkClient/clientAttributesDecoration.js +1 -1
  4. package/cjs/sdkFactory/index.js +6 -13
  5. package/cjs/services/splitApi.js +1 -20
  6. package/cjs/storages/inMemory/AttributesCacheInMemory.js +1 -1
  7. package/cjs/sync/submitters/submitterManager.js +0 -3
  8. package/cjs/trackers/impressionsTracker.js +28 -7
  9. package/cjs/utils/constants/index.js +2 -3
  10. package/cjs/utils/key/index.js +1 -1
  11. package/cjs/utils/settingsValidation/impressionsMode.js +2 -2
  12. package/cjs/utils/settingsValidation/index.js +1 -3
  13. package/esm/listeners/browser.js +2 -3
  14. package/esm/logger/constants.js +0 -1
  15. package/esm/sdkClient/clientAttributesDecoration.js +1 -1
  16. package/esm/sdkFactory/index.js +6 -13
  17. package/esm/services/splitApi.js +1 -20
  18. package/esm/storages/inMemory/AttributesCacheInMemory.js +1 -1
  19. package/esm/sync/submitters/submitterManager.js +0 -3
  20. package/esm/trackers/impressionsTracker.js +28 -7
  21. package/esm/utils/constants/index.js +0 -1
  22. package/esm/utils/key/index.js +1 -1
  23. package/esm/utils/settingsValidation/impressionsMode.js +3 -3
  24. package/esm/utils/settingsValidation/index.js +1 -3
  25. package/package.json +4 -5
  26. package/src/consent/sdkUserConsent.ts +4 -3
  27. package/src/dtos/types.ts +0 -8
  28. package/src/evaluator/Engine.ts +3 -3
  29. package/src/evaluator/combiners/and.ts +1 -1
  30. package/src/evaluator/combiners/ifelseif.ts +3 -3
  31. package/src/evaluator/condition/engineUtils.ts +1 -1
  32. package/src/evaluator/condition/index.ts +6 -6
  33. package/src/evaluator/index.ts +10 -10
  34. package/src/evaluator/matchers/all.ts +1 -1
  35. package/src/evaluator/matchers/between.ts +1 -1
  36. package/src/evaluator/matchers/boolean.ts +1 -1
  37. package/src/evaluator/matchers/cont_all.ts +1 -1
  38. package/src/evaluator/matchers/cont_any.ts +1 -1
  39. package/src/evaluator/matchers/cont_str.ts +1 -1
  40. package/src/evaluator/matchers/dependency.ts +1 -1
  41. package/src/evaluator/matchers/eq.ts +1 -1
  42. package/src/evaluator/matchers/eq_set.ts +1 -1
  43. package/src/evaluator/matchers/ew.ts +1 -1
  44. package/src/evaluator/matchers/gte.ts +1 -1
  45. package/src/evaluator/matchers/index.ts +1 -1
  46. package/src/evaluator/matchers/lte.ts +1 -1
  47. package/src/evaluator/matchers/part_of.ts +1 -1
  48. package/src/evaluator/matchers/segment.ts +1 -1
  49. package/src/evaluator/matchers/string.ts +1 -1
  50. package/src/evaluator/matchers/sw.ts +1 -1
  51. package/src/evaluator/matchers/whitelist.ts +1 -1
  52. package/src/evaluator/parser/index.ts +3 -3
  53. package/src/evaluator/types.ts +6 -6
  54. package/src/evaluator/value/index.ts +4 -4
  55. package/src/evaluator/value/sanitize.ts +4 -4
  56. package/src/integrations/ga/GaToSplit.ts +6 -6
  57. package/src/integrations/ga/SplitToGa.ts +10 -10
  58. package/src/integrations/ga/types.ts +4 -4
  59. package/src/integrations/pluggable.ts +3 -3
  60. package/src/integrations/types.ts +2 -2
  61. package/src/listeners/browser.ts +2 -3
  62. package/src/logger/.DS_Store +0 -0
  63. package/src/logger/constants.ts +0 -1
  64. package/src/logger/index.ts +3 -3
  65. package/src/logger/sdkLogger.ts +1 -2
  66. package/src/logger/types.ts +0 -16
  67. package/src/readiness/sdkReadinessManager.ts +1 -1
  68. package/src/readiness/types.ts +2 -9
  69. package/src/sdkClient/client.ts +13 -13
  70. package/src/sdkClient/clientAttributesDecoration.ts +13 -13
  71. package/src/sdkClient/clientCS.ts +3 -4
  72. package/src/sdkClient/clientInputValidation.ts +15 -15
  73. package/src/sdkClient/sdkClient.ts +2 -2
  74. package/src/sdkClient/sdkClientMethod.ts +2 -2
  75. package/src/sdkClient/sdkClientMethodCS.ts +9 -9
  76. package/src/sdkClient/sdkClientMethodCSWithTT.ts +9 -9
  77. package/src/sdkFactory/index.ts +8 -17
  78. package/src/sdkFactory/types.ts +8 -11
  79. package/src/sdkManager/index.ts +5 -5
  80. package/src/services/splitApi.ts +1 -22
  81. package/src/services/types.ts +0 -6
  82. package/src/storages/dataLoader.ts +2 -2
  83. package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +1 -1
  84. package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +2 -2
  85. package/src/storages/inLocalStorage/index.ts +3 -2
  86. package/src/storages/inMemory/AttributesCacheInMemory.ts +13 -12
  87. package/src/storages/inMemory/EventsCacheInMemory.ts +4 -4
  88. package/src/storages/inRedis/EventsCacheInRedis.ts +4 -4
  89. package/src/storages/inRedis/ImpressionsCacheInRedis.ts +1 -1
  90. package/src/storages/inRedis/RedisAdapter.ts +1 -1
  91. package/src/storages/inRedis/SegmentsCacheInRedis.ts +1 -1
  92. package/src/storages/inRedis/SplitsCacheInRedis.ts +1 -1
  93. package/src/storages/inRedis/TelemetryCacheInRedis.ts +1 -1
  94. package/src/storages/inRedis/index.ts +3 -2
  95. package/src/storages/pluggable/EventsCachePluggable.ts +4 -4
  96. package/src/storages/pluggable/ImpressionsCachePluggable.ts +1 -1
  97. package/src/storages/pluggable/SegmentsCachePluggable.ts +1 -1
  98. package/src/storages/pluggable/SplitsCachePluggable.ts +1 -1
  99. package/src/storages/pluggable/TelemetryCachePluggable.ts +1 -1
  100. package/src/storages/pluggable/index.ts +3 -3
  101. package/src/storages/pluggable/wrapperAdapter.ts +1 -1
  102. package/src/storages/types.ts +46 -35
  103. package/src/sync/offline/LocalhostFromObject.ts +4 -4
  104. package/src/sync/offline/splitsParser/splitsParserFromSettings.ts +8 -8
  105. package/src/sync/polling/updaters/mySegmentsUpdater.ts +1 -1
  106. package/src/sync/polling/updaters/segmentChangesUpdater.ts +1 -1
  107. package/src/sync/polling/updaters/splitChangesUpdater.ts +1 -1
  108. package/src/sync/streaming/SSEHandler/index.ts +1 -1
  109. package/src/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.ts +1 -1
  110. package/src/sync/streaming/UpdateWorkers/SplitsUpdateWorker.ts +1 -1
  111. package/src/sync/submitters/submitter.ts +1 -1
  112. package/src/sync/submitters/submitterManager.ts +0 -2
  113. package/src/sync/submitters/types.ts +3 -22
  114. package/src/sync/syncTask.ts +1 -1
  115. package/src/trackers/eventTracker.ts +3 -3
  116. package/src/trackers/impressionsTracker.ts +37 -15
  117. package/src/trackers/types.ts +4 -34
  118. package/src/types.d.ts +1581 -0
  119. package/src/utils/constants/index.ts +1 -2
  120. package/src/utils/inputValidation/apiKey.ts +1 -1
  121. package/src/utils/inputValidation/attribute.ts +1 -1
  122. package/src/utils/inputValidation/attributes.ts +3 -3
  123. package/src/utils/inputValidation/event.ts +1 -1
  124. package/src/utils/inputValidation/eventProperties.ts +3 -3
  125. package/src/utils/inputValidation/eventValue.ts +1 -1
  126. package/src/utils/inputValidation/isOperational.ts +1 -1
  127. package/src/utils/inputValidation/key.ts +3 -3
  128. package/src/utils/inputValidation/preloadedData.ts +3 -3
  129. package/src/utils/inputValidation/split.ts +1 -1
  130. package/src/utils/inputValidation/splitExistance.ts +1 -1
  131. package/src/utils/inputValidation/splits.ts +1 -1
  132. package/src/utils/inputValidation/trafficType.ts +1 -1
  133. package/src/utils/inputValidation/trafficTypeExistance.ts +1 -1
  134. package/src/utils/key/index.ts +9 -9
  135. package/src/utils/settingsValidation/consent.ts +1 -2
  136. package/src/utils/settingsValidation/impressionsMode.ts +6 -6
  137. package/src/utils/settingsValidation/index.ts +1 -4
  138. package/src/utils/settingsValidation/integrations/common.ts +1 -1
  139. package/src/utils/settingsValidation/integrations/configurable.ts +1 -1
  140. package/src/utils/settingsValidation/integrations/pluggable.ts +1 -2
  141. package/src/utils/settingsValidation/localhost/builtin.ts +1 -2
  142. package/src/utils/settingsValidation/localhost/pluggable.ts +1 -2
  143. package/src/utils/settingsValidation/logger/builtinLogger.ts +1 -2
  144. package/src/utils/settingsValidation/logger/pluggableLogger.ts +1 -2
  145. package/src/utils/settingsValidation/splitFilters.ts +7 -9
  146. package/src/utils/settingsValidation/storage/storageCS.ts +1 -2
  147. package/cjs/sync/submitters/uniqueKeysSubmitter.js +0 -70
  148. package/cjs/trackers/strategy/strategyDebug.js +0 -25
  149. package/cjs/trackers/strategy/strategyNone.js +0 -29
  150. package/cjs/trackers/strategy/strategyOptimized.js +0 -34
  151. package/cjs/trackers/uniqueKeysTracker.js +0 -69
  152. package/cjs/types.js +0 -2
  153. package/esm/sync/submitters/uniqueKeysSubmitter.js +0 -64
  154. package/esm/trackers/strategy/strategyDebug.js +0 -21
  155. package/esm/trackers/strategy/strategyNone.js +0 -25
  156. package/esm/trackers/strategy/strategyOptimized.js +0 -30
  157. package/esm/trackers/uniqueKeysTracker.js +0 -65
  158. package/esm/types.js +0 -1
  159. package/src/sync/submitters/uniqueKeysSubmitter.ts +0 -79
  160. package/src/trackers/strategy/strategyDebug.ts +0 -28
  161. package/src/trackers/strategy/strategyNone.ts +0 -34
  162. package/src/trackers/strategy/strategyOptimized.ts +0 -42
  163. package/src/trackers/uniqueKeysTracker.ts +0 -80
  164. package/src/types.ts +0 -1264
  165. package/types/consent/index.d.ts +0 -2
  166. package/types/consent/sdkUserConsent.d.ts +0 -13
  167. package/types/dtos/types.d.ts +0 -172
  168. package/types/evaluator/Engine.d.ts +0 -15
  169. package/types/evaluator/combiners/and.d.ts +0 -4
  170. package/types/evaluator/combiners/ifelseif.d.ts +0 -3
  171. package/types/evaluator/condition/engineUtils.d.ts +0 -11
  172. package/types/evaluator/condition/index.d.ts +0 -6
  173. package/types/evaluator/convertions/index.d.ts +0 -2
  174. package/types/evaluator/index.d.ts +0 -7
  175. package/types/evaluator/matchers/all.d.ts +0 -2
  176. package/types/evaluator/matchers/between.d.ts +0 -3
  177. package/types/evaluator/matchers/boolean.d.ts +0 -2
  178. package/types/evaluator/matchers/cont_all.d.ts +0 -2
  179. package/types/evaluator/matchers/cont_any.d.ts +0 -2
  180. package/types/evaluator/matchers/cont_str.d.ts +0 -2
  181. package/types/evaluator/matchers/dependency.d.ts +0 -5
  182. package/types/evaluator/matchers/eq.d.ts +0 -2
  183. package/types/evaluator/matchers/eq_set.d.ts +0 -2
  184. package/types/evaluator/matchers/ew.d.ts +0 -2
  185. package/types/evaluator/matchers/gte.d.ts +0 -2
  186. package/types/evaluator/matchers/index.d.ts +0 -7
  187. package/types/evaluator/matchers/lte.d.ts +0 -2
  188. package/types/evaluator/matchers/matcherTypes.d.ts +0 -10
  189. package/types/evaluator/matchers/part_of.d.ts +0 -2
  190. package/types/evaluator/matchers/segment.d.ts +0 -6
  191. package/types/evaluator/matchers/string.d.ts +0 -2
  192. package/types/evaluator/matchers/sw.d.ts +0 -2
  193. package/types/evaluator/matchers/whitelist.d.ts +0 -3
  194. package/types/evaluator/matchersTransform/index.d.ts +0 -6
  195. package/types/evaluator/matchersTransform/segment.d.ts +0 -5
  196. package/types/evaluator/matchersTransform/set.d.ts +0 -5
  197. package/types/evaluator/matchersTransform/unaryNumeric.d.ts +0 -5
  198. package/types/evaluator/matchersTransform/whitelist.d.ts +0 -5
  199. package/types/evaluator/parser/index.d.ts +0 -5
  200. package/types/evaluator/treatments/index.d.ts +0 -8
  201. package/types/evaluator/types.d.ts +0 -28
  202. package/types/evaluator/value/index.d.ts +0 -7
  203. package/types/evaluator/value/sanitize.d.ts +0 -7
  204. package/types/index.d.ts +0 -5
  205. package/types/integrations/browser.d.ts +0 -12
  206. package/types/integrations/ga/GaToSplit.d.ts +0 -40
  207. package/types/integrations/ga/GoogleAnalyticsToSplit.d.ts +0 -3
  208. package/types/integrations/ga/SplitToGa.d.ts +0 -34
  209. package/types/integrations/ga/SplitToGoogleAnalytics.d.ts +0 -3
  210. package/types/integrations/ga/types.d.ts +0 -148
  211. package/types/integrations/pluggable.d.ts +0 -11
  212. package/types/integrations/types.d.ts +0 -17
  213. package/types/listeners/browser.d.ts +0 -40
  214. package/types/listeners/node.d.ts +0 -22
  215. package/types/listeners/types.d.ts +0 -4
  216. package/types/logger/browser/DebugLogger.d.ts +0 -2
  217. package/types/logger/browser/ErrorLogger.d.ts +0 -2
  218. package/types/logger/browser/InfoLogger.d.ts +0 -2
  219. package/types/logger/browser/WarnLogger.d.ts +0 -2
  220. package/types/logger/constants.d.ts +0 -142
  221. package/types/logger/index.d.ts +0 -22
  222. package/types/logger/messages/debug.d.ts +0 -1
  223. package/types/logger/messages/error.d.ts +0 -1
  224. package/types/logger/messages/info.d.ts +0 -1
  225. package/types/logger/messages/warn.d.ts +0 -1
  226. package/types/logger/sdkLogger.d.ts +0 -8
  227. package/types/logger/types.d.ts +0 -17
  228. package/types/readiness/constants.d.ts +0 -7
  229. package/types/readiness/readinessManager.d.ts +0 -6
  230. package/types/readiness/sdkReadinessManager.d.ts +0 -11
  231. package/types/readiness/types.d.ts +0 -60
  232. package/types/sdkClient/client.d.ts +0 -6
  233. package/types/sdkClient/clientAttributesDecoration.d.ts +0 -51
  234. package/types/sdkClient/clientCS.d.ts +0 -10
  235. package/types/sdkClient/clientInputValidation.d.ts +0 -7
  236. package/types/sdkClient/sdkClient.d.ts +0 -6
  237. package/types/sdkClient/sdkClientMethod.d.ts +0 -6
  238. package/types/sdkClient/sdkClientMethodCS.d.ts +0 -7
  239. package/types/sdkClient/sdkClientMethodCSWithTT.d.ts +0 -8
  240. package/types/sdkClient/types.d.ts +0 -18
  241. package/types/sdkFactory/index.d.ts +0 -6
  242. package/types/sdkFactory/types.d.ts +0 -82
  243. package/types/sdkManager/index.d.ts +0 -5
  244. package/types/services/splitApi.d.ts +0 -11
  245. package/types/services/splitHttpClient.d.ts +0 -10
  246. package/types/services/types.d.ts +0 -54
  247. package/types/storages/AbstractSegmentsCacheSync.d.ts +0 -55
  248. package/types/storages/AbstractSplitsCacheAsync.d.ts +0 -36
  249. package/types/storages/AbstractSplitsCacheSync.d.ts +0 -42
  250. package/types/storages/KeyBuilder.d.ts +0 -14
  251. package/types/storages/KeyBuilderCS.d.ts +0 -16
  252. package/types/storages/KeyBuilderSS.d.ts +0 -15
  253. package/types/storages/dataLoader.d.ts +0 -10
  254. package/types/storages/findLatencyIndex.d.ts +0 -7
  255. package/types/storages/inLocalStorage/MySegmentsCacheInLocal.d.ts +0 -25
  256. package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +0 -51
  257. package/types/storages/inLocalStorage/constants.d.ts +0 -2
  258. package/types/storages/inLocalStorage/index.d.ts +0 -8
  259. package/types/storages/inMemory/AttributesCacheInMemory.d.ts +0 -43
  260. package/types/storages/inMemory/CountsCacheInMemory.d.ts +0 -20
  261. package/types/storages/inMemory/EventsCacheInMemory.d.ts +0 -35
  262. package/types/storages/inMemory/ImpressionCountsCacheInMemory.d.ts +0 -24
  263. package/types/storages/inMemory/ImpressionsCacheInMemory.d.ts +0 -30
  264. package/types/storages/inMemory/InMemoryStorage.d.ts +0 -10
  265. package/types/storages/inMemory/InMemoryStorageCS.d.ts +0 -10
  266. package/types/storages/inMemory/LatenciesCacheInMemory.d.ts +0 -20
  267. package/types/storages/inMemory/MySegmentsCacheInMemory.d.ts +0 -22
  268. package/types/storages/inMemory/SegmentsCacheInMemory.d.ts +0 -19
  269. package/types/storages/inMemory/SplitsCacheInMemory.d.ts +0 -20
  270. package/types/storages/inMemory/TelemetryCacheInMemory.d.ts +0 -53
  271. package/types/storages/inRedis/CountsCacheInRedis.d.ts +0 -9
  272. package/types/storages/inRedis/EventsCacheInRedis.d.ts +0 -32
  273. package/types/storages/inRedis/ImpressionsCacheInRedis.d.ts +0 -18
  274. package/types/storages/inRedis/LatenciesCacheInRedis.d.ts +0 -9
  275. package/types/storages/inRedis/RedisAdapter.d.ts +0 -24
  276. package/types/storages/inRedis/SegmentsCacheInRedis.d.ts +0 -18
  277. package/types/storages/inRedis/SplitsCacheInRedis.d.ts +0 -91
  278. package/types/storages/inRedis/TelemetryCacheInRedis.d.ts +0 -20
  279. package/types/storages/inRedis/constants.d.ts +0 -1
  280. package/types/storages/inRedis/index.d.ts +0 -10
  281. package/types/storages/metadataBuilder.d.ts +0 -3
  282. package/types/storages/pluggable/EventsCachePluggable.d.ts +0 -38
  283. package/types/storages/pluggable/ImpressionsCachePluggable.d.ts +0 -35
  284. package/types/storages/pluggable/SegmentsCachePluggable.d.ts +0 -54
  285. package/types/storages/pluggable/SplitsCachePluggable.d.ts +0 -89
  286. package/types/storages/pluggable/TelemetryCachePluggable.d.ts +0 -18
  287. package/types/storages/pluggable/constants.d.ts +0 -1
  288. package/types/storages/pluggable/inMemoryWrapper.d.ts +0 -13
  289. package/types/storages/pluggable/index.d.ts +0 -9
  290. package/types/storages/pluggable/wrapperAdapter.d.ts +0 -12
  291. package/types/storages/types.d.ts +0 -417
  292. package/types/sync/offline/LocalhostFromFile.d.ts +0 -2
  293. package/types/sync/offline/LocalhostFromObject.d.ts +0 -2
  294. package/types/sync/offline/splitsParser/parseCondition.d.ts +0 -7
  295. package/types/sync/offline/splitsParser/splitsParserFromFile.d.ts +0 -2
  296. package/types/sync/offline/splitsParser/splitsParserFromSettings.d.ts +0 -3
  297. package/types/sync/offline/splitsParser/types.d.ts +0 -3
  298. package/types/sync/offline/syncManagerOffline.d.ts +0 -10
  299. package/types/sync/offline/syncTasks/fromObjectSyncTask.d.ts +0 -17
  300. package/types/sync/polling/fetchers/mySegmentsFetcher.d.ts +0 -7
  301. package/types/sync/polling/fetchers/segmentChangesFetcher.d.ts +0 -7
  302. package/types/sync/polling/fetchers/splitChangesFetcher.d.ts +0 -7
  303. package/types/sync/polling/fetchers/types.d.ts +0 -5
  304. package/types/sync/polling/pollingManagerCS.d.ts +0 -7
  305. package/types/sync/polling/pollingManagerSS.d.ts +0 -6
  306. package/types/sync/polling/syncTasks/mySegmentsSyncTask.d.ts +0 -9
  307. package/types/sync/polling/syncTasks/segmentsSyncTask.d.ts +0 -9
  308. package/types/sync/polling/syncTasks/splitsSyncTask.d.ts +0 -9
  309. package/types/sync/polling/types.d.ts +0 -26
  310. package/types/sync/polling/updaters/mySegmentsUpdater.d.ts +0 -13
  311. package/types/sync/polling/updaters/segmentChangesUpdater.d.ts +0 -18
  312. package/types/sync/polling/updaters/splitChangesUpdater.d.ts +0 -39
  313. package/types/sync/streaming/AuthClient/index.d.ts +0 -12
  314. package/types/sync/streaming/AuthClient/types.d.ts +0 -17
  315. package/types/sync/streaming/SSEClient/index.d.ts +0 -34
  316. package/types/sync/streaming/SSEClient/types.d.ts +0 -11
  317. package/types/sync/streaming/SSEHandler/NotificationKeeper.d.ts +0 -14
  318. package/types/sync/streaming/SSEHandler/NotificationParser.d.ts +0 -20
  319. package/types/sync/streaming/SSEHandler/index.d.ts +0 -11
  320. package/types/sync/streaming/SSEHandler/types.d.ts +0 -67
  321. package/types/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.d.ts +0 -6
  322. package/types/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.d.ts +0 -8
  323. package/types/sync/streaming/UpdateWorkers/SplitsUpdateWorker.d.ts +0 -12
  324. package/types/sync/streaming/UpdateWorkers/constants.d.ts +0 -3
  325. package/types/sync/streaming/UpdateWorkers/types.d.ts +0 -4
  326. package/types/sync/streaming/constants.d.ts +0 -34
  327. package/types/sync/streaming/mySegmentsV2utils.d.ts +0 -27
  328. package/types/sync/streaming/pushManager.d.ts +0 -9
  329. package/types/sync/streaming/types.d.ts +0 -35
  330. package/types/sync/submitters/eventsSubmitter.d.ts +0 -5
  331. package/types/sync/submitters/eventsSyncTask.d.ts +0 -8
  332. package/types/sync/submitters/impressionCountsSubmitter.d.ts +0 -10
  333. package/types/sync/submitters/impressionCountsSyncTask.d.ts +0 -13
  334. package/types/sync/submitters/impressionsSubmitter.d.ts +0 -11
  335. package/types/sync/submitters/impressionsSyncTask.d.ts +0 -14
  336. package/types/sync/submitters/metricsSyncTask.d.ts +0 -12
  337. package/types/sync/submitters/submitter.d.ts +0 -12
  338. package/types/sync/submitters/submitterManager.d.ts +0 -3
  339. package/types/sync/submitters/submitterSyncTask.d.ts +0 -10
  340. package/types/sync/submitters/telemetrySubmitter.d.ts +0 -25
  341. package/types/sync/submitters/types.d.ts +0 -194
  342. package/types/sync/submitters/uniqueKeysSubmitter.d.ts +0 -19
  343. package/types/sync/syncManagerOnline.d.ts +0 -13
  344. package/types/sync/syncTask.d.ts +0 -13
  345. package/types/sync/syncTaskComposite.d.ts +0 -5
  346. package/types/sync/types.d.ts +0 -43
  347. package/types/trackers/eventTracker.d.ts +0 -10
  348. package/types/trackers/filter/bloomFilter.d.ts +0 -10
  349. package/types/trackers/filter/dictionaryFilter.d.ts +0 -8
  350. package/types/trackers/filter/types.d.ts +0 -5
  351. package/types/trackers/impressionObserver/ImpressionObserver.d.ts +0 -8
  352. package/types/trackers/impressionObserver/buildKey.d.ts +0 -2
  353. package/types/trackers/impressionObserver/impressionObserverCS.d.ts +0 -4
  354. package/types/trackers/impressionObserver/impressionObserverSS.d.ts +0 -4
  355. package/types/trackers/impressionObserver/types.d.ts +0 -4
  356. package/types/trackers/impressionObserver/utils.d.ts +0 -13
  357. package/types/trackers/impressionsTracker.d.ts +0 -13
  358. package/types/trackers/strategy/strategyDebug.d.ts +0 -9
  359. package/types/trackers/strategy/strategyNone.d.ts +0 -10
  360. package/types/trackers/strategy/strategyOptimized.d.ts +0 -11
  361. package/types/trackers/telemetryTracker.d.ts +0 -3
  362. package/types/trackers/types.d.ts +0 -65
  363. package/types/trackers/uniqueKeysTracker.d.ts +0 -13
  364. package/types/types.d.ts +0 -1262
  365. package/types/utils/Backoff.d.ts +0 -25
  366. package/types/utils/LRUCache/LinkedList.d.ts +0 -34
  367. package/types/utils/LRUCache/index.d.ts +0 -16
  368. package/types/utils/MinEventEmitter.d.ts +0 -12
  369. package/types/utils/MinEvents.d.ts +0 -4
  370. package/types/utils/base64/index.d.ts +0 -30
  371. package/types/utils/constants/browser.d.ts +0 -3
  372. package/types/utils/constants/index.d.ts +0 -63
  373. package/types/utils/decompress/index.d.ts +0 -16
  374. package/types/utils/env/isLocalStorageAvailable.d.ts +0 -1
  375. package/types/utils/env/isNode.d.ts +0 -5
  376. package/types/utils/inputValidation/apiKey.d.ts +0 -7
  377. package/types/utils/inputValidation/attribute.d.ts +0 -2
  378. package/types/utils/inputValidation/attributes.d.ts +0 -4
  379. package/types/utils/inputValidation/event.d.ts +0 -2
  380. package/types/utils/inputValidation/eventProperties.d.ts +0 -6
  381. package/types/utils/inputValidation/eventValue.d.ts +0 -2
  382. package/types/utils/inputValidation/index.d.ts +0 -13
  383. package/types/utils/inputValidation/isOperational.d.ts +0 -4
  384. package/types/utils/inputValidation/key.d.ts +0 -3
  385. package/types/utils/inputValidation/preloadedData.d.ts +0 -3
  386. package/types/utils/inputValidation/split.d.ts +0 -2
  387. package/types/utils/inputValidation/splitExistance.d.ts +0 -7
  388. package/types/utils/inputValidation/splits.d.ts +0 -2
  389. package/types/utils/inputValidation/trafficType.d.ts +0 -2
  390. package/types/utils/inputValidation/trafficTypeExistance.d.ts +0 -9
  391. package/types/utils/jwt/index.d.ts +0 -5
  392. package/types/utils/jwt/types.d.ts +0 -5
  393. package/types/utils/key/index.d.ts +0 -8
  394. package/types/utils/labels/index.d.ts +0 -7
  395. package/types/utils/lang/binarySearch.d.ts +0 -9
  396. package/types/utils/lang/getFnName.d.ts +0 -4
  397. package/types/utils/lang/getGlobal.d.ts +0 -4
  398. package/types/utils/lang/index.d.ts +0 -105
  399. package/types/utils/lang/maps.d.ts +0 -55
  400. package/types/utils/lang/objectAssign.d.ts +0 -3
  401. package/types/utils/lang/sets.d.ts +0 -60
  402. package/types/utils/murmur3/common.d.ts +0 -12
  403. package/types/utils/murmur3/legacy.d.ts +0 -2
  404. package/types/utils/murmur3/murmur3.d.ts +0 -2
  405. package/types/utils/murmur3/murmur3_128.d.ts +0 -6
  406. package/types/utils/murmur3/murmur3_128_x86.d.ts +0 -7
  407. package/types/utils/murmur3/murmur3_64.d.ts +0 -10
  408. package/types/utils/murmur3/utfx.d.ts +0 -27
  409. package/types/utils/promise/thenable.d.ts +0 -1
  410. package/types/utils/promise/timeout.d.ts +0 -1
  411. package/types/utils/promise/wrapper.d.ts +0 -21
  412. package/types/utils/settingsValidation/consent.d.ts +0 -6
  413. package/types/utils/settingsValidation/impressionsMode.d.ts +0 -3
  414. package/types/utils/settingsValidation/index.d.ts +0 -52
  415. package/types/utils/settingsValidation/integrations/common.d.ts +0 -14
  416. package/types/utils/settingsValidation/integrations/configurable.d.ts +0 -13
  417. package/types/utils/settingsValidation/integrations/pluggable.d.ts +0 -13
  418. package/types/utils/settingsValidation/localhost/builtin.d.ts +0 -16
  419. package/types/utils/settingsValidation/localhost/pluggable.d.ts +0 -16
  420. package/types/utils/settingsValidation/logger/builtinLogger.d.ts +0 -10
  421. package/types/utils/settingsValidation/logger/commons.d.ts +0 -9
  422. package/types/utils/settingsValidation/logger/pluggableLogger.d.ts +0 -11
  423. package/types/utils/settingsValidation/mode.d.ts +0 -1
  424. package/types/utils/settingsValidation/runtime.d.ts +0 -2
  425. package/types/utils/settingsValidation/splitFilters.d.ts +0 -16
  426. package/types/utils/settingsValidation/storage/storageCS.d.ts +0 -21
  427. package/types/utils/settingsValidation/types.d.ts +0 -32
  428. package/types/utils/settingsValidation/url.d.ts +0 -10
  429. package/types/utils/time/index.d.ts +0 -4
  430. package/types/utils/timeTracker/index.d.ts +0 -70
  431. package/types/utils/timeTracker/now/browser.d.ts +0 -1
  432. package/types/utils/timeTracker/now/node.d.ts +0 -1
  433. package/types/utils/timeTracker/timer.d.ts +0 -1
@@ -1,89 +0,0 @@
1
- import { KeyBuilder } from '../KeyBuilder';
2
- import { IPluggableStorageWrapper } from '../types';
3
- import { ILogger } from '../../logger/types';
4
- import { AbstractSplitsCacheAsync } from '../AbstractSplitsCacheAsync';
5
- /**
6
- * ISplitsCacheAsync implementation for pluggable storages.
7
- */
8
- export declare class SplitsCachePluggable extends AbstractSplitsCacheAsync {
9
- private readonly log;
10
- private readonly keys;
11
- private readonly wrapper;
12
- /**
13
- * Create a SplitsCache that uses a storage wrapper.
14
- * @param log Logger instance.
15
- * @param keys Key builder.
16
- * @param wrapper Adapted wrapper storage.
17
- */
18
- constructor(log: ILogger, keys: KeyBuilder, wrapper: IPluggableStorageWrapper);
19
- private _decrementCounts;
20
- private _incrementCounts;
21
- /**
22
- * Add a given split.
23
- * The returned promise is resolved when the operation success
24
- * or rejected if it fails (e.g., wrapper operation fails)
25
- */
26
- addSplit(name: string, split: string): Promise<boolean>;
27
- /**
28
- * Add a list of splits.
29
- * The returned promise is resolved when the operation success
30
- * or rejected if it fails (e.g., wrapper operation fails)
31
- */
32
- addSplits(entries: [string, string][]): Promise<boolean[]>;
33
- /**
34
- * Remove a given split.
35
- * The returned promise is resolved when the operation success, with a boolean indicating if the split existed or not.
36
- * or rejected if it fails (e.g., wrapper operation fails).
37
- */
38
- removeSplit(name: string): Promise<boolean | void>;
39
- /**
40
- * Remove a list of splits.
41
- * The returned promise is resolved when the operation success, with a boolean array indicating if the splits existed or not.
42
- * or rejected if it fails (e.g., wrapper operation fails).
43
- */
44
- removeSplits(names: string[]): Promise<void>;
45
- /**
46
- * Get split.
47
- * The returned promise is resolved with the split definition or null if it's not defined,
48
- * or rejected if wrapper operation fails.
49
- */
50
- getSplit(name: string): Promise<string | null>;
51
- /**
52
- * Get list of splits.
53
- * The returned promise is resolved with a map of split names to their split definition or null if it's not defined,
54
- * or rejected if wrapper operation fails.
55
- */
56
- getSplits(names: string[]): Promise<Record<string, string | null>>;
57
- /**
58
- * Get list of all split definitions.
59
- * The returned promise is resolved with the list of split definitions,
60
- * or rejected if wrapper operation fails.
61
- */
62
- getAll(): Promise<string[]>;
63
- /**
64
- * Get list of split names.
65
- * The returned promise is resolved with the list of split names,
66
- * or rejected if wrapper operation fails.
67
- */
68
- getSplitNames(): Promise<string[]>;
69
- /**
70
- * Check traffic type existence.
71
- * The returned promise is resolved with a boolean indicating whether the TT exist or not.
72
- * In case of wrapper operation failures, the promise resolves with a true value, assuming that the TT might exist.
73
- * It will never be rejected.
74
- */
75
- trafficTypeExists(trafficType: string): Promise<boolean>;
76
- /**
77
- * Set till number.
78
- * The returned promise is resolved when the operation success,
79
- * or rejected if it fails (e.g., wrapper operation fails).
80
- */
81
- setChangeNumber(changeNumber: number): Promise<boolean | void>;
82
- /**
83
- * Get till number or -1 if it's not defined.
84
- * The returned promise is resolved with the changeNumber or -1 if it doesn't exist or a wrapper operation fails.
85
- * The promise will never be rejected.
86
- */
87
- getChangeNumber(): Promise<number>;
88
- clear(): Promise<boolean>;
89
- }
@@ -1,18 +0,0 @@
1
- import { ILogger } from '../../logger/types';
2
- import { Method } from '../../sync/submitters/types';
3
- import { KeyBuilderSS } from '../KeyBuilderSS';
4
- import { IPluggableStorageWrapper, ITelemetryCacheAsync } from '../types';
5
- export declare class TelemetryCachePluggable implements ITelemetryCacheAsync {
6
- private readonly log;
7
- private readonly keys;
8
- private readonly wrapper;
9
- /**
10
- * Create a Telemetry cache that uses a storage wrapper.
11
- * @param log Logger instance.
12
- * @param keys Key builder.
13
- * @param wrapper Adapted wrapper storage.
14
- */
15
- constructor(log: ILogger, keys: KeyBuilderSS, wrapper: IPluggableStorageWrapper);
16
- recordLatency(method: Method, latencyMs: number): Promise<number | void>;
17
- recordException(method: Method): Promise<number | void>;
18
- }
@@ -1 +0,0 @@
1
- export declare const LOG_PREFIX = "storage:pluggable: ";
@@ -1,13 +0,0 @@
1
- import { IPluggableStorageWrapper } from '../types';
2
- import { ISet } from '../../utils/lang/sets';
3
- /**
4
- * Creates a IPluggableStorageWrapper implementation that stores items in memory.
5
- * The `_cache` property is the object were items are stored.
6
- * Intended for testing purposes.
7
- *
8
- * @param connDelay delay in millis for `connect` resolve. If not provided, `connect` resolves inmediatelly.
9
- */
10
- export declare function inMemoryWrapperFactory(connDelay?: number): IPluggableStorageWrapper & {
11
- _cache: Record<string, string | string[] | ISet<string>>;
12
- _setConnDelay(connDelay: number): void;
13
- };
@@ -1,9 +0,0 @@
1
- import { IPluggableStorageWrapper, IStorageAsyncFactory } from '../types';
2
- export interface PluggableStorageOptions {
3
- prefix?: string;
4
- wrapper: IPluggableStorageWrapper;
5
- }
6
- /**
7
- * Pluggable storage factory for consumer server-side & client-side SplitFactory.
8
- */
9
- export declare function PluggableStorage(options: PluggableStorageOptions): IStorageAsyncFactory;
@@ -1,12 +0,0 @@
1
- import { ILogger } from '../../logger/types';
2
- import { IPluggableStorageWrapper } from '../types';
3
- export declare const METHODS_TO_PROMISE_WRAP: string[];
4
- /**
5
- * Adapter of the Pluggable Storage Wrapper.
6
- * Used to handle exceptions as rejected promises, in order to simplify the error handling on storages.
7
- *
8
- * @param log logger instance
9
- * @param wrapper storage wrapper to adapt
10
- * @returns an adapted version of the given storage wrapper
11
- */
12
- export declare function wrapperAdapter(log: ILogger, wrapper: IPluggableStorageWrapper): IPluggableStorageWrapper;
@@ -1,417 +0,0 @@
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 } from '../sync/submitters/types';
4
- import { SplitIO, ImpressionDTO, SDKMode } from '../types';
5
- import { ISet } from '../utils/lang/sets';
6
- /**
7
- * Interface of a pluggable storage wrapper.
8
- */
9
- export interface IPluggableStorageWrapper {
10
- /** Key-Value operations */
11
- /**
12
- * Get the value of given `key`.
13
- *
14
- * @function get
15
- * @param {string} key Item to retrieve
16
- * @returns {Promise<string | null>} A promise that resolves with the element value associated with the specified `key`,
17
- * or null if the key does not exist. The promise rejects if the operation fails.
18
- */
19
- get: (key: string) => Promise<string | null>;
20
- /**
21
- * Add or update an item with a specified `key` and `value`.
22
- *
23
- * @function set
24
- * @param {string} key Item to update
25
- * @param {string} value Value to set
26
- * @returns {Promise<void>} A promise that resolves if the operation success, whether the key was added or updated.
27
- * The promise rejects if the operation fails.
28
- */
29
- set: (key: string, value: string) => Promise<boolean | void>;
30
- /**
31
- * Add or update an item with a specified `key` and `value`.
32
- *
33
- * @function getAndSet
34
- * @param {string} key Item to update
35
- * @param {string} value Value to set
36
- * @returns {Promise<string | null>} A promise that resolves with the previous value associated to the given `key`, or null if not set.
37
- * The promise rejects if the operation fails.
38
- */
39
- getAndSet: (key: string, value: string) => Promise<string | null>;
40
- /**
41
- * Removes the specified item by `key`.
42
- *
43
- * @function del
44
- * @param {string} key Item to delete
45
- * @returns {Promise<void>} A promise that resolves if the operation success, whether the key existed and was removed or it didn't exist.
46
- * The promise rejects if the operation fails, for example, if there is a connection error.
47
- */
48
- del: (key: string) => Promise<boolean | void>;
49
- /**
50
- * Returns all keys matching the given prefix.
51
- *
52
- * @function getKeysByPrefix
53
- * @param {string} prefix String prefix to match
54
- * @returns {Promise<string[]>} A promise that resolves with the list of keys that match the given `prefix`.
55
- * The promise rejects if the operation fails.
56
- */
57
- getKeysByPrefix: (prefix: string) => Promise<string[]>;
58
- /**
59
- * Returns the values of all given `keys`.
60
- *
61
- * @function getMany
62
- * @param {string[]} keys List of keys to retrieve
63
- * @returns {Promise<(string | null)[]>} A promise that resolves with the list of items associated with the specified list of `keys`.
64
- * For every key that does not hold a string value or does not exist, null is returned. The promise rejects if the operation fails.
65
- */
66
- getMany: (keys: string[]) => Promise<(string | null)[]>;
67
- /** Integer operations */
68
- /**
69
- * Increments in 1 the given `key` value or set it to 1 if the value doesn't exist.
70
- *
71
- * @function incr
72
- * @param {string} key Key to increment
73
- * @returns {Promise<number>} A promise that resolves with the value of key after the increment. The promise rejects if the operation fails,
74
- * for example, if there is a connection error or the key contains a string that can not be represented as integer.
75
- */
76
- incr: (key: string) => Promise<number>;
77
- /**
78
- * Decrements in 1 the given `key` value or set it to -1 if the value doesn't exist.
79
- *
80
- * @function decr
81
- * @param {string} key Key to decrement
82
- * @returns {Promise<number>} A promise that resolves with the value of key after the decrement. The promise rejects if the operation fails,
83
- * for example, if there is a connection error or the key contains a string that can not be represented as integer.
84
- */
85
- decr: (key: string) => Promise<number>;
86
- /** Queue operations */
87
- /**
88
- * Inserts given items at the tail of `key` list. If `key` does not exist, an empty list is created before pushing the items.
89
- *
90
- * @function pushItems
91
- * @param {string} key List key
92
- * @param {string[]} items List of items to push
93
- * @returns {Promise<void>} A promise that resolves if the operation success.
94
- * 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.
95
- */
96
- pushItems: (key: string, items: string[]) => Promise<void>;
97
- /**
98
- * Removes and returns the first `count` items from a list. If `key` does not exist, an empty list is items is returned.
99
- *
100
- * @function popItems
101
- * @param {string} key List key
102
- * @param {number} count Number of items to pop
103
- * @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.
104
- * 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.
105
- */
106
- popItems: (key: string, count: number) => Promise<string[]>;
107
- /**
108
- * Returns the count of items in a list, or 0 if `key` does not exist.
109
- *
110
- * @function getItemsCount
111
- * @param {string} key List key
112
- * @returns {Promise<number>} A promise that resolves with the number of items at the `key` list, or 0 when `key` does not exist.
113
- * 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.
114
- */
115
- getItemsCount: (key: string) => Promise<number>;
116
- /** Set operations */
117
- /**
118
- * Returns if item is a member of a set.
119
- *
120
- * @function itemContains
121
- * @param {string} key Set key
122
- * @param {string} item Item value
123
- * @returns {Promise<boolean>} A promise that resolves with true boolean value if `item` is a member of the set stored at `key`,
124
- * or false if it is not a member or `key` set does not exist. The promise rejects if the operation fails, for example,
125
- * if there is a connection error or the key holds a value that is not a set.
126
- */
127
- itemContains: (key: string, item: string) => Promise<boolean>;
128
- /**
129
- * Add the specified `items` to the set stored at `key`. Those items that are already part of the set are ignored.
130
- * If key does not exist, an empty set is created before adding the items.
131
- *
132
- * @function addItems
133
- * @param {string} key Set key
134
- * @param {string} items Items to add
135
- * @returns {Promise<boolean | void>} A promise that resolves if the operation success.
136
- * 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.
137
- */
138
- addItems: (key: string, items: string[]) => Promise<boolean | void>;
139
- /**
140
- * Remove the specified `items` from the set stored at `key`. Those items that are not part of the set are ignored.
141
- *
142
- * @function removeItems
143
- * @param {string} key Set key
144
- * @param {string} items Items to remove
145
- * @returns {Promise<boolean | void>} A promise that resolves if the operation success. If key does not exist, the promise also resolves.
146
- * 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.
147
- */
148
- removeItems: (key: string, items: string[]) => Promise<boolean | void>;
149
- /**
150
- * Returns all the items of the `key` set.
151
- *
152
- * @function getItems
153
- * @param {string} key Set key
154
- * @returns {Promise<string[]>} A promise that resolves with the list of items. If key does not exist, the result is an empty list.
155
- * 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.
156
- */
157
- getItems: (key: string) => Promise<string[]>;
158
- /** Control operations */
159
- /**
160
- * Connects to the underlying storage.
161
- * It is meant for storages that requires to be connected to some database or server. Otherwise it can just return a resolved promise.
162
- * Note: will be called once on SplitFactory instantiation and once per each shared client instantiation.
163
- *
164
- * @function connect
165
- * @returns {Promise<void>} A promise that resolves when the wrapper successfully connect to the underlying storage.
166
- * The promise rejects with the corresponding error if the wrapper fails to connect.
167
- */
168
- connect: () => Promise<void>;
169
- /**
170
- * Disconnects from the underlying storage.
171
- * It is meant for storages that requires to be closed, in order to release resources. Otherwise it can just return a resolved promise.
172
- * Note: will be called once on SplitFactory main client destroy.
173
- *
174
- * @function disconnect
175
- * @returns {Promise<void>} A promise that resolves when the operation ends.
176
- * The promise never rejects.
177
- */
178
- disconnect: () => Promise<void>;
179
- }
180
- /** Splits cache */
181
- export interface ISplitsCacheBase {
182
- addSplits(entries: [string, string][]): MaybeThenable<boolean[] | void>;
183
- removeSplits(names: string[]): MaybeThenable<boolean[] | void>;
184
- getSplit(name: string): MaybeThenable<string | null>;
185
- getSplits(names: string[]): MaybeThenable<Record<string, string | null>>;
186
- setChangeNumber(changeNumber: number): MaybeThenable<boolean | void>;
187
- getChangeNumber(): MaybeThenable<number>;
188
- getAll(): MaybeThenable<string[]>;
189
- getSplitNames(): MaybeThenable<string[]>;
190
- trafficTypeExists(trafficType: string): MaybeThenable<boolean>;
191
- usesSegments(): MaybeThenable<boolean>;
192
- clear(): MaybeThenable<boolean | void>;
193
- checkCache(): MaybeThenable<boolean>;
194
- killLocally(name: string, defaultTreatment: string, changeNumber: number): MaybeThenable<boolean>;
195
- }
196
- export interface ISplitsCacheSync extends ISplitsCacheBase {
197
- addSplits(entries: [string, string][]): boolean[];
198
- removeSplits(names: string[]): boolean[];
199
- getSplit(name: string): string | null;
200
- getSplits(names: string[]): Record<string, string | null>;
201
- setChangeNumber(changeNumber: number): boolean;
202
- getChangeNumber(): number;
203
- getAll(): string[];
204
- getSplitNames(): string[];
205
- trafficTypeExists(trafficType: string): boolean;
206
- usesSegments(): boolean;
207
- clear(): void;
208
- checkCache(): boolean;
209
- killLocally(name: string, defaultTreatment: string, changeNumber: number): boolean;
210
- }
211
- export interface ISplitsCacheAsync extends ISplitsCacheBase {
212
- addSplits(entries: [string, string][]): Promise<boolean[] | void>;
213
- removeSplits(names: string[]): Promise<boolean[] | void>;
214
- getSplit(name: string): Promise<string | null>;
215
- getSplits(names: string[]): Promise<Record<string, string | null>>;
216
- setChangeNumber(changeNumber: number): Promise<boolean | void>;
217
- getChangeNumber(): Promise<number>;
218
- getAll(): Promise<string[]>;
219
- getSplitNames(): Promise<string[]>;
220
- trafficTypeExists(trafficType: string): Promise<boolean>;
221
- usesSegments(): Promise<boolean>;
222
- clear(): Promise<boolean | void>;
223
- checkCache(): Promise<boolean>;
224
- killLocally(name: string, defaultTreatment: string, changeNumber: number): Promise<boolean>;
225
- }
226
- /** Segments cache */
227
- export interface ISegmentsCacheBase {
228
- addToSegment(name: string, segmentKeys: string[]): MaybeThenable<boolean | void>;
229
- removeFromSegment(name: string, segmentKeys: string[]): MaybeThenable<boolean | void>;
230
- isInSegment(name: string, key?: string): MaybeThenable<boolean>;
231
- registerSegments(names: string[]): MaybeThenable<boolean | void>;
232
- getRegisteredSegments(): MaybeThenable<string[]>;
233
- setChangeNumber(name: string, changeNumber: number): MaybeThenable<boolean | void>;
234
- getChangeNumber(name: string): MaybeThenable<number>;
235
- clear(): MaybeThenable<boolean | void>;
236
- }
237
- export interface ISegmentsCacheSync extends ISegmentsCacheBase {
238
- addToSegment(name: string, segmentKeys?: string[]): boolean;
239
- removeFromSegment(name: string, segmentKeys?: string[]): boolean;
240
- isInSegment(name: string, key?: string): boolean;
241
- registerSegments(names: string[]): boolean;
242
- getRegisteredSegments(): string[];
243
- getKeysCount(): number;
244
- setChangeNumber(name: string, changeNumber: number): boolean;
245
- getChangeNumber(name: string): number;
246
- resetSegments(names: string[]): boolean;
247
- clear(): void;
248
- }
249
- export interface ISegmentsCacheAsync extends ISegmentsCacheBase {
250
- addToSegment(name: string, segmentKeys: string[]): Promise<boolean | void>;
251
- removeFromSegment(name: string, segmentKeys: string[]): Promise<boolean | void>;
252
- isInSegment(name: string, key: string): Promise<boolean>;
253
- registerSegments(names: string[]): Promise<boolean | void>;
254
- getRegisteredSegments(): Promise<string[]>;
255
- setChangeNumber(name: string, changeNumber: number): Promise<boolean | void>;
256
- getChangeNumber(name: string): Promise<number>;
257
- clear(): Promise<boolean | void>;
258
- }
259
- /** Recorder storages (impressions, events and telemetry) */
260
- export interface IImpressionsCacheBase {
261
- track(data: ImpressionDTO[]): MaybeThenable<void>;
262
- }
263
- export interface IEventsCacheBase {
264
- track(data: SplitIO.EventData, size?: number): MaybeThenable<boolean>;
265
- }
266
- /** Impressions and events cache for standalone mode (sync) */
267
- export interface IRecorderCacheProducerSync<T> {
268
- isEmpty(): boolean;
269
- clear(): void;
270
- pop(toMerge?: T): T;
271
- }
272
- export interface IImpressionsCacheSync extends IImpressionsCacheBase, IRecorderCacheProducerSync<ImpressionDTO[]> {
273
- track(data: ImpressionDTO[]): void;
274
- setOnFullQueueCb(cb: () => void): void;
275
- }
276
- export interface IEventsCacheSync extends IEventsCacheBase, IRecorderCacheProducerSync<SplitIO.EventData[]> {
277
- track(data: SplitIO.EventData, size?: number): boolean;
278
- setOnFullQueueCb(cb: () => void): void;
279
- }
280
- /** Impressions and events cache for consumer and producer mode (async) */
281
- export interface IRecorderCacheProducerAsync<T> {
282
- count(): Promise<number>;
283
- drop(count?: number): Promise<void>;
284
- popNWithMetadata(count: number): Promise<T>;
285
- }
286
- export interface IImpressionsCacheAsync extends IImpressionsCacheBase, IRecorderCacheProducerAsync<StoredImpressionWithMetadata[]> {
287
- track(data: ImpressionDTO[]): Promise<void>;
288
- }
289
- export interface IEventsCacheAsync extends IEventsCacheBase, IRecorderCacheProducerAsync<StoredEventWithMetadata[]> {
290
- track(data: SplitIO.EventData, size?: number): Promise<boolean>;
291
- }
292
- /**
293
- * Impression counts cache for impressions dedup in standalone and producer mode.
294
- * Only in memory. Named `ImpressionsCounter` in spec.
295
- */
296
- export interface IImpressionCountsCacheSync extends IRecorderCacheProducerSync<Record<string, number>> {
297
- track(featureName: string, timeFrame: number, amount: number): void;
298
- isEmpty(): boolean;
299
- pop(toMerge?: Record<string, number>): Record<string, number>;
300
- }
301
- export interface IUniqueKeysCacheBase extends IRecorderCacheProducerSync<{
302
- [featureName: string]: ISet<string>;
303
- }> {
304
- track(featureName: string, timeFrame: number, amount: number): void;
305
- isEmpty(): boolean;
306
- pop(toMerge?: {
307
- [featureName: string]: ISet<string>;
308
- }): {
309
- [featureName: string]: ISet<string>;
310
- };
311
- }
312
- /**
313
- * Telemetry storage interface for standalone and partial consumer modes.
314
- * Methods are sync because data is stored in memory.
315
- */
316
- export interface ITelemetryInitConsumerSync {
317
- getTimeUntilReady(): number | undefined;
318
- getTimeUntilReadyFromCache(): number | undefined;
319
- getNonReadyUsage(): number;
320
- }
321
- export interface ITelemetryRuntimeConsumerSync {
322
- getImpressionStats(type: ImpressionDataType): number;
323
- getEventStats(type: EventDataType): number;
324
- getLastSynchronization(): LastSync;
325
- popHttpErrors(): HttpErrors;
326
- popHttpLatencies(): HttpLatencies;
327
- popAuthRejections(): number;
328
- popTokenRefreshes(): number;
329
- popStreamingEvents(): Array<StreamingEvent>;
330
- popTags(): Array<string> | undefined;
331
- getSessionLength(): number | undefined;
332
- }
333
- export interface ITelemetryEvaluationConsumerSync {
334
- popExceptions(): MethodExceptions;
335
- popLatencies(): MethodLatencies;
336
- }
337
- export interface ITelemetryStorageConsumerSync extends ITelemetryInitConsumerSync, ITelemetryRuntimeConsumerSync, ITelemetryEvaluationConsumerSync {
338
- }
339
- export interface ITelemetryInitProducerSync {
340
- recordTimeUntilReady(ms: number): void;
341
- recordTimeUntilReadyFromCache(ms: number): void;
342
- recordNonReadyUsage(): void;
343
- }
344
- export interface ITelemetryRuntimeProducerSync {
345
- addTag(tag: string): void;
346
- recordImpressionStats(type: ImpressionDataType, count: number): void;
347
- recordEventStats(type: EventDataType, count: number): void;
348
- recordSuccessfulSync(resource: OperationType, timeMs: number): void;
349
- recordHttpError(resource: OperationType, status: number): void;
350
- recordHttpLatency(resource: OperationType, latencyMs: number): void;
351
- recordAuthRejections(): void;
352
- recordTokenRefreshes(): void;
353
- recordStreamingEvents(streamingEvent: StreamingEvent): void;
354
- recordSessionLength(ms: number): void;
355
- }
356
- export interface ITelemetryEvaluationProducerSync {
357
- recordLatency(method: Method, latencyMs: number): void;
358
- recordException(method: Method): void;
359
- }
360
- export interface ITelemetryStorageProducerSync extends ITelemetryInitProducerSync, ITelemetryRuntimeProducerSync, ITelemetryEvaluationProducerSync {
361
- }
362
- export interface ITelemetryCacheSync extends ITelemetryStorageConsumerSync, ITelemetryStorageProducerSync {
363
- }
364
- /**
365
- * Telemetry storage interface for consumer mode.
366
- * Methods are async because data is stored in Redis or a pluggable storage.
367
- */
368
- export interface ITelemetryEvaluationConsumerAsync {
369
- popExceptions(): Promise<MethodExceptions>;
370
- popLatencies(): Promise<MethodLatencies>;
371
- }
372
- export interface ITelemetryEvaluationProducerAsync {
373
- recordLatency(method: Method, latencyMs: number): Promise<any>;
374
- recordException(method: Method): Promise<any>;
375
- }
376
- export interface ITelemetryCacheAsync extends ITelemetryEvaluationProducerAsync {
377
- }
378
- /**
379
- * Storages
380
- */
381
- export interface IStorageBase<TSplitsCache extends ISplitsCacheBase, TSegmentsCache extends ISegmentsCacheBase, TImpressionsCache extends IImpressionsCacheBase, TEventsCache extends IEventsCacheBase, TTelemetryCache extends ITelemetryCacheSync | ITelemetryCacheAsync, TUniqueKeysCache extends IUniqueKeysCacheBase> {
382
- splits: TSplitsCache;
383
- segments: TSegmentsCache;
384
- impressions: TImpressionsCache;
385
- impressionCounts?: IImpressionCountsCacheSync;
386
- events: TEventsCache;
387
- telemetry?: TTelemetryCache;
388
- uniqueKeys?: TUniqueKeysCache;
389
- destroy(): void | Promise<void>;
390
- shared?: (matchingKey: string, onReadyCb: (error?: any) => void) => this;
391
- }
392
- export interface IStorageSync extends IStorageBase<ISplitsCacheSync, ISegmentsCacheSync, IImpressionsCacheSync, IEventsCacheSync, ITelemetryCacheSync, IUniqueKeysCacheBase> {
393
- }
394
- export interface IStorageAsync extends IStorageBase<ISplitsCacheAsync, ISegmentsCacheAsync, IImpressionsCacheAsync | IImpressionsCacheSync, IEventsCacheAsync | IEventsCacheSync, ITelemetryCacheAsync, IUniqueKeysCacheBase> {
395
- }
396
- /** StorageFactory */
397
- export declare type DataLoader = (storage: IStorageSync, matchingKey: string) => void;
398
- export interface IStorageFactoryParams {
399
- log: ILogger;
400
- impressionsQueueSize?: number;
401
- eventsQueueSize?: number;
402
- optimize?: boolean;
403
- mode: SDKMode;
404
- matchingKey?: string;
405
- splitFiltersValidation?: ISplitFiltersValidation;
406
- onReadyCb: (error?: any) => void;
407
- metadata: IMetadata;
408
- }
409
- export declare type StorageType = 'MEMORY' | 'LOCALSTORAGE' | 'REDIS' | 'PLUGGABLE';
410
- export declare type IStorageSyncFactory = {
411
- readonly type: StorageType;
412
- (params: IStorageFactoryParams): IStorageSync;
413
- };
414
- export declare type IStorageAsyncFactory = {
415
- type: StorageType;
416
- (params: IStorageFactoryParams): IStorageAsync;
417
- };
@@ -1,2 +0,0 @@
1
- import { SplitIO } from '../../types';
2
- export declare function LocalhostFromFile(): SplitIO.LocalhostFactory;
@@ -1,2 +0,0 @@
1
- import { SplitIO } from '../../types';
2
- export declare function LocalhostFromObject(): SplitIO.LocalhostFactory;
@@ -1,7 +0,0 @@
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;
@@ -1,2 +0,0 @@
1
- import { ISplitsParser } from './types';
2
- export declare function splitsParserFromFileFactory(): ISplitsParser;
@@ -1,3 +0,0 @@
1
- import { ISplitPartial } from '../../../dtos/types';
2
- import { ISettings } from '../../../types';
3
- export declare function splitsParserFromSettingsFactory(): (settings: ISettings) => false | Record<string, ISplitPartial>;
@@ -1,3 +0,0 @@
1
- import { ISplitPartial } from '../../../dtos/types';
2
- import { ISettings } from '../../../types';
3
- export declare type ISplitsParser = (settings: ISettings) => false | Record<string, ISplitPartial>;
@@ -1,10 +0,0 @@
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;
@@ -1,17 +0,0 @@
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>;
@@ -1,7 +0,0 @@
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;
@@ -1,7 +0,0 @@
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;
@@ -1,7 +0,0 @@
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;
@@ -1,5 +0,0 @@
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[]>;