@splitsoftware/splitio-commons 1.6.2-rc.5 → 1.6.2-rc.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cjs/consent/sdkUserConsent.js +2 -2
- package/cjs/evaluator/index.js +10 -11
- package/cjs/integrations/ga/GaToSplit.js +8 -5
- package/cjs/listeners/browser.js +1 -2
- package/cjs/logger/constants.js +1 -2
- package/cjs/sdkFactory/index.js +7 -25
- package/cjs/sdkManager/index.js +3 -11
- package/cjs/services/splitApi.js +0 -20
- package/cjs/storages/AbstractSplitsCacheAsync.js +7 -9
- package/cjs/storages/AbstractSplitsCacheSync.js +7 -9
- package/cjs/storages/KeyBuilderSS.js +0 -6
- package/cjs/storages/dataLoader.js +1 -1
- package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +5 -6
- package/cjs/storages/inLocalStorage/index.js +0 -4
- package/cjs/storages/inMemory/ImpressionCountsCacheInMemory.js +1 -12
- package/cjs/storages/inMemory/InMemoryStorage.js +1 -5
- package/cjs/storages/inMemory/InMemoryStorageCS.js +1 -5
- package/cjs/storages/inMemory/SplitsCacheInMemory.js +7 -10
- package/cjs/storages/inRedis/SplitsCacheInRedis.js +15 -9
- package/cjs/storages/inRedis/constants.js +1 -4
- package/cjs/storages/inRedis/index.js +1 -15
- package/cjs/storages/pluggable/SplitsCachePluggable.js +14 -9
- package/cjs/sync/offline/syncTasks/fromObjectSyncTask.js +2 -3
- package/cjs/sync/polling/updaters/splitChangesUpdater.js +1 -1
- package/cjs/sync/submitters/submitterManager.js +0 -3
- package/cjs/sync/submitters/telemetrySubmitter.js +0 -1
- package/cjs/trackers/impressionsTracker.js +41 -22
- package/cjs/trackers/telemetryTracker.js +6 -0
- package/cjs/utils/constants/index.js +2 -4
- package/cjs/utils/settingsValidation/impressionsMode.js +2 -2
- package/cjs/utils/settingsValidation/index.js +0 -3
- package/esm/consent/sdkUserConsent.js +2 -2
- package/esm/evaluator/index.js +10 -11
- package/esm/integrations/ga/GaToSplit.js +8 -5
- package/esm/listeners/browser.js +2 -3
- package/esm/logger/constants.js +0 -1
- package/esm/sdkFactory/index.js +7 -25
- package/esm/sdkManager/index.js +3 -11
- package/esm/services/splitApi.js +0 -20
- package/esm/storages/AbstractSplitsCacheAsync.js +7 -9
- package/esm/storages/AbstractSplitsCacheSync.js +7 -9
- package/esm/storages/KeyBuilderSS.js +0 -6
- package/esm/storages/dataLoader.js +1 -1
- package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +5 -6
- package/esm/storages/inLocalStorage/index.js +1 -5
- package/esm/storages/inMemory/ImpressionCountsCacheInMemory.js +1 -12
- package/esm/storages/inMemory/InMemoryStorage.js +2 -6
- package/esm/storages/inMemory/InMemoryStorageCS.js +2 -6
- package/esm/storages/inMemory/SplitsCacheInMemory.js +7 -10
- package/esm/storages/inRedis/SplitsCacheInRedis.js +15 -9
- package/esm/storages/inRedis/constants.js +0 -3
- package/esm/storages/inRedis/index.js +2 -16
- package/esm/storages/pluggable/SplitsCachePluggable.js +14 -9
- package/esm/sync/offline/syncTasks/fromObjectSyncTask.js +2 -3
- package/esm/sync/polling/updaters/splitChangesUpdater.js +1 -1
- package/esm/sync/submitters/submitterManager.js +0 -3
- package/esm/sync/submitters/telemetrySubmitter.js +1 -2
- package/esm/trackers/impressionsTracker.js +41 -22
- package/esm/trackers/telemetryTracker.js +6 -0
- package/esm/utils/constants/index.js +0 -2
- package/esm/utils/settingsValidation/impressionsMode.js +3 -3
- package/esm/utils/settingsValidation/index.js +0 -3
- package/package.json +1 -1
- package/src/consent/sdkUserConsent.ts +2 -2
- package/src/evaluator/index.ts +8 -9
- package/src/integrations/ga/GaToSplit.ts +9 -5
- package/src/integrations/types.ts +2 -1
- package/src/listeners/browser.ts +2 -3
- package/src/logger/.DS_Store +0 -0
- package/src/logger/constants.ts +0 -1
- package/src/sdkFactory/index.ts +7 -28
- package/src/sdkFactory/types.ts +4 -7
- package/src/sdkManager/index.ts +3 -12
- package/src/services/splitApi.ts +0 -22
- package/src/services/types.ts +0 -6
- package/src/storages/AbstractSplitsCacheAsync.ts +13 -14
- package/src/storages/AbstractSplitsCacheSync.ts +14 -16
- package/src/storages/KeyBuilderSS.ts +0 -8
- package/src/storages/dataLoader.ts +1 -1
- package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +8 -10
- package/src/storages/inLocalStorage/index.ts +1 -4
- package/src/storages/inMemory/ImpressionCountsCacheInMemory.ts +1 -16
- package/src/storages/inMemory/InMemoryStorage.ts +2 -5
- package/src/storages/inMemory/InMemoryStorageCS.ts +2 -6
- package/src/storages/inMemory/SplitsCacheInMemory.ts +10 -14
- package/src/storages/inRedis/SplitsCacheInRedis.ts +21 -17
- package/src/storages/inRedis/constants.ts +0 -3
- package/src/storages/inRedis/index.ts +3 -12
- package/src/storages/pluggable/SplitsCachePluggable.ts +20 -17
- package/src/storages/types.ts +21 -40
- package/src/sync/offline/syncTasks/fromObjectSyncTask.ts +5 -6
- package/src/sync/polling/updaters/splitChangesUpdater.ts +2 -2
- package/src/sync/submitters/submitterManager.ts +0 -2
- package/src/sync/submitters/telemetrySubmitter.ts +3 -4
- package/src/sync/submitters/types.ts +1 -20
- package/src/trackers/impressionsTracker.ts +48 -27
- package/src/trackers/telemetryTracker.ts +7 -2
- package/src/trackers/types.ts +4 -26
- package/src/types.ts +1 -3
- package/src/utils/constants/index.ts +0 -2
- package/src/utils/settingsValidation/impressionsMode.ts +3 -3
- package/src/utils/settingsValidation/index.ts +0 -4
- package/types/integrations/types.d.ts +2 -1
- package/types/logger/constants.d.ts +0 -1
- package/types/sdkFactory/types.d.ts +2 -4
- package/types/services/types.d.ts +0 -4
- package/types/storages/AbstractSplitsCacheAsync.d.ts +6 -5
- package/types/storages/AbstractSplitsCacheSync.d.ts +5 -5
- package/types/storages/KeyBuilderSS.d.ts +0 -2
- package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +3 -3
- package/types/storages/inMemory/ImpressionCountsCacheInMemory.d.ts +1 -5
- package/types/storages/inMemory/SplitsCacheInMemory.d.ts +3 -2
- package/types/storages/inRedis/SplitsCacheInRedis.d.ts +6 -5
- package/types/storages/inRedis/constants.d.ts +0 -3
- package/types/storages/pluggable/SplitsCachePluggable.d.ts +6 -5
- package/types/storages/types.d.ts +18 -28
- package/types/sync/polling/updaters/splitChangesUpdater.d.ts +1 -1
- package/types/sync/submitters/types.d.ts +1 -18
- package/types/trackers/impressionsTracker.d.ts +6 -4
- package/types/trackers/types.d.ts +4 -21
- package/types/types.d.ts +1 -3
- package/types/utils/constants/index.d.ts +0 -2
- package/types/utils/settingsValidation/index.d.ts +0 -1
- package/cjs/storages/inMemory/uniqueKeysCacheInMemory.js +0 -73
- package/cjs/storages/inMemory/uniqueKeysCacheInMemoryCS.js +0 -78
- package/cjs/storages/inRedis/ImpressionCountsCacheInRedis.js +0 -46
- package/cjs/storages/inRedis/uniqueKeysCacheInRedis.js +0 -55
- package/cjs/sync/submitters/uniqueKeysSubmitter.js +0 -26
- package/cjs/trackers/strategy/strategyDebug.js +0 -25
- package/cjs/trackers/strategy/strategyNone.js +0 -29
- package/cjs/trackers/strategy/strategyOptimized.js +0 -34
- package/cjs/trackers/uniqueKeysTracker.js +0 -31
- package/esm/storages/inMemory/uniqueKeysCacheInMemory.js +0 -70
- package/esm/storages/inMemory/uniqueKeysCacheInMemoryCS.js +0 -75
- package/esm/storages/inRedis/ImpressionCountsCacheInRedis.js +0 -43
- package/esm/storages/inRedis/uniqueKeysCacheInRedis.js +0 -52
- package/esm/sync/submitters/uniqueKeysSubmitter.js +0 -22
- package/esm/trackers/strategy/strategyDebug.js +0 -21
- package/esm/trackers/strategy/strategyNone.js +0 -25
- package/esm/trackers/strategy/strategyOptimized.js +0 -30
- package/esm/trackers/uniqueKeysTracker.js +0 -27
- package/src/storages/inMemory/uniqueKeysCacheInMemory.ts +0 -82
- package/src/storages/inMemory/uniqueKeysCacheInMemoryCS.ts +0 -88
- package/src/storages/inRedis/ImpressionCountsCacheInRedis.ts +0 -48
- package/src/storages/inRedis/uniqueKeysCacheInRedis.ts +0 -61
- package/src/sync/submitters/uniqueKeysSubmitter.ts +0 -35
- package/src/trackers/strategy/strategyDebug.ts +0 -28
- package/src/trackers/strategy/strategyNone.ts +0 -34
- package/src/trackers/strategy/strategyOptimized.ts +0 -42
- package/src/trackers/uniqueKeysTracker.ts +0 -37
- package/types/sdkClient/types.d.ts +0 -18
- package/types/storages/inMemory/CountsCacheInMemory.d.ts +0 -20
- package/types/storages/inMemory/LatenciesCacheInMemory.d.ts +0 -20
- package/types/storages/inMemory/uniqueKeysCacheInMemory.d.ts +0 -35
- package/types/storages/inMemory/uniqueKeysCacheInMemoryCS.d.ts +0 -37
- package/types/storages/inRedis/CountsCacheInRedis.d.ts +0 -9
- package/types/storages/inRedis/ImpressionCountsCacheInRedis.d.ts +0 -13
- package/types/storages/inRedis/LatenciesCacheInRedis.d.ts +0 -9
- package/types/storages/inRedis/uniqueKeysCacheInRedis.d.ts +0 -14
- package/types/sync/offline/LocalhostFromFile.d.ts +0 -2
- package/types/sync/offline/splitsParser/splitsParserFromFile.d.ts +0 -2
- package/types/sync/submitters/eventsSyncTask.d.ts +0 -8
- package/types/sync/submitters/impressionCountsSubmitterInRedis.d.ts +0 -5
- package/types/sync/submitters/impressionCountsSyncTask.d.ts +0 -13
- package/types/sync/submitters/impressionsSyncTask.d.ts +0 -14
- package/types/sync/submitters/metricsSyncTask.d.ts +0 -12
- package/types/sync/submitters/submitterSyncTask.d.ts +0 -10
- package/types/sync/submitters/uniqueKeysSubmitter.d.ts +0 -5
- package/types/sync/submitters/uniqueKeysSubmitterInRedis.d.ts +0 -5
- package/types/sync/syncTaskComposite.d.ts +0 -5
- package/types/trackers/filter/bloomFilter.d.ts +0 -10
- package/types/trackers/filter/dictionaryFilter.d.ts +0 -8
- package/types/trackers/filter/types.d.ts +0 -5
- package/types/trackers/strategy/strategyDebug.d.ts +0 -9
- package/types/trackers/strategy/strategyNone.d.ts +0 -10
- package/types/trackers/strategy/strategyOptimized.d.ts +0 -11
- package/types/trackers/uniqueKeysTracker.d.ts +0 -13
- package/types/utils/timeTracker/index.d.ts +0 -70
|
@@ -10,8 +10,6 @@ var ImpressionsCacheInRedis_1 = require("./ImpressionsCacheInRedis");
|
|
|
10
10
|
var EventsCacheInRedis_1 = require("./EventsCacheInRedis");
|
|
11
11
|
var constants_1 = require("../../utils/constants");
|
|
12
12
|
var TelemetryCacheInRedis_1 = require("./TelemetryCacheInRedis");
|
|
13
|
-
var uniqueKeysCacheInRedis_1 = require("./uniqueKeysCacheInRedis");
|
|
14
|
-
var ImpressionCountsCacheInRedis_1 = require("./ImpressionCountsCacheInRedis");
|
|
15
13
|
/**
|
|
16
14
|
* InRedis storage factory for consumer server-side SplitFactory, that uses `Ioredis` Redis client for Node.
|
|
17
15
|
* @see {@link https://www.npmjs.com/package/ioredis}
|
|
@@ -20,19 +18,13 @@ function InRedisStorage(options) {
|
|
|
20
18
|
if (options === void 0) { options = {}; }
|
|
21
19
|
var prefix = (0, KeyBuilder_1.validatePrefix)(options.prefix);
|
|
22
20
|
function InRedisStorageFactory(_a) {
|
|
23
|
-
var log = _a.log, metadata = _a.metadata, onReadyCb = _a.onReadyCb
|
|
21
|
+
var log = _a.log, metadata = _a.metadata, onReadyCb = _a.onReadyCb;
|
|
24
22
|
var keys = new KeyBuilderSS_1.KeyBuilderSS(prefix, metadata);
|
|
25
23
|
var redisClient = new RedisAdapter_1.RedisAdapter(log, options.options || {});
|
|
26
24
|
var telemetry = new TelemetryCacheInRedis_1.TelemetryCacheInRedis(log, keys, redisClient);
|
|
27
|
-
var impressionCountsCache = impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInRedis_1.ImpressionCountsCacheInRedis(log, keys.buildImpressionsCountKey(), redisClient) : undefined;
|
|
28
|
-
var uniqueKeysCache = impressionsMode === constants_1.NONE ? new uniqueKeysCacheInRedis_1.UniqueKeysCacheInRedis(log, keys.buildUniqueKeysKey(), redisClient) : undefined;
|
|
29
25
|
// subscription to Redis connect event in order to emit SDK_READY event on consumer mode
|
|
30
26
|
redisClient.on('connect', function () {
|
|
31
27
|
onReadyCb();
|
|
32
|
-
if (impressionCountsCache)
|
|
33
|
-
impressionCountsCache.start();
|
|
34
|
-
if (uniqueKeysCache)
|
|
35
|
-
uniqueKeysCache.start();
|
|
36
28
|
// Synchronize config
|
|
37
29
|
telemetry.recordConfig();
|
|
38
30
|
});
|
|
@@ -40,18 +32,12 @@ function InRedisStorage(options) {
|
|
|
40
32
|
splits: new SplitsCacheInRedis_1.SplitsCacheInRedis(log, keys, redisClient),
|
|
41
33
|
segments: new SegmentsCacheInRedis_1.SegmentsCacheInRedis(log, keys, redisClient),
|
|
42
34
|
impressions: new ImpressionsCacheInRedis_1.ImpressionsCacheInRedis(log, keys.buildImpressionsKey(), redisClient, metadata),
|
|
43
|
-
impressionCounts: impressionCountsCache,
|
|
44
35
|
events: new EventsCacheInRedis_1.EventsCacheInRedis(log, keys.buildEventsKey(), redisClient, metadata),
|
|
45
36
|
telemetry: telemetry,
|
|
46
|
-
uniqueKeys: uniqueKeysCache,
|
|
47
37
|
// When using REDIS we should:
|
|
48
38
|
// 1- Disconnect from the storage
|
|
49
39
|
destroy: function () {
|
|
50
40
|
redisClient.disconnect();
|
|
51
|
-
if (impressionCountsCache)
|
|
52
|
-
impressionCountsCache.stop();
|
|
53
|
-
if (uniqueKeysCache)
|
|
54
|
-
uniqueKeysCache.stop();
|
|
55
41
|
// @TODO check that caches works as expected when redisClient is disconnected
|
|
56
42
|
}
|
|
57
43
|
};
|
|
@@ -49,17 +49,17 @@ var SplitsCachePluggable = /** @class */ (function (_super) {
|
|
|
49
49
|
var splitKey = this.keys.buildSplitKey(name);
|
|
50
50
|
return this.wrapper.get(splitKey).then(function (splitFromStorage) {
|
|
51
51
|
// handling parsing error
|
|
52
|
-
var parsedPreviousSplit,
|
|
52
|
+
var parsedPreviousSplit, stringifiedNewSplit;
|
|
53
53
|
try {
|
|
54
54
|
parsedPreviousSplit = splitFromStorage ? JSON.parse(splitFromStorage) : undefined;
|
|
55
|
-
|
|
55
|
+
stringifiedNewSplit = JSON.stringify(split);
|
|
56
56
|
}
|
|
57
57
|
catch (e) {
|
|
58
58
|
throw new Error('Error parsing split definition: ' + e);
|
|
59
59
|
}
|
|
60
60
|
return Promise.all([
|
|
61
|
-
_this.wrapper.set(splitKey,
|
|
62
|
-
_this._incrementCounts(
|
|
61
|
+
_this.wrapper.set(splitKey, stringifiedNewSplit),
|
|
62
|
+
_this._incrementCounts(split),
|
|
63
63
|
// If it's an update, we decrement the traffic type and segment count of the existing split,
|
|
64
64
|
parsedPreviousSplit && _this._decrementCounts(parsedPreviousSplit)
|
|
65
65
|
]);
|
|
@@ -83,8 +83,7 @@ var SplitsCachePluggable = /** @class */ (function (_super) {
|
|
|
83
83
|
var _this = this;
|
|
84
84
|
return this.getSplit(name).then(function (split) {
|
|
85
85
|
if (split) {
|
|
86
|
-
|
|
87
|
-
_this._decrementCounts(parsedSplit);
|
|
86
|
+
_this._decrementCounts(split);
|
|
88
87
|
}
|
|
89
88
|
return _this.wrapper.del(_this.keys.buildSplitKey(name));
|
|
90
89
|
});
|
|
@@ -104,7 +103,8 @@ var SplitsCachePluggable = /** @class */ (function (_super) {
|
|
|
104
103
|
* or rejected if wrapper operation fails.
|
|
105
104
|
*/
|
|
106
105
|
SplitsCachePluggable.prototype.getSplit = function (name) {
|
|
107
|
-
return this.wrapper.get(this.keys.buildSplitKey(name))
|
|
106
|
+
return this.wrapper.get(this.keys.buildSplitKey(name))
|
|
107
|
+
.then(function (maybeSplit) { return maybeSplit && JSON.parse(maybeSplit); });
|
|
108
108
|
};
|
|
109
109
|
/**
|
|
110
110
|
* Get list of splits.
|
|
@@ -117,7 +117,8 @@ var SplitsCachePluggable = /** @class */ (function (_super) {
|
|
|
117
117
|
return this.wrapper.getMany(keys).then(function (splitDefinitions) {
|
|
118
118
|
var splits = {};
|
|
119
119
|
names.forEach(function (name, idx) {
|
|
120
|
-
|
|
120
|
+
var split = splitDefinitions[idx];
|
|
121
|
+
splits[name] = split && JSON.parse(split);
|
|
121
122
|
});
|
|
122
123
|
return Promise.resolve(splits);
|
|
123
124
|
});
|
|
@@ -129,7 +130,11 @@ var SplitsCachePluggable = /** @class */ (function (_super) {
|
|
|
129
130
|
*/
|
|
130
131
|
SplitsCachePluggable.prototype.getAll = function () {
|
|
131
132
|
var _this = this;
|
|
132
|
-
return this.wrapper.getKeysByPrefix(this.keys.buildSplitKeyPrefix())
|
|
133
|
+
return this.wrapper.getKeysByPrefix(this.keys.buildSplitKeyPrefix())
|
|
134
|
+
.then(function (listOfKeys) { return _this.wrapper.getMany(listOfKeys); })
|
|
135
|
+
.then(function (splitDefinitions) { return splitDefinitions.map(function (splitDefinition) {
|
|
136
|
+
return JSON.parse(splitDefinition);
|
|
137
|
+
}); });
|
|
133
138
|
};
|
|
134
139
|
/**
|
|
135
140
|
* Get list of split names.
|
|
@@ -27,8 +27,7 @@ function fromObjectUpdaterFactory(splitsParser, storage, readiness, settings) {
|
|
|
27
27
|
log.debug(constants_3.SYNC_OFFLINE_DATA, [JSON.stringify(splitsMock)]);
|
|
28
28
|
(0, lang_1.forOwn)(splitsMock, function (val, name) {
|
|
29
29
|
splits.push([
|
|
30
|
-
name,
|
|
31
|
-
JSON.stringify({
|
|
30
|
+
name, {
|
|
32
31
|
name: name,
|
|
33
32
|
status: 'ACTIVE',
|
|
34
33
|
killed: false,
|
|
@@ -37,7 +36,7 @@ function fromObjectUpdaterFactory(splitsParser, storage, readiness, settings) {
|
|
|
37
36
|
conditions: val.conditions || [],
|
|
38
37
|
configurations: val.configurations,
|
|
39
38
|
trafficTypeName: val.trafficTypeName
|
|
40
|
-
}
|
|
39
|
+
}
|
|
41
40
|
]);
|
|
42
41
|
});
|
|
43
42
|
return Promise.all([
|
|
@@ -41,7 +41,7 @@ function computeSplitsMutation(entries) {
|
|
|
41
41
|
var segments = new sets_1._Set();
|
|
42
42
|
var computed = entries.reduce(function (accum, split) {
|
|
43
43
|
if (split.status === 'ACTIVE') {
|
|
44
|
-
accum.added.push([split.name,
|
|
44
|
+
accum.added.push([split.name, split]);
|
|
45
45
|
parseSegments(split).forEach(function (segmentName) {
|
|
46
46
|
segments.add(segmentName);
|
|
47
47
|
});
|
|
@@ -5,7 +5,6 @@ var eventsSubmitter_1 = require("./eventsSubmitter");
|
|
|
5
5
|
var impressionsSubmitter_1 = require("./impressionsSubmitter");
|
|
6
6
|
var impressionCountsSubmitter_1 = require("./impressionCountsSubmitter");
|
|
7
7
|
var telemetrySubmitter_1 = require("./telemetrySubmitter");
|
|
8
|
-
var uniqueKeysSubmitter_1 = require("./uniqueKeysSubmitter");
|
|
9
8
|
function submitterManagerFactory(params) {
|
|
10
9
|
var submitters = [
|
|
11
10
|
(0, impressionsSubmitter_1.impressionsSubmitterFactory)(params),
|
|
@@ -15,8 +14,6 @@ function submitterManagerFactory(params) {
|
|
|
15
14
|
if (impressionCountsSubmitter)
|
|
16
15
|
submitters.push(impressionCountsSubmitter);
|
|
17
16
|
var telemetrySubmitter = (0, telemetrySubmitter_1.telemetrySubmitterFactory)(params);
|
|
18
|
-
if (params.uniqueKeysTracker)
|
|
19
|
-
submitters.push((0, uniqueKeysSubmitter_1.uniqueKeysSubmitterFactory)(params));
|
|
20
17
|
return {
|
|
21
18
|
// `onlyTelemetry` true if SDK is created with userConsent not GRANTED
|
|
22
19
|
start: function (onlyTelemetry) {
|
|
@@ -50,7 +50,6 @@ var OPERATION_MODE_MAP = (_a = {},
|
|
|
50
50
|
var IMPRESSIONS_MODE_MAP = (_b = {},
|
|
51
51
|
_b[constants_1.OPTIMIZED] = constants_1.OPTIMIZED_ENUM,
|
|
52
52
|
_b[constants_1.DEBUG] = constants_1.DEBUG_ENUM,
|
|
53
|
-
_b[constants_1.NONE] = constants_1.NONE_ENUM,
|
|
54
53
|
_b);
|
|
55
54
|
var USER_CONSENT_MAP = (_c = {},
|
|
56
55
|
_c[constants_1.CONSENT_UNKNOWN] = 1,
|
|
@@ -3,6 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.impressionsTrackerFactory = void 0;
|
|
4
4
|
var objectAssign_1 = require("../utils/lang/objectAssign");
|
|
5
5
|
var thenable_1 = require("../utils/promise/thenable");
|
|
6
|
+
var time_1 = require("../utils/time");
|
|
6
7
|
var constants_1 = require("../logger/constants");
|
|
7
8
|
var constants_2 = require("../utils/constants");
|
|
8
9
|
/**
|
|
@@ -12,34 +13,52 @@ var constants_2 = require("../utils/constants");
|
|
|
12
13
|
* @param metadata runtime metadata (ip, hostname and version)
|
|
13
14
|
* @param impressionListener optional impression listener
|
|
14
15
|
* @param integrationsManager optional integrations manager
|
|
15
|
-
* @param
|
|
16
|
+
* @param observer optional impression observer. If provided, previous time (pt property) is included in impression instances
|
|
17
|
+
* @param countsCache optional cache to save impressions count. If provided, impressions will be deduped (OPTIMIZED mode)
|
|
16
18
|
*/
|
|
17
|
-
function impressionsTrackerFactory(settings, impressionsCache,
|
|
19
|
+
function impressionsTrackerFactory(settings, impressionsCache, integrationsManager,
|
|
20
|
+
// if observer is provided, it implies `shouldAddPreviousTime` flag (i.e., if impressions previous time should be added or not)
|
|
21
|
+
observer,
|
|
22
|
+
// if countsCache is provided, it implies `isOptimized` flag (i.e., if impressions should be deduped or not)
|
|
23
|
+
countsCache, telemetryCache) {
|
|
18
24
|
var log = settings.log, impressionListener = settings.impressionListener, _a = settings.runtime, ip = _a.ip, hostname = _a.hostname, version = settings.version;
|
|
19
25
|
return {
|
|
20
26
|
track: function (impressions, attributes) {
|
|
21
27
|
if (settings.userConsent === constants_2.CONSENT_DECLINED)
|
|
22
28
|
return;
|
|
23
29
|
var impressionsCount = impressions.length;
|
|
24
|
-
var
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
res.then(function () {
|
|
31
|
-
log.info(constants_1.IMPRESSIONS_TRACKER_SUCCESS, [impressionsCount]);
|
|
32
|
-
}).catch(function (err) {
|
|
33
|
-
log.error(constants_1.ERROR_IMPRESSIONS_TRACKER, [impressionsCount, err]);
|
|
34
|
-
});
|
|
30
|
+
var impressionsToStore = []; // Track only the impressions that are going to be stored
|
|
31
|
+
// Wraps impressions to store and adds previousTime if it corresponds
|
|
32
|
+
impressions.forEach(function (impression) {
|
|
33
|
+
if (observer) {
|
|
34
|
+
// Adds previous time if it is enabled
|
|
35
|
+
impression.pt = observer.testAndSet(impression);
|
|
35
36
|
}
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
//
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
37
|
+
var now = Date.now();
|
|
38
|
+
if (countsCache) {
|
|
39
|
+
// Increments impression counter per featureName
|
|
40
|
+
countsCache.track(impression.feature, now, 1);
|
|
41
|
+
}
|
|
42
|
+
// Checks if the impression should be added in queue to be sent
|
|
43
|
+
if (!countsCache || !impression.pt || impression.pt < (0, time_1.truncateTimeFrame)(now)) {
|
|
44
|
+
impressionsToStore.push(impression);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
var res = impressionsCache.track(impressionsToStore);
|
|
48
|
+
// If we're on an async storage, handle error and log it.
|
|
49
|
+
if ((0, thenable_1.thenable)(res)) {
|
|
50
|
+
res.then(function () {
|
|
51
|
+
log.info(constants_1.IMPRESSIONS_TRACKER_SUCCESS, [impressionsCount]);
|
|
52
|
+
}).catch(function (err) {
|
|
53
|
+
log.error(constants_1.ERROR_IMPRESSIONS_TRACKER, [impressionsCount, err]);
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
else {
|
|
57
|
+
// Record when impressionsCache is sync only (standalone mode)
|
|
58
|
+
// @TODO we are not dropping impressions on full queue yet, so DROPPED stats are not recorded
|
|
59
|
+
if (telemetryCache) {
|
|
60
|
+
telemetryCache.recordImpressionStats(constants_2.QUEUED, impressionsToStore.length);
|
|
61
|
+
telemetryCache.recordImpressionStats(constants_2.DEDUPED, impressions.length - impressionsToStore.length);
|
|
43
62
|
}
|
|
44
63
|
}
|
|
45
64
|
// @TODO next block might be handled by the integration manager. In that case, the metadata object doesn't need to be passed in the constructor
|
|
@@ -47,7 +66,7 @@ function impressionsTrackerFactory(settings, impressionsCache, strategy, integra
|
|
|
47
66
|
var _loop_1 = function (i) {
|
|
48
67
|
var impressionData = {
|
|
49
68
|
// copy of impression, to avoid unexpected behaviour if modified by integrations or impressionListener
|
|
50
|
-
impression: (0, objectAssign_1.objectAssign)({},
|
|
69
|
+
impression: (0, objectAssign_1.objectAssign)({}, impressions[i]),
|
|
51
70
|
attributes: attributes,
|
|
52
71
|
ip: ip,
|
|
53
72
|
hostname: hostname,
|
|
@@ -67,7 +86,7 @@ function impressionsTrackerFactory(settings, impressionsCache, strategy, integra
|
|
|
67
86
|
}
|
|
68
87
|
}, 0);
|
|
69
88
|
};
|
|
70
|
-
for (var i = 0; i <
|
|
89
|
+
for (var i = 0; i < impressionsCount; i++) {
|
|
71
90
|
_loop_1(i);
|
|
72
91
|
}
|
|
73
92
|
}
|
|
@@ -49,6 +49,11 @@ function telemetryTrackerFactory(telemetryCache, now) {
|
|
|
49
49
|
if (e === constants_1.TOKEN_REFRESH)
|
|
50
50
|
telemetryCache.recordTokenRefreshes();
|
|
51
51
|
}
|
|
52
|
+
},
|
|
53
|
+
addTag: function (tag) {
|
|
54
|
+
// @ts-ignore
|
|
55
|
+
if (telemetryCache.addTag)
|
|
56
|
+
telemetryCache.addTag(tag);
|
|
52
57
|
}
|
|
53
58
|
};
|
|
54
59
|
}
|
|
@@ -59,6 +64,7 @@ function telemetryTrackerFactory(telemetryCache, now) {
|
|
|
59
64
|
trackHttp: noopTrack,
|
|
60
65
|
sessionLength: function () { },
|
|
61
66
|
streamingEvent: function () { },
|
|
67
|
+
addTag: function () { }
|
|
62
68
|
};
|
|
63
69
|
}
|
|
64
70
|
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ABLY_ERROR = exports.TOKEN_REFRESH = exports.SSE_CONNECTION_ERROR = exports.STREAMING_STATUS = exports.OCCUPANCY_SEC = exports.OCCUPANCY_PRI = exports.CONNECTION_ESTABLISHED = exports.TRACK = exports.TREATMENTS_WITH_CONFIG = exports.TREATMENT_WITH_CONFIG = exports.TREATMENTS = exports.TREATMENT = exports.MY_SEGMENT = exports.SEGMENT = exports.TOKEN = exports.TELEMETRY = exports.EVENTS = exports.IMPRESSIONS_COUNT = exports.IMPRESSIONS = exports.SPLITS = exports.
|
|
4
|
-
exports.PAUSED = exports.ENABLED = exports.DISABLED = exports.NON_REQUESTED = exports.REQUESTED = exports.POLLING = exports.STREAMING =
|
|
3
|
+
exports.AUTH_REJECTION = exports.SYNC_MODE_UPDATE = exports.ABLY_ERROR = exports.TOKEN_REFRESH = exports.SSE_CONNECTION_ERROR = exports.STREAMING_STATUS = exports.OCCUPANCY_SEC = exports.OCCUPANCY_PRI = exports.CONNECTION_ESTABLISHED = exports.TRACK = exports.TREATMENTS_WITH_CONFIG = exports.TREATMENT_WITH_CONFIG = exports.TREATMENTS = exports.TREATMENT = exports.MY_SEGMENT = exports.SEGMENT = exports.TOKEN = exports.TELEMETRY = exports.EVENTS = exports.IMPRESSIONS_COUNT = exports.IMPRESSIONS = exports.SPLITS = exports.DEBUG_ENUM = exports.OPTIMIZED_ENUM = exports.CONSUMER_PARTIAL_ENUM = exports.CONSUMER_ENUM = exports.STANDALONE_ENUM = exports.DEDUPED = exports.DROPPED = exports.QUEUED = exports.CONSENT_UNKNOWN = exports.CONSENT_DECLINED = exports.CONSENT_GRANTED = exports.STORAGE_PLUGGABLE = exports.STORAGE_REDIS = exports.STORAGE_LOCALSTORAGE = exports.STORAGE_MEMORY = exports.CONSUMER_PARTIAL_MODE = exports.CONSUMER_MODE = exports.PRODUCER_MODE = exports.STANDALONE_MODE = exports.LOCALHOST_MODE = exports.OPTIMIZED = exports.DEBUG = exports.SPLIT_EVENT = exports.SPLIT_IMPRESSION = exports.NA = exports.UNKNOWN = exports.CONTROL_WITH_CONFIG = exports.CONTROL = void 0;
|
|
4
|
+
exports.PAUSED = exports.ENABLED = exports.DISABLED = exports.NON_REQUESTED = exports.REQUESTED = exports.POLLING = exports.STREAMING = void 0;
|
|
5
5
|
// Special treatments
|
|
6
6
|
exports.CONTROL = 'control';
|
|
7
7
|
exports.CONTROL_WITH_CONFIG = {
|
|
@@ -17,7 +17,6 @@ exports.SPLIT_EVENT = 'EVENT';
|
|
|
17
17
|
// Impression collection modes
|
|
18
18
|
exports.DEBUG = 'DEBUG';
|
|
19
19
|
exports.OPTIMIZED = 'OPTIMIZED';
|
|
20
|
-
exports.NONE = 'NONE';
|
|
21
20
|
// SDK Modes
|
|
22
21
|
exports.LOCALHOST_MODE = 'localhost';
|
|
23
22
|
exports.STANDALONE_MODE = 'standalone';
|
|
@@ -42,7 +41,6 @@ exports.CONSUMER_ENUM = 1;
|
|
|
42
41
|
exports.CONSUMER_PARTIAL_ENUM = 2;
|
|
43
42
|
exports.OPTIMIZED_ENUM = 0;
|
|
44
43
|
exports.DEBUG_ENUM = 1;
|
|
45
|
-
exports.NONE_ENUM = 2;
|
|
46
44
|
exports.SPLITS = 'sp';
|
|
47
45
|
exports.IMPRESSIONS = 'im';
|
|
48
46
|
exports.IMPRESSIONS_COUNT = 'ic';
|
|
@@ -6,9 +6,9 @@ var constants_2 = require("../constants");
|
|
|
6
6
|
var lang_1 = require("../lang");
|
|
7
7
|
function validImpressionsMode(log, impressionsMode) {
|
|
8
8
|
impressionsMode = (0, lang_1.stringToUpperCase)(impressionsMode);
|
|
9
|
-
if ([constants_2.DEBUG, constants_2.OPTIMIZED
|
|
9
|
+
if ([constants_2.DEBUG, constants_2.OPTIMIZED].indexOf(impressionsMode) > -1)
|
|
10
10
|
return impressionsMode;
|
|
11
|
-
log.error(constants_1.ERROR_INVALID_CONFIG_PARAM, ['impressionsMode', [constants_2.DEBUG, constants_2.OPTIMIZED
|
|
11
|
+
log.error(constants_1.ERROR_INVALID_CONFIG_PARAM, ['impressionsMode', [constants_2.DEBUG, constants_2.OPTIMIZED], constants_2.OPTIMIZED]);
|
|
12
12
|
return constants_2.OPTIMIZED;
|
|
13
13
|
}
|
|
14
14
|
exports.validImpressionsMode = validImpressionsMode;
|
|
@@ -34,8 +34,6 @@ exports.base = {
|
|
|
34
34
|
telemetryRefreshRate: 3600,
|
|
35
35
|
// publish evaluations each 300 sec (default value for OPTIMIZED impressions mode)
|
|
36
36
|
impressionsRefreshRate: 300,
|
|
37
|
-
// publish unique Keys each 900 sec (15 min)
|
|
38
|
-
uniqueKeysRefreshRate: 900,
|
|
39
37
|
// fetch offline changes each 15 sec
|
|
40
38
|
offlineRefreshRate: 15,
|
|
41
39
|
// publish events every 60 seconds after the first flush
|
|
@@ -114,7 +112,6 @@ function settingsValidation(config, validationParams) {
|
|
|
114
112
|
scheduler.segmentsRefreshRate = fromSecondsToMillis(scheduler.segmentsRefreshRate);
|
|
115
113
|
scheduler.offlineRefreshRate = fromSecondsToMillis(scheduler.offlineRefreshRate);
|
|
116
114
|
scheduler.eventsPushRate = fromSecondsToMillis(scheduler.eventsPushRate);
|
|
117
|
-
scheduler.uniqueKeysRefreshRate = fromSecondsToMillis(scheduler.uniqueKeysRefreshRate);
|
|
118
115
|
scheduler.telemetryRefreshRate = fromSecondsToMillis(validateMinValue('telemetryRefreshRate', scheduler.telemetryRefreshRate, 60));
|
|
119
116
|
// Default impressionsRefreshRate for DEBUG mode is 60 secs
|
|
120
117
|
if ((0, lang_1.get)(config, 'scheduler.impressionsRefreshRate') === undefined && withDefaults.sync.impressionsMode === constants_1.DEBUG)
|
|
@@ -36,8 +36,8 @@ export function createUserConsentAPI(params) {
|
|
|
36
36
|
if (events.clear)
|
|
37
37
|
events.clear(); // @ts-ignore
|
|
38
38
|
if (impressions.clear)
|
|
39
|
-
impressions.clear();
|
|
40
|
-
if (impressionCounts
|
|
39
|
+
impressions.clear();
|
|
40
|
+
if (impressionCounts)
|
|
41
41
|
impressionCounts.clear();
|
|
42
42
|
}
|
|
43
43
|
}
|
package/esm/evaluator/index.js
CHANGED
|
@@ -32,44 +32,43 @@ export function evaluateFeature(log, key, splitName, attributes, storage) {
|
|
|
32
32
|
return getEvaluation(log, stringifiedSplit, key, attributes, storage);
|
|
33
33
|
}
|
|
34
34
|
export function evaluateFeatures(log, key, splitNames, attributes, storage) {
|
|
35
|
-
var
|
|
35
|
+
var parsedSplits;
|
|
36
36
|
try {
|
|
37
|
-
|
|
37
|
+
parsedSplits = storage.splits.getSplits(splitNames);
|
|
38
38
|
}
|
|
39
39
|
catch (e) {
|
|
40
40
|
// Exception on sync `getSplits` storage. Not possible ATM with InMemory and InLocal storages.
|
|
41
41
|
return treatmentsException(splitNames);
|
|
42
42
|
}
|
|
43
|
-
return
|
|
44
|
-
|
|
43
|
+
return thenable(parsedSplits) ?
|
|
44
|
+
parsedSplits.then(function (splits) { return getEvaluations(log, splitNames, splits, key, attributes, storage); })
|
|
45
45
|
.catch(function () {
|
|
46
46
|
// Exception on async `getSplits` storage. For example, when the storage is redis or
|
|
47
47
|
// pluggable and there is a connection issue and we can't retrieve the split to be evaluated
|
|
48
48
|
return treatmentsException(splitNames);
|
|
49
49
|
}) :
|
|
50
|
-
getEvaluations(log, splitNames,
|
|
50
|
+
getEvaluations(log, splitNames, parsedSplits, key, attributes, storage);
|
|
51
51
|
}
|
|
52
|
-
function getEvaluation(log,
|
|
52
|
+
function getEvaluation(log, splitJSON, key, attributes, storage) {
|
|
53
53
|
var evaluation = {
|
|
54
54
|
treatment: CONTROL,
|
|
55
55
|
label: LabelsConstants.SPLIT_NOT_FOUND,
|
|
56
56
|
config: null
|
|
57
57
|
};
|
|
58
|
-
if (
|
|
59
|
-
var
|
|
60
|
-
var split_1 = Engine.parse(log, splitJSON_1, storage);
|
|
58
|
+
if (splitJSON) {
|
|
59
|
+
var split_1 = Engine.parse(log, splitJSON, storage);
|
|
61
60
|
evaluation = split_1.getTreatment(key, attributes, evaluateFeature);
|
|
62
61
|
// If the storage is async and the evaluated split uses segment, evaluation is thenable
|
|
63
62
|
if (thenable(evaluation)) {
|
|
64
63
|
return evaluation.then(function (result) {
|
|
65
64
|
result.changeNumber = split_1.getChangeNumber();
|
|
66
|
-
result.config =
|
|
65
|
+
result.config = splitJSON.configurations && splitJSON.configurations[result.treatment] || null;
|
|
67
66
|
return result;
|
|
68
67
|
});
|
|
69
68
|
}
|
|
70
69
|
else {
|
|
71
70
|
evaluation.changeNumber = split_1.getChangeNumber(); // Always sync and optional
|
|
72
|
-
evaluation.config =
|
|
71
|
+
evaluation.config = splitJSON.configurations && splitJSON.configurations[evaluation.treatment] || null;
|
|
73
72
|
}
|
|
74
73
|
}
|
|
75
74
|
return evaluation;
|
|
@@ -13,7 +13,7 @@ var logNameMapper = 'ga-to-split:mapper';
|
|
|
13
13
|
* @param log Logger instance.
|
|
14
14
|
* @param autoRequire If true, log error when auto-require script is not detected
|
|
15
15
|
*/
|
|
16
|
-
function providePlugin(window, pluginName, pluginConstructor, log, autoRequire) {
|
|
16
|
+
function providePlugin(window, pluginName, pluginConstructor, log, autoRequire, telemetryTracker) {
|
|
17
17
|
// get reference to global command queue. Init it if not defined yet.
|
|
18
18
|
var gaAlias = window.GoogleAnalyticsObject || 'ga';
|
|
19
19
|
window[gaAlias] = window[gaAlias] || function () {
|
|
@@ -21,10 +21,13 @@ function providePlugin(window, pluginName, pluginConstructor, log, autoRequire)
|
|
|
21
21
|
};
|
|
22
22
|
// provides the plugin for use with analytics.js.
|
|
23
23
|
window[gaAlias]('provide', pluginName, pluginConstructor);
|
|
24
|
-
|
|
25
|
-
|
|
24
|
+
var hasAutoRequire = window[gaAlias].q && window[gaAlias].q.push !== [].push;
|
|
25
|
+
if (autoRequire && !hasAutoRequire) { // Expecting spy on ga.q push method but not found
|
|
26
26
|
log.error(logPrefix + 'integration is configured to autorequire the splitTracker plugin, but the necessary script does not seem to have run. Please check the docs.');
|
|
27
27
|
}
|
|
28
|
+
if (telemetryTracker && hasAutoRequire) {
|
|
29
|
+
telemetryTracker.addTag('integration:ga-autorequire');
|
|
30
|
+
}
|
|
28
31
|
}
|
|
29
32
|
// Default mapping: object used for building the default mapper from hits to Split events
|
|
30
33
|
var defaultMapping = {
|
|
@@ -157,7 +160,7 @@ export function fixEventTypeId(log, eventTypeId) {
|
|
|
157
160
|
* @param {object} log factory logger
|
|
158
161
|
*/
|
|
159
162
|
export function GaToSplit(sdkOptions, params) {
|
|
160
|
-
var storage = params.storage, _a = params.settings, coreSettings = _a.core, log = _a.log;
|
|
163
|
+
var storage = params.storage, _a = params.settings, coreSettings = _a.core, log = _a.log, telemetryTracker = params.telemetryTracker;
|
|
161
164
|
var defaultOptions = {
|
|
162
165
|
prefix: defaultPrefix,
|
|
163
166
|
// We set default identities if key and TT are present in settings.core
|
|
@@ -243,5 +246,5 @@ export function GaToSplit(sdkOptions, params) {
|
|
|
243
246
|
return SplitTracker;
|
|
244
247
|
}());
|
|
245
248
|
// Register the plugin, even if config is invalid, since, if not provided, it will block `ga` command queue.
|
|
246
|
-
providePlugin(window, 'splitTracker', SplitTracker, log, sdkOptions.autoRequire === true);
|
|
249
|
+
providePlugin(window, 'splitTracker', SplitTracker, log, sdkOptions.autoRequire === true, telemetryTracker);
|
|
247
250
|
}
|
package/esm/listeners/browser.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { fromImpressionsCollector } from '../sync/submitters/impressionsSubmitter';
|
|
2
2
|
import { fromImpressionCountsCollector } from '../sync/submitters/impressionCountsSubmitter';
|
|
3
|
-
import { OPTIMIZED, DEBUG
|
|
3
|
+
import { OPTIMIZED, DEBUG } from '../utils/constants';
|
|
4
4
|
import { objectAssign } from '../utils/lang/objectAssign';
|
|
5
5
|
import { CLEANUP_REGISTERING, CLEANUP_DEREGISTERING } from '../logger/constants';
|
|
6
6
|
import { isConsentGranted } from '../consent';
|
|
@@ -71,10 +71,9 @@ var BrowserSignalListener = /** @class */ (function () {
|
|
|
71
71
|
// Flush impressions & events data if there is user consent
|
|
72
72
|
if (isConsentGranted(this.settings)) {
|
|
73
73
|
var eventsUrl = this.settings.urls.events;
|
|
74
|
-
var sim = this.settings.sync.impressionsMode;
|
|
75
74
|
var extraMetadata = {
|
|
76
75
|
// sim stands for Sync/Split Impressions Mode
|
|
77
|
-
sim:
|
|
76
|
+
sim: this.settings.sync.impressionsMode === OPTIMIZED ? OPTIMIZED : DEBUG
|
|
78
77
|
};
|
|
79
78
|
this._flushData(eventsUrl + '/testImpressions/beacon', this.storage.impressions, this.serviceApi.postTestImpressionsBulk, this.fromImpressionsCollector, extraMetadata);
|
|
80
79
|
this._flushData(eventsUrl + '/events/beacon', this.storage.events, this.serviceApi.postEventsBulk);
|
package/esm/logger/constants.js
CHANGED
|
@@ -139,5 +139,4 @@ export var LOG_PREFIX_SYNC_POLLING = LOG_PREFIX_SYNC + ':polling-manager: ';
|
|
|
139
139
|
export var LOG_PREFIX_SYNC_SUBMITTERS = LOG_PREFIX_SYNC + ':submitter: ';
|
|
140
140
|
export var LOG_PREFIX_IMPRESSIONS_TRACKER = 'impressions-tracker: ';
|
|
141
141
|
export var LOG_PREFIX_EVENTS_TRACKER = 'events-tracker: ';
|
|
142
|
-
export var LOG_PREFIX_UNIQUE_KEYS_TRACKER = 'unique-keys-tracker: ';
|
|
143
142
|
export var LOG_PREFIX_CLEANUP = 'cleanup: ';
|
package/esm/sdkFactory/index.js
CHANGED
|
@@ -10,16 +10,11 @@ import { NEW_FACTORY, RETRIEVE_MANAGER } from '../logger/constants';
|
|
|
10
10
|
import { metadataBuilder } from '../storages/metadataBuilder';
|
|
11
11
|
import { SDK_SPLITS_ARRIVED, SDK_SEGMENTS_ARRIVED } from '../readiness/constants';
|
|
12
12
|
import { objectAssign } from '../utils/lang/objectAssign';
|
|
13
|
-
import { strategyDebugFactory } from '../trackers/strategy/strategyDebug';
|
|
14
|
-
import { strategyOptimizedFactory } from '../trackers/strategy/strategyOptimized';
|
|
15
|
-
import { strategyNoneFactory } from '../trackers/strategy/strategyNone';
|
|
16
|
-
import { uniqueKeysTrackerFactory } from '../trackers/uniqueKeysTracker';
|
|
17
|
-
import { NONE, OPTIMIZED } from '../utils/constants';
|
|
18
13
|
/**
|
|
19
14
|
* Modular SDK factory
|
|
20
15
|
*/
|
|
21
16
|
export function sdkFactory(params) {
|
|
22
|
-
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
|
|
17
|
+
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;
|
|
23
18
|
var log = settings.log;
|
|
24
19
|
// @TODO handle non-recoverable errors, such as, global `fetch` not available, invalid API Key, etc.
|
|
25
20
|
// On non-recoverable errors, we should mark the SDK as destroyed and not start synchronization.
|
|
@@ -31,14 +26,12 @@ export function sdkFactory(params) {
|
|
|
31
26
|
var storageFactoryParams = {
|
|
32
27
|
impressionsQueueSize: settings.scheduler.impressionsQueueSize,
|
|
33
28
|
eventsQueueSize: settings.scheduler.eventsQueueSize,
|
|
34
|
-
uniqueKeysCacheSize: settings.scheduler.uniqueKeysCacheSize,
|
|
35
29
|
optimize: shouldBeOptimized(settings),
|
|
36
30
|
// ATM, only used by InLocalStorage
|
|
37
31
|
matchingKey: getMatching(settings.core.key),
|
|
38
32
|
splitFiltersValidation: settings.sync.__splitFiltersValidation,
|
|
39
33
|
// ATM, only used by PluggableStorage
|
|
40
34
|
mode: settings.mode,
|
|
41
|
-
impressionsMode: settings.sync.impressionsMode,
|
|
42
35
|
// Callback used to emit SDK_READY in consumer mode, where `syncManagerFactory` is undefined,
|
|
43
36
|
// or partial consumer mode, where it only has submitters, and therefore it doesn't emit readiness events.
|
|
44
37
|
onReadyCb: function (error) {
|
|
@@ -52,26 +45,15 @@ export function sdkFactory(params) {
|
|
|
52
45
|
};
|
|
53
46
|
var storage = storageFactory(storageFactoryParams);
|
|
54
47
|
// @TODO add support for dataloader: `if (params.dataLoader) params.dataLoader(storage);`
|
|
55
|
-
var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage });
|
|
56
|
-
var observer = impressionsObserverFactory();
|
|
57
|
-
var uniqueKeysTracker = storageFactoryParams.impressionsMode === NONE ? uniqueKeysTrackerFactory(log, storage.uniqueKeys, filterAdapterFactory && filterAdapterFactory()) : undefined;
|
|
58
|
-
var strategy;
|
|
59
|
-
switch (storageFactoryParams.impressionsMode) {
|
|
60
|
-
case OPTIMIZED:
|
|
61
|
-
strategy = strategyOptimizedFactory(observer, storage.impressionCounts);
|
|
62
|
-
break;
|
|
63
|
-
case NONE:
|
|
64
|
-
strategy = strategyNoneFactory(storage.impressionCounts, uniqueKeysTracker);
|
|
65
|
-
break;
|
|
66
|
-
default:
|
|
67
|
-
strategy = strategyDebugFactory(observer);
|
|
68
|
-
}
|
|
69
|
-
var impressionsTracker = impressionsTrackerFactory(settings, storage.impressions, strategy, integrationsManager, storage.telemetry);
|
|
70
|
-
var eventTracker = eventTrackerFactory(settings, storage.events, integrationsManager, storage.telemetry);
|
|
71
48
|
var telemetryTracker = telemetryTrackerFactory(storage.telemetry, platform.now);
|
|
49
|
+
var integrationsManager = integrationsManagerFactory && integrationsManagerFactory({ settings: settings, storage: storage, telemetryTracker: telemetryTracker });
|
|
50
|
+
// trackers
|
|
51
|
+
var observer = impressionsObserverFactory && impressionsObserverFactory();
|
|
52
|
+
var impressionsTracker = impressionsTrackerFactory(settings, storage.impressions, integrationsManager, observer, storage.impressionCounts, storage.telemetry);
|
|
53
|
+
var eventTracker = eventTrackerFactory(settings, storage.events, integrationsManager, storage.telemetry);
|
|
72
54
|
// splitApi is used by SyncManager and Browser signal listener
|
|
73
55
|
var splitApi = splitApiFactory && splitApiFactory(settings, platform, telemetryTracker);
|
|
74
|
-
var ctx = { splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker,
|
|
56
|
+
var ctx = { splitApi: splitApi, eventTracker: eventTracker, impressionsTracker: impressionsTracker, telemetryTracker: telemetryTracker, sdkReadinessManager: sdkReadinessManager, readiness: readiness, settings: settings, storage: storage, platform: platform };
|
|
75
57
|
var syncManager = syncManagerFactory && syncManagerFactory(ctx);
|
|
76
58
|
ctx.syncManager = syncManager;
|
|
77
59
|
var signalListener = SignalListener && new SignalListener(syncManager, settings, storage, splitApi);
|
package/esm/sdkManager/index.js
CHANGED
|
@@ -12,15 +12,7 @@ function collectTreatments(splitObject) {
|
|
|
12
12
|
// Then extract the treatments from the partitions
|
|
13
13
|
return allTreatmentsCondition ? allTreatmentsCondition.partitions.map(function (v) { return v.treatment; }) : [];
|
|
14
14
|
}
|
|
15
|
-
function objectToView(
|
|
16
|
-
var splitObject;
|
|
17
|
-
try {
|
|
18
|
-
// @ts-expect-error
|
|
19
|
-
splitObject = JSON.parse(json);
|
|
20
|
-
}
|
|
21
|
-
catch (e) {
|
|
22
|
-
return null;
|
|
23
|
-
}
|
|
15
|
+
function objectToView(splitObject) {
|
|
24
16
|
if (!splitObject)
|
|
25
17
|
return null;
|
|
26
18
|
return {
|
|
@@ -32,9 +24,9 @@ function objectToView(json) {
|
|
|
32
24
|
configs: splitObject.configurations || {}
|
|
33
25
|
};
|
|
34
26
|
}
|
|
35
|
-
function objectsToViews(
|
|
27
|
+
function objectsToViews(splitObjects) {
|
|
36
28
|
var views = [];
|
|
37
|
-
|
|
29
|
+
splitObjects.forEach(function (split) {
|
|
38
30
|
var view = objectToView(split);
|
|
39
31
|
if (view)
|
|
40
32
|
views.push(view);
|
package/esm/services/splitApi.js
CHANGED
|
@@ -87,26 +87,6 @@ export function splitApiFactory(settings, platform, telemetryTracker) {
|
|
|
87
87
|
var url = urls.events + "/testImpressions/count";
|
|
88
88
|
return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(IMPRESSIONS_COUNT));
|
|
89
89
|
},
|
|
90
|
-
/**
|
|
91
|
-
* Post unique keys for client side.
|
|
92
|
-
*
|
|
93
|
-
* @param body unique keys payload
|
|
94
|
-
* @param headers Optionals headers to overwrite default ones. For example, it is used in producer mode to overwrite metadata headers.
|
|
95
|
-
*/
|
|
96
|
-
postUniqueKeysBulkCs: function (body, headers) {
|
|
97
|
-
var url = urls.telemetry + "/v1/keys/cs";
|
|
98
|
-
return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(TELEMETRY));
|
|
99
|
-
},
|
|
100
|
-
/**
|
|
101
|
-
* Post unique keys for server side.
|
|
102
|
-
*
|
|
103
|
-
* @param body unique keys payload
|
|
104
|
-
* @param headers Optionals headers to overwrite default ones. For example, it is used in producer mode to overwrite metadata headers.
|
|
105
|
-
*/
|
|
106
|
-
postUniqueKeysBulkSs: function (body, headers) {
|
|
107
|
-
var url = urls.telemetry + "/v1/keys/ss";
|
|
108
|
-
return splitHttpClient(url, { method: 'POST', body: body, headers: headers }, telemetryTracker.trackHttp(TELEMETRY));
|
|
109
|
-
},
|
|
110
90
|
postMetricsConfig: function (body) {
|
|
111
91
|
var url = urls.telemetry + "/v1/metrics/config";
|
|
112
92
|
return splitHttpClient(url, { method: 'POST', body: body }, telemetryTracker.trackHttp(TELEMETRY), true);
|