@splitsoftware/splitio-commons 2.2.1-rc.0 → 2.2.1-rc.2
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.
- package/CHANGES.txt +2 -3
- package/README.md +0 -1
- package/cjs/evaluator/Engine.js +61 -40
- package/cjs/evaluator/combiners/and.js +6 -2
- package/cjs/evaluator/combiners/ifelseif.js +6 -6
- package/cjs/evaluator/condition/index.js +5 -6
- package/cjs/evaluator/index.js +11 -11
- package/cjs/evaluator/matchers/index.js +1 -3
- package/cjs/evaluator/matchers/matcherTypes.js +0 -1
- package/cjs/evaluator/matchersTransform/index.js +0 -4
- package/cjs/evaluator/parser/index.js +2 -2
- package/cjs/evaluator/value/sanitize.js +0 -1
- package/cjs/logger/constants.js +3 -5
- package/cjs/logger/messages/debug.js +2 -4
- package/cjs/logger/messages/warn.js +1 -1
- package/cjs/sdkManager/index.js +1 -2
- package/cjs/services/splitApi.js +4 -3
- package/cjs/storages/AbstractSplitsCacheSync.js +2 -5
- package/cjs/storages/KeyBuilder.js +0 -9
- package/cjs/storages/KeyBuilderCS.js +0 -3
- package/cjs/storages/KeyBuilderSS.js +0 -3
- package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +14 -9
- package/cjs/storages/inLocalStorage/index.js +1 -5
- package/cjs/storages/inLocalStorage/validateCache.js +1 -2
- package/cjs/storages/inMemory/InMemoryStorage.js +0 -3
- package/cjs/storages/inMemory/InMemoryStorageCS.js +0 -4
- package/cjs/storages/inRedis/index.js +9 -5
- package/cjs/storages/pluggable/index.js +0 -2
- package/cjs/sync/polling/fetchers/splitChangesFetcher.js +4 -51
- package/cjs/sync/polling/pollingManagerCS.js +7 -7
- package/cjs/sync/polling/syncTasks/splitsSyncTask.js +1 -1
- package/cjs/sync/polling/updaters/mySegmentsUpdater.js +2 -2
- package/cjs/sync/polling/updaters/segmentChangesUpdater.js +1 -1
- package/cjs/sync/polling/updaters/splitChangesUpdater.js +33 -51
- package/cjs/sync/streaming/SSEHandler/index.js +0 -1
- package/cjs/sync/streaming/UpdateWorkers/SplitsUpdateWorker.js +77 -106
- package/cjs/sync/streaming/constants.js +1 -2
- package/cjs/sync/streaming/pushManager.js +16 -3
- package/cjs/sync/syncManagerOnline.js +2 -2
- package/cjs/utils/constants/index.js +2 -3
- package/cjs/utils/labels/index.js +1 -2
- package/esm/evaluator/Engine.js +62 -40
- package/esm/evaluator/combiners/and.js +6 -2
- package/esm/evaluator/combiners/ifelseif.js +7 -7
- package/esm/evaluator/condition/index.js +5 -6
- package/esm/evaluator/index.js +12 -12
- package/esm/evaluator/matchers/index.js +1 -3
- package/esm/evaluator/matchers/matcherTypes.js +0 -1
- package/esm/evaluator/matchersTransform/index.js +0 -4
- package/esm/evaluator/parser/index.js +2 -2
- package/esm/evaluator/value/sanitize.js +0 -1
- package/esm/logger/constants.js +0 -2
- package/esm/logger/messages/debug.js +2 -4
- package/esm/logger/messages/warn.js +1 -1
- package/esm/sdkManager/index.js +1 -2
- package/esm/services/splitApi.js +4 -3
- package/esm/storages/AbstractSplitsCacheSync.js +2 -5
- package/esm/storages/KeyBuilder.js +0 -9
- package/esm/storages/KeyBuilderCS.js +0 -3
- package/esm/storages/KeyBuilderSS.js +0 -3
- package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +14 -9
- package/esm/storages/inLocalStorage/index.js +1 -5
- package/esm/storages/inLocalStorage/validateCache.js +1 -2
- package/esm/storages/inMemory/InMemoryStorage.js +0 -3
- package/esm/storages/inMemory/InMemoryStorageCS.js +0 -4
- package/esm/storages/inRedis/index.js +9 -5
- package/esm/storages/pluggable/index.js +0 -2
- package/esm/sync/polling/fetchers/splitChangesFetcher.js +4 -51
- package/esm/sync/polling/pollingManagerCS.js +7 -7
- package/esm/sync/polling/syncTasks/splitsSyncTask.js +1 -1
- package/esm/sync/polling/updaters/mySegmentsUpdater.js +2 -2
- package/esm/sync/polling/updaters/segmentChangesUpdater.js +1 -1
- package/esm/sync/polling/updaters/splitChangesUpdater.js +33 -51
- package/esm/sync/streaming/SSEHandler/index.js +1 -2
- package/esm/sync/streaming/UpdateWorkers/SplitsUpdateWorker.js +73 -102
- package/esm/sync/streaming/constants.js +0 -1
- package/esm/sync/streaming/pushManager.js +19 -6
- package/esm/sync/syncManagerOnline.js +2 -2
- package/esm/utils/constants/index.js +1 -2
- package/esm/utils/labels/index.js +0 -1
- package/package.json +1 -1
- package/src/dtos/types.ts +8 -36
- package/src/evaluator/Engine.ts +69 -42
- package/src/evaluator/combiners/and.ts +4 -5
- package/src/evaluator/combiners/ifelseif.ts +9 -7
- package/src/evaluator/condition/engineUtils.ts +1 -1
- package/src/evaluator/condition/index.ts +12 -12
- package/src/evaluator/index.ts +14 -12
- package/src/evaluator/matchers/index.ts +1 -3
- package/src/evaluator/matchers/matcherTypes.ts +0 -1
- package/src/evaluator/matchersTransform/index.ts +0 -3
- package/src/evaluator/parser/index.ts +3 -3
- package/src/evaluator/types.ts +2 -2
- package/src/evaluator/value/index.ts +2 -2
- package/src/evaluator/value/sanitize.ts +4 -5
- package/src/logger/constants.ts +0 -2
- package/src/logger/messages/debug.ts +2 -4
- package/src/logger/messages/warn.ts +1 -1
- package/src/sdkManager/index.ts +2 -3
- package/src/services/splitApi.ts +4 -3
- package/src/services/types.ts +1 -1
- package/src/storages/AbstractSplitsCacheSync.ts +3 -6
- package/src/storages/KeyBuilder.ts +0 -12
- package/src/storages/KeyBuilderCS.ts +0 -4
- package/src/storages/KeyBuilderSS.ts +0 -4
- package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +14 -10
- package/src/storages/inLocalStorage/index.ts +1 -5
- package/src/storages/inLocalStorage/validateCache.ts +1 -3
- package/src/storages/inMemory/InMemoryStorage.ts +0 -3
- package/src/storages/inMemory/InMemoryStorageCS.ts +0 -4
- package/src/storages/inRedis/index.ts +11 -7
- package/src/storages/pluggable/index.ts +0 -2
- package/src/storages/types.ts +1 -33
- package/src/sync/polling/fetchers/splitChangesFetcher.ts +4 -62
- package/src/sync/polling/fetchers/types.ts +0 -1
- package/src/sync/polling/pollingManagerCS.ts +7 -7
- package/src/sync/polling/syncTasks/splitsSyncTask.ts +1 -1
- package/src/sync/polling/types.ts +2 -2
- package/src/sync/polling/updaters/mySegmentsUpdater.ts +2 -2
- package/src/sync/polling/updaters/segmentChangesUpdater.ts +1 -1
- package/src/sync/polling/updaters/splitChangesUpdater.ts +42 -61
- package/src/sync/streaming/SSEHandler/index.ts +1 -2
- package/src/sync/streaming/SSEHandler/types.ts +2 -2
- package/src/sync/streaming/UpdateWorkers/SplitsUpdateWorker.ts +68 -98
- package/src/sync/streaming/constants.ts +0 -1
- package/src/sync/streaming/parseUtils.ts +2 -2
- package/src/sync/streaming/pushManager.ts +18 -6
- package/src/sync/streaming/types.ts +2 -3
- package/src/sync/syncManagerOnline.ts +2 -2
- package/src/utils/constants/index.ts +1 -2
- package/src/utils/labels/index.ts +0 -1
- package/src/utils/lang/index.ts +1 -1
- package/types/splitio.d.ts +1 -5
- package/cjs/evaluator/matchers/prerequisites.js +0 -22
- package/cjs/evaluator/matchers/rbsegment.js +0 -44
- package/cjs/storages/inLocalStorage/RBSegmentsCacheInLocal.js +0 -117
- package/cjs/storages/inMemory/RBSegmentsCacheInMemory.js +0 -61
- package/cjs/storages/inRedis/RBSegmentsCacheInRedis.js +0 -64
- package/cjs/storages/pluggable/RBSegmentsCachePluggable.js +0 -64
- package/esm/evaluator/matchers/prerequisites.js +0 -18
- package/esm/evaluator/matchers/rbsegment.js +0 -40
- package/esm/storages/inLocalStorage/RBSegmentsCacheInLocal.js +0 -114
- package/esm/storages/inMemory/RBSegmentsCacheInMemory.js +0 -58
- package/esm/storages/inRedis/RBSegmentsCacheInRedis.js +0 -61
- package/esm/storages/pluggable/RBSegmentsCachePluggable.js +0 -61
- package/src/evaluator/matchers/prerequisites.ts +0 -24
- package/src/evaluator/matchers/rbsegment.ts +0 -62
- package/src/storages/inLocalStorage/RBSegmentsCacheInLocal.ts +0 -136
- package/src/storages/inMemory/RBSegmentsCacheInMemory.ts +0 -68
- package/src/storages/inRedis/RBSegmentsCacheInRedis.ts +0 -79
- package/src/storages/pluggable/RBSegmentsCachePluggable.ts +0 -76
|
@@ -7,14 +7,14 @@ import SplitIO from '../../../types/splitio';
|
|
|
7
7
|
import { ILogger } from '../../logger/types';
|
|
8
8
|
|
|
9
9
|
// Build Evaluation object if and only if matchingResult is true
|
|
10
|
-
function match(log: ILogger, matchingResult: boolean, bucketingKey: string | undefined, seed
|
|
10
|
+
function match(log: ILogger, matchingResult: boolean, bucketingKey: string | undefined, seed: number, treatments: { getTreatmentFor: (x: number) => string }, label: string): IEvaluation | undefined {
|
|
11
11
|
if (matchingResult) {
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
12
|
+
const treatment = getTreatment(log, bucketingKey as string, seed, treatments);
|
|
13
|
+
|
|
14
|
+
return {
|
|
15
|
+
treatment,
|
|
16
|
+
label
|
|
17
|
+
};
|
|
18
18
|
}
|
|
19
19
|
|
|
20
20
|
// else we should notify the engine to continue evaluating
|
|
@@ -22,12 +22,12 @@ function match(log: ILogger, matchingResult: boolean, bucketingKey: string | und
|
|
|
22
22
|
}
|
|
23
23
|
|
|
24
24
|
// Condition factory
|
|
25
|
-
export function conditionContext(log: ILogger, matcherEvaluator: (
|
|
25
|
+
export function conditionContext(log: ILogger, matcherEvaluator: (...args: any) => MaybeThenable<boolean>, treatments: { getTreatmentFor: (x: number) => string }, label: string, conditionType: 'ROLLOUT' | 'WHITELIST'): IEvaluator {
|
|
26
26
|
|
|
27
|
-
return function conditionEvaluator(key: SplitIO.
|
|
27
|
+
return function conditionEvaluator(key: SplitIO.SplitKey, seed: number, trafficAllocation?: number, trafficAllocationSeed?: number, attributes?: SplitIO.Attributes, splitEvaluator?: ISplitEvaluator) {
|
|
28
28
|
|
|
29
29
|
// Whitelisting has more priority than traffic allocation, so we don't apply this filtering to those conditions.
|
|
30
|
-
if (conditionType === 'ROLLOUT' && !shouldApplyRollout(trafficAllocation
|
|
30
|
+
if (conditionType === 'ROLLOUT' && !shouldApplyRollout(trafficAllocation as number, (key as SplitIO.SplitKeyObject).bucketingKey as string, trafficAllocationSeed as number)) {
|
|
31
31
|
return {
|
|
32
32
|
treatment: undefined, // treatment value is assigned later
|
|
33
33
|
label: NOT_IN_SPLIT
|
|
@@ -41,10 +41,10 @@ export function conditionContext(log: ILogger, matcherEvaluator: (key: SplitIO.S
|
|
|
41
41
|
const matches = matcherEvaluator(key, attributes, splitEvaluator);
|
|
42
42
|
|
|
43
43
|
if (thenable(matches)) {
|
|
44
|
-
return matches.then(result => match(log, result, key.bucketingKey, seed, treatments, label));
|
|
44
|
+
return matches.then(result => match(log, result, (key as SplitIO.SplitKeyObject).bucketingKey, seed, treatments, label));
|
|
45
45
|
}
|
|
46
46
|
|
|
47
|
-
return match(log, matches, key.bucketingKey, seed, treatments, label);
|
|
47
|
+
return match(log, matches, (key as SplitIO.SplitKeyObject).bucketingKey, seed, treatments, label);
|
|
48
48
|
};
|
|
49
49
|
|
|
50
50
|
}
|
package/src/evaluator/index.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Engine } from './Engine';
|
|
2
2
|
import { thenable } from '../utils/promise/thenable';
|
|
3
3
|
import { EXCEPTION, SPLIT_NOT_FOUND } from '../utils/labels';
|
|
4
4
|
import { CONTROL } from '../utils/constants';
|
|
@@ -43,8 +43,8 @@ export function evaluateFeature(
|
|
|
43
43
|
if (thenable(parsedSplit)) {
|
|
44
44
|
return parsedSplit.then((split) => getEvaluation(
|
|
45
45
|
log,
|
|
46
|
-
key,
|
|
47
46
|
split,
|
|
47
|
+
key,
|
|
48
48
|
attributes,
|
|
49
49
|
storage,
|
|
50
50
|
)).catch(
|
|
@@ -56,8 +56,8 @@ export function evaluateFeature(
|
|
|
56
56
|
|
|
57
57
|
return getEvaluation(
|
|
58
58
|
log,
|
|
59
|
-
key,
|
|
60
59
|
parsedSplit,
|
|
60
|
+
key,
|
|
61
61
|
attributes,
|
|
62
62
|
storage,
|
|
63
63
|
);
|
|
@@ -80,13 +80,13 @@ export function evaluateFeatures(
|
|
|
80
80
|
}
|
|
81
81
|
|
|
82
82
|
return thenable(parsedSplits) ?
|
|
83
|
-
parsedSplits.then(splits => getEvaluations(log,
|
|
83
|
+
parsedSplits.then(splits => getEvaluations(log, splitNames, splits, key, attributes, storage))
|
|
84
84
|
.catch(() => {
|
|
85
85
|
// Exception on async `getSplits` storage. For example, when the storage is redis or
|
|
86
86
|
// pluggable and there is a connection issue and we can't retrieve the split to be evaluated
|
|
87
87
|
return treatmentsException(splitNames);
|
|
88
88
|
}) :
|
|
89
|
-
getEvaluations(log,
|
|
89
|
+
getEvaluations(log, splitNames, parsedSplits, key, attributes, storage);
|
|
90
90
|
}
|
|
91
91
|
|
|
92
92
|
export function evaluateFeaturesByFlagSets(
|
|
@@ -99,7 +99,9 @@ export function evaluateFeaturesByFlagSets(
|
|
|
99
99
|
): MaybeThenable<Record<string, IEvaluationResult>> {
|
|
100
100
|
let storedFlagNames: MaybeThenable<Set<string>[]>;
|
|
101
101
|
|
|
102
|
-
function evaluate(
|
|
102
|
+
function evaluate(
|
|
103
|
+
featureFlagsByFlagSets: Set<string>[],
|
|
104
|
+
) {
|
|
103
105
|
let featureFlags = new Set<string>();
|
|
104
106
|
for (let i = 0; i < flagSets.length; i++) {
|
|
105
107
|
const featureFlagByFlagSet = featureFlagsByFlagSets[i];
|
|
@@ -134,8 +136,8 @@ export function evaluateFeaturesByFlagSets(
|
|
|
134
136
|
|
|
135
137
|
function getEvaluation(
|
|
136
138
|
log: ILogger,
|
|
137
|
-
key: SplitIO.SplitKey,
|
|
138
139
|
splitJSON: ISplit | null,
|
|
140
|
+
key: SplitIO.SplitKey,
|
|
139
141
|
attributes: SplitIO.Attributes | undefined,
|
|
140
142
|
storage: IStorageSync | IStorageAsync,
|
|
141
143
|
): MaybeThenable<IEvaluationResult> {
|
|
@@ -146,20 +148,20 @@ function getEvaluation(
|
|
|
146
148
|
};
|
|
147
149
|
|
|
148
150
|
if (splitJSON) {
|
|
149
|
-
const split =
|
|
151
|
+
const split = Engine.parse(log, splitJSON, storage);
|
|
150
152
|
evaluation = split.getTreatment(key, attributes, evaluateFeature);
|
|
151
153
|
|
|
152
154
|
// If the storage is async and the evaluated flag uses segments or dependencies, evaluation is thenable
|
|
153
155
|
if (thenable(evaluation)) {
|
|
154
156
|
return evaluation.then(result => {
|
|
155
|
-
result.changeNumber =
|
|
157
|
+
result.changeNumber = split.getChangeNumber();
|
|
156
158
|
result.config = splitJSON.configurations && splitJSON.configurations[result.treatment] || null;
|
|
157
159
|
result.impressionsDisabled = splitJSON.impressionsDisabled;
|
|
158
160
|
|
|
159
161
|
return result;
|
|
160
162
|
});
|
|
161
163
|
} else {
|
|
162
|
-
evaluation.changeNumber =
|
|
164
|
+
evaluation.changeNumber = split.getChangeNumber(); // Always sync and optional
|
|
163
165
|
evaluation.config = splitJSON.configurations && splitJSON.configurations[evaluation.treatment] || null;
|
|
164
166
|
evaluation.impressionsDisabled = splitJSON.impressionsDisabled;
|
|
165
167
|
}
|
|
@@ -170,9 +172,9 @@ function getEvaluation(
|
|
|
170
172
|
|
|
171
173
|
function getEvaluations(
|
|
172
174
|
log: ILogger,
|
|
173
|
-
key: SplitIO.SplitKey,
|
|
174
175
|
splitNames: string[],
|
|
175
176
|
splits: Record<string, ISplit | null>,
|
|
177
|
+
key: SplitIO.SplitKey,
|
|
176
178
|
attributes: SplitIO.Attributes | undefined,
|
|
177
179
|
storage: IStorageSync | IStorageAsync,
|
|
178
180
|
): MaybeThenable<Record<string, IEvaluationResult>> {
|
|
@@ -181,8 +183,8 @@ function getEvaluations(
|
|
|
181
183
|
splitNames.forEach(splitName => {
|
|
182
184
|
const evaluation = getEvaluation(
|
|
183
185
|
log,
|
|
184
|
-
key,
|
|
185
186
|
splits[splitName],
|
|
187
|
+
key,
|
|
186
188
|
attributes,
|
|
187
189
|
storage
|
|
188
190
|
);
|
|
@@ -24,7 +24,6 @@ import { inListSemverMatcherContext } from './semver_inlist';
|
|
|
24
24
|
import { IStorageAsync, IStorageSync } from '../../storages/types';
|
|
25
25
|
import { IMatcher, IMatcherDto } from '../types';
|
|
26
26
|
import { ILogger } from '../../logger/types';
|
|
27
|
-
import { ruleBasedSegmentMatcherContext } from './rbsegment';
|
|
28
27
|
|
|
29
28
|
const matchers = [
|
|
30
29
|
undefined, // UNDEFINED: 0
|
|
@@ -51,7 +50,6 @@ const matchers = [
|
|
|
51
50
|
betweenSemverMatcherContext, // BETWEEN_SEMVER: 21
|
|
52
51
|
inListSemverMatcherContext, // IN_LIST_SEMVER: 22
|
|
53
52
|
largeSegmentMatcherContext, // IN_LARGE_SEGMENT: 23
|
|
54
|
-
ruleBasedSegmentMatcherContext // IN_RULE_BASED_SEGMENT: 24
|
|
55
53
|
];
|
|
56
54
|
|
|
57
55
|
/**
|
|
@@ -66,5 +64,5 @@ export function matcherFactory(log: ILogger, matcherDto: IMatcherDto, storage?:
|
|
|
66
64
|
let matcherFn;
|
|
67
65
|
// @ts-ignore
|
|
68
66
|
if (matchers[type]) matcherFn = matchers[type](value, storage, log); // There is no index-out-of-bound exception in JavaScript
|
|
69
|
-
return matcherFn
|
|
67
|
+
return matcherFn;
|
|
70
68
|
}
|
|
@@ -95,9 +95,6 @@ export function matchersTransform(matchers: ISplitMatcher[]): IMatcherDto[] {
|
|
|
95
95
|
type === matcherTypes.LESS_THAN_OR_EQUAL_TO_SEMVER
|
|
96
96
|
) {
|
|
97
97
|
value = stringMatcherData;
|
|
98
|
-
} else if (type === matcherTypes.IN_RULE_BASED_SEGMENT) {
|
|
99
|
-
value = segmentTransform(userDefinedSegmentMatcherData as IInSegmentMatcherData);
|
|
100
|
-
dataType = matcherDataTypes.NOT_SPECIFIED;
|
|
101
98
|
}
|
|
102
99
|
|
|
103
100
|
return {
|
|
@@ -37,7 +37,7 @@ export function parser(log: ILogger, conditions: ISplitCondition[], storage: ISt
|
|
|
37
37
|
}
|
|
38
38
|
|
|
39
39
|
// Evaluator function.
|
|
40
|
-
return (key:
|
|
40
|
+
return (key: string, attributes: SplitIO.Attributes | undefined, splitEvaluator: ISplitEvaluator) => {
|
|
41
41
|
const value = sanitizeValue(log, key, matcherDto, attributes);
|
|
42
42
|
let result: MaybeThenable<boolean> = false;
|
|
43
43
|
|
|
@@ -71,12 +71,12 @@ export function parser(log: ILogger, conditions: ISplitCondition[], storage: ISt
|
|
|
71
71
|
predicates.push(conditionContext(
|
|
72
72
|
log,
|
|
73
73
|
andCombinerContext(log, expressions),
|
|
74
|
-
|
|
74
|
+
Treatments.parse(partitions),
|
|
75
75
|
label,
|
|
76
76
|
conditionType
|
|
77
77
|
));
|
|
78
78
|
}
|
|
79
79
|
|
|
80
|
-
//
|
|
80
|
+
// Instanciate evaluator given the set of conditions using if else if logic
|
|
81
81
|
return ifElseIfCombinerContext(log, predicates);
|
|
82
82
|
}
|
package/src/evaluator/types.ts
CHANGED
|
@@ -29,6 +29,6 @@ export type IEvaluationResult = IEvaluation & { treatment: string; impressionsDi
|
|
|
29
29
|
|
|
30
30
|
export type ISplitEvaluator = (log: ILogger, key: SplitIO.SplitKey, splitName: string, attributes: SplitIO.Attributes | undefined, storage: IStorageSync | IStorageAsync) => MaybeThenable<IEvaluation>
|
|
31
31
|
|
|
32
|
-
export type IEvaluator = (key: SplitIO.
|
|
32
|
+
export type IEvaluator = (key: SplitIO.SplitKey, seed: number, trafficAllocation?: number, trafficAllocationSeed?: number, attributes?: SplitIO.Attributes, splitEvaluator?: ISplitEvaluator) => MaybeThenable<IEvaluation | undefined>
|
|
33
33
|
|
|
34
|
-
export type IMatcher = (
|
|
34
|
+
export type IMatcher = (...args: any) => MaybeThenable<boolean>
|
|
@@ -4,7 +4,7 @@ import { ILogger } from '../../logger/types';
|
|
|
4
4
|
import { sanitize } from './sanitize';
|
|
5
5
|
import { ENGINE_VALUE, ENGINE_VALUE_NO_ATTRIBUTES, ENGINE_VALUE_INVALID } from '../../logger/constants';
|
|
6
6
|
|
|
7
|
-
function parseValue(log: ILogger, key:
|
|
7
|
+
function parseValue(log: ILogger, key: string, attributeName: string | null, attributes?: SplitIO.Attributes) {
|
|
8
8
|
let value = undefined;
|
|
9
9
|
if (attributeName) {
|
|
10
10
|
if (attributes) {
|
|
@@ -23,7 +23,7 @@ function parseValue(log: ILogger, key: SplitIO.SplitKey, attributeName: string |
|
|
|
23
23
|
/**
|
|
24
24
|
* Defines value to be matched (key / attribute).
|
|
25
25
|
*/
|
|
26
|
-
export function sanitizeValue(log: ILogger, key:
|
|
26
|
+
export function sanitizeValue(log: ILogger, key: string, matcherDto: IMatcherDto, attributes?: SplitIO.Attributes) {
|
|
27
27
|
const attributeName = matcherDto.attribute;
|
|
28
28
|
const valueToMatch = parseValue(log, key, attributeName, attributes);
|
|
29
29
|
const sanitizedValue = sanitize(log, matcherDto.type, valueToMatch, matcherDto.dataType, attributes);
|
|
@@ -41,7 +41,7 @@ function sanitizeBoolean(val: any): boolean | undefined {
|
|
|
41
41
|
return undefined;
|
|
42
42
|
}
|
|
43
43
|
|
|
44
|
-
function dependencyProcessor(sanitizedValue:
|
|
44
|
+
function dependencyProcessor(sanitizedValue: string, attributes?: SplitIO.Attributes): IDependencyMatcherValue {
|
|
45
45
|
return {
|
|
46
46
|
key: sanitizedValue,
|
|
47
47
|
attributes
|
|
@@ -60,7 +60,6 @@ function getProcessingFunction(matcherTypeID: number, dataType: string) {
|
|
|
60
60
|
case matcherTypes.BETWEEN:
|
|
61
61
|
return dataType === 'DATETIME' ? zeroSinceSS : undefined;
|
|
62
62
|
case matcherTypes.IN_SPLIT_TREATMENT:
|
|
63
|
-
case matcherTypes.IN_RULE_BASED_SEGMENT:
|
|
64
63
|
return dependencyProcessor;
|
|
65
64
|
default:
|
|
66
65
|
return undefined;
|
|
@@ -70,9 +69,9 @@ function getProcessingFunction(matcherTypeID: number, dataType: string) {
|
|
|
70
69
|
/**
|
|
71
70
|
* Sanitize matcher value
|
|
72
71
|
*/
|
|
73
|
-
export function sanitize(log: ILogger, matcherTypeID: number, value: string | number | boolean | Array<string | number> |
|
|
72
|
+
export function sanitize(log: ILogger, matcherTypeID: number, value: string | number | boolean | Array<string | number> | undefined, dataType: string, attributes?: SplitIO.Attributes) {
|
|
74
73
|
const processor = getProcessingFunction(matcherTypeID, dataType);
|
|
75
|
-
let sanitizedValue: string | number | boolean | Array<string> | IDependencyMatcherValue | undefined;
|
|
74
|
+
let sanitizedValue: string | number | boolean | Array<string | number> | IDependencyMatcherValue | undefined;
|
|
76
75
|
|
|
77
76
|
switch (dataType) {
|
|
78
77
|
case matcherDataTypes.NUMBER:
|
|
@@ -89,7 +88,7 @@ export function sanitize(log: ILogger, matcherTypeID: number, value: string | nu
|
|
|
89
88
|
sanitizedValue = sanitizeBoolean(value);
|
|
90
89
|
break;
|
|
91
90
|
case matcherDataTypes.NOT_SPECIFIED:
|
|
92
|
-
sanitizedValue = value
|
|
91
|
+
sanitizedValue = value;
|
|
93
92
|
break;
|
|
94
93
|
default:
|
|
95
94
|
sanitizedValue = undefined;
|
package/src/logger/constants.ts
CHANGED
|
@@ -21,14 +21,12 @@ export const RETRIEVE_MANAGER = 29;
|
|
|
21
21
|
export const SYNC_OFFLINE_DATA = 30;
|
|
22
22
|
export const SYNC_SPLITS_FETCH = 31;
|
|
23
23
|
export const SYNC_SPLITS_UPDATE = 32;
|
|
24
|
-
export const SYNC_RBS_UPDATE = 33;
|
|
25
24
|
export const STREAMING_NEW_MESSAGE = 35;
|
|
26
25
|
export const SYNC_TASK_START = 36;
|
|
27
26
|
export const SYNC_TASK_EXECUTE = 37;
|
|
28
27
|
export const SYNC_TASK_STOP = 38;
|
|
29
28
|
export const SETTINGS_SPLITS_FILTER = 39;
|
|
30
29
|
export const ENGINE_MATCHER_RESULT = 40;
|
|
31
|
-
export const ENGINE_DEFAULT = 41;
|
|
32
30
|
|
|
33
31
|
export const CLIENT_READY_FROM_CACHE = 100;
|
|
34
32
|
export const CLIENT_READY = 101;
|
|
@@ -12,7 +12,6 @@ export const codesDebug: [number, string][] = codesInfo.concat([
|
|
|
12
12
|
[c.ENGINE_VALUE, c.LOG_PREFIX_ENGINE_VALUE + 'Extracted attribute `%s`. %s will be used for matching.'],
|
|
13
13
|
[c.ENGINE_SANITIZE, c.LOG_PREFIX_ENGINE + ':sanitize: Attempted to sanitize %s which should be of type %s. Sanitized and processed value => %s'],
|
|
14
14
|
[c.ENGINE_MATCHER_RESULT, c.LOG_PREFIX_ENGINE_MATCHER + '[%s] Result: %s. Rule value: %s. Evaluation value: %s'],
|
|
15
|
-
[c.ENGINE_DEFAULT, c.LOG_PREFIX_ENGINE + 'Evaluates to default treatment. %s'],
|
|
16
15
|
// SDK
|
|
17
16
|
[c.CLEANUP_REGISTERING, c.LOG_PREFIX_CLEANUP + 'Registering cleanup handler %s'],
|
|
18
17
|
[c.CLEANUP_DEREGISTERING, c.LOG_PREFIX_CLEANUP + 'Deregistering cleanup handler %s'],
|
|
@@ -21,9 +20,8 @@ export const codesDebug: [number, string][] = codesInfo.concat([
|
|
|
21
20
|
[c.RETRIEVE_MANAGER, 'Retrieving manager instance.'],
|
|
22
21
|
// synchronizer
|
|
23
22
|
[c.SYNC_OFFLINE_DATA, c.LOG_PREFIX_SYNC_OFFLINE + 'Feature flags data: \n%s'],
|
|
24
|
-
[c.SYNC_SPLITS_FETCH, c.LOG_PREFIX_SYNC_SPLITS + 'Spin up feature flags update using since = %s
|
|
25
|
-
[c.SYNC_SPLITS_UPDATE, c.LOG_PREFIX_SYNC_SPLITS + 'New feature flags %s. Removed feature flags %s.'],
|
|
26
|
-
[c.SYNC_RBS_UPDATE, c.LOG_PREFIX_SYNC_SPLITS + 'New rule-based segments %s. Removed rule-based segments %s.'],
|
|
23
|
+
[c.SYNC_SPLITS_FETCH, c.LOG_PREFIX_SYNC_SPLITS + 'Spin up feature flags update using since = %s'],
|
|
24
|
+
[c.SYNC_SPLITS_UPDATE, c.LOG_PREFIX_SYNC_SPLITS + 'New feature flags %s. Removed feature flags %s. Segment names collected %s'],
|
|
27
25
|
[c.STREAMING_NEW_MESSAGE, c.LOG_PREFIX_SYNC_STREAMING + 'New SSE message received, with data: %s.'],
|
|
28
26
|
[c.SYNC_TASK_START, c.LOG_PREFIX_SYNC + ': Starting %s. Running each %s millis'],
|
|
29
27
|
[c.SYNC_TASK_EXECUTE, c.LOG_PREFIX_SYNC + ': Running %s'],
|
|
@@ -33,7 +33,7 @@ export const codesWarn: [number, string][] = codesError.concat([
|
|
|
33
33
|
[c.WARN_SDK_KEY, c.LOG_PREFIX_SETTINGS + ': You already have %s. We recommend keeping only one instance of the factory at all times (Singleton pattern) and reusing it throughout your application'],
|
|
34
34
|
|
|
35
35
|
[c.STREAMING_PARSING_MEMBERSHIPS_UPDATE, c.LOG_PREFIX_SYNC_STREAMING + 'Fetching Memberships due to an error processing %s notification: %s'],
|
|
36
|
-
[c.STREAMING_PARSING_SPLIT_UPDATE, c.LOG_PREFIX_SYNC_STREAMING + 'Fetching SplitChanges due to an error processing
|
|
36
|
+
[c.STREAMING_PARSING_SPLIT_UPDATE, c.LOG_PREFIX_SYNC_STREAMING + 'Fetching SplitChanges due to an error processing SPLIT_UPDATE notification: %s'],
|
|
37
37
|
[c.WARN_INVALID_FLAGSET, '%s: you passed %s, flag set must adhere to the regular expressions %s. This means a flag set must start with a letter or number, be in lowercase, alphanumeric and have a max length of 50 characters. %s was discarded.'],
|
|
38
38
|
[c.WARN_LOWERCASE_FLAGSET, '%s: flag set %s should be all lowercase - converting string to lowercase.'],
|
|
39
39
|
[c.WARN_FLAGSET_WITHOUT_FLAGS, '%s: you passed %s flag set that does not contain cached feature flag names. Please double check what flag sets are in use in the Split user interface.'],
|
package/src/sdkManager/index.ts
CHANGED
|
@@ -17,7 +17,7 @@ function collectTreatments(splitObject: ISplit) {
|
|
|
17
17
|
// Localstorage mode could fall into a no rollout conditions state. Take the first condition in that case.
|
|
18
18
|
if (!allTreatmentsCondition) allTreatmentsCondition = conditions[0];
|
|
19
19
|
// Then extract the treatments from the partitions
|
|
20
|
-
return allTreatmentsCondition ? allTreatmentsCondition.partitions
|
|
20
|
+
return allTreatmentsCondition ? allTreatmentsCondition.partitions.map(v => v.treatment) : [];
|
|
21
21
|
}
|
|
22
22
|
|
|
23
23
|
function objectToView(splitObject: ISplit | null): SplitIO.SplitView | null {
|
|
@@ -32,8 +32,7 @@ function objectToView(splitObject: ISplit | null): SplitIO.SplitView | null {
|
|
|
32
32
|
configs: splitObject.configurations || {},
|
|
33
33
|
sets: splitObject.sets || [],
|
|
34
34
|
defaultTreatment: splitObject.defaultTreatment,
|
|
35
|
-
impressionsDisabled: splitObject.impressionsDisabled === true
|
|
36
|
-
prerequisites: (splitObject.prerequisites || []).map(p => ({ flagName: p.n, treatments: p.ts })),
|
|
35
|
+
impressionsDisabled: splitObject.impressionsDisabled === true
|
|
37
36
|
};
|
|
38
37
|
}
|
|
39
38
|
|
package/src/services/splitApi.ts
CHANGED
|
@@ -29,6 +29,7 @@ export function splitApiFactory(
|
|
|
29
29
|
const urls = settings.urls;
|
|
30
30
|
const filterQueryString = settings.sync.__splitFiltersValidation && settings.sync.__splitFiltersValidation.queryString;
|
|
31
31
|
const SplitSDKImpressionsMode = settings.sync.impressionsMode;
|
|
32
|
+
const flagSpecVersion = settings.sync.flagSpecVersion;
|
|
32
33
|
const splitHttpClient = splitHttpClientFactory(settings, platform);
|
|
33
34
|
|
|
34
35
|
return {
|
|
@@ -44,7 +45,7 @@ export function splitApiFactory(
|
|
|
44
45
|
},
|
|
45
46
|
|
|
46
47
|
fetchAuth(userMatchingKeys?: string[]) {
|
|
47
|
-
let url = `${urls.auth}/v2/auth?s=${
|
|
48
|
+
let url = `${urls.auth}/v2/auth?s=${flagSpecVersion}`;
|
|
48
49
|
if (userMatchingKeys) { // `userMatchingKeys` is undefined in server-side
|
|
49
50
|
const queryParams = userMatchingKeys.map(userKeyToQueryParam).join('&');
|
|
50
51
|
if (queryParams) url += '&' + queryParams;
|
|
@@ -52,8 +53,8 @@ export function splitApiFactory(
|
|
|
52
53
|
return splitHttpClient(url, undefined, telemetryTracker.trackHttp(TOKEN));
|
|
53
54
|
},
|
|
54
55
|
|
|
55
|
-
fetchSplitChanges(since: number, noCache?: boolean, till?: number
|
|
56
|
-
const url = `${urls.sdk}/splitChanges?s=${
|
|
56
|
+
fetchSplitChanges(since: number, noCache?: boolean, till?: number) {
|
|
57
|
+
const url = `${urls.sdk}/splitChanges?s=${flagSpecVersion}&since=${since}${filterQueryString || ''}${till ? '&till=' + till : ''}`;
|
|
57
58
|
return splitHttpClient(url, noCache ? noCacheHeaderOptions : undefined, telemetryTracker.trackHttp(SPLITS))
|
|
58
59
|
.catch((err) => {
|
|
59
60
|
if (err.statusCode === 414) settings.log.error(ERROR_TOO_MANY_SETS);
|
package/src/services/types.ts
CHANGED
|
@@ -35,7 +35,7 @@ export type ISplitHttpClient = (url: string, options?: IRequestOptions, latencyT
|
|
|
35
35
|
|
|
36
36
|
export type IFetchAuth = (userKeys?: string[]) => Promise<IResponse>
|
|
37
37
|
|
|
38
|
-
export type IFetchSplitChanges = (since: number, noCache?: boolean, till?: number
|
|
38
|
+
export type IFetchSplitChanges = (since: number, noCache?: boolean, till?: number) => Promise<IResponse>
|
|
39
39
|
|
|
40
40
|
export type IFetchSegmentChanges = (since: number, segmentName: string, noCache?: boolean, till?: number) => Promise<IResponse>
|
|
41
41
|
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ISplitsCacheSync } from './types';
|
|
2
|
-
import {
|
|
2
|
+
import { ISplit } from '../dtos/types';
|
|
3
3
|
import { objectAssign } from '../utils/lang/objectAssign';
|
|
4
4
|
import { IN_SEGMENT, IN_LARGE_SEGMENT } from '../utils/constants';
|
|
5
5
|
|
|
@@ -72,8 +72,8 @@ export abstract class AbstractSplitsCacheSync implements ISplitsCacheSync {
|
|
|
72
72
|
* Given a parsed split, it returns a boolean flagging if its conditions use segments matchers (rules & whitelists).
|
|
73
73
|
* This util is intended to simplify the implementation of `splitsCache::usesSegments` method
|
|
74
74
|
*/
|
|
75
|
-
export function usesSegments(
|
|
76
|
-
const conditions =
|
|
75
|
+
export function usesSegments(split: ISplit) {
|
|
76
|
+
const conditions = split.conditions || [];
|
|
77
77
|
for (let i = 0; i < conditions.length; i++) {
|
|
78
78
|
const matchers = conditions[i].matcherGroup.matchers;
|
|
79
79
|
|
|
@@ -83,8 +83,5 @@ export function usesSegments(ruleEntity: ISplit | IRBSegment) {
|
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
85
|
|
|
86
|
-
const excluded = (ruleEntity as IRBSegment).excluded;
|
|
87
|
-
if (excluded && excluded.segments && excluded.segments.length > 0) return true;
|
|
88
|
-
|
|
89
86
|
return false;
|
|
90
87
|
}
|
|
@@ -37,18 +37,6 @@ export class KeyBuilder {
|
|
|
37
37
|
return `${this.prefix}.split.`;
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
-
buildRBSegmentKey(rbsegmentName: string) {
|
|
41
|
-
return `${this.prefix}.rbsegment.${rbsegmentName}`;
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
buildRBSegmentsTillKey() {
|
|
45
|
-
return `${this.prefix}.rbsegments.till`;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
buildRBSegmentKeyPrefix() {
|
|
49
|
-
return `${this.prefix}.rbsegment.`;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
40
|
buildSegmentNameKey(segmentName: string) {
|
|
53
41
|
return `${this.prefix}.segment.${segmentName}`;
|
|
54
42
|
}
|
|
@@ -47,10 +47,6 @@ export class KeyBuilderCS extends KeyBuilder implements MySegmentsKeyBuilder {
|
|
|
47
47
|
return startsWith(key, `${this.prefix}.split.`);
|
|
48
48
|
}
|
|
49
49
|
|
|
50
|
-
isRBSegmentKey(key: string) {
|
|
51
|
-
return startsWith(key, `${this.prefix}.rbsegment.`);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
50
|
buildSplitsWithSegmentCountKey() {
|
|
55
51
|
return `${this.prefix}.splits.usingSegments`;
|
|
56
52
|
}
|
|
@@ -53,10 +53,6 @@ export class KeyBuilderSS extends KeyBuilder {
|
|
|
53
53
|
return `${this.buildSplitKeyPrefix()}*`;
|
|
54
54
|
}
|
|
55
55
|
|
|
56
|
-
searchPatternForRBSegmentKeys() {
|
|
57
|
-
return `${this.buildRBSegmentKeyPrefix()}*`;
|
|
58
|
-
}
|
|
59
|
-
|
|
60
56
|
/* Telemetry keys */
|
|
61
57
|
|
|
62
58
|
buildLatencyKey(method: Method, bucket: number) {
|
|
@@ -47,14 +47,16 @@ export class SplitsCacheInLocal extends AbstractSplitsCacheSync {
|
|
|
47
47
|
|
|
48
48
|
private _incrementCounts(split: ISplit) {
|
|
49
49
|
try {
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
localStorage.setItem(ttKey, toNumber(localStorage.getItem(ttKey)) + 1);
|
|
53
|
-
|
|
54
|
-
if (usesSegments(split)) {
|
|
55
|
-
const segmentsCountKey = this.keys.buildSplitsWithSegmentCountKey();
|
|
50
|
+
if (split) {
|
|
51
|
+
const ttKey = this.keys.buildTrafficTypeKey(split.trafficTypeName);
|
|
56
52
|
// @ts-expect-error
|
|
57
|
-
localStorage.setItem(
|
|
53
|
+
localStorage.setItem(ttKey, toNumber(localStorage.getItem(ttKey)) + 1);
|
|
54
|
+
|
|
55
|
+
if (usesSegments(split)) {
|
|
56
|
+
const segmentsCountKey = this.keys.buildSplitsWithSegmentCountKey();
|
|
57
|
+
// @ts-expect-error
|
|
58
|
+
localStorage.setItem(segmentsCountKey, toNumber(localStorage.getItem(segmentsCountKey)) + 1);
|
|
59
|
+
}
|
|
58
60
|
}
|
|
59
61
|
} catch (e) {
|
|
60
62
|
this.log.error(LOG_PREFIX + e);
|
|
@@ -183,9 +185,11 @@ export class SplitsCacheInLocal extends AbstractSplitsCacheSync {
|
|
|
183
185
|
const storedCount = localStorage.getItem(this.keys.buildSplitsWithSegmentCountKey());
|
|
184
186
|
const splitsWithSegmentsCount = storedCount === null ? 0 : toNumber(storedCount);
|
|
185
187
|
|
|
186
|
-
|
|
187
|
-
splitsWithSegmentsCount > 0
|
|
188
|
-
|
|
188
|
+
if (isFiniteNumber(splitsWithSegmentsCount)) {
|
|
189
|
+
return splitsWithSegmentsCount > 0;
|
|
190
|
+
} else {
|
|
191
|
+
return true;
|
|
192
|
+
}
|
|
189
193
|
}
|
|
190
194
|
|
|
191
195
|
getNamesByFlagSets(flagSets: string[]): Set<string>[] {
|
|
@@ -6,7 +6,6 @@ import { validatePrefix } from '../KeyBuilder';
|
|
|
6
6
|
import { KeyBuilderCS, myLargeSegmentsKeyBuilder } from '../KeyBuilderCS';
|
|
7
7
|
import { isLocalStorageAvailable } from '../../utils/env/isLocalStorageAvailable';
|
|
8
8
|
import { SplitsCacheInLocal } from './SplitsCacheInLocal';
|
|
9
|
-
import { RBSegmentsCacheInLocal } from './RBSegmentsCacheInLocal';
|
|
10
9
|
import { MySegmentsCacheInLocal } from './MySegmentsCacheInLocal';
|
|
11
10
|
import { InMemoryStorageCSFactory } from '../inMemory/InMemoryStorageCS';
|
|
12
11
|
import { LOG_PREFIX } from './constants';
|
|
@@ -37,13 +36,11 @@ export function InLocalStorage(options: SplitIO.InLocalStorageOptions = {}): ISt
|
|
|
37
36
|
const keys = new KeyBuilderCS(prefix, matchingKey);
|
|
38
37
|
|
|
39
38
|
const splits = new SplitsCacheInLocal(settings, keys);
|
|
40
|
-
const rbSegments = new RBSegmentsCacheInLocal(settings, keys);
|
|
41
39
|
const segments = new MySegmentsCacheInLocal(log, keys);
|
|
42
40
|
const largeSegments = new MySegmentsCacheInLocal(log, myLargeSegmentsKeyBuilder(prefix, matchingKey));
|
|
43
41
|
|
|
44
42
|
return {
|
|
45
43
|
splits,
|
|
46
|
-
rbSegments,
|
|
47
44
|
segments,
|
|
48
45
|
largeSegments,
|
|
49
46
|
impressions: new ImpressionsCacheInMemory(impressionsQueueSize),
|
|
@@ -53,7 +50,7 @@ export function InLocalStorage(options: SplitIO.InLocalStorageOptions = {}): ISt
|
|
|
53
50
|
uniqueKeys: new UniqueKeysCacheInMemoryCS(),
|
|
54
51
|
|
|
55
52
|
validateCache() {
|
|
56
|
-
return validateCache(options, settings, keys, splits,
|
|
53
|
+
return validateCache(options, settings, keys, splits, segments, largeSegments);
|
|
57
54
|
},
|
|
58
55
|
|
|
59
56
|
destroy() { },
|
|
@@ -63,7 +60,6 @@ export function InLocalStorage(options: SplitIO.InLocalStorageOptions = {}): ISt
|
|
|
63
60
|
|
|
64
61
|
return {
|
|
65
62
|
splits: this.splits,
|
|
66
|
-
rbSegments: this.rbSegments,
|
|
67
63
|
segments: new MySegmentsCacheInLocal(log, new KeyBuilderCS(prefix, matchingKey)),
|
|
68
64
|
largeSegments: new MySegmentsCacheInLocal(log, myLargeSegmentsKeyBuilder(prefix, matchingKey)),
|
|
69
65
|
impressions: this.impressions,
|
|
@@ -3,7 +3,6 @@ import { isFiniteNumber, isNaNNumber } from '../../utils/lang';
|
|
|
3
3
|
import { getStorageHash } from '../KeyBuilder';
|
|
4
4
|
import { LOG_PREFIX } from './constants';
|
|
5
5
|
import type { SplitsCacheInLocal } from './SplitsCacheInLocal';
|
|
6
|
-
import type { RBSegmentsCacheInLocal } from './RBSegmentsCacheInLocal';
|
|
7
6
|
import type { MySegmentsCacheInLocal } from './MySegmentsCacheInLocal';
|
|
8
7
|
import { KeyBuilderCS } from '../KeyBuilderCS';
|
|
9
8
|
import SplitIO from '../../../types/splitio';
|
|
@@ -67,14 +66,13 @@ function validateExpiration(options: SplitIO.InLocalStorageOptions, settings: IS
|
|
|
67
66
|
*
|
|
68
67
|
* @returns `true` if cache is ready to be used, `false` otherwise (cache was cleared or there is no cache)
|
|
69
68
|
*/
|
|
70
|
-
export function validateCache(options: SplitIO.InLocalStorageOptions, settings: ISettings, keys: KeyBuilderCS, splits: SplitsCacheInLocal,
|
|
69
|
+
export function validateCache(options: SplitIO.InLocalStorageOptions, settings: ISettings, keys: KeyBuilderCS, splits: SplitsCacheInLocal, segments: MySegmentsCacheInLocal, largeSegments: MySegmentsCacheInLocal): boolean {
|
|
71
70
|
|
|
72
71
|
const currentTimestamp = Date.now();
|
|
73
72
|
const isThereCache = splits.getChangeNumber() > -1;
|
|
74
73
|
|
|
75
74
|
if (validateExpiration(options, settings, keys, currentTimestamp, isThereCache)) {
|
|
76
75
|
splits.clear();
|
|
77
|
-
rbSegments.clear();
|
|
78
76
|
segments.clear();
|
|
79
77
|
largeSegments.clear();
|
|
80
78
|
|
|
@@ -7,7 +7,6 @@ import { ImpressionCountsCacheInMemory } from './ImpressionCountsCacheInMemory';
|
|
|
7
7
|
import { LOCALHOST_MODE, STORAGE_MEMORY } from '../../utils/constants';
|
|
8
8
|
import { shouldRecordTelemetry, TelemetryCacheInMemory } from './TelemetryCacheInMemory';
|
|
9
9
|
import { UniqueKeysCacheInMemory } from './UniqueKeysCacheInMemory';
|
|
10
|
-
import { RBSegmentsCacheInMemory } from './RBSegmentsCacheInMemory';
|
|
11
10
|
|
|
12
11
|
/**
|
|
13
12
|
* InMemory storage factory for standalone server-side SplitFactory
|
|
@@ -18,12 +17,10 @@ export function InMemoryStorageFactory(params: IStorageFactoryParams): IStorageS
|
|
|
18
17
|
const { settings: { scheduler: { impressionsQueueSize, eventsQueueSize, }, sync: { __splitFiltersValidation } } } = params;
|
|
19
18
|
|
|
20
19
|
const splits = new SplitsCacheInMemory(__splitFiltersValidation);
|
|
21
|
-
const rbSegments = new RBSegmentsCacheInMemory();
|
|
22
20
|
const segments = new SegmentsCacheInMemory();
|
|
23
21
|
|
|
24
22
|
const storage = {
|
|
25
23
|
splits,
|
|
26
|
-
rbSegments,
|
|
27
24
|
segments,
|
|
28
25
|
impressions: new ImpressionsCacheInMemory(impressionsQueueSize),
|
|
29
26
|
impressionCounts: new ImpressionCountsCacheInMemory(),
|
|
@@ -7,7 +7,6 @@ import { ImpressionCountsCacheInMemory } from './ImpressionCountsCacheInMemory';
|
|
|
7
7
|
import { LOCALHOST_MODE, STORAGE_MEMORY } from '../../utils/constants';
|
|
8
8
|
import { shouldRecordTelemetry, TelemetryCacheInMemory } from './TelemetryCacheInMemory';
|
|
9
9
|
import { UniqueKeysCacheInMemoryCS } from './UniqueKeysCacheInMemoryCS';
|
|
10
|
-
import { RBSegmentsCacheInMemory } from './RBSegmentsCacheInMemory';
|
|
11
10
|
|
|
12
11
|
/**
|
|
13
12
|
* InMemory storage factory for standalone client-side SplitFactory
|
|
@@ -18,13 +17,11 @@ export function InMemoryStorageCSFactory(params: IStorageFactoryParams): IStorag
|
|
|
18
17
|
const { settings: { scheduler: { impressionsQueueSize, eventsQueueSize }, sync: { __splitFiltersValidation } } } = params;
|
|
19
18
|
|
|
20
19
|
const splits = new SplitsCacheInMemory(__splitFiltersValidation);
|
|
21
|
-
const rbSegments = new RBSegmentsCacheInMemory();
|
|
22
20
|
const segments = new MySegmentsCacheInMemory();
|
|
23
21
|
const largeSegments = new MySegmentsCacheInMemory();
|
|
24
22
|
|
|
25
23
|
const storage = {
|
|
26
24
|
splits,
|
|
27
|
-
rbSegments,
|
|
28
25
|
segments,
|
|
29
26
|
largeSegments,
|
|
30
27
|
impressions: new ImpressionsCacheInMemory(impressionsQueueSize),
|
|
@@ -39,7 +36,6 @@ export function InMemoryStorageCSFactory(params: IStorageFactoryParams): IStorag
|
|
|
39
36
|
shared() {
|
|
40
37
|
return {
|
|
41
38
|
splits: this.splits,
|
|
42
|
-
rbSegments: this.rbSegments,
|
|
43
39
|
segments: new MySegmentsCacheInMemory(),
|
|
44
40
|
largeSegments: new MySegmentsCacheInMemory(),
|
|
45
41
|
impressions: this.impressions,
|