@splitsoftware/splitio-commons 1.17.1-rc.3 → 2.0.0-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGES.txt +7 -3
- package/cjs/evaluator/index.js +2 -2
- package/cjs/evaluator/matchers/semver_inlist.js +1 -2
- package/cjs/evaluator/matchers/whitelist.js +1 -2
- package/cjs/listeners/browser.js +1 -2
- package/cjs/logger/browser/DebugLogger.js +1 -2
- package/cjs/logger/browser/ErrorLogger.js +1 -2
- package/cjs/logger/browser/InfoLogger.js +1 -2
- package/cjs/logger/browser/WarnLogger.js +1 -2
- package/cjs/logger/index.js +1 -2
- package/cjs/readiness/readinessManager.js +5 -7
- package/cjs/sdkClient/clientCS.js +5 -8
- package/cjs/sdkClient/sdkClientMethodCS.js +5 -8
- package/cjs/sdkFactory/index.js +10 -33
- package/cjs/services/decorateHeaders.js +1 -2
- package/cjs/storages/AbstractSplitsCacheAsync.js +7 -0
- package/cjs/storages/AbstractSplitsCacheSync.js +7 -0
- package/cjs/storages/KeyBuilderCS.js +0 -9
- package/cjs/storages/dataLoader.js +32 -64
- package/cjs/storages/inLocalStorage/MySegmentsCacheInLocal.js +1 -21
- package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +14 -7
- package/cjs/storages/inLocalStorage/index.js +1 -6
- package/cjs/storages/inMemory/InMemoryStorageCS.js +4 -16
- package/cjs/storages/inMemory/SegmentsCacheInMemory.js +3 -4
- package/cjs/storages/inMemory/SplitsCacheInMemory.js +2 -3
- package/cjs/storages/inMemory/UniqueKeysCacheInMemory.js +2 -3
- package/cjs/storages/inMemory/UniqueKeysCacheInMemoryCS.js +2 -3
- package/cjs/storages/inRedis/RedisAdapter.js +3 -4
- package/cjs/storages/inRedis/SplitsCacheInRedis.js +1 -1
- package/cjs/storages/inRedis/TelemetryCacheInRedis.js +3 -4
- package/cjs/storages/inRedis/UniqueKeysCacheInRedis.js +1 -2
- package/cjs/storages/pluggable/SplitsCachePluggable.js +1 -1
- package/cjs/storages/pluggable/TelemetryCachePluggable.js +6 -7
- package/cjs/storages/pluggable/UniqueKeysCachePluggable.js +1 -2
- package/cjs/storages/pluggable/inMemoryWrapper.js +7 -8
- package/cjs/storages/pluggable/index.js +32 -37
- package/cjs/sync/offline/syncTasks/fromObjectSyncTask.js +7 -2
- package/cjs/sync/polling/pollingManagerSS.js +3 -3
- package/cjs/sync/polling/updaters/splitChangesUpdater.js +13 -5
- package/cjs/sync/streaming/parseUtils.js +0 -1
- package/cjs/sync/streaming/pushManager.js +2 -3
- package/cjs/trackers/eventTracker.js +9 -11
- package/cjs/trackers/impressionsTracker.js +13 -15
- package/cjs/trackers/uniqueKeysTracker.js +3 -5
- package/cjs/utils/LRUCache/index.js +1 -2
- package/cjs/utils/constants/browser.js +1 -4
- package/cjs/utils/lang/index.js +6 -9
- package/cjs/utils/lang/objectAssign.js +12 -77
- package/cjs/utils/lang/sets.js +3 -110
- package/cjs/utils/settingsValidation/index.js +0 -9
- package/cjs/utils/settingsValidation/logger/builtinLogger.js +1 -2
- package/cjs/utils/settingsValidation/storage/storageCS.js +12 -1
- package/esm/evaluator/index.js +3 -3
- package/esm/evaluator/matchers/semver_inlist.js +1 -2
- package/esm/evaluator/matchers/whitelist.js +1 -2
- package/esm/listeners/browser.js +1 -2
- package/esm/logger/browser/DebugLogger.js +1 -2
- package/esm/logger/browser/ErrorLogger.js +1 -2
- package/esm/logger/browser/InfoLogger.js +1 -2
- package/esm/logger/browser/WarnLogger.js +1 -2
- package/esm/logger/index.js +1 -2
- package/esm/readiness/readinessManager.js +5 -7
- package/esm/sdkClient/clientCS.js +5 -8
- package/esm/sdkClient/sdkClientMethodCS.js +5 -8
- package/esm/sdkFactory/index.js +11 -34
- package/esm/services/decorateHeaders.js +1 -2
- package/esm/storages/AbstractSplitsCacheAsync.js +7 -0
- package/esm/storages/AbstractSplitsCacheSync.js +7 -0
- package/esm/storages/KeyBuilderCS.js +0 -9
- package/esm/storages/dataLoader.js +30 -61
- package/esm/storages/inLocalStorage/MySegmentsCacheInLocal.js +1 -21
- package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +14 -7
- package/esm/storages/inLocalStorage/index.js +2 -7
- package/esm/storages/inMemory/InMemoryStorageCS.js +4 -16
- package/esm/storages/inMemory/SegmentsCacheInMemory.js +3 -4
- package/esm/storages/inMemory/SplitsCacheInMemory.js +2 -3
- package/esm/storages/inMemory/UniqueKeysCacheInMemory.js +2 -3
- package/esm/storages/inMemory/UniqueKeysCacheInMemoryCS.js +2 -3
- package/esm/storages/inRedis/RedisAdapter.js +3 -4
- package/esm/storages/inRedis/SplitsCacheInRedis.js +2 -2
- package/esm/storages/inRedis/TelemetryCacheInRedis.js +3 -4
- package/esm/storages/inRedis/UniqueKeysCacheInRedis.js +1 -2
- package/esm/storages/pluggable/SplitsCachePluggable.js +2 -2
- package/esm/storages/pluggable/TelemetryCachePluggable.js +6 -7
- package/esm/storages/pluggable/UniqueKeysCachePluggable.js +1 -2
- package/esm/storages/pluggable/inMemoryWrapper.js +7 -8
- package/esm/storages/pluggable/index.js +32 -37
- package/esm/sync/offline/syncTasks/fromObjectSyncTask.js +8 -3
- package/esm/sync/polling/pollingManagerSS.js +3 -3
- package/esm/sync/polling/updaters/splitChangesUpdater.js +14 -6
- package/esm/sync/streaming/parseUtils.js +0 -1
- package/esm/sync/streaming/pushManager.js +2 -3
- package/esm/trackers/eventTracker.js +9 -11
- package/esm/trackers/impressionsTracker.js +13 -15
- package/esm/trackers/uniqueKeysTracker.js +3 -5
- package/esm/utils/LRUCache/index.js +1 -2
- package/esm/utils/constants/browser.js +0 -3
- package/esm/utils/lang/index.js +6 -9
- package/esm/utils/lang/objectAssign.js +12 -77
- package/esm/utils/lang/sets.js +2 -107
- package/esm/utils/settingsValidation/index.js +0 -9
- package/esm/utils/settingsValidation/logger/builtinLogger.js +1 -2
- package/esm/utils/settingsValidation/storage/storageCS.js +10 -0
- package/package.json +2 -2
- package/src/evaluator/index.ts +5 -5
- package/src/evaluator/matchers/semver_inlist.ts +1 -2
- package/src/evaluator/matchers/whitelist.ts +1 -3
- package/src/listeners/browser.ts +1 -2
- package/src/logger/browser/DebugLogger.ts +1 -2
- package/src/logger/browser/ErrorLogger.ts +1 -2
- package/src/logger/browser/InfoLogger.ts +1 -2
- package/src/logger/browser/WarnLogger.ts +1 -2
- package/src/logger/index.ts +3 -4
- package/src/readiness/readinessManager.ts +7 -9
- package/src/readiness/types.ts +0 -1
- package/src/sdkClient/clientCS.ts +5 -8
- package/src/sdkClient/sdkClientMethodCS.ts +3 -6
- package/src/sdkFactory/index.ts +12 -37
- package/src/sdkFactory/types.ts +1 -4
- package/src/services/decorateHeaders.ts +1 -2
- package/src/storages/AbstractSplitsCacheAsync.ts +9 -2
- package/src/storages/AbstractSplitsCacheSync.ts +9 -2
- package/src/storages/KeyBuilderCS.ts +0 -13
- package/src/storages/dataLoader.ts +32 -62
- package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +1 -21
- package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +16 -8
- package/src/storages/inLocalStorage/index.ts +2 -8
- package/src/storages/inMemory/InMemoryStorageCS.ts +4 -19
- package/src/storages/inMemory/SegmentsCacheInMemory.ts +4 -5
- package/src/storages/inMemory/SplitsCacheInMemory.ts +4 -5
- package/src/storages/inMemory/UniqueKeysCacheInMemory.ts +4 -5
- package/src/storages/inMemory/UniqueKeysCacheInMemoryCS.ts +4 -5
- package/src/storages/inRedis/RedisAdapter.ts +4 -5
- package/src/storages/inRedis/SplitsCacheInRedis.ts +3 -3
- package/src/storages/inRedis/TelemetryCacheInRedis.ts +3 -4
- package/src/storages/inRedis/UniqueKeysCacheInRedis.ts +1 -2
- package/src/storages/pluggable/SegmentsCachePluggable.ts +0 -1
- package/src/storages/pluggable/SplitsCachePluggable.ts +3 -3
- package/src/storages/pluggable/TelemetryCachePluggable.ts +6 -7
- package/src/storages/pluggable/UniqueKeysCachePluggable.ts +1 -2
- package/src/storages/pluggable/inMemoryWrapper.ts +8 -9
- package/src/storages/pluggable/index.ts +33 -38
- package/src/storages/types.ts +9 -6
- package/src/sync/offline/syncTasks/fromObjectSyncTask.ts +7 -3
- package/src/sync/polling/pollingManagerSS.ts +2 -3
- package/src/sync/polling/updaters/splitChangesUpdater.ts +15 -8
- package/src/sync/streaming/parseUtils.ts +0 -1
- package/src/sync/streaming/pushManager.ts +3 -4
- package/src/sync/submitters/types.ts +3 -4
- package/src/trackers/eventTracker.ts +7 -10
- package/src/trackers/impressionsTracker.ts +9 -12
- package/src/trackers/types.ts +0 -1
- package/src/trackers/uniqueKeysTracker.ts +4 -6
- package/src/types.ts +9 -18
- package/src/utils/LRUCache/index.ts +2 -3
- package/src/utils/constants/browser.ts +0 -4
- package/src/utils/lang/index.ts +6 -7
- package/src/utils/lang/objectAssign.ts +13 -92
- package/src/utils/lang/sets.ts +3 -125
- package/src/utils/settingsValidation/index.ts +0 -10
- package/src/utils/settingsValidation/logger/builtinLogger.ts +1 -2
- package/src/utils/settingsValidation/storage/storageCS.ts +13 -0
- package/src/utils/settingsValidation/types.ts +0 -2
- package/types/logger/index.d.ts +1 -2
- package/types/readiness/types.d.ts +0 -1
- package/types/sdkClient/clientCS.d.ts +2 -3
- package/types/sdkFactory/types.d.ts +1 -3
- package/types/storages/AbstractSplitsCacheAsync.d.ts +6 -2
- package/types/storages/AbstractSplitsCacheSync.d.ts +6 -2
- package/types/storages/KeyBuilderCS.d.ts +0 -2
- package/types/storages/dataLoader.d.ts +6 -17
- package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +7 -2
- package/types/storages/inMemory/SplitsCacheInMemory.d.ts +1 -2
- package/types/storages/inMemory/UniqueKeysCacheInMemory.d.ts +2 -3
- package/types/storages/inRedis/SplitsCacheInRedis.d.ts +1 -2
- package/types/storages/pluggable/SplitsCachePluggable.d.ts +1 -2
- package/types/storages/pluggable/inMemoryWrapper.d.ts +1 -2
- package/types/storages/types.d.ts +7 -6
- package/types/sync/polling/updaters/splitChangesUpdater.d.ts +1 -2
- package/types/sync/submitters/types.d.ts +3 -4
- package/types/trackers/eventTracker.d.ts +1 -1
- package/types/trackers/impressionsTracker.d.ts +1 -1
- package/types/trackers/types.d.ts +0 -1
- package/types/types.d.ts +9 -17
- package/types/utils/LRUCache/index.d.ts +1 -2
- package/types/utils/constants/browser.d.ts +0 -2
- package/types/utils/lang/objectAssign.d.ts +3 -0
- package/types/utils/lang/sets.d.ts +1 -61
- package/types/utils/settingsValidation/index.d.ts +0 -1
- package/types/utils/settingsValidation/storage/storageCS.d.ts +5 -0
- package/types/utils/settingsValidation/types.d.ts +0 -2
- package/cjs/integrations/browser.js +0 -31
- package/cjs/integrations/ga/GaToSplit.js +0 -257
- package/cjs/integrations/ga/GoogleAnalyticsToSplit.js +0 -14
- package/cjs/integrations/ga/SplitToGa.js +0 -123
- package/cjs/integrations/ga/SplitToGoogleAnalytics.js +0 -14
- package/cjs/integrations/ga/types.js +0 -2
- package/cjs/sdkClient/sdkClientMethodCSWithTT.js +0 -79
- package/cjs/utils/lang/maps.js +0 -96
- package/esm/integrations/browser.js +0 -27
- package/esm/integrations/ga/GaToSplit.js +0 -250
- package/esm/integrations/ga/GoogleAnalyticsToSplit.js +0 -10
- package/esm/integrations/ga/SplitToGa.js +0 -120
- package/esm/integrations/ga/SplitToGoogleAnalytics.js +0 -10
- package/esm/integrations/ga/types.js +0 -1
- package/esm/sdkClient/sdkClientMethodCSWithTT.js +0 -75
- package/esm/utils/lang/maps.js +0 -92
- package/src/integrations/browser.ts +0 -35
- package/src/integrations/ga/GaToSplit.ts +0 -299
- package/src/integrations/ga/GoogleAnalyticsToSplit.ts +0 -14
- package/src/integrations/ga/SplitToGa.ts +0 -135
- package/src/integrations/ga/SplitToGoogleAnalytics.ts +0 -14
- package/src/integrations/ga/autoRequire.js +0 -33
- package/src/integrations/ga/types.ts +0 -153
- package/src/sdkClient/sdkClientMethodCSWithTT.ts +0 -101
- package/src/utils/lang/maps.ts +0 -108
|
@@ -1,16 +1,15 @@
|
|
|
1
1
|
import { objectAssign } from '../utils/lang/objectAssign';
|
|
2
2
|
import { clientAttributesDecoration } from './clientAttributesDecoration';
|
|
3
3
|
/**
|
|
4
|
-
* Decorator that binds a key
|
|
4
|
+
* Decorator that binds a key to client methods
|
|
5
5
|
*
|
|
6
6
|
* @param client sync client instance
|
|
7
7
|
* @param key validated split key
|
|
8
|
-
* @param trafficType validated traffic type
|
|
9
8
|
*/
|
|
10
|
-
export function clientCSDecorator(log, client, key
|
|
9
|
+
export function clientCSDecorator(log, client, key) {
|
|
11
10
|
var clientCS = clientAttributesDecoration(log, client);
|
|
12
11
|
return objectAssign(clientCS, {
|
|
13
|
-
// In the client-side API, we bind a key to the client `getTreatment*` methods
|
|
12
|
+
// In the client-side API, we bind a key to the client `getTreatment*` and `track` methods
|
|
14
13
|
getTreatment: clientCS.getTreatment.bind(clientCS, key),
|
|
15
14
|
getTreatmentWithConfig: clientCS.getTreatmentWithConfig.bind(clientCS, key),
|
|
16
15
|
getTreatments: clientCS.getTreatments.bind(clientCS, key),
|
|
@@ -19,11 +18,9 @@ export function clientCSDecorator(log, client, key, trafficType) {
|
|
|
19
18
|
getTreatmentsWithConfigByFlagSets: clientCS.getTreatmentsWithConfigByFlagSets.bind(clientCS, key),
|
|
20
19
|
getTreatmentsByFlagSet: clientCS.getTreatmentsByFlagSet.bind(clientCS, key),
|
|
21
20
|
getTreatmentsWithConfigByFlagSet: clientCS.getTreatmentsWithConfigByFlagSet.bind(clientCS, key),
|
|
22
|
-
|
|
23
|
-
track: trafficType ? clientCS.track.bind(clientCS, key, trafficType) : clientCS.track.bind(clientCS, key),
|
|
21
|
+
track: clientCS.track.bind(clientCS, key),
|
|
24
22
|
// Not part of the public API. These properties are used to support other modules (e.g., Split Suite)
|
|
25
23
|
isClientSide: true,
|
|
26
|
-
key: key
|
|
27
|
-
trafficType: trafficType
|
|
24
|
+
key: key
|
|
28
25
|
});
|
|
29
26
|
}
|
|
@@ -11,7 +11,7 @@ import { buildInstanceId } from './identity';
|
|
|
11
11
|
* Therefore, clients don't have a bound TT for the track method.
|
|
12
12
|
*/
|
|
13
13
|
export function sdkClientMethodCSFactory(params) {
|
|
14
|
-
var clients = params.clients, storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, key = _a.core.key, log = _a.log
|
|
14
|
+
var clients = params.clients, storage = params.storage, syncManager = params.syncManager, sdkReadinessManager = params.sdkReadinessManager, _a = params.settings, key = _a.core.key, log = _a.log;
|
|
15
15
|
var mainClientInstance = clientCSDecorator(log, sdkClientFactory(params), key);
|
|
16
16
|
var parsedDefaultKey = keyParser(key);
|
|
17
17
|
var defaultInstanceId = buildInstanceId(parsedDefaultKey);
|
|
@@ -22,7 +22,7 @@ export function sdkClientMethodCSFactory(params) {
|
|
|
22
22
|
log.debug(RETRIEVE_CLIENT_DEFAULT);
|
|
23
23
|
return mainClientInstance;
|
|
24
24
|
}
|
|
25
|
-
// Validate the key value
|
|
25
|
+
// Validate the key value
|
|
26
26
|
var validKey = validateKey(log, key, LOG_PREFIX_CLIENT_INSTANTIATION);
|
|
27
27
|
if (validKey === false) {
|
|
28
28
|
throw new Error('Shared Client needs a valid key.');
|
|
@@ -44,18 +44,15 @@ export function sdkClientMethodCSFactory(params) {
|
|
|
44
44
|
// - Consumer mode: both syncManager and sharedSyncManager are undefined
|
|
45
45
|
// - Consumer partial mode: syncManager is defined (only for submitters) but sharedSyncManager is undefined
|
|
46
46
|
// @ts-ignore
|
|
47
|
-
var
|
|
47
|
+
var sharedSyncManager = syncManager && sharedStorage && syncManager.shared(matchingKey, sharedSdkReadiness_1.readinessManager, sharedStorage);
|
|
48
48
|
// As shared clients reuse all the storage information, we don't need to check here if we
|
|
49
49
|
// will use offline or online mode. We should stick with the original decision.
|
|
50
50
|
clients[instanceId] = clientCSDecorator(log, sdkClientFactory(objectAssign({}, params, {
|
|
51
51
|
sdkReadinessManager: sharedSdkReadiness_1,
|
|
52
52
|
storage: sharedStorage || storage,
|
|
53
|
-
syncManager:
|
|
53
|
+
syncManager: sharedSyncManager,
|
|
54
54
|
}), true), validKey);
|
|
55
|
-
|
|
56
|
-
sharedSdkReadiness_1.readinessManager.init();
|
|
57
|
-
sharedSyncManager_1 && sharedSyncManager_1.start();
|
|
58
|
-
});
|
|
55
|
+
sharedSyncManager && sharedSyncManager.start();
|
|
59
56
|
log.info(NEW_SHARED_CLIENT);
|
|
60
57
|
}
|
|
61
58
|
else {
|
package/esm/sdkFactory/index.js
CHANGED
|
@@ -5,7 +5,7 @@ import { telemetryTrackerFactory } from '../trackers/telemetryTracker';
|
|
|
5
5
|
import { validateAndTrackApiKey } from '../utils/inputValidation/apiKey';
|
|
6
6
|
import { createLoggerAPI } from '../logger/sdkLogger';
|
|
7
7
|
import { NEW_FACTORY, RETRIEVE_MANAGER } from '../logger/constants';
|
|
8
|
-
import { SDK_SPLITS_ARRIVED, SDK_SEGMENTS_ARRIVED
|
|
8
|
+
import { SDK_SPLITS_ARRIVED, SDK_SEGMENTS_ARRIVED } from '../readiness/constants';
|
|
9
9
|
import { objectAssign } from '../utils/lang/objectAssign';
|
|
10
10
|
import { strategyDebugFactory } from '../trackers/strategy/strategyDebug';
|
|
11
11
|
import { strategyOptimizedFactory } from '../trackers/strategy/strategyOptimized';
|
|
@@ -16,19 +16,12 @@ import { NONE, OPTIMIZED } from '../utils/constants';
|
|
|
16
16
|
* Modular SDK factory
|
|
17
17
|
*/
|
|
18
18
|
export function sdkFactory(params) {
|
|
19
|
-
var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory, filterAdapterFactory = params.filterAdapterFactory
|
|
19
|
+
var settings = params.settings, platform = params.platform, storageFactory = params.storageFactory, splitApiFactory = params.splitApiFactory, extraProps = params.extraProps, syncManagerFactory = params.syncManagerFactory, SignalListener = params.SignalListener, impressionsObserverFactory = params.impressionsObserverFactory, integrationsManagerFactory = params.integrationsManagerFactory, sdkManagerFactory = params.sdkManagerFactory, sdkClientMethodFactory = params.sdkClientMethodFactory, filterAdapterFactory = params.filterAdapterFactory;
|
|
20
20
|
var log = settings.log, impressionsMode = settings.sync.impressionsMode;
|
|
21
21
|
// @TODO handle non-recoverable errors, such as, global `fetch` not available, invalid SDK Key, etc.
|
|
22
22
|
// On non-recoverable errors, we should mark the SDK as destroyed and not start synchronization.
|
|
23
|
-
//
|
|
24
|
-
|
|
25
|
-
var initCallbacks = [];
|
|
26
|
-
function whenInit(cb) {
|
|
27
|
-
if (isInit)
|
|
28
|
-
cb();
|
|
29
|
-
else
|
|
30
|
-
initCallbacks.push(cb);
|
|
31
|
-
}
|
|
23
|
+
// We will just log and allow for the SDK to end up throwing an SDK_TIMEOUT event for devs to handle.
|
|
24
|
+
validateAndTrackApiKey(log, settings.core.authorizationKey);
|
|
32
25
|
var sdkReadinessManager = sdkReadinessManagerFactory(platform.EventEmitter, settings);
|
|
33
26
|
var readiness = sdkReadinessManager.readinessManager;
|
|
34
27
|
var storage = storageFactory({
|
|
@@ -42,10 +35,8 @@ export function sdkFactory(params) {
|
|
|
42
35
|
readiness.splits.emit(SDK_SPLITS_ARRIVED);
|
|
43
36
|
readiness.segments.emit(SDK_SEGMENTS_ARRIVED);
|
|
44
37
|
},
|
|
45
|
-
onReadyFromCacheCb: function () {
|
|
46
|
-
readiness.splits.emit(SDK_SPLITS_CACHE_LOADED);
|
|
47
|
-
}
|
|
48
38
|
});
|
|
39
|
+
// @TODO add support for dataloader: `if (params.dataLoader) params.dataLoader(storage);`
|
|
49
40
|
var clients = {};
|
|
50
41
|
var telemetryTracker = telemetryTrackerFactory(storage.telemetry, platform.now);
|
|
51
42
|
var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage, telemetryTracker: telemetryTracker });
|
|
@@ -62,11 +53,11 @@ export function sdkFactory(params) {
|
|
|
62
53
|
default:
|
|
63
54
|
strategy = strategyDebugFactory(observer);
|
|
64
55
|
}
|
|
65
|
-
var impressionsTracker = impressionsTrackerFactory(settings, storage.impressions, strategy,
|
|
66
|
-
var eventTracker = eventTrackerFactory(settings, storage.events,
|
|
56
|
+
var impressionsTracker = impressionsTrackerFactory(settings, storage.impressions, strategy, integrationsManager, storage.telemetry);
|
|
57
|
+
var eventTracker = eventTrackerFactory(settings, storage.events, integrationsManager, storage.telemetry);
|
|
67
58
|
// splitApi is used by SyncManager and Browser signal listener
|
|
68
59
|
var splitApi = splitApiFactory && splitApiFactory(settings, platform, telemetryTracker);
|
|
69
|
-
var ctx = { clients: clients, splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, uniqueKeysTracker: uniqueKeysTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform
|
|
60
|
+
var ctx = { clients: clients, splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, uniqueKeysTracker: uniqueKeysTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
|
|
70
61
|
var syncManager = syncManagerFactory && syncManagerFactory(ctx);
|
|
71
62
|
ctx.syncManager = syncManager;
|
|
72
63
|
var signalListener = SignalListener && new SignalListener(syncManager, settings, storage, splitApi);
|
|
@@ -74,22 +65,8 @@ export function sdkFactory(params) {
|
|
|
74
65
|
// SDK client and manager
|
|
75
66
|
var clientMethod = sdkClientMethodFactory(ctx);
|
|
76
67
|
var managerInstance = sdkManagerFactory(settings, storage.splits, sdkReadinessManager);
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
return;
|
|
80
|
-
isInit = true;
|
|
81
|
-
// We will just log and allow for the SDK to end up throwing an SDK_TIMEOUT event for devs to handle.
|
|
82
|
-
validateAndTrackApiKey(log, settings.core.authorizationKey);
|
|
83
|
-
readiness.init();
|
|
84
|
-
storage.init && storage.init();
|
|
85
|
-
uniqueKeysTracker && uniqueKeysTracker.start();
|
|
86
|
-
syncManager && syncManager.start();
|
|
87
|
-
signalListener && signalListener.start();
|
|
88
|
-
initCallbacks.forEach(function (cb) { return cb(); });
|
|
89
|
-
initCallbacks.length = 0;
|
|
90
|
-
}
|
|
91
|
-
if (!isPure)
|
|
92
|
-
init();
|
|
68
|
+
syncManager && syncManager.start();
|
|
69
|
+
signalListener && signalListener.start();
|
|
93
70
|
log.info(NEW_FACTORY);
|
|
94
71
|
// @ts-ignore
|
|
95
72
|
return objectAssign({
|
|
@@ -106,5 +83,5 @@ export function sdkFactory(params) {
|
|
|
106
83
|
destroy: function () {
|
|
107
84
|
return Promise.all(Object.keys(clients).map(function (key) { return clients[key].destroy(); })).then(function () { });
|
|
108
85
|
}
|
|
109
|
-
}, extraProps && extraProps(ctx)
|
|
86
|
+
}, extraProps && extraProps(ctx));
|
|
110
87
|
}
|
|
@@ -11,6 +11,13 @@ var AbstractSplitsCacheAsync = /** @class */ (function () {
|
|
|
11
11
|
AbstractSplitsCacheAsync.prototype.usesSegments = function () {
|
|
12
12
|
return Promise.resolve(true);
|
|
13
13
|
};
|
|
14
|
+
/**
|
|
15
|
+
* Check if the splits information is already stored in cache.
|
|
16
|
+
* Noop, just keeping the interface. This is used by client-side implementations only.
|
|
17
|
+
*/
|
|
18
|
+
AbstractSplitsCacheAsync.prototype.checkCache = function () {
|
|
19
|
+
return Promise.resolve(false);
|
|
20
|
+
};
|
|
14
21
|
/**
|
|
15
22
|
* Kill `name` split and set `defaultTreatment` and `changeNumber`.
|
|
16
23
|
* Used for SPLIT_KILL push notifications.
|
|
@@ -27,6 +27,13 @@ var AbstractSplitsCacheSync = /** @class */ (function () {
|
|
|
27
27
|
var _this = this;
|
|
28
28
|
return this.getSplitNames().map(function (key) { return _this.getSplit(key); });
|
|
29
29
|
};
|
|
30
|
+
/**
|
|
31
|
+
* Check if the splits information is already stored in cache. This data can be preloaded.
|
|
32
|
+
* It is used as condition to emit SDK_SPLITS_CACHE_LOADED, and then SDK_READY_FROM_CACHE.
|
|
33
|
+
*/
|
|
34
|
+
AbstractSplitsCacheSync.prototype.checkCache = function () {
|
|
35
|
+
return false;
|
|
36
|
+
};
|
|
30
37
|
/**
|
|
31
38
|
* Kill `name` split and set `defaultTreatment` and `changeNumber`.
|
|
32
39
|
* Used for SPLIT_KILL push notifications.
|
|
@@ -20,12 +20,6 @@ var KeyBuilderCS = /** @class */ (function (_super) {
|
|
|
20
20
|
if (startsWith(builtSegmentKeyName, prefix))
|
|
21
21
|
return builtSegmentKeyName.substr(prefix.length);
|
|
22
22
|
};
|
|
23
|
-
// @BREAKING: The key used to start with the matching key instead of the prefix, this was changed on version 10.17.3
|
|
24
|
-
KeyBuilderCS.prototype.extractOldSegmentKey = function (builtSegmentKeyName) {
|
|
25
|
-
var prefix = this.matchingKey + "." + this.prefix + ".segment.";
|
|
26
|
-
if (startsWith(builtSegmentKeyName, prefix))
|
|
27
|
-
return builtSegmentKeyName.substr(prefix.length);
|
|
28
|
-
};
|
|
29
23
|
KeyBuilderCS.prototype.buildLastUpdatedKey = function () {
|
|
30
24
|
return this.prefix + ".splits.lastUpdated";
|
|
31
25
|
};
|
|
@@ -48,9 +42,6 @@ export function myLargeSegmentsKeyBuilder(prefix, matchingKey) {
|
|
|
48
42
|
if (startsWith(builtSegmentKeyName, p))
|
|
49
43
|
return builtSegmentKeyName.substr(p.length);
|
|
50
44
|
},
|
|
51
|
-
extractOldSegmentKey: function () {
|
|
52
|
-
return undefined;
|
|
53
|
-
},
|
|
54
45
|
buildTillKey: function () {
|
|
55
46
|
return prefix + "." + matchingKey + ".largeSegments.till";
|
|
56
47
|
}
|
|
@@ -1,78 +1,47 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { getMatching } from '../utils/key';
|
|
1
|
+
import { DEFAULT_CACHE_EXPIRATION_IN_MILLIS } from '../utils/constants/browser';
|
|
3
2
|
/**
|
|
4
|
-
*
|
|
5
|
-
* (https://github.com/godaddy/split-javascript-data-loader/blob/master/src/load-data.js)
|
|
3
|
+
* Factory of client-side storage loader
|
|
6
4
|
*
|
|
7
|
-
* @param preloadedData validated data following the format proposed in https://github.com/godaddy/split-javascript-data-loader
|
|
8
|
-
*
|
|
9
|
-
* @
|
|
10
|
-
*
|
|
11
|
-
* @TODO extend to load largeSegments
|
|
12
|
-
* @TODO extend to load data on shared mySegments storages. Be specific when emitting SDK_READY_FROM_CACHE on shared clients. Maybe the serializer should provide the `useSegments` flag.
|
|
13
|
-
* @TODO add logs, and input validation in this module, in favor of size reduction.
|
|
14
|
-
* @TODO unit tests
|
|
5
|
+
* @param preloadedData validated data following the format proposed in https://github.com/godaddy/split-javascript-data-loader
|
|
6
|
+
* and extended with a `mySegmentsData` property.
|
|
7
|
+
* @returns function to preload the storage
|
|
15
8
|
*/
|
|
16
|
-
export function
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
9
|
+
export function dataLoaderFactory(preloadedData) {
|
|
10
|
+
/**
|
|
11
|
+
* Storage-agnostic adaptation of `loadDataIntoLocalStorage` function
|
|
12
|
+
* (https://github.com/godaddy/split-javascript-data-loader/blob/master/src/load-data.js)
|
|
13
|
+
*
|
|
14
|
+
* @param storage object containing `splits` and `segments` cache (client-side variant)
|
|
15
|
+
* @param userId user key string of the provided MySegmentsCache
|
|
16
|
+
*
|
|
17
|
+
* @TODO extend to support SegmentsCache (server-side variant) by making `userId` optional and adding the corresponding logic.
|
|
18
|
+
* @TODO extend to load data on shared mySegments storages. Be specific when emitting SDK_READY_FROM_CACHE on shared clients. Maybe the serializer should provide the `useSegments` flag.
|
|
19
|
+
*/
|
|
20
|
+
return function loadData(storage, userId) {
|
|
21
|
+
// Do not load data if current preloadedData is empty
|
|
22
|
+
if (Object.keys(preloadedData).length === 0)
|
|
23
|
+
return;
|
|
24
|
+
var _a = preloadedData.lastUpdated, lastUpdated = _a === void 0 ? -1 : _a, _b = preloadedData.segmentsData, segmentsData = _b === void 0 ? {} : _b, _c = preloadedData.since, since = _c === void 0 ? -1 : _c, _d = preloadedData.splitsData, splitsData = _d === void 0 ? {} : _d;
|
|
22
25
|
var storedSince = storage.splits.getChangeNumber();
|
|
23
|
-
|
|
24
|
-
if
|
|
26
|
+
var expirationTimestamp = Date.now() - DEFAULT_CACHE_EXPIRATION_IN_MILLIS;
|
|
27
|
+
// Do not load data if current localStorage data is more recent,
|
|
28
|
+
// or if its `lastUpdated` timestamp is older than the given `expirationTimestamp`,
|
|
29
|
+
if (storedSince > since || lastUpdated < expirationTimestamp)
|
|
25
30
|
return;
|
|
26
31
|
// cleaning up the localStorage data, since some cached splits might need be part of the preloaded data
|
|
27
32
|
storage.splits.clear();
|
|
28
33
|
storage.splits.setChangeNumber(since);
|
|
29
34
|
// splitsData in an object where the property is the split name and the pertaining value is a stringified json of its data
|
|
30
|
-
storage.splits.addSplits(splitsData.map(function (
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
var mySegmentsData = preloadedData.mySegmentsData && preloadedData.mySegmentsData[matchingKey];
|
|
35
|
+
storage.splits.addSplits(Object.keys(splitsData).map(function (splitName) { return JSON.parse(splitsData[splitName]); }));
|
|
36
|
+
// add mySegments data
|
|
37
|
+
var mySegmentsData = preloadedData.mySegmentsData && preloadedData.mySegmentsData[userId];
|
|
34
38
|
if (!mySegmentsData) {
|
|
35
39
|
// segmentsData in an object where the property is the segment name and the pertaining value is a stringified object that contains the `added` array of userIds
|
|
36
40
|
mySegmentsData = Object.keys(segmentsData).filter(function (segmentName) {
|
|
37
|
-
var
|
|
38
|
-
return
|
|
41
|
+
var userIds = JSON.parse(segmentsData[segmentName]).added;
|
|
42
|
+
return Array.isArray(userIds) && userIds.indexOf(userId) > -1;
|
|
39
43
|
});
|
|
40
44
|
}
|
|
41
45
|
storage.segments.resetSegments({ k: mySegmentsData.map(function (s) { return ({ n: s }); }) });
|
|
42
|
-
}
|
|
43
|
-
else { // add segments data (server-side)
|
|
44
|
-
Object.keys(segmentsData).filter(function (segmentName) {
|
|
45
|
-
var matchingKeys = segmentsData[segmentName];
|
|
46
|
-
storage.segments.addToSegment(segmentName, matchingKeys);
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
export function getSnapshot(storage, userKeys) {
|
|
51
|
-
return {
|
|
52
|
-
// lastUpdated: Date.now(),
|
|
53
|
-
since: storage.splits.getChangeNumber(),
|
|
54
|
-
splitsData: storage.splits.getAll(),
|
|
55
|
-
segmentsData: userKeys ?
|
|
56
|
-
undefined : // @ts-ignore accessing private prop
|
|
57
|
-
Object.keys(storage.segments.segmentCache).reduce(function (prev, cur) {
|
|
58
|
-
prev[cur] = setToArray(storage.segments.segmentCache[cur]);
|
|
59
|
-
return prev;
|
|
60
|
-
}, {}),
|
|
61
|
-
mySegmentsData: userKeys ?
|
|
62
|
-
userKeys.reduce(function (prev, userKey) {
|
|
63
|
-
prev[getMatching(userKey)] = storage.shared ?
|
|
64
|
-
// Client-side segments
|
|
65
|
-
// @ts-ignore accessing private prop
|
|
66
|
-
Object.keys(storage.shared(userKey).segments.segmentCache) :
|
|
67
|
-
// Server-side segments
|
|
68
|
-
// @ts-ignore accessing private prop
|
|
69
|
-
Object.keys(storage.segments.segmentCache).reduce(function (prev, segmentName) {
|
|
70
|
-
return storage.segments.segmentCache[segmentName].has(userKey) ?
|
|
71
|
-
prev.concat(segmentName) :
|
|
72
|
-
prev;
|
|
73
|
-
}, []);
|
|
74
|
-
return prev;
|
|
75
|
-
}, {}) :
|
|
76
|
-
undefined
|
|
77
46
|
};
|
|
78
47
|
}
|
|
@@ -45,28 +45,8 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
|
45
45
|
// Scan current values from localStorage
|
|
46
46
|
return Object.keys(localStorage).reduce(function (accum, key) {
|
|
47
47
|
var segmentName = _this.keys.extractSegmentName(key);
|
|
48
|
-
if (segmentName)
|
|
48
|
+
if (segmentName)
|
|
49
49
|
accum.push(segmentName);
|
|
50
|
-
}
|
|
51
|
-
else {
|
|
52
|
-
// @TODO @BREAKING: This is only to clean up "old" keys. Remove this whole else code block
|
|
53
|
-
segmentName = _this.keys.extractOldSegmentKey(key);
|
|
54
|
-
if (segmentName) { // this was an old segment key, let's clean up.
|
|
55
|
-
var newSegmentKey = _this.keys.buildSegmentNameKey(segmentName);
|
|
56
|
-
try {
|
|
57
|
-
// If the new format key is not there, create it.
|
|
58
|
-
if (!localStorage.getItem(newSegmentKey)) {
|
|
59
|
-
localStorage.setItem(newSegmentKey, DEFINED);
|
|
60
|
-
// we are migrating a segment, let's track it.
|
|
61
|
-
accum.push(segmentName);
|
|
62
|
-
}
|
|
63
|
-
localStorage.removeItem(key); // we migrated the current key, let's delete it.
|
|
64
|
-
}
|
|
65
|
-
catch (e) {
|
|
66
|
-
_this.log.error(e);
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
50
|
return accum;
|
|
71
51
|
}, []);
|
|
72
52
|
};
|
|
@@ -2,7 +2,6 @@ import { __extends } from "tslib";
|
|
|
2
2
|
import { AbstractSplitsCacheSync, usesSegments } from '../AbstractSplitsCacheSync';
|
|
3
3
|
import { isFiniteNumber, toNumber, isNaNNumber } from '../../utils/lang';
|
|
4
4
|
import { LOG_PREFIX } from './constants';
|
|
5
|
-
import { _Set, setToArray } from '../../utils/lang/sets';
|
|
6
5
|
import { getStorageHash } from '../KeyBuilder';
|
|
7
6
|
/**
|
|
8
7
|
* ISplitsCacheSync implementation that stores split definitions in browser LocalStorage.
|
|
@@ -183,6 +182,14 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
183
182
|
return true;
|
|
184
183
|
}
|
|
185
184
|
};
|
|
185
|
+
/**
|
|
186
|
+
* Check if the splits information is already stored in browser LocalStorage.
|
|
187
|
+
* In this function we could add more code to check if the data is valid.
|
|
188
|
+
* @override
|
|
189
|
+
*/
|
|
190
|
+
SplitsCacheInLocal.prototype.checkCache = function () {
|
|
191
|
+
return this.getChangeNumber() > -1;
|
|
192
|
+
};
|
|
186
193
|
/**
|
|
187
194
|
* Clean Splits cache if its `lastUpdated` timestamp is older than the given `expirationTimestamp`,
|
|
188
195
|
*
|
|
@@ -205,7 +212,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
205
212
|
// mark cache to update the new query filter on first successful splits fetch
|
|
206
213
|
this.updateNewFilter = true;
|
|
207
214
|
// if there is cache, clear it
|
|
208
|
-
if (this.
|
|
215
|
+
if (this.checkCache())
|
|
209
216
|
this.clear();
|
|
210
217
|
}
|
|
211
218
|
catch (e) {
|
|
@@ -219,7 +226,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
219
226
|
return flagSets.map(function (flagSet) {
|
|
220
227
|
var flagSetKey = _this.keys.buildFlagSetKey(flagSet);
|
|
221
228
|
var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
|
|
222
|
-
return new
|
|
229
|
+
return new Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
|
|
223
230
|
});
|
|
224
231
|
};
|
|
225
232
|
SplitsCacheInLocal.prototype.addToFlagSets = function (featureFlag) {
|
|
@@ -231,9 +238,9 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
231
238
|
return;
|
|
232
239
|
var flagSetKey = _this.keys.buildFlagSetKey(featureFlagSet);
|
|
233
240
|
var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
|
|
234
|
-
var flagSetCache = new
|
|
241
|
+
var flagSetCache = new Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
|
|
235
242
|
flagSetCache.add(featureFlag.name);
|
|
236
|
-
localStorage.setItem(flagSetKey, JSON.stringify(
|
|
243
|
+
localStorage.setItem(flagSetKey, JSON.stringify(Array.from(flagSetCache)));
|
|
237
244
|
});
|
|
238
245
|
};
|
|
239
246
|
SplitsCacheInLocal.prototype.removeFromFlagSets = function (featureFlagName, flagSets) {
|
|
@@ -249,13 +256,13 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
249
256
|
var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
|
|
250
257
|
if (!flagSetFromLocalStorage)
|
|
251
258
|
return;
|
|
252
|
-
var flagSetCache = new
|
|
259
|
+
var flagSetCache = new Set(JSON.parse(flagSetFromLocalStorage));
|
|
253
260
|
flagSetCache.delete(featureFlagName);
|
|
254
261
|
if (flagSetCache.size === 0) {
|
|
255
262
|
localStorage.removeItem(flagSetKey);
|
|
256
263
|
return;
|
|
257
264
|
}
|
|
258
|
-
localStorage.setItem(flagSetKey, JSON.stringify(
|
|
265
|
+
localStorage.setItem(flagSetKey, JSON.stringify(Array.from(flagSetCache)));
|
|
259
266
|
};
|
|
260
267
|
return SplitsCacheInLocal;
|
|
261
268
|
}(AbstractSplitsCacheSync));
|
|
@@ -11,7 +11,7 @@ import { SplitsCacheInMemory } from '../inMemory/SplitsCacheInMemory';
|
|
|
11
11
|
import { DEFAULT_CACHE_EXPIRATION_IN_MILLIS } from '../../utils/constants/browser';
|
|
12
12
|
import { InMemoryStorageCSFactory } from '../inMemory/InMemoryStorageCS';
|
|
13
13
|
import { LOG_PREFIX } from './constants';
|
|
14
|
-
import { DEBUG,
|
|
14
|
+
import { DEBUG, NONE, STORAGE_LOCALSTORAGE } from '../../utils/constants';
|
|
15
15
|
import { shouldRecordTelemetry, TelemetryCacheInMemory } from '../inMemory/TelemetryCacheInMemory';
|
|
16
16
|
import { UniqueKeysCacheInMemoryCS } from '../inMemory/UniqueKeysCacheInMemoryCS';
|
|
17
17
|
import { getMatching } from '../../utils/key';
|
|
@@ -27,7 +27,7 @@ export function InLocalStorage(options) {
|
|
|
27
27
|
params.settings.log.warn(LOG_PREFIX + 'LocalStorage API is unavailable. Falling back to default MEMORY storage');
|
|
28
28
|
return InMemoryStorageCSFactory(params);
|
|
29
29
|
}
|
|
30
|
-
var
|
|
30
|
+
var settings = params.settings, _a = params.settings, log = _a.log, _b = _a.scheduler, impressionsQueueSize = _b.impressionsQueueSize, eventsQueueSize = _b.eventsQueueSize, _c = _a.sync, impressionsMode = _c.impressionsMode, __splitFiltersValidation = _c.__splitFiltersValidation;
|
|
31
31
|
var matchingKey = getMatching(settings.core.key);
|
|
32
32
|
var keys = new KeyBuilderCS(prefix, matchingKey);
|
|
33
33
|
var expirationTimestamp = Date.now() - DEFAULT_CACHE_EXPIRATION_IN_MILLIS;
|
|
@@ -43,11 +43,6 @@ export function InLocalStorage(options) {
|
|
|
43
43
|
events: new EventsCacheInMemory(eventsQueueSize),
|
|
44
44
|
telemetry: shouldRecordTelemetry(params) ? new TelemetryCacheInMemory(splits, segments) : undefined,
|
|
45
45
|
uniqueKeys: impressionsMode === NONE ? new UniqueKeysCacheInMemoryCS() : undefined,
|
|
46
|
-
init: function () {
|
|
47
|
-
if (settings.mode === LOCALHOST_MODE || splits.getChangeNumber() > -1) {
|
|
48
|
-
Promise.resolve().then(onReadyFromCacheCb);
|
|
49
|
-
}
|
|
50
|
-
},
|
|
51
46
|
destroy: function () {
|
|
52
47
|
var _a;
|
|
53
48
|
this.splits = new SplitsCacheInMemory(__splitFiltersValidation);
|
|
@@ -6,15 +6,13 @@ import { ImpressionCountsCacheInMemory } from './ImpressionCountsCacheInMemory';
|
|
|
6
6
|
import { DEBUG, LOCALHOST_MODE, NONE, STORAGE_MEMORY } from '../../utils/constants';
|
|
7
7
|
import { shouldRecordTelemetry, TelemetryCacheInMemory } from './TelemetryCacheInMemory';
|
|
8
8
|
import { UniqueKeysCacheInMemoryCS } from './UniqueKeysCacheInMemoryCS';
|
|
9
|
-
import { getMatching } from '../../utils/key';
|
|
10
|
-
import { loadData } from '../dataLoader';
|
|
11
9
|
/**
|
|
12
10
|
* InMemory storage factory for standalone client-side SplitFactory
|
|
13
11
|
*
|
|
14
12
|
* @param params parameters required by EventsCacheSync
|
|
15
13
|
*/
|
|
16
14
|
export function InMemoryStorageCSFactory(params) {
|
|
17
|
-
var _a = params.settings, _b = _a.scheduler, impressionsQueueSize = _b.impressionsQueueSize, eventsQueueSize = _b.eventsQueueSize, _c = _a.sync, impressionsMode = _c.impressionsMode, __splitFiltersValidation = _c.__splitFiltersValidation
|
|
15
|
+
var _a = params.settings, _b = _a.scheduler, impressionsQueueSize = _b.impressionsQueueSize, eventsQueueSize = _b.eventsQueueSize, _c = _a.sync, impressionsMode = _c.impressionsMode, __splitFiltersValidation = _c.__splitFiltersValidation;
|
|
18
16
|
var splits = new SplitsCacheInMemory(__splitFiltersValidation);
|
|
19
17
|
var segments = new MySegmentsCacheInMemory();
|
|
20
18
|
var largeSegments = new MySegmentsCacheInMemory();
|
|
@@ -38,16 +36,11 @@ export function InMemoryStorageCSFactory(params) {
|
|
|
38
36
|
this.uniqueKeys && this.uniqueKeys.clear();
|
|
39
37
|
},
|
|
40
38
|
// When using shared instanciation with MEMORY we reuse everything but segments (they are unique per key)
|
|
41
|
-
shared: function (
|
|
42
|
-
var segments = new MySegmentsCacheInMemory();
|
|
43
|
-
var largeSegments = new MySegmentsCacheInMemory();
|
|
44
|
-
if (preloadedData) {
|
|
45
|
-
loadData(preloadedData, { segments: segments, largeSegments: largeSegments }, matchingKey);
|
|
46
|
-
}
|
|
39
|
+
shared: function () {
|
|
47
40
|
return {
|
|
48
41
|
splits: this.splits,
|
|
49
|
-
segments:
|
|
50
|
-
largeSegments:
|
|
42
|
+
segments: new MySegmentsCacheInMemory(),
|
|
43
|
+
largeSegments: new MySegmentsCacheInMemory(),
|
|
51
44
|
impressions: this.impressions,
|
|
52
45
|
impressionCounts: this.impressionCounts,
|
|
53
46
|
events: this.events,
|
|
@@ -72,11 +65,6 @@ export function InMemoryStorageCSFactory(params) {
|
|
|
72
65
|
if (storage.uniqueKeys)
|
|
73
66
|
storage.uniqueKeys.track = noopTrack;
|
|
74
67
|
}
|
|
75
|
-
if (preloadedData) {
|
|
76
|
-
loadData(preloadedData, storage, getMatching(params.settings.core.key));
|
|
77
|
-
if (splits.getChangeNumber() > -1)
|
|
78
|
-
onReadyFromCacheCb();
|
|
79
|
-
}
|
|
80
68
|
return storage;
|
|
81
69
|
}
|
|
82
70
|
InMemoryStorageCSFactory.type = STORAGE_MEMORY;
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import { __extends } from "tslib";
|
|
2
2
|
import { AbstractSegmentsCacheSync } from '../AbstractSegmentsCacheSync';
|
|
3
|
-
import { _Set } from '../../utils/lang/sets';
|
|
4
3
|
import { isIntegerNumber } from '../../utils/lang';
|
|
5
4
|
/**
|
|
6
5
|
* Default ISplitsCacheSync implementation that stores split definitions in memory.
|
|
@@ -16,14 +15,14 @@ var SegmentsCacheInMemory = /** @class */ (function (_super) {
|
|
|
16
15
|
}
|
|
17
16
|
SegmentsCacheInMemory.prototype.addToSegment = function (name, segmentKeys) {
|
|
18
17
|
var values = this.segmentCache[name];
|
|
19
|
-
var keySet = values ? values : new
|
|
18
|
+
var keySet = values ? values : new Set();
|
|
20
19
|
segmentKeys.forEach(function (k) { return keySet.add(k); });
|
|
21
20
|
this.segmentCache[name] = keySet;
|
|
22
21
|
return true;
|
|
23
22
|
};
|
|
24
23
|
SegmentsCacheInMemory.prototype.removeFromSegment = function (name, segmentKeys) {
|
|
25
24
|
var values = this.segmentCache[name];
|
|
26
|
-
var keySet = values ? values : new
|
|
25
|
+
var keySet = values ? values : new Set();
|
|
27
26
|
segmentKeys.forEach(function (k) { return keySet.delete(k); });
|
|
28
27
|
this.segmentCache[name] = keySet;
|
|
29
28
|
return true;
|
|
@@ -41,7 +40,7 @@ var SegmentsCacheInMemory = /** @class */ (function (_super) {
|
|
|
41
40
|
};
|
|
42
41
|
SegmentsCacheInMemory.prototype._registerSegment = function (name) {
|
|
43
42
|
if (!this.segmentCache[name]) {
|
|
44
|
-
this.segmentCache[name] = new
|
|
43
|
+
this.segmentCache[name] = new Set();
|
|
45
44
|
}
|
|
46
45
|
return true;
|
|
47
46
|
};
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
import { __extends } from "tslib";
|
|
2
2
|
import { AbstractSplitsCacheSync, usesSegments } from '../AbstractSplitsCacheSync';
|
|
3
3
|
import { isFiniteNumber } from '../../utils/lang';
|
|
4
|
-
import { _Set } from '../../utils/lang/sets';
|
|
5
4
|
/**
|
|
6
5
|
* Default ISplitsCacheSync implementation that stores split definitions in memory.
|
|
7
6
|
* Supported by all JS runtimes.
|
|
@@ -92,7 +91,7 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
|
|
|
92
91
|
};
|
|
93
92
|
SplitsCacheInMemory.prototype.getNamesByFlagSets = function (flagSets) {
|
|
94
93
|
var _this = this;
|
|
95
|
-
return flagSets.map(function (flagSet) { return _this.flagSetsCache[flagSet] || new
|
|
94
|
+
return flagSets.map(function (flagSet) { return _this.flagSetsCache[flagSet] || new Set(); });
|
|
96
95
|
};
|
|
97
96
|
SplitsCacheInMemory.prototype.addToFlagSets = function (featureFlag) {
|
|
98
97
|
var _this = this;
|
|
@@ -102,7 +101,7 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
|
|
|
102
101
|
if (_this.flagSetsFilter.length > 0 && !_this.flagSetsFilter.some(function (filterFlagSet) { return filterFlagSet === featureFlagSet; }))
|
|
103
102
|
return;
|
|
104
103
|
if (!_this.flagSetsCache[featureFlagSet])
|
|
105
|
-
_this.flagSetsCache[featureFlagSet] = new
|
|
104
|
+
_this.flagSetsCache[featureFlagSet] = new Set([]);
|
|
106
105
|
_this.flagSetsCache[featureFlagSet].add(featureFlag.name);
|
|
107
106
|
});
|
|
108
107
|
};
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { setToArray, _Set } from '../../utils/lang/sets';
|
|
2
1
|
import { DEFAULT_CACHE_SIZE } from '../inRedis/constants';
|
|
3
2
|
/**
|
|
4
3
|
* Converts `uniqueKeys` data from cache into request payload for SS.
|
|
@@ -8,7 +7,7 @@ export function fromUniqueKeysCollector(uniqueKeys) {
|
|
|
8
7
|
var featureNames = Object.keys(uniqueKeys);
|
|
9
8
|
for (var i = 0; i < featureNames.length; i++) {
|
|
10
9
|
var featureName = featureNames[i];
|
|
11
|
-
var userKeys =
|
|
10
|
+
var userKeys = Array.from(uniqueKeys[featureName]);
|
|
12
11
|
var uniqueKeysPayload = {
|
|
13
12
|
f: featureName,
|
|
14
13
|
ks: userKeys
|
|
@@ -32,7 +31,7 @@ var UniqueKeysCacheInMemory = /** @class */ (function () {
|
|
|
32
31
|
*/
|
|
33
32
|
UniqueKeysCacheInMemory.prototype.track = function (userKey, featureName) {
|
|
34
33
|
if (!this.uniqueKeysTracker[featureName])
|
|
35
|
-
this.uniqueKeysTracker[featureName] = new
|
|
34
|
+
this.uniqueKeysTracker[featureName] = new Set();
|
|
36
35
|
var tracker = this.uniqueKeysTracker[featureName];
|
|
37
36
|
if (!tracker.has(userKey)) {
|
|
38
37
|
tracker.add(userKey);
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
import { setToArray, _Set } from '../../utils/lang/sets';
|
|
2
1
|
import { DEFAULT_CACHE_SIZE } from '../inRedis/constants';
|
|
3
2
|
var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
|
|
4
3
|
/**
|
|
@@ -20,7 +19,7 @@ var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
|
|
|
20
19
|
*/
|
|
21
20
|
UniqueKeysCacheInMemoryCS.prototype.track = function (userKey, featureName) {
|
|
22
21
|
if (!this.uniqueKeysTracker[userKey])
|
|
23
|
-
this.uniqueKeysTracker[userKey] = new
|
|
22
|
+
this.uniqueKeysTracker[userKey] = new Set();
|
|
24
23
|
var tracker = this.uniqueKeysTracker[userKey];
|
|
25
24
|
if (!tracker.has(featureName)) {
|
|
26
25
|
tracker.add(featureName);
|
|
@@ -59,7 +58,7 @@ var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
|
|
|
59
58
|
var userKeys = Object.keys(uniqueKeys);
|
|
60
59
|
for (var k = 0; k < userKeys.length; k++) {
|
|
61
60
|
var userKey = userKeys[k];
|
|
62
|
-
var featureNames =
|
|
61
|
+
var featureNames = Array.from(uniqueKeys[userKey]);
|
|
63
62
|
var uniqueKeysPayload = {
|
|
64
63
|
k: userKey,
|
|
65
64
|
fs: featureNames
|