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

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 (178) hide show
  1. package/cjs/consent/sdkUserConsent.js +2 -2
  2. package/cjs/evaluator/index.js +10 -11
  3. package/cjs/integrations/ga/GaToSplit.js +8 -5
  4. package/cjs/listeners/browser.js +1 -2
  5. package/cjs/logger/constants.js +1 -2
  6. package/cjs/sdkFactory/index.js +7 -25
  7. package/cjs/sdkManager/index.js +3 -11
  8. package/cjs/services/splitApi.js +0 -20
  9. package/cjs/storages/AbstractSplitsCacheAsync.js +7 -9
  10. package/cjs/storages/AbstractSplitsCacheSync.js +7 -9
  11. package/cjs/storages/KeyBuilderSS.js +0 -6
  12. package/cjs/storages/dataLoader.js +1 -1
  13. package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +5 -6
  14. package/cjs/storages/inLocalStorage/index.js +0 -4
  15. package/cjs/storages/inMemory/ImpressionCountsCacheInMemory.js +1 -12
  16. package/cjs/storages/inMemory/InMemoryStorage.js +1 -5
  17. package/cjs/storages/inMemory/InMemoryStorageCS.js +1 -5
  18. package/cjs/storages/inMemory/SplitsCacheInMemory.js +7 -10
  19. package/cjs/storages/inRedis/SplitsCacheInRedis.js +15 -9
  20. package/cjs/storages/inRedis/constants.js +1 -4
  21. package/cjs/storages/inRedis/index.js +1 -15
  22. package/cjs/storages/pluggable/SplitsCachePluggable.js +14 -9
  23. package/cjs/sync/offline/syncTasks/fromObjectSyncTask.js +2 -3
  24. package/cjs/sync/polling/updaters/splitChangesUpdater.js +1 -1
  25. package/cjs/sync/submitters/submitterManager.js +0 -3
  26. package/cjs/sync/submitters/telemetrySubmitter.js +0 -1
  27. package/cjs/trackers/impressionsTracker.js +41 -22
  28. package/cjs/trackers/telemetryTracker.js +6 -0
  29. package/cjs/utils/constants/index.js +2 -4
  30. package/cjs/utils/settingsValidation/impressionsMode.js +2 -2
  31. package/cjs/utils/settingsValidation/index.js +0 -3
  32. package/esm/consent/sdkUserConsent.js +2 -2
  33. package/esm/evaluator/index.js +10 -11
  34. package/esm/integrations/ga/GaToSplit.js +8 -5
  35. package/esm/listeners/browser.js +2 -3
  36. package/esm/logger/constants.js +0 -1
  37. package/esm/sdkFactory/index.js +7 -25
  38. package/esm/sdkManager/index.js +3 -11
  39. package/esm/services/splitApi.js +0 -20
  40. package/esm/storages/AbstractSplitsCacheAsync.js +7 -9
  41. package/esm/storages/AbstractSplitsCacheSync.js +7 -9
  42. package/esm/storages/KeyBuilderSS.js +0 -6
  43. package/esm/storages/dataLoader.js +1 -1
  44. package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +5 -6
  45. package/esm/storages/inLocalStorage/index.js +1 -5
  46. package/esm/storages/inMemory/ImpressionCountsCacheInMemory.js +1 -12
  47. package/esm/storages/inMemory/InMemoryStorage.js +2 -6
  48. package/esm/storages/inMemory/InMemoryStorageCS.js +2 -6
  49. package/esm/storages/inMemory/SplitsCacheInMemory.js +7 -10
  50. package/esm/storages/inRedis/SplitsCacheInRedis.js +15 -9
  51. package/esm/storages/inRedis/constants.js +0 -3
  52. package/esm/storages/inRedis/index.js +2 -16
  53. package/esm/storages/pluggable/SplitsCachePluggable.js +14 -9
  54. package/esm/sync/offline/syncTasks/fromObjectSyncTask.js +2 -3
  55. package/esm/sync/polling/updaters/splitChangesUpdater.js +1 -1
  56. package/esm/sync/submitters/submitterManager.js +0 -3
  57. package/esm/sync/submitters/telemetrySubmitter.js +1 -2
  58. package/esm/trackers/impressionsTracker.js +41 -22
  59. package/esm/trackers/telemetryTracker.js +6 -0
  60. package/esm/utils/constants/index.js +0 -2
  61. package/esm/utils/settingsValidation/impressionsMode.js +3 -3
  62. package/esm/utils/settingsValidation/index.js +0 -3
  63. package/package.json +1 -1
  64. package/src/consent/sdkUserConsent.ts +2 -2
  65. package/src/evaluator/index.ts +8 -9
  66. package/src/integrations/ga/GaToSplit.ts +9 -5
  67. package/src/integrations/types.ts +2 -1
  68. package/src/listeners/browser.ts +2 -3
  69. package/src/logger/.DS_Store +0 -0
  70. package/src/logger/constants.ts +0 -1
  71. package/src/sdkFactory/index.ts +7 -28
  72. package/src/sdkFactory/types.ts +4 -7
  73. package/src/sdkManager/index.ts +3 -12
  74. package/src/services/splitApi.ts +0 -22
  75. package/src/services/types.ts +0 -6
  76. package/src/storages/AbstractSplitsCacheAsync.ts +13 -14
  77. package/src/storages/AbstractSplitsCacheSync.ts +14 -16
  78. package/src/storages/KeyBuilderSS.ts +0 -8
  79. package/src/storages/dataLoader.ts +1 -1
  80. package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +8 -10
  81. package/src/storages/inLocalStorage/index.ts +1 -4
  82. package/src/storages/inMemory/ImpressionCountsCacheInMemory.ts +1 -16
  83. package/src/storages/inMemory/InMemoryStorage.ts +2 -5
  84. package/src/storages/inMemory/InMemoryStorageCS.ts +2 -6
  85. package/src/storages/inMemory/SplitsCacheInMemory.ts +10 -14
  86. package/src/storages/inRedis/SplitsCacheInRedis.ts +21 -17
  87. package/src/storages/inRedis/constants.ts +0 -3
  88. package/src/storages/inRedis/index.ts +3 -12
  89. package/src/storages/pluggable/SplitsCachePluggable.ts +20 -17
  90. package/src/storages/types.ts +21 -40
  91. package/src/sync/offline/syncTasks/fromObjectSyncTask.ts +5 -6
  92. package/src/sync/polling/updaters/splitChangesUpdater.ts +2 -2
  93. package/src/sync/submitters/submitterManager.ts +0 -2
  94. package/src/sync/submitters/telemetrySubmitter.ts +3 -4
  95. package/src/sync/submitters/types.ts +1 -20
  96. package/src/trackers/impressionsTracker.ts +48 -27
  97. package/src/trackers/telemetryTracker.ts +7 -2
  98. package/src/trackers/types.ts +4 -26
  99. package/src/types.ts +1 -3
  100. package/src/utils/constants/index.ts +0 -2
  101. package/src/utils/settingsValidation/impressionsMode.ts +3 -3
  102. package/src/utils/settingsValidation/index.ts +0 -4
  103. package/types/integrations/types.d.ts +2 -1
  104. package/types/logger/constants.d.ts +0 -1
  105. package/types/sdkFactory/types.d.ts +2 -4
  106. package/types/services/types.d.ts +0 -4
  107. package/types/storages/AbstractSplitsCacheAsync.d.ts +6 -5
  108. package/types/storages/AbstractSplitsCacheSync.d.ts +5 -5
  109. package/types/storages/KeyBuilderSS.d.ts +0 -2
  110. package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +3 -3
  111. package/types/storages/inMemory/ImpressionCountsCacheInMemory.d.ts +1 -5
  112. package/types/storages/inMemory/SplitsCacheInMemory.d.ts +3 -2
  113. package/types/storages/inRedis/SplitsCacheInRedis.d.ts +6 -5
  114. package/types/storages/inRedis/constants.d.ts +0 -3
  115. package/types/storages/pluggable/SplitsCachePluggable.d.ts +6 -5
  116. package/types/storages/types.d.ts +18 -28
  117. package/types/sync/polling/updaters/splitChangesUpdater.d.ts +1 -1
  118. package/types/sync/submitters/types.d.ts +1 -18
  119. package/types/trackers/impressionsTracker.d.ts +6 -4
  120. package/types/trackers/types.d.ts +4 -21
  121. package/types/types.d.ts +1 -3
  122. package/types/utils/constants/index.d.ts +0 -2
  123. package/types/utils/settingsValidation/index.d.ts +0 -1
  124. package/cjs/storages/inMemory/uniqueKeysCacheInMemory.js +0 -73
  125. package/cjs/storages/inMemory/uniqueKeysCacheInMemoryCS.js +0 -78
  126. package/cjs/storages/inRedis/ImpressionCountsCacheInRedis.js +0 -46
  127. package/cjs/storages/inRedis/uniqueKeysCacheInRedis.js +0 -55
  128. package/cjs/sync/submitters/uniqueKeysSubmitter.js +0 -26
  129. package/cjs/trackers/strategy/strategyDebug.js +0 -25
  130. package/cjs/trackers/strategy/strategyNone.js +0 -29
  131. package/cjs/trackers/strategy/strategyOptimized.js +0 -34
  132. package/cjs/trackers/uniqueKeysTracker.js +0 -31
  133. package/esm/storages/inMemory/uniqueKeysCacheInMemory.js +0 -70
  134. package/esm/storages/inMemory/uniqueKeysCacheInMemoryCS.js +0 -75
  135. package/esm/storages/inRedis/ImpressionCountsCacheInRedis.js +0 -43
  136. package/esm/storages/inRedis/uniqueKeysCacheInRedis.js +0 -52
  137. package/esm/sync/submitters/uniqueKeysSubmitter.js +0 -22
  138. package/esm/trackers/strategy/strategyDebug.js +0 -21
  139. package/esm/trackers/strategy/strategyNone.js +0 -25
  140. package/esm/trackers/strategy/strategyOptimized.js +0 -30
  141. package/esm/trackers/uniqueKeysTracker.js +0 -27
  142. package/src/storages/inMemory/uniqueKeysCacheInMemory.ts +0 -82
  143. package/src/storages/inMemory/uniqueKeysCacheInMemoryCS.ts +0 -88
  144. package/src/storages/inRedis/ImpressionCountsCacheInRedis.ts +0 -48
  145. package/src/storages/inRedis/uniqueKeysCacheInRedis.ts +0 -61
  146. package/src/sync/submitters/uniqueKeysSubmitter.ts +0 -35
  147. package/src/trackers/strategy/strategyDebug.ts +0 -28
  148. package/src/trackers/strategy/strategyNone.ts +0 -34
  149. package/src/trackers/strategy/strategyOptimized.ts +0 -42
  150. package/src/trackers/uniqueKeysTracker.ts +0 -37
  151. package/types/sdkClient/types.d.ts +0 -18
  152. package/types/storages/inMemory/CountsCacheInMemory.d.ts +0 -20
  153. package/types/storages/inMemory/LatenciesCacheInMemory.d.ts +0 -20
  154. package/types/storages/inMemory/uniqueKeysCacheInMemory.d.ts +0 -35
  155. package/types/storages/inMemory/uniqueKeysCacheInMemoryCS.d.ts +0 -37
  156. package/types/storages/inRedis/CountsCacheInRedis.d.ts +0 -9
  157. package/types/storages/inRedis/ImpressionCountsCacheInRedis.d.ts +0 -13
  158. package/types/storages/inRedis/LatenciesCacheInRedis.d.ts +0 -9
  159. package/types/storages/inRedis/uniqueKeysCacheInRedis.d.ts +0 -14
  160. package/types/sync/offline/LocalhostFromFile.d.ts +0 -2
  161. package/types/sync/offline/splitsParser/splitsParserFromFile.d.ts +0 -2
  162. package/types/sync/submitters/eventsSyncTask.d.ts +0 -8
  163. package/types/sync/submitters/impressionCountsSubmitterInRedis.d.ts +0 -5
  164. package/types/sync/submitters/impressionCountsSyncTask.d.ts +0 -13
  165. package/types/sync/submitters/impressionsSyncTask.d.ts +0 -14
  166. package/types/sync/submitters/metricsSyncTask.d.ts +0 -12
  167. package/types/sync/submitters/submitterSyncTask.d.ts +0 -10
  168. package/types/sync/submitters/uniqueKeysSubmitter.d.ts +0 -5
  169. package/types/sync/submitters/uniqueKeysSubmitterInRedis.d.ts +0 -5
  170. package/types/sync/syncTaskComposite.d.ts +0 -5
  171. package/types/trackers/filter/bloomFilter.d.ts +0 -10
  172. package/types/trackers/filter/dictionaryFilter.d.ts +0 -8
  173. package/types/trackers/filter/types.d.ts +0 -5
  174. package/types/trackers/strategy/strategyDebug.d.ts +0 -9
  175. package/types/trackers/strategy/strategyNone.d.ts +0 -10
  176. package/types/trackers/strategy/strategyOptimized.d.ts +0 -11
  177. package/types/trackers/uniqueKeysTracker.d.ts +0 -13
  178. package/types/utils/timeTracker/index.d.ts +0 -70
@@ -39,8 +39,8 @@ function createUserConsentAPI(params) {
39
39
  if (events.clear)
40
40
  events.clear(); // @ts-ignore
41
41
  if (impressions.clear)
42
- impressions.clear(); // @ts-ignore
43
- if (impressionCounts && impressionCounts.clear)
42
+ impressions.clear();
43
+ if (impressionCounts)
44
44
  impressionCounts.clear();
45
45
  }
46
46
  }
@@ -37,45 +37,44 @@ function evaluateFeature(log, key, splitName, attributes, storage) {
37
37
  }
38
38
  exports.evaluateFeature = evaluateFeature;
39
39
  function evaluateFeatures(log, key, splitNames, attributes, storage) {
40
- var stringifiedSplits;
40
+ var parsedSplits;
41
41
  try {
42
- stringifiedSplits = storage.splits.getSplits(splitNames);
42
+ parsedSplits = storage.splits.getSplits(splitNames);
43
43
  }
44
44
  catch (e) {
45
45
  // Exception on sync `getSplits` storage. Not possible ATM with InMemory and InLocal storages.
46
46
  return treatmentsException(splitNames);
47
47
  }
48
- return ((0, thenable_1.thenable)(stringifiedSplits)) ?
49
- stringifiedSplits.then(function (splits) { return getEvaluations(log, splitNames, splits, key, attributes, storage); })
48
+ return (0, thenable_1.thenable)(parsedSplits) ?
49
+ parsedSplits.then(function (splits) { return getEvaluations(log, splitNames, splits, key, attributes, storage); })
50
50
  .catch(function () {
51
51
  // Exception on async `getSplits` storage. For example, when the storage is redis or
52
52
  // pluggable and there is a connection issue and we can't retrieve the split to be evaluated
53
53
  return treatmentsException(splitNames);
54
54
  }) :
55
- getEvaluations(log, splitNames, stringifiedSplits, key, attributes, storage);
55
+ getEvaluations(log, splitNames, parsedSplits, key, attributes, storage);
56
56
  }
57
57
  exports.evaluateFeatures = evaluateFeatures;
58
- function getEvaluation(log, stringifiedSplit, key, attributes, storage) {
58
+ function getEvaluation(log, splitJSON, key, attributes, storage) {
59
59
  var evaluation = {
60
60
  treatment: constants_1.CONTROL,
61
61
  label: LabelsConstants.SPLIT_NOT_FOUND,
62
62
  config: null
63
63
  };
64
- if (stringifiedSplit) {
65
- var splitJSON_1 = JSON.parse(stringifiedSplit);
66
- var split_1 = Engine_1.Engine.parse(log, splitJSON_1, storage);
64
+ if (splitJSON) {
65
+ var split_1 = Engine_1.Engine.parse(log, splitJSON, storage);
67
66
  evaluation = split_1.getTreatment(key, attributes, evaluateFeature);
68
67
  // If the storage is async and the evaluated split uses segment, evaluation is thenable
69
68
  if ((0, thenable_1.thenable)(evaluation)) {
70
69
  return evaluation.then(function (result) {
71
70
  result.changeNumber = split_1.getChangeNumber();
72
- result.config = splitJSON_1.configurations && splitJSON_1.configurations[result.treatment] || null;
71
+ result.config = splitJSON.configurations && splitJSON.configurations[result.treatment] || null;
73
72
  return result;
74
73
  });
75
74
  }
76
75
  else {
77
76
  evaluation.changeNumber = split_1.getChangeNumber(); // Always sync and optional
78
- evaluation.config = splitJSON_1.configurations && splitJSON_1.configurations[evaluation.treatment] || null;
77
+ evaluation.config = splitJSON.configurations && splitJSON.configurations[evaluation.treatment] || null;
79
78
  }
80
79
  }
81
80
  return evaluation;
@@ -16,7 +16,7 @@ var logNameMapper = 'ga-to-split:mapper';
16
16
  * @param log Logger instance.
17
17
  * @param autoRequire If true, log error when auto-require script is not detected
18
18
  */
19
- function providePlugin(window, pluginName, pluginConstructor, log, autoRequire) {
19
+ function providePlugin(window, pluginName, pluginConstructor, log, autoRequire, telemetryTracker) {
20
20
  // get reference to global command queue. Init it if not defined yet.
21
21
  var gaAlias = window.GoogleAnalyticsObject || 'ga';
22
22
  window[gaAlias] = window[gaAlias] || function () {
@@ -24,10 +24,13 @@ function providePlugin(window, pluginName, pluginConstructor, log, autoRequire)
24
24
  };
25
25
  // provides the plugin for use with analytics.js.
26
26
  window[gaAlias]('provide', pluginName, pluginConstructor);
27
- if (autoRequire && (!window[gaAlias].q || window[gaAlias].q.push === [].push)) {
28
- // Expecting spy on ga.q push method but not found
27
+ var hasAutoRequire = window[gaAlias].q && window[gaAlias].q.push !== [].push;
28
+ if (autoRequire && !hasAutoRequire) { // Expecting spy on ga.q push method but not found
29
29
  log.error(logPrefix + 'integration is configured to autorequire the splitTracker plugin, but the necessary script does not seem to have run. Please check the docs.');
30
30
  }
31
+ if (telemetryTracker && hasAutoRequire) {
32
+ telemetryTracker.addTag('integration:ga-autorequire');
33
+ }
31
34
  }
32
35
  // Default mapping: object used for building the default mapper from hits to Split events
33
36
  var defaultMapping = {
@@ -163,7 +166,7 @@ exports.fixEventTypeId = fixEventTypeId;
163
166
  * @param {object} log factory logger
164
167
  */
165
168
  function GaToSplit(sdkOptions, params) {
166
- var storage = params.storage, _a = params.settings, coreSettings = _a.core, log = _a.log;
169
+ var storage = params.storage, _a = params.settings, coreSettings = _a.core, log = _a.log, telemetryTracker = params.telemetryTracker;
167
170
  var defaultOptions = {
168
171
  prefix: exports.defaultPrefix,
169
172
  // We set default identities if key and TT are present in settings.core
@@ -249,6 +252,6 @@ function GaToSplit(sdkOptions, params) {
249
252
  return SplitTracker;
250
253
  }());
251
254
  // Register the plugin, even if config is invalid, since, if not provided, it will block `ga` command queue.
252
- providePlugin(window, 'splitTracker', SplitTracker, log, sdkOptions.autoRequire === true);
255
+ providePlugin(window, 'splitTracker', SplitTracker, log, sdkOptions.autoRequire === true, telemetryTracker);
253
256
  }
254
257
  exports.GaToSplit = GaToSplit;
@@ -74,10 +74,9 @@ var BrowserSignalListener = /** @class */ (function () {
74
74
  // Flush impressions & events data if there is user consent
75
75
  if ((0, consent_1.isConsentGranted)(this.settings)) {
76
76
  var eventsUrl = this.settings.urls.events;
77
- var sim = this.settings.sync.impressionsMode;
78
77
  var extraMetadata = {
79
78
  // sim stands for Sync/Split Impressions Mode
80
- sim: sim === constants_1.OPTIMIZED ? constants_1.OPTIMIZED : sim === constants_1.DEBUG ? constants_1.DEBUG : constants_1.NONE
79
+ sim: this.settings.sync.impressionsMode === constants_1.OPTIMIZED ? constants_1.OPTIMIZED : constants_1.DEBUG
81
80
  };
82
81
  this._flushData(eventsUrl + '/testImpressions/beacon', this.storage.impressions, this.serviceApi.postTestImpressionsBulk, this.fromImpressionsCollector, extraMetadata);
83
82
  this._flushData(eventsUrl + '/events/beacon', this.storage.events, this.serviceApi.postEventsBulk);
@@ -2,7 +2,7 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SYNC_SPLITS_FETCH_RETRY = exports.POLLING_STOP = exports.POLLING_START = exports.POLLING_SMART_PAUSING = exports.NEW_FACTORY = exports.NEW_SHARED_CLIENT = exports.IMPRESSION_QUEUEING = exports.IMPRESSION = exports.CLIENT_READY = exports.CLIENT_READY_FROM_CACHE = exports.SETTINGS_SPLITS_FILTER = exports.SYNC_TASK_STOP = exports.SYNC_TASK_EXECUTE = exports.SYNC_TASK_START = exports.STREAMING_NEW_MESSAGE = exports.SYNC_SPLITS_SEGMENTS = exports.SYNC_SPLITS_REMOVED = exports.SYNC_SPLITS_NEW = exports.SYNC_SPLITS_FETCH = exports.SYNC_OFFLINE_DATA = exports.RETRIEVE_MANAGER = exports.RETRIEVE_CLIENT_EXISTING = exports.RETRIEVE_CLIENT_DEFAULT = exports.CLEANUP_DEREGISTERING = exports.CLEANUP_REGISTERING = exports.ENGINE_SANITIZE = exports.ENGINE_VALUE = exports.ENGINE_MATCHER_WHITELIST = exports.ENGINE_MATCHER_STARTS_WITH = exports.ENGINE_MATCHER_STRING_INVALID = exports.ENGINE_MATCHER_STRING = exports.ENGINE_MATCHER_SEGMENT = exports.ENGINE_MATCHER_PART_OF = exports.ENGINE_MATCHER_LESS = exports.ENGINE_MATCHER_GREATER = exports.ENGINE_MATCHER_ENDS_WITH = exports.ENGINE_MATCHER_EQUAL_TO_SET = exports.ENGINE_MATCHER_EQUAL = exports.ENGINE_MATCHER_DEPENDENCY_PRE = exports.ENGINE_MATCHER_DEPENDENCY = exports.ENGINE_MATCHER_CONTAINS_STRING = exports.ENGINE_MATCHER_CONTAINS_ANY = exports.ENGINE_MATCHER_CONTAINS_ALL = exports.ENGINE_MATCHER_BOOLEAN = exports.ENGINE_MATCHER_BETWEEN = exports.ENGINE_MATCHER_ALL = exports.ENGINE_BUCKET = exports.ENGINE_COMBINER_IFELSEIF_NO_TREATMENT = exports.ENGINE_COMBINER_IFELSEIF = exports.ENGINE_COMBINER_AND = void 0;
4
4
  exports.ERROR_EVENT_TYPE_FORMAT = exports.ERROR_EVENTS_TRACKER = exports.ERROR_IMPRESSIONS_LISTENER = exports.ERROR_IMPRESSIONS_TRACKER = exports.ERROR_STREAMING_AUTH = exports.ERROR_STREAMING_SSE = exports.ERROR_SYNC_OFFLINE_LOADING = exports.ERROR_CLIENT_CANNOT_GET_READY = exports.ERROR_CLIENT_LISTENER = exports.ERROR_LOGLEVEL_INVALID = exports.ERROR_ENGINE_COMBINER_IFELSEIF = exports.STREAMING_PARSING_MY_SEGMENTS_UPDATE_V2 = exports.WARN_API_KEY = exports.WARN_SPLITS_FILTER_EMPTY = exports.WARN_SPLITS_FILTER_INVALID = exports.WARN_SPLITS_FILTER_IGNORED = exports.WARN_INTEGRATION_INVALID = exports.WARN_NOT_EXISTENT_TT = exports.WARN_LOWERCASE_TRAFFIC_TYPE = exports.WARN_NOT_EXISTENT_SPLIT = exports.WARN_TRIMMING = exports.WARN_CONVERTING = exports.WARN_TRIMMING_PROPERTIES = exports.WARN_SETTING_NULL = exports.SUBMITTERS_PUSH_RETRY = exports.SUBMITTERS_PUSH_FAILS = exports.STREAMING_FALLBACK = exports.STREAMING_PARSING_MESSAGE_FAILS = exports.STREAMING_PARSING_ERROR_FAILS = exports.SYNC_SPLITS_FETCH_FAILS = exports.SYNC_MYSEGMENTS_FETCH_RETRY = exports.CLIENT_NOT_READY = exports.CLIENT_NO_LISTENER = exports.ENGINE_VALUE_NO_ATTRIBUTES = exports.ENGINE_VALUE_INVALID = exports.USER_CONSENT_INITIAL = exports.USER_CONSENT_NOT_UPDATED = exports.USER_CONSENT_UPDATED = exports.IMPRESSIONS_TRACKER_SUCCESS = exports.EVENTS_TRACKER_SUCCESS = exports.SYNC_STOP_POLLING = exports.SYNC_CONTINUE_POLLING = exports.SYNC_START_POLLING = exports.SUBMITTERS_PUSH = exports.SUBMITTERS_PUSH_FULL_QUEUE = exports.STREAMING_DISCONNECTING = exports.STREAMING_DISABLED = exports.STREAMING_CONNECTING = exports.STREAMING_RECONNECT = exports.STREAMING_REFRESH_TOKEN = void 0;
5
- exports.LOG_PREFIX_CLEANUP = exports.LOG_PREFIX_UNIQUE_KEYS_TRACKER = exports.LOG_PREFIX_EVENTS_TRACKER = exports.LOG_PREFIX_IMPRESSIONS_TRACKER = exports.LOG_PREFIX_SYNC_SUBMITTERS = exports.LOG_PREFIX_SYNC_POLLING = exports.LOG_PREFIX_SYNC_MYSEGMENTS = exports.LOG_PREFIX_SYNC_SEGMENTS = exports.LOG_PREFIX_SYNC_SPLITS = exports.LOG_PREFIX_SYNC_STREAMING = exports.LOG_PREFIX_SYNC_OFFLINE = exports.LOG_PREFIX_SYNC_MANAGER = exports.LOG_PREFIX_SYNC = exports.LOG_PREFIX_ENGINE_VALUE = exports.LOG_PREFIX_ENGINE_MATCHER = exports.LOG_PREFIX_ENGINE_COMBINER = exports.LOG_PREFIX_ENGINE = exports.LOG_PREFIX_INSTANTIATION = exports.LOG_PREFIX_SETTINGS = exports.ERROR_MIN_CONFIG_PARAM = exports.ERROR_NOT_BOOLEAN = exports.ERROR_STORAGE_INVALID = exports.ERROR_LOCALHOST_MODULE_REQUIRED = exports.ERROR_HTTP = exports.ERROR_INVALID_CONFIG_PARAM = exports.ERROR_EMPTY_ARRAY = exports.ERROR_EMPTY = exports.ERROR_INVALID = exports.ERROR_INVALID_KEY_OBJECT = exports.ERROR_TOO_LONG = exports.ERROR_NULL = exports.ERROR_CLIENT_DESTROYED = exports.ERROR_NOT_FINITE = exports.ERROR_SIZE_EXCEEDED = exports.ERROR_NOT_PLAIN_OBJECT = void 0;
5
+ exports.LOG_PREFIX_CLEANUP = exports.LOG_PREFIX_EVENTS_TRACKER = exports.LOG_PREFIX_IMPRESSIONS_TRACKER = exports.LOG_PREFIX_SYNC_SUBMITTERS = exports.LOG_PREFIX_SYNC_POLLING = exports.LOG_PREFIX_SYNC_MYSEGMENTS = exports.LOG_PREFIX_SYNC_SEGMENTS = exports.LOG_PREFIX_SYNC_SPLITS = exports.LOG_PREFIX_SYNC_STREAMING = exports.LOG_PREFIX_SYNC_OFFLINE = exports.LOG_PREFIX_SYNC_MANAGER = exports.LOG_PREFIX_SYNC = exports.LOG_PREFIX_ENGINE_VALUE = exports.LOG_PREFIX_ENGINE_MATCHER = exports.LOG_PREFIX_ENGINE_COMBINER = exports.LOG_PREFIX_ENGINE = exports.LOG_PREFIX_INSTANTIATION = exports.LOG_PREFIX_SETTINGS = exports.ERROR_MIN_CONFIG_PARAM = exports.ERROR_NOT_BOOLEAN = exports.ERROR_STORAGE_INVALID = exports.ERROR_LOCALHOST_MODULE_REQUIRED = exports.ERROR_HTTP = exports.ERROR_INVALID_CONFIG_PARAM = exports.ERROR_EMPTY_ARRAY = exports.ERROR_EMPTY = exports.ERROR_INVALID = exports.ERROR_INVALID_KEY_OBJECT = exports.ERROR_TOO_LONG = exports.ERROR_NULL = exports.ERROR_CLIENT_DESTROYED = exports.ERROR_NOT_FINITE = exports.ERROR_SIZE_EXCEEDED = exports.ERROR_NOT_PLAIN_OBJECT = void 0;
6
6
  /**
7
7
  * Message codes used to trim string log messages from commons and client-side API modules,
8
8
  * in order to reduce the minimal SDK size for Browser and eventually other client-side environments.
@@ -144,5 +144,4 @@ exports.LOG_PREFIX_SYNC_POLLING = exports.LOG_PREFIX_SYNC + ':polling-manager: '
144
144
  exports.LOG_PREFIX_SYNC_SUBMITTERS = exports.LOG_PREFIX_SYNC + ':submitter: ';
145
145
  exports.LOG_PREFIX_IMPRESSIONS_TRACKER = 'impressions-tracker: ';
146
146
  exports.LOG_PREFIX_EVENTS_TRACKER = 'events-tracker: ';
147
- exports.LOG_PREFIX_UNIQUE_KEYS_TRACKER = 'unique-keys-tracker: ';
148
147
  exports.LOG_PREFIX_CLEANUP = 'cleanup: ';
@@ -13,16 +13,11 @@ var constants_1 = require("../logger/constants");
13
13
  var metadataBuilder_1 = require("../storages/metadataBuilder");
14
14
  var constants_2 = require("../readiness/constants");
15
15
  var objectAssign_1 = require("../utils/lang/objectAssign");
16
- var strategyDebug_1 = require("../trackers/strategy/strategyDebug");
17
- var strategyOptimized_1 = require("../trackers/strategy/strategyOptimized");
18
- var strategyNone_1 = require("../trackers/strategy/strategyNone");
19
- var uniqueKeysTracker_1 = require("../trackers/uniqueKeysTracker");
20
- var constants_3 = require("../utils/constants");
21
16
  /**
22
17
  * Modular SDK factory
23
18
  */
24
19
  function sdkFactory(params) {
25
- var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory, filterAdapterFactory = params.filterAdapterFactory;
20
+ var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory;
26
21
  var log = settings.log;
27
22
  // @TODO handle non-recoverable errors, such as, global `fetch` not available, invalid API Key, etc.
28
23
  // On non-recoverable errors, we should mark the SDK as destroyed and not start synchronization.
@@ -34,14 +29,12 @@ function sdkFactory(params) {
34
29
  var storageFactoryParams = {
35
30
  impressionsQueueSize: settings.scheduler.impressionsQueueSize,
36
31
  eventsQueueSize: settings.scheduler.eventsQueueSize,
37
- uniqueKeysCacheSize: settings.scheduler.uniqueKeysCacheSize,
38
32
  optimize: (0, utils_1.shouldBeOptimized)(settings),
39
33
  // ATM, only used by InLocalStorage
40
34
  matchingKey: (0, key_1.getMatching)(settings.core.key),
41
35
  splitFiltersValidation: settings.sync.__splitFiltersValidation,
42
36
  // ATM, only used by PluggableStorage
43
37
  mode: settings.mode,
44
- impressionsMode: settings.sync.impressionsMode,
45
38
  // Callback used to emit SDK_READY in consumer mode, where `syncManagerFactory` is undefined,
46
39
  // or partial consumer mode, where it only has submitters, and therefore it doesn't emit readiness events.
47
40
  onReadyCb: function (error) {
@@ -55,26 +48,15 @@ function sdkFactory(params) {
55
48
  };
56
49
  var storage = storageFactory(storageFactoryParams);
57
50
  // @TODO add support for dataloader: `if (params.dataLoader) params.dataLoader(storage);`
58
- var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage });
59
- var observer = impressionsObserverFactory();
60
- var uniqueKeysTracker = storageFactoryParams.impressionsMode === constants_3.NONE ? (0, uniqueKeysTracker_1.uniqueKeysTrackerFactory)(log, storage.uniqueKeys, filterAdapterFactory && filterAdapterFactory()) : undefined;
61
- var strategy;
62
- switch (storageFactoryParams.impressionsMode) {
63
- case constants_3.OPTIMIZED:
64
- strategy = (0, strategyOptimized_1.strategyOptimizedFactory)(observer, storage.impressionCounts);
65
- break;
66
- case constants_3.NONE:
67
- strategy = (0, strategyNone_1.strategyNoneFactory)(storage.impressionCounts, uniqueKeysTracker);
68
- break;
69
- default:
70
- strategy = (0, strategyDebug_1.strategyDebugFactory)(observer);
71
- }
72
- var impressionsTracker = (0, impressionsTracker_1.impressionsTrackerFactory)(settings, storage.impressions, strategy, integrationsManager, storage.telemetry);
73
- var eventTracker = (0, eventTracker_1.eventTrackerFactory)(settings, storage.events, integrationsManager, storage.telemetry);
74
51
  var telemetryTracker = (0, telemetryTracker_1.telemetryTrackerFactory)(storage.telemetry, platform.now);
52
+ var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage, telemetryTracker: telemetryTracker });
53
+ // trackers
54
+ var observer = impressionsObserverFactory && impressionsObserverFactory();
55
+ var impressionsTracker = (0, impressionsTracker_1.impressionsTrackerFactory)(settings, storage.impressions, integrationsManager, observer, storage.impressionCounts, storage.telemetry);
56
+ var eventTracker = (0, eventTracker_1.eventTrackerFactory)(settings, storage.events, integrationsManager, storage.telemetry);
75
57
  // splitApi is used by SyncManager and Browser signal listener
76
58
  var splitApi = splitApiFactory && splitApiFactory(settings, platform, telemetryTracker);
77
- var ctx = { splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, uniqueKeysTracker: uniqueKeysTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
59
+ var ctx = { splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
78
60
  var syncManager = syncManagerFactory && syncManagerFactory(ctx);
79
61
  ctx.syncManager = syncManager;
80
62
  var signalListener = SignalListener && new SignalListener(syncManager, settings, storage, splitApi);
@@ -15,15 +15,7 @@ function collectTreatments(splitObject) {
15
15
  // Then extract the treatments from the partitions
16
16
  return allTreatmentsCondition ? allTreatmentsCondition.partitions.map(function (v) { return v.treatment; }) : [];
17
17
  }
18
- function objectToView(json) {
19
- var splitObject;
20
- try {
21
- // @ts-expect-error
22
- splitObject = JSON.parse(json);
23
- }
24
- catch (e) {
25
- return null;
26
- }
18
+ function objectToView(splitObject) {
27
19
  if (!splitObject)
28
20
  return null;
29
21
  return {
@@ -35,9 +27,9 @@ function objectToView(json) {
35
27
  configs: splitObject.configurations || {}
36
28
  };
37
29
  }
38
- function objectsToViews(jsons) {
30
+ function objectsToViews(splitObjects) {
39
31
  var views = [];
40
- jsons.forEach(function (split) {
32
+ splitObjects.forEach(function (split) {
41
33
  var view = objectToView(split);
42
34
  if (view)
43
35
  views.push(view);
@@ -90,26 +90,6 @@ function splitApiFactory(settings, platform, telemetryTracker) {
90
90
  var url = urls.events + "/testImpressions/count";
91
91
  return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(constants_1.IMPRESSIONS_COUNT));
92
92
  },
93
- /**
94
- * Post unique keys for client side.
95
- *
96
- * @param body unique keys payload
97
- * @param headers Optionals headers to overwrite default ones. For example, it is used in producer mode to overwrite metadata headers.
98
- */
99
- postUniqueKeysBulkCs: function (body, headers) {
100
- var url = urls.telemetry + "/v1/keys/cs";
101
- return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(constants_1.TELEMETRY));
102
- },
103
- /**
104
- * Post unique keys for server side.
105
- *
106
- * @param body unique keys payload
107
- * @param headers Optionals headers to overwrite default ones. For example, it is used in producer mode to overwrite metadata headers.
108
- */
109
- postUniqueKeysBulkSs: function (body, headers) {
110
- var url = urls.telemetry + "/v1/keys/ss";
111
- return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(constants_1.TELEMETRY));
112
- },
113
93
  postMetricsConfig: function (body) {
114
94
  var url = urls.telemetry + "/v1/metrics/config";
115
95
  return splitHttpClient(url, { method: 'POST', body: body }, telemetryTracker.trackHttp(constants_1.TELEMETRY), true);
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AbstractSplitsCacheAsync = void 0;
4
+ var objectAssign_1 = require("../utils/lang/objectAssign");
4
5
  /**
5
6
  * This class provides a skeletal implementation of the ISplitsCacheAsync interface
6
7
  * to minimize the effort required to implement this interface.
@@ -34,15 +35,12 @@ var AbstractSplitsCacheAsync = /** @class */ (function () {
34
35
  AbstractSplitsCacheAsync.prototype.killLocally = function (name, defaultTreatment, changeNumber) {
35
36
  var _this = this;
36
37
  return this.getSplit(name).then(function (split) {
37
- if (split) {
38
- var parsedSplit = JSON.parse(split);
39
- if (!parsedSplit.changeNumber || parsedSplit.changeNumber < changeNumber) {
40
- parsedSplit.killed = true;
41
- parsedSplit.defaultTreatment = defaultTreatment;
42
- parsedSplit.changeNumber = changeNumber;
43
- var newSplit = JSON.stringify(parsedSplit);
44
- return _this.addSplit(name, newSplit);
45
- }
38
+ if (split && (!split.changeNumber || split.changeNumber < changeNumber)) {
39
+ var newSplit = (0, objectAssign_1.objectAssign)({}, split);
40
+ newSplit.killed = true;
41
+ newSplit.defaultTreatment = defaultTreatment;
42
+ newSplit.changeNumber = changeNumber;
43
+ return _this.addSplit(name, newSplit);
46
44
  }
47
45
  return false;
48
46
  }).catch(function () { return false; });
@@ -1,6 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.usesSegments = exports.AbstractSplitsCacheSync = void 0;
4
+ var objectAssign_1 = require("../utils/lang/objectAssign");
4
5
  /**
5
6
  * This class provides a skeletal implementation of the ISplitsCacheSync interface
6
7
  * to minimize the effort required to implement this interface.
@@ -47,15 +48,12 @@ var AbstractSplitsCacheSync = /** @class */ (function () {
47
48
  */
48
49
  AbstractSplitsCacheSync.prototype.killLocally = function (name, defaultTreatment, changeNumber) {
49
50
  var split = this.getSplit(name);
50
- if (split) {
51
- var parsedSplit = JSON.parse(split);
52
- if (!parsedSplit.changeNumber || parsedSplit.changeNumber < changeNumber) {
53
- parsedSplit.killed = true;
54
- parsedSplit.defaultTreatment = defaultTreatment;
55
- parsedSplit.changeNumber = changeNumber;
56
- var newSplit = JSON.stringify(parsedSplit);
57
- return this.addSplit(name, newSplit);
58
- }
51
+ if (split && (!split.changeNumber || split.changeNumber < changeNumber)) {
52
+ var newSplit = (0, objectAssign_1.objectAssign)({}, split);
53
+ newSplit.killed = true;
54
+ newSplit.defaultTreatment = defaultTreatment;
55
+ newSplit.changeNumber = changeNumber;
56
+ return this.addSplit(name, newSplit);
59
57
  }
60
58
  return false;
61
59
  };
@@ -23,12 +23,6 @@ var KeyBuilderSS = /** @class */ (function (_super) {
23
23
  KeyBuilderSS.prototype.buildImpressionsKey = function () {
24
24
  return this.prefix + ".impressions";
25
25
  };
26
- KeyBuilderSS.prototype.buildImpressionsCountKey = function () {
27
- return this.prefix + ".impressions.count";
28
- };
29
- KeyBuilderSS.prototype.buildUniqueKeysKey = function () {
30
- return this.prefix + ".uniquekeys";
31
- };
32
26
  KeyBuilderSS.prototype.buildEventsKey = function () {
33
27
  return this.prefix + ".events";
34
28
  };
@@ -35,7 +35,7 @@ function dataLoaderFactory(preloadedData) {
35
35
  storage.splits.clear();
36
36
  storage.splits.setChangeNumber(since);
37
37
  // splitsData in an object where the property is the split name and the pertaining value is a stringified json of its data
38
- storage.splits.addSplits(Object.keys(splitsData).map(function (splitName) { return [splitName, splitsData[splitName]]; }));
38
+ storage.splits.addSplits(Object.keys(splitsData).map(function (splitName) { return JSON.parse(splitsData[splitName]); }));
39
39
  // add mySegments data
40
40
  var mySegmentsData = preloadedData.mySegmentsData && preloadedData.mySegmentsData[userId];
41
41
  if (!mySegmentsData) {
@@ -96,9 +96,8 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
96
96
  var splitFromLocalStorage = localStorage.getItem(splitKey);
97
97
  var previousSplit = splitFromLocalStorage ? JSON.parse(splitFromLocalStorage) : null;
98
98
  this._decrementCounts(previousSplit);
99
- localStorage.setItem(splitKey, split);
100
- var parsedSplit = split ? JSON.parse(split) : null;
101
- this._incrementCounts(parsedSplit);
99
+ localStorage.setItem(splitKey, JSON.stringify(split));
100
+ this._incrementCounts(split);
102
101
  return true;
103
102
  }
104
103
  catch (e) {
@@ -110,8 +109,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
110
109
  try {
111
110
  var split = this.getSplit(name);
112
111
  localStorage.removeItem(this.keys.buildSplitKey(name));
113
- var parsedSplit = JSON.parse(split);
114
- this._decrementCounts(parsedSplit);
112
+ this._decrementCounts(split);
115
113
  return true;
116
114
  }
117
115
  catch (e) {
@@ -120,7 +118,8 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
120
118
  }
121
119
  };
122
120
  SplitsCacheInLocal.prototype.getSplit = function (name) {
123
- return localStorage.getItem(this.keys.buildSplitKey(name));
121
+ var item = localStorage.getItem(this.keys.buildSplitKey(name));
122
+ return item && JSON.parse(item);
124
123
  };
125
124
  SplitsCacheInLocal.prototype.setChangeNumber = function (changeNumber) {
126
125
  // when cache is ready but using a new split query, we must clear all split data
@@ -16,7 +16,6 @@ var InMemoryStorageCS_1 = require("../inMemory/InMemoryStorageCS");
16
16
  var constants_1 = require("./constants");
17
17
  var constants_2 = require("../../utils/constants");
18
18
  var TelemetryCacheInMemory_1 = require("../inMemory/TelemetryCacheInMemory");
19
- var uniqueKeysCacheInMemoryCS_1 = require("../inMemory/uniqueKeysCacheInMemoryCS");
20
19
  /**
21
20
  * InLocal storage factory for standalone client-side SplitFactory
22
21
  */
@@ -39,15 +38,12 @@ function InLocalStorage(options) {
39
38
  impressionCounts: params.optimize ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
40
39
  events: new EventsCacheInMemory_1.EventsCacheInMemory(params.eventsQueueSize),
41
40
  telemetry: params.mode !== constants_2.LOCALHOST_MODE && (0, TelemetryCacheInMemory_1.shouldRecordTelemetry)() ? new TelemetryCacheInMemory_1.TelemetryCacheInMemory() : undefined,
42
- uniqueKeys: params.impressionsMode === constants_2.NONE ? new uniqueKeysCacheInMemoryCS_1.UniqueKeysCacheInMemoryCS() : undefined,
43
41
  destroy: function () {
44
- var _a;
45
42
  this.splits = new SplitsCacheInMemory_1.SplitsCacheInMemory();
46
43
  this.segments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
47
44
  this.impressions.clear();
48
45
  this.impressionCounts && this.impressionCounts.clear();
49
46
  this.events.clear();
50
- (_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
51
47
  },
52
48
  // When using shared instanciation with MEMORY we reuse everything but segments (they are customer per key).
53
49
  shared: function (matchingKey) {
@@ -2,13 +2,9 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ImpressionCountsCacheInMemory = void 0;
4
4
  var time_1 = require("../../utils/time");
5
- var constants_1 = require("../inRedis/constants");
6
5
  var ImpressionCountsCacheInMemory = /** @class */ (function () {
7
- function ImpressionCountsCacheInMemory(impressionCountsCacheSize) {
8
- if (impressionCountsCacheSize === void 0) { impressionCountsCacheSize = constants_1.DEFAULT_CACHE_SIZE; }
6
+ function ImpressionCountsCacheInMemory() {
9
7
  this.cache = {};
10
- this.cacheSize = 0;
11
- this.maxStorage = impressionCountsCacheSize;
12
8
  }
13
9
  /**
14
10
  * Builds key to be stored in the cache with the featureName and the timeFrame truncated.
@@ -23,13 +19,6 @@ var ImpressionCountsCacheInMemory = /** @class */ (function () {
23
19
  var key = this._makeKey(featureName, timeFrame);
24
20
  var currentAmount = this.cache[key];
25
21
  this.cache[key] = currentAmount ? currentAmount + amount : amount;
26
- if (this.onFullQueue) {
27
- this.cacheSize = this.cacheSize + amount;
28
- if (this.cacheSize >= this.maxStorage) {
29
- this.onFullQueue();
30
- this.cacheSize = 0;
31
- }
32
- }
33
22
  };
34
23
  /**
35
24
  * Pop the collected data, used as payload for posting.
@@ -8,7 +8,6 @@ var EventsCacheInMemory_1 = require("./EventsCacheInMemory");
8
8
  var ImpressionCountsCacheInMemory_1 = require("./ImpressionCountsCacheInMemory");
9
9
  var constants_1 = require("../../utils/constants");
10
10
  var TelemetryCacheInMemory_1 = require("./TelemetryCacheInMemory");
11
- var uniqueKeysCacheInMemory_1 = require("./uniqueKeysCacheInMemory");
12
11
  /**
13
12
  * InMemory storage factory for standalone server-side SplitFactory
14
13
  *
@@ -19,19 +18,16 @@ function InMemoryStorageFactory(params) {
19
18
  splits: new SplitsCacheInMemory_1.SplitsCacheInMemory(),
20
19
  segments: new SegmentsCacheInMemory_1.SegmentsCacheInMemory(),
21
20
  impressions: new ImpressionsCacheInMemory_1.ImpressionsCacheInMemory(params.impressionsQueueSize),
22
- impressionCounts: params.impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
21
+ impressionCounts: params.optimize ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
23
22
  events: new EventsCacheInMemory_1.EventsCacheInMemory(params.eventsQueueSize),
24
23
  telemetry: params.mode !== constants_1.LOCALHOST_MODE ? new TelemetryCacheInMemory_1.TelemetryCacheInMemory() : undefined,
25
- uniqueKeys: params.impressionsMode === constants_1.NONE ? new uniqueKeysCacheInMemory_1.UniqueKeysCacheInMemory(params.uniqueKeysCacheSize) : undefined,
26
24
  // When using MEMORY we should clean all the caches to leave them empty
27
25
  destroy: function () {
28
- var _a;
29
26
  this.splits.clear();
30
27
  this.segments.clear();
31
28
  this.impressions.clear();
32
29
  this.impressionCounts && this.impressionCounts.clear();
33
30
  this.events.clear();
34
- (_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
35
31
  }
36
32
  };
37
33
  }
@@ -8,7 +8,6 @@ var EventsCacheInMemory_1 = require("./EventsCacheInMemory");
8
8
  var ImpressionCountsCacheInMemory_1 = require("./ImpressionCountsCacheInMemory");
9
9
  var constants_1 = require("../../utils/constants");
10
10
  var TelemetryCacheInMemory_1 = require("./TelemetryCacheInMemory");
11
- var uniqueKeysCacheInMemoryCS_1 = require("./uniqueKeysCacheInMemoryCS");
12
11
  /**
13
12
  * InMemory storage factory for standalone client-side SplitFactory
14
13
  *
@@ -19,19 +18,16 @@ function InMemoryStorageCSFactory(params) {
19
18
  splits: new SplitsCacheInMemory_1.SplitsCacheInMemory(),
20
19
  segments: new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory(),
21
20
  impressions: new ImpressionsCacheInMemory_1.ImpressionsCacheInMemory(params.impressionsQueueSize),
22
- impressionCounts: params.impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
21
+ impressionCounts: params.optimize ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
23
22
  events: new EventsCacheInMemory_1.EventsCacheInMemory(params.eventsQueueSize),
24
23
  telemetry: params.mode !== constants_1.LOCALHOST_MODE && (0, TelemetryCacheInMemory_1.shouldRecordTelemetry)() ? new TelemetryCacheInMemory_1.TelemetryCacheInMemory() : undefined,
25
- uniqueKeys: params.impressionsMode === constants_1.NONE ? new uniqueKeysCacheInMemoryCS_1.UniqueKeysCacheInMemoryCS(params.uniqueKeysCacheSize) : undefined,
26
24
  // When using MEMORY we should clean all the caches to leave them empty
27
25
  destroy: function () {
28
- var _a;
29
26
  this.splits.clear();
30
27
  this.segments.clear();
31
28
  this.impressions.clear();
32
29
  this.impressionCounts && this.impressionCounts.clear();
33
30
  this.events.clear();
34
- (_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
35
31
  },
36
32
  // When using shared instanciation with MEMORY we reuse everything but segments (they are unique per key)
37
33
  shared: function () {
@@ -25,9 +25,8 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
25
25
  this.splitsWithSegmentsCount = 0;
26
26
  };
27
27
  SplitsCacheInMemory.prototype.addSplit = function (name, split) {
28
- var splitFromMemory = this.getSplit(name);
29
- if (splitFromMemory) { // We had this Split already
30
- var previousSplit = JSON.parse(splitFromMemory);
28
+ var previousSplit = this.getSplit(name);
29
+ if (previousSplit) { // We had this Split already
31
30
  if (previousSplit.trafficTypeName) {
32
31
  var previousTtName = previousSplit.trafficTypeName;
33
32
  this.ttCache[previousTtName]--;
@@ -38,19 +37,18 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
38
37
  this.splitsWithSegmentsCount--;
39
38
  }
40
39
  }
41
- var parsedSplit = JSON.parse(split);
42
- if (parsedSplit) {
40
+ if (split) {
43
41
  // Store the Split.
44
42
  this.splitsCache[name] = split;
45
43
  // Update TT cache
46
- var ttName = parsedSplit.trafficTypeName;
44
+ var ttName = split.trafficTypeName;
47
45
  if (ttName) { // safeguard
48
46
  if (!this.ttCache[ttName])
49
47
  this.ttCache[ttName] = 0;
50
48
  this.ttCache[ttName]++;
51
49
  }
52
50
  // Add to segments count for the new version of the Split
53
- if ((0, AbstractSplitsCacheSync_1.usesSegments)(parsedSplit))
51
+ if ((0, AbstractSplitsCacheSync_1.usesSegments)(split))
54
52
  this.splitsWithSegmentsCount++;
55
53
  return true;
56
54
  }
@@ -63,15 +61,14 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
63
61
  if (split) {
64
62
  // Delete the Split
65
63
  delete this.splitsCache[name];
66
- var parsedSplit = JSON.parse(split);
67
- var ttName = parsedSplit.trafficTypeName;
64
+ var ttName = split.trafficTypeName;
68
65
  if (ttName) { // safeguard
69
66
  this.ttCache[ttName]--; // Update tt cache
70
67
  if (!this.ttCache[ttName])
71
68
  delete this.ttCache[ttName];
72
69
  }
73
70
  // Update the segments count.
74
- if ((0, AbstractSplitsCacheSync_1.usesSegments)(parsedSplit))
71
+ if ((0, AbstractSplitsCacheSync_1.usesSegments)(split))
75
72
  this.splitsWithSegmentsCount--;
76
73
  return true;
77
74
  }
@@ -62,17 +62,17 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
62
62
  var splitKey = this.keys.buildSplitKey(name);
63
63
  return this.redis.get(splitKey).then(function (splitFromStorage) {
64
64
  // handling parsing errors
65
- var parsedPreviousSplit, parsedSplit;
65
+ var parsedPreviousSplit, newStringifiedSplit;
66
66
  try {
67
67
  parsedPreviousSplit = splitFromStorage ? JSON.parse(splitFromStorage) : undefined;
68
- parsedSplit = JSON.parse(split);
68
+ newStringifiedSplit = JSON.stringify(split);
69
69
  }
70
70
  catch (e) {
71
71
  throw new Error('Error parsing split definition: ' + e);
72
72
  }
73
73
  return Promise.all([
74
- _this.redis.set(splitKey, split),
75
- _this._incrementCounts(parsedSplit),
74
+ _this.redis.set(splitKey, newStringifiedSplit),
75
+ _this._incrementCounts(split),
76
76
  // If it's an update, we decrement the traffic type of the existing split,
77
77
  parsedPreviousSplit && _this._decrementCounts(parsedPreviousSplit)
78
78
  ]);
@@ -99,8 +99,7 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
99
99
  var _this = this;
100
100
  return this.getSplit(name).then(function (split) {
101
101
  if (split) {
102
- var parsedSplit = JSON.parse(split);
103
- _this._decrementCounts(parsedSplit);
102
+ _this._decrementCounts(split);
104
103
  }
105
104
  return _this.redis.del(_this.keys.buildSplitKey(name));
106
105
  });
@@ -123,7 +122,8 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
123
122
  this.log.error(constants_1.LOG_PREFIX + this.redisError);
124
123
  return Promise.reject(this.redisError);
125
124
  }
126
- return this.redis.get(this.keys.buildSplitKey(name));
125
+ return this.redis.get(this.keys.buildSplitKey(name))
126
+ .then(function (maybeSplit) { return maybeSplit && JSON.parse(maybeSplit); });
127
127
  };
128
128
  /**
129
129
  * Set till number.
@@ -158,7 +158,12 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
158
158
  */
159
159
  SplitsCacheInRedis.prototype.getAll = function () {
160
160
  var _this = this;
161
- return this.redis.keys(this.keys.searchPatternForSplitKeys()).then(function (listOfKeys) { return _this.redis.pipeline(listOfKeys.map(function (k) { return ['get', k]; })).exec(); }).then(processPipelineAnswer);
161
+ return this.redis.keys(this.keys.searchPatternForSplitKeys())
162
+ .then(function (listOfKeys) { return _this.redis.pipeline(listOfKeys.map(function (k) { return ['get', k]; })).exec(); })
163
+ .then(processPipelineAnswer)
164
+ .then(function (splitDefinitions) { return splitDefinitions.map(function (splitDefinition) {
165
+ return JSON.parse(splitDefinition);
166
+ }); });
162
167
  };
163
168
  /**
164
169
  * Get list of split names.
@@ -218,7 +223,8 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
218
223
  var keys = names.map(function (name) { return _this.keys.buildSplitKey(name); });
219
224
  return (_a = this.redis).mget.apply(_a, keys).then(function (splitDefinitions) {
220
225
  names.forEach(function (name, idx) {
221
- splits[name] = splitDefinitions[idx];
226
+ var split = splitDefinitions[idx];
227
+ splits[name] = split && JSON.parse(split);
222
228
  });
223
229
  return Promise.resolve(splits);
224
230
  })
@@ -1,7 +1,4 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.TTL_REFRESH = exports.REFRESH_RATE = exports.DEFAULT_CACHE_SIZE = exports.LOG_PREFIX = void 0;
3
+ exports.LOG_PREFIX = void 0;
4
4
  exports.LOG_PREFIX = 'storage:redis: ';
5
- exports.DEFAULT_CACHE_SIZE = 30000;
6
- exports.REFRESH_RATE = 300000; // 300.000 ms = start after 5 mins
7
- exports.TTL_REFRESH = 3600; // 1hr