@splitsoftware/splitio-commons 1.17.1-rc.4 → 2.0.0-rc.1
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 +4 -0
- package/cjs/evaluator/Engine.js +1 -1
- package/cjs/evaluator/index.js +1 -1
- 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/sdkClient/clientCS.js +5 -8
- package/cjs/sdkClient/sdkClientMethodCS.js +1 -1
- package/cjs/services/decorateHeaders.js +1 -2
- package/cjs/storages/KeyBuilderCS.js +0 -9
- package/cjs/storages/inLocalStorage/MySegmentsCacheInLocal.js +1 -21
- package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +4 -4
- package/cjs/storages/inLocalStorage/index.js +1 -1
- package/cjs/storages/inMemory/InMemoryStorageCS.js +1 -1
- package/cjs/storages/inMemory/SegmentsCacheInMemory.js +2 -3
- package/cjs/storages/inMemory/SplitsCacheInMemory.js +2 -3
- package/cjs/storages/inMemory/UniqueKeysCacheInMemory.js +2 -2
- package/cjs/storages/inMemory/UniqueKeysCacheInMemoryCS.js +2 -2
- package/cjs/storages/inRedis/RedisAdapter.js +2 -2
- package/cjs/storages/inRedis/SplitsCacheInRedis.js +1 -1
- package/cjs/storages/inRedis/TelemetryCacheInRedis.js +3 -4
- package/cjs/storages/inRedis/UniqueKeysCacheInRedis.js +1 -1
- package/cjs/storages/pluggable/SplitsCachePluggable.js +1 -1
- package/cjs/storages/pluggable/TelemetryCachePluggable.js +6 -7
- package/cjs/storages/pluggable/UniqueKeysCachePluggable.js +1 -1
- package/cjs/storages/pluggable/inMemoryWrapper.js +6 -6
- package/cjs/sync/polling/updaters/splitChangesUpdater.js +3 -3
- package/cjs/sync/streaming/parseUtils.js +0 -1
- package/cjs/sync/streaming/pushManager.js +2 -3
- 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 +10 -107
- package/cjs/utils/settingsValidation/index.js +0 -9
- package/cjs/utils/settingsValidation/logger/builtinLogger.js +1 -2
- package/esm/evaluator/Engine.js +1 -1
- package/esm/evaluator/index.js +2 -2
- 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/sdkClient/clientCS.js +5 -8
- package/esm/sdkClient/sdkClientMethodCS.js +1 -1
- package/esm/services/decorateHeaders.js +1 -2
- package/esm/storages/KeyBuilderCS.js +0 -9
- package/esm/storages/inLocalStorage/MySegmentsCacheInLocal.js +1 -21
- package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +4 -4
- package/esm/storages/inLocalStorage/index.js +1 -1
- package/esm/storages/inMemory/InMemoryStorageCS.js +1 -1
- package/esm/storages/inMemory/SegmentsCacheInMemory.js +2 -3
- package/esm/storages/inMemory/SplitsCacheInMemory.js +2 -3
- package/esm/storages/inMemory/UniqueKeysCacheInMemory.js +2 -2
- package/esm/storages/inMemory/UniqueKeysCacheInMemoryCS.js +2 -2
- package/esm/storages/inRedis/RedisAdapter.js +2 -2
- package/esm/storages/inRedis/SplitsCacheInRedis.js +2 -2
- package/esm/storages/inRedis/TelemetryCacheInRedis.js +3 -4
- package/esm/storages/inRedis/UniqueKeysCacheInRedis.js +1 -1
- package/esm/storages/pluggable/SplitsCachePluggable.js +2 -2
- package/esm/storages/pluggable/TelemetryCachePluggable.js +6 -7
- package/esm/storages/pluggable/UniqueKeysCachePluggable.js +1 -1
- package/esm/storages/pluggable/inMemoryWrapper.js +7 -7
- package/esm/sync/polling/updaters/splitChangesUpdater.js +3 -3
- package/esm/sync/streaming/parseUtils.js +0 -1
- package/esm/sync/streaming/pushManager.js +2 -3
- 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 +9 -105
- package/esm/utils/settingsValidation/index.js +0 -9
- package/esm/utils/settingsValidation/logger/builtinLogger.js +1 -2
- package/package.json +2 -2
- package/src/evaluator/Engine.ts +1 -1
- package/src/evaluator/index.ts +4 -4
- 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/sdkClient/clientCS.ts +5 -8
- package/src/sdkClient/sdkClientMethodCS.ts +1 -1
- package/src/sdkFactory/types.ts +1 -1
- package/src/services/decorateHeaders.ts +1 -2
- package/src/storages/AbstractSplitsCacheAsync.ts +1 -2
- package/src/storages/AbstractSplitsCacheSync.ts +1 -2
- package/src/storages/KeyBuilderCS.ts +0 -13
- package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +1 -21
- package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +5 -5
- package/src/storages/inLocalStorage/index.ts +1 -1
- package/src/storages/inMemory/InMemoryStorageCS.ts +1 -1
- package/src/storages/inMemory/SegmentsCacheInMemory.ts +3 -4
- package/src/storages/inMemory/SplitsCacheInMemory.ts +4 -5
- package/src/storages/inMemory/UniqueKeysCacheInMemory.ts +4 -4
- package/src/storages/inMemory/UniqueKeysCacheInMemoryCS.ts +4 -4
- package/src/storages/inRedis/RedisAdapter.ts +3 -3
- package/src/storages/inRedis/SplitsCacheInRedis.ts +3 -3
- package/src/storages/inRedis/TelemetryCacheInRedis.ts +3 -4
- package/src/storages/inRedis/UniqueKeysCacheInRedis.ts +1 -1
- 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 -1
- package/src/storages/pluggable/inMemoryWrapper.ts +9 -9
- package/src/storages/types.ts +3 -4
- package/src/sync/polling/updaters/splitChangesUpdater.ts +4 -4
- 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/types.ts +1 -9
- 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 +10 -122
- package/src/utils/settingsValidation/index.ts +0 -10
- package/src/utils/settingsValidation/logger/builtinLogger.ts +1 -2
- package/src/utils/settingsValidation/types.ts +0 -2
- package/types/logger/index.d.ts +1 -2
- package/types/sdkClient/clientCS.d.ts +2 -3
- package/types/sdkFactory/types.d.ts +1 -1
- package/types/storages/AbstractSplitsCacheAsync.d.ts +1 -2
- package/types/storages/AbstractSplitsCacheSync.d.ts +1 -2
- package/types/storages/KeyBuilderCS.d.ts +0 -2
- package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +1 -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 +3 -4
- package/types/sync/polling/updaters/splitChangesUpdater.d.ts +1 -2
- package/types/sync/submitters/types.d.ts +3 -4
- package/types/types.d.ts +1 -9
- 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 +2 -61
- package/types/utils/settingsValidation/index.d.ts +0 -1
- 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 -75
- 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 -71
- 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 -96
- package/src/utils/lang/maps.ts +0 -108
package/CHANGES.txt
CHANGED
|
@@ -7,6 +7,10 @@
|
|
|
7
7
|
- Updated default flag spec version to 1.2.
|
|
8
8
|
- Removed `/mySegments` endpoint from SplitAPI module, as it is replaced by `/memberships` endpoint.
|
|
9
9
|
- Removed support for MY_SEGMENTS_UPDATE and MY_SEGMENTS_UPDATE_V2 notification types, as they are replaced by MEMBERSHIPS_MS_UPDATE and MEMBERSHIPS_LS_UPDATE notification types.
|
|
10
|
+
- Removed the deprecated `GOOGLE_ANALYTICS_TO_SPLIT` and `SPLIT_TO_GOOGLE_ANALYTICS` integrations.
|
|
11
|
+
- Removed the migration logic for the old format of MySegments keys in LocalStorage introduced in JavaScript SDK v10.17.3.
|
|
12
|
+
- Removed the `sdkClientMethodCSWithTT` function, which handled the logic to bound an optional traffic type to SDK clients. Client-side SDK implementations must use `sdkClientMethodCS` module, which, unlike the previous function, does not allow passing a traffic type but simplifies the SDK API.
|
|
13
|
+
- Removed internal ponyfills for `Map` and `Set` global objects, dropping support for IE and other outdated browsers. The SDK now requires the runtime environment to support these features natively or to provide a polyfill.
|
|
10
14
|
|
|
11
15
|
1.17.0 (September 6, 2024)
|
|
12
16
|
- Added `sync.requestOptions.getHeaderOverrides` configuration option to enhance SDK HTTP request Headers for Authorization Frameworks.
|
package/cjs/evaluator/Engine.js
CHANGED
|
@@ -17,7 +17,7 @@ var Engine = /** @class */ (function () {
|
|
|
17
17
|
function Engine(baseInfo, evaluator) {
|
|
18
18
|
this.baseInfo = baseInfo;
|
|
19
19
|
this.evaluator = evaluator;
|
|
20
|
-
// in case we don't have a default treatment in the
|
|
20
|
+
// in case we don't have a default treatment in the instantiation, use 'control'
|
|
21
21
|
if (typeof this.baseInfo.defaultTreatment !== 'string') {
|
|
22
22
|
this.baseInfo.defaultTreatment = constants_1.CONTROL;
|
|
23
23
|
}
|
package/cjs/evaluator/index.js
CHANGED
|
@@ -59,7 +59,7 @@ exports.evaluateFeatures = evaluateFeatures;
|
|
|
59
59
|
function evaluateFeaturesByFlagSets(log, key, flagSets, attributes, storage, method) {
|
|
60
60
|
var storedFlagNames;
|
|
61
61
|
function evaluate(featureFlagsByFlagSets) {
|
|
62
|
-
var featureFlags = new
|
|
62
|
+
var featureFlags = new Set();
|
|
63
63
|
for (var i = 0; i < flagSets.length; i++) {
|
|
64
64
|
var featureFlagByFlagSet = featureFlagsByFlagSets[i];
|
|
65
65
|
if (featureFlagByFlagSet.size) {
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.inListSemverMatcherContext = void 0;
|
|
4
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
5
4
|
var Semver_1 = require("../../utils/Semver");
|
|
6
5
|
function inListSemverMatcherContext(ruleAttr) {
|
|
7
6
|
// @TODO ruleAttr validation should be done at the `parser` or `matchersTransform` level to reuse for all matchers
|
|
8
7
|
if (!ruleAttr || ruleAttr.length === 0)
|
|
9
8
|
throw new Error('whitelistMatcherData is required for IN_LIST_SEMVER matcher type');
|
|
10
|
-
var listOfSemvers = new
|
|
9
|
+
var listOfSemvers = new Set(ruleAttr.map(function (version) { return new Semver_1.Semver(version).version; }));
|
|
11
10
|
return function inListSemverMatcher(runtimeAttr) {
|
|
12
11
|
var runtimeSemver = new Semver_1.Semver(runtimeAttr).version;
|
|
13
12
|
var isInList = listOfSemvers.has(runtimeSemver);
|
|
@@ -1,9 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.whitelistMatcherContext = void 0;
|
|
4
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
5
4
|
function whitelistMatcherContext(ruleAttr) {
|
|
6
|
-
var whitelistSet = new
|
|
5
|
+
var whitelistSet = new Set(ruleAttr);
|
|
7
6
|
return function whitelistMatcher(runtimeAttr) {
|
|
8
7
|
var isInWhitelist = whitelistSet.has(runtimeAttr);
|
|
9
8
|
return isInWhitelist;
|
package/cjs/listeners/browser.js
CHANGED
|
@@ -100,7 +100,6 @@ var BrowserSignalListener = /** @class */ (function () {
|
|
|
100
100
|
* Returns true if beacon API was used successfully, false otherwise.
|
|
101
101
|
*/
|
|
102
102
|
BrowserSignalListener.prototype._sendBeacon = function (url, data, extraMetadata) {
|
|
103
|
-
// eslint-disable-next-line compat/compat
|
|
104
103
|
if (typeof navigator !== 'undefined' && navigator.sendBeacon) {
|
|
105
104
|
var json = {
|
|
106
105
|
entries: data,
|
|
@@ -113,7 +112,7 @@ var BrowserSignalListener = /** @class */ (function () {
|
|
|
113
112
|
// Stringify the payload
|
|
114
113
|
var payload = JSON.stringify(json);
|
|
115
114
|
// https://xgwang.me/posts/you-may-not-know-beacon/#it-may-throw-error%2C-be-sure-to-catch
|
|
116
|
-
try {
|
|
115
|
+
try {
|
|
117
116
|
return navigator.sendBeacon(url, payload);
|
|
118
117
|
}
|
|
119
118
|
catch (e) {
|
|
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.DebugLogger = void 0;
|
|
4
4
|
var index_1 = require("../index");
|
|
5
5
|
var debug_1 = require("../messages/debug");
|
|
6
|
-
var maps_1 = require("../../utils/lang/maps");
|
|
7
6
|
function DebugLogger() {
|
|
8
|
-
return new index_1.Logger({ logLevel: 'DEBUG' }, new
|
|
7
|
+
return new index_1.Logger({ logLevel: 'DEBUG' }, new Map(debug_1.codesDebug));
|
|
9
8
|
}
|
|
10
9
|
exports.DebugLogger = DebugLogger;
|
|
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.ErrorLogger = void 0;
|
|
4
4
|
var index_1 = require("../index");
|
|
5
5
|
var error_1 = require("../messages/error");
|
|
6
|
-
var maps_1 = require("../../utils/lang/maps");
|
|
7
6
|
function ErrorLogger() {
|
|
8
|
-
return new index_1.Logger({ logLevel: 'ERROR' }, new
|
|
7
|
+
return new index_1.Logger({ logLevel: 'ERROR' }, new Map(error_1.codesError));
|
|
9
8
|
}
|
|
10
9
|
exports.ErrorLogger = ErrorLogger;
|
|
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.InfoLogger = void 0;
|
|
4
4
|
var index_1 = require("../index");
|
|
5
5
|
var info_1 = require("../messages/info");
|
|
6
|
-
var maps_1 = require("../../utils/lang/maps");
|
|
7
6
|
function InfoLogger() {
|
|
8
|
-
return new index_1.Logger({ logLevel: 'INFO' }, new
|
|
7
|
+
return new index_1.Logger({ logLevel: 'INFO' }, new Map(info_1.codesInfo));
|
|
9
8
|
}
|
|
10
9
|
exports.InfoLogger = InfoLogger;
|
|
@@ -3,8 +3,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.WarnLogger = void 0;
|
|
4
4
|
var index_1 = require("../index");
|
|
5
5
|
var warn_1 = require("../messages/warn");
|
|
6
|
-
var maps_1 = require("../../utils/lang/maps");
|
|
7
6
|
function WarnLogger() {
|
|
8
|
-
return new index_1.Logger({ logLevel: 'WARN' }, new
|
|
7
|
+
return new index_1.Logger({ logLevel: 'WARN' }, new Map(warn_1.codesWarn));
|
|
9
8
|
}
|
|
10
9
|
exports.WarnLogger = WarnLogger;
|
package/cjs/logger/index.js
CHANGED
|
@@ -3,7 +3,6 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.Logger = exports._sprintf = exports.isLogLevelString = exports.LogLevels = void 0;
|
|
4
4
|
var objectAssign_1 = require("../utils/lang/objectAssign");
|
|
5
5
|
var lang_1 = require("../utils/lang");
|
|
6
|
-
var maps_1 = require("../utils/lang/maps");
|
|
7
6
|
exports.LogLevels = {
|
|
8
7
|
DEBUG: 'DEBUG',
|
|
9
8
|
INFO: 'INFO',
|
|
@@ -47,7 +46,7 @@ var defaultOptions = {
|
|
|
47
46
|
var Logger = /** @class */ (function () {
|
|
48
47
|
function Logger(options, codes) {
|
|
49
48
|
this.options = (0, objectAssign_1.objectAssign)({}, defaultOptions, options);
|
|
50
|
-
this.codes = codes || new
|
|
49
|
+
this.codes = codes || new Map();
|
|
51
50
|
this.logLevel = LogLevelIndexes[this.options.logLevel];
|
|
52
51
|
}
|
|
53
52
|
Logger.prototype.setLogLevel = function (logLevel) {
|
|
@@ -4,16 +4,15 @@ exports.clientCSDecorator = void 0;
|
|
|
4
4
|
var objectAssign_1 = require("../utils/lang/objectAssign");
|
|
5
5
|
var clientAttributesDecoration_1 = require("./clientAttributesDecoration");
|
|
6
6
|
/**
|
|
7
|
-
* Decorator that binds a key
|
|
7
|
+
* Decorator that binds a key to client methods
|
|
8
8
|
*
|
|
9
9
|
* @param client sync client instance
|
|
10
10
|
* @param key validated split key
|
|
11
|
-
* @param trafficType validated traffic type
|
|
12
11
|
*/
|
|
13
|
-
function clientCSDecorator(log, client, key
|
|
12
|
+
function clientCSDecorator(log, client, key) {
|
|
14
13
|
var clientCS = (0, clientAttributesDecoration_1.clientAttributesDecoration)(log, client);
|
|
15
14
|
return (0, objectAssign_1.objectAssign)(clientCS, {
|
|
16
|
-
// In the client-side API, we bind a key to the client `getTreatment*` methods
|
|
15
|
+
// In the client-side API, we bind a key to the client `getTreatment*` and `track` methods
|
|
17
16
|
getTreatment: clientCS.getTreatment.bind(clientCS, key),
|
|
18
17
|
getTreatmentWithConfig: clientCS.getTreatmentWithConfig.bind(clientCS, key),
|
|
19
18
|
getTreatments: clientCS.getTreatments.bind(clientCS, key),
|
|
@@ -22,12 +21,10 @@ function clientCSDecorator(log, client, key, trafficType) {
|
|
|
22
21
|
getTreatmentsWithConfigByFlagSets: clientCS.getTreatmentsWithConfigByFlagSets.bind(clientCS, key),
|
|
23
22
|
getTreatmentsByFlagSet: clientCS.getTreatmentsByFlagSet.bind(clientCS, key),
|
|
24
23
|
getTreatmentsWithConfigByFlagSet: clientCS.getTreatmentsWithConfigByFlagSet.bind(clientCS, key),
|
|
25
|
-
|
|
26
|
-
track: trafficType ? clientCS.track.bind(clientCS, key, trafficType) : clientCS.track.bind(clientCS, key),
|
|
24
|
+
track: clientCS.track.bind(clientCS, key),
|
|
27
25
|
// Not part of the public API. These properties are used to support other modules (e.g., Split Suite)
|
|
28
26
|
isClientSide: true,
|
|
29
|
-
key: key
|
|
30
|
-
trafficType: trafficType
|
|
27
|
+
key: key
|
|
31
28
|
});
|
|
32
29
|
}
|
|
33
30
|
exports.clientCSDecorator = clientCSDecorator;
|
|
@@ -25,7 +25,7 @@ function sdkClientMethodCSFactory(params) {
|
|
|
25
25
|
log.debug(constants_1.RETRIEVE_CLIENT_DEFAULT);
|
|
26
26
|
return mainClientInstance;
|
|
27
27
|
}
|
|
28
|
-
// Validate the key value
|
|
28
|
+
// Validate the key value
|
|
29
29
|
var validKey = (0, key_1.validateKey)(log, key, constants_1.LOG_PREFIX_CLIENT_INSTANTIATION);
|
|
30
30
|
if (validKey === false) {
|
|
31
31
|
throw new Error('Shared Client needs a valid key.');
|
|
@@ -2,8 +2,7 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.decorateHeaders = void 0;
|
|
4
4
|
var objectAssign_1 = require("../utils/lang/objectAssign");
|
|
5
|
-
var
|
|
6
|
-
var FORBIDDEN_HEADERS = new sets_1._Set([
|
|
5
|
+
var FORBIDDEN_HEADERS = new Set([
|
|
7
6
|
'splitsdkclientkey',
|
|
8
7
|
'splitsdkversion',
|
|
9
8
|
'splitsdkmachineip',
|
|
@@ -23,12 +23,6 @@ var KeyBuilderCS = /** @class */ (function (_super) {
|
|
|
23
23
|
if ((0, lang_1.startsWith)(builtSegmentKeyName, prefix))
|
|
24
24
|
return builtSegmentKeyName.substr(prefix.length);
|
|
25
25
|
};
|
|
26
|
-
// @BREAKING: The key used to start with the matching key instead of the prefix, this was changed on version 10.17.3
|
|
27
|
-
KeyBuilderCS.prototype.extractOldSegmentKey = function (builtSegmentKeyName) {
|
|
28
|
-
var prefix = this.matchingKey + "." + this.prefix + ".segment.";
|
|
29
|
-
if ((0, lang_1.startsWith)(builtSegmentKeyName, prefix))
|
|
30
|
-
return builtSegmentKeyName.substr(prefix.length);
|
|
31
|
-
};
|
|
32
26
|
KeyBuilderCS.prototype.buildLastUpdatedKey = function () {
|
|
33
27
|
return this.prefix + ".splits.lastUpdated";
|
|
34
28
|
};
|
|
@@ -51,9 +45,6 @@ function myLargeSegmentsKeyBuilder(prefix, matchingKey) {
|
|
|
51
45
|
if ((0, lang_1.startsWith)(builtSegmentKeyName, p))
|
|
52
46
|
return builtSegmentKeyName.substr(p.length);
|
|
53
47
|
},
|
|
54
|
-
extractOldSegmentKey: function () {
|
|
55
|
-
return undefined;
|
|
56
|
-
},
|
|
57
48
|
buildTillKey: function () {
|
|
58
49
|
return prefix + "." + matchingKey + ".largeSegments.till";
|
|
59
50
|
}
|
|
@@ -48,28 +48,8 @@ var MySegmentsCacheInLocal = /** @class */ (function (_super) {
|
|
|
48
48
|
// Scan current values from localStorage
|
|
49
49
|
return Object.keys(localStorage).reduce(function (accum, key) {
|
|
50
50
|
var segmentName = _this.keys.extractSegmentName(key);
|
|
51
|
-
if (segmentName)
|
|
51
|
+
if (segmentName)
|
|
52
52
|
accum.push(segmentName);
|
|
53
|
-
}
|
|
54
|
-
else {
|
|
55
|
-
// @TODO @BREAKING: This is only to clean up "old" keys. Remove this whole else code block
|
|
56
|
-
segmentName = _this.keys.extractOldSegmentKey(key);
|
|
57
|
-
if (segmentName) { // this was an old segment key, let's clean up.
|
|
58
|
-
var newSegmentKey = _this.keys.buildSegmentNameKey(segmentName);
|
|
59
|
-
try {
|
|
60
|
-
// If the new format key is not there, create it.
|
|
61
|
-
if (!localStorage.getItem(newSegmentKey)) {
|
|
62
|
-
localStorage.setItem(newSegmentKey, constants_1.DEFINED);
|
|
63
|
-
// we are migrating a segment, let's track it.
|
|
64
|
-
accum.push(segmentName);
|
|
65
|
-
}
|
|
66
|
-
localStorage.removeItem(key); // we migrated the current key, let's delete it.
|
|
67
|
-
}
|
|
68
|
-
catch (e) {
|
|
69
|
-
_this.log.error(e);
|
|
70
|
-
}
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
53
|
return accum;
|
|
74
54
|
}, []);
|
|
75
55
|
};
|
|
@@ -5,8 +5,8 @@ var tslib_1 = require("tslib");
|
|
|
5
5
|
var AbstractSplitsCacheSync_1 = require("../AbstractSplitsCacheSync");
|
|
6
6
|
var lang_1 = require("../../utils/lang");
|
|
7
7
|
var constants_1 = require("./constants");
|
|
8
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
9
8
|
var KeyBuilder_1 = require("../KeyBuilder");
|
|
9
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
10
10
|
/**
|
|
11
11
|
* ISplitsCacheSync implementation that stores split definitions in browser LocalStorage.
|
|
12
12
|
*/
|
|
@@ -230,7 +230,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
230
230
|
return flagSets.map(function (flagSet) {
|
|
231
231
|
var flagSetKey = _this.keys.buildFlagSetKey(flagSet);
|
|
232
232
|
var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
|
|
233
|
-
return new
|
|
233
|
+
return new Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
|
|
234
234
|
});
|
|
235
235
|
};
|
|
236
236
|
SplitsCacheInLocal.prototype.addToFlagSets = function (featureFlag) {
|
|
@@ -242,7 +242,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
242
242
|
return;
|
|
243
243
|
var flagSetKey = _this.keys.buildFlagSetKey(featureFlagSet);
|
|
244
244
|
var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
|
|
245
|
-
var flagSetCache = new
|
|
245
|
+
var flagSetCache = new Set(flagSetFromLocalStorage ? JSON.parse(flagSetFromLocalStorage) : []);
|
|
246
246
|
flagSetCache.add(featureFlag.name);
|
|
247
247
|
localStorage.setItem(flagSetKey, JSON.stringify((0, sets_1.setToArray)(flagSetCache)));
|
|
248
248
|
});
|
|
@@ -260,7 +260,7 @@ var SplitsCacheInLocal = /** @class */ (function (_super) {
|
|
|
260
260
|
var flagSetFromLocalStorage = localStorage.getItem(flagSetKey);
|
|
261
261
|
if (!flagSetFromLocalStorage)
|
|
262
262
|
return;
|
|
263
|
-
var flagSetCache = new
|
|
263
|
+
var flagSetCache = new Set(JSON.parse(flagSetFromLocalStorage));
|
|
264
264
|
flagSetCache.delete(featureFlagName);
|
|
265
265
|
if (flagSetCache.size === 0) {
|
|
266
266
|
localStorage.removeItem(flagSetKey);
|
|
@@ -56,7 +56,7 @@ function InLocalStorage(options) {
|
|
|
56
56
|
this.events.clear();
|
|
57
57
|
(_a = this.uniqueKeys) === null || _a === void 0 ? void 0 : _a.clear();
|
|
58
58
|
},
|
|
59
|
-
// When using shared
|
|
59
|
+
// When using shared instantiation with MEMORY we reuse everything but segments (they are customer per key).
|
|
60
60
|
shared: function (matchingKey) {
|
|
61
61
|
return {
|
|
62
62
|
splits: this.splits,
|
|
@@ -38,7 +38,7 @@ function InMemoryStorageCSFactory(params) {
|
|
|
38
38
|
this.events.clear();
|
|
39
39
|
this.uniqueKeys && this.uniqueKeys.clear();
|
|
40
40
|
},
|
|
41
|
-
// When using shared
|
|
41
|
+
// When using shared instantiation with MEMORY we reuse everything but segments (they are unique per key)
|
|
42
42
|
shared: function () {
|
|
43
43
|
return {
|
|
44
44
|
splits: this.splits,
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.SegmentsCacheInMemory = void 0;
|
|
4
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
5
4
|
var lang_1 = require("../../utils/lang");
|
|
6
5
|
/**
|
|
7
6
|
* Default ISplitsCacheSync implementation for server-side that stores segments definitions in memory.
|
|
@@ -12,7 +11,7 @@ var SegmentsCacheInMemory = /** @class */ (function () {
|
|
|
12
11
|
this.segmentChangeNumber = {};
|
|
13
12
|
}
|
|
14
13
|
SegmentsCacheInMemory.prototype.update = function (name, addedKeys, removedKeys, changeNumber) {
|
|
15
|
-
var keySet = this.segmentCache[name] || new
|
|
14
|
+
var keySet = this.segmentCache[name] || new Set();
|
|
16
15
|
addedKeys.forEach(function (k) { return keySet.add(k); });
|
|
17
16
|
removedKeys.forEach(function (k) { return keySet.delete(k); });
|
|
18
17
|
this.segmentCache[name] = keySet;
|
|
@@ -32,7 +31,7 @@ var SegmentsCacheInMemory = /** @class */ (function () {
|
|
|
32
31
|
};
|
|
33
32
|
SegmentsCacheInMemory.prototype._registerSegment = function (name) {
|
|
34
33
|
if (!this.segmentCache[name]) {
|
|
35
|
-
this.segmentCache[name] = new
|
|
34
|
+
this.segmentCache[name] = new Set();
|
|
36
35
|
}
|
|
37
36
|
return true;
|
|
38
37
|
};
|
|
@@ -4,7 +4,6 @@ exports.SplitsCacheInMemory = void 0;
|
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
5
|
var AbstractSplitsCacheSync_1 = require("../AbstractSplitsCacheSync");
|
|
6
6
|
var lang_1 = require("../../utils/lang");
|
|
7
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
8
7
|
/**
|
|
9
8
|
* Default ISplitsCacheSync implementation that stores split definitions in memory.
|
|
10
9
|
*/
|
|
@@ -94,7 +93,7 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
|
|
|
94
93
|
};
|
|
95
94
|
SplitsCacheInMemory.prototype.getNamesByFlagSets = function (flagSets) {
|
|
96
95
|
var _this = this;
|
|
97
|
-
return flagSets.map(function (flagSet) { return _this.flagSetsCache[flagSet] || new
|
|
96
|
+
return flagSets.map(function (flagSet) { return _this.flagSetsCache[flagSet] || new Set(); });
|
|
98
97
|
};
|
|
99
98
|
SplitsCacheInMemory.prototype.addToFlagSets = function (featureFlag) {
|
|
100
99
|
var _this = this;
|
|
@@ -104,7 +103,7 @@ var SplitsCacheInMemory = /** @class */ (function (_super) {
|
|
|
104
103
|
if (_this.flagSetsFilter.length > 0 && !_this.flagSetsFilter.some(function (filterFlagSet) { return filterFlagSet === featureFlagSet; }))
|
|
105
104
|
return;
|
|
106
105
|
if (!_this.flagSetsCache[featureFlagSet])
|
|
107
|
-
_this.flagSetsCache[featureFlagSet] = new
|
|
106
|
+
_this.flagSetsCache[featureFlagSet] = new Set([]);
|
|
108
107
|
_this.flagSetsCache[featureFlagSet].add(featureFlag.name);
|
|
109
108
|
});
|
|
110
109
|
};
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.UniqueKeysCacheInMemory = exports.fromUniqueKeysCollector = void 0;
|
|
4
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
5
4
|
var constants_1 = require("../inRedis/constants");
|
|
5
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
6
6
|
/**
|
|
7
7
|
* Converts `uniqueKeys` data from cache into request payload for SS.
|
|
8
8
|
*/
|
|
@@ -36,7 +36,7 @@ var UniqueKeysCacheInMemory = /** @class */ (function () {
|
|
|
36
36
|
*/
|
|
37
37
|
UniqueKeysCacheInMemory.prototype.track = function (userKey, featureName) {
|
|
38
38
|
if (!this.uniqueKeysTracker[featureName])
|
|
39
|
-
this.uniqueKeysTracker[featureName] = new
|
|
39
|
+
this.uniqueKeysTracker[featureName] = new Set();
|
|
40
40
|
var tracker = this.uniqueKeysTracker[featureName];
|
|
41
41
|
if (!tracker.has(userKey)) {
|
|
42
42
|
tracker.add(userKey);
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.UniqueKeysCacheInMemoryCS = void 0;
|
|
4
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
5
4
|
var constants_1 = require("../inRedis/constants");
|
|
5
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
6
6
|
var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
|
|
7
7
|
/**
|
|
8
8
|
*
|
|
@@ -23,7 +23,7 @@ var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
|
|
|
23
23
|
*/
|
|
24
24
|
UniqueKeysCacheInMemoryCS.prototype.track = function (userKey, featureName) {
|
|
25
25
|
if (!this.uniqueKeysTracker[userKey])
|
|
26
|
-
this.uniqueKeysTracker[userKey] = new
|
|
26
|
+
this.uniqueKeysTracker[userKey] = new Set();
|
|
27
27
|
var tracker = this.uniqueKeysTracker[userKey];
|
|
28
28
|
if (!tracker.has(featureName)) {
|
|
29
29
|
tracker.add(featureName);
|
|
@@ -4,9 +4,9 @@ exports.RedisAdapter = void 0;
|
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
5
|
var ioredis_1 = (0, tslib_1.__importDefault)(require("ioredis"));
|
|
6
6
|
var lang_1 = require("../../utils/lang");
|
|
7
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
8
7
|
var thenable_1 = require("../../utils/promise/thenable");
|
|
9
8
|
var timeout_1 = require("../../utils/promise/timeout");
|
|
9
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
10
10
|
var LOG_PREFIX = 'storage:redis-adapter: ';
|
|
11
11
|
// If we ever decide to fully wrap every method, there's a Commander.getBuiltinCommands from ioredis.
|
|
12
12
|
var METHODS_TO_PROMISE_WRAP = ['set', 'exec', 'del', 'get', 'keys', 'sadd', 'srem', 'sismember', 'smembers', 'incr', 'rpush', 'expire', 'mget', 'lrange', 'ltrim', 'hset', 'hincrby', 'popNRaw'];
|
|
@@ -36,7 +36,7 @@ var RedisAdapter = /** @class */ (function (_super) {
|
|
|
36
36
|
_this.log = log;
|
|
37
37
|
_this._options = options;
|
|
38
38
|
_this._notReadyCommandsQueue = [];
|
|
39
|
-
_this._runningCommands = new
|
|
39
|
+
_this._runningCommands = new Set();
|
|
40
40
|
_this._listenToEvents();
|
|
41
41
|
_this._setTimeoutWrappers();
|
|
42
42
|
_this._setDisconnectWrapper();
|
|
@@ -200,7 +200,7 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
|
|
|
200
200
|
return value;
|
|
201
201
|
_this.log.error(constants_1.LOG_PREFIX + ("Could not read result from get members of flag set " + flagSets[index] + " due to an error: " + e));
|
|
202
202
|
}); })
|
|
203
|
-
.then(function (namesByFlagSets) { return namesByFlagSets.map(function (namesByFlagSet) { return new
|
|
203
|
+
.then(function (namesByFlagSets) { return namesByFlagSets.map(function (namesByFlagSet) { return new Set(namesByFlagSet); }); });
|
|
204
204
|
};
|
|
205
205
|
/**
|
|
206
206
|
* Check traffic type existence.
|
|
@@ -5,7 +5,6 @@ var findLatencyIndex_1 = require("../findLatencyIndex");
|
|
|
5
5
|
var telemetrySubmitter_1 = require("../../sync/submitters/telemetrySubmitter");
|
|
6
6
|
var constants_1 = require("../../utils/constants");
|
|
7
7
|
var lang_1 = require("../../utils/lang");
|
|
8
|
-
var maps_1 = require("../../utils/lang/maps");
|
|
9
8
|
var TelemetryCacheInMemory_1 = require("../inMemory/TelemetryCacheInMemory");
|
|
10
9
|
var utils_1 = require("../utils");
|
|
11
10
|
var TelemetryCacheInRedis = /** @class */ (function () {
|
|
@@ -42,7 +41,7 @@ var TelemetryCacheInRedis = /** @class */ (function () {
|
|
|
42
41
|
TelemetryCacheInRedis.prototype.popLatencies = function () {
|
|
43
42
|
var _this = this;
|
|
44
43
|
return this.redis.hgetall(this.keys.latencyPrefix).then(function (latencies) {
|
|
45
|
-
var result = new
|
|
44
|
+
var result = new Map();
|
|
46
45
|
Object.keys(latencies).forEach(function (field) {
|
|
47
46
|
var parsedField = (0, utils_1.parseLatencyField)(field);
|
|
48
47
|
if ((0, lang_1.isString)(parsedField)) {
|
|
@@ -74,7 +73,7 @@ var TelemetryCacheInRedis = /** @class */ (function () {
|
|
|
74
73
|
TelemetryCacheInRedis.prototype.popExceptions = function () {
|
|
75
74
|
var _this = this;
|
|
76
75
|
return this.redis.hgetall(this.keys.exceptionPrefix).then(function (exceptions) {
|
|
77
|
-
var result = new
|
|
76
|
+
var result = new Map();
|
|
78
77
|
Object.keys(exceptions).forEach(function (field) {
|
|
79
78
|
var parsedField = (0, utils_1.parseExceptionField)(field);
|
|
80
79
|
if ((0, lang_1.isString)(parsedField)) {
|
|
@@ -101,7 +100,7 @@ var TelemetryCacheInRedis = /** @class */ (function () {
|
|
|
101
100
|
TelemetryCacheInRedis.prototype.popConfigs = function () {
|
|
102
101
|
var _this = this;
|
|
103
102
|
return this.redis.hgetall(this.keys.initPrefix).then(function (configs) {
|
|
104
|
-
var result = new
|
|
103
|
+
var result = new Map();
|
|
105
104
|
Object.keys(configs).forEach(function (field) {
|
|
106
105
|
var parsedField = (0, utils_1.parseMetadata)(field);
|
|
107
106
|
if ((0, lang_1.isString)(parsedField)) {
|
|
@@ -3,9 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.UniqueKeysCacheInRedis = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
5
|
var UniqueKeysCacheInMemory_1 = require("../inMemory/UniqueKeysCacheInMemory");
|
|
6
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
7
6
|
var constants_1 = require("./constants");
|
|
8
7
|
var constants_2 = require("./constants");
|
|
8
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
9
9
|
var UniqueKeysCacheInRedis = /** @class */ (function (_super) {
|
|
10
10
|
(0, tslib_1.__extends)(UniqueKeysCacheInRedis, _super);
|
|
11
11
|
function UniqueKeysCacheInRedis(log, key, redis, uniqueKeysQueueSize, refreshRate) {
|
|
@@ -170,7 +170,7 @@ var SplitsCachePluggable = /** @class */ (function (_super) {
|
|
|
170
170
|
return Promise.all(flagSets.map(function (flagSet) {
|
|
171
171
|
var flagSetKey = _this.keys.buildFlagSetKey(flagSet);
|
|
172
172
|
return _this.wrapper.getItems(flagSetKey).catch(function () { return []; });
|
|
173
|
-
})).then(function (namesByFlagSets) { return namesByFlagSets.map(function (namesByFlagSet) { return new
|
|
173
|
+
})).then(function (namesByFlagSets) { return namesByFlagSets.map(function (namesByFlagSet) { return new Set(namesByFlagSet); }); });
|
|
174
174
|
};
|
|
175
175
|
/**
|
|
176
176
|
* Check traffic type existence.
|
|
@@ -5,7 +5,6 @@ var findLatencyIndex_1 = require("../findLatencyIndex");
|
|
|
5
5
|
var telemetrySubmitter_1 = require("../../sync/submitters/telemetrySubmitter");
|
|
6
6
|
var constants_1 = require("../../utils/constants");
|
|
7
7
|
var lang_1 = require("../../utils/lang");
|
|
8
|
-
var maps_1 = require("../../utils/lang/maps");
|
|
9
8
|
var TelemetryCacheInMemory_1 = require("../inMemory/TelemetryCacheInMemory");
|
|
10
9
|
var utils_1 = require("../utils");
|
|
11
10
|
var TelemetryCachePluggable = /** @class */ (function () {
|
|
@@ -41,7 +40,7 @@ var TelemetryCachePluggable = /** @class */ (function () {
|
|
|
41
40
|
return this.wrapper.getKeysByPrefix(this.keys.latencyPrefix).then(function (latencyKeys) {
|
|
42
41
|
return latencyKeys.length ?
|
|
43
42
|
_this.wrapper.getMany(latencyKeys).then(function (latencies) {
|
|
44
|
-
var result = new
|
|
43
|
+
var result = new Map();
|
|
45
44
|
for (var i = 0; i < latencyKeys.length; i++) {
|
|
46
45
|
var field = latencyKeys[i].split('::')[1];
|
|
47
46
|
var parsedField = (0, utils_1.parseLatencyField)(field);
|
|
@@ -68,7 +67,7 @@ var TelemetryCachePluggable = /** @class */ (function () {
|
|
|
68
67
|
return Promise.all(latencyKeys.map(function (latencyKey) { return _this.wrapper.del(latencyKey); })).then(function () { return result; });
|
|
69
68
|
}) :
|
|
70
69
|
// If latencyKeys is empty, return an empty map.
|
|
71
|
-
new
|
|
70
|
+
new Map();
|
|
72
71
|
});
|
|
73
72
|
};
|
|
74
73
|
/**
|
|
@@ -80,7 +79,7 @@ var TelemetryCachePluggable = /** @class */ (function () {
|
|
|
80
79
|
return this.wrapper.getKeysByPrefix(this.keys.exceptionPrefix).then(function (exceptionKeys) {
|
|
81
80
|
return exceptionKeys.length ?
|
|
82
81
|
_this.wrapper.getMany(exceptionKeys).then(function (exceptions) {
|
|
83
|
-
var result = new
|
|
82
|
+
var result = new Map();
|
|
84
83
|
for (var i = 0; i < exceptionKeys.length; i++) {
|
|
85
84
|
var field = exceptionKeys[i].split('::')[1];
|
|
86
85
|
var parsedField = (0, utils_1.parseExceptionField)(field);
|
|
@@ -102,7 +101,7 @@ var TelemetryCachePluggable = /** @class */ (function () {
|
|
|
102
101
|
return Promise.all(exceptionKeys.map(function (exceptionKey) { return _this.wrapper.del(exceptionKey); })).then(function () { return result; });
|
|
103
102
|
}) :
|
|
104
103
|
// If exceptionKeys is empty, return an empty map.
|
|
105
|
-
new
|
|
104
|
+
new Map();
|
|
106
105
|
});
|
|
107
106
|
};
|
|
108
107
|
/**
|
|
@@ -114,7 +113,7 @@ var TelemetryCachePluggable = /** @class */ (function () {
|
|
|
114
113
|
return this.wrapper.getKeysByPrefix(this.keys.initPrefix).then(function (configKeys) {
|
|
115
114
|
return configKeys.length ?
|
|
116
115
|
_this.wrapper.getMany(configKeys).then(function (configs) {
|
|
117
|
-
var result = new
|
|
116
|
+
var result = new Map();
|
|
118
117
|
for (var i = 0; i < configKeys.length; i++) {
|
|
119
118
|
var field = configKeys[i].split('::')[1];
|
|
120
119
|
var parsedField = (0, utils_1.parseMetadata)(field);
|
|
@@ -134,7 +133,7 @@ var TelemetryCachePluggable = /** @class */ (function () {
|
|
|
134
133
|
return Promise.all(configKeys.map(function (configKey) { return _this.wrapper.del(configKey); })).then(function () { return result; });
|
|
135
134
|
}) :
|
|
136
135
|
// If configKeys is empty, return an empty map.
|
|
137
|
-
new
|
|
136
|
+
new Map();
|
|
138
137
|
});
|
|
139
138
|
};
|
|
140
139
|
return TelemetryCachePluggable;
|
|
@@ -3,9 +3,9 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.UniqueKeysCachePluggable = void 0;
|
|
4
4
|
var tslib_1 = require("tslib");
|
|
5
5
|
var UniqueKeysCacheInMemory_1 = require("../inMemory/UniqueKeysCacheInMemory");
|
|
6
|
-
var sets_1 = require("../../utils/lang/sets");
|
|
7
6
|
var constants_1 = require("../inRedis/constants");
|
|
8
7
|
var constants_2 = require("./constants");
|
|
8
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
9
9
|
var UniqueKeysCachePluggable = /** @class */ (function (_super) {
|
|
10
10
|
(0, tslib_1.__extends)(UniqueKeysCachePluggable, _super);
|
|
11
11
|
function UniqueKeysCachePluggable(log, key, wrapper, uniqueKeysQueueSize, refreshRate) {
|
|
@@ -90,15 +90,15 @@ function inMemoryWrapperFactory(connDelay) {
|
|
|
90
90
|
var set = _cache[key];
|
|
91
91
|
if (!set)
|
|
92
92
|
return Promise.resolve(false);
|
|
93
|
-
if (set instanceof
|
|
93
|
+
if (set instanceof Set)
|
|
94
94
|
return Promise.resolve(set.has(item));
|
|
95
95
|
return Promise.reject('key is not a set');
|
|
96
96
|
},
|
|
97
97
|
addItems: function (key, items) {
|
|
98
98
|
if (!(key in _cache))
|
|
99
|
-
_cache[key] = new
|
|
99
|
+
_cache[key] = new Set();
|
|
100
100
|
var set = _cache[key];
|
|
101
|
-
if (set instanceof
|
|
101
|
+
if (set instanceof Set) {
|
|
102
102
|
items.forEach(function (item) { return set.add(item); });
|
|
103
103
|
return Promise.resolve();
|
|
104
104
|
}
|
|
@@ -106,9 +106,9 @@ function inMemoryWrapperFactory(connDelay) {
|
|
|
106
106
|
},
|
|
107
107
|
removeItems: function (key, items) {
|
|
108
108
|
if (!(key in _cache))
|
|
109
|
-
_cache[key] = new
|
|
109
|
+
_cache[key] = new Set();
|
|
110
110
|
var set = _cache[key];
|
|
111
|
-
if (set instanceof
|
|
111
|
+
if (set instanceof Set) {
|
|
112
112
|
items.forEach(function (item) { return set.delete(item); });
|
|
113
113
|
return Promise.resolve();
|
|
114
114
|
}
|
|
@@ -118,7 +118,7 @@ function inMemoryWrapperFactory(connDelay) {
|
|
|
118
118
|
var set = _cache[key];
|
|
119
119
|
if (!set)
|
|
120
120
|
return Promise.resolve([]);
|
|
121
|
-
if (set instanceof
|
|
121
|
+
if (set instanceof Set)
|
|
122
122
|
return Promise.resolve((0, sets_1.setToArray)(set));
|
|
123
123
|
return Promise.reject('key is not a set');
|
|
124
124
|
},
|