@splitsoftware/splitio-commons 1.17.0-rc.5 → 1.17.1-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGES.txt +6 -0
- package/cjs/evaluator/matchers/index.js +3 -1
- package/cjs/evaluator/matchers/large_segment.js +16 -0
- package/cjs/evaluator/matchers/matcherTypes.js +1 -0
- package/cjs/evaluator/matchersTransform/index.js +4 -1
- package/cjs/evaluator/matchersTransform/segment.js +3 -1
- package/cjs/logger/constants.js +2 -2
- package/cjs/logger/messages/info.js +1 -1
- package/cjs/logger/messages/warn.js +1 -1
- package/cjs/readiness/readinessManager.js +5 -6
- package/cjs/readiness/sdkReadinessManager.js +5 -6
- package/cjs/sdkClient/sdkClientMethodCS.js +2 -2
- package/cjs/sdkClient/sdkClientMethodCSWithTT.js +2 -2
- package/cjs/sdkFactory/index.js +1 -1
- package/cjs/services/splitApi.js +5 -5
- package/cjs/storages/AbstractSegmentsCacheSync.js +41 -12
- package/cjs/storages/AbstractSplitsCacheSync.js +2 -1
- package/cjs/storages/KeyBuilderCS.js +23 -5
- package/cjs/storages/dataLoader.js +1 -1
- package/cjs/storages/inLocalStorage/MySegmentsCacheInLocal.js +29 -52
- package/cjs/storages/inLocalStorage/index.js +6 -2
- package/cjs/storages/inMemory/InMemoryStorageCS.js +5 -0
- package/cjs/storages/inMemory/MySegmentsCacheInMemory.js +9 -40
- package/cjs/storages/inMemory/SplitsCacheInMemory.js +8 -8
- package/cjs/storages/inMemory/TelemetryCacheInMemory.js +7 -10
- package/cjs/storages/pluggable/inMemoryWrapper.js +1 -1
- package/cjs/sync/polling/fetchers/mySegmentsFetcher.js +5 -8
- package/cjs/sync/polling/fetchers/segmentChangesFetcher.js +1 -1
- package/cjs/sync/polling/pollingManagerCS.js +1 -1
- package/cjs/sync/polling/syncTasks/mySegmentsSyncTask.js +2 -2
- package/cjs/sync/polling/updaters/mySegmentsUpdater.js +15 -21
- package/cjs/sync/streaming/AuthClient/index.js +1 -1
- package/cjs/sync/streaming/SSEClient/index.js +2 -2
- package/cjs/sync/streaming/SSEHandler/index.js +3 -5
- package/cjs/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.js +107 -48
- package/cjs/sync/streaming/constants.js +3 -3
- package/cjs/sync/streaming/parseUtils.js +14 -9
- package/cjs/sync/streaming/pushManager.js +69 -67
- package/cjs/utils/constants/index.js +5 -4
- package/cjs/utils/settingsValidation/index.js +2 -1
- package/esm/evaluator/matchers/index.js +3 -1
- package/esm/evaluator/matchers/large_segment.js +12 -0
- package/esm/evaluator/matchers/matcherTypes.js +1 -0
- package/esm/evaluator/matchersTransform/index.js +4 -1
- package/esm/evaluator/matchersTransform/segment.js +3 -1
- package/esm/logger/constants.js +1 -1
- package/esm/logger/messages/info.js +1 -1
- package/esm/logger/messages/warn.js +1 -1
- package/esm/readiness/readinessManager.js +5 -6
- package/esm/readiness/sdkReadinessManager.js +5 -6
- package/esm/sdkClient/sdkClientMethodCS.js +2 -2
- package/esm/sdkClient/sdkClientMethodCSWithTT.js +2 -2
- package/esm/sdkFactory/index.js +1 -1
- package/esm/services/splitApi.js +6 -6
- package/esm/storages/AbstractSegmentsCacheSync.js +41 -12
- package/esm/storages/AbstractSplitsCacheSync.js +3 -2
- package/esm/storages/KeyBuilderCS.js +21 -4
- package/esm/storages/dataLoader.js +1 -1
- package/esm/storages/inLocalStorage/MySegmentsCacheInLocal.js +29 -52
- package/esm/storages/inLocalStorage/index.js +7 -3
- package/esm/storages/inMemory/InMemoryStorageCS.js +5 -0
- package/esm/storages/inMemory/MySegmentsCacheInMemory.js +9 -40
- package/esm/storages/inMemory/SplitsCacheInMemory.js +8 -8
- package/esm/storages/inMemory/TelemetryCacheInMemory.js +7 -10
- package/esm/storages/pluggable/inMemoryWrapper.js +1 -1
- package/esm/sync/polling/fetchers/mySegmentsFetcher.js +5 -8
- package/esm/sync/polling/fetchers/segmentChangesFetcher.js +1 -1
- package/esm/sync/polling/pollingManagerCS.js +1 -1
- package/esm/sync/polling/syncTasks/mySegmentsSyncTask.js +2 -2
- package/esm/sync/polling/updaters/mySegmentsUpdater.js +15 -21
- package/esm/sync/streaming/AuthClient/index.js +1 -1
- package/esm/sync/streaming/SSEClient/index.js +2 -2
- package/esm/sync/streaming/SSEHandler/index.js +4 -6
- package/esm/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.js +108 -49
- package/esm/sync/streaming/constants.js +2 -2
- package/esm/sync/streaming/parseUtils.js +12 -8
- package/esm/sync/streaming/pushManager.js +72 -70
- package/esm/utils/constants/index.js +3 -2
- package/esm/utils/settingsValidation/index.js +2 -1
- package/package.json +1 -1
- package/src/dtos/types.ts +21 -7
- package/src/evaluator/matchers/index.ts +2 -0
- package/src/evaluator/matchers/large_segment.ts +18 -0
- package/src/evaluator/matchers/matcherTypes.ts +1 -0
- package/src/evaluator/matchersTransform/index.ts +4 -1
- package/src/evaluator/matchersTransform/segment.ts +5 -3
- package/src/logger/constants.ts +1 -1
- package/src/logger/messages/info.ts +1 -1
- package/src/logger/messages/warn.ts +1 -1
- package/src/readiness/readinessManager.ts +7 -5
- package/src/readiness/sdkReadinessManager.ts +7 -7
- package/src/readiness/types.ts +2 -2
- package/src/sdkClient/sdkClientMethodCS.ts +2 -2
- package/src/sdkClient/sdkClientMethodCSWithTT.ts +2 -2
- package/src/sdkFactory/index.ts +1 -1
- package/src/services/splitApi.ts +7 -7
- package/src/services/splitHttpClient.ts +1 -1
- package/src/services/types.ts +2 -2
- package/src/storages/AbstractSegmentsCacheSync.ts +53 -12
- package/src/storages/AbstractSplitsCacheSync.ts +4 -3
- package/src/storages/KeyBuilderCS.ts +34 -5
- package/src/storages/dataLoader.ts +1 -1
- package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +29 -59
- package/src/storages/inLocalStorage/index.ts +8 -4
- package/src/storages/inMemory/InMemoryStorageCS.ts +5 -0
- package/src/storages/inMemory/MySegmentsCacheInMemory.ts +10 -44
- package/src/storages/inMemory/SplitsCacheInMemory.ts +7 -8
- package/src/storages/inMemory/TelemetryCacheInMemory.ts +7 -11
- package/src/storages/pluggable/inMemoryWrapper.ts +1 -1
- package/src/storages/types.ts +11 -7
- package/src/sync/polling/fetchers/mySegmentsFetcher.ts +8 -10
- package/src/sync/polling/fetchers/segmentChangesFetcher.ts +1 -1
- package/src/sync/polling/fetchers/types.ts +3 -2
- package/src/sync/polling/pollingManagerCS.ts +4 -4
- package/src/sync/polling/syncTasks/mySegmentsSyncTask.ts +4 -5
- package/src/sync/polling/types.ts +7 -6
- package/src/sync/polling/updaters/mySegmentsUpdater.ts +19 -22
- package/src/sync/streaming/AuthClient/index.ts +1 -1
- package/src/sync/streaming/SSEClient/index.ts +6 -8
- package/src/sync/streaming/SSEHandler/index.ts +5 -8
- package/src/sync/streaming/SSEHandler/types.ts +15 -15
- package/src/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.ts +116 -49
- package/src/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.ts +1 -1
- package/src/sync/streaming/UpdateWorkers/SplitsUpdateWorker.ts +1 -1
- package/src/sync/streaming/UpdateWorkers/types.ts +2 -2
- package/src/sync/streaming/constants.ts +2 -2
- package/src/sync/streaming/parseUtils.ts +19 -11
- package/src/sync/streaming/pushManager.ts +73 -72
- package/src/sync/streaming/types.ts +10 -10
- package/src/sync/submitters/types.ts +8 -5
- package/src/utils/constants/index.ts +3 -2
- package/src/utils/settingsValidation/index.ts +3 -2
- package/src/utils/settingsValidation/types.ts +1 -1
- package/types/dtos/types.d.ts +18 -7
- package/types/evaluator/matchersTransform/segment.d.ts +2 -2
- package/types/logger/constants.d.ts +1 -1
- package/types/readiness/readinessManager.d.ts +2 -2
- package/types/readiness/sdkReadinessManager.d.ts +2 -3
- package/types/readiness/types.d.ts +2 -2
- package/types/services/splitApi.d.ts +1 -1
- package/types/services/splitHttpClient.d.ts +1 -1
- package/types/services/types.d.ts +2 -2
- package/types/storages/AbstractSegmentsCacheSync.d.ts +9 -11
- package/types/storages/AbstractSplitsCacheSync.d.ts +1 -1
- package/types/storages/KeyBuilderCS.d.ts +9 -2
- package/types/storages/inLocalStorage/MySegmentsCacheInLocal.d.ts +4 -14
- package/types/storages/inMemory/MySegmentsCacheInMemory.d.ts +3 -9
- package/types/storages/inMemory/SplitsCacheInMemory.d.ts +1 -1
- package/types/storages/inMemory/TelemetryCacheInMemory.d.ts +4 -6
- package/types/storages/pluggable/inMemoryWrapper.d.ts +1 -1
- package/types/storages/types.d.ts +7 -5
- package/types/sync/polling/fetchers/mySegmentsFetcher.d.ts +2 -2
- package/types/sync/polling/fetchers/types.d.ts +2 -2
- package/types/sync/polling/syncTasks/mySegmentsSyncTask.d.ts +2 -2
- package/types/sync/polling/types.d.ts +7 -4
- package/types/sync/polling/updaters/mySegmentsUpdater.d.ts +4 -3
- package/types/sync/streaming/SSEHandler/types.d.ts +16 -14
- package/types/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.d.ts +4 -2
- package/types/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.d.ts +2 -1
- package/types/sync/streaming/UpdateWorkers/SplitsUpdateWorker.d.ts +3 -2
- package/types/sync/streaming/UpdateWorkers/types.d.ts +2 -2
- package/types/sync/streaming/constants.d.ts +2 -2
- package/types/sync/streaming/parseUtils.d.ts +4 -5
- package/types/sync/streaming/types.d.ts +8 -8
- package/types/sync/submitters/types.d.ts +7 -4
- package/types/utils/constants/index.d.ts +3 -2
- package/types/utils/settingsValidation/types.d.ts +1 -1
package/CHANGES.txt
CHANGED
|
@@ -1,3 +1,9 @@
|
|
|
1
|
+
2.0.0 (September XX, 2024)
|
|
2
|
+
- Added support for targeting rules based on large segments.
|
|
3
|
+
- BREAKING CHANGES:
|
|
4
|
+
- Removed `/mySegments` endpoint from SplitAPI module, as it is replaced by `/memberships` endpoint.
|
|
5
|
+
- Removed support for MY_SEGMENTS_UPDATE and MY_SEGMENTS_UPDATE_V2 notification types, as they are replaced by MEMBERSHIPS_MS_UPDATE and MEMBERSHIPS_LS_UPDATE notification types.
|
|
6
|
+
|
|
1
7
|
1.17.0 (September 6, 2024)
|
|
2
8
|
- Added `sync.requestOptions.getHeaderOverrides` configuration option to enhance SDK HTTP request Headers for Authorization Frameworks.
|
|
3
9
|
- Added `isTimedout` and `lastUpdate` properties to IStatusInterface to keep track of the timestamp of the last SDK event, used on React and Redux SDKs.
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.matcherFactory = void 0;
|
|
4
4
|
var all_1 = require("./all");
|
|
5
5
|
var segment_1 = require("./segment");
|
|
6
|
+
var large_segment_1 = require("./large_segment");
|
|
6
7
|
var whitelist_1 = require("./whitelist");
|
|
7
8
|
var eq_1 = require("./eq");
|
|
8
9
|
var gte_1 = require("./gte");
|
|
@@ -46,7 +47,8 @@ var matchers = [
|
|
|
46
47
|
semver_gte_1.greaterThanEqualToSemverMatcherContext,
|
|
47
48
|
semver_lte_1.lessThanEqualToSemverMatcherContext,
|
|
48
49
|
semver_between_1.betweenSemverMatcherContext,
|
|
49
|
-
semver_inlist_1.inListSemverMatcherContext,
|
|
50
|
+
semver_inlist_1.inListSemverMatcherContext,
|
|
51
|
+
large_segment_1.largeSegmentMatcherContext, // IN_LARGE_SEGMENT: 23
|
|
50
52
|
];
|
|
51
53
|
/**
|
|
52
54
|
* Matcher factory.
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.largeSegmentMatcherContext = void 0;
|
|
4
|
+
var thenable_1 = require("../../utils/promise/thenable");
|
|
5
|
+
function largeSegmentMatcherContext(largeSegmentName, storage) {
|
|
6
|
+
return function largeSegmentMatcher(key) {
|
|
7
|
+
var isInLargeSegment = storage.largeSegments ? storage.largeSegments.isInSegment(largeSegmentName, key) : false;
|
|
8
|
+
if ((0, thenable_1.thenable)(isInLargeSegment)) {
|
|
9
|
+
isInLargeSegment.then(function (result) {
|
|
10
|
+
return result;
|
|
11
|
+
});
|
|
12
|
+
}
|
|
13
|
+
return isInLargeSegment;
|
|
14
|
+
};
|
|
15
|
+
}
|
|
16
|
+
exports.largeSegmentMatcherContext = largeSegmentMatcherContext;
|
|
@@ -12,7 +12,7 @@ var convertions_1 = require("../convertions");
|
|
|
12
12
|
*/
|
|
13
13
|
function matchersTransform(matchers) {
|
|
14
14
|
var parsedMatchers = matchers.map(function (matcher) {
|
|
15
|
-
var matcherType = matcher.matcherType, negate = matcher.negate, keySelector = matcher.keySelector, userDefinedSegmentMatcherData = matcher.userDefinedSegmentMatcherData, whitelistMatcherData = matcher.whitelistMatcherData, /* whitelistObject, provided by 'WHITELIST', 'IN_LIST_SEMVER', set and string matchers */ unaryNumericMatcherData = matcher.unaryNumericMatcherData, betweenMatcherData = matcher.betweenMatcherData, dependencyMatcherData = matcher.dependencyMatcherData, booleanMatcherData = matcher.booleanMatcherData, stringMatcherData = matcher.stringMatcherData, betweenStringMatcherData = matcher.betweenStringMatcherData;
|
|
15
|
+
var matcherType = matcher.matcherType, negate = matcher.negate, keySelector = matcher.keySelector, userDefinedSegmentMatcherData = matcher.userDefinedSegmentMatcherData, userDefinedLargeSegmentMatcherData = matcher.userDefinedLargeSegmentMatcherData, whitelistMatcherData = matcher.whitelistMatcherData, /* whitelistObject, provided by 'WHITELIST', 'IN_LIST_SEMVER', set and string matchers */ unaryNumericMatcherData = matcher.unaryNumericMatcherData, betweenMatcherData = matcher.betweenMatcherData, dependencyMatcherData = matcher.dependencyMatcherData, booleanMatcherData = matcher.booleanMatcherData, stringMatcherData = matcher.stringMatcherData, betweenStringMatcherData = matcher.betweenStringMatcherData;
|
|
16
16
|
var attribute = keySelector && keySelector.attribute;
|
|
17
17
|
var type = (0, matcherTypes_1.matcherTypesMapper)(matcherType);
|
|
18
18
|
// As default input data type we use string (even for ALL_KEYS)
|
|
@@ -21,6 +21,9 @@ function matchersTransform(matchers) {
|
|
|
21
21
|
if (type === matcherTypes_1.matcherTypes.IN_SEGMENT) {
|
|
22
22
|
value = (0, segment_1.segmentTransform)(userDefinedSegmentMatcherData);
|
|
23
23
|
}
|
|
24
|
+
else if (type === matcherTypes_1.matcherTypes.IN_LARGE_SEGMENT) {
|
|
25
|
+
value = (0, segment_1.segmentTransform)(userDefinedLargeSegmentMatcherData);
|
|
26
|
+
}
|
|
24
27
|
else if (type === matcherTypes_1.matcherTypes.EQUAL_TO) {
|
|
25
28
|
value = (0, unaryNumeric_1.numericTransform)(unaryNumericMatcherData);
|
|
26
29
|
dataType = matcherTypes_1.matcherDataTypes.NUMBER;
|
|
@@ -5,6 +5,8 @@ exports.segmentTransform = void 0;
|
|
|
5
5
|
* Extract segment name as a plain string.
|
|
6
6
|
*/
|
|
7
7
|
function segmentTransform(segment) {
|
|
8
|
-
return segment ?
|
|
8
|
+
return segment ?
|
|
9
|
+
segment.segmentName || segment.largeSegmentName :
|
|
10
|
+
undefined;
|
|
9
11
|
}
|
|
10
12
|
exports.segmentTransform = segmentTransform;
|
package/cjs/logger/constants.js
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
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 = 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.ENGINE_MATCHER_RESULT = 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_DEPENDENCY_PRE = exports.ENGINE_MATCHER_DEPENDENCY = exports.ENGINE_BUCKET = exports.ENGINE_COMBINER_IFELSEIF_NO_TREATMENT = exports.ENGINE_COMBINER_IFELSEIF = exports.ENGINE_COMBINER_AND = void 0;
|
|
4
|
-
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 = 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.WARN_FLAGSET_WITHOUT_FLAGS = exports.WARN_FLAGSET_NOT_CONFIGURED = exports.WARN_LOWERCASE_FLAGSET = exports.WARN_INVALID_FLAGSET = exports.STREAMING_PARSING_SPLIT_UPDATE = exports.
|
|
4
|
+
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 = 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.WARN_FLAGSET_WITHOUT_FLAGS = exports.WARN_FLAGSET_NOT_CONFIGURED = exports.WARN_LOWERCASE_FLAGSET = exports.WARN_INVALID_FLAGSET = exports.STREAMING_PARSING_SPLIT_UPDATE = exports.STREAMING_PARSING_MEMBERSHIPS_UPDATE = exports.WARN_SDK_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 = void 0;
|
|
5
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_CLIENT_INSTANTIATION = exports.LOG_PREFIX_INSTANTIATION = exports.LOG_PREFIX_SETTINGS = exports.ENGINE_MATCHER_ERROR = exports.ERROR_SETS_FILTER_EXCLUSIVE = exports.ERROR_TOO_MANY_SETS = exports.ERROR_MIN_CONFIG_PARAM = exports.ERROR_NOT_BOOLEAN = exports.ERROR_STORAGE_INVALID = exports.ERROR_LOCALHOST_MODULE_REQUIRED = exports.ERROR_HTTP = void 0;
|
|
6
6
|
/**
|
|
7
7
|
* Message codes used to trim string log messages from commons and client-side API modules,
|
|
@@ -82,7 +82,7 @@ exports.WARN_SPLITS_FILTER_IGNORED = 219;
|
|
|
82
82
|
exports.WARN_SPLITS_FILTER_INVALID = 220;
|
|
83
83
|
exports.WARN_SPLITS_FILTER_EMPTY = 221;
|
|
84
84
|
exports.WARN_SDK_KEY = 222;
|
|
85
|
-
exports.
|
|
85
|
+
exports.STREAMING_PARSING_MEMBERSHIPS_UPDATE = 223;
|
|
86
86
|
exports.STREAMING_PARSING_SPLIT_UPDATE = 224;
|
|
87
87
|
exports.WARN_INVALID_FLAGSET = 225;
|
|
88
88
|
exports.WARN_LOWERCASE_FLAGSET = 226;
|
|
@@ -24,7 +24,7 @@ exports.codesInfo = warn_1.codesWarn.concat([
|
|
|
24
24
|
[c.POLLING_START, c.LOG_PREFIX_SYNC_POLLING + 'Starting polling'],
|
|
25
25
|
[c.POLLING_STOP, c.LOG_PREFIX_SYNC_POLLING + 'Stopping polling'],
|
|
26
26
|
[c.SYNC_SPLITS_FETCH_RETRY, c.LOG_PREFIX_SYNC_SPLITS + 'Retrying download of feature flags #%s. Reason: %s'],
|
|
27
|
-
[c.SUBMITTERS_PUSH_FULL_QUEUE, c.LOG_PREFIX_SYNC_SUBMITTERS + 'Flushing full %s queue and
|
|
27
|
+
[c.SUBMITTERS_PUSH_FULL_QUEUE, c.LOG_PREFIX_SYNC_SUBMITTERS + 'Flushing full %s queue and resetting timer.'],
|
|
28
28
|
[c.SUBMITTERS_PUSH, c.LOG_PREFIX_SYNC_SUBMITTERS + 'Pushing %s.'],
|
|
29
29
|
[c.STREAMING_REFRESH_TOKEN, c.LOG_PREFIX_SYNC_STREAMING + 'Refreshing streaming token in %s seconds, and connecting streaming in %s seconds.'],
|
|
30
30
|
[c.STREAMING_RECONNECT, c.LOG_PREFIX_SYNC_STREAMING + 'Attempting to reconnect streaming in %s seconds.'],
|
|
@@ -34,7 +34,7 @@ exports.codesWarn = error_1.codesError.concat([
|
|
|
34
34
|
[c.WARN_SPLITS_FILTER_INVALID, c.LOG_PREFIX_SETTINGS + ': feature flag filter at position %s is invalid. It must be an object with a valid filter type ("bySet", "byName" or "byPrefix") and a list of "values".'],
|
|
35
35
|
[c.WARN_SPLITS_FILTER_EMPTY, c.LOG_PREFIX_SETTINGS + ': feature flag filter configuration must be a non-empty array of filter objects.'],
|
|
36
36
|
[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'],
|
|
37
|
-
[c.
|
|
37
|
+
[c.STREAMING_PARSING_MEMBERSHIPS_UPDATE, c.LOG_PREFIX_SYNC_STREAMING + 'Fetching Memberships due to an error processing %s notification: %s'],
|
|
38
38
|
[c.STREAMING_PARSING_SPLIT_UPDATE, c.LOG_PREFIX_SYNC_STREAMING + 'Fetching SplitChanges due to an error processing SPLIT_UPDATE notification: %s'],
|
|
39
39
|
[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.'],
|
|
40
40
|
[c.WARN_LOWERCASE_FLAGSET, '%s: flag set %s should be all lowercase - converting string to lowercase.'],
|
|
@@ -9,7 +9,7 @@ function splitsEventEmitterFactory(EventEmitter) {
|
|
|
9
9
|
splitsCacheLoaded: false,
|
|
10
10
|
});
|
|
11
11
|
// `isSplitKill` condition avoids an edge-case of wrongly emitting SDK_READY if:
|
|
12
|
-
// - `/
|
|
12
|
+
// - `/memberships` fetch and SPLIT_KILL occurs before `/splitChanges` fetch, and
|
|
13
13
|
// - storage has cached splits (for which case `splitsStorage.killLocally` can return true)
|
|
14
14
|
splitsEventEmitter.on(constants_1.SDK_SPLITS_ARRIVED, function (isSplitKill) { if (!isSplitKill)
|
|
15
15
|
splitsEventEmitter.splitsArrived = true; });
|
|
@@ -26,9 +26,9 @@ function segmentsEventEmitterFactory(EventEmitter) {
|
|
|
26
26
|
/**
|
|
27
27
|
* Factory of readiness manager, which handles the ready / update event propagation.
|
|
28
28
|
*/
|
|
29
|
-
function readinessManagerFactory(EventEmitter,
|
|
30
|
-
if (readyTimeout === void 0) { readyTimeout = 0; }
|
|
29
|
+
function readinessManagerFactory(EventEmitter, settings, splits) {
|
|
31
30
|
if (splits === void 0) { splits = splitsEventEmitterFactory(EventEmitter); }
|
|
31
|
+
var readyTimeout = settings.startup.readyTimeout;
|
|
32
32
|
var segments = segmentsEventEmitterFactory(EventEmitter);
|
|
33
33
|
var gate = new EventEmitter();
|
|
34
34
|
var lastUpdate = 0;
|
|
@@ -106,10 +106,9 @@ function readinessManagerFactory(EventEmitter, readyTimeout, splits) {
|
|
|
106
106
|
splits: splits,
|
|
107
107
|
segments: segments,
|
|
108
108
|
gate: gate,
|
|
109
|
-
shared: function (
|
|
110
|
-
if (readyTimeout === void 0) { readyTimeout = 0; }
|
|
109
|
+
shared: function () {
|
|
111
110
|
refCount++;
|
|
112
|
-
return readinessManagerFactory(EventEmitter,
|
|
111
|
+
return readinessManagerFactory(EventEmitter, settings, splits);
|
|
113
112
|
},
|
|
114
113
|
// @TODO review/remove next methods when non-recoverable errors are reworked
|
|
115
114
|
// Called on consumer mode, when storage fails to connect
|
|
@@ -15,9 +15,9 @@ var REMOVE_LISTENER_EVENT = 'removeListener';
|
|
|
15
15
|
* @param readyTimeout time in millis to emit SDK_READY_TIME_OUT event
|
|
16
16
|
* @param readinessManager optional readinessManager to use. only used internally for `shared` method
|
|
17
17
|
*/
|
|
18
|
-
function sdkReadinessManagerFactory(
|
|
19
|
-
if (
|
|
20
|
-
|
|
18
|
+
function sdkReadinessManagerFactory(EventEmitter, settings, readinessManager) {
|
|
19
|
+
if (readinessManager === void 0) { readinessManager = (0, readinessManager_1.readinessManagerFactory)(EventEmitter, settings); }
|
|
20
|
+
var log = settings.log;
|
|
21
21
|
/** Ready callback warning */
|
|
22
22
|
var internalReadyCbCount = 0;
|
|
23
23
|
var readyCbCount = 0;
|
|
@@ -60,9 +60,8 @@ function sdkReadinessManagerFactory(log, EventEmitter, readyTimeout, readinessMa
|
|
|
60
60
|
}
|
|
61
61
|
return {
|
|
62
62
|
readinessManager: readinessManager,
|
|
63
|
-
shared: function (
|
|
64
|
-
|
|
65
|
-
return sdkReadinessManagerFactory(log, EventEmitter, readyTimeout, readinessManager.shared(readyTimeout));
|
|
63
|
+
shared: function () {
|
|
64
|
+
return sdkReadinessManagerFactory(EventEmitter, settings, readinessManager.shared());
|
|
66
65
|
},
|
|
67
66
|
incInternalReadyCbCount: function () {
|
|
68
67
|
internalReadyCbCount++;
|
|
@@ -17,7 +17,7 @@ function buildInstanceId(key) {
|
|
|
17
17
|
* Therefore, clients don't have a bound TT for the track method.
|
|
18
18
|
*/
|
|
19
19
|
function sdkClientMethodCSFactory(params) {
|
|
20
|
-
var storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, key = _a.core.key,
|
|
20
|
+
var storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, key = _a.core.key, log = _a.log;
|
|
21
21
|
var mainClientInstance = (0, clientCS_1.clientCSDecorator)(log, (0, sdkClient_1.sdkClientFactory)(params), key);
|
|
22
22
|
var parsedDefaultKey = (0, key_2.keyParser)(key);
|
|
23
23
|
var defaultInstanceId = buildInstanceId(parsedDefaultKey);
|
|
@@ -37,7 +37,7 @@ function sdkClientMethodCSFactory(params) {
|
|
|
37
37
|
var instanceId = buildInstanceId(validKey);
|
|
38
38
|
if (!clientInstances[instanceId]) {
|
|
39
39
|
var matchingKey = (0, key_2.getMatching)(validKey);
|
|
40
|
-
var sharedSdkReadiness_1 = sdkReadinessManager.shared(
|
|
40
|
+
var sharedSdkReadiness_1 = sdkReadinessManager.shared();
|
|
41
41
|
var sharedStorage = storage.shared && storage.shared(matchingKey, function (err) {
|
|
42
42
|
if (err) {
|
|
43
43
|
sharedSdkReadiness_1.readinessManager.timeout();
|
|
@@ -19,7 +19,7 @@ function buildInstanceId(key, trafficType) {
|
|
|
19
19
|
* (default client) or the client method (shared clients).
|
|
20
20
|
*/
|
|
21
21
|
function sdkClientMethodCSFactory(params) {
|
|
22
|
-
var storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, _b = _a.core, key = _b.key, trafficType = _b.trafficType,
|
|
22
|
+
var storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, _b = _a.core, key = _b.key, trafficType = _b.trafficType, log = _a.log;
|
|
23
23
|
var mainClientInstance = (0, clientCS_1.clientCSDecorator)(log, (0, sdkClient_1.sdkClientFactory)(params), key, trafficType);
|
|
24
24
|
var parsedDefaultKey = (0, key_2.keyParser)(key);
|
|
25
25
|
var defaultInstanceId = buildInstanceId(parsedDefaultKey, trafficType);
|
|
@@ -46,7 +46,7 @@ function sdkClientMethodCSFactory(params) {
|
|
|
46
46
|
var instanceId = buildInstanceId(validKey, validTrafficType);
|
|
47
47
|
if (!clientInstances[instanceId]) {
|
|
48
48
|
var matchingKey = (0, key_2.getMatching)(validKey);
|
|
49
|
-
var sharedSdkReadiness_1 = sdkReadinessManager.shared(
|
|
49
|
+
var sharedSdkReadiness_1 = sdkReadinessManager.shared();
|
|
50
50
|
var sharedStorage = storage.shared && storage.shared(matchingKey, function (err) {
|
|
51
51
|
if (err) {
|
|
52
52
|
sharedSdkReadiness_1.readinessManager.timeout();
|
package/cjs/sdkFactory/index.js
CHANGED
|
@@ -25,7 +25,7 @@ function sdkFactory(params) {
|
|
|
25
25
|
// On non-recoverable errors, we should mark the SDK as destroyed and not start synchronization.
|
|
26
26
|
// We will just log and allow for the SDK to end up throwing an SDK_TIMEOUT event for devs to handle.
|
|
27
27
|
(0, apiKey_1.validateAndTrackApiKey)(log, settings.core.authorizationKey);
|
|
28
|
-
var sdkReadinessManager = (0, sdkReadinessManager_1.sdkReadinessManagerFactory)(
|
|
28
|
+
var sdkReadinessManager = (0, sdkReadinessManager_1.sdkReadinessManagerFactory)(platform.EventEmitter, settings);
|
|
29
29
|
var readiness = sdkReadinessManager.readinessManager;
|
|
30
30
|
var storage = storageFactory({
|
|
31
31
|
settings: settings,
|
package/cjs/services/splitApi.js
CHANGED
|
@@ -54,15 +54,15 @@ function splitApiFactory(settings, platform, telemetryTracker) {
|
|
|
54
54
|
var url = urls.sdk + "/segmentChanges/" + segmentName + "?since=" + since + (till ? '&till=' + till : '');
|
|
55
55
|
return splitHttpClient(url, noCache ? noCacheHeaderOptions : undefined, telemetryTracker.trackHttp(constants_1.SEGMENT));
|
|
56
56
|
},
|
|
57
|
-
|
|
57
|
+
fetchMemberships: function (userMatchingKey, noCache, till) {
|
|
58
58
|
/**
|
|
59
59
|
* URI encoding of user keys in order to:
|
|
60
|
-
* - avoid 400 responses (due to URI malformed). E.g.: '/api/
|
|
61
|
-
* - avoid 404 responses. E.g.: '/api/
|
|
60
|
+
* - avoid 400 responses (due to URI malformed). E.g.: '/api/memberships/%'
|
|
61
|
+
* - avoid 404 responses. E.g.: '/api/memberships/foo/bar'
|
|
62
62
|
* - match user keys with special characters. E.g.: 'foo%bar', 'foo/bar'
|
|
63
63
|
*/
|
|
64
|
-
var url = urls.sdk + "/
|
|
65
|
-
return splitHttpClient(url, noCache ? noCacheHeaderOptions : undefined, telemetryTracker.trackHttp(constants_1.
|
|
64
|
+
var url = urls.sdk + "/memberships/" + encodeURIComponent(userMatchingKey) + (till ? '?till=' + till : '');
|
|
65
|
+
return splitHttpClient(url, noCache ? noCacheHeaderOptions : undefined, telemetryTracker.trackHttp(constants_1.MEMBERSHIPS));
|
|
66
66
|
},
|
|
67
67
|
/**
|
|
68
68
|
* Post events.
|
|
@@ -9,25 +9,54 @@ var AbstractSegmentsCacheSync = /** @class */ (function () {
|
|
|
9
9
|
function AbstractSegmentsCacheSync() {
|
|
10
10
|
}
|
|
11
11
|
/**
|
|
12
|
-
*
|
|
13
|
-
* For client-side synchronizer: the method is not used.
|
|
14
|
-
*/
|
|
15
|
-
AbstractSegmentsCacheSync.prototype.registerSegments = function (names) { return false; };
|
|
16
|
-
/**
|
|
17
|
-
* For server-side synchronizer: set the change number of `name` segment.
|
|
18
|
-
* For client-side synchronizer: the method is not used.
|
|
12
|
+
* clear the cache.
|
|
19
13
|
*/
|
|
20
|
-
AbstractSegmentsCacheSync.prototype.
|
|
14
|
+
AbstractSegmentsCacheSync.prototype.clear = function () {
|
|
15
|
+
this.resetSegments({});
|
|
16
|
+
};
|
|
21
17
|
/**
|
|
22
|
-
* For server-side synchronizer:
|
|
18
|
+
* For server-side synchronizer: add the given list of segments to the cache, with an empty list of keys. The segments that already exist are not modified.
|
|
23
19
|
* For client-side synchronizer: the method is not used.
|
|
24
20
|
*/
|
|
25
|
-
AbstractSegmentsCacheSync.prototype.
|
|
21
|
+
AbstractSegmentsCacheSync.prototype.registerSegments = function (names) { return false; };
|
|
26
22
|
/**
|
|
27
23
|
* For server-side synchronizer: the method is not used.
|
|
28
|
-
* For client-side synchronizer:
|
|
24
|
+
* For client-side synchronizer: it resets or updates the cache.
|
|
29
25
|
*/
|
|
30
|
-
AbstractSegmentsCacheSync.prototype.resetSegments = function (
|
|
26
|
+
AbstractSegmentsCacheSync.prototype.resetSegments = function (segmentsData) {
|
|
27
|
+
var _this = this;
|
|
28
|
+
this.setChangeNumber(undefined, segmentsData.cn);
|
|
29
|
+
var _a = segmentsData, added = _a.added, removed = _a.removed;
|
|
30
|
+
if (added && removed) {
|
|
31
|
+
var isDiff_1 = false;
|
|
32
|
+
added.forEach(function (segment) {
|
|
33
|
+
isDiff_1 = _this.addToSegment(segment) || isDiff_1;
|
|
34
|
+
});
|
|
35
|
+
removed.forEach(function (segment) {
|
|
36
|
+
isDiff_1 = _this.removeFromSegment(segment) || isDiff_1;
|
|
37
|
+
});
|
|
38
|
+
return isDiff_1;
|
|
39
|
+
}
|
|
40
|
+
var names = (segmentsData.k || []).map(function (s) { return s.n; }).sort();
|
|
41
|
+
var storedSegmentKeys = this.getRegisteredSegments().sort();
|
|
42
|
+
// Extreme fast => everything is empty
|
|
43
|
+
if (!names.length && !storedSegmentKeys.length)
|
|
44
|
+
return false;
|
|
45
|
+
var index = 0;
|
|
46
|
+
while (index < names.length && index < storedSegmentKeys.length && names[index] === storedSegmentKeys[index])
|
|
47
|
+
index++;
|
|
48
|
+
// Quick path => no changes
|
|
49
|
+
if (index === names.length && index === storedSegmentKeys.length)
|
|
50
|
+
return false;
|
|
51
|
+
// Slowest path => add and/or remove segments
|
|
52
|
+
for (var removeIndex = index; removeIndex < storedSegmentKeys.length; removeIndex++) {
|
|
53
|
+
this.removeFromSegment(storedSegmentKeys[removeIndex]);
|
|
54
|
+
}
|
|
55
|
+
for (var addIndex = index; addIndex < names.length; addIndex++) {
|
|
56
|
+
this.addToSegment(names[addIndex]);
|
|
57
|
+
}
|
|
58
|
+
return true;
|
|
59
|
+
};
|
|
31
60
|
return AbstractSegmentsCacheSync;
|
|
32
61
|
}());
|
|
33
62
|
exports.AbstractSegmentsCacheSync = AbstractSegmentsCacheSync;
|
|
@@ -70,7 +70,8 @@ function usesSegments(split) {
|
|
|
70
70
|
for (var i = 0; i < conditions.length; i++) {
|
|
71
71
|
var matchers = conditions[i].matcherGroup.matchers;
|
|
72
72
|
for (var j = 0; j < matchers.length; j++) {
|
|
73
|
-
|
|
73
|
+
var matcher = matchers[j].matcherType;
|
|
74
|
+
if (matcher === constants_1.IN_SEGMENT || matcher === constants_1.IN_LARGE_SEGMENT)
|
|
74
75
|
return true;
|
|
75
76
|
}
|
|
76
77
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.KeyBuilderCS = void 0;
|
|
3
|
+
exports.myLargeSegmentsKeyBuilder = exports.KeyBuilderCS = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
5
|
var lang_1 = require("../utils/lang");
|
|
6
6
|
var KeyBuilder_1 = require("./KeyBuilder");
|
|
@@ -24,10 +24,6 @@ var KeyBuilderCS = /** @class */ (function (_super) {
|
|
|
24
24
|
return builtSegmentKeyName.substr(prefix.length);
|
|
25
25
|
};
|
|
26
26
|
// @BREAKING: The key used to start with the matching key instead of the prefix, this was changed on version 10.17.3
|
|
27
|
-
KeyBuilderCS.prototype.buildOldSegmentNameKey = function (segmentName) {
|
|
28
|
-
return this.matchingKey + "." + this.prefix + ".segment." + segmentName;
|
|
29
|
-
};
|
|
30
|
-
// @BREAKING: The key used to start with the matching key instead of the prefix, this was changed on version 10.17.3
|
|
31
27
|
KeyBuilderCS.prototype.extractOldSegmentKey = function (builtSegmentKeyName) {
|
|
32
28
|
var prefix = this.matchingKey + "." + this.prefix + ".segment.";
|
|
33
29
|
if ((0, lang_1.startsWith)(builtSegmentKeyName, prefix))
|
|
@@ -39,6 +35,28 @@ var KeyBuilderCS = /** @class */ (function (_super) {
|
|
|
39
35
|
KeyBuilderCS.prototype.isSplitsCacheKey = function (key) {
|
|
40
36
|
return this.regexSplitsCacheKey.test(key);
|
|
41
37
|
};
|
|
38
|
+
KeyBuilderCS.prototype.buildTillKey = function () {
|
|
39
|
+
return this.prefix + "." + this.matchingKey + ".segments.till";
|
|
40
|
+
};
|
|
42
41
|
return KeyBuilderCS;
|
|
43
42
|
}(KeyBuilder_1.KeyBuilder));
|
|
44
43
|
exports.KeyBuilderCS = KeyBuilderCS;
|
|
44
|
+
function myLargeSegmentsKeyBuilder(prefix, matchingKey) {
|
|
45
|
+
return {
|
|
46
|
+
buildSegmentNameKey: function (segmentName) {
|
|
47
|
+
return prefix + "." + matchingKey + ".largeSegment." + segmentName;
|
|
48
|
+
},
|
|
49
|
+
extractSegmentName: function (builtSegmentKeyName) {
|
|
50
|
+
var p = prefix + "." + matchingKey + ".largeSegment.";
|
|
51
|
+
if ((0, lang_1.startsWith)(builtSegmentKeyName, p))
|
|
52
|
+
return builtSegmentKeyName.substr(p.length);
|
|
53
|
+
},
|
|
54
|
+
extractOldSegmentKey: function () {
|
|
55
|
+
return undefined;
|
|
56
|
+
},
|
|
57
|
+
buildTillKey: function () {
|
|
58
|
+
return prefix + "." + matchingKey + ".largeSegments.till";
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
exports.myLargeSegmentsKeyBuilder = myLargeSegmentsKeyBuilder;
|
|
@@ -45,7 +45,7 @@ function dataLoaderFactory(preloadedData) {
|
|
|
45
45
|
return Array.isArray(userIds) && userIds.indexOf(userId) > -1;
|
|
46
46
|
});
|
|
47
47
|
}
|
|
48
|
-
storage.segments.resetSegments(mySegmentsData);
|
|
48
|
+
storage.segments.resetSegments({ k: mySegmentsData.map(function (s) { return ({ n: s }); }) });
|
|
49
49
|
};
|
|
50
50
|
}
|
|
51
51
|
exports.dataLoaderFactory = dataLoaderFactory;
|
|
@@ -2,6 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.MySegmentsCacheInLocal = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
|
+
var lang_1 = require("../../utils/lang");
|
|
5
6
|
var AbstractSegmentsCacheSync_1 = require("../AbstractSegmentsCacheSync");
|
|
6
7
|
var constants_1 = require("./constants");
|
|
7
8
|
var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
@@ -13,19 +14,11 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
|
13
14
|
return _this;
|
|
14
15
|
// There is not need to flush segments cache like splits cache, since resetSegments receives the up-to-date list of active segments
|
|
15
16
|
}
|
|
16
|
-
/**
|
|
17
|
-
* Removes list of segments from localStorage
|
|
18
|
-
* @NOTE this method is not being used at the moment.
|
|
19
|
-
*/
|
|
20
|
-
MySegmentsCacheInLocal.prototype.clear = function () {
|
|
21
|
-
this.log.info(constants_1.LOG_PREFIX + 'Flushing MySegments data from localStorage');
|
|
22
|
-
// We cannot simply call `localStorage.clear()` since that implies removing user items from the storage
|
|
23
|
-
// We could optimize next sentence, since it implies iterating over all localStorage items
|
|
24
|
-
this.resetSegments([]);
|
|
25
|
-
};
|
|
26
17
|
MySegmentsCacheInLocal.prototype.addToSegment = function (name) {
|
|
27
18
|
var segmentKey = this.keys.buildSegmentNameKey(name);
|
|
28
19
|
try {
|
|
20
|
+
if (localStorage.getItem(segmentKey) === constants_1.DEFINED)
|
|
21
|
+
return false;
|
|
29
22
|
localStorage.setItem(segmentKey, constants_1.DEFINED);
|
|
30
23
|
return true;
|
|
31
24
|
}
|
|
@@ -37,6 +30,8 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
|
37
30
|
MySegmentsCacheInLocal.prototype.removeFromSegment = function (name) {
|
|
38
31
|
var segmentKey = this.keys.buildSegmentNameKey(name);
|
|
39
32
|
try {
|
|
33
|
+
if (localStorage.getItem(segmentKey) !== constants_1.DEFINED)
|
|
34
|
+
return false;
|
|
40
35
|
localStorage.removeItem(segmentKey);
|
|
41
36
|
return true;
|
|
42
37
|
}
|
|
@@ -48,30 +43,22 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
|
48
43
|
MySegmentsCacheInLocal.prototype.isInSegment = function (name) {
|
|
49
44
|
return localStorage.getItem(this.keys.buildSegmentNameKey(name)) === constants_1.DEFINED;
|
|
50
45
|
};
|
|
51
|
-
|
|
52
|
-
* Reset (update) the cached list of segments with the given list, removing and adding segments if necessary.
|
|
53
|
-
*
|
|
54
|
-
* @param {string[]} segmentNames list of segment names
|
|
55
|
-
* @returns boolean indicating if the cache was updated (i.e., given list was different from the cached one)
|
|
56
|
-
*/
|
|
57
|
-
MySegmentsCacheInLocal.prototype.resetSegments = function (names) {
|
|
46
|
+
MySegmentsCacheInLocal.prototype.getRegisteredSegments = function () {
|
|
58
47
|
var _this = this;
|
|
59
|
-
var isDiff = false;
|
|
60
|
-
var index;
|
|
61
48
|
// Scan current values from localStorage
|
|
62
|
-
|
|
49
|
+
return Object.keys(localStorage).reduce(function (accum, key) {
|
|
63
50
|
var segmentName = _this.keys.extractSegmentName(key);
|
|
64
51
|
if (segmentName) {
|
|
65
52
|
accum.push(segmentName);
|
|
66
53
|
}
|
|
67
54
|
else {
|
|
68
|
-
// @TODO @BREAKING: This is only to clean up "old" keys. Remove this whole else code block
|
|
55
|
+
// @TODO @BREAKING: This is only to clean up "old" keys. Remove this whole else code block
|
|
69
56
|
segmentName = _this.keys.extractOldSegmentKey(key);
|
|
70
57
|
if (segmentName) { // this was an old segment key, let's clean up.
|
|
71
58
|
var newSegmentKey = _this.keys.buildSegmentNameKey(segmentName);
|
|
72
59
|
try {
|
|
73
60
|
// If the new format key is not there, create it.
|
|
74
|
-
if (!localStorage.getItem(newSegmentKey)
|
|
61
|
+
if (!localStorage.getItem(newSegmentKey)) {
|
|
75
62
|
localStorage.setItem(newSegmentKey, constants_1.DEFINED);
|
|
76
63
|
// we are migrating a segment, let's track it.
|
|
77
64
|
accum.push(segmentName);
|
|
@@ -85,40 +72,30 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
|
85
72
|
}
|
|
86
73
|
return accum;
|
|
87
74
|
}, []);
|
|
88
|
-
// Extreme fast => everything is empty
|
|
89
|
-
if (names.length === 0 && storedSegmentNames.length === names.length)
|
|
90
|
-
return isDiff;
|
|
91
|
-
// Quick path
|
|
92
|
-
if (storedSegmentNames.length !== names.length) {
|
|
93
|
-
isDiff = true;
|
|
94
|
-
storedSegmentNames.forEach(function (name) { return _this.removeFromSegment(name); });
|
|
95
|
-
names.forEach(function (name) { return _this.addToSegment(name); });
|
|
96
|
-
}
|
|
97
|
-
else {
|
|
98
|
-
// Slowest path => we need to find at least 1 difference because
|
|
99
|
-
for (index = 0; index < names.length && storedSegmentNames.indexOf(names[index]) !== -1; index++) {
|
|
100
|
-
// TODO: why empty statement?
|
|
101
|
-
}
|
|
102
|
-
if (index < names.length) {
|
|
103
|
-
isDiff = true;
|
|
104
|
-
storedSegmentNames.forEach(function (name) { return _this.removeFromSegment(name); });
|
|
105
|
-
names.forEach(function (name) { return _this.addToSegment(name); });
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
return isDiff;
|
|
109
|
-
};
|
|
110
|
-
MySegmentsCacheInLocal.prototype.getRegisteredSegments = function () {
|
|
111
|
-
var _this = this;
|
|
112
|
-
return Object.keys(localStorage).reduce(function (accum, key) {
|
|
113
|
-
var segmentName = _this.keys.extractSegmentName(key);
|
|
114
|
-
if (segmentName)
|
|
115
|
-
accum.push(segmentName);
|
|
116
|
-
return accum;
|
|
117
|
-
}, []);
|
|
118
75
|
};
|
|
119
76
|
MySegmentsCacheInLocal.prototype.getKeysCount = function () {
|
|
120
77
|
return 1;
|
|
121
78
|
};
|
|
79
|
+
MySegmentsCacheInLocal.prototype.setChangeNumber = function (name, changeNumber) {
|
|
80
|
+
try {
|
|
81
|
+
if (changeNumber)
|
|
82
|
+
localStorage.setItem(this.keys.buildTillKey(), changeNumber + '');
|
|
83
|
+
else
|
|
84
|
+
localStorage.removeItem(this.keys.buildTillKey());
|
|
85
|
+
}
|
|
86
|
+
catch (e) {
|
|
87
|
+
this.log.error(e);
|
|
88
|
+
}
|
|
89
|
+
};
|
|
90
|
+
MySegmentsCacheInLocal.prototype.getChangeNumber = function () {
|
|
91
|
+
var n = -1;
|
|
92
|
+
var value = localStorage.getItem(this.keys.buildTillKey());
|
|
93
|
+
if (value !== null) {
|
|
94
|
+
value = parseInt(value, 10);
|
|
95
|
+
return (0, lang_1.isNaNNumber)(value) ? n : value;
|
|
96
|
+
}
|
|
97
|
+
return n;
|
|
98
|
+
};
|
|
122
99
|
return MySegmentsCacheInLocal;
|
|
123
100
|
}(AbstractSegmentsCacheSync_1.AbstractSegmentsCacheSync));
|
|
124
101
|
exports.MySegmentsCacheInLocal = MySegmentsCacheInLocal;
|
|
@@ -36,9 +36,11 @@ function InLocalStorage(options) {
|
|
|
36
36
|
var expirationTimestamp = Date.now() - browser_1.DEFAULT_CACHE_EXPIRATION_IN_MILLIS;
|
|
37
37
|
var splits = new SplitsCacheInLocal_1.SplitsCacheInLocal(settings, keys, expirationTimestamp);
|
|
38
38
|
var segments = new MySegmentsCacheInLocal_1.MySegmentsCacheInLocal(log, keys);
|
|
39
|
+
var largeSegments = new MySegmentsCacheInLocal_1.MySegmentsCacheInLocal(log, (0, KeyBuilderCS_1.myLargeSegmentsKeyBuilder)(prefix, matchingKey));
|
|
39
40
|
return {
|
|
40
41
|
splits: splits,
|
|
41
42
|
segments: segments,
|
|
43
|
+
largeSegments: largeSegments,
|
|
42
44
|
impressions: new ImpressionsCacheInMemory_1.ImpressionsCacheInMemory(impressionsQueueSize),
|
|
43
45
|
impressionCounts: impressionsMode !== constants_2.DEBUG ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
|
|
44
46
|
events: new EventsCacheInMemory_1.EventsCacheInMemory(eventsQueueSize),
|
|
@@ -48,6 +50,7 @@ function InLocalStorage(options) {
|
|
|
48
50
|
var _a;
|
|
49
51
|
this.splits = new SplitsCacheInMemory_1.SplitsCacheInMemory(__splitFiltersValidation);
|
|
50
52
|
this.segments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
|
|
53
|
+
this.largeSegments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
|
|
51
54
|
this.impressions.clear();
|
|
52
55
|
this.impressionCounts && this.impressionCounts.clear();
|
|
53
56
|
this.events.clear();
|
|
@@ -55,10 +58,10 @@ function InLocalStorage(options) {
|
|
|
55
58
|
},
|
|
56
59
|
// When using shared instanciation with MEMORY we reuse everything but segments (they are customer per key).
|
|
57
60
|
shared: function (matchingKey) {
|
|
58
|
-
var childKeysBuilder = new KeyBuilderCS_1.KeyBuilderCS(prefix, matchingKey);
|
|
59
61
|
return {
|
|
60
62
|
splits: this.splits,
|
|
61
|
-
segments: new MySegmentsCacheInLocal_1.MySegmentsCacheInLocal(log,
|
|
63
|
+
segments: new MySegmentsCacheInLocal_1.MySegmentsCacheInLocal(log, new KeyBuilderCS_1.KeyBuilderCS(prefix, matchingKey)),
|
|
64
|
+
largeSegments: new MySegmentsCacheInLocal_1.MySegmentsCacheInLocal(log, (0, KeyBuilderCS_1.myLargeSegmentsKeyBuilder)(prefix, matchingKey)),
|
|
62
65
|
impressions: this.impressions,
|
|
63
66
|
impressionCounts: this.impressionCounts,
|
|
64
67
|
events: this.events,
|
|
@@ -66,6 +69,7 @@ function InLocalStorage(options) {
|
|
|
66
69
|
destroy: function () {
|
|
67
70
|
this.splits = new SplitsCacheInMemory_1.SplitsCacheInMemory(__splitFiltersValidation);
|
|
68
71
|
this.segments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
|
|
72
|
+
this.largeSegments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
|
|
69
73
|
}
|
|
70
74
|
};
|
|
71
75
|
},
|
|
@@ -18,9 +18,11 @@ function InMemoryStorageCSFactory(params) {
|
|
|
18
18
|
var _a = params.settings, _b = _a.scheduler, impressionsQueueSize = _b.impressionsQueueSize, eventsQueueSize = _b.eventsQueueSize, _c = _a.sync, impressionsMode = _c.impressionsMode, __splitFiltersValidation = _c.__splitFiltersValidation;
|
|
19
19
|
var splits = new SplitsCacheInMemory_1.SplitsCacheInMemory(__splitFiltersValidation);
|
|
20
20
|
var segments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
|
|
21
|
+
var largeSegments = new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory();
|
|
21
22
|
var storage = {
|
|
22
23
|
splits: splits,
|
|
23
24
|
segments: segments,
|
|
25
|
+
largeSegments: largeSegments,
|
|
24
26
|
impressions: new ImpressionsCacheInMemory_1.ImpressionsCacheInMemory(impressionsQueueSize),
|
|
25
27
|
impressionCounts: impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory() : undefined,
|
|
26
28
|
events: new EventsCacheInMemory_1.EventsCacheInMemory(eventsQueueSize),
|
|
@@ -30,6 +32,7 @@ function InMemoryStorageCSFactory(params) {
|
|
|
30
32
|
destroy: function () {
|
|
31
33
|
this.splits.clear();
|
|
32
34
|
this.segments.clear();
|
|
35
|
+
this.largeSegments.clear();
|
|
33
36
|
this.impressions.clear();
|
|
34
37
|
this.impressionCounts && this.impressionCounts.clear();
|
|
35
38
|
this.events.clear();
|
|
@@ -40,6 +43,7 @@ function InMemoryStorageCSFactory(params) {
|
|
|
40
43
|
return {
|
|
41
44
|
splits: this.splits,
|
|
42
45
|
segments: new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory(),
|
|
46
|
+
largeSegments: new MySegmentsCacheInMemory_1.MySegmentsCacheInMemory(),
|
|
43
47
|
impressions: this.impressions,
|
|
44
48
|
impressionCounts: this.impressionCounts,
|
|
45
49
|
events: this.events,
|
|
@@ -48,6 +52,7 @@ function InMemoryStorageCSFactory(params) {
|
|
|
48
52
|
destroy: function () {
|
|
49
53
|
this.splits = new SplitsCacheInMemory_1.SplitsCacheInMemory(__splitFiltersValidation);
|
|
50
54
|
this.segments.clear();
|
|
55
|
+
this.largeSegments.clear();
|
|
51
56
|
}
|
|
52
57
|
};
|
|
53
58
|
},
|