@splitsoftware/splitio-commons 1.6.2-rc.4 → 1.6.2-rc.7
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 +3 -0
- 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 +2 -1
- package/cjs/logger/constants.js +2 -1
- package/cjs/sdkClient/clientAttributesDecoration.js +1 -1
- package/cjs/sdkClient/sdkClient.js +3 -1
- package/cjs/sdkFactory/index.js +28 -8
- package/cjs/sdkManager/index.js +3 -11
- package/cjs/services/splitApi.js +20 -1
- package/cjs/storages/AbstractSplitsCacheAsync.js +7 -9
- package/cjs/storages/AbstractSplitsCacheSync.js +7 -9
- package/cjs/storages/KeyBuilderSS.js +6 -0
- package/cjs/storages/dataLoader.js +1 -1
- package/cjs/storages/inLocalStorage/SplitsCacheInLocal.js +5 -6
- package/cjs/storages/inLocalStorage/index.js +4 -0
- package/cjs/storages/inMemory/AttributesCacheInMemory.js +1 -1
- package/cjs/storages/inMemory/ImpressionCountsCacheInMemory.js +12 -1
- package/cjs/storages/inMemory/InMemoryStorage.js +5 -1
- package/cjs/storages/inMemory/InMemoryStorageCS.js +5 -1
- package/cjs/storages/inMemory/SplitsCacheInMemory.js +7 -10
- package/cjs/storages/inMemory/uniqueKeysCacheInMemory.js +73 -0
- package/cjs/storages/inMemory/uniqueKeysCacheInMemoryCS.js +78 -0
- package/cjs/storages/inRedis/ImpressionCountsCacheInRedis.js +49 -0
- package/cjs/storages/inRedis/SplitsCacheInRedis.js +15 -9
- package/cjs/storages/inRedis/constants.js +4 -1
- package/cjs/storages/inRedis/index.js +15 -1
- package/cjs/storages/inRedis/uniqueKeysCacheInRedis.js +56 -0
- 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 +3 -0
- package/cjs/sync/submitters/telemetrySubmitter.js +1 -0
- package/cjs/sync/submitters/uniqueKeysSubmitter.js +26 -0
- package/cjs/trackers/impressionsTracker.js +22 -41
- package/cjs/trackers/strategy/strategyDebug.js +25 -0
- package/cjs/trackers/strategy/strategyNone.js +29 -0
- package/cjs/trackers/strategy/strategyOptimized.js +35 -0
- package/cjs/trackers/telemetryTracker.js +6 -0
- package/cjs/trackers/uniqueKeysTracker.js +38 -0
- package/cjs/types.js +2 -0
- package/cjs/utils/constants/index.js +4 -2
- package/cjs/utils/key/index.js +1 -1
- package/cjs/utils/settingsValidation/impressionsMode.js +2 -2
- package/cjs/utils/settingsValidation/index.js +4 -1
- 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 +3 -2
- package/esm/logger/constants.js +1 -0
- package/esm/sdkClient/clientAttributesDecoration.js +1 -1
- package/esm/sdkClient/sdkClient.js +3 -1
- package/esm/sdkFactory/index.js +28 -8
- package/esm/sdkManager/index.js +3 -11
- package/esm/services/splitApi.js +20 -1
- package/esm/storages/AbstractSplitsCacheAsync.js +7 -9
- package/esm/storages/AbstractSplitsCacheSync.js +7 -9
- package/esm/storages/KeyBuilderSS.js +6 -0
- package/esm/storages/dataLoader.js +1 -1
- package/esm/storages/inLocalStorage/SplitsCacheInLocal.js +5 -6
- package/esm/storages/inLocalStorage/index.js +5 -1
- package/esm/storages/inMemory/AttributesCacheInMemory.js +1 -1
- package/esm/storages/inMemory/ImpressionCountsCacheInMemory.js +12 -1
- package/esm/storages/inMemory/InMemoryStorage.js +6 -2
- package/esm/storages/inMemory/InMemoryStorageCS.js +6 -2
- package/esm/storages/inMemory/SplitsCacheInMemory.js +7 -10
- package/esm/storages/inMemory/uniqueKeysCacheInMemory.js +70 -0
- package/esm/storages/inMemory/uniqueKeysCacheInMemoryCS.js +75 -0
- package/esm/storages/inRedis/ImpressionCountsCacheInRedis.js +46 -0
- package/esm/storages/inRedis/SplitsCacheInRedis.js +15 -9
- package/esm/storages/inRedis/constants.js +3 -0
- package/esm/storages/inRedis/index.js +16 -2
- package/esm/storages/inRedis/uniqueKeysCacheInRedis.js +53 -0
- 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 +3 -0
- package/esm/sync/submitters/telemetrySubmitter.js +2 -1
- package/esm/sync/submitters/uniqueKeysSubmitter.js +22 -0
- package/esm/trackers/impressionsTracker.js +22 -41
- package/esm/trackers/strategy/strategyDebug.js +21 -0
- package/esm/trackers/strategy/strategyNone.js +25 -0
- package/esm/trackers/strategy/strategyOptimized.js +31 -0
- package/esm/trackers/telemetryTracker.js +6 -0
- package/esm/trackers/uniqueKeysTracker.js +34 -0
- package/esm/types.js +1 -0
- package/esm/utils/constants/index.js +2 -0
- package/esm/utils/key/index.js +1 -1
- package/esm/utils/settingsValidation/impressionsMode.js +3 -3
- package/esm/utils/settingsValidation/index.js +4 -1
- package/package.json +5 -4
- package/src/consent/sdkUserConsent.ts +5 -6
- package/src/dtos/types.ts +8 -0
- package/src/evaluator/Engine.ts +3 -3
- package/src/evaluator/combiners/and.ts +1 -1
- package/src/evaluator/combiners/ifelseif.ts +3 -3
- package/src/evaluator/condition/engineUtils.ts +1 -1
- package/src/evaluator/condition/index.ts +6 -6
- package/src/evaluator/index.ts +18 -19
- package/src/evaluator/matchers/all.ts +1 -1
- package/src/evaluator/matchers/between.ts +1 -1
- package/src/evaluator/matchers/boolean.ts +1 -1
- package/src/evaluator/matchers/cont_all.ts +1 -1
- package/src/evaluator/matchers/cont_any.ts +1 -1
- package/src/evaluator/matchers/cont_str.ts +1 -1
- package/src/evaluator/matchers/dependency.ts +1 -1
- package/src/evaluator/matchers/eq.ts +1 -1
- package/src/evaluator/matchers/eq_set.ts +1 -1
- package/src/evaluator/matchers/ew.ts +1 -1
- package/src/evaluator/matchers/gte.ts +1 -1
- package/src/evaluator/matchers/index.ts +1 -1
- package/src/evaluator/matchers/lte.ts +1 -1
- package/src/evaluator/matchers/part_of.ts +1 -1
- package/src/evaluator/matchers/segment.ts +1 -1
- package/src/evaluator/matchers/string.ts +1 -1
- package/src/evaluator/matchers/sw.ts +1 -1
- package/src/evaluator/matchers/whitelist.ts +1 -1
- package/src/evaluator/parser/index.ts +3 -3
- package/src/evaluator/types.ts +6 -6
- package/src/evaluator/value/index.ts +4 -4
- package/src/evaluator/value/sanitize.ts +4 -4
- package/src/integrations/ga/GaToSplit.ts +15 -11
- package/src/integrations/ga/SplitToGa.ts +10 -10
- package/src/integrations/ga/types.ts +4 -4
- package/src/integrations/pluggable.ts +3 -3
- package/src/integrations/types.ts +4 -3
- package/src/listeners/browser.ts +3 -2
- package/src/logger/constants.ts +1 -0
- package/src/logger/index.ts +3 -3
- package/src/logger/sdkLogger.ts +2 -1
- package/src/logger/types.ts +16 -0
- package/src/readiness/sdkReadinessManager.ts +1 -1
- package/src/readiness/types.ts +9 -2
- package/src/sdkClient/client.ts +13 -13
- package/src/sdkClient/clientAttributesDecoration.ts +13 -13
- package/src/sdkClient/clientCS.ts +4 -3
- package/src/sdkClient/clientInputValidation.ts +15 -15
- package/src/sdkClient/sdkClient.ts +5 -3
- package/src/sdkClient/sdkClientMethod.ts +2 -2
- package/src/sdkClient/sdkClientMethodCS.ts +9 -9
- package/src/sdkClient/sdkClientMethodCSWithTT.ts +9 -9
- package/src/sdkFactory/index.ts +34 -11
- package/src/sdkFactory/types.ts +11 -8
- package/src/sdkManager/index.ts +7 -16
- package/src/services/splitApi.ts +22 -1
- package/src/services/types.ts +6 -0
- package/src/storages/AbstractSplitsCacheAsync.ts +12 -14
- package/src/storages/AbstractSplitsCacheSync.ts +14 -16
- package/src/storages/KeyBuilderSS.ts +8 -0
- package/src/storages/dataLoader.ts +3 -3
- package/src/storages/inLocalStorage/MySegmentsCacheInLocal.ts +1 -1
- package/src/storages/inLocalStorage/SplitsCacheInLocal.ts +10 -12
- package/src/storages/inLocalStorage/index.ts +6 -4
- package/src/storages/inMemory/AttributesCacheInMemory.ts +12 -13
- package/src/storages/inMemory/EventsCacheInMemory.ts +4 -4
- package/src/storages/inMemory/ImpressionCountsCacheInMemory.ts +16 -1
- package/src/storages/inMemory/InMemoryStorage.ts +5 -2
- package/src/storages/inMemory/InMemoryStorageCS.ts +6 -2
- package/src/storages/inMemory/SplitsCacheInMemory.ts +10 -14
- package/src/storages/inMemory/uniqueKeysCacheInMemory.ts +82 -0
- package/src/storages/inMemory/uniqueKeysCacheInMemoryCS.ts +88 -0
- package/src/storages/inRedis/EventsCacheInRedis.ts +4 -4
- package/src/storages/inRedis/ImpressionCountsCacheInRedis.ts +51 -0
- package/src/storages/inRedis/ImpressionsCacheInRedis.ts +1 -1
- package/src/storages/inRedis/RedisAdapter.ts +1 -1
- package/src/storages/inRedis/SegmentsCacheInRedis.ts +1 -1
- package/src/storages/inRedis/SplitsCacheInRedis.ts +22 -18
- package/src/storages/inRedis/TelemetryCacheInRedis.ts +1 -1
- package/src/storages/inRedis/constants.ts +3 -0
- package/src/storages/inRedis/index.ts +14 -6
- package/src/storages/inRedis/uniqueKeysCacheInRedis.ts +63 -0
- package/src/storages/pluggable/EventsCachePluggable.ts +4 -4
- package/src/storages/pluggable/ImpressionsCachePluggable.ts +1 -1
- package/src/storages/pluggable/SegmentsCachePluggable.ts +1 -1
- package/src/storages/pluggable/SplitsCachePluggable.ts +21 -18
- package/src/storages/pluggable/TelemetryCachePluggable.ts +1 -1
- package/src/storages/pluggable/index.ts +3 -3
- package/src/storages/pluggable/wrapperAdapter.ts +1 -1
- package/src/storages/types.ts +60 -62
- package/src/sync/offline/LocalhostFromObject.ts +4 -4
- package/src/sync/offline/splitsParser/splitsParserFromSettings.ts +8 -8
- package/src/sync/offline/syncTasks/fromObjectSyncTask.ts +5 -6
- package/src/sync/polling/updaters/mySegmentsUpdater.ts +1 -1
- package/src/sync/polling/updaters/segmentChangesUpdater.ts +1 -1
- package/src/sync/polling/updaters/splitChangesUpdater.ts +3 -3
- package/src/sync/streaming/SSEHandler/index.ts +1 -1
- package/src/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.ts +1 -1
- package/src/sync/streaming/UpdateWorkers/SplitsUpdateWorker.ts +1 -1
- package/src/sync/submitters/submitter.ts +1 -1
- package/src/sync/submitters/submitterManager.ts +2 -0
- package/src/sync/submitters/telemetrySubmitter.ts +4 -3
- package/src/sync/submitters/types.ts +22 -3
- package/src/sync/submitters/uniqueKeysSubmitter.ts +35 -0
- package/src/sync/syncTask.ts +1 -1
- package/src/trackers/eventTracker.ts +3 -3
- package/src/trackers/impressionsTracker.ts +30 -51
- package/src/trackers/strategy/strategyDebug.ts +28 -0
- package/src/trackers/strategy/strategyNone.ts +34 -0
- package/src/trackers/strategy/strategyOptimized.ts +42 -0
- package/src/trackers/telemetryTracker.ts +7 -2
- package/src/trackers/types.ts +36 -4
- package/src/trackers/uniqueKeysTracker.ts +48 -0
- package/src/types.ts +1267 -0
- package/src/utils/constants/index.ts +3 -1
- package/src/utils/inputValidation/apiKey.ts +1 -1
- package/src/utils/inputValidation/attribute.ts +1 -1
- package/src/utils/inputValidation/attributes.ts +3 -3
- package/src/utils/inputValidation/event.ts +1 -1
- package/src/utils/inputValidation/eventProperties.ts +3 -3
- package/src/utils/inputValidation/eventValue.ts +1 -1
- package/src/utils/inputValidation/isOperational.ts +1 -1
- package/src/utils/inputValidation/key.ts +3 -3
- package/src/utils/inputValidation/preloadedData.ts +3 -3
- package/src/utils/inputValidation/split.ts +1 -1
- package/src/utils/inputValidation/splitExistance.ts +1 -1
- package/src/utils/inputValidation/splits.ts +1 -1
- package/src/utils/inputValidation/trafficType.ts +1 -1
- package/src/utils/inputValidation/trafficTypeExistance.ts +1 -1
- package/src/utils/key/index.ts +9 -9
- package/src/utils/settingsValidation/consent.ts +2 -1
- package/src/utils/settingsValidation/impressionsMode.ts +6 -6
- package/src/utils/settingsValidation/index.ts +5 -1
- package/src/utils/settingsValidation/integrations/common.ts +1 -1
- package/src/utils/settingsValidation/integrations/configurable.ts +1 -1
- package/src/utils/settingsValidation/integrations/pluggable.ts +2 -1
- package/src/utils/settingsValidation/localhost/builtin.ts +2 -1
- package/src/utils/settingsValidation/localhost/pluggable.ts +2 -1
- package/src/utils/settingsValidation/logger/builtinLogger.ts +2 -1
- package/src/utils/settingsValidation/logger/pluggableLogger.ts +2 -1
- package/src/utils/settingsValidation/splitFilters.ts +9 -7
- package/src/utils/settingsValidation/storage/storageCS.ts +2 -1
- package/types/consent/index.d.ts +2 -0
- package/types/consent/sdkUserConsent.d.ts +13 -0
- package/types/dtos/types.d.ts +172 -0
- package/types/evaluator/Engine.d.ts +15 -0
- package/types/evaluator/combiners/and.d.ts +4 -0
- package/types/evaluator/combiners/ifelseif.d.ts +3 -0
- package/types/evaluator/condition/engineUtils.d.ts +11 -0
- package/types/evaluator/condition/index.d.ts +6 -0
- package/types/evaluator/convertions/index.d.ts +2 -0
- package/types/evaluator/index.d.ts +7 -0
- package/types/evaluator/matchers/all.d.ts +2 -0
- package/types/evaluator/matchers/between.d.ts +3 -0
- package/types/evaluator/matchers/boolean.d.ts +2 -0
- package/types/evaluator/matchers/cont_all.d.ts +2 -0
- package/types/evaluator/matchers/cont_any.d.ts +2 -0
- package/types/evaluator/matchers/cont_str.d.ts +2 -0
- package/types/evaluator/matchers/dependency.d.ts +5 -0
- package/types/evaluator/matchers/eq.d.ts +2 -0
- package/types/evaluator/matchers/eq_set.d.ts +2 -0
- package/types/evaluator/matchers/ew.d.ts +2 -0
- package/types/evaluator/matchers/gte.d.ts +2 -0
- package/types/evaluator/matchers/index.d.ts +7 -0
- package/types/evaluator/matchers/lte.d.ts +2 -0
- package/types/evaluator/matchers/matcherTypes.d.ts +10 -0
- package/types/evaluator/matchers/part_of.d.ts +2 -0
- package/types/evaluator/matchers/segment.d.ts +6 -0
- package/types/evaluator/matchers/string.d.ts +2 -0
- package/types/evaluator/matchers/sw.d.ts +2 -0
- package/types/evaluator/matchers/whitelist.d.ts +3 -0
- package/types/evaluator/matchersTransform/index.d.ts +6 -0
- package/types/evaluator/matchersTransform/segment.d.ts +5 -0
- package/types/evaluator/matchersTransform/set.d.ts +5 -0
- package/types/evaluator/matchersTransform/unaryNumeric.d.ts +5 -0
- package/types/evaluator/matchersTransform/whitelist.d.ts +5 -0
- package/types/evaluator/parser/index.d.ts +5 -0
- package/types/evaluator/treatments/index.d.ts +8 -0
- package/types/evaluator/types.d.ts +28 -0
- package/types/evaluator/value/index.d.ts +7 -0
- package/types/evaluator/value/sanitize.d.ts +7 -0
- package/types/index.d.ts +5 -0
- package/types/integrations/browser.d.ts +12 -0
- package/types/integrations/ga/GaToSplit.d.ts +40 -0
- package/types/integrations/ga/GoogleAnalyticsToSplit.d.ts +3 -0
- package/types/integrations/ga/SplitToGa.d.ts +34 -0
- package/types/integrations/ga/SplitToGoogleAnalytics.d.ts +3 -0
- package/types/integrations/ga/types.d.ts +148 -0
- package/types/integrations/pluggable.d.ts +11 -0
- package/types/integrations/types.d.ts +18 -0
- package/types/listeners/browser.d.ts +40 -0
- package/types/listeners/node.d.ts +22 -0
- package/types/listeners/types.d.ts +4 -0
- package/types/logger/browser/DebugLogger.d.ts +2 -0
- package/types/logger/browser/ErrorLogger.d.ts +2 -0
- package/types/logger/browser/InfoLogger.d.ts +2 -0
- package/types/logger/browser/WarnLogger.d.ts +2 -0
- package/types/logger/constants.d.ts +142 -0
- package/types/logger/index.d.ts +22 -0
- package/types/logger/messages/debug.d.ts +1 -0
- package/types/logger/messages/error.d.ts +1 -0
- package/types/logger/messages/info.d.ts +1 -0
- package/types/logger/messages/warn.d.ts +1 -0
- package/types/logger/sdkLogger.d.ts +8 -0
- package/types/logger/types.d.ts +17 -0
- package/types/readiness/constants.d.ts +7 -0
- package/types/readiness/readinessManager.d.ts +6 -0
- package/types/readiness/sdkReadinessManager.d.ts +11 -0
- package/types/readiness/types.d.ts +60 -0
- package/types/sdkClient/client.d.ts +6 -0
- package/types/sdkClient/clientAttributesDecoration.d.ts +51 -0
- package/types/sdkClient/clientCS.d.ts +10 -0
- package/types/sdkClient/clientInputValidation.d.ts +7 -0
- package/types/sdkClient/sdkClient.d.ts +6 -0
- package/types/sdkClient/sdkClientMethod.d.ts +6 -0
- package/types/sdkClient/sdkClientMethodCS.d.ts +7 -0
- package/types/sdkClient/sdkClientMethodCSWithTT.d.ts +8 -0
- package/types/sdkClient/types.d.ts +18 -0
- package/types/sdkFactory/index.d.ts +6 -0
- package/types/sdkFactory/types.d.ts +82 -0
- package/types/sdkManager/index.d.ts +5 -0
- package/types/services/splitApi.d.ts +11 -0
- package/types/services/splitHttpClient.d.ts +10 -0
- package/types/services/types.d.ts +54 -0
- package/types/storages/AbstractSegmentsCacheSync.d.ts +55 -0
- package/types/storages/AbstractSplitsCacheAsync.d.ts +37 -0
- package/types/storages/AbstractSplitsCacheSync.d.ts +42 -0
- package/types/storages/KeyBuilder.d.ts +14 -0
- package/types/storages/KeyBuilderCS.d.ts +16 -0
- package/types/storages/KeyBuilderSS.d.ts +17 -0
- package/types/storages/dataLoader.d.ts +10 -0
- package/types/storages/findLatencyIndex.d.ts +7 -0
- package/types/storages/inLocalStorage/MySegmentsCacheInLocal.d.ts +25 -0
- package/types/storages/inLocalStorage/SplitsCacheInLocal.d.ts +51 -0
- package/types/storages/inLocalStorage/constants.d.ts +2 -0
- package/types/storages/inLocalStorage/index.d.ts +8 -0
- package/types/storages/inMemory/AttributesCacheInMemory.d.ts +43 -0
- package/types/storages/inMemory/CountsCacheInMemory.d.ts +20 -0
- package/types/storages/inMemory/EventsCacheInMemory.d.ts +35 -0
- package/types/storages/inMemory/ImpressionCountsCacheInMemory.d.ts +28 -0
- package/types/storages/inMemory/ImpressionsCacheInMemory.d.ts +30 -0
- package/types/storages/inMemory/InMemoryStorage.d.ts +10 -0
- package/types/storages/inMemory/InMemoryStorageCS.d.ts +10 -0
- package/types/storages/inMemory/LatenciesCacheInMemory.d.ts +20 -0
- package/types/storages/inMemory/MySegmentsCacheInMemory.d.ts +22 -0
- package/types/storages/inMemory/SegmentsCacheInMemory.d.ts +19 -0
- package/types/storages/inMemory/SplitsCacheInMemory.d.ts +21 -0
- package/types/storages/inMemory/TelemetryCacheInMemory.d.ts +53 -0
- package/types/storages/inMemory/uniqueKeysCacheInMemory.d.ts +35 -0
- package/types/storages/inMemory/uniqueKeysCacheInMemoryCS.d.ts +37 -0
- package/types/storages/inRedis/CountsCacheInRedis.d.ts +9 -0
- package/types/storages/inRedis/EventsCacheInRedis.d.ts +32 -0
- package/types/storages/inRedis/ImpressionCountsCacheInRedis.d.ts +14 -0
- package/types/storages/inRedis/ImpressionsCacheInRedis.d.ts +18 -0
- package/types/storages/inRedis/LatenciesCacheInRedis.d.ts +9 -0
- package/types/storages/inRedis/RedisAdapter.d.ts +24 -0
- package/types/storages/inRedis/SegmentsCacheInRedis.d.ts +18 -0
- package/types/storages/inRedis/SplitsCacheInRedis.d.ts +92 -0
- package/types/storages/inRedis/TelemetryCacheInRedis.d.ts +20 -0
- package/types/storages/inRedis/constants.d.ts +4 -0
- package/types/storages/inRedis/index.d.ts +10 -0
- package/types/storages/inRedis/uniqueKeysCacheInRedis.d.ts +15 -0
- package/types/storages/metadataBuilder.d.ts +3 -0
- package/types/storages/pluggable/EventsCachePluggable.d.ts +38 -0
- package/types/storages/pluggable/ImpressionsCachePluggable.d.ts +35 -0
- package/types/storages/pluggable/SegmentsCachePluggable.d.ts +54 -0
- package/types/storages/pluggable/SplitsCachePluggable.d.ts +90 -0
- package/types/storages/pluggable/TelemetryCachePluggable.d.ts +18 -0
- package/types/storages/pluggable/constants.d.ts +1 -0
- package/types/storages/pluggable/inMemoryWrapper.d.ts +13 -0
- package/types/storages/pluggable/index.d.ts +9 -0
- package/types/storages/pluggable/wrapperAdapter.d.ts +12 -0
- package/types/storages/types.d.ts +417 -0
- package/types/sync/offline/LocalhostFromFile.d.ts +2 -0
- package/types/sync/offline/LocalhostFromObject.d.ts +2 -0
- package/types/sync/offline/splitsParser/parseCondition.d.ts +7 -0
- package/types/sync/offline/splitsParser/splitsParserFromFile.d.ts +2 -0
- package/types/sync/offline/splitsParser/splitsParserFromSettings.d.ts +3 -0
- package/types/sync/offline/splitsParser/types.d.ts +3 -0
- package/types/sync/offline/syncManagerOffline.d.ts +10 -0
- package/types/sync/offline/syncTasks/fromObjectSyncTask.d.ts +17 -0
- package/types/sync/polling/fetchers/mySegmentsFetcher.d.ts +7 -0
- package/types/sync/polling/fetchers/segmentChangesFetcher.d.ts +7 -0
- package/types/sync/polling/fetchers/splitChangesFetcher.d.ts +7 -0
- package/types/sync/polling/fetchers/types.d.ts +5 -0
- package/types/sync/polling/pollingManagerCS.d.ts +7 -0
- package/types/sync/polling/pollingManagerSS.d.ts +6 -0
- package/types/sync/polling/syncTasks/mySegmentsSyncTask.d.ts +9 -0
- package/types/sync/polling/syncTasks/segmentsSyncTask.d.ts +9 -0
- package/types/sync/polling/syncTasks/splitsSyncTask.d.ts +9 -0
- package/types/sync/polling/types.d.ts +26 -0
- package/types/sync/polling/updaters/mySegmentsUpdater.d.ts +13 -0
- package/types/sync/polling/updaters/segmentChangesUpdater.d.ts +18 -0
- package/types/sync/polling/updaters/splitChangesUpdater.d.ts +39 -0
- package/types/sync/streaming/AuthClient/index.d.ts +12 -0
- package/types/sync/streaming/AuthClient/types.d.ts +17 -0
- package/types/sync/streaming/SSEClient/index.d.ts +34 -0
- package/types/sync/streaming/SSEClient/types.d.ts +11 -0
- package/types/sync/streaming/SSEHandler/NotificationKeeper.d.ts +14 -0
- package/types/sync/streaming/SSEHandler/NotificationParser.d.ts +20 -0
- package/types/sync/streaming/SSEHandler/index.d.ts +11 -0
- package/types/sync/streaming/SSEHandler/types.d.ts +67 -0
- package/types/sync/streaming/UpdateWorkers/MySegmentsUpdateWorker.d.ts +6 -0
- package/types/sync/streaming/UpdateWorkers/SegmentsUpdateWorker.d.ts +8 -0
- package/types/sync/streaming/UpdateWorkers/SplitsUpdateWorker.d.ts +12 -0
- package/types/sync/streaming/UpdateWorkers/constants.d.ts +3 -0
- package/types/sync/streaming/UpdateWorkers/types.d.ts +4 -0
- package/types/sync/streaming/constants.d.ts +34 -0
- package/types/sync/streaming/mySegmentsV2utils.d.ts +27 -0
- package/types/sync/streaming/pushManager.d.ts +9 -0
- package/types/sync/streaming/types.d.ts +35 -0
- package/types/sync/submitters/eventsSubmitter.d.ts +5 -0
- package/types/sync/submitters/eventsSyncTask.d.ts +8 -0
- package/types/sync/submitters/impressionCountsSubmitter.d.ts +10 -0
- package/types/sync/submitters/impressionCountsSubmitterInRedis.d.ts +5 -0
- package/types/sync/submitters/impressionCountsSyncTask.d.ts +13 -0
- package/types/sync/submitters/impressionsSubmitter.d.ts +11 -0
- package/types/sync/submitters/impressionsSyncTask.d.ts +14 -0
- package/types/sync/submitters/metricsSyncTask.d.ts +12 -0
- package/types/sync/submitters/submitter.d.ts +12 -0
- package/types/sync/submitters/submitterManager.d.ts +3 -0
- package/types/sync/submitters/submitterSyncTask.d.ts +10 -0
- package/types/sync/submitters/telemetrySubmitter.d.ts +25 -0
- package/types/sync/submitters/types.d.ts +194 -0
- package/types/sync/submitters/uniqueKeysSubmitter.d.ts +5 -0
- package/types/sync/submitters/uniqueKeysSubmitterInRedis.d.ts +5 -0
- package/types/sync/syncManagerOnline.d.ts +13 -0
- package/types/sync/syncTask.d.ts +13 -0
- package/types/sync/syncTaskComposite.d.ts +5 -0
- package/types/sync/types.d.ts +43 -0
- package/types/trackers/eventTracker.d.ts +10 -0
- package/types/trackers/filter/bloomFilter.d.ts +10 -0
- package/types/trackers/filter/dictionaryFilter.d.ts +8 -0
- package/types/trackers/filter/types.d.ts +5 -0
- package/types/trackers/impressionObserver/ImpressionObserver.d.ts +8 -0
- package/types/trackers/impressionObserver/buildKey.d.ts +2 -0
- package/types/trackers/impressionObserver/impressionObserverCS.d.ts +4 -0
- package/types/trackers/impressionObserver/impressionObserverSS.d.ts +4 -0
- package/types/trackers/impressionObserver/types.d.ts +4 -0
- package/types/trackers/impressionObserver/utils.d.ts +13 -0
- package/types/trackers/impressionsTracker.d.ts +13 -0
- package/types/trackers/strategy/strategyDebug.d.ts +9 -0
- package/types/trackers/strategy/strategyNone.d.ts +10 -0
- package/types/trackers/strategy/strategyOptimized.d.ts +11 -0
- package/types/trackers/telemetryTracker.d.ts +3 -0
- package/types/trackers/types.d.ts +63 -0
- package/types/trackers/uniqueKeysTracker.d.ts +13 -0
- package/types/types.d.ts +1265 -0
- package/types/utils/Backoff.d.ts +25 -0
- package/types/utils/LRUCache/LinkedList.d.ts +34 -0
- package/types/utils/LRUCache/index.d.ts +16 -0
- package/types/utils/MinEventEmitter.d.ts +12 -0
- package/types/utils/MinEvents.d.ts +4 -0
- package/types/utils/base64/index.d.ts +30 -0
- package/types/utils/constants/browser.d.ts +3 -0
- package/types/utils/constants/index.d.ts +64 -0
- package/types/utils/decompress/index.d.ts +16 -0
- package/types/utils/env/isLocalStorageAvailable.d.ts +1 -0
- package/types/utils/env/isNode.d.ts +5 -0
- package/types/utils/inputValidation/apiKey.d.ts +7 -0
- package/types/utils/inputValidation/attribute.d.ts +2 -0
- package/types/utils/inputValidation/attributes.d.ts +4 -0
- package/types/utils/inputValidation/event.d.ts +2 -0
- package/types/utils/inputValidation/eventProperties.d.ts +6 -0
- package/types/utils/inputValidation/eventValue.d.ts +2 -0
- package/types/utils/inputValidation/index.d.ts +13 -0
- package/types/utils/inputValidation/isOperational.d.ts +4 -0
- package/types/utils/inputValidation/key.d.ts +3 -0
- package/types/utils/inputValidation/preloadedData.d.ts +3 -0
- package/types/utils/inputValidation/split.d.ts +2 -0
- package/types/utils/inputValidation/splitExistance.d.ts +7 -0
- package/types/utils/inputValidation/splits.d.ts +2 -0
- package/types/utils/inputValidation/trafficType.d.ts +2 -0
- package/types/utils/inputValidation/trafficTypeExistance.d.ts +9 -0
- package/types/utils/jwt/index.d.ts +5 -0
- package/types/utils/jwt/types.d.ts +5 -0
- package/types/utils/key/index.d.ts +8 -0
- package/types/utils/labels/index.d.ts +7 -0
- package/types/utils/lang/binarySearch.d.ts +9 -0
- package/types/utils/lang/getFnName.d.ts +4 -0
- package/types/utils/lang/getGlobal.d.ts +4 -0
- package/types/utils/lang/index.d.ts +105 -0
- package/types/utils/lang/maps.d.ts +55 -0
- package/types/utils/lang/objectAssign.d.ts +3 -0
- package/types/utils/lang/sets.d.ts +60 -0
- package/types/utils/murmur3/common.d.ts +12 -0
- package/types/utils/murmur3/legacy.d.ts +2 -0
- package/types/utils/murmur3/murmur3.d.ts +2 -0
- package/types/utils/murmur3/murmur3_128.d.ts +6 -0
- package/types/utils/murmur3/murmur3_128_x86.d.ts +7 -0
- package/types/utils/murmur3/murmur3_64.d.ts +10 -0
- package/types/utils/murmur3/utfx.d.ts +27 -0
- package/types/utils/promise/thenable.d.ts +1 -0
- package/types/utils/promise/timeout.d.ts +1 -0
- package/types/utils/promise/wrapper.d.ts +21 -0
- package/types/utils/settingsValidation/consent.d.ts +6 -0
- package/types/utils/settingsValidation/impressionsMode.d.ts +3 -0
- package/types/utils/settingsValidation/index.d.ts +52 -0
- package/types/utils/settingsValidation/integrations/common.d.ts +14 -0
- package/types/utils/settingsValidation/integrations/configurable.d.ts +13 -0
- package/types/utils/settingsValidation/integrations/pluggable.d.ts +13 -0
- package/types/utils/settingsValidation/localhost/builtin.d.ts +16 -0
- package/types/utils/settingsValidation/localhost/pluggable.d.ts +16 -0
- package/types/utils/settingsValidation/logger/builtinLogger.d.ts +10 -0
- package/types/utils/settingsValidation/logger/commons.d.ts +9 -0
- package/types/utils/settingsValidation/logger/pluggableLogger.d.ts +11 -0
- package/types/utils/settingsValidation/mode.d.ts +1 -0
- package/types/utils/settingsValidation/runtime.d.ts +2 -0
- package/types/utils/settingsValidation/splitFilters.d.ts +16 -0
- package/types/utils/settingsValidation/storage/storageCS.d.ts +21 -0
- package/types/utils/settingsValidation/types.d.ts +32 -0
- package/types/utils/settingsValidation/url.d.ts +10 -0
- package/types/utils/time/index.d.ts +4 -0
- package/types/utils/timeTracker/index.d.ts +70 -0
- package/types/utils/timeTracker/now/browser.d.ts +1 -0
- package/types/utils/timeTracker/now/node.d.ts +1 -0
- package/types/utils/timeTracker/timer.d.ts +1 -0
- package/src/logger/.DS_Store +0 -0
- package/src/types.d.ts +0 -1581
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UniqueKeysCacheInMemory = void 0;
|
|
4
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
5
|
+
var constants_1 = require("../inRedis/constants");
|
|
6
|
+
var UniqueKeysCacheInMemory = /** @class */ (function () {
|
|
7
|
+
function UniqueKeysCacheInMemory(uniqueKeysQueueSize) {
|
|
8
|
+
if (uniqueKeysQueueSize === void 0) { uniqueKeysQueueSize = constants_1.DEFAULT_CACHE_SIZE; }
|
|
9
|
+
this.uniqueTrackerSize = 0;
|
|
10
|
+
this.maxStorage = uniqueKeysQueueSize;
|
|
11
|
+
this.uniqueKeysTracker = {};
|
|
12
|
+
}
|
|
13
|
+
UniqueKeysCacheInMemory.prototype.setOnFullQueueCb = function (cb) {
|
|
14
|
+
this.onFullQueue = cb;
|
|
15
|
+
};
|
|
16
|
+
/**
|
|
17
|
+
* Store unique keys in sequential order
|
|
18
|
+
* key: string = feature name.
|
|
19
|
+
* value: Set<string> = set of unique keys.
|
|
20
|
+
*/
|
|
21
|
+
UniqueKeysCacheInMemory.prototype.track = function (key, featureName) {
|
|
22
|
+
if (!this.uniqueKeysTracker[featureName])
|
|
23
|
+
this.uniqueKeysTracker[featureName] = new sets_1._Set();
|
|
24
|
+
var tracker = this.uniqueKeysTracker[featureName];
|
|
25
|
+
if (!tracker.has(key)) {
|
|
26
|
+
tracker.add(key);
|
|
27
|
+
this.uniqueTrackerSize++;
|
|
28
|
+
}
|
|
29
|
+
if (this.uniqueTrackerSize >= this.maxStorage && this.onFullQueue) {
|
|
30
|
+
this.uniqueTrackerSize = 0;
|
|
31
|
+
this.onFullQueue();
|
|
32
|
+
}
|
|
33
|
+
};
|
|
34
|
+
/**
|
|
35
|
+
* Clear the data stored on the cache.
|
|
36
|
+
*/
|
|
37
|
+
UniqueKeysCacheInMemory.prototype.clear = function () {
|
|
38
|
+
this.uniqueKeysTracker = {};
|
|
39
|
+
};
|
|
40
|
+
/**
|
|
41
|
+
* Pop the collected data, used as payload for posting.
|
|
42
|
+
*/
|
|
43
|
+
UniqueKeysCacheInMemory.prototype.pop = function () {
|
|
44
|
+
var data = this.uniqueKeysTracker;
|
|
45
|
+
this.uniqueKeysTracker = {};
|
|
46
|
+
return this.fromUniqueKeysCollector(data);
|
|
47
|
+
};
|
|
48
|
+
/**
|
|
49
|
+
* Check if the cache is empty.
|
|
50
|
+
*/
|
|
51
|
+
UniqueKeysCacheInMemory.prototype.isEmpty = function () {
|
|
52
|
+
return Object.keys(this.uniqueKeysTracker).length === 0;
|
|
53
|
+
};
|
|
54
|
+
/**
|
|
55
|
+
* Converts `uniqueKeys` data from cache into request payload for SS.
|
|
56
|
+
*/
|
|
57
|
+
UniqueKeysCacheInMemory.prototype.fromUniqueKeysCollector = function (uniqueKeys) {
|
|
58
|
+
var payload = [];
|
|
59
|
+
var featureNames = Object.keys(uniqueKeys);
|
|
60
|
+
for (var i = 0; i < featureNames.length; i++) {
|
|
61
|
+
var featureName = featureNames[i];
|
|
62
|
+
var featureKeys = (0, sets_1.setToArray)(uniqueKeys[featureName]);
|
|
63
|
+
var uniqueKeysPayload = {
|
|
64
|
+
f: featureName,
|
|
65
|
+
ks: featureKeys
|
|
66
|
+
};
|
|
67
|
+
payload.push(uniqueKeysPayload);
|
|
68
|
+
}
|
|
69
|
+
return { keys: payload };
|
|
70
|
+
};
|
|
71
|
+
return UniqueKeysCacheInMemory;
|
|
72
|
+
}());
|
|
73
|
+
exports.UniqueKeysCacheInMemory = UniqueKeysCacheInMemory;
|
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UniqueKeysCacheInMemoryCS = void 0;
|
|
4
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
5
|
+
var constants_1 = require("../inRedis/constants");
|
|
6
|
+
var UniqueKeysCacheInMemoryCS = /** @class */ (function () {
|
|
7
|
+
/**
|
|
8
|
+
*
|
|
9
|
+
* @param impressionsQueueSize number of queued impressions to call onFullQueueCb.
|
|
10
|
+
* Default value is 0, that means no maximum value, in case we want to avoid this being triggered.
|
|
11
|
+
*/
|
|
12
|
+
function UniqueKeysCacheInMemoryCS(uniqueKeysQueueSize) {
|
|
13
|
+
if (uniqueKeysQueueSize === void 0) { uniqueKeysQueueSize = constants_1.DEFAULT_CACHE_SIZE; }
|
|
14
|
+
this.uniqueTrackerSize = 0;
|
|
15
|
+
this.maxStorage = uniqueKeysQueueSize;
|
|
16
|
+
this.uniqueKeysTracker = {};
|
|
17
|
+
}
|
|
18
|
+
UniqueKeysCacheInMemoryCS.prototype.setOnFullQueueCb = function (cb) {
|
|
19
|
+
this.onFullQueue = cb;
|
|
20
|
+
};
|
|
21
|
+
/**
|
|
22
|
+
* Store unique keys in sequential order
|
|
23
|
+
* key: string = key.
|
|
24
|
+
* value: HashSet<string> = set of split names.
|
|
25
|
+
*/
|
|
26
|
+
UniqueKeysCacheInMemoryCS.prototype.track = function (key, featureName) {
|
|
27
|
+
if (!this.uniqueKeysTracker[key])
|
|
28
|
+
this.uniqueKeysTracker[key] = new sets_1._Set();
|
|
29
|
+
var tracker = this.uniqueKeysTracker[key];
|
|
30
|
+
if (!tracker.has(featureName)) {
|
|
31
|
+
tracker.add(featureName);
|
|
32
|
+
this.uniqueTrackerSize++;
|
|
33
|
+
}
|
|
34
|
+
if (this.uniqueTrackerSize >= this.maxStorage && this.onFullQueue) {
|
|
35
|
+
this.uniqueTrackerSize = 0;
|
|
36
|
+
this.onFullQueue();
|
|
37
|
+
}
|
|
38
|
+
};
|
|
39
|
+
/**
|
|
40
|
+
* Clear the data stored on the cache.
|
|
41
|
+
*/
|
|
42
|
+
UniqueKeysCacheInMemoryCS.prototype.clear = function () {
|
|
43
|
+
this.uniqueKeysTracker = {};
|
|
44
|
+
};
|
|
45
|
+
/**
|
|
46
|
+
* Pop the collected data, used as payload for posting.
|
|
47
|
+
*/
|
|
48
|
+
UniqueKeysCacheInMemoryCS.prototype.pop = function () {
|
|
49
|
+
var data = this.uniqueKeysTracker;
|
|
50
|
+
this.uniqueKeysTracker = {};
|
|
51
|
+
return this.fromUniqueKeysCollector(data);
|
|
52
|
+
};
|
|
53
|
+
/**
|
|
54
|
+
* Check if the cache is empty.
|
|
55
|
+
*/
|
|
56
|
+
UniqueKeysCacheInMemoryCS.prototype.isEmpty = function () {
|
|
57
|
+
return Object.keys(this.uniqueKeysTracker).length === 0;
|
|
58
|
+
};
|
|
59
|
+
/**
|
|
60
|
+
* Converts `uniqueKeys` data from cache into request payload.
|
|
61
|
+
*/
|
|
62
|
+
UniqueKeysCacheInMemoryCS.prototype.fromUniqueKeysCollector = function (uniqueKeys) {
|
|
63
|
+
var payload = [];
|
|
64
|
+
var featureKeys = Object.keys(uniqueKeys);
|
|
65
|
+
for (var k = 0; k < featureKeys.length; k++) {
|
|
66
|
+
var featureKey = featureKeys[k];
|
|
67
|
+
var featureNames = (0, sets_1.setToArray)(uniqueKeys[featureKey]);
|
|
68
|
+
var uniqueKeysPayload = {
|
|
69
|
+
k: featureKey,
|
|
70
|
+
fs: featureNames
|
|
71
|
+
};
|
|
72
|
+
payload.push(uniqueKeysPayload);
|
|
73
|
+
}
|
|
74
|
+
return { keys: payload };
|
|
75
|
+
};
|
|
76
|
+
return UniqueKeysCacheInMemoryCS;
|
|
77
|
+
}());
|
|
78
|
+
exports.UniqueKeysCacheInMemoryCS = UniqueKeysCacheInMemoryCS;
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ImpressionCountsCacheInRedis = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var ImpressionCountsCacheInMemory_1 = require("../inMemory/ImpressionCountsCacheInMemory");
|
|
6
|
+
var constants_1 = require("./constants");
|
|
7
|
+
var ImpressionCountsCacheInRedis = /** @class */ (function (_super) {
|
|
8
|
+
(0, tslib_1.__extends)(ImpressionCountsCacheInRedis, _super);
|
|
9
|
+
function ImpressionCountsCacheInRedis(log, key, redis, impressionCountsCacheSize, refreshRate) {
|
|
10
|
+
if (refreshRate === void 0) { refreshRate = constants_1.REFRESH_RATE; }
|
|
11
|
+
var _this = _super.call(this, impressionCountsCacheSize) || this;
|
|
12
|
+
_this.log = log;
|
|
13
|
+
_this.key = key;
|
|
14
|
+
_this.redis = redis;
|
|
15
|
+
_this.refreshRate = refreshRate;
|
|
16
|
+
_this.onFullQueue = function () { _this.postImpressionCountsInRedis(); };
|
|
17
|
+
return _this;
|
|
18
|
+
}
|
|
19
|
+
ImpressionCountsCacheInRedis.prototype.postImpressionCountsInRedis = function () {
|
|
20
|
+
var _this = this;
|
|
21
|
+
var counts = this.pop();
|
|
22
|
+
if (!counts)
|
|
23
|
+
return false;
|
|
24
|
+
var keys = Object.keys(counts);
|
|
25
|
+
var pipeline = this.redis.pipeline();
|
|
26
|
+
keys.forEach(function (key) {
|
|
27
|
+
pipeline.hincrby(_this.key, key, counts[key]);
|
|
28
|
+
});
|
|
29
|
+
return pipeline.exec()
|
|
30
|
+
.then(function (data) {
|
|
31
|
+
// If this is the creation of the key on Redis, set the expiration for it in 3600 seconds.
|
|
32
|
+
if (data.length && data.length === keys.length) {
|
|
33
|
+
return _this.redis.expire(_this.key, constants_1.TTL_REFRESH);
|
|
34
|
+
}
|
|
35
|
+
})
|
|
36
|
+
.catch(function (err) {
|
|
37
|
+
_this.log.error(constants_1.LOG_PREFIX + "Error in impression counts pipeline: " + err + ".");
|
|
38
|
+
return false;
|
|
39
|
+
});
|
|
40
|
+
};
|
|
41
|
+
ImpressionCountsCacheInRedis.prototype.start = function () {
|
|
42
|
+
this.intervalId = setInterval(this.postImpressionCountsInRedis.bind(this), this.refreshRate);
|
|
43
|
+
};
|
|
44
|
+
ImpressionCountsCacheInRedis.prototype.stop = function () {
|
|
45
|
+
clearInterval(this.intervalId);
|
|
46
|
+
};
|
|
47
|
+
return ImpressionCountsCacheInRedis;
|
|
48
|
+
}(ImpressionCountsCacheInMemory_1.ImpressionCountsCacheInMemory));
|
|
49
|
+
exports.ImpressionCountsCacheInRedis = ImpressionCountsCacheInRedis;
|
|
@@ -62,17 +62,17 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
|
|
|
62
62
|
var splitKey = this.keys.buildSplitKey(name);
|
|
63
63
|
return this.redis.get(splitKey).then(function (splitFromStorage) {
|
|
64
64
|
// handling parsing errors
|
|
65
|
-
var parsedPreviousSplit,
|
|
65
|
+
var parsedPreviousSplit, newStringifiedSplit;
|
|
66
66
|
try {
|
|
67
67
|
parsedPreviousSplit = splitFromStorage ? JSON.parse(splitFromStorage) : undefined;
|
|
68
|
-
|
|
68
|
+
newStringifiedSplit = JSON.stringify(split);
|
|
69
69
|
}
|
|
70
70
|
catch (e) {
|
|
71
71
|
throw new Error('Error parsing split definition: ' + e);
|
|
72
72
|
}
|
|
73
73
|
return Promise.all([
|
|
74
|
-
_this.redis.set(splitKey,
|
|
75
|
-
_this._incrementCounts(
|
|
74
|
+
_this.redis.set(splitKey, newStringifiedSplit),
|
|
75
|
+
_this._incrementCounts(split),
|
|
76
76
|
// If it's an update, we decrement the traffic type of the existing split,
|
|
77
77
|
parsedPreviousSplit && _this._decrementCounts(parsedPreviousSplit)
|
|
78
78
|
]);
|
|
@@ -99,8 +99,7 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
|
|
|
99
99
|
var _this = this;
|
|
100
100
|
return this.getSplit(name).then(function (split) {
|
|
101
101
|
if (split) {
|
|
102
|
-
|
|
103
|
-
_this._decrementCounts(parsedSplit);
|
|
102
|
+
_this._decrementCounts(split);
|
|
104
103
|
}
|
|
105
104
|
return _this.redis.del(_this.keys.buildSplitKey(name));
|
|
106
105
|
});
|
|
@@ -123,7 +122,8 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
|
|
|
123
122
|
this.log.error(constants_1.LOG_PREFIX + this.redisError);
|
|
124
123
|
return Promise.reject(this.redisError);
|
|
125
124
|
}
|
|
126
|
-
return this.redis.get(this.keys.buildSplitKey(name))
|
|
125
|
+
return this.redis.get(this.keys.buildSplitKey(name))
|
|
126
|
+
.then(function (maybeSplit) { return maybeSplit && JSON.parse(maybeSplit); });
|
|
127
127
|
};
|
|
128
128
|
/**
|
|
129
129
|
* Set till number.
|
|
@@ -158,7 +158,12 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
|
|
|
158
158
|
*/
|
|
159
159
|
SplitsCacheInRedis.prototype.getAll = function () {
|
|
160
160
|
var _this = this;
|
|
161
|
-
return this.redis.keys(this.keys.searchPatternForSplitKeys())
|
|
161
|
+
return this.redis.keys(this.keys.searchPatternForSplitKeys())
|
|
162
|
+
.then(function (listOfKeys) { return _this.redis.pipeline(listOfKeys.map(function (k) { return ['get', k]; })).exec(); })
|
|
163
|
+
.then(processPipelineAnswer)
|
|
164
|
+
.then(function (splitDefinitions) { return splitDefinitions.map(function (splitDefinition) {
|
|
165
|
+
return JSON.parse(splitDefinition);
|
|
166
|
+
}); });
|
|
162
167
|
};
|
|
163
168
|
/**
|
|
164
169
|
* Get list of split names.
|
|
@@ -218,7 +223,8 @@ var SplitsCacheInRedis = /** @class */ (function (_super) {
|
|
|
218
223
|
var keys = names.map(function (name) { return _this.keys.buildSplitKey(name); });
|
|
219
224
|
return (_a = this.redis).mget.apply(_a, keys).then(function (splitDefinitions) {
|
|
220
225
|
names.forEach(function (name, idx) {
|
|
221
|
-
|
|
226
|
+
var split = splitDefinitions[idx];
|
|
227
|
+
splits[name] = split && JSON.parse(split);
|
|
222
228
|
});
|
|
223
229
|
return Promise.resolve(splits);
|
|
224
230
|
})
|
|
@@ -1,4 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.LOG_PREFIX = void 0;
|
|
3
|
+
exports.TTL_REFRESH = exports.REFRESH_RATE = exports.DEFAULT_CACHE_SIZE = exports.LOG_PREFIX = void 0;
|
|
4
4
|
exports.LOG_PREFIX = 'storage:redis: ';
|
|
5
|
+
exports.DEFAULT_CACHE_SIZE = 30000;
|
|
6
|
+
exports.REFRESH_RATE = 300000; // 300.000 ms = start after 5 mins
|
|
7
|
+
exports.TTL_REFRESH = 3600; // 1hr
|
|
@@ -10,6 +10,8 @@ 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");
|
|
13
15
|
/**
|
|
14
16
|
* InRedis storage factory for consumer server-side SplitFactory, that uses `Ioredis` Redis client for Node.
|
|
15
17
|
* @see {@link https://www.npmjs.com/package/ioredis}
|
|
@@ -18,13 +20,19 @@ function InRedisStorage(options) {
|
|
|
18
20
|
if (options === void 0) { options = {}; }
|
|
19
21
|
var prefix = (0, KeyBuilder_1.validatePrefix)(options.prefix);
|
|
20
22
|
function InRedisStorageFactory(_a) {
|
|
21
|
-
var log = _a.log, metadata = _a.metadata, onReadyCb = _a.onReadyCb;
|
|
23
|
+
var log = _a.log, metadata = _a.metadata, onReadyCb = _a.onReadyCb, impressionsMode = _a.impressionsMode, impressionCountsQueueSize = _a.impressionCountsQueueSize, impressionCountsRefreshRate = _a.impressionCountsRefreshRate, uniqueKeysCacheSize = _a.uniqueKeysCacheSize, uniqueKeysRefreshRate = _a.uniqueKeysRefreshRate;
|
|
22
24
|
var keys = new KeyBuilderSS_1.KeyBuilderSS(prefix, metadata);
|
|
23
25
|
var redisClient = new RedisAdapter_1.RedisAdapter(log, options.options || {});
|
|
24
26
|
var telemetry = new TelemetryCacheInRedis_1.TelemetryCacheInRedis(log, keys, redisClient);
|
|
27
|
+
var impressionCountsCache = impressionsMode !== constants_1.DEBUG ? new ImpressionCountsCacheInRedis_1.ImpressionCountsCacheInRedis(log, keys.buildImpressionsCountKey(), redisClient, impressionCountsQueueSize, impressionCountsRefreshRate) : undefined;
|
|
28
|
+
var uniqueKeysCache = impressionsMode === constants_1.NONE ? new uniqueKeysCacheInRedis_1.UniqueKeysCacheInRedis(log, keys.buildUniqueKeysKey(), redisClient, uniqueKeysCacheSize, uniqueKeysRefreshRate) : undefined;
|
|
25
29
|
// subscription to Redis connect event in order to emit SDK_READY event on consumer mode
|
|
26
30
|
redisClient.on('connect', function () {
|
|
27
31
|
onReadyCb();
|
|
32
|
+
if (impressionCountsCache)
|
|
33
|
+
impressionCountsCache.start();
|
|
34
|
+
if (uniqueKeysCache)
|
|
35
|
+
uniqueKeysCache.start();
|
|
28
36
|
// Synchronize config
|
|
29
37
|
telemetry.recordConfig();
|
|
30
38
|
});
|
|
@@ -32,12 +40,18 @@ function InRedisStorage(options) {
|
|
|
32
40
|
splits: new SplitsCacheInRedis_1.SplitsCacheInRedis(log, keys, redisClient),
|
|
33
41
|
segments: new SegmentsCacheInRedis_1.SegmentsCacheInRedis(log, keys, redisClient),
|
|
34
42
|
impressions: new ImpressionsCacheInRedis_1.ImpressionsCacheInRedis(log, keys.buildImpressionsKey(), redisClient, metadata),
|
|
43
|
+
impressionCounts: impressionCountsCache,
|
|
35
44
|
events: new EventsCacheInRedis_1.EventsCacheInRedis(log, keys.buildEventsKey(), redisClient, metadata),
|
|
36
45
|
telemetry: telemetry,
|
|
46
|
+
uniqueKeys: uniqueKeysCache,
|
|
37
47
|
// When using REDIS we should:
|
|
38
48
|
// 1- Disconnect from the storage
|
|
39
49
|
destroy: function () {
|
|
40
50
|
redisClient.disconnect();
|
|
51
|
+
if (impressionCountsCache)
|
|
52
|
+
impressionCountsCache.stop();
|
|
53
|
+
if (uniqueKeysCache)
|
|
54
|
+
uniqueKeysCache.stop();
|
|
41
55
|
// @TODO check that caches works as expected when redisClient is disconnected
|
|
42
56
|
}
|
|
43
57
|
};
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.UniqueKeysCacheInRedis = void 0;
|
|
4
|
+
var tslib_1 = require("tslib");
|
|
5
|
+
var uniqueKeysCacheInMemory_1 = require("../inMemory/uniqueKeysCacheInMemory");
|
|
6
|
+
var sets_1 = require("../../utils/lang/sets");
|
|
7
|
+
var constants_1 = require("./constants");
|
|
8
|
+
var constants_2 = require("./constants");
|
|
9
|
+
var UniqueKeysCacheInRedis = /** @class */ (function (_super) {
|
|
10
|
+
(0, tslib_1.__extends)(UniqueKeysCacheInRedis, _super);
|
|
11
|
+
function UniqueKeysCacheInRedis(log, key, redis, uniqueKeysQueueSize, refreshRate) {
|
|
12
|
+
if (uniqueKeysQueueSize === void 0) { uniqueKeysQueueSize = constants_1.DEFAULT_CACHE_SIZE; }
|
|
13
|
+
if (refreshRate === void 0) { refreshRate = constants_1.REFRESH_RATE; }
|
|
14
|
+
var _this = _super.call(this, uniqueKeysQueueSize) || this;
|
|
15
|
+
_this.log = log;
|
|
16
|
+
_this.key = key;
|
|
17
|
+
_this.redis = redis;
|
|
18
|
+
_this.refreshRate = refreshRate;
|
|
19
|
+
_this.onFullQueue = function () { _this.postUniqueKeysInRedis(); };
|
|
20
|
+
return _this;
|
|
21
|
+
}
|
|
22
|
+
UniqueKeysCacheInRedis.prototype.postUniqueKeysInRedis = function () {
|
|
23
|
+
var _this = this;
|
|
24
|
+
var pipeline = this.redis.pipeline();
|
|
25
|
+
var featureNames = Object.keys(this.uniqueKeysTracker);
|
|
26
|
+
for (var i = 0; i < featureNames.length; i++) {
|
|
27
|
+
var featureName = featureNames[i];
|
|
28
|
+
var featureKeys = (0, sets_1.setToArray)(this.uniqueKeysTracker[featureName]);
|
|
29
|
+
var uniqueKeysPayload = {
|
|
30
|
+
f: featureName,
|
|
31
|
+
ks: featureKeys
|
|
32
|
+
};
|
|
33
|
+
pipeline.rpush(this.key, JSON.stringify(uniqueKeysPayload));
|
|
34
|
+
}
|
|
35
|
+
this.clear();
|
|
36
|
+
return pipeline.exec()
|
|
37
|
+
.then(function (data) {
|
|
38
|
+
// If this is the creation of the key on Redis, set the expiration for it in 3600 seconds.
|
|
39
|
+
if (data.length && data.length === featureNames.length) {
|
|
40
|
+
return _this.redis.expire(_this.key, constants_1.TTL_REFRESH);
|
|
41
|
+
}
|
|
42
|
+
})
|
|
43
|
+
.catch(function (err) {
|
|
44
|
+
_this.log.error(constants_2.LOG_PREFIX + "Error in uniqueKeys pipeline: " + err + ".");
|
|
45
|
+
return false;
|
|
46
|
+
});
|
|
47
|
+
};
|
|
48
|
+
UniqueKeysCacheInRedis.prototype.start = function () {
|
|
49
|
+
this.intervalId = setInterval(this.postUniqueKeysInRedis.bind(this), this.refreshRate);
|
|
50
|
+
};
|
|
51
|
+
UniqueKeysCacheInRedis.prototype.stop = function () {
|
|
52
|
+
clearInterval(this.intervalId);
|
|
53
|
+
};
|
|
54
|
+
return UniqueKeysCacheInRedis;
|
|
55
|
+
}(uniqueKeysCacheInMemory_1.UniqueKeysCacheInMemory));
|
|
56
|
+
exports.UniqueKeysCacheInRedis = UniqueKeysCacheInRedis;
|
|
@@ -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,6 +5,7 @@ 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");
|
|
8
9
|
function submitterManagerFactory(params) {
|
|
9
10
|
var submitters = [
|
|
10
11
|
(0, impressionsSubmitter_1.impressionsSubmitterFactory)(params),
|
|
@@ -14,6 +15,8 @@ function submitterManagerFactory(params) {
|
|
|
14
15
|
if (impressionCountsSubmitter)
|
|
15
16
|
submitters.push(impressionCountsSubmitter);
|
|
16
17
|
var telemetrySubmitter = (0, telemetrySubmitter_1.telemetrySubmitterFactory)(params);
|
|
18
|
+
if (params.uniqueKeysTracker)
|
|
19
|
+
submitters.push((0, uniqueKeysSubmitter_1.uniqueKeysSubmitterFactory)(params));
|
|
17
20
|
return {
|
|
18
21
|
// `onlyTelemetry` true if SDK is created with userConsent not GRANTED
|
|
19
22
|
start: function (onlyTelemetry) {
|
|
@@ -50,6 +50,7 @@ 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,
|
|
53
54
|
_b);
|
|
54
55
|
var USER_CONSENT_MAP = (_c = {},
|
|
55
56
|
_c[constants_1.CONSENT_UNKNOWN] = 1,
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.uniqueKeysSubmitterFactory = void 0;
|
|
4
|
+
var constants_1 = require("../../logger/constants");
|
|
5
|
+
var submitter_1 = require("./submitter");
|
|
6
|
+
var DATA_NAME = 'uniqueKeys';
|
|
7
|
+
/**
|
|
8
|
+
* Submitter that periodically posts impression counts
|
|
9
|
+
*/
|
|
10
|
+
function uniqueKeysSubmitterFactory(params) {
|
|
11
|
+
var _a = params.settings, log = _a.log, uniqueKeysRefreshRate = _a.scheduler.uniqueKeysRefreshRate, key = _a.core.key, _b = params.splitApi, postUniqueKeysBulkCs = _b.postUniqueKeysBulkCs, postUniqueKeysBulkSs = _b.postUniqueKeysBulkSs, uniqueKeys = params.storage.uniqueKeys;
|
|
12
|
+
var isClientSide = key !== undefined;
|
|
13
|
+
var postUniqueKeysBulk = isClientSide ? postUniqueKeysBulkCs : postUniqueKeysBulkSs;
|
|
14
|
+
var syncTask = (0, submitter_1.submitterFactory)(log, postUniqueKeysBulk, uniqueKeys, uniqueKeysRefreshRate, 'unique keys');
|
|
15
|
+
// register unique keys submitter to be executed when uniqueKeys cache is full
|
|
16
|
+
uniqueKeys.setOnFullQueueCb(function () {
|
|
17
|
+
if (syncTask.isRunning()) {
|
|
18
|
+
log.info(constants_1.SUBMITTERS_PUSH_FULL_QUEUE, [DATA_NAME]);
|
|
19
|
+
syncTask.execute();
|
|
20
|
+
}
|
|
21
|
+
// If submitter is stopped (e.g., user consent declined or unknown, or app state offline), we don't send the data.
|
|
22
|
+
// Data will be sent when submitter is resumed.
|
|
23
|
+
});
|
|
24
|
+
return syncTask;
|
|
25
|
+
}
|
|
26
|
+
exports.uniqueKeysSubmitterFactory = uniqueKeysSubmitterFactory;
|
|
@@ -3,7 +3,6 @@ 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");
|
|
7
6
|
var constants_1 = require("../logger/constants");
|
|
8
7
|
var constants_2 = require("../utils/constants");
|
|
9
8
|
/**
|
|
@@ -13,52 +12,34 @@ var constants_2 = require("../utils/constants");
|
|
|
13
12
|
* @param metadata runtime metadata (ip, hostname and version)
|
|
14
13
|
* @param impressionListener optional impression listener
|
|
15
14
|
* @param integrationsManager optional integrations manager
|
|
16
|
-
* @param
|
|
17
|
-
* @param countsCache optional cache to save impressions count. If provided, impressions will be deduped (OPTIMIZED mode)
|
|
15
|
+
* @param strategy strategy for impressions tracking.
|
|
18
16
|
*/
|
|
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) {
|
|
17
|
+
function impressionsTrackerFactory(settings, impressionsCache, strategy, integrationsManager, telemetryCache) {
|
|
24
18
|
var log = settings.log, impressionListener = settings.impressionListener, _a = settings.runtime, ip = _a.ip, hostname = _a.hostname, version = settings.version;
|
|
25
19
|
return {
|
|
26
20
|
track: function (impressions, attributes) {
|
|
27
21
|
if (settings.userConsent === constants_2.CONSENT_DECLINED)
|
|
28
22
|
return;
|
|
29
23
|
var impressionsCount = impressions.length;
|
|
30
|
-
var
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
24
|
+
var _a = strategy.process(impressions), impressionsToStore = _a.impressionsToStore, impressionsToListener = _a.impressionsToListener, deduped = _a.deduped;
|
|
25
|
+
var impressionsToListenerCount = impressionsToListener.length;
|
|
26
|
+
if (impressionsToStore.length > 0) {
|
|
27
|
+
var res = impressionsCache.track(impressionsToStore);
|
|
28
|
+
// If we're on an async storage, handle error and log it.
|
|
29
|
+
if ((0, thenable_1.thenable)(res)) {
|
|
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
|
+
});
|
|
36
35
|
}
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
//
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
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);
|
|
36
|
+
else {
|
|
37
|
+
// Record when impressionsCache is sync only (standalone mode)
|
|
38
|
+
// @TODO we are not dropping impressions on full queue yet, so DROPPED stats are not recorded
|
|
39
|
+
if (telemetryCache) {
|
|
40
|
+
telemetryCache.recordImpressionStats(constants_2.QUEUED, impressionsToStore.length);
|
|
41
|
+
telemetryCache.recordImpressionStats(constants_2.DEDUPED, deduped);
|
|
42
|
+
}
|
|
62
43
|
}
|
|
63
44
|
}
|
|
64
45
|
// @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
|
|
@@ -66,7 +47,7 @@ countsCache, telemetryCache) {
|
|
|
66
47
|
var _loop_1 = function (i) {
|
|
67
48
|
var impressionData = {
|
|
68
49
|
// copy of impression, to avoid unexpected behaviour if modified by integrations or impressionListener
|
|
69
|
-
impression: (0, objectAssign_1.objectAssign)({},
|
|
50
|
+
impression: (0, objectAssign_1.objectAssign)({}, impressionsToListener[i]),
|
|
70
51
|
attributes: attributes,
|
|
71
52
|
ip: ip,
|
|
72
53
|
hostname: hostname,
|
|
@@ -86,7 +67,7 @@ countsCache, telemetryCache) {
|
|
|
86
67
|
}
|
|
87
68
|
}, 0);
|
|
88
69
|
};
|
|
89
|
-
for (var i = 0; i <
|
|
70
|
+
for (var i = 0; i < impressionsToListenerCount; i++) {
|
|
90
71
|
_loop_1(i);
|
|
91
72
|
}
|
|
92
73
|
}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.strategyDebugFactory = void 0;
|
|
4
|
+
/**
|
|
5
|
+
* Debug strategy for impressions tracker. Wraps impressions to store and adds previousTime if it corresponds
|
|
6
|
+
*
|
|
7
|
+
* @param impressionsObserver impression observer. Previous time (pt property) is included in impression instances
|
|
8
|
+
* @returns IStrategyResult
|
|
9
|
+
*/
|
|
10
|
+
function strategyDebugFactory(impressionsObserver) {
|
|
11
|
+
return {
|
|
12
|
+
process: function (impressions) {
|
|
13
|
+
impressions.forEach(function (impression) {
|
|
14
|
+
// Adds previous time if it is enabled
|
|
15
|
+
impression.pt = impressionsObserver.testAndSet(impression);
|
|
16
|
+
});
|
|
17
|
+
return {
|
|
18
|
+
impressionsToStore: impressions,
|
|
19
|
+
impressionsToListener: impressions,
|
|
20
|
+
deduped: 0
|
|
21
|
+
};
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
}
|
|
25
|
+
exports.strategyDebugFactory = strategyDebugFactory;
|