@splitsoftware/splitio-commons 2.2.1-rc.1 → 2.2.1-rc.3

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 (143) hide show
  1. package/CHANGES.txt +2 -2
  2. package/README.md +0 -1
  3. package/cjs/evaluator/combiners/and.js +6 -2
  4. package/cjs/evaluator/combiners/ifelseif.js +6 -6
  5. package/cjs/evaluator/condition/index.js +5 -6
  6. package/cjs/evaluator/index.js +7 -7
  7. package/cjs/evaluator/matchers/index.js +1 -3
  8. package/cjs/evaluator/matchers/matcherTypes.js +0 -1
  9. package/cjs/evaluator/matchersTransform/index.js +0 -4
  10. package/cjs/evaluator/parser/index.js +2 -2
  11. package/cjs/evaluator/value/sanitize.js +0 -1
  12. package/cjs/logger/constants.js +3 -4
  13. package/cjs/logger/messages/debug.js +2 -3
  14. package/cjs/logger/messages/warn.js +1 -1
  15. package/cjs/sdkFactory/index.js +3 -0
  16. package/cjs/services/splitApi.js +4 -3
  17. package/cjs/storages/AbstractSplitsCacheSync.js +2 -5
  18. package/cjs/storages/KeyBuilder.js +0 -9
  19. package/cjs/storages/KeyBuilderCS.js +0 -3
  20. package/cjs/storages/KeyBuilderSS.js +0 -3
  21. package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +14 -9
  22. package/cjs/storages/inLocalStorage/index.js +1 -5
  23. package/cjs/storages/inLocalStorage/validateCache.js +1 -2
  24. package/cjs/storages/inMemory/InMemoryStorage.js +0 -3
  25. package/cjs/storages/inMemory/InMemoryStorageCS.js +0 -4
  26. package/cjs/storages/inRedis/index.js +12 -6
  27. package/cjs/storages/pluggable/index.js +0 -2
  28. package/cjs/sync/polling/fetchers/splitChangesFetcher.js +4 -51
  29. package/cjs/sync/polling/pollingManagerCS.js +7 -7
  30. package/cjs/sync/polling/syncTasks/splitsSyncTask.js +1 -1
  31. package/cjs/sync/polling/updaters/mySegmentsUpdater.js +2 -2
  32. package/cjs/sync/polling/updaters/segmentChangesUpdater.js +1 -1
  33. package/cjs/sync/polling/updaters/splitChangesUpdater.js +33 -51
  34. package/cjs/sync/streaming/SSEHandler/index.js +0 -1
  35. package/cjs/sync/streaming/UpdateWorkers/SplitsUpdateWorker.js +77 -106
  36. package/cjs/sync/streaming/constants.js +1 -2
  37. package/cjs/sync/streaming/pushManager.js +16 -3
  38. package/cjs/sync/syncManagerOnline.js +2 -2
  39. package/cjs/utils/constants/index.js +2 -3
  40. package/esm/evaluator/combiners/and.js +6 -2
  41. package/esm/evaluator/combiners/ifelseif.js +7 -7
  42. package/esm/evaluator/condition/index.js +5 -6
  43. package/esm/evaluator/index.js +7 -7
  44. package/esm/evaluator/matchers/index.js +1 -3
  45. package/esm/evaluator/matchers/matcherTypes.js +0 -1
  46. package/esm/evaluator/matchersTransform/index.js +0 -4
  47. package/esm/evaluator/parser/index.js +2 -2
  48. package/esm/evaluator/value/sanitize.js +0 -1
  49. package/esm/logger/constants.js +0 -1
  50. package/esm/logger/messages/debug.js +2 -3
  51. package/esm/logger/messages/warn.js +1 -1
  52. package/esm/sdkFactory/index.js +4 -1
  53. package/esm/services/splitApi.js +4 -3
  54. package/esm/storages/AbstractSplitsCacheSync.js +2 -5
  55. package/esm/storages/KeyBuilder.js +0 -9
  56. package/esm/storages/KeyBuilderCS.js +0 -3
  57. package/esm/storages/KeyBuilderSS.js +0 -3
  58. package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +14 -9
  59. package/esm/storages/inLocalStorage/index.js +1 -5
  60. package/esm/storages/inLocalStorage/validateCache.js +1 -2
  61. package/esm/storages/inMemory/InMemoryStorage.js +0 -3
  62. package/esm/storages/inMemory/InMemoryStorageCS.js +0 -4
  63. package/esm/storages/inRedis/index.js +12 -6
  64. package/esm/storages/pluggable/index.js +0 -2
  65. package/esm/sync/polling/fetchers/splitChangesFetcher.js +4 -51
  66. package/esm/sync/polling/pollingManagerCS.js +7 -7
  67. package/esm/sync/polling/syncTasks/splitsSyncTask.js +1 -1
  68. package/esm/sync/polling/updaters/mySegmentsUpdater.js +2 -2
  69. package/esm/sync/polling/updaters/segmentChangesUpdater.js +1 -1
  70. package/esm/sync/polling/updaters/splitChangesUpdater.js +33 -51
  71. package/esm/sync/streaming/SSEHandler/index.js +1 -2
  72. package/esm/sync/streaming/UpdateWorkers/SplitsUpdateWorker.js +73 -102
  73. package/esm/sync/streaming/constants.js +0 -1
  74. package/esm/sync/streaming/pushManager.js +19 -6
  75. package/esm/sync/syncManagerOnline.js +2 -2
  76. package/esm/utils/constants/index.js +1 -2
  77. package/package.json +1 -1
  78. package/src/dtos/types.ts +8 -32
  79. package/src/evaluator/Engine.ts +1 -1
  80. package/src/evaluator/combiners/and.ts +4 -5
  81. package/src/evaluator/combiners/ifelseif.ts +9 -7
  82. package/src/evaluator/condition/engineUtils.ts +1 -1
  83. package/src/evaluator/condition/index.ts +12 -12
  84. package/src/evaluator/index.ts +7 -7
  85. package/src/evaluator/matchers/index.ts +1 -3
  86. package/src/evaluator/matchers/matcherTypes.ts +0 -1
  87. package/src/evaluator/matchersTransform/index.ts +0 -3
  88. package/src/evaluator/parser/index.ts +3 -3
  89. package/src/evaluator/types.ts +2 -2
  90. package/src/evaluator/value/index.ts +2 -2
  91. package/src/evaluator/value/sanitize.ts +4 -5
  92. package/src/logger/constants.ts +0 -1
  93. package/src/logger/messages/debug.ts +2 -3
  94. package/src/logger/messages/warn.ts +1 -1
  95. package/src/sdkFactory/index.ts +4 -1
  96. package/src/sdkManager/index.ts +1 -1
  97. package/src/services/splitApi.ts +4 -3
  98. package/src/services/types.ts +1 -1
  99. package/src/storages/AbstractSplitsCacheSync.ts +3 -6
  100. package/src/storages/KeyBuilder.ts +0 -12
  101. package/src/storages/KeyBuilderCS.ts +0 -4
  102. package/src/storages/KeyBuilderSS.ts +0 -4
  103. package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +14 -10
  104. package/src/storages/inLocalStorage/index.ts +1 -5
  105. package/src/storages/inLocalStorage/validateCache.ts +1 -3
  106. package/src/storages/inMemory/InMemoryStorage.ts +0 -3
  107. package/src/storages/inMemory/InMemoryStorageCS.ts +0 -4
  108. package/src/storages/inRedis/index.ts +15 -8
  109. package/src/storages/pluggable/index.ts +0 -2
  110. package/src/storages/types.ts +2 -33
  111. package/src/sync/polling/fetchers/splitChangesFetcher.ts +4 -62
  112. package/src/sync/polling/fetchers/types.ts +0 -1
  113. package/src/sync/polling/pollingManagerCS.ts +7 -7
  114. package/src/sync/polling/syncTasks/splitsSyncTask.ts +1 -1
  115. package/src/sync/polling/types.ts +2 -2
  116. package/src/sync/polling/updaters/mySegmentsUpdater.ts +2 -2
  117. package/src/sync/polling/updaters/segmentChangesUpdater.ts +1 -1
  118. package/src/sync/polling/updaters/splitChangesUpdater.ts +42 -61
  119. package/src/sync/streaming/SSEHandler/index.ts +1 -2
  120. package/src/sync/streaming/SSEHandler/types.ts +2 -2
  121. package/src/sync/streaming/UpdateWorkers/SplitsUpdateWorker.ts +68 -98
  122. package/src/sync/streaming/constants.ts +0 -1
  123. package/src/sync/streaming/parseUtils.ts +2 -2
  124. package/src/sync/streaming/pushManager.ts +18 -6
  125. package/src/sync/streaming/types.ts +2 -3
  126. package/src/sync/syncManagerOnline.ts +2 -2
  127. package/src/utils/constants/index.ts +1 -2
  128. package/src/utils/lang/index.ts +1 -1
  129. package/cjs/evaluator/matchers/rbsegment.js +0 -44
  130. package/cjs/storages/inLocalStorage/RBSegmentsCacheInLocal.js +0 -117
  131. package/cjs/storages/inMemory/RBSegmentsCacheInMemory.js +0 -61
  132. package/cjs/storages/inRedis/RBSegmentsCacheInRedis.js +0 -64
  133. package/cjs/storages/pluggable/RBSegmentsCachePluggable.js +0 -64
  134. package/esm/evaluator/matchers/rbsegment.js +0 -40
  135. package/esm/storages/inLocalStorage/RBSegmentsCacheInLocal.js +0 -114
  136. package/esm/storages/inMemory/RBSegmentsCacheInMemory.js +0 -58
  137. package/esm/storages/inRedis/RBSegmentsCacheInRedis.js +0 -61
  138. package/esm/storages/pluggable/RBSegmentsCachePluggable.js +0 -61
  139. package/src/evaluator/matchers/rbsegment.ts +0 -62
  140. package/src/storages/inLocalStorage/RBSegmentsCacheInLocal.ts +0 -136
  141. package/src/storages/inMemory/RBSegmentsCacheInMemory.ts +0 -68
  142. package/src/storages/inRedis/RBSegmentsCacheInRedis.ts +0 -79
  143. package/src/storages/pluggable/RBSegmentsCachePluggable.ts +0 -76
@@ -1,65 +1,18 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.splitChangesFetcherFactory = void 0;
4
- var constants_1 = require("../../../utils/constants");
5
- var settingsValidation_1 = require("../../../utils/settingsValidation");
6
- var constants_2 = require("../../../logger/constants");
7
- var PROXY_CHECK_INTERVAL_MILLIS_CS = 60 * 60 * 1000; // 1 hour in Client Side
8
- var PROXY_CHECK_INTERVAL_MILLIS_SS = 24 * PROXY_CHECK_INTERVAL_MILLIS_CS; // 24 hours in Server Side
9
- function sdkEndpointOverriden(settings) {
10
- return settings.urls.sdk !== settingsValidation_1.base.urls.sdk;
11
- }
12
4
  /**
13
5
  * Factory of SplitChanges fetcher.
14
6
  * SplitChanges fetcher is a wrapper around `splitChanges` API service that parses the response and handle errors.
15
7
  */
16
- // @TODO breaking: drop support for Split Proxy below v5.10.0 and simplify the implementation
17
- function splitChangesFetcherFactory(fetchSplitChanges, settings, storage) {
18
- var log = settings.log;
19
- var PROXY_CHECK_INTERVAL_MILLIS = settings.core.key !== undefined ? PROXY_CHECK_INTERVAL_MILLIS_CS : PROXY_CHECK_INTERVAL_MILLIS_SS;
20
- var lastProxyCheckTimestamp;
21
- return function splitChangesFetcher(since, noCache, till, rbSince,
8
+ function splitChangesFetcherFactory(fetchSplitChanges) {
9
+ return function splitChangesFetcher(since, noCache, till,
22
10
  // Optional decorator for `fetchSplitChanges` promise, such as timeout or time tracker
23
11
  decorator) {
24
- // Recheck proxy
25
- if (lastProxyCheckTimestamp && (Date.now() - lastProxyCheckTimestamp) > PROXY_CHECK_INTERVAL_MILLIS) {
26
- settings.sync.flagSpecVersion = constants_1.FLAG_SPEC_VERSION;
27
- }
28
- var splitsPromise = fetchSplitChanges(since, noCache, till, settings.sync.flagSpecVersion === constants_1.FLAG_SPEC_VERSION ? rbSince : undefined)
29
- // Handle proxy error with spec 1.3
30
- .catch(function (err) {
31
- if (err.statusCode === 400 && sdkEndpointOverriden(settings) && settings.sync.flagSpecVersion === constants_1.FLAG_SPEC_VERSION) {
32
- log.error(constants_2.LOG_PREFIX_SYNC_SPLITS + 'Proxy error detected. If you are using Split Proxy, please upgrade to latest version');
33
- lastProxyCheckTimestamp = Date.now();
34
- settings.sync.flagSpecVersion = '1.2'; // fallback to 1.2 spec
35
- return fetchSplitChanges(since, noCache, till); // retry request without rbSince
36
- }
37
- throw err;
38
- });
12
+ var splitsPromise = fetchSplitChanges(since, noCache, till);
39
13
  if (decorator)
40
14
  splitsPromise = decorator(splitsPromise);
41
- return splitsPromise
42
- .then(function (resp) { return resp.json(); })
43
- .then(function (data) {
44
- // Using flag spec version 1.2
45
- if (data.splits) {
46
- return {
47
- ff: {
48
- d: data.splits,
49
- s: data.since,
50
- t: data.till
51
- }
52
- };
53
- }
54
- // Proxy recovery
55
- if (lastProxyCheckTimestamp) {
56
- log.info(constants_2.LOG_PREFIX_SYNC_SPLITS + 'Proxy error recovered');
57
- lastProxyCheckTimestamp = undefined;
58
- return Promise.all([storage.splits.clear(), storage.rbSegments.clear()])
59
- .then(function () { return splitChangesFetcher(storage.splits.getChangeNumber(), undefined, undefined, storage.rbSegments.getChangeNumber()); });
60
- }
61
- return data;
62
- });
15
+ return splitsPromise.then(function (resp) { return resp.json(); });
63
16
  };
64
17
  }
65
18
  exports.splitChangesFetcherFactory = splitChangesFetcherFactory;
@@ -34,10 +34,10 @@ function pollingManagerCSFactory(params) {
34
34
  readiness.splits.on(constants_1.SDK_SPLITS_ARRIVED, function () {
35
35
  if (!splitsSyncTask.isRunning())
36
36
  return; // noop if not doing polling
37
- var usingSegments = storage.splits.usesSegments() || storage.rbSegments.usesSegments();
38
- if (usingSegments !== mySegmentsSyncTask.isRunning()) {
39
- log.info(constants_2.POLLING_SMART_PAUSING, [usingSegments ? 'ON' : 'OFF']);
40
- if (usingSegments) {
37
+ var splitsHaveSegments = storage.splits.usesSegments();
38
+ if (splitsHaveSegments !== mySegmentsSyncTask.isRunning()) {
39
+ log.info(constants_2.POLLING_SMART_PAUSING, [splitsHaveSegments ? 'ON' : 'OFF']);
40
+ if (splitsHaveSegments) {
41
41
  startMySegmentsSyncTasks();
42
42
  }
43
43
  else {
@@ -49,10 +49,10 @@ function pollingManagerCSFactory(params) {
49
49
  var mySegmentsSyncTask = (0, mySegmentsSyncTask_1.mySegmentsSyncTaskFactory)(splitApi.fetchMemberships, storage, readiness, settings, matchingKey);
50
50
  // smart ready
51
51
  function smartReady() {
52
- if (!readiness.isReady() && !storage.splits.usesSegments() && !storage.rbSegments.usesSegments())
52
+ if (!readiness.isReady() && !storage.splits.usesSegments())
53
53
  readiness.segments.emit(constants_1.SDK_SEGMENTS_ARRIVED);
54
54
  }
55
- if (!storage.splits.usesSegments() && !storage.rbSegments.usesSegments())
55
+ if (!storage.splits.usesSegments())
56
56
  setTimeout(smartReady, 0);
57
57
  else
58
58
  readiness.splits.once(constants_1.SDK_SPLITS_ARRIVED, smartReady);
@@ -66,7 +66,7 @@ function pollingManagerCSFactory(params) {
66
66
  start: function () {
67
67
  log.info(constants_2.POLLING_START);
68
68
  splitsSyncTask.start();
69
- if (storage.splits.usesSegments() || storage.rbSegments.usesSegments())
69
+ if (storage.splits.usesSegments())
70
70
  startMySegmentsSyncTasks();
71
71
  },
72
72
  // Stop periodic fetching (polling)
@@ -8,6 +8,6 @@ var splitChangesUpdater_1 = require("../updaters/splitChangesUpdater");
8
8
  * Creates a sync task that periodically executes a `splitChangesUpdater` task
9
9
  */
10
10
  function splitsSyncTaskFactory(fetchSplitChanges, storage, readiness, settings, isClientSide) {
11
- return (0, syncTask_1.syncTaskFactory)(settings.log, (0, splitChangesUpdater_1.splitChangesUpdaterFactory)(settings.log, (0, splitChangesFetcher_1.splitChangesFetcherFactory)(fetchSplitChanges, settings, storage), storage, settings.sync.__splitFiltersValidation, readiness.splits, settings.startup.requestTimeoutBeforeReady, settings.startup.retriesOnFailureBeforeReady, isClientSide), settings.scheduler.featuresRefreshRate, 'splitChangesUpdater');
11
+ return (0, syncTask_1.syncTaskFactory)(settings.log, (0, splitChangesUpdater_1.splitChangesUpdaterFactory)(settings.log, (0, splitChangesFetcher_1.splitChangesFetcherFactory)(fetchSplitChanges), storage, settings.sync.__splitFiltersValidation, readiness.splits, settings.startup.requestTimeoutBeforeReady, settings.startup.retriesOnFailureBeforeReady, isClientSide), settings.scheduler.featuresRefreshRate, 'splitChangesUpdater');
12
12
  }
13
13
  exports.splitsSyncTaskFactory = splitsSyncTaskFactory;
@@ -12,7 +12,7 @@ var constants_3 = require("../../streaming/constants");
12
12
  * - uses `segmentsEventEmitter` to emit events related to segments data updates
13
13
  */
14
14
  function mySegmentsUpdaterFactory(log, mySegmentsFetcher, storage, segmentsEventEmitter, requestTimeoutBeforeReady, retriesOnFailureBeforeReady, matchingKey) {
15
- var splits = storage.splits, rbSegments = storage.rbSegments, segments = storage.segments, largeSegments = storage.largeSegments;
15
+ var splits = storage.splits, segments = storage.segments, largeSegments = storage.largeSegments;
16
16
  var readyOnAlreadyExistentState = true;
17
17
  var startingUp = true;
18
18
  /** timeout and telemetry decorator for `splitChangesFetcher` promise */
@@ -34,7 +34,7 @@ function mySegmentsUpdaterFactory(log, mySegmentsFetcher, storage, segmentsEvent
34
34
  shouldNotifyUpdate = largeSegments.resetSegments(segmentsData.ls || {}) || shouldNotifyUpdate;
35
35
  }
36
36
  // Notify update if required
37
- if ((splits.usesSegments() || rbSegments.usesSegments()) && (shouldNotifyUpdate || readyOnAlreadyExistentState)) {
37
+ if (splits.usesSegments() && (shouldNotifyUpdate || readyOnAlreadyExistentState)) {
38
38
  readyOnAlreadyExistentState = false;
39
39
  segmentsEventEmitter.emit(constants_1.SDK_SEGMENTS_ARRIVED);
40
40
  }
@@ -39,7 +39,7 @@ function segmentChangesUpdaterFactory(log, segmentChangesFetcher, segments, read
39
39
  * Returned promise will not be rejected.
40
40
  *
41
41
  * @param fetchOnlyNew - if true, only fetch the segments that not exists, i.e., which `changeNumber` is equal to -1.
42
- * This param is used by SplitUpdateWorker on server-side SDK, to fetch new registered segments on SPLIT_UPDATE or RB_SEGMENT_UPDATE notifications.
42
+ * This param is used by SplitUpdateWorker on server-side SDK, to fetch new registered segments on SPLIT_UPDATE notifications.
43
43
  * @param segmentName - segment name to fetch. By passing `undefined` it fetches the list of segments registered at the storage
44
44
  * @param noCache - true to revalidate data to fetch on a SEGMENT_UPDATE notifications.
45
45
  * @param till - till target for the provided segmentName, for CDN bypass.
@@ -1,13 +1,12 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.splitChangesUpdaterFactory = exports.computeMutation = exports.parseSegments = void 0;
3
+ exports.splitChangesUpdaterFactory = exports.computeSplitsMutation = exports.parseSegments = void 0;
4
4
  var timeout_1 = require("../../../utils/promise/timeout");
5
5
  var constants_1 = require("../../../readiness/constants");
6
6
  var constants_2 = require("../../../logger/constants");
7
7
  var lang_1 = require("../../../utils/lang");
8
8
  var constants_3 = require("../../../utils/constants");
9
9
  var sets_1 = require("../../../utils/lang/sets");
10
- var constants_4 = require("../../streaming/constants");
11
10
  // Checks that all registered segments have been fetched (changeNumber !== -1 for every segment).
12
11
  // Returns a promise that could be rejected.
13
12
  // @TODO review together with Segments and MySegments storage APIs
@@ -22,14 +21,13 @@ function checkAllSegmentsExist(segments) {
22
21
  * Collect segments from a raw split definition.
23
22
  * Exported for testing purposes.
24
23
  */
25
- function parseSegments(ruleEntity, matcherType) {
26
- if (matcherType === void 0) { matcherType = constants_3.IN_SEGMENT; }
27
- var _a = ruleEntity, _b = _a.conditions, conditions = _b === void 0 ? [] : _b, excluded = _a.excluded;
28
- var segments = new Set(excluded && excluded.segments);
24
+ function parseSegments(_a) {
25
+ var conditions = _a.conditions;
26
+ var segments = new Set();
29
27
  for (var i = 0; i < conditions.length; i++) {
30
28
  var matchers = conditions[i].matcherGroup.matchers;
31
29
  matchers.forEach(function (matcher) {
32
- if (matcher.matcherType === matcherType)
30
+ if (matcher.matcherType === constants_3.IN_SEGMENT)
33
31
  segments.add(matcher.userDefinedSegmentMatcherData.segmentName);
34
32
  });
35
33
  }
@@ -60,21 +58,24 @@ function matchFilters(featureFlag, filters) {
60
58
  * i.e., an object with added splits, removed splits and used segments.
61
59
  * Exported for testing purposes.
62
60
  */
63
- function computeMutation(rules, segments, filters) {
64
- return rules.reduce(function (accum, ruleEntity) {
65
- if (ruleEntity.status === 'ACTIVE' && (!filters || matchFilters(ruleEntity, filters))) {
66
- accum.added.push(ruleEntity);
67
- parseSegments(ruleEntity).forEach(function (segmentName) {
61
+ function computeSplitsMutation(entries, filters) {
62
+ var segments = new Set();
63
+ var computed = entries.reduce(function (accum, split) {
64
+ if (split.status === 'ACTIVE' && matchFilters(split, filters)) {
65
+ accum.added.push(split);
66
+ parseSegments(split).forEach(function (segmentName) {
68
67
  segments.add(segmentName);
69
68
  });
70
69
  }
71
70
  else {
72
- accum.removed.push(ruleEntity);
71
+ accum.removed.push(split);
73
72
  }
74
73
  return accum;
75
- }, { added: [], removed: [] });
74
+ }, { added: [], removed: [], segments: [] });
75
+ computed.segments = (0, sets_1.setToArray)(segments);
76
+ return computed;
76
77
  }
77
- exports.computeMutation = computeMutation;
78
+ exports.computeSplitsMutation = computeSplitsMutation;
78
79
  /**
79
80
  * factory of SplitChanges updater, a task that:
80
81
  * - fetches split changes using `splitChangesFetcher`
@@ -92,7 +93,7 @@ exports.computeMutation = computeMutation;
92
93
  function splitChangesUpdaterFactory(log, splitChangesFetcher, storage, splitFiltersValidation, splitsEventEmitter, requestTimeoutBeforeReady, retriesOnFailureBeforeReady, isClientSide) {
93
94
  if (requestTimeoutBeforeReady === void 0) { requestTimeoutBeforeReady = 0; }
94
95
  if (retriesOnFailureBeforeReady === void 0) { retriesOnFailureBeforeReady = 0; }
95
- var splits = storage.splits, rbSegments = storage.rbSegments, segments = storage.segments;
96
+ var splits = storage.splits, segments = storage.segments;
96
97
  var startingUp = true;
97
98
  /** timeout decorator for `splitChangesFetcher` promise */
98
99
  function _promiseDecorator(promise) {
@@ -107,48 +108,29 @@ function splitChangesUpdaterFactory(log, splitChangesFetcher, storage, splitFilt
107
108
  * @param noCache - true to revalidate data to fetch
108
109
  * @param till - query param to bypass CDN requests
109
110
  */
110
- return function splitChangesUpdater(noCache, till, instantUpdate) {
111
+ return function splitChangesUpdater(noCache, till, splitUpdateNotification) {
111
112
  /**
112
113
  * @param since - current changeNumber at splitsCache
113
114
  * @param retry - current number of retry attempts
114
115
  */
115
- function _splitChangesUpdater(sinces, retry) {
116
+ function _splitChangesUpdater(since, retry) {
116
117
  if (retry === void 0) { retry = 0; }
117
- var since = sinces[0], rbSince = sinces[1];
118
- log.debug(constants_2.SYNC_SPLITS_FETCH, sinces);
119
- return Promise.resolve(instantUpdate ?
120
- instantUpdate.type === constants_4.SPLIT_UPDATE ?
121
- // IFFU edge case: a change to a flag that adds an IN_RULE_BASED_SEGMENT matcher that is not present yet
122
- Promise.resolve(rbSegments.contains(parseSegments(instantUpdate.payload, constants_3.IN_RULE_BASED_SEGMENT))).then(function (contains) {
123
- return contains ?
124
- { ff: { d: [instantUpdate.payload], t: instantUpdate.changeNumber } } :
125
- splitChangesFetcher(since, noCache, till, rbSince, _promiseDecorator);
126
- }) :
127
- { rbs: { d: [instantUpdate.payload], t: instantUpdate.changeNumber } } :
128
- splitChangesFetcher(since, noCache, till, rbSince, _promiseDecorator))
118
+ log.debug(constants_2.SYNC_SPLITS_FETCH, [since]);
119
+ return Promise.resolve(splitUpdateNotification ?
120
+ { splits: [splitUpdateNotification.payload], till: splitUpdateNotification.changeNumber } :
121
+ splitChangesFetcher(since, noCache, till, _promiseDecorator))
129
122
  .then(function (splitChanges) {
130
123
  startingUp = false;
131
- var usedSegments = new Set();
132
- var ffUpdate = false;
133
- if (splitChanges.ff) {
134
- var _a = computeMutation(splitChanges.ff.d, usedSegments, splitFiltersValidation), added = _a.added, removed = _a.removed;
135
- log.debug(constants_2.SYNC_SPLITS_UPDATE, [added.length, removed.length]);
136
- ffUpdate = splits.update(added, removed, splitChanges.ff.t);
137
- }
138
- var rbsUpdate = false;
139
- if (splitChanges.rbs) {
140
- var _b = computeMutation(splitChanges.rbs.d, usedSegments), added = _b.added, removed = _b.removed;
141
- log.debug(constants_2.SYNC_RBS_UPDATE, [added.length, removed.length]);
142
- rbsUpdate = rbSegments.update(added, removed, splitChanges.rbs.t);
143
- }
144
- return Promise.all([ffUpdate, rbsUpdate,
145
- // @TODO if at least 1 segment fetch fails due to 404 and other segments are updated in the storage, SDK_UPDATE is not emitted
146
- segments.registerSegments((0, sets_1.setToArray)(usedSegments))
124
+ var mutation = computeSplitsMutation(splitChanges.splits, splitFiltersValidation);
125
+ log.debug(constants_2.SYNC_SPLITS_UPDATE, [mutation.added.length, mutation.removed.length, mutation.segments.length]);
126
+ return Promise.all([
127
+ splits.update(mutation.added, mutation.removed, splitChanges.till),
128
+ segments.registerSegments(mutation.segments)
147
129
  ]).then(function (_a) {
148
- var ffChanged = _a[0], rbsChanged = _a[1];
130
+ var isThereUpdate = _a[0];
149
131
  if (splitsEventEmitter) {
150
132
  // To emit SDK_SPLITS_ARRIVED for server-side SDK, we must check that all registered segments have been fetched
151
- return Promise.resolve(!splitsEventEmitter.splitsArrived || ((ffChanged || rbsChanged) && (isClientSide || checkAllSegmentsExist(segments))))
133
+ return Promise.resolve(!splitsEventEmitter.splitsArrived || (since !== splitChanges.till && isThereUpdate && (isClientSide || checkAllSegmentsExist(segments))))
152
134
  .catch(function () { return false; } /** noop. just to handle a possible `checkAllSegmentsExist` rejection, before emitting SDK event */)
153
135
  .then(function (emitSplitsArrivedEvent) {
154
136
  // emit SDK events
@@ -165,7 +147,7 @@ function splitChangesUpdaterFactory(log, splitChangesFetcher, storage, splitFilt
165
147
  if (startingUp && retriesOnFailureBeforeReady > retry) {
166
148
  retry += 1;
167
149
  log.info(constants_2.SYNC_SPLITS_FETCH_RETRY, [retry, error]);
168
- return _splitChangesUpdater(sinces, retry);
150
+ return _splitChangesUpdater(since, retry);
169
151
  }
170
152
  else {
171
153
  startingUp = false;
@@ -173,8 +155,8 @@ function splitChangesUpdaterFactory(log, splitChangesFetcher, storage, splitFilt
173
155
  return false;
174
156
  });
175
157
  }
176
- // `getChangeNumber` never rejects or throws error
177
- return Promise.all([splits.getChangeNumber(), rbSegments.getChangeNumber()]).then(_splitChangesUpdater);
158
+ var sincePromise = Promise.resolve(splits.getChangeNumber()); // `getChangeNumber` never rejects or throws error
159
+ return sincePromise.then(_splitChangesUpdater);
178
160
  };
179
161
  }
180
162
  exports.splitChangesUpdaterFactory = splitChangesUpdaterFactory;
@@ -78,7 +78,6 @@ function SSEHandlerFactory(log, pushEmitter, telemetryTracker) {
78
78
  case constants_1.MEMBERSHIPS_MS_UPDATE:
79
79
  case constants_1.MEMBERSHIPS_LS_UPDATE:
80
80
  case constants_1.SPLIT_KILL:
81
- case constants_1.RB_SEGMENT_UPDATE:
82
81
  pushEmitter.emit(parsedData.type, parsedData);
83
82
  break;
84
83
  /* occupancy & control events, handled by NotificationManagerKeeper */
@@ -1,135 +1,106 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SplitsUpdateWorker = void 0;
4
- var constants_1 = require("../../../logger/constants");
5
- var constants_2 = require("../../../readiness/constants");
4
+ var constants_1 = require("../../../readiness/constants");
6
5
  var Backoff_1 = require("../../../utils/Backoff");
7
- var constants_3 = require("../../../utils/constants");
8
- var constants_4 = require("../constants");
9
- var parseUtils_1 = require("../parseUtils");
10
- var constants_5 = require("./constants");
6
+ var constants_2 = require("../../../utils/constants");
7
+ var constants_3 = require("./constants");
11
8
  /**
12
9
  * SplitsUpdateWorker factory
13
10
  */
14
- function SplitsUpdateWorker(log, storage, splitsSyncTask, splitsEventEmitter, telemetryTracker, segmentsSyncTask) {
15
- var ff = SplitsUpdateWorker(storage.splits);
16
- var rbs = SplitsUpdateWorker(storage.rbSegments);
17
- function SplitsUpdateWorker(cache) {
18
- var maxChangeNumber = -1;
19
- var handleNewEvent = false;
20
- var isHandlingEvent;
21
- var cdnBypass;
22
- var instantUpdate;
23
- var backoff = new Backoff_1.Backoff(__handleSplitUpdateCall, constants_5.FETCH_BACKOFF_BASE, constants_5.FETCH_BACKOFF_MAX_WAIT);
24
- function __handleSplitUpdateCall() {
25
- isHandlingEvent = true;
26
- if (maxChangeNumber > cache.getChangeNumber()) {
27
- handleNewEvent = false;
28
- // fetch splits revalidating data if cached
29
- splitsSyncTask.execute(true, cdnBypass ? maxChangeNumber : undefined, instantUpdate).then(function () {
30
- if (!isHandlingEvent)
31
- return; // halt if `stop` has been called
32
- if (handleNewEvent) {
33
- __handleSplitUpdateCall();
11
+ function SplitsUpdateWorker(log, splitsCache, splitsSyncTask, splitsEventEmitter, telemetryTracker, segmentsSyncTask) {
12
+ var maxChangeNumber = 0;
13
+ var handleNewEvent = false;
14
+ var isHandlingEvent;
15
+ var cdnBypass;
16
+ var payload;
17
+ var backoff = new Backoff_1.Backoff(__handleSplitUpdateCall, constants_3.FETCH_BACKOFF_BASE, constants_3.FETCH_BACKOFF_MAX_WAIT);
18
+ function __handleSplitUpdateCall() {
19
+ isHandlingEvent = true;
20
+ if (maxChangeNumber > splitsCache.getChangeNumber()) {
21
+ handleNewEvent = false;
22
+ var splitUpdateNotification_1 = payload ? { payload: payload, changeNumber: maxChangeNumber } : undefined;
23
+ // fetch splits revalidating data if cached
24
+ splitsSyncTask.execute(true, cdnBypass ? maxChangeNumber : undefined, splitUpdateNotification_1).then(function () {
25
+ if (!isHandlingEvent)
26
+ return; // halt if `stop` has been called
27
+ if (handleNewEvent) {
28
+ __handleSplitUpdateCall();
29
+ }
30
+ else {
31
+ if (splitUpdateNotification_1)
32
+ telemetryTracker.trackUpdatesFromSSE(constants_2.SPLITS);
33
+ // fetch new registered segments for server-side API. Not retrying on error
34
+ if (segmentsSyncTask)
35
+ segmentsSyncTask.execute(true);
36
+ var attempts = backoff.attempts + 1;
37
+ if (maxChangeNumber <= splitsCache.getChangeNumber()) {
38
+ log.debug("Refresh completed" + (cdnBypass ? ' bypassing the CDN' : '') + " in " + attempts + " attempts.");
39
+ isHandlingEvent = false;
40
+ return;
41
+ }
42
+ if (attempts < constants_3.FETCH_BACKOFF_MAX_RETRIES) {
43
+ backoff.scheduleCall();
44
+ return;
45
+ }
46
+ if (cdnBypass) {
47
+ log.debug("No changes fetched after " + attempts + " attempts with CDN bypassed.");
48
+ isHandlingEvent = false;
34
49
  }
35
50
  else {
36
- if (instantUpdate)
37
- telemetryTracker.trackUpdatesFromSSE(constants_3.SPLITS);
38
- // fetch new registered segments for server-side API. Not retrying on error
39
- if (segmentsSyncTask)
40
- segmentsSyncTask.execute(true);
41
- var attempts = backoff.attempts + 1;
42
- if (ff.isSync() && rbs.isSync()) {
43
- log.debug("Refresh completed" + (cdnBypass ? ' bypassing the CDN' : '') + " in " + attempts + " attempts.");
44
- isHandlingEvent = false;
45
- return;
46
- }
47
- if (attempts < constants_5.FETCH_BACKOFF_MAX_RETRIES) {
48
- backoff.scheduleCall();
49
- return;
50
- }
51
- if (cdnBypass) {
52
- log.debug("No changes fetched after " + attempts + " attempts with CDN bypassed.");
53
- isHandlingEvent = false;
54
- }
55
- else {
56
- backoff.reset();
57
- cdnBypass = true;
58
- __handleSplitUpdateCall();
59
- }
51
+ backoff.reset();
52
+ cdnBypass = true;
53
+ __handleSplitUpdateCall();
60
54
  }
61
- });
62
- }
63
- else {
64
- isHandlingEvent = false;
65
- }
66
- }
67
- return {
68
- /**
69
- * Invoked by NotificationProcessor on SPLIT_UPDATE or RB_SEGMENT_UPDATE event
70
- *
71
- * @param changeNumber - change number of the notification
72
- */
73
- put: function (_a, payload) {
74
- var changeNumber = _a.changeNumber, pcn = _a.pcn, type = _a.type;
75
- var currentChangeNumber = cache.getChangeNumber();
76
- if (changeNumber <= currentChangeNumber || changeNumber <= maxChangeNumber)
77
- return;
78
- maxChangeNumber = changeNumber;
79
- handleNewEvent = true;
80
- cdnBypass = false;
81
- instantUpdate = undefined;
82
- if (payload && currentChangeNumber === pcn) {
83
- instantUpdate = { payload: payload, changeNumber: changeNumber, type: type };
84
55
  }
85
- if (backoff.timeoutID || !isHandlingEvent)
86
- __handleSplitUpdateCall();
87
- backoff.reset();
88
- },
89
- stop: function () {
90
- isHandlingEvent = false;
91
- backoff.reset();
92
- },
93
- isSync: function () {
94
- return maxChangeNumber <= cache.getChangeNumber();
95
- }
96
- };
56
+ });
57
+ }
58
+ else {
59
+ isHandlingEvent = false;
60
+ }
61
+ }
62
+ /**
63
+ * Invoked by NotificationProcessor on SPLIT_UPDATE event
64
+ *
65
+ * @param changeNumber - change number of the SPLIT_UPDATE notification
66
+ */
67
+ function put(_a, _payload) {
68
+ var changeNumber = _a.changeNumber, pcn = _a.pcn;
69
+ var currentChangeNumber = splitsCache.getChangeNumber();
70
+ if (changeNumber <= currentChangeNumber || changeNumber <= maxChangeNumber)
71
+ return;
72
+ maxChangeNumber = changeNumber;
73
+ handleNewEvent = true;
74
+ cdnBypass = false;
75
+ payload = undefined;
76
+ if (_payload && currentChangeNumber === pcn) {
77
+ payload = _payload;
78
+ }
79
+ if (backoff.timeoutID || !isHandlingEvent)
80
+ __handleSplitUpdateCall();
81
+ backoff.reset();
97
82
  }
98
83
  return {
99
- put: function (parsedData) {
100
- if (parsedData.d && parsedData.c !== undefined) {
101
- try {
102
- var payload = (0, parseUtils_1.parseFFUpdatePayload)(parsedData.c, parsedData.d);
103
- if (payload) {
104
- (parsedData.type === constants_4.RB_SEGMENT_UPDATE ? rbs : ff).put(parsedData, payload);
105
- return;
106
- }
107
- }
108
- catch (e) {
109
- log.warn(constants_1.STREAMING_PARSING_SPLIT_UPDATE, [parsedData.type, e]);
110
- }
111
- }
112
- (parsedData.type === constants_4.RB_SEGMENT_UPDATE ? rbs : ff).put(parsedData);
113
- },
84
+ put: put,
114
85
  /**
115
86
  * Invoked by NotificationProcessor on SPLIT_KILL event
116
87
  *
117
- * @param changeNumber - change number of the notification
88
+ * @param changeNumber - change number of the SPLIT_UPDATE notification
118
89
  * @param splitName - name of split to kill
119
90
  * @param defaultTreatment - default treatment value
120
91
  */
121
92
  killSplit: function (_a) {
122
93
  var changeNumber = _a.changeNumber, splitName = _a.splitName, defaultTreatment = _a.defaultTreatment;
123
- if (storage.splits.killLocally(splitName, defaultTreatment, changeNumber)) {
94
+ if (splitsCache.killLocally(splitName, defaultTreatment, changeNumber)) {
124
95
  // trigger an SDK_UPDATE if Split was killed locally
125
- splitsEventEmitter.emit(constants_2.SDK_SPLITS_ARRIVED, true);
96
+ splitsEventEmitter.emit(constants_1.SDK_SPLITS_ARRIVED, true);
126
97
  }
127
98
  // queues the SplitChanges fetch (only if changeNumber is newer)
128
- ff.put({ changeNumber: changeNumber });
99
+ put({ changeNumber: changeNumber });
129
100
  },
130
101
  stop: function () {
131
- ff.stop();
132
- rbs.stop();
102
+ isHandlingEvent = false;
103
+ backoff.reset();
133
104
  }
134
105
  };
135
106
  }
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ControlType = exports.OCCUPANCY = exports.CONTROL = exports.RB_SEGMENT_UPDATE = exports.SPLIT_UPDATE = exports.SPLIT_KILL = exports.SEGMENT_UPDATE = exports.MEMBERSHIPS_LS_UPDATE = exports.MEMBERSHIPS_MS_UPDATE = exports.PUSH_SUBSYSTEM_DOWN = exports.PUSH_SUBSYSTEM_UP = exports.PUSH_RETRYABLE_ERROR = exports.PUSH_NONRETRYABLE_ERROR = exports.SECONDS_BEFORE_EXPIRATION = void 0;
3
+ exports.ControlType = exports.OCCUPANCY = exports.CONTROL = exports.SPLIT_UPDATE = exports.SPLIT_KILL = exports.SEGMENT_UPDATE = exports.MEMBERSHIPS_LS_UPDATE = exports.MEMBERSHIPS_MS_UPDATE = exports.PUSH_SUBSYSTEM_DOWN = exports.PUSH_SUBSYSTEM_UP = exports.PUSH_RETRYABLE_ERROR = exports.PUSH_NONRETRYABLE_ERROR = exports.SECONDS_BEFORE_EXPIRATION = void 0;
4
4
  // time for refresh token
5
5
  exports.SECONDS_BEFORE_EXPIRATION = 600;
6
6
  // Internal SDK events, subscribed by SyncManager and PushManager
@@ -30,7 +30,6 @@ exports.MEMBERSHIPS_LS_UPDATE = 'MEMBERSHIPS_LS_UPDATE';
30
30
  exports.SEGMENT_UPDATE = 'SEGMENT_UPDATE';
31
31
  exports.SPLIT_KILL = 'SPLIT_KILL';
32
32
  exports.SPLIT_UPDATE = 'SPLIT_UPDATE';
33
- exports.RB_SEGMENT_UPDATE = 'RB_SEGMENT_UPDATE';
34
33
  // Control-type push notifications, handled by NotificationKeeper
35
34
  exports.CONTROL = 'CONTROL';
36
35
  exports.OCCUPANCY = 'OCCUPANCY';
@@ -46,7 +46,7 @@ function pushManagerFactory(params, pollingManager) {
46
46
  // MySegmentsUpdateWorker (client-side) are initiated in `add` method
47
47
  var segmentsUpdateWorker = userKey ? undefined : (0, SegmentsUpdateWorker_1.SegmentsUpdateWorker)(log, pollingManager.segmentsSyncTask, storage.segments);
48
48
  // For server-side we pass the segmentsSyncTask, used by SplitsUpdateWorker to fetch new segments
49
- var splitsUpdateWorker = (0, SplitsUpdateWorker_1.SplitsUpdateWorker)(log, storage, pollingManager.splitsSyncTask, readiness.splits, telemetryTracker, userKey ? undefined : pollingManager.segmentsSyncTask);
49
+ var splitsUpdateWorker = (0, SplitsUpdateWorker_1.SplitsUpdateWorker)(log, storage.splits, pollingManager.splitsSyncTask, readiness.splits, telemetryTracker, userKey ? undefined : pollingManager.segmentsSyncTask);
50
50
  // [Only for client-side] map of hashes to user keys, to dispatch membership update events to the corresponding MySegmentsUpdateWorker
51
51
  var userKeyHashes = {};
52
52
  // [Only for client-side] map of user keys to their corresponding hash64 and MySegmentsUpdateWorkers.
@@ -182,8 +182,21 @@ function pushManagerFactory(params, pollingManager) {
182
182
  });
183
183
  /** Functions related to synchronization (Queues and Workers in the spec) */
184
184
  pushEmitter.on(constants_1.SPLIT_KILL, splitsUpdateWorker.killSplit);
185
- pushEmitter.on(constants_1.SPLIT_UPDATE, splitsUpdateWorker.put);
186
- pushEmitter.on(constants_1.RB_SEGMENT_UPDATE, splitsUpdateWorker.put);
185
+ pushEmitter.on(constants_1.SPLIT_UPDATE, function (parsedData) {
186
+ if (parsedData.d && parsedData.c !== undefined) {
187
+ try {
188
+ var payload = (0, parseUtils_1.parseFFUpdatePayload)(parsedData.c, parsedData.d);
189
+ if (payload) {
190
+ splitsUpdateWorker.put(parsedData, payload);
191
+ return;
192
+ }
193
+ }
194
+ catch (e) {
195
+ log.warn(constants_2.STREAMING_PARSING_SPLIT_UPDATE, [e]);
196
+ }
197
+ }
198
+ splitsUpdateWorker.put(parsedData);
199
+ });
187
200
  function handleMySegmentsUpdate(parsedData) {
188
201
  switch (parsedData.u) {
189
202
  case types_1.UpdateStrategy.BoundedFetchRequest: {
@@ -130,7 +130,7 @@ function syncManagerOnlineFactory(pollingManagerFactory, pushManagerFactory) {
130
130
  if (pushManager) {
131
131
  if (pollingManager.isRunning()) {
132
132
  // if doing polling, we must start the periodic fetch of data
133
- if (storage.splits.usesSegments() || storage.rbSegments.usesSegments())
133
+ if (storage.splits.usesSegments())
134
134
  mySegmentsSyncTask.start();
135
135
  }
136
136
  else {
@@ -140,7 +140,7 @@ function syncManagerOnlineFactory(pollingManagerFactory, pushManagerFactory) {
140
140
  }
141
141
  }
142
142
  else {
143
- if (storage.splits.usesSegments() || storage.rbSegments.usesSegments())
143
+ if (storage.splits.usesSegments())
144
144
  mySegmentsSyncTask.start();
145
145
  }
146
146
  }
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.MEMBERSHIPS = exports.SEGMENT = exports.TOKEN = exports.TELEMETRY = exports.EVENTS = exports.IMPRESSIONS_COUNT = exports.IMPRESSIONS = exports.SPLITS = exports.NONE_ENUM = exports.DEBUG_ENUM = exports.OPTIMIZED_ENUM = exports.CONSUMER_PARTIAL_ENUM = exports.CONSUMER_ENUM = exports.STANDALONE_ENUM = exports.DEDUPED = exports.DROPPED = exports.QUEUED = exports.NAMES_FN_LABEL = exports.SPLITS_FN_LABEL = exports.SPLIT_FN_LABEL = exports.TRACK_FN_LABEL = exports.GET_TREATMENTS_WITH_CONFIG_BY_FLAG_SETS = exports.GET_TREATMENTS_WITH_CONFIG_BY_FLAG_SET = exports.GET_TREATMENTS_BY_FLAG_SETS = exports.GET_TREATMENTS_BY_FLAG_SET = exports.GET_TREATMENTS_WITH_CONFIG = exports.GET_TREATMENT_WITH_CONFIG = exports.GET_TREATMENTS = exports.GET_TREATMENT = exports.CONSENT_UNKNOWN = exports.CONSENT_DECLINED = exports.CONSENT_GRANTED = exports.STORAGE_PLUGGABLE = exports.STORAGE_REDIS = exports.STORAGE_LOCALSTORAGE = exports.STORAGE_MEMORY = exports.CONSUMER_PARTIAL_MODE = exports.CONSUMER_MODE = exports.PRODUCER_MODE = exports.STANDALONE_MODE = exports.LOCALHOST_MODE = exports.NONE = exports.OPTIMIZED = exports.DEBUG = exports.SPLIT_EVENT = exports.SPLIT_IMPRESSION = exports.NA = exports.UNKNOWN = exports.CONTROL_WITH_CONFIG = exports.CONTROL = void 0;
4
- exports.IN_RULE_BASED_SEGMENT = exports.IN_LARGE_SEGMENT = exports.IN_SEGMENT = exports.FLAG_SPEC_VERSION = exports.PAUSED = exports.ENABLED = exports.DISABLED = exports.NON_REQUESTED = exports.REQUESTED = exports.POLLING = exports.STREAMING = exports.AUTH_REJECTION = exports.SYNC_MODE_UPDATE = exports.ABLY_ERROR = exports.TOKEN_REFRESH = exports.SSE_CONNECTION_ERROR = exports.STREAMING_STATUS = exports.OCCUPANCY_SEC = exports.OCCUPANCY_PRI = exports.CONNECTION_ESTABLISHED = exports.TRACK = exports.TREATMENTS_WITH_CONFIG_BY_FLAGSETS = exports.TREATMENTS_WITH_CONFIG_BY_FLAGSET = exports.TREATMENTS_BY_FLAGSETS = exports.TREATMENTS_BY_FLAGSET = exports.TREATMENTS_WITH_CONFIG = exports.TREATMENT_WITH_CONFIG = exports.TREATMENTS = exports.TREATMENT = void 0;
4
+ exports.IN_LARGE_SEGMENT = exports.IN_SEGMENT = exports.FLAG_SPEC_VERSION = exports.PAUSED = exports.ENABLED = exports.DISABLED = exports.NON_REQUESTED = exports.REQUESTED = exports.POLLING = exports.STREAMING = exports.AUTH_REJECTION = exports.SYNC_MODE_UPDATE = exports.ABLY_ERROR = exports.TOKEN_REFRESH = exports.SSE_CONNECTION_ERROR = exports.STREAMING_STATUS = exports.OCCUPANCY_SEC = exports.OCCUPANCY_PRI = exports.CONNECTION_ESTABLISHED = exports.TRACK = exports.TREATMENTS_WITH_CONFIG_BY_FLAGSETS = exports.TREATMENTS_WITH_CONFIG_BY_FLAGSET = exports.TREATMENTS_BY_FLAGSETS = exports.TREATMENTS_BY_FLAGSET = exports.TREATMENTS_WITH_CONFIG = exports.TREATMENT_WITH_CONFIG = exports.TREATMENTS = exports.TREATMENT = void 0;
5
5
  // Special treatments
6
6
  exports.CONTROL = 'control';
7
7
  exports.CONTROL_WITH_CONFIG = {
@@ -90,8 +90,7 @@ exports.NON_REQUESTED = 1;
90
90
  exports.DISABLED = 0;
91
91
  exports.ENABLED = 1;
92
92
  exports.PAUSED = 2;
93
- exports.FLAG_SPEC_VERSION = '1.3';
93
+ exports.FLAG_SPEC_VERSION = '1.2';
94
94
  // Matcher types
95
95
  exports.IN_SEGMENT = 'IN_SEGMENT';
96
96
  exports.IN_LARGE_SEGMENT = 'IN_LARGE_SEGMENT';
97
- exports.IN_RULE_BASED_SEGMENT = 'IN_RULE_BASED_SEGMENT';
@@ -8,8 +8,12 @@ export function andCombinerContext(log, matchers) {
8
8
  log.debug(ENGINE_COMBINER_AND, [hasMatchedAll]);
9
9
  return hasMatchedAll;
10
10
  }
11
- return function andCombiner(key, attributes, splitEvaluator) {
12
- var matcherResults = matchers.map(function (matcher) { return matcher(key, attributes, splitEvaluator); });
11
+ return function andCombiner() {
12
+ var params = [];
13
+ for (var _i = 0; _i < arguments.length; _i++) {
14
+ params[_i] = arguments[_i];
15
+ }
16
+ var matcherResults = matchers.map(function (matcher) { return matcher.apply(void 0, params); });
13
17
  // If any matching result is a thenable we should use Promise.all
14
18
  if (findIndex(matcherResults, thenable) !== -1) {
15
19
  return Promise.all(matcherResults).then(andResults);