@splitsoftware/splitio-commons 1.17.1-rc.3 → 2.0.0-rc.0

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 (216) hide show
  1. package/CHANGES.txt +7 -3
  2. package/cjs/evaluator/index.js +2 -2
  3. package/cjs/evaluator/matchers/semver_inlist.js +1 -2
  4. package/cjs/evaluator/matchers/whitelist.js +1 -2
  5. package/cjs/listeners/browser.js +1 -2
  6. package/cjs/logger/browser/DebugLogger.js +1 -2
  7. package/cjs/logger/browser/ErrorLogger.js +1 -2
  8. package/cjs/logger/browser/InfoLogger.js +1 -2
  9. package/cjs/logger/browser/WarnLogger.js +1 -2
  10. package/cjs/logger/index.js +1 -2
  11. package/cjs/readiness/readinessManager.js +5 -7
  12. package/cjs/sdkClient/clientCS.js +5 -8
  13. package/cjs/sdkClient/sdkClientMethodCS.js +5 -8
  14. package/cjs/sdkFactory/index.js +10 -33
  15. package/cjs/services/decorateHeaders.js +1 -2
  16. package/cjs/storages/AbstractSplitsCacheAsync.js +7 -0
  17. package/cjs/storages/AbstractSplitsCacheSync.js +7 -0
  18. package/cjs/storages/KeyBuilderCS.js +0 -9
  19. package/cjs/storages/dataLoader.js +32 -64
  20. package/cjs/storages/inLocalStorage/MySegmentsCacheInLocal.js +1 -21
  21. package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +14 -7
  22. package/cjs/storages/inLocalStorage/index.js +1 -6
  23. package/cjs/storages/inMemory/InMemoryStorageCS.js +4 -16
  24. package/cjs/storages/inMemory/SegmentsCacheInMemory.js +3 -4
  25. package/cjs/storages/inMemory/SplitsCacheInMemory.js +2 -3
  26. package/cjs/storages/inMemory/UniqueKeysCacheInMemory.js +2 -3
  27. package/cjs/storages/inMemory/UniqueKeysCacheInMemoryCS.js +2 -3
  28. package/cjs/storages/inRedis/RedisAdapter.js +3 -4
  29. package/cjs/storages/inRedis/SplitsCacheInRedis.js +1 -1
  30. package/cjs/storages/inRedis/TelemetryCacheInRedis.js +3 -4
  31. package/cjs/storages/inRedis/UniqueKeysCacheInRedis.js +1 -2
  32. package/cjs/storages/pluggable/SplitsCachePluggable.js +1 -1
  33. package/cjs/storages/pluggable/TelemetryCachePluggable.js +6 -7
  34. package/cjs/storages/pluggable/UniqueKeysCachePluggable.js +1 -2
  35. package/cjs/storages/pluggable/inMemoryWrapper.js +7 -8
  36. package/cjs/storages/pluggable/index.js +32 -37
  37. package/cjs/sync/offline/syncTasks/fromObjectSyncTask.js +7 -2
  38. package/cjs/sync/polling/pollingManagerSS.js +3 -3
  39. package/cjs/sync/polling/updaters/splitChangesUpdater.js +13 -5
  40. package/cjs/sync/streaming/parseUtils.js +0 -1
  41. package/cjs/sync/streaming/pushManager.js +2 -3
  42. package/cjs/trackers/eventTracker.js +9 -11
  43. package/cjs/trackers/impressionsTracker.js +13 -15
  44. package/cjs/trackers/uniqueKeysTracker.js +3 -5
  45. package/cjs/utils/LRUCache/index.js +1 -2
  46. package/cjs/utils/constants/browser.js +1 -4
  47. package/cjs/utils/lang/index.js +6 -9
  48. package/cjs/utils/lang/objectAssign.js +12 -77
  49. package/cjs/utils/lang/sets.js +3 -110
  50. package/cjs/utils/settingsValidation/index.js +0 -9
  51. package/cjs/utils/settingsValidation/logger/builtinLogger.js +1 -2
  52. package/cjs/utils/settingsValidation/storage/storageCS.js +12 -1
  53. package/esm/evaluator/index.js +3 -3
  54. package/esm/evaluator/matchers/semver_inlist.js +1 -2
  55. package/esm/evaluator/matchers/whitelist.js +1 -2
  56. package/esm/listeners/browser.js +1 -2
  57. package/esm/logger/browser/DebugLogger.js +1 -2
  58. package/esm/logger/browser/ErrorLogger.js +1 -2
  59. package/esm/logger/browser/InfoLogger.js +1 -2
  60. package/esm/logger/browser/WarnLogger.js +1 -2
  61. package/esm/logger/index.js +1 -2
  62. package/esm/readiness/readinessManager.js +5 -7
  63. package/esm/sdkClient/clientCS.js +5 -8
  64. package/esm/sdkClient/sdkClientMethodCS.js +5 -8
  65. package/esm/sdkFactory/index.js +11 -34
  66. package/esm/services/decorateHeaders.js +1 -2
  67. package/esm/storages/AbstractSplitsCacheAsync.js +7 -0
  68. package/esm/storages/AbstractSplitsCacheSync.js +7 -0
  69. package/esm/storages/KeyBuilderCS.js +0 -9
  70. package/esm/storages/dataLoader.js +30 -61
  71. package/esm/storages/inLocalStorage/MySegmentsCacheInLocal.js +1 -21
  72. package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +14 -7
  73. package/esm/storages/inLocalStorage/index.js +2 -7
  74. package/esm/storages/inMemory/InMemoryStorageCS.js +4 -16
  75. package/esm/storages/inMemory/SegmentsCacheInMemory.js +3 -4
  76. package/esm/storages/inMemory/SplitsCacheInMemory.js +2 -3
  77. package/esm/storages/inMemory/UniqueKeysCacheInMemory.js +2 -3
  78. package/esm/storages/inMemory/UniqueKeysCacheInMemoryCS.js +2 -3
  79. package/esm/storages/inRedis/RedisAdapter.js +3 -4
  80. package/esm/storages/inRedis/SplitsCacheInRedis.js +2 -2
  81. package/esm/storages/inRedis/TelemetryCacheInRedis.js +3 -4
  82. package/esm/storages/inRedis/UniqueKeysCacheInRedis.js +1 -2
  83. package/esm/storages/pluggable/SplitsCachePluggable.js +2 -2
  84. package/esm/storages/pluggable/TelemetryCachePluggable.js +6 -7
  85. package/esm/storages/pluggable/UniqueKeysCachePluggable.js +1 -2
  86. package/esm/storages/pluggable/inMemoryWrapper.js +7 -8
  87. package/esm/storages/pluggable/index.js +32 -37
  88. package/esm/sync/offline/syncTasks/fromObjectSyncTask.js +8 -3
  89. package/esm/sync/polling/pollingManagerSS.js +3 -3
  90. package/esm/sync/polling/updaters/splitChangesUpdater.js +14 -6
  91. package/esm/sync/streaming/parseUtils.js +0 -1
  92. package/esm/sync/streaming/pushManager.js +2 -3
  93. package/esm/trackers/eventTracker.js +9 -11
  94. package/esm/trackers/impressionsTracker.js +13 -15
  95. package/esm/trackers/uniqueKeysTracker.js +3 -5
  96. package/esm/utils/LRUCache/index.js +1 -2
  97. package/esm/utils/constants/browser.js +0 -3
  98. package/esm/utils/lang/index.js +6 -9
  99. package/esm/utils/lang/objectAssign.js +12 -77
  100. package/esm/utils/lang/sets.js +2 -107
  101. package/esm/utils/settingsValidation/index.js +0 -9
  102. package/esm/utils/settingsValidation/logger/builtinLogger.js +1 -2
  103. package/esm/utils/settingsValidation/storage/storageCS.js +10 -0
  104. package/package.json +2 -2
  105. package/src/evaluator/index.ts +5 -5
  106. package/src/evaluator/matchers/semver_inlist.ts +1 -2
  107. package/src/evaluator/matchers/whitelist.ts +1 -3
  108. package/src/listeners/browser.ts +1 -2
  109. package/src/logger/browser/DebugLogger.ts +1 -2
  110. package/src/logger/browser/ErrorLogger.ts +1 -2
  111. package/src/logger/browser/InfoLogger.ts +1 -2
  112. package/src/logger/browser/WarnLogger.ts +1 -2
  113. package/src/logger/index.ts +3 -4
  114. package/src/readiness/readinessManager.ts +7 -9
  115. package/src/readiness/types.ts +0 -1
  116. package/src/sdkClient/clientCS.ts +5 -8
  117. package/src/sdkClient/sdkClientMethodCS.ts +3 -6
  118. package/src/sdkFactory/index.ts +12 -37
  119. package/src/sdkFactory/types.ts +1 -4
  120. package/src/services/decorateHeaders.ts +1 -2
  121. package/src/storages/AbstractSplitsCacheAsync.ts +9 -2
  122. package/src/storages/AbstractSplitsCacheSync.ts +9 -2
  123. package/src/storages/KeyBuilderCS.ts +0 -13
  124. package/src/storages/dataLoader.ts +32 -62
  125. package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +1 -21
  126. package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +16 -8
  127. package/src/storages/inLocalStorage/index.ts +2 -8
  128. package/src/storages/inMemory/InMemoryStorageCS.ts +4 -19
  129. package/src/storages/inMemory/SegmentsCacheInMemory.ts +4 -5
  130. package/src/storages/inMemory/SplitsCacheInMemory.ts +4 -5
  131. package/src/storages/inMemory/UniqueKeysCacheInMemory.ts +4 -5
  132. package/src/storages/inMemory/UniqueKeysCacheInMemoryCS.ts +4 -5
  133. package/src/storages/inRedis/RedisAdapter.ts +4 -5
  134. package/src/storages/inRedis/SplitsCacheInRedis.ts +3 -3
  135. package/src/storages/inRedis/TelemetryCacheInRedis.ts +3 -4
  136. package/src/storages/inRedis/UniqueKeysCacheInRedis.ts +1 -2
  137. package/src/storages/pluggable/SegmentsCachePluggable.ts +0 -1
  138. package/src/storages/pluggable/SplitsCachePluggable.ts +3 -3
  139. package/src/storages/pluggable/TelemetryCachePluggable.ts +6 -7
  140. package/src/storages/pluggable/UniqueKeysCachePluggable.ts +1 -2
  141. package/src/storages/pluggable/inMemoryWrapper.ts +8 -9
  142. package/src/storages/pluggable/index.ts +33 -38
  143. package/src/storages/types.ts +9 -6
  144. package/src/sync/offline/syncTasks/fromObjectSyncTask.ts +7 -3
  145. package/src/sync/polling/pollingManagerSS.ts +2 -3
  146. package/src/sync/polling/updaters/splitChangesUpdater.ts +15 -8
  147. package/src/sync/streaming/parseUtils.ts +0 -1
  148. package/src/sync/streaming/pushManager.ts +3 -4
  149. package/src/sync/submitters/types.ts +3 -4
  150. package/src/trackers/eventTracker.ts +7 -10
  151. package/src/trackers/impressionsTracker.ts +9 -12
  152. package/src/trackers/types.ts +0 -1
  153. package/src/trackers/uniqueKeysTracker.ts +4 -6
  154. package/src/types.ts +9 -18
  155. package/src/utils/LRUCache/index.ts +2 -3
  156. package/src/utils/constants/browser.ts +0 -4
  157. package/src/utils/lang/index.ts +6 -7
  158. package/src/utils/lang/objectAssign.ts +13 -92
  159. package/src/utils/lang/sets.ts +3 -125
  160. package/src/utils/settingsValidation/index.ts +0 -10
  161. package/src/utils/settingsValidation/logger/builtinLogger.ts +1 -2
  162. package/src/utils/settingsValidation/storage/storageCS.ts +13 -0
  163. package/src/utils/settingsValidation/types.ts +0 -2
  164. package/types/logger/index.d.ts +1 -2
  165. package/types/readiness/types.d.ts +0 -1
  166. package/types/sdkClient/clientCS.d.ts +2 -3
  167. package/types/sdkFactory/types.d.ts +1 -3
  168. package/types/storages/AbstractSplitsCacheAsync.d.ts +6 -2
  169. package/types/storages/AbstractSplitsCacheSync.d.ts +6 -2
  170. package/types/storages/KeyBuilderCS.d.ts +0 -2
  171. package/types/storages/dataLoader.d.ts +6 -17
  172. package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +7 -2
  173. package/types/storages/inMemory/SplitsCacheInMemory.d.ts +1 -2
  174. package/types/storages/inMemory/UniqueKeysCacheInMemory.d.ts +2 -3
  175. package/types/storages/inRedis/SplitsCacheInRedis.d.ts +1 -2
  176. package/types/storages/pluggable/SplitsCachePluggable.d.ts +1 -2
  177. package/types/storages/pluggable/inMemoryWrapper.d.ts +1 -2
  178. package/types/storages/types.d.ts +7 -6
  179. package/types/sync/polling/updaters/splitChangesUpdater.d.ts +1 -2
  180. package/types/sync/submitters/types.d.ts +3 -4
  181. package/types/trackers/eventTracker.d.ts +1 -1
  182. package/types/trackers/impressionsTracker.d.ts +1 -1
  183. package/types/trackers/types.d.ts +0 -1
  184. package/types/types.d.ts +9 -17
  185. package/types/utils/LRUCache/index.d.ts +1 -2
  186. package/types/utils/constants/browser.d.ts +0 -2
  187. package/types/utils/lang/objectAssign.d.ts +3 -0
  188. package/types/utils/lang/sets.d.ts +1 -61
  189. package/types/utils/settingsValidation/index.d.ts +0 -1
  190. package/types/utils/settingsValidation/storage/storageCS.d.ts +5 -0
  191. package/types/utils/settingsValidation/types.d.ts +0 -2
  192. package/cjs/integrations/browser.js +0 -31
  193. package/cjs/integrations/ga/GaToSplit.js +0 -257
  194. package/cjs/integrations/ga/GoogleAnalyticsToSplit.js +0 -14
  195. package/cjs/integrations/ga/SplitToGa.js +0 -123
  196. package/cjs/integrations/ga/SplitToGoogleAnalytics.js +0 -14
  197. package/cjs/integrations/ga/types.js +0 -2
  198. package/cjs/sdkClient/sdkClientMethodCSWithTT.js +0 -79
  199. package/cjs/utils/lang/maps.js +0 -96
  200. package/esm/integrations/browser.js +0 -27
  201. package/esm/integrations/ga/GaToSplit.js +0 -250
  202. package/esm/integrations/ga/GoogleAnalyticsToSplit.js +0 -10
  203. package/esm/integrations/ga/SplitToGa.js +0 -120
  204. package/esm/integrations/ga/SplitToGoogleAnalytics.js +0 -10
  205. package/esm/integrations/ga/types.js +0 -1
  206. package/esm/sdkClient/sdkClientMethodCSWithTT.js +0 -75
  207. package/esm/utils/lang/maps.js +0 -92
  208. package/src/integrations/browser.ts +0 -35
  209. package/src/integrations/ga/GaToSplit.ts +0 -299
  210. package/src/integrations/ga/GoogleAnalyticsToSplit.ts +0 -14
  211. package/src/integrations/ga/SplitToGa.ts +0 -135
  212. package/src/integrations/ga/SplitToGoogleAnalytics.ts +0 -14
  213. package/src/integrations/ga/autoRequire.js +0 -33
  214. package/src/integrations/ga/types.ts +0 -153
  215. package/src/sdkClient/sdkClientMethodCSWithTT.ts +0 -101
  216. package/src/utils/lang/maps.ts +0 -108
package/CHANGES.txt CHANGED
@@ -1,11 +1,15 @@
1
- 2.0.0 (September XX, 2024)
2
- - Updated internal storage factory to emit the SDK_READY_FROM_CACHE event when it corresponds, to clean up the initialization flow.
3
- - Added `factory.destroy()` method, which invokes the `destroy` method on all SDK clients created by the factory.
1
+ 2.0.0 (October XX, 2024)
4
2
  - Added support for targeting rules based on large segments.
3
+ - Added `factory.destroy()` method, which invokes the `destroy` method on all SDK clients created by the factory.
4
+ - Bugfixing - Fixed an issue with the server-side polling manager that caused dangling timers when the SDK was destroyed before it was ready.
5
5
  - BREAKING CHANGES:
6
6
  - Updated default flag spec version to 1.2.
7
7
  - Removed `/mySegments` endpoint from SplitAPI module, as it is replaced by `/memberships` endpoint.
8
8
  - Removed support for MY_SEGMENTS_UPDATE and MY_SEGMENTS_UPDATE_V2 notification types, as they are replaced by MEMBERSHIPS_MS_UPDATE and MEMBERSHIPS_LS_UPDATE notification types.
9
+ - Removed the deprecated `GOOGLE_ANALYTICS_TO_SPLIT` and `SPLIT_TO_GOOGLE_ANALYTICS` integrations.
10
+ - Removed internal ponyfills for `Map`, `Set` and `Array.from` global objects, dropping support for IE and other outdated browsers. The SDK now requires the runtime environment to support these features natively or to provide a polyfill.
11
+ - Removed the migration logic for the old format of MySegments keys in LocalStorage introduced in JavaScript SDK v10.17.3.
12
+ - Removed the `sdkClientMethodCSWithTT` function, which handled the logic to bound an optional traffic type to SDK clients. Client-side SDK implementations must use `sdkClientMethodCS` module, which, unlike the previous function, does not allow passing a traffic type but simplifies the SDK API.
9
13
 
10
14
  1.17.0 (September 6, 2024)
11
15
  - Added `sync.requestOptions.getHeaderOverrides` configuration option to enhance SDK HTTP request Headers for Authorization Frameworks.
@@ -59,7 +59,7 @@ exports.evaluateFeatures = evaluateFeatures;
59
59
  function evaluateFeaturesByFlagSets(log, key, flagSets, attributes, storage, method) {
60
60
  var storedFlagNames;
61
61
  function evaluate(featureFlagsByFlagSets) {
62
- var featureFlags = new sets_1._Set();
62
+ var featureFlags = new Set();
63
63
  for (var i = 0; i < flagSets.length; i++) {
64
64
  var featureFlagByFlagSet = featureFlagsByFlagSets[i];
65
65
  if (featureFlagByFlagSet.size) {
@@ -70,7 +70,7 @@ function evaluateFeaturesByFlagSets(log, key, flagSets, attributes, storage, met
70
70
  }
71
71
  }
72
72
  return featureFlags.size ?
73
- evaluateFeatures(log, key, (0, sets_1.setToArray)(featureFlags), attributes, storage) :
73
+ evaluateFeatures(log, key, Array.from(featureFlags), attributes, storage) :
74
74
  {};
75
75
  }
76
76
  // get features by flag sets
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.inListSemverMatcherContext = void 0;
4
- var sets_1 = require("../../utils/lang/sets");
5
4
  var Semver_1 = require("../../utils/Semver");
6
5
  function inListSemverMatcherContext(ruleAttr) {
7
6
  // @TODO ruleAttr validation should be done at the `parser` or `matchersTransform` level to reuse for all matchers
8
7
  if (!ruleAttr || ruleAttr.length === 0)
9
8
  throw new Error('whitelistMatcherData is required for IN_LIST_SEMVER matcher type');
10
- var listOfSemvers = new sets_1._Set(ruleAttr.map(function (version) { return new Semver_1.Semver(version).version; }));
9
+ var listOfSemvers = new Set(ruleAttr.map(function (version) { return new Semver_1.Semver(version).version; }));
11
10
  return function inListSemverMatcher(runtimeAttr) {
12
11
  var runtimeSemver = new Semver_1.Semver(runtimeAttr).version;
13
12
  var isInList = listOfSemvers.has(runtimeSemver);
@@ -1,9 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.whitelistMatcherContext = void 0;
4
- var sets_1 = require("../../utils/lang/sets");
5
4
  function whitelistMatcherContext(ruleAttr) {
6
- var whitelistSet = new sets_1._Set(ruleAttr);
5
+ var whitelistSet = new Set(ruleAttr);
7
6
  return function whitelistMatcher(runtimeAttr) {
8
7
  var isInWhitelist = whitelistSet.has(runtimeAttr);
9
8
  return isInWhitelist;
@@ -100,7 +100,6 @@ var BrowserSignalListener = /** @class */ (function () {
100
100
  * Returns true if beacon API was used successfully, false otherwise.
101
101
  */
102
102
  BrowserSignalListener.prototype._sendBeacon = function (url, data, extraMetadata) {
103
- // eslint-disable-next-line compat/compat
104
103
  if (typeof navigator !== 'undefined' && navigator.sendBeacon) {
105
104
  var json = {
106
105
  entries: data,
@@ -113,7 +112,7 @@ var BrowserSignalListener = /** @class */ (function () {
113
112
  // Stringify the payload
114
113
  var payload = JSON.stringify(json);
115
114
  // https://xgwang.me/posts/you-may-not-know-beacon/#it-may-throw-error%2C-be-sure-to-catch
116
- try { // eslint-disable-next-line compat/compat
115
+ try {
117
116
  return navigator.sendBeacon(url, payload);
118
117
  }
119
118
  catch (e) {
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.DebugLogger = void 0;
4
4
  var index_1 = require("../index");
5
5
  var debug_1 = require("../messages/debug");
6
- var maps_1 = require("../../utils/lang/maps");
7
6
  function DebugLogger() {
8
- return new index_1.Logger({ logLevel: 'DEBUG' }, new maps_1._Map(debug_1.codesDebug));
7
+ return new index_1.Logger({ logLevel: 'DEBUG' }, new Map(debug_1.codesDebug));
9
8
  }
10
9
  exports.DebugLogger = DebugLogger;
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ErrorLogger = void 0;
4
4
  var index_1 = require("../index");
5
5
  var error_1 = require("../messages/error");
6
- var maps_1 = require("../../utils/lang/maps");
7
6
  function ErrorLogger() {
8
- return new index_1.Logger({ logLevel: 'ERROR' }, new maps_1._Map(error_1.codesError));
7
+ return new index_1.Logger({ logLevel: 'ERROR' }, new Map(error_1.codesError));
9
8
  }
10
9
  exports.ErrorLogger = ErrorLogger;
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.InfoLogger = void 0;
4
4
  var index_1 = require("../index");
5
5
  var info_1 = require("../messages/info");
6
- var maps_1 = require("../../utils/lang/maps");
7
6
  function InfoLogger() {
8
- return new index_1.Logger({ logLevel: 'INFO' }, new maps_1._Map(info_1.codesInfo));
7
+ return new index_1.Logger({ logLevel: 'INFO' }, new Map(info_1.codesInfo));
9
8
  }
10
9
  exports.InfoLogger = InfoLogger;
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.WarnLogger = void 0;
4
4
  var index_1 = require("../index");
5
5
  var warn_1 = require("../messages/warn");
6
- var maps_1 = require("../../utils/lang/maps");
7
6
  function WarnLogger() {
8
- return new index_1.Logger({ logLevel: 'WARN' }, new maps_1._Map(warn_1.codesWarn));
7
+ return new index_1.Logger({ logLevel: 'WARN' }, new Map(warn_1.codesWarn));
9
8
  }
10
9
  exports.WarnLogger = WarnLogger;
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.Logger = exports._sprintf = exports.isLogLevelString = exports.LogLevels = void 0;
4
4
  var objectAssign_1 = require("../utils/lang/objectAssign");
5
5
  var lang_1 = require("../utils/lang");
6
- var maps_1 = require("../utils/lang/maps");
7
6
  exports.LogLevels = {
8
7
  DEBUG: 'DEBUG',
9
8
  INFO: 'INFO',
@@ -47,7 +46,7 @@ var defaultOptions = {
47
46
  var Logger = /** @class */ (function () {
48
47
  function Logger(options, codes) {
49
48
  this.options = (0, objectAssign_1.objectAssign)({}, defaultOptions, options);
50
- this.codes = codes || new maps_1._Map();
49
+ this.codes = codes || new Map();
51
50
  this.logLevel = LogLevelIndexes[this.options.logLevel];
52
51
  }
53
52
  Logger.prototype.setLogLevel = function (logLevel) {
@@ -45,14 +45,17 @@ function readinessManagerFactory(EventEmitter, settings, splits) {
45
45
  splits.once(constants_1.SDK_SPLITS_CACHE_LOADED, checkIsReadyFromCache);
46
46
  // emit SDK_READY_TIMED_OUT
47
47
  var hasTimedout = false;
48
- var readyTimeoutId;
49
48
  function timeout() {
50
- if (hasTimedout || isReady)
49
+ if (hasTimedout)
51
50
  return;
52
51
  hasTimedout = true;
53
52
  syncLastUpdate();
54
53
  gate.emit(constants_1.SDK_READY_TIMED_OUT, 'Split SDK emitted SDK_READY_TIMED_OUT event.');
55
54
  }
55
+ var readyTimeoutId;
56
+ if (readyTimeout > 0) {
57
+ readyTimeoutId = setTimeout(timeout, readyTimeout);
58
+ }
56
59
  // emit SDK_READY and SDK_UPDATE
57
60
  var isReady = false;
58
61
  splits.on(constants_1.SDK_SPLITS_ARRIVED, checkIsReadyOrUpdate);
@@ -113,11 +116,6 @@ function readinessManagerFactory(EventEmitter, settings, splits) {
113
116
  // Called on 403 error (client-side SDK key on server-side), to set the SDK as destroyed for
114
117
  // tracking and evaluations, while keeping event listeners to emit SDK_READY_TIMED_OUT event
115
118
  setDestroyed: function () { isDestroyed = true; },
116
- init: function () {
117
- if (readyTimeout > 0) {
118
- readyTimeoutId = setTimeout(timeout, readyTimeout);
119
- }
120
- },
121
119
  destroy: function () {
122
120
  isDestroyed = true;
123
121
  syncLastUpdate();
@@ -4,16 +4,15 @@ exports.clientCSDecorator = void 0;
4
4
  var objectAssign_1 = require("../utils/lang/objectAssign");
5
5
  var clientAttributesDecoration_1 = require("./clientAttributesDecoration");
6
6
  /**
7
- * Decorator that binds a key and (optionally) a traffic type to client methods
7
+ * Decorator that binds a key to client methods
8
8
  *
9
9
  * @param client sync client instance
10
10
  * @param key validated split key
11
- * @param trafficType validated traffic type
12
11
  */
13
- function clientCSDecorator(log, client, key, trafficType) {
12
+ function clientCSDecorator(log, client, key) {
14
13
  var clientCS = (0, clientAttributesDecoration_1.clientAttributesDecoration)(log, client);
15
14
  return (0, objectAssign_1.objectAssign)(clientCS, {
16
- // In the client-side API, we bind a key to the client `getTreatment*` methods
15
+ // In the client-side API, we bind a key to the client `getTreatment*` and `track` methods
17
16
  getTreatment: clientCS.getTreatment.bind(clientCS, key),
18
17
  getTreatmentWithConfig: clientCS.getTreatmentWithConfig.bind(clientCS, key),
19
18
  getTreatments: clientCS.getTreatments.bind(clientCS, key),
@@ -22,12 +21,10 @@ function clientCSDecorator(log, client, key, trafficType) {
22
21
  getTreatmentsWithConfigByFlagSets: clientCS.getTreatmentsWithConfigByFlagSets.bind(clientCS, key),
23
22
  getTreatmentsByFlagSet: clientCS.getTreatmentsByFlagSet.bind(clientCS, key),
24
23
  getTreatmentsWithConfigByFlagSet: clientCS.getTreatmentsWithConfigByFlagSet.bind(clientCS, key),
25
- // Key is bound to the `track` method. Same thing happens with trafficType but only if provided
26
- track: trafficType ? clientCS.track.bind(clientCS, key, trafficType) : clientCS.track.bind(clientCS, key),
24
+ track: clientCS.track.bind(clientCS, key),
27
25
  // Not part of the public API. These properties are used to support other modules (e.g., Split Suite)
28
26
  isClientSide: true,
29
- key: key,
30
- trafficType: trafficType
27
+ key: key
31
28
  });
32
29
  }
33
30
  exports.clientCSDecorator = clientCSDecorator;
@@ -14,7 +14,7 @@ var identity_1 = require("./identity");
14
14
  * Therefore, clients don't have a bound TT for the track method.
15
15
  */
16
16
  function sdkClientMethodCSFactory(params) {
17
- var clients = params.clients, storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, key = _a.core.key, log = _a.log, whenInit = params.whenInit;
17
+ var clients = params.clients, storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, key = _a.core.key, log = _a.log;
18
18
  var mainClientInstance = (0, clientCS_1.clientCSDecorator)(log, (0, sdkClient_1.sdkClientFactory)(params), key);
19
19
  var parsedDefaultKey = (0, key_2.keyParser)(key);
20
20
  var defaultInstanceId = (0, identity_1.buildInstanceId)(parsedDefaultKey);
@@ -25,7 +25,7 @@ function sdkClientMethodCSFactory(params) {
25
25
  log.debug(constants_1.RETRIEVE_CLIENT_DEFAULT);
26
26
  return mainClientInstance;
27
27
  }
28
- // Validate the key value. The trafficType (2nd argument) is ignored
28
+ // Validate the key value
29
29
  var validKey = (0, key_1.validateKey)(log, key, constants_1.LOG_PREFIX_CLIENT_INSTANTIATION);
30
30
  if (validKey === false) {
31
31
  throw new Error('Shared Client needs a valid key.');
@@ -47,18 +47,15 @@ function sdkClientMethodCSFactory(params) {
47
47
  // - Consumer mode: both syncManager and sharedSyncManager are undefined
48
48
  // - Consumer partial mode: syncManager is defined (only for submitters) but sharedSyncManager is undefined
49
49
  // @ts-ignore
50
- var sharedSyncManager_1 = syncManager && sharedStorage && syncManager.shared(matchingKey, sharedSdkReadiness_1.readinessManager, sharedStorage);
50
+ var sharedSyncManager = syncManager && sharedStorage && syncManager.shared(matchingKey, sharedSdkReadiness_1.readinessManager, sharedStorage);
51
51
  // As shared clients reuse all the storage information, we don't need to check here if we
52
52
  // will use offline or online mode. We should stick with the original decision.
53
53
  clients[instanceId] = (0, clientCS_1.clientCSDecorator)(log, (0, sdkClient_1.sdkClientFactory)((0, objectAssign_1.objectAssign)({}, params, {
54
54
  sdkReadinessManager: sharedSdkReadiness_1,
55
55
  storage: sharedStorage || storage,
56
- syncManager: sharedSyncManager_1,
56
+ syncManager: sharedSyncManager,
57
57
  }), true), validKey);
58
- whenInit(function () {
59
- sharedSdkReadiness_1.readinessManager.init();
60
- sharedSyncManager_1 && sharedSyncManager_1.start();
61
- });
58
+ sharedSyncManager && sharedSyncManager.start();
62
59
  log.info(constants_1.NEW_SHARED_CLIENT);
63
60
  }
64
61
  else {
@@ -19,19 +19,12 @@ var constants_3 = require("../utils/constants");
19
19
  * Modular SDK factory
20
20
  */
21
21
  function sdkFactory(params) {
22
- var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory, filterAdapterFactory = params.filterAdapterFactory, isPure = params.isPure;
22
+ var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory, filterAdapterFactory = params.filterAdapterFactory;
23
23
  var log = settings.log, impressionsMode = settings.sync.impressionsMode;
24
24
  // @TODO handle non-recoverable errors, such as, global `fetch` not available, invalid SDK Key, etc.
25
25
  // On non-recoverable errors, we should mark the SDK as destroyed and not start synchronization.
26
- // initialization
27
- var isInit = false;
28
- var initCallbacks = [];
29
- function whenInit(cb) {
30
- if (isInit)
31
- cb();
32
- else
33
- initCallbacks.push(cb);
34
- }
26
+ // We will just log and allow for the SDK to end up throwing an SDK_TIMEOUT event for devs to handle.
27
+ (0, apiKey_1.validateAndTrackApiKey)(log, settings.core.authorizationKey);
35
28
  var sdkReadinessManager = (0, sdkReadinessManager_1.sdkReadinessManagerFactory)(platform.EventEmitter, settings);
36
29
  var readiness = sdkReadinessManager.readinessManager;
37
30
  var storage = storageFactory({
@@ -45,10 +38,8 @@ function sdkFactory(params) {
45
38
  readiness.splits.emit(constants_2.SDK_SPLITS_ARRIVED);
46
39
  readiness.segments.emit(constants_2.SDK_SEGMENTS_ARRIVED);
47
40
  },
48
- onReadyFromCacheCb: function () {
49
- readiness.splits.emit(constants_2.SDK_SPLITS_CACHE_LOADED);
50
- }
51
41
  });
42
+ // @TODO add support for dataloader: `if (params.dataLoader) params.dataLoader(storage);`
52
43
  var clients = {};
53
44
  var telemetryTracker = (0, telemetryTracker_1.telemetryTrackerFactory)(storage.telemetry, platform.now);
54
45
  var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage, telemetryTracker: telemetryTracker });
@@ -65,11 +56,11 @@ function sdkFactory(params) {
65
56
  default:
66
57
  strategy = (0, strategyDebug_1.strategyDebugFactory)(observer);
67
58
  }
68
- var impressionsTracker = (0, impressionsTracker_1.impressionsTrackerFactory)(settings, storage.impressions, strategy, whenInit, integrationsManager, storage.telemetry);
69
- var eventTracker = (0, eventTracker_1.eventTrackerFactory)(settings, storage.events, whenInit, integrationsManager, storage.telemetry);
59
+ var impressionsTracker = (0, impressionsTracker_1.impressionsTrackerFactory)(settings, storage.impressions, strategy, integrationsManager, storage.telemetry);
60
+ var eventTracker = (0, eventTracker_1.eventTrackerFactory)(settings, storage.events, integrationsManager, storage.telemetry);
70
61
  // splitApi is used by SyncManager and Browser signal listener
71
62
  var splitApi = splitApiFactory && splitApiFactory(settings, platform, telemetryTracker);
72
- var ctx = { clients: clients, splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, uniqueKeysTracker: uniqueKeysTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform, whenInit: whenInit };
63
+ var ctx = { clients: clients, splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, uniqueKeysTracker: uniqueKeysTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
73
64
  var syncManager = syncManagerFactory && syncManagerFactory(ctx);
74
65
  ctx.syncManager = syncManager;
75
66
  var signalListener = SignalListener && new SignalListener(syncManager, settings, storage, splitApi);
@@ -77,22 +68,8 @@ function sdkFactory(params) {
77
68
  // SDK client and manager
78
69
  var clientMethod = sdkClientMethodFactory(ctx);
79
70
  var managerInstance = sdkManagerFactory(settings, storage.splits, sdkReadinessManager);
80
- function init() {
81
- if (isInit)
82
- return;
83
- isInit = true;
84
- // We will just log and allow for the SDK to end up throwing an SDK_TIMEOUT event for devs to handle.
85
- (0, apiKey_1.validateAndTrackApiKey)(log, settings.core.authorizationKey);
86
- readiness.init();
87
- storage.init && storage.init();
88
- uniqueKeysTracker && uniqueKeysTracker.start();
89
- syncManager && syncManager.start();
90
- signalListener && signalListener.start();
91
- initCallbacks.forEach(function (cb) { return cb(); });
92
- initCallbacks.length = 0;
93
- }
94
- if (!isPure)
95
- init();
71
+ syncManager && syncManager.start();
72
+ signalListener && signalListener.start();
96
73
  log.info(constants_1.NEW_FACTORY);
97
74
  // @ts-ignore
98
75
  return (0, objectAssign_1.objectAssign)({
@@ -109,6 +86,6 @@ function sdkFactory(params) {
109
86
  destroy: function () {
110
87
  return Promise.all(Object.keys(clients).map(function (key) { return clients[key].destroy(); })).then(function () { });
111
88
  }
112
- }, extraProps && extraProps(ctx), isPure && { init: init });
89
+ }, extraProps && extraProps(ctx));
113
90
  }
114
91
  exports.sdkFactory = sdkFactory;
@@ -2,8 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.decorateHeaders = void 0;
4
4
  var objectAssign_1 = require("../utils/lang/objectAssign");
5
- var sets_1 = require("../utils/lang/sets");
6
- var FORBIDDEN_HEADERS = new sets_1._Set([
5
+ var FORBIDDEN_HEADERS = new Set([
7
6
  'splitsdkclientkey',
8
7
  'splitsdkversion',
9
8
  'splitsdkmachineip',
@@ -14,6 +14,13 @@ var AbstractSplitsCacheAsync = /** @class */ (function () {
14
14
  AbstractSplitsCacheAsync.prototype.usesSegments = function () {
15
15
  return Promise.resolve(true);
16
16
  };
17
+ /**
18
+ * Check if the splits information is already stored in cache.
19
+ * Noop, just keeping the interface. This is used by client-side implementations only.
20
+ */
21
+ AbstractSplitsCacheAsync.prototype.checkCache = function () {
22
+ return Promise.resolve(false);
23
+ };
17
24
  /**
18
25
  * Kill `name` split and set `defaultTreatment` and `changeNumber`.
19
26
  * Used for SPLIT_KILL push notifications.
@@ -30,6 +30,13 @@ var AbstractSplitsCacheSync = /** @class */ (function () {
30
30
  var _this = this;
31
31
  return this.getSplitNames().map(function (key) { return _this.getSplit(key); });
32
32
  };
33
+ /**
34
+ * Check if the splits information is already stored in cache. This data can be preloaded.
35
+ * It is used as condition to emit SDK_SPLITS_CACHE_LOADED, and then SDK_READY_FROM_CACHE.
36
+ */
37
+ AbstractSplitsCacheSync.prototype.checkCache = function () {
38
+ return false;
39
+ };
33
40
  /**
34
41
  * Kill `name` split and set `defaultTreatment` and `changeNumber`.
35
42
  * Used for SPLIT_KILL push notifications.
@@ -23,12 +23,6 @@ var KeyBuilderCS = /** @class */ (function (_super) {
23
23
  if ((0, lang_1.startsWith)(builtSegmentKeyName, prefix))
24
24
  return builtSegmentKeyName.substr(prefix.length);
25
25
  };
26
- // @BREAKING: The key used to start with the matching key instead of the prefix, this was changed on version 10.17.3
27
- KeyBuilderCS.prototype.extractOldSegmentKey = function (builtSegmentKeyName) {
28
- var prefix = this.matchingKey + "." + this.prefix + ".segment.";
29
- if ((0, lang_1.startsWith)(builtSegmentKeyName, prefix))
30
- return builtSegmentKeyName.substr(prefix.length);
31
- };
32
26
  KeyBuilderCS.prototype.buildLastUpdatedKey = function () {
33
27
  return this.prefix + ".splits.lastUpdated";
34
28
  };
@@ -51,9 +45,6 @@ function myLargeSegmentsKeyBuilder(prefix, matchingKey) {
51
45
  if ((0, lang_1.startsWith)(builtSegmentKeyName, p))
52
46
  return builtSegmentKeyName.substr(p.length);
53
47
  },
54
- extractOldSegmentKey: function () {
55
- return undefined;
56
- },
57
48
  buildTillKey: function () {
58
49
  return prefix + "." + matchingKey + ".largeSegments.till";
59
50
  }
@@ -1,83 +1,51 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getSnapshot = exports.loadData = void 0;
4
- var sets_1 = require("../utils/lang/sets");
5
- var key_1 = require("../utils/key");
3
+ exports.dataLoaderFactory = void 0;
4
+ var browser_1 = require("../utils/constants/browser");
6
5
  /**
7
- * Storage-agnostic adaptation of `loadDataIntoLocalStorage` function
8
- * (https://github.com/godaddy/split-javascript-data-loader/blob/master/src/load-data.js)
6
+ * Factory of client-side storage loader
9
7
  *
10
- * @param preloadedData validated data following the format proposed in https://github.com/godaddy/split-javascript-data-loader and extended with a `mySegmentsData` property.
11
- * @param storage object containing `splits` and `segments` cache (client-side variant)
12
- * @param userKey user key (matching key) of the provided MySegmentsCache
13
- *
14
- * @TODO extend to load largeSegments
15
- * @TODO extend to load data on shared mySegments storages. Be specific when emitting SDK_READY_FROM_CACHE on shared clients. Maybe the serializer should provide the `useSegments` flag.
16
- * @TODO add logs, and input validation in this module, in favor of size reduction.
17
- * @TODO unit tests
8
+ * @param preloadedData validated data following the format proposed in https://github.com/godaddy/split-javascript-data-loader
9
+ * and extended with a `mySegmentsData` property.
10
+ * @returns function to preload the storage
18
11
  */
19
- function loadData(preloadedData, storage, matchingKey) {
20
- // Do not load data if current preloadedData is empty
21
- if (Object.keys(preloadedData).length === 0)
22
- return;
23
- var _a = preloadedData.segmentsData, segmentsData = _a === void 0 ? {} : _a, _b = preloadedData.since, since = _b === void 0 ? -1 : _b, _c = preloadedData.splitsData, splitsData = _c === void 0 ? [] : _c;
24
- if (storage.splits) {
12
+ function dataLoaderFactory(preloadedData) {
13
+ /**
14
+ * Storage-agnostic adaptation of `loadDataIntoLocalStorage` function
15
+ * (https://github.com/godaddy/split-javascript-data-loader/blob/master/src/load-data.js)
16
+ *
17
+ * @param storage object containing `splits` and `segments` cache (client-side variant)
18
+ * @param userId user key string of the provided MySegmentsCache
19
+ *
20
+ * @TODO extend to support SegmentsCache (server-side variant) by making `userId` optional and adding the corresponding logic.
21
+ * @TODO extend to load data on shared mySegments storages. Be specific when emitting SDK_READY_FROM_CACHE on shared clients. Maybe the serializer should provide the `useSegments` flag.
22
+ */
23
+ return function loadData(storage, userId) {
24
+ // Do not load data if current preloadedData is empty
25
+ if (Object.keys(preloadedData).length === 0)
26
+ return;
27
+ var _a = preloadedData.lastUpdated, lastUpdated = _a === void 0 ? -1 : _a, _b = preloadedData.segmentsData, segmentsData = _b === void 0 ? {} : _b, _c = preloadedData.since, since = _c === void 0 ? -1 : _c, _d = preloadedData.splitsData, splitsData = _d === void 0 ? {} : _d;
25
28
  var storedSince = storage.splits.getChangeNumber();
26
- // Do not load data if current data is more recent
27
- if (storedSince > since)
29
+ var expirationTimestamp = Date.now() - browser_1.DEFAULT_CACHE_EXPIRATION_IN_MILLIS;
30
+ // Do not load data if current localStorage data is more recent,
31
+ // or if its `lastUpdated` timestamp is older than the given `expirationTimestamp`,
32
+ if (storedSince > since || lastUpdated < expirationTimestamp)
28
33
  return;
29
34
  // cleaning up the localStorage data, since some cached splits might need be part of the preloaded data
30
35
  storage.splits.clear();
31
36
  storage.splits.setChangeNumber(since);
32
37
  // splitsData in an object where the property is the split name and the pertaining value is a stringified json of its data
33
- storage.splits.addSplits(splitsData.map(function (split) { return ([split.name, split]); }));
34
- }
35
- if (matchingKey) { // add mySegments data (client-side)
36
- var mySegmentsData = preloadedData.mySegmentsData && preloadedData.mySegmentsData[matchingKey];
38
+ storage.splits.addSplits(Object.keys(splitsData).map(function (splitName) { return JSON.parse(splitsData[splitName]); }));
39
+ // add mySegments data
40
+ var mySegmentsData = preloadedData.mySegmentsData && preloadedData.mySegmentsData[userId];
37
41
  if (!mySegmentsData) {
38
42
  // segmentsData in an object where the property is the segment name and the pertaining value is a stringified object that contains the `added` array of userIds
39
43
  mySegmentsData = Object.keys(segmentsData).filter(function (segmentName) {
40
- var matchingKeys = segmentsData[segmentName];
41
- return matchingKeys.indexOf(matchingKey) > -1;
44
+ var userIds = JSON.parse(segmentsData[segmentName]).added;
45
+ return Array.isArray(userIds) && userIds.indexOf(userId) > -1;
42
46
  });
43
47
  }
44
48
  storage.segments.resetSegments({ k: mySegmentsData.map(function (s) { return ({ n: s }); }) });
45
- }
46
- else { // add segments data (server-side)
47
- Object.keys(segmentsData).filter(function (segmentName) {
48
- var matchingKeys = segmentsData[segmentName];
49
- storage.segments.addToSegment(segmentName, matchingKeys);
50
- });
51
- }
52
- }
53
- exports.loadData = loadData;
54
- function getSnapshot(storage, userKeys) {
55
- return {
56
- // lastUpdated: Date.now(),
57
- since: storage.splits.getChangeNumber(),
58
- splitsData: storage.splits.getAll(),
59
- segmentsData: userKeys ?
60
- undefined : // @ts-ignore accessing private prop
61
- Object.keys(storage.segments.segmentCache).reduce(function (prev, cur) {
62
- prev[cur] = (0, sets_1.setToArray)(storage.segments.segmentCache[cur]);
63
- return prev;
64
- }, {}),
65
- mySegmentsData: userKeys ?
66
- userKeys.reduce(function (prev, userKey) {
67
- prev[(0, key_1.getMatching)(userKey)] = storage.shared ?
68
- // Client-side segments
69
- // @ts-ignore accessing private prop
70
- Object.keys(storage.shared(userKey).segments.segmentCache) :
71
- // Server-side segments
72
- // @ts-ignore accessing private prop
73
- Object.keys(storage.segments.segmentCache).reduce(function (prev, segmentName) {
74
- return storage.segments.segmentCache[segmentName].has(userKey) ?
75
- prev.concat(segmentName) :
76
- prev;
77
- }, []);
78
- return prev;
79
- }, {}) :
80
- undefined
81
49
  };
82
50
  }
83
- exports.getSnapshot = getSnapshot;
51
+ exports.dataLoaderFactory = dataLoaderFactory;
@@ -48,28 +48,8 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
48
48
  // Scan current values from localStorage
49
49
  return Object.keys(localStorage).reduce(function (accum, key) {
50
50
  var segmentName = _this.keys.extractSegmentName(key);
51
- if (segmentName) {
51
+ if (segmentName)
52
52
  accum.push(segmentName);
53
- }
54
- else {
55
- // @TODO @BREAKING: This is only to clean up "old" keys. Remove this whole else code block
56
- segmentName = _this.keys.extractOldSegmentKey(key);
57
- if (segmentName) { // this was an old segment key, let's clean up.
58
- var newSegmentKey = _this.keys.buildSegmentNameKey(segmentName);
59
- try {
60
- // If the new format key is not there, create it.
61
- if (!localStorage.getItem(newSegmentKey)) {
62
- localStorage.setItem(newSegmentKey, constants_1.DEFINED);
63
- // we are migrating a segment, let's track it.
64
- accum.push(segmentName);
65
- }
66
- localStorage.removeItem(key); // we migrated the current key, let's delete it.
67
- }
68
- catch (e) {
69
- _this.log.error(e);
70
- }
71
- }
72
- }
73
53
  return accum;
74
54
  }, []);
75
55
  };
@@ -5,7 +5,6 @@ var tslib_1 = require("tslib");
5
5
  var AbstractSplitsCacheSync_1 = require("../AbstractSplitsCacheSync");
6
6
  var lang_1 = require("../../utils/lang");
7
7
  var constants_1 = require("./constants");
8
- var sets_1 = require("../../utils/lang/sets");
9
8
  var KeyBuilder_1 = require("../KeyBuilder");
10
9
  /**
11
10
  * ISplitsCacheSync implementation that stores split definitions in browser LocalStorage.
@@ -186,6 +185,14 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
186
185
  return true;
187
186
  }
188
187
  };
188
+ /**
189
+ * Check if the splits information is already stored in browser LocalStorage.
190
+ * In this function we could add more code to check if the data is valid.
191
+ * @override
192
+ */
193
+ SplitsCacheInLocal.prototype.checkCache = function () {
194
+ return this.getChangeNumber() > -1;
195
+ };
189
196
  /**
190
197
  * Clean Splits cache if its `lastUpdated` timestamp is older than the given `expirationTimestamp`,
191
198
  *
@@ -208,7 +215,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
208
215
  // mark cache to update the new query filter on first successful splits fetch
209
216
  this.updateNewFilter = true;
210
217
  // if there is cache, clear it
211
- if (this.getChangeNumber() > -1)
218
+ if (this.checkCache())
212
219
  this.clear();
213
220
  }
214
221
  catch (e) {
@@ -222,7 +229,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
222
229
  return flagSets.map(function (flagSet) {
223
230
  var flagSetKey = _this.keys.buildFlagSetKey(flagSet);
224
231
  var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
225
- return new sets_1._Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
232
+ return new Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
226
233
  });
227
234
  };
228
235
  SplitsCacheInLocal.prototype.addToFlagSets = function (featureFlag) {
@@ -234,9 +241,9 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
234
241
  return;
235
242
  var flagSetKey = _this.keys.buildFlagSetKey(featureFlagSet);
236
243
  var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
237
- var flagSetCache = new sets_1._Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
244
+ var flagSetCache = new Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
238
245
  flagSetCache.add(featureFlag.name);
239
- localStorage.setItem(flagSetKey, JSON.stringify((0, sets_1.setToArray)(flagSetCache)));
246
+ localStorage.setItem(flagSetKey, JSON.stringify(Array.from(flagSetCache)));
240
247
  });
241
248
  };
242
249
  SplitsCacheInLocal.prototype.removeFromFlagSets = function (featureFlagName, flagSets) {
@@ -252,13 +259,13 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
252
259
  var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
253
260
  if (!flagSetFromLocalStorage)
254
261
  return;
255
- var flagSetCache = new sets_1._Set(JSON.parse(flagSetFromLocalStorage));
262
+ var flagSetCache = new Set(JSON.parse(flagSetFromLocalStorage));
256
263
  flagSetCache.delete(featureFlagName);
257
264
  if (flagSetCache.size === 0) {
258
265
  localStorage.removeItem(flagSetKey);
259
266
  return;
260
267
  }
261
- localStorage.setItem(flagSetKey, JSON.stringify((0, sets_1.setToArray)(flagSetCache)));
268
+ localStorage.setItem(flagSetKey, JSON.stringify(Array.from(flagSetCache)));
262
269
  };
263
270
  return SplitsCacheInLocal;
264
271
  }(AbstractSplitsCacheSync_1.AbstractSplitsCacheSync));