@splitsoftware/splitio 10.17.2 → 10.17.3-rc.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/factory/clientSide.js +45 -0
- package/es/factory/commons.js +16 -0
- package/es/factory/package.json +4 -0
- package/es/factory/serverSide.js +42 -0
- package/es/index.js +1 -132
- package/es/platform/browser.js +11 -0
- package/es/{services → platform}/getEventSource/browser.js +1 -1
- package/es/{services → platform}/getEventSource/node.js +1 -1
- package/es/{client → platform/getEventSource}/package.json +0 -0
- package/es/{services → platform}/getFetch/browser.js +1 -1
- package/es/{services → platform}/getFetch/node.js +1 -1
- package/es/{impressions/observer → platform/getFetch}/package.json +0 -0
- package/es/platform/node.js +13 -0
- package/es/{integrations → platform}/package.json +0 -0
- package/es/{services → platform}/request/options/node.js +2 -2
- package/es/settings/clientSide.js +18 -0
- package/{lib/utils → es}/settings/defaults/browser.js +6 -8
- package/{src/utils → es}/settings/defaults/node.js +6 -3
- package/es/settings/defaults/version.js +1 -0
- package/es/settings/integrations/browser.js +5 -0
- package/es/settings/integrations/node.js +5 -0
- package/es/settings/package.json +4 -0
- package/es/{utils/settings → settings}/runtime/node.js +6 -4
- package/es/settings/serverSide.js +20 -0
- package/es/{utils/settings → settings}/storage/browser.js +12 -14
- package/es/{utils/settings → settings}/storage/node.js +10 -9
- package/es/umd.js +2 -1
- package/lib/factory/clientSide.js +65 -0
- package/lib/factory/commons.js +23 -0
- package/lib/factory/package.json +4 -0
- package/lib/factory/serverSide.js +60 -0
- package/lib/index.js +3 -151
- package/lib/platform/browser.js +24 -0
- package/lib/{services → platform}/getEventSource/browser.js +1 -1
- package/lib/{services → platform}/getEventSource/node.js +1 -1
- package/{es/listeners → lib/platform/getEventSource}/package.json +0 -0
- package/lib/{services → platform}/getFetch/browser.js +1 -1
- package/lib/{services → platform}/getFetch/node.js +1 -1
- package/{es/producer/offline → lib/platform/getFetch}/package.json +0 -0
- package/lib/platform/node.js +27 -0
- package/{es/producer → lib/platform}/package.json +0 -0
- package/lib/{services → platform}/request/options/node.js +2 -2
- package/lib/settings/clientSide.js +30 -0
- package/{src/utils → lib}/settings/defaults/browser.js +13 -3
- package/{es/utils → lib}/settings/defaults/node.js +13 -3
- package/lib/settings/defaults/version.js +6 -0
- package/lib/settings/integrations/browser.js +14 -0
- package/lib/settings/integrations/node.js +12 -0
- package/lib/settings/package.json +4 -0
- package/lib/{utils/settings → settings}/runtime/node.js +7 -5
- package/lib/settings/serverSide.js +33 -0
- package/lib/{utils/settings → settings}/storage/browser.js +15 -20
- package/lib/{utils/settings → settings}/storage/node.js +13 -11
- package/lib/umd.js +1 -0
- package/package.json +15 -12
- package/src/.DS_Store +0 -0
- package/src/factory/clientSide.js +58 -0
- package/src/factory/commons.js +16 -0
- package/src/factory/package.json +4 -0
- package/src/factory/serverSide.js +51 -0
- package/src/index.js +1 -140
- package/src/{sync/SSEHandler → platform}/.DS_Store +0 -0
- package/src/platform/browser.js +13 -0
- package/src/{services → platform}/getEventSource/browser.js +2 -2
- package/src/{services → platform}/getEventSource/node.js +2 -2
- package/{es/services → src/platform}/getEventSource/package.json +0 -0
- package/src/{services → platform}/getFetch/browser.js +2 -2
- package/src/{services → platform}/getFetch/node.js +1 -1
- package/{es/services → src/platform}/getFetch/package.json +0 -0
- package/src/platform/node.js +15 -0
- package/{es/services/request/options → src/platform}/package.json +0 -0
- package/src/{services → platform}/request/options/node.js +2 -2
- package/src/{listeners → settings}/.DS_Store +0 -0
- package/src/settings/clientSide.js +18 -0
- package/{es/utils → src}/settings/defaults/browser.js +8 -3
- package/{lib/utils → src}/settings/defaults/node.js +6 -6
- package/src/settings/defaults/version.js +1 -0
- package/src/settings/integrations/browser.js +6 -0
- package/src/{utils/settings → settings}/integrations/node.js +1 -3
- package/src/settings/package.json +4 -0
- package/src/{utils/settings → settings}/runtime/node.js +9 -6
- package/src/settings/serverSide.js +20 -0
- package/src/{utils/settings → settings}/storage/browser.js +10 -16
- package/src/{utils/settings → settings}/storage/node.js +7 -7
- package/src/umd.js +1 -0
- package/es/client/attributesDecoration.js +0 -116
- package/es/client/browser.js +0 -39
- package/es/client/client.js +0 -155
- package/es/client/inputValidation.js +0 -117
- package/es/client/node.js +0 -6
- package/es/engine/combiners/and.js +0 -54
- package/es/engine/combiners/ifelseif.js +0 -73
- package/es/engine/condition/index.js +0 -62
- package/es/engine/convertions/index.js +0 -29
- package/es/engine/engine/index.js +0 -60
- package/es/engine/engine/legacy.js +0 -77
- package/es/engine/engine/murmur3/common.js +0 -40
- package/es/engine/engine/murmur3/murmur3.js +0 -83
- package/es/engine/engine/murmur3/murmur3_128.js +0 -250
- package/es/engine/engine/murmur3/murmur3_128_x86.js +0 -183
- package/es/engine/engine/murmur3/murmur3_64.js +0 -52
- package/es/engine/engine/murmur3/utfx.js +0 -112
- package/es/engine/evaluator/index.js +0 -111
- package/es/engine/index.js +0 -112
- package/es/engine/matchers/all.js +0 -32
- package/es/engine/matchers/between.js +0 -35
- package/es/engine/matchers/boolean.js +0 -35
- package/es/engine/matchers/cont_all.js +0 -51
- package/es/engine/matchers/cont_any.js +0 -47
- package/es/engine/matchers/cont_str.js +0 -38
- package/es/engine/matchers/dependency.js +0 -50
- package/es/engine/matchers/eq.js +0 -35
- package/es/engine/matchers/eq_set.js +0 -49
- package/es/engine/matchers/ew.js +0 -38
- package/es/engine/matchers/gte.js +0 -35
- package/es/engine/matchers/index.js +0 -65
- package/es/engine/matchers/lte.js +0 -35
- package/es/engine/matchers/part_of.js +0 -49
- package/es/engine/matchers/segment.js +0 -39
- package/es/engine/matchers/string.js +0 -44
- package/es/engine/matchers/sw.js +0 -38
- package/es/engine/matchers/types.js +0 -48
- package/es/engine/matchers/whitelist.js +0 -36
- package/es/engine/parser/index.js +0 -69
- package/es/engine/parser/segments.js +0 -22
- package/es/engine/transforms/matcherGroup.js +0 -43
- package/es/engine/transforms/matchers.js +0 -109
- package/es/engine/transforms/segment.js +0 -28
- package/es/engine/transforms/set.js +0 -20
- package/es/engine/transforms/unaryNumeric.js +0 -20
- package/es/engine/transforms/whitelist.js +0 -22
- package/es/engine/treatments/index.js +0 -67
- package/es/engine/value/index.js +0 -54
- package/es/engine/value/sanitize.js +0 -125
- package/es/events/index.js +0 -65
- package/es/factory/offline.js +0 -50
- package/es/factory/online.js +0 -113
- package/es/impressions/counter.js +0 -52
- package/es/impressions/hasher/buildKey.js +0 -3
- package/es/impressions/hasher/hashImpression128.js +0 -5
- package/es/impressions/hasher/hashImpression32.js +0 -5
- package/es/impressions/observer/browser.js +0 -9
- package/es/impressions/observer/node.js +0 -9
- package/es/impressions/observer/observer.js +0 -21
- package/es/integrations/browser.js +0 -62
- package/es/integrations/ga/GaToSplit.js +0 -246
- package/es/integrations/ga/SplitToGa.js +0 -127
- package/es/integrations/node.js +0 -3
- package/es/listeners/browser.js +0 -157
- package/es/listeners/node.js +0 -65
- package/es/manager/index.js +0 -104
- package/es/metrics/Collectors.js +0 -100
- package/es/metrics/index.js +0 -157
- package/es/producer/browser/Partial.js +0 -103
- package/es/producer/browser.js +0 -70
- package/es/producer/fetcher/MySegments.js +0 -47
- package/es/producer/fetcher/SegmentChanges.js +0 -52
- package/es/producer/fetcher/SplitChanges.js +0 -46
- package/es/producer/node.js +0 -130
- package/es/producer/offline/browser.js +0 -26
- package/es/producer/offline/node.js +0 -26
- package/es/producer/task.js +0 -50
- package/es/producer/updater/MySegments.js +0 -108
- package/es/producer/updater/SegmentChanges.js +0 -135
- package/es/producer/updater/SplitChanges.js +0 -131
- package/es/producer/updater/SplitChangesFromFeatures.js +0 -21
- package/es/producer/updater/SplitChangesFromFileSystem.js +0 -21
- package/es/producer/updater/SplitChangesFromObject.js +0 -73
- package/es/readiness/index.js +0 -123
- package/es/readiness/statusManager.js +0 -114
- package/es/services/auth/auth.js +0 -25
- package/es/services/auth/index.js +0 -2
- package/es/services/events/bulk.js +0 -22
- package/es/services/events/index.js +0 -17
- package/es/services/impressions/bulk.js +0 -26
- package/es/services/impressions/count.js +0 -7
- package/es/services/impressions/dto.js +0 -73
- package/es/services/impressions/index.js +0 -17
- package/es/services/impressions/post.js +0 -22
- package/es/services/metrics/counters.js +0 -24
- package/es/services/metrics/dto.js +0 -38
- package/es/services/metrics/index.js +0 -17
- package/es/services/metrics/times.js +0 -24
- package/es/services/mySegments/get.js +0 -26
- package/es/services/mySegments/index.js +0 -17
- package/es/services/request/index.js +0 -43
- package/es/services/request/options/browser.js +0 -18
- package/es/services/segmentChanges/get.js +0 -21
- package/es/services/segmentChanges/index.js +0 -17
- package/es/services/splitChanges/get.js +0 -19
- package/es/services/splitChanges/index.js +0 -17
- package/es/services/splitChanges/offline/browser.js +0 -63
- package/es/services/splitChanges/offline/node.js +0 -176
- package/es/services/splitChanges/offline/package.json +0 -4
- package/es/services/splitChanges/offline/parseCondition.js +0 -43
- package/es/services/transport/index.js +0 -51
- package/es/storage/AttributesCache/InMemory.js +0 -85
- package/es/storage/BaseMetricsAsyncCache.js +0 -23
- package/es/storage/CountCache/InMemory.js +0 -48
- package/es/storage/CountCache/InRedis.js +0 -42
- package/es/storage/EventsCache/InMemory.js +0 -109
- package/es/storage/EventsCache/InRedis.js +0 -65
- package/es/storage/ImpressionsCache/InMemory.js +0 -71
- package/es/storage/ImpressionsCache/InRedis.js +0 -73
- package/es/storage/Keys.js +0 -125
- package/es/storage/KeysLocalStorage.js +0 -47
- package/es/storage/LatencyCache/InMemory.js +0 -56
- package/es/storage/LatencyCache/InRedis.js +0 -44
- package/es/storage/LatencyCache/findIndex.js +0 -2
- package/es/storage/Meta.js +0 -7
- package/es/storage/RedisAdapter.js +0 -198
- package/es/storage/SegmentCache/InLocalStorage/index.js +0 -138
- package/es/storage/SegmentCache/InMemory/browser.js +0 -107
- package/es/storage/SegmentCache/InMemory/node.js +0 -82
- package/es/storage/SegmentCache/InMemory/package.json +0 -4
- package/es/storage/SegmentCache/InRedis/index.js +0 -81
- package/es/storage/SplitCache/InLocalStorage.js +0 -332
- package/es/storage/SplitCache/InMemory.js +0 -162
- package/es/storage/SplitCache/InRedis.js +0 -214
- package/es/storage/SplitCache/killLocally.js +0 -35
- package/es/storage/browser.js +0 -101
- package/es/storage/node.js +0 -81
- package/es/storage/package.json +0 -4
- package/es/sync/AuthClient/index.js +0 -34
- package/es/sync/PushManager/index.js +0 -315
- package/es/sync/PushManager/mySegmentsV2utils.js +0 -76
- package/es/sync/PushManager/pushRequirements/browser.js +0 -23
- package/es/sync/PushManager/pushRequirements/node.js +0 -18
- package/es/sync/PushManager/pushRequirements/package.json +0 -4
- package/es/sync/SSEClient/index.js +0 -93
- package/es/sync/SSEHandler/NotificationKeeper.js +0 -97
- package/es/sync/SSEHandler/NotificationParser.js +0 -31
- package/es/sync/SSEHandler/index.js +0 -110
- package/es/sync/SegmentUpdateWorker/browser.js +0 -74
- package/es/sync/SegmentUpdateWorker/node.js +0 -79
- package/es/sync/SegmentUpdateWorker/package.json +0 -4
- package/es/sync/SplitUpdateWorker/index.js +0 -86
- package/es/sync/browser.js +0 -125
- package/es/sync/constants.js +0 -42
- package/es/sync/node.js +0 -60
- package/es/sync/package.json +0 -4
- package/es/trackers/event.js +0 -53
- package/es/trackers/impressions.js +0 -132
- package/es/utils/backoff/index.js +0 -51
- package/es/utils/base64/browser.js +0 -19
- package/es/utils/base64/node.js +0 -19
- package/es/utils/base64/package.json +0 -4
- package/es/utils/binarySearch/index.js +0 -50
- package/es/utils/constants/index.js +0 -38
- package/es/utils/context/constants.js +0 -30
- package/es/utils/context/index.js +0 -101
- package/es/utils/decompress/index.js +0 -476
- package/es/utils/fn/repeat.js +0 -58
- package/es/utils/inputValidation/apiKey.js +0 -39
- package/es/utils/inputValidation/attribute.js +0 -22
- package/es/utils/inputValidation/attributes.js +0 -19
- package/es/utils/inputValidation/event.js +0 -23
- package/es/utils/inputValidation/eventProperties.js +0 -69
- package/es/utils/inputValidation/eventValue.js +0 -9
- package/es/utils/inputValidation/index.js +0 -11
- package/es/utils/inputValidation/isOperational.js +0 -14
- package/es/utils/inputValidation/key.js +0 -50
- package/es/utils/inputValidation/split.js +0 -47
- package/es/utils/inputValidation/splitFilters.js +0 -121
- package/es/utils/inputValidation/splits.js +0 -27
- package/es/utils/inputValidation/trafficType.js +0 -55
- package/es/utils/jwt/hashUserKey.js +0 -11
- package/es/utils/jwt/index.js +0 -14
- package/es/utils/key/factory.js +0 -38
- package/es/utils/key/parser.js +0 -34
- package/es/utils/labels/index.js +0 -7
- package/es/utils/lang/Errors.js +0 -41
- package/es/utils/lang/Sets.js +0 -114
- package/es/utils/lang/index.js +0 -305
- package/es/utils/localstorage/isAvailable.js +0 -26
- package/es/utils/logger/LoggerFactory.js +0 -86
- package/es/utils/logger/index.js +0 -97
- package/es/utils/lrucache/linkedlist.js +0 -122
- package/es/utils/lrucache/lru.spec.js +0 -24
- package/es/utils/lrucache/lrucache.js +0 -80
- package/es/utils/now/browser.js +0 -27
- package/es/utils/now/node.js +0 -19
- package/es/utils/now/package.json +0 -4
- package/es/utils/promise/thenable.js +0 -3
- package/es/utils/promise/timeout.js +0 -34
- package/es/utils/promise/wrapper.js +0 -58
- package/es/utils/settings/defaults/package.json +0 -4
- package/es/utils/settings/impressionsMode.js +0 -16
- package/es/utils/settings/index.js +0 -194
- package/es/utils/settings/integrations/browser.js +0 -8
- package/es/utils/settings/integrations/common.js +0 -30
- package/es/utils/settings/integrations/node.js +0 -7
- package/es/utils/settings/integrations/package.json +0 -4
- package/es/utils/settings/language/browser.js +0 -16
- package/es/utils/settings/language/node.js +0 -16
- package/es/utils/settings/language/package.json +0 -4
- package/es/utils/settings/mode.js +0 -10
- package/es/utils/settings/runtime/browser.js +0 -21
- package/es/utils/settings/runtime/package.json +0 -4
- package/es/utils/settings/storage/package.json +0 -4
- package/es/utils/splits/usesSegments.js +0 -21
- package/es/utils/time/index.js +0 -8
- package/es/utils/timeTracker/index.js +0 -216
- package/es/utils/timeTracker/timer.js +0 -25
- package/lib/client/attributesDecoration.js +0 -128
- package/lib/client/browser.js +0 -50
- package/lib/client/client.js +0 -174
- package/lib/client/inputValidation.js +0 -129
- package/lib/client/node.js +0 -14
- package/lib/client/package.json +0 -4
- package/lib/engine/combiners/and.js +0 -65
- package/lib/engine/combiners/ifelseif.js +0 -88
- package/lib/engine/condition/index.js +0 -76
- package/lib/engine/convertions/index.js +0 -36
- package/lib/engine/engine/index.js +0 -71
- package/lib/engine/engine/legacy.js +0 -83
- package/lib/engine/engine/murmur3/common.js +0 -52
- package/lib/engine/engine/murmur3/murmur3.js +0 -90
- package/lib/engine/engine/murmur3/murmur3_128.js +0 -256
- package/lib/engine/engine/murmur3/murmur3_128_x86.js +0 -189
- package/lib/engine/engine/murmur3/murmur3_64.js +0 -57
- package/lib/engine/engine/murmur3/utfx.js +0 -121
- package/lib/engine/evaluator/index.js +0 -129
- package/lib/engine/index.js +0 -128
- package/lib/engine/matchers/all.js +0 -41
- package/lib/engine/matchers/between.js +0 -44
- package/lib/engine/matchers/boolean.js +0 -44
- package/lib/engine/matchers/cont_all.js +0 -61
- package/lib/engine/matchers/cont_any.js +0 -57
- package/lib/engine/matchers/cont_str.js +0 -48
- package/lib/engine/matchers/dependency.js +0 -60
- package/lib/engine/matchers/eq.js +0 -44
- package/lib/engine/matchers/eq_set.js +0 -59
- package/lib/engine/matchers/ew.js +0 -48
- package/lib/engine/matchers/gte.js +0 -44
- package/lib/engine/matchers/index.js +0 -90
- package/lib/engine/matchers/lte.js +0 -44
- package/lib/engine/matchers/part_of.js +0 -59
- package/lib/engine/matchers/segment.js +0 -49
- package/lib/engine/matchers/string.js +0 -53
- package/lib/engine/matchers/sw.js +0 -48
- package/lib/engine/matchers/types.js +0 -57
- package/lib/engine/matchers/whitelist.js +0 -46
- package/lib/engine/parser/index.js +0 -84
- package/lib/engine/parser/segments.js +0 -28
- package/lib/engine/transforms/matcherGroup.js +0 -54
- package/lib/engine/transforms/matchers.js +0 -124
- package/lib/engine/transforms/segment.js +0 -34
- package/lib/engine/transforms/set.js +0 -26
- package/lib/engine/transforms/unaryNumeric.js +0 -26
- package/lib/engine/transforms/whitelist.js +0 -28
- package/lib/engine/treatments/index.js +0 -73
- package/lib/engine/value/index.js +0 -64
- package/lib/engine/value/sanitize.js +0 -137
- package/lib/events/index.js +0 -80
- package/lib/factory/offline.js +0 -62
- package/lib/factory/online.js +0 -129
- package/lib/impressions/counter.js +0 -61
- package/lib/impressions/hasher/buildKey.js +0 -8
- package/lib/impressions/hasher/hashImpression128.js +0 -12
- package/lib/impressions/hasher/hashImpression32.js +0 -14
- package/lib/impressions/observer/browser.js +0 -19
- package/lib/impressions/observer/node.js +0 -19
- package/lib/impressions/observer/observer.js +0 -29
- package/lib/impressions/observer/package.json +0 -4
- package/lib/integrations/browser.js +0 -72
- package/lib/integrations/ga/GaToSplit.js +0 -267
- package/lib/integrations/ga/SplitToGa.js +0 -138
- package/lib/integrations/node.js +0 -9
- package/lib/integrations/package.json +0 -4
- package/lib/listeners/browser.js +0 -173
- package/lib/listeners/node.js +0 -74
- package/lib/listeners/package.json +0 -4
- package/lib/manager/index.js +0 -115
- package/lib/metrics/Collectors.js +0 -118
- package/lib/metrics/index.js +0 -182
- package/lib/producer/browser/Partial.js +0 -114
- package/lib/producer/browser.js +0 -82
- package/lib/producer/fetcher/MySegments.js +0 -59
- package/lib/producer/fetcher/SegmentChanges.js +0 -62
- package/lib/producer/fetcher/SplitChanges.js +0 -58
- package/lib/producer/node.js +0 -142
- package/lib/producer/offline/browser.js +0 -35
- package/lib/producer/offline/node.js +0 -35
- package/lib/producer/offline/package.json +0 -4
- package/lib/producer/package.json +0 -4
- package/lib/producer/task.js +0 -61
- package/lib/producer/updater/MySegments.js +0 -119
- package/lib/producer/updater/SegmentChanges.js +0 -148
- package/lib/producer/updater/SplitChanges.js +0 -145
- package/lib/producer/updater/SplitChangesFromFeatures.js +0 -30
- package/lib/producer/updater/SplitChangesFromFileSystem.js +0 -30
- package/lib/producer/updater/SplitChangesFromObject.js +0 -84
- package/lib/readiness/index.js +0 -132
- package/lib/readiness/statusManager.js +0 -124
- package/lib/services/auth/auth.js +0 -32
- package/lib/services/auth/index.js +0 -11
- package/lib/services/events/bulk.js +0 -31
- package/lib/services/events/index.js +0 -26
- package/lib/services/getEventSource/package.json +0 -4
- package/lib/services/getFetch/package.json +0 -4
- package/lib/services/impressions/bulk.js +0 -36
- package/lib/services/impressions/count.js +0 -16
- package/lib/services/impressions/dto.js +0 -81
- package/lib/services/impressions/index.js +0 -26
- package/lib/services/impressions/post.js +0 -31
- package/lib/services/metrics/counters.js +0 -33
- package/lib/services/metrics/dto.js +0 -46
- package/lib/services/metrics/index.js +0 -26
- package/lib/services/metrics/times.js +0 -33
- package/lib/services/mySegments/get.js +0 -35
- package/lib/services/mySegments/index.js +0 -26
- package/lib/services/request/index.js +0 -53
- package/lib/services/request/options/browser.js +0 -23
- package/lib/services/request/options/package.json +0 -4
- package/lib/services/segmentChanges/get.js +0 -29
- package/lib/services/segmentChanges/index.js +0 -26
- package/lib/services/splitChanges/get.js +0 -27
- package/lib/services/splitChanges/index.js +0 -26
- package/lib/services/splitChanges/offline/browser.js +0 -71
- package/lib/services/splitChanges/offline/node.js +0 -189
- package/lib/services/splitChanges/offline/package.json +0 -4
- package/lib/services/splitChanges/offline/parseCondition.js +0 -49
- package/lib/services/transport/index.js +0 -62
- package/lib/storage/AttributesCache/InMemory.js +0 -93
- package/lib/storage/BaseMetricsAsyncCache.js +0 -28
- package/lib/storage/CountCache/InMemory.js +0 -54
- package/lib/storage/CountCache/InRedis.js +0 -50
- package/lib/storage/EventsCache/InMemory.js +0 -118
- package/lib/storage/EventsCache/InRedis.js +0 -74
- package/lib/storage/ImpressionsCache/InMemory.js +0 -77
- package/lib/storage/ImpressionsCache/InRedis.js +0 -79
- package/lib/storage/Keys.js +0 -132
- package/lib/storage/KeysLocalStorage.js +0 -58
- package/lib/storage/LatencyCache/InMemory.js +0 -64
- package/lib/storage/LatencyCache/InRedis.js +0 -53
- package/lib/storage/LatencyCache/findIndex.js +0 -12
- package/lib/storage/Meta.js +0 -12
- package/lib/storage/RedisAdapter.js +0 -212
- package/lib/storage/SegmentCache/InLocalStorage/index.js +0 -147
- package/lib/storage/SegmentCache/InMemory/browser.js +0 -113
- package/lib/storage/SegmentCache/InMemory/node.js +0 -89
- package/lib/storage/SegmentCache/InMemory/package.json +0 -4
- package/lib/storage/SegmentCache/InRedis/index.js +0 -87
- package/lib/storage/SplitCache/InLocalStorage.js +0 -344
- package/lib/storage/SplitCache/InMemory.js +0 -172
- package/lib/storage/SplitCache/InRedis.js +0 -224
- package/lib/storage/SplitCache/killLocally.js +0 -42
- package/lib/storage/browser.js +0 -122
- package/lib/storage/node.js +0 -104
- package/lib/storage/package.json +0 -4
- package/lib/sync/AuthClient/index.js +0 -44
- package/lib/sync/PushManager/index.js +0 -340
- package/lib/sync/PushManager/mySegmentsV2utils.js +0 -87
- package/lib/sync/PushManager/pushRequirements/browser.js +0 -30
- package/lib/sync/PushManager/pushRequirements/node.js +0 -25
- package/lib/sync/PushManager/pushRequirements/package.json +0 -4
- package/lib/sync/SSEClient/index.js +0 -101
- package/lib/sync/SSEHandler/NotificationKeeper.js +0 -104
- package/lib/sync/SSEHandler/NotificationParser.js +0 -39
- package/lib/sync/SSEHandler/index.js +0 -121
- package/lib/sync/SegmentUpdateWorker/browser.js +0 -81
- package/lib/sync/SegmentUpdateWorker/node.js +0 -86
- package/lib/sync/SegmentUpdateWorker/package.json +0 -4
- package/lib/sync/SplitUpdateWorker/index.js +0 -93
- package/lib/sync/browser.js +0 -139
- package/lib/sync/constants.js +0 -59
- package/lib/sync/node.js +0 -71
- package/lib/sync/package.json +0 -4
- package/lib/trackers/event.js +0 -64
- package/lib/trackers/impressions.js +0 -146
- package/lib/utils/backoff/index.js +0 -57
- package/lib/utils/base64/browser.js +0 -26
- package/lib/utils/base64/node.js +0 -26
- package/lib/utils/base64/package.json +0 -4
- package/lib/utils/binarySearch/index.js +0 -56
- package/lib/utils/constants/index.js +0 -60
- package/lib/utils/context/constants.js +0 -49
- package/lib/utils/context/index.js +0 -111
- package/lib/utils/decompress/index.js +0 -483
- package/lib/utils/fn/repeat.js +0 -64
- package/lib/utils/inputValidation/apiKey.js +0 -51
- package/lib/utils/inputValidation/attribute.js +0 -32
- package/lib/utils/inputValidation/attributes.js +0 -32
- package/lib/utils/inputValidation/event.js +0 -33
- package/lib/utils/inputValidation/eventProperties.js +0 -78
- package/lib/utils/inputValidation/eventValue.js +0 -19
- package/lib/utils/inputValidation/index.js +0 -48
- package/lib/utils/inputValidation/isOperational.js +0 -25
- package/lib/utils/inputValidation/key.js +0 -59
- package/lib/utils/inputValidation/split.js +0 -60
- package/lib/utils/inputValidation/splitFilters.js +0 -134
- package/lib/utils/inputValidation/splits.js +0 -38
- package/lib/utils/inputValidation/trafficType.js +0 -68
- package/lib/utils/jwt/hashUserKey.js +0 -19
- package/lib/utils/jwt/index.js +0 -19
- package/lib/utils/key/factory.js +0 -46
- package/lib/utils/key/parser.js +0 -42
- package/lib/utils/labels/index.js +0 -18
- package/lib/utils/lang/Errors.js +0 -58
- package/lib/utils/lang/Sets.js +0 -127
- package/lib/utils/lang/index.js +0 -350
- package/lib/utils/localstorage/isAvailable.js +0 -31
- package/lib/utils/logger/LoggerFactory.js +0 -98
- package/lib/utils/logger/index.js +0 -109
- package/lib/utils/lrucache/linkedlist.js +0 -132
- package/lib/utils/lrucache/lru.spec.js +0 -30
- package/lib/utils/lrucache/lrucache.js +0 -88
- package/lib/utils/now/browser.js +0 -33
- package/lib/utils/now/node.js +0 -24
- package/lib/utils/now/package.json +0 -4
- package/lib/utils/promise/thenable.js +0 -10
- package/lib/utils/promise/timeout.js +0 -40
- package/lib/utils/promise/wrapper.js +0 -63
- package/lib/utils/settings/defaults/package.json +0 -4
- package/lib/utils/settings/impressionsMode.js +0 -26
- package/lib/utils/settings/index.js +0 -214
- package/lib/utils/settings/integrations/browser.js +0 -17
- package/lib/utils/settings/integrations/common.js +0 -40
- package/lib/utils/settings/integrations/node.js +0 -13
- package/lib/utils/settings/integrations/package.json +0 -4
- package/lib/utils/settings/language/browser.js +0 -22
- package/lib/utils/settings/language/node.js +0 -22
- package/lib/utils/settings/language/package.json +0 -4
- package/lib/utils/settings/mode.js +0 -16
- package/lib/utils/settings/runtime/browser.js +0 -26
- package/lib/utils/settings/runtime/package.json +0 -4
- package/lib/utils/settings/storage/package.json +0 -4
- package/lib/utils/splits/usesSegments.js +0 -27
- package/lib/utils/time/index.js +0 -12
- package/lib/utils/timeTracker/index.js +0 -213
- package/lib/utils/timeTracker/timer.js +0 -33
- package/src/client/attributesDecoration.js +0 -112
- package/src/client/browser.js +0 -41
- package/src/client/client.js +0 -131
- package/src/client/inputValidation.js +0 -130
- package/src/client/node.js +0 -8
- package/src/client/package.json +0 -4
- package/src/engine/combiners/and.js +0 -55
- package/src/engine/combiners/ifelseif.js +0 -74
- package/src/engine/condition/index.js +0 -65
- package/src/engine/convertions/index.js +0 -22
- package/src/engine/engine/index.js +0 -63
- package/src/engine/engine/legacy.js +0 -66
- package/src/engine/engine/murmur3/common.js +0 -54
- package/src/engine/engine/murmur3/murmur3.js +0 -79
- package/src/engine/engine/murmur3/murmur3_128.js +0 -273
- package/src/engine/engine/murmur3/murmur3_128_x86.js +0 -188
- package/src/engine/engine/murmur3/murmur3_64.js +0 -34
- package/src/engine/engine/murmur3/utfx.js +0 -111
- package/src/engine/evaluator/index.js +0 -148
- package/src/engine/index.js +0 -123
- package/src/engine/matchers/all.js +0 -29
- package/src/engine/matchers/between.js +0 -30
- package/src/engine/matchers/boolean.js +0 -29
- package/src/engine/matchers/cont_all.js +0 -40
- package/src/engine/matchers/cont_any.js +0 -35
- package/src/engine/matchers/cont_str.js +0 -31
- package/src/engine/matchers/dependency.js +0 -52
- package/src/engine/matchers/eq.js +0 -30
- package/src/engine/matchers/eq_set.js +0 -37
- package/src/engine/matchers/ew.js +0 -31
- package/src/engine/matchers/gte.js +0 -30
- package/src/engine/matchers/index.js +0 -71
- package/src/engine/matchers/lte.js +0 -30
- package/src/engine/matchers/part_of.js +0 -37
- package/src/engine/matchers/segment.js +0 -41
- package/src/engine/matchers/string.js +0 -39
- package/src/engine/matchers/sw.js +0 -31
- package/src/engine/matchers/types.js +0 -52
- package/src/engine/matchers/whitelist.js +0 -30
- package/src/engine/parser/index.js +0 -79
- package/src/engine/parser/segments.js +0 -31
- package/src/engine/transforms/matcherGroup.js +0 -45
- package/src/engine/transforms/matchers.js +0 -118
- package/src/engine/transforms/segment.js +0 -23
- package/src/engine/transforms/set.js +0 -20
- package/src/engine/transforms/unaryNumeric.js +0 -20
- package/src/engine/transforms/whitelist.js +0 -22
- package/src/engine/treatments/index.js +0 -67
- package/src/engine/value/index.js +0 -53
- package/src/engine/value/sanitize.js +0 -117
- package/src/events/index.js +0 -62
- package/src/factory/offline.js +0 -60
- package/src/factory/online.js +0 -127
- package/src/impressions/counter.js +0 -43
- package/src/impressions/hasher/buildKey.js +0 -3
- package/src/impressions/hasher/hashImpression128.js +0 -6
- package/src/impressions/hasher/hashImpression32.js +0 -6
- package/src/impressions/observer/browser.js +0 -8
- package/src/impressions/observer/node.js +0 -8
- package/src/impressions/observer/observer.js +0 -17
- package/src/impressions/observer/package.json +0 -4
- package/src/integrations/browser.js +0 -57
- package/src/integrations/ga/GaToSplit.js +0 -278
- package/src/integrations/ga/SplitToGa.js +0 -125
- package/src/integrations/node.js +0 -4
- package/src/integrations/package.json +0 -4
- package/src/listeners/browser.js +0 -137
- package/src/listeners/node.js +0 -59
- package/src/listeners/package.json +0 -4
- package/src/manager/index.js +0 -103
- package/src/metrics/Collectors.js +0 -77
- package/src/metrics/index.js +0 -174
- package/src/producer/browser/Partial.js +0 -104
- package/src/producer/browser.js +0 -82
- package/src/producer/fetcher/MySegments.js +0 -40
- package/src/producer/fetcher/SegmentChanges.js +0 -52
- package/src/producer/fetcher/SplitChanges.js +0 -39
- package/src/producer/node.js +0 -142
- package/src/producer/offline/browser.js +0 -28
- package/src/producer/offline/node.js +0 -28
- package/src/producer/offline/package.json +0 -4
- package/src/producer/package.json +0 -4
- package/src/producer/task.js +0 -57
- package/src/producer/updater/MySegments.js +0 -104
- package/src/producer/updater/SegmentChanges.js +0 -126
- package/src/producer/updater/SplitChanges.js +0 -138
- package/src/producer/updater/SplitChangesFromFeatures.js +0 -23
- package/src/producer/updater/SplitChangesFromFileSystem.js +0 -23
- package/src/producer/updater/SplitChangesFromObject.js +0 -81
- package/src/readiness/index.js +0 -125
- package/src/readiness/statusManager.js +0 -121
- package/src/services/.DS_Store +0 -0
- package/src/services/auth/auth.js +0 -21
- package/src/services/auth/index.js +0 -3
- package/src/services/events/bulk.js +0 -23
- package/src/services/events/index.js +0 -18
- package/src/services/getEventSource/package.json +0 -4
- package/src/services/getFetch/package.json +0 -4
- package/src/services/impressions/bulk.js +0 -26
- package/src/services/impressions/count.js +0 -8
- package/src/services/impressions/dto.js +0 -71
- package/src/services/impressions/index.js +0 -18
- package/src/services/impressions/post.js +0 -23
- package/src/services/metrics/counters.js +0 -25
- package/src/services/metrics/dto.js +0 -44
- package/src/services/metrics/index.js +0 -18
- package/src/services/metrics/times.js +0 -25
- package/src/services/mySegments/get.js +0 -27
- package/src/services/mySegments/index.js +0 -18
- package/src/services/request/index.js +0 -43
- package/src/services/request/options/browser.js +0 -18
- package/src/services/request/options/package.json +0 -4
- package/src/services/segmentChanges/get.js +0 -20
- package/src/services/segmentChanges/index.js +0 -18
- package/src/services/splitChanges/get.js +0 -20
- package/src/services/splitChanges/index.js +0 -18
- package/src/services/splitChanges/offline/browser.js +0 -66
- package/src/services/splitChanges/offline/node.js +0 -190
- package/src/services/splitChanges/offline/package.json +0 -4
- package/src/services/splitChanges/offline/parseCondition.js +0 -52
- package/src/services/transport/index.js +0 -44
- package/src/storage/AttributesCache/InMemory.js +0 -76
- package/src/storage/BaseMetricsAsyncCache.js +0 -14
- package/src/storage/CountCache/InMemory.js +0 -48
- package/src/storage/CountCache/InRedis.js +0 -32
- package/src/storage/EventsCache/InMemory.js +0 -99
- package/src/storage/EventsCache/InRedis.js +0 -62
- package/src/storage/ImpressionsCache/InMemory.js +0 -62
- package/src/storage/ImpressionsCache/InRedis.js +0 -65
- package/src/storage/Keys.js +0 -122
- package/src/storage/KeysLocalStorage.js +0 -40
- package/src/storage/LatencyCache/InMemory.js +0 -56
- package/src/storage/LatencyCache/InRedis.js +0 -35
- package/src/storage/LatencyCache/findIndex.js +0 -7
- package/src/storage/Meta.js +0 -7
- package/src/storage/RedisAdapter.js +0 -170
- package/src/storage/SegmentCache/InLocalStorage/index.js +0 -120
- package/src/storage/SegmentCache/InMemory/browser.js +0 -99
- package/src/storage/SegmentCache/InMemory/node.js +0 -84
- package/src/storage/SegmentCache/InMemory/package.json +0 -4
- package/src/storage/SegmentCache/InRedis/index.js +0 -71
- package/src/storage/SplitCache/InLocalStorage.js +0 -324
- package/src/storage/SplitCache/InMemory.js +0 -145
- package/src/storage/SplitCache/InRedis.js +0 -187
- package/src/storage/SplitCache/killLocally.js +0 -33
- package/src/storage/browser.js +0 -110
- package/src/storage/node.js +0 -83
- package/src/storage/package.json +0 -4
- package/src/sync/.DS_Store +0 -0
- package/src/sync/AuthClient/index.js +0 -31
- package/src/sync/PushManager/index.js +0 -328
- package/src/sync/PushManager/mySegmentsV2utils.js +0 -76
- package/src/sync/PushManager/pushRequirements/browser.js +0 -20
- package/src/sync/PushManager/pushRequirements/node.js +0 -16
- package/src/sync/PushManager/pushRequirements/package.json +0 -4
- package/src/sync/SSEClient/index.js +0 -92
- package/src/sync/SSEHandler/NotificationKeeper.js +0 -90
- package/src/sync/SSEHandler/NotificationParser.js +0 -35
- package/src/sync/SSEHandler/index.js +0 -110
- package/src/sync/SegmentUpdateWorker/browser.js +0 -67
- package/src/sync/SegmentUpdateWorker/node.js +0 -73
- package/src/sync/SegmentUpdateWorker/package.json +0 -4
- package/src/sync/SplitUpdateWorker/index.js +0 -79
- package/src/sync/browser.js +0 -130
- package/src/sync/constants.js +0 -43
- package/src/sync/node.js +0 -66
- package/src/sync/package.json +0 -4
- package/src/trackers/event.js +0 -47
- package/src/trackers/impressions.js +0 -123
- package/src/utils/backoff/index.js +0 -46
- package/src/utils/base64/browser.js +0 -19
- package/src/utils/base64/node.js +0 -19
- package/src/utils/base64/package.json +0 -4
- package/src/utils/binarySearch/index.js +0 -50
- package/src/utils/constants/index.js +0 -41
- package/src/utils/context/constants.js +0 -18
- package/src/utils/context/index.js +0 -84
- package/src/utils/decompress/index.js +0 -428
- package/src/utils/fn/repeat.js +0 -48
- package/src/utils/inputValidation/apiKey.js +0 -42
- package/src/utils/inputValidation/attribute.js +0 -22
- package/src/utils/inputValidation/attributes.js +0 -26
- package/src/utils/inputValidation/event.js +0 -23
- package/src/utils/inputValidation/eventProperties.js +0 -65
- package/src/utils/inputValidation/eventValue.js +0 -11
- package/src/utils/inputValidation/index.js +0 -11
- package/src/utils/inputValidation/isOperational.js +0 -16
- package/src/utils/inputValidation/key.js +0 -53
- package/src/utils/inputValidation/split.js +0 -42
- package/src/utils/inputValidation/splitFilters.js +0 -108
- package/src/utils/inputValidation/splits.js +0 -21
- package/src/utils/inputValidation/trafficType.js +0 -58
- package/src/utils/jwt/hashUserKey.js +0 -11
- package/src/utils/jwt/index.js +0 -15
- package/src/utils/key/factory.js +0 -34
- package/src/utils/key/parser.js +0 -34
- package/src/utils/labels/index.js +0 -7
- package/src/utils/lang/Errors.js +0 -19
- package/src/utils/lang/Sets.js +0 -94
- package/src/utils/lang/index.js +0 -291
- package/src/utils/localstorage/isAvailable.js +0 -26
- package/src/utils/logger/LoggerFactory.js +0 -90
- package/src/utils/logger/index.js +0 -93
- package/src/utils/lrucache/linkedlist.js +0 -116
- package/src/utils/lrucache/lru.spec.js +0 -26
- package/src/utils/lrucache/lrucache.js +0 -49
- package/src/utils/now/browser.js +0 -29
- package/src/utils/now/node.js +0 -21
- package/src/utils/now/package.json +0 -4
- package/src/utils/promise/thenable.js +0 -1
- package/src/utils/promise/timeout.js +0 -38
- package/src/utils/promise/wrapper.js +0 -60
- package/src/utils/settings/defaults/package.json +0 -4
- package/src/utils/settings/impressionsMode.js +0 -15
- package/src/utils/settings/index.js +0 -217
- package/src/utils/settings/integrations/browser.js +0 -8
- package/src/utils/settings/integrations/common.js +0 -32
- package/src/utils/settings/integrations/package.json +0 -4
- package/src/utils/settings/language/browser.js +0 -17
- package/src/utils/settings/language/node.js +0 -17
- package/src/utils/settings/language/package.json +0 -4
- package/src/utils/settings/mode.js +0 -12
- package/src/utils/settings/runtime/browser.js +0 -22
- package/src/utils/settings/runtime/package.json +0 -4
- package/src/utils/settings/storage/package.json +0 -4
- package/src/utils/splits/usesSegments.js +0 -17
- package/src/utils/time/index.js +0 -8
- package/src/utils/timeTracker/index.js +0 -223
- package/src/utils/timeTracker/timer.js +0 -27
|
@@ -1,120 +0,0 @@
|
|
|
1
|
-
import logFactory from '../../../utils/logger';
|
|
2
|
-
const log = logFactory('splitio-storage:localstorage');
|
|
3
|
-
|
|
4
|
-
const DEFINED = '1';
|
|
5
|
-
|
|
6
|
-
class SegmentCacheInLocalStorage {
|
|
7
|
-
|
|
8
|
-
constructor(keys) {
|
|
9
|
-
this.keys = keys;
|
|
10
|
-
// There is not need to flush segments cache like splits cache, since resetSegments receives the up-to-date list of active segments
|
|
11
|
-
}
|
|
12
|
-
|
|
13
|
-
addToSegment(segmentName/*, segmentKeys: Array<string>*/) {
|
|
14
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
15
|
-
|
|
16
|
-
try {
|
|
17
|
-
localStorage.setItem(segmentKey, DEFINED);
|
|
18
|
-
return true;
|
|
19
|
-
} catch (e) {
|
|
20
|
-
log.error(e);
|
|
21
|
-
return false;
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
removeFromSegment(segmentName/*, segmentKeys: Array<string>*/) {
|
|
26
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
27
|
-
|
|
28
|
-
try {
|
|
29
|
-
localStorage.removeItem(segmentKey);
|
|
30
|
-
return true;
|
|
31
|
-
} catch (e) {
|
|
32
|
-
log.error(e);
|
|
33
|
-
return false;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Reset (update) the cached list of segments with the given list, removing and adding segments if necessary.
|
|
39
|
-
*
|
|
40
|
-
* @param {string[]} segmentNames list of segment names
|
|
41
|
-
* @returns boolean indicating if the cache was updated (i.e., given list was different from the cached one)
|
|
42
|
-
*/
|
|
43
|
-
resetSegments(segmentNames) {
|
|
44
|
-
let isDiff = false;
|
|
45
|
-
let index;
|
|
46
|
-
|
|
47
|
-
// Scan current values from localStorage
|
|
48
|
-
const storedSegmentNames = Object.keys(localStorage).reduce((accum, key) => {
|
|
49
|
-
const segmentName = this.keys.extractSegmentName(key);
|
|
50
|
-
|
|
51
|
-
if (segmentName) accum.push(segmentName);
|
|
52
|
-
|
|
53
|
-
return accum;
|
|
54
|
-
}, []);
|
|
55
|
-
|
|
56
|
-
// Extreme fast => everything is empty
|
|
57
|
-
if (segmentNames.length === 0 && storedSegmentNames.length === segmentNames.length)
|
|
58
|
-
return isDiff;
|
|
59
|
-
|
|
60
|
-
// Quick path
|
|
61
|
-
if (storedSegmentNames.length !== segmentNames.length) {
|
|
62
|
-
isDiff = true;
|
|
63
|
-
|
|
64
|
-
storedSegmentNames.forEach(segmentName => this.removeFromSegment(segmentName));
|
|
65
|
-
segmentNames.forEach(segmentName => this.addToSegment(segmentName));
|
|
66
|
-
} else {
|
|
67
|
-
// Slowest path => we need to find at least 1 difference because
|
|
68
|
-
for(index = 0; index < segmentNames.length && storedSegmentNames.indexOf(segmentNames[index]) !== -1; index++) {
|
|
69
|
-
// TODO: why empty statement?
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
if (index < segmentNames.length) {
|
|
73
|
-
isDiff = true;
|
|
74
|
-
|
|
75
|
-
storedSegmentNames.forEach(segmentName => this.removeFromSegment(segmentName));
|
|
76
|
-
segmentNames.forEach(segmentName => this.addToSegment(segmentName));
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
return isDiff;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
isInSegment(segmentName/*, key: string*/) {
|
|
84
|
-
return localStorage.getItem(this.keys.buildSegmentNameKey(segmentName)) === DEFINED;
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
setChangeNumber(/*segmentName: string, changeNumber: number*/) {
|
|
88
|
-
return true;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
getChangeNumber(/*segmentName: string*/) {
|
|
92
|
-
return -1;
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
registerSegment(/*segment: string*/) {
|
|
96
|
-
return false;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
registerSegments(/*segments: Iterable<string>*/) {
|
|
100
|
-
return false;
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
getRegisteredSegments() {
|
|
104
|
-
return [];
|
|
105
|
-
}
|
|
106
|
-
|
|
107
|
-
/**
|
|
108
|
-
* Removes list of segments from localStorage
|
|
109
|
-
* @NOTE this method is not being used at the moment
|
|
110
|
-
*/
|
|
111
|
-
flush() {
|
|
112
|
-
log.info('Flushing MySegments data from localStorage');
|
|
113
|
-
|
|
114
|
-
// We cannot simply call `localStorage.clear()` since that implies removing user items from the storage
|
|
115
|
-
// We could optimize next sentence, since it implies iterating over all localStorage items
|
|
116
|
-
this.resetSegments([]);
|
|
117
|
-
}
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
export default SegmentCacheInLocalStorage;
|
|
@@ -1,99 +0,0 @@
|
|
|
1
|
-
class SegmentCacheInMemory {
|
|
2
|
-
|
|
3
|
-
constructor(keys) {
|
|
4
|
-
this.keys = keys;
|
|
5
|
-
this.flush();
|
|
6
|
-
}
|
|
7
|
-
|
|
8
|
-
flush() {
|
|
9
|
-
this.segmentCache = {};
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
addToSegment(segmentName/*, segmentKeys: Array<string>*/) {
|
|
13
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
14
|
-
|
|
15
|
-
this.segmentCache[segmentKey] = true;
|
|
16
|
-
|
|
17
|
-
return true;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
removeFromSegment(segmentName/*, segmentKeys: Array<string>*/) {
|
|
21
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
22
|
-
|
|
23
|
-
delete this.segmentCache[segmentKey];
|
|
24
|
-
|
|
25
|
-
return true;
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
/**
|
|
29
|
-
* Reset (update) the cached list of segments with the given list, removing and adding segments if necessary.
|
|
30
|
-
* @NOTE based on the way we use segments in the browser, this way is the best option
|
|
31
|
-
*
|
|
32
|
-
* @param {string[]} segmentNames list of segment names
|
|
33
|
-
* @returns boolean indicating if the cache was updated (i.e., given list was different from the cached one)
|
|
34
|
-
*/
|
|
35
|
-
resetSegments(segmentNames) {
|
|
36
|
-
let isDiff = false;
|
|
37
|
-
let index;
|
|
38
|
-
|
|
39
|
-
const storedSegmentKeys = Object.keys(this.segmentCache);
|
|
40
|
-
|
|
41
|
-
// Extreme fast => everything is empty
|
|
42
|
-
if (segmentNames.length === 0 && storedSegmentKeys.length === segmentNames.length)
|
|
43
|
-
return isDiff;
|
|
44
|
-
|
|
45
|
-
// Quick path
|
|
46
|
-
if (storedSegmentKeys.length !== segmentNames.length) {
|
|
47
|
-
isDiff = true;
|
|
48
|
-
|
|
49
|
-
this.segmentCache = {};
|
|
50
|
-
segmentNames.forEach (s => {
|
|
51
|
-
this.addToSegment(s);
|
|
52
|
-
});
|
|
53
|
-
} else {
|
|
54
|
-
// Slowest path => we need to find at least 1 difference because
|
|
55
|
-
for(index = 0; index < segmentNames.length && this.isInSegment(segmentNames[index]); index++) {
|
|
56
|
-
// TODO: why empty statement?
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
if (index < segmentNames.length) {
|
|
60
|
-
isDiff = true;
|
|
61
|
-
|
|
62
|
-
this.segmentCache = {};
|
|
63
|
-
segmentNames.forEach (s => {
|
|
64
|
-
this.addToSegment(s);
|
|
65
|
-
});
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
return isDiff;
|
|
70
|
-
}
|
|
71
|
-
|
|
72
|
-
isInSegment(segmentName/*, key: string*/) {
|
|
73
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
74
|
-
|
|
75
|
-
return this.segmentCache[segmentKey] === true;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
setChangeNumber(/*segmentName: string, changeNumber: number*/) {
|
|
79
|
-
return true;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
getChangeNumber(/*segmentName: string*/) {
|
|
83
|
-
return -1;
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
registerSegment(/*segment: string*/) {
|
|
87
|
-
return false;
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
registerSegments(/*segments: Iterable<string>*/) {
|
|
91
|
-
return false;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
getRegisteredSegments() {
|
|
95
|
-
return [];
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
export default SegmentCacheInMemory;
|
|
@@ -1,84 +0,0 @@
|
|
|
1
|
-
import { numberIsInteger } from '../../../utils/lang';
|
|
2
|
-
import { _Set } from '../../../utils/lang/Sets';
|
|
3
|
-
|
|
4
|
-
class SegmentCacheInMemory {
|
|
5
|
-
|
|
6
|
-
constructor(keys) {
|
|
7
|
-
this.keys = keys;
|
|
8
|
-
this.flush();
|
|
9
|
-
}
|
|
10
|
-
|
|
11
|
-
addToSegment(segmentName, segmentKeys) {
|
|
12
|
-
const values = this.segmentCache[segmentName];
|
|
13
|
-
const keySet = values ? values : new _Set();
|
|
14
|
-
|
|
15
|
-
segmentKeys.forEach(k => keySet.add(k));
|
|
16
|
-
|
|
17
|
-
this.segmentCache[segmentName] = keySet;
|
|
18
|
-
|
|
19
|
-
return true;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
removeFromSegment(segmentName, segmentKeys) {
|
|
23
|
-
const values = this.segmentCache[segmentName];
|
|
24
|
-
const keySet = values ? values : new _Set();
|
|
25
|
-
|
|
26
|
-
segmentKeys.forEach(k => keySet.delete(k));
|
|
27
|
-
|
|
28
|
-
this.segmentCache[segmentName] = keySet;
|
|
29
|
-
|
|
30
|
-
return true;
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
isInSegment(segmentName, key) {
|
|
34
|
-
const segmentValues = this.segmentCache[segmentName];
|
|
35
|
-
|
|
36
|
-
if (segmentValues) {
|
|
37
|
-
return segmentValues.has(key);
|
|
38
|
-
}
|
|
39
|
-
|
|
40
|
-
return false;
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
registerSegment(segmentName) {
|
|
44
|
-
if (!this.segmentCache[segmentName]) {
|
|
45
|
-
this.segmentCache[segmentName] = new _Set();
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
return true;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
registerSegments(segments) {
|
|
52
|
-
for (let i = 0; i < segments.length; i++) {
|
|
53
|
-
this.registerSegment(segments[i]);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
return true;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
getRegisteredSegments() {
|
|
60
|
-
return Object.keys(this.segmentCache);
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
setChangeNumber(segmentName, changeNumber) {
|
|
64
|
-
const segmentChangeNumberKey = this.keys.buildSegmentTillKey(segmentName);
|
|
65
|
-
|
|
66
|
-
this.segmentChangeNumber[segmentChangeNumberKey] = changeNumber;
|
|
67
|
-
|
|
68
|
-
return true;
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
getChangeNumber(segmentName) {
|
|
72
|
-
const segmentChangeNumberKey = this.keys.buildSegmentTillKey(segmentName);
|
|
73
|
-
const value = this.segmentChangeNumber[segmentChangeNumberKey];
|
|
74
|
-
|
|
75
|
-
return numberIsInteger(value) ? value: -1;
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
flush() {
|
|
79
|
-
this.segmentCache = {};
|
|
80
|
-
this.segmentChangeNumber = {};
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
export default SegmentCacheInMemory;
|
|
@@ -1,71 +0,0 @@
|
|
|
1
|
-
import { numberIsNaN } from '../../../utils/lang';
|
|
2
|
-
|
|
3
|
-
class SegmentCacheInRedis {
|
|
4
|
-
|
|
5
|
-
constructor(keys, redis) {
|
|
6
|
-
this.redis = redis;
|
|
7
|
-
this.keys = keys;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
addToSegment(segmentName, segmentKeys) {
|
|
11
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
12
|
-
|
|
13
|
-
if (segmentKeys.length) {
|
|
14
|
-
return this.redis.sadd(segmentKey, segmentKeys).then(() => true);
|
|
15
|
-
} else {
|
|
16
|
-
return Promise.resolve(true);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
removeFromSegment(segmentName, segmentKeys) {
|
|
21
|
-
const segmentKey = this.keys.buildSegmentNameKey(segmentName);
|
|
22
|
-
|
|
23
|
-
if (segmentKeys.length) {
|
|
24
|
-
return this.redis.srem(segmentKey, segmentKeys).then(() => true);
|
|
25
|
-
} else {
|
|
26
|
-
return Promise.resolve(true);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
isInSegment(segmentName, key) {
|
|
31
|
-
return this.redis.sismember(
|
|
32
|
-
this.keys.buildSegmentNameKey(segmentName), key
|
|
33
|
-
).then(matches => matches !== 0);
|
|
34
|
-
}
|
|
35
|
-
|
|
36
|
-
setChangeNumber(segmentName, changeNumber) {
|
|
37
|
-
return this.redis.set(
|
|
38
|
-
this.keys.buildSegmentTillKey(segmentName), changeNumber + ''
|
|
39
|
-
).then(status => status === 'OK');
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
getChangeNumber(segmentName) {
|
|
43
|
-
return this.redis.get(this.keys.buildSegmentTillKey(segmentName)).then(value => {
|
|
44
|
-
const i = parseInt(value, 10);
|
|
45
|
-
|
|
46
|
-
return numberIsNaN(i) ? -1 : i;
|
|
47
|
-
});
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
registerSegment(segment) {
|
|
51
|
-
return this.registerSegments(segment);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
registerSegments(segments) {
|
|
55
|
-
if (segments.length) {
|
|
56
|
-
return this.redis.sadd(this.keys.buildRegisteredSegmentsKey(), segments).then(() => true);
|
|
57
|
-
} else {
|
|
58
|
-
return Promise.resolve(true);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
getRegisteredSegments() {
|
|
63
|
-
return this.redis.smembers(this.keys.buildRegisteredSegmentsKey());
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
flush() {
|
|
67
|
-
return this.redis.flushdb().then(status => status === 'OK');
|
|
68
|
-
}
|
|
69
|
-
}
|
|
70
|
-
|
|
71
|
-
export default SegmentCacheInRedis;
|
|
@@ -1,324 +0,0 @@
|
|
|
1
|
-
import { numberIsFinite, toNumber, numberIsNaN } from '../../utils/lang';
|
|
2
|
-
import usesSegments from '../../utils/splits/usesSegments';
|
|
3
|
-
import logFactory from '../../utils/logger';
|
|
4
|
-
const log = logFactory('splitio-storage:localstorage');
|
|
5
|
-
import killLocally from './killLocally';
|
|
6
|
-
|
|
7
|
-
class SplitCacheLocalStorage {
|
|
8
|
-
|
|
9
|
-
/**
|
|
10
|
-
* @param {Object} keys
|
|
11
|
-
* @param {number} expirationTimestamp
|
|
12
|
-
* @param {Object} splitFiltersValidation
|
|
13
|
-
*/
|
|
14
|
-
constructor(keys, expirationTimestamp, splitFiltersValidation = { validFilters: [], queryString: null, groupedFilters: { byName: [], byPrefix: [] } }) {
|
|
15
|
-
this.keys = keys;
|
|
16
|
-
this.splitFiltersValidation = splitFiltersValidation;
|
|
17
|
-
|
|
18
|
-
this.__checkExpiration(expirationTimestamp);
|
|
19
|
-
|
|
20
|
-
this.__checkFilterQuery();
|
|
21
|
-
}
|
|
22
|
-
|
|
23
|
-
decrementCount(key) {
|
|
24
|
-
const count = toNumber(localStorage.getItem(key)) - 1;
|
|
25
|
-
|
|
26
|
-
if (count > 0) localStorage.setItem(key, count);
|
|
27
|
-
else localStorage.removeItem(key);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
decrementCounts(split) {
|
|
31
|
-
try {
|
|
32
|
-
if (split) {
|
|
33
|
-
if (split.trafficTypeName) {
|
|
34
|
-
const ttKey = this.keys.buildTrafficTypeKey(split.trafficTypeName);
|
|
35
|
-
this.decrementCount(ttKey);
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
if (usesSegments(split.conditions)) {
|
|
39
|
-
const segmentsCountKey = this.keys.buildSplitsWithSegmentCountKey();
|
|
40
|
-
this.decrementCount(segmentsCountKey);
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
} catch (e) {
|
|
44
|
-
log.error(e);
|
|
45
|
-
}
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
incrementCounts(split) {
|
|
49
|
-
try {
|
|
50
|
-
if (split) {
|
|
51
|
-
if (split.trafficTypeName) {
|
|
52
|
-
const ttKey = this.keys.buildTrafficTypeKey(split.trafficTypeName);
|
|
53
|
-
localStorage.setItem(ttKey, toNumber(localStorage.getItem(ttKey)) + 1);
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
if (usesSegments(split.conditions)) {
|
|
57
|
-
const segmentsCountKey = this.keys.buildSplitsWithSegmentCountKey();
|
|
58
|
-
localStorage.setItem(segmentsCountKey, toNumber(localStorage.getItem(segmentsCountKey)) + 1);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
} catch (e) {
|
|
62
|
-
log.error(e);
|
|
63
|
-
}
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
addSplit(splitName, split) {
|
|
67
|
-
try {
|
|
68
|
-
const splitKey = this.keys.buildSplitKey(splitName);
|
|
69
|
-
const splitFromLocalStorage = localStorage.getItem(splitKey);
|
|
70
|
-
const previousSplit = splitFromLocalStorage ? JSON.parse(splitFromLocalStorage) : null;
|
|
71
|
-
this.decrementCounts(previousSplit);
|
|
72
|
-
|
|
73
|
-
localStorage.setItem(splitKey, split);
|
|
74
|
-
|
|
75
|
-
const parsedSplit = split ? JSON.parse(split) : null;
|
|
76
|
-
|
|
77
|
-
this.incrementCounts(parsedSplit);
|
|
78
|
-
|
|
79
|
-
return true;
|
|
80
|
-
} catch (e) {
|
|
81
|
-
log.error(e);
|
|
82
|
-
return false;
|
|
83
|
-
}
|
|
84
|
-
}
|
|
85
|
-
|
|
86
|
-
addSplits(entries) {
|
|
87
|
-
let results = [];
|
|
88
|
-
|
|
89
|
-
entries.forEach(keyValuePair => {
|
|
90
|
-
results.push(this.addSplit(keyValuePair[0], keyValuePair[1]));
|
|
91
|
-
});
|
|
92
|
-
|
|
93
|
-
return results;
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
removeSplit(splitName) {
|
|
97
|
-
try {
|
|
98
|
-
const split = this.getSplit(splitName);
|
|
99
|
-
localStorage.removeItem(this.keys.buildSplitKey(splitName));
|
|
100
|
-
|
|
101
|
-
const parsedSplit = JSON.parse(split);
|
|
102
|
-
this.decrementCounts(parsedSplit);
|
|
103
|
-
|
|
104
|
-
return 1;
|
|
105
|
-
} catch (e) {
|
|
106
|
-
log.error(e);
|
|
107
|
-
return 0;
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
/**
|
|
112
|
-
* Bulk delete of splits from LocalStorage. Returns the number of deleted keys.
|
|
113
|
-
*/
|
|
114
|
-
removeSplits(names) {
|
|
115
|
-
let i = 0;
|
|
116
|
-
let len = names.length;
|
|
117
|
-
let counter = 0;
|
|
118
|
-
|
|
119
|
-
for (; i < len; i++) {
|
|
120
|
-
counter += this.removeSplit(names[i]);
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
return counter;
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
getSplit(splitName) {
|
|
127
|
-
return localStorage.getItem(this.keys.buildSplitKey(splitName));
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
setChangeNumber(changeNumber) {
|
|
131
|
-
// when cache is ready but using a new split query, we must flush all split data
|
|
132
|
-
if (this.cacheReadyButNeedsToFlush) {
|
|
133
|
-
this.flush();
|
|
134
|
-
this.cacheReadyButNeedsToFlush = false;
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
// when using a new split query, we must update it at the store
|
|
138
|
-
if (this.updateNewFilter) {
|
|
139
|
-
log.info('Split filter query was modified. Updating cache.');
|
|
140
|
-
const queryKey = this.keys.buildSplitsFilterQueryKey();
|
|
141
|
-
const { queryString } = this.splitFiltersValidation;
|
|
142
|
-
try {
|
|
143
|
-
if (queryString) localStorage.setItem(queryKey, queryString);
|
|
144
|
-
else localStorage.removeItem(queryKey);
|
|
145
|
-
} catch (e) {
|
|
146
|
-
log.error(e);
|
|
147
|
-
}
|
|
148
|
-
this.updateNewFilter = false;
|
|
149
|
-
}
|
|
150
|
-
|
|
151
|
-
try {
|
|
152
|
-
localStorage.setItem(this.keys.buildSplitsTillKey(), changeNumber + '');
|
|
153
|
-
// update "last updated" timestamp with current time
|
|
154
|
-
localStorage.setItem(this.keys.buildLastUpdatedKey(), Date.now() + '');
|
|
155
|
-
this.hasSync = true;
|
|
156
|
-
return true;
|
|
157
|
-
} catch (e) {
|
|
158
|
-
log.error(e);
|
|
159
|
-
return false;
|
|
160
|
-
}
|
|
161
|
-
}
|
|
162
|
-
|
|
163
|
-
getChangeNumber() {
|
|
164
|
-
const n = -1;
|
|
165
|
-
let value = localStorage.getItem(this.keys.buildSplitsTillKey());
|
|
166
|
-
|
|
167
|
-
if (value !== null) {
|
|
168
|
-
value = parseInt(value, 10);
|
|
169
|
-
|
|
170
|
-
return numberIsNaN(value) ? n : value;
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
return n;
|
|
174
|
-
}
|
|
175
|
-
|
|
176
|
-
getAll() {
|
|
177
|
-
const len = localStorage.length;
|
|
178
|
-
const accum = [];
|
|
179
|
-
|
|
180
|
-
let cur = 0;
|
|
181
|
-
|
|
182
|
-
while (cur < len) {
|
|
183
|
-
const key = localStorage.key(cur);
|
|
184
|
-
const value = key && localStorage.getItem(key);
|
|
185
|
-
|
|
186
|
-
if (key != null && this.keys.isSplitKey(key) && value) accum.push(value);
|
|
187
|
-
|
|
188
|
-
cur++;
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
return accum;
|
|
192
|
-
}
|
|
193
|
-
|
|
194
|
-
getKeys() {
|
|
195
|
-
const len = localStorage.length;
|
|
196
|
-
const accum = [];
|
|
197
|
-
|
|
198
|
-
let cur = 0;
|
|
199
|
-
|
|
200
|
-
while (cur < len) {
|
|
201
|
-
const key = localStorage.key(cur);
|
|
202
|
-
|
|
203
|
-
if (key != null && this.keys.isSplitKey(key)) accum.push(this.keys.extractKey(key));
|
|
204
|
-
|
|
205
|
-
cur++;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
return accum;
|
|
209
|
-
}
|
|
210
|
-
|
|
211
|
-
trafficTypeExists(trafficType) {
|
|
212
|
-
const ttCount = toNumber(localStorage.getItem(this.keys.buildTrafficTypeKey(trafficType)));
|
|
213
|
-
return numberIsFinite(ttCount) && ttCount > 0;
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
usesSegments() {
|
|
217
|
-
// If cache hasn't been synchronized with the cloud, assume we need them.
|
|
218
|
-
if (!this.hasSync) return true;
|
|
219
|
-
|
|
220
|
-
const storedCount = localStorage.getItem(this.keys.buildSplitsWithSegmentCountKey());
|
|
221
|
-
const splitsWithSegmentsCount = storedCount === null ? 0 : toNumber(storedCount);
|
|
222
|
-
|
|
223
|
-
if (numberIsFinite(splitsWithSegmentsCount)) {
|
|
224
|
-
return splitsWithSegmentsCount > 0;
|
|
225
|
-
} else {
|
|
226
|
-
return true;
|
|
227
|
-
}
|
|
228
|
-
}
|
|
229
|
-
|
|
230
|
-
/**
|
|
231
|
-
* Removes all splits cache related data from localStorage (splits, counters, changeNumber and lastUpdated).
|
|
232
|
-
* We cannot simply call `localStorage.clear()` since that implies removing user items from the storage.
|
|
233
|
-
*/
|
|
234
|
-
flush() {
|
|
235
|
-
log.info('Flushing Splits data from localStorage');
|
|
236
|
-
|
|
237
|
-
// collect item keys
|
|
238
|
-
const len = localStorage.length;
|
|
239
|
-
const accum = [];
|
|
240
|
-
for (let cur = 0; cur < len; cur++) {
|
|
241
|
-
const key = localStorage.key(cur);
|
|
242
|
-
if (key != null && this.keys.isSplitCacheKey(key)) accum.push(key);
|
|
243
|
-
}
|
|
244
|
-
// remove items
|
|
245
|
-
accum.forEach(key => {
|
|
246
|
-
localStorage.removeItem(key);
|
|
247
|
-
});
|
|
248
|
-
|
|
249
|
-
this.hasSync = false;
|
|
250
|
-
}
|
|
251
|
-
|
|
252
|
-
/**
|
|
253
|
-
* Fetches multiple splits definitions.
|
|
254
|
-
*/
|
|
255
|
-
fetchMany(splitNames) {
|
|
256
|
-
const splits = {};
|
|
257
|
-
splitNames.forEach(splitName => {
|
|
258
|
-
splits[splitName] = localStorage.getItem(this.keys.buildSplitKey(splitName));
|
|
259
|
-
});
|
|
260
|
-
return splits;
|
|
261
|
-
}
|
|
262
|
-
|
|
263
|
-
/**
|
|
264
|
-
* Check if the splits information is already stored in cache.
|
|
265
|
-
* It is used as condition to emit SDK_SPLITS_CACHE_LOADED, and then SDK_READY_FROM_CACHE.
|
|
266
|
-
* In this function we could add more code to check if the data is valid.
|
|
267
|
-
*/
|
|
268
|
-
checkCache() {
|
|
269
|
-
return this.getChangeNumber() > -1 || this.cacheReadyButNeedsToFlush;
|
|
270
|
-
}
|
|
271
|
-
|
|
272
|
-
/**
|
|
273
|
-
* Clean Splits cache if its `lastUpdated` timestamp is older than the given `expirationTimestamp`,
|
|
274
|
-
* Clean operation (flush) also updates `lastUpdated` timestamp with current time.
|
|
275
|
-
*
|
|
276
|
-
* @param {number | undefined} expirationTimestamp if the value is not a number, data will not be cleaned
|
|
277
|
-
*/
|
|
278
|
-
__checkExpiration(expirationTimestamp) {
|
|
279
|
-
let value = localStorage.getItem(this.keys.buildLastUpdatedKey());
|
|
280
|
-
if (value !== null) {
|
|
281
|
-
value = parseInt(value, 10);
|
|
282
|
-
if (!numberIsNaN(value) && value < expirationTimestamp) this.flush();
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
|
|
286
|
-
__checkFilterQuery() {
|
|
287
|
-
const { queryString, groupedFilters } = this.splitFiltersValidation;
|
|
288
|
-
const queryKey = this.keys.buildSplitsFilterQueryKey();
|
|
289
|
-
const currentQueryString = localStorage.getItem(queryKey);
|
|
290
|
-
|
|
291
|
-
if (currentQueryString !== queryString) {
|
|
292
|
-
try {
|
|
293
|
-
// mark cache to update the new query filter on first successful splits fetch
|
|
294
|
-
this.updateNewFilter = true;
|
|
295
|
-
|
|
296
|
-
// if cache is ready:
|
|
297
|
-
if (this.checkCache()) {
|
|
298
|
-
// * set change number to -1, to fetch splits with -1 `since` value.
|
|
299
|
-
localStorage.setItem(this.keys.buildSplitsTillKey(), '-1');
|
|
300
|
-
|
|
301
|
-
// * remove from cache splits that doesn't match with the new filters
|
|
302
|
-
this.getKeys().forEach((splitName) => {
|
|
303
|
-
if (queryString && (
|
|
304
|
-
groupedFilters.byName.indexOf(splitName) > -1 ||
|
|
305
|
-
groupedFilters.byPrefix.some(prefix => splitName.startsWith(prefix + '__'))
|
|
306
|
-
)) {
|
|
307
|
-
// * set `cacheReadyButNeedsToFlush` so that `checkCache` returns true (the storage is ready to be used) and the data is flushed before updating on first successful splits fetch
|
|
308
|
-
this.cacheReadyButNeedsToFlush = true;
|
|
309
|
-
return;
|
|
310
|
-
}
|
|
311
|
-
this.removeSplit(splitName);
|
|
312
|
-
});
|
|
313
|
-
}
|
|
314
|
-
} catch (e) {
|
|
315
|
-
log.error(e);
|
|
316
|
-
}
|
|
317
|
-
}
|
|
318
|
-
// if the filter didn't change, nothing is done
|
|
319
|
-
}
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
SplitCacheLocalStorage.prototype.killLocally = killLocally;
|
|
323
|
-
|
|
324
|
-
export default SplitCacheLocalStorage;
|