@splitsoftware/splitio 10.17.3-rc.4 → 10.17.4-rc.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGES.txt +0 -3
- package/client/package.json +5 -0
- package/es/factory/browser.js +67 -0
- package/es/factory/node.js +63 -0
- package/es/{client → factory}/package.json +0 -0
- package/es/index.js +16 -132
- package/es/platform/EventEmitter.js +386 -0
- package/es/platform/browser.js +10 -0
- package/es/platform/getEventSource/browser.js +3 -0
- package/es/platform/getEventSource/node.js +19 -0
- package/es/{impressions/observer → platform/getEventSource}/package.json +0 -0
- package/es/platform/getFetch/browser.js +4 -0
- package/es/platform/getFetch/node.js +18 -0
- package/es/{integrations → platform/getFetch}/package.json +0 -0
- package/es/platform/node.js +12 -0
- package/es/{listeners → platform}/package.json +0 -0
- package/es/platform/request/options/node.js +13 -0
- package/es/settings/browser.js +20 -0
- package/es/settings/defaults/browser.js +18 -0
- package/es/settings/defaults/node.js +24 -0
- package/es/settings/defaults/version.js +1 -0
- package/es/settings/integrations/browser.js +5 -0
- package/es/settings/node.js +18 -0
- package/es/{producer/offline → settings}/package.json +0 -0
- package/es/settings/runtime/node.js +17 -0
- package/es/settings/storage/browser.js +29 -0
- package/es/settings/storage/node.js +60 -0
- package/es/umd.js +2 -1
- package/lib/factory/browser.js +71 -0
- package/lib/factory/node.js +67 -0
- package/{es/producer → lib/factory}/package.json +0 -0
- package/lib/index.js +19 -155
- package/lib/platform/EventEmitter.js +390 -0
- package/lib/platform/browser.js +13 -0
- package/lib/platform/getEventSource/browser.js +7 -0
- package/lib/platform/getEventSource/node.js +25 -0
- package/{es/services → lib/platform}/getEventSource/package.json +0 -0
- package/lib/platform/getFetch/browser.js +9 -0
- package/lib/platform/getFetch/node.js +23 -0
- package/{es/services → lib/platform}/getFetch/package.json +0 -0
- package/lib/platform/node.js +16 -0
- package/{es/services/request/options → lib/platform}/package.json +0 -0
- package/lib/platform/request/options/node.js +18 -0
- package/lib/settings/browser.js +24 -0
- package/lib/settings/defaults/browser.js +21 -0
- package/lib/settings/defaults/node.js +27 -0
- package/lib/settings/defaults/version.js +4 -0
- package/lib/settings/integrations/browser.js +9 -0
- package/lib/settings/node.js +22 -0
- package/{es/services/splitChanges/offline → lib/settings}/package.json +0 -0
- package/lib/settings/runtime/node.js +22 -0
- package/lib/settings/storage/browser.js +33 -0
- package/lib/settings/storage/node.js +64 -0
- package/lib/umd.js +4 -8
- package/package.json +29 -31
- package/server/package.json +5 -0
- package/src/.DS_Store +0 -0
- package/src/factory/browser.js +84 -0
- package/src/factory/node.js +78 -0
- package/{es/storage/SegmentCache/InMemory → src/factory}/package.json +0 -0
- package/src/index.js +13 -136
- package/src/platform/.DS_Store +0 -0
- package/src/platform/EventEmitter.js +443 -0
- package/src/platform/browser.js +12 -0
- package/{es/services → src/platform}/getEventSource/browser.js +2 -2
- package/src/{services → platform}/getEventSource/node.js +2 -2
- package/{es/storage → 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/sync/PushManager/pushRequirements → src/platform/getFetch}/package.json +0 -0
- package/src/platform/node.js +14 -0
- package/{es/sync/SegmentUpdateWorker → src/platform}/package.json +0 -0
- package/src/platform/request/options/node.js +15 -0
- package/src/settings/.DS_Store +0 -0
- package/src/settings/browser.js +22 -0
- package/{lib/utils → src}/settings/defaults/browser.js +10 -6
- 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/settings/node.js +20 -0
- package/{es/sync → src/settings}/package.json +0 -0
- package/src/settings/runtime/node.js +21 -0
- package/src/settings/storage/browser.js +43 -0
- package/src/{utils/settings → settings}/storage/node.js +18 -34
- package/src/umd.js +1 -0
- package/types/client/index.d.ts +14 -0
- package/types/server/index.d.ts +20 -0
- package/types/splitio.d.ts +77 -6
- 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/getEventSource/node.js +0 -18
- package/es/services/getFetch/browser.js +0 -4
- package/es/services/getFetch/node.js +0 -18
- 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/request/options/node.js +0 -28
- 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/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 -58
- 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 -162
- package/es/storage/SegmentCache/InMemory/browser.js +0 -107
- package/es/storage/SegmentCache/InMemory/node.js +0 -82
- 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/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/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/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/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/browser.js +0 -12
- package/es/utils/settings/defaults/node.js +0 -21
- 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/node.js +0 -33
- package/es/utils/settings/runtime/package.json +0 -4
- package/es/utils/settings/storage/browser.js +0 -64
- package/es/utils/settings/storage/node.js +0 -86
- 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/browser.js +0 -8
- package/lib/services/getEventSource/node.js +0 -26
- package/lib/services/getEventSource/package.json +0 -4
- package/lib/services/getFetch/browser.js +0 -12
- package/lib/services/getFetch/node.js +0 -24
- 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/node.js +0 -37
- 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 -69
- 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 -171
- 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/node.js +0 -43
- package/lib/utils/settings/runtime/package.json +0 -4
- package/lib/utils/settings/storage/browser.js +0 -75
- package/lib/utils/settings/storage/node.js +0 -92
- 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/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/browser.js +0 -3
- 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/node.js +0 -30
- 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 -52
- 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 -140
- 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/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/browser.js +0 -12
- package/src/utils/settings/defaults/node.js +0 -21
- 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/node.js +0 -7
- 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/node.js +0 -34
- package/src/utils/settings/runtime/package.json +0 -4
- package/src/utils/settings/storage/browser.js +0 -70
- 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,35 +0,0 @@
|
|
|
1
|
-
import thenable from '../../utils/promise/thenable';
|
|
2
|
-
/**
|
|
3
|
-
* Kill `splitName` at `this` split storage, setting `defaultTreatment` and `changeNumber`,
|
|
4
|
-
* only if the split exists and its `changeNumber` is older than the given one.
|
|
5
|
-
* Used for SPLIT_KILL push notifications.
|
|
6
|
-
*
|
|
7
|
-
* @param {string} splitName
|
|
8
|
-
* @param {string} defaultTreatment
|
|
9
|
-
* @param {number} changeNumber
|
|
10
|
-
* @returns {Promise} a promise that is resolved once the split kill is performed.
|
|
11
|
-
* The fulfillment value is a boolean: `true` if the kill success updating the split or `false` if no split is updated, for instance,
|
|
12
|
-
* if the `changeNumber` is old, if the `splitName` is not found, or if the storage fails to apply the update.
|
|
13
|
-
*/
|
|
14
|
-
|
|
15
|
-
export default function killLocally(splitName, defaultTreatment, changeNumber) {
|
|
16
|
-
var _this = this;
|
|
17
|
-
|
|
18
|
-
var split = this.getSplit(splitName);
|
|
19
|
-
var splitPromise = thenable(split) ? split : Promise.resolve(split);
|
|
20
|
-
return splitPromise.then(function (split) {
|
|
21
|
-
if (split) {
|
|
22
|
-
var parsedSplit = JSON.parse(split);
|
|
23
|
-
|
|
24
|
-
if (!parsedSplit.changeNumber || parsedSplit.changeNumber < changeNumber) {
|
|
25
|
-
parsedSplit.killed = true;
|
|
26
|
-
parsedSplit.defaultTreatment = defaultTreatment;
|
|
27
|
-
parsedSplit.changeNumber = changeNumber;
|
|
28
|
-
var newSplit = JSON.stringify(parsedSplit);
|
|
29
|
-
return _this.addSplit(splitName, newSplit);
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
return false;
|
|
34
|
-
});
|
|
35
|
-
}
|
package/es/storage/browser.js
DELETED
|
@@ -1,101 +0,0 @@
|
|
|
1
|
-
import SplitCacheInMemory from './SplitCache/InMemory';
|
|
2
|
-
import SplitCacheInLocalStorage from './SplitCache/InLocalStorage';
|
|
3
|
-
import SegmentCacheInMemory from './SegmentCache/InMemory';
|
|
4
|
-
import SegmentCacheInLocalStorage from './SegmentCache/InLocalStorage';
|
|
5
|
-
import ImpressionsCacheInMemory from './ImpressionsCache/InMemory';
|
|
6
|
-
import LatencyCacheInMemory from './LatencyCache/InMemory';
|
|
7
|
-
import CountCacheInMemory from './CountCache/InMemory';
|
|
8
|
-
import EventsCacheInMemory from './EventsCache/InMemory';
|
|
9
|
-
import KeyBuilder from './Keys';
|
|
10
|
-
import KeyBuilderLocalStorage from './KeysLocalStorage';
|
|
11
|
-
import { STORAGE_MEMORY, STORAGE_LOCALSTORAGE } from '../utils/constants'; // This value might be eventually set via a config parameter
|
|
12
|
-
|
|
13
|
-
export var DEFAULT_CACHE_EXPIRATION_IN_MILLIS = 864000000; // 10 days
|
|
14
|
-
|
|
15
|
-
var BrowserStorageFactory = function BrowserStorageFactory(context) {
|
|
16
|
-
var settings = context.get(context.constants.SETTINGS);
|
|
17
|
-
var storage = settings.storage;
|
|
18
|
-
|
|
19
|
-
switch (storage.type) {
|
|
20
|
-
case STORAGE_MEMORY:
|
|
21
|
-
{
|
|
22
|
-
var keys = new KeyBuilder(settings);
|
|
23
|
-
return {
|
|
24
|
-
splits: new SplitCacheInMemory(),
|
|
25
|
-
segments: new SegmentCacheInMemory(keys),
|
|
26
|
-
impressions: new ImpressionsCacheInMemory(),
|
|
27
|
-
metrics: new LatencyCacheInMemory(),
|
|
28
|
-
count: new CountCacheInMemory(),
|
|
29
|
-
events: new EventsCacheInMemory(context),
|
|
30
|
-
// When using shared instanciation with MEMORY we reuse everything but segments (they are customer per key).
|
|
31
|
-
shared: function shared(settings) {
|
|
32
|
-
var childKeyBuilder = new KeyBuilder(settings);
|
|
33
|
-
return {
|
|
34
|
-
splits: this.splits,
|
|
35
|
-
segments: new SegmentCacheInMemory(childKeyBuilder),
|
|
36
|
-
impressions: this.impressions,
|
|
37
|
-
metrics: this.metrics,
|
|
38
|
-
count: this.count,
|
|
39
|
-
events: this.events,
|
|
40
|
-
destroy: function destroy() {
|
|
41
|
-
this.splits = new SplitCacheInMemory();
|
|
42
|
-
this.segments.flush();
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
},
|
|
46
|
-
destroy: function destroy() {
|
|
47
|
-
this.splits.flush();
|
|
48
|
-
this.segments.flush();
|
|
49
|
-
this.impressions.clear();
|
|
50
|
-
this.metrics.clear();
|
|
51
|
-
this.count.clear();
|
|
52
|
-
this.events.clear();
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
}
|
|
56
|
-
|
|
57
|
-
case STORAGE_LOCALSTORAGE:
|
|
58
|
-
{
|
|
59
|
-
var _keys = new KeyBuilderLocalStorage(settings);
|
|
60
|
-
|
|
61
|
-
var expirationTimestamp = Date.now() - DEFAULT_CACHE_EXPIRATION_IN_MILLIS;
|
|
62
|
-
return {
|
|
63
|
-
splits: new SplitCacheInLocalStorage(_keys, expirationTimestamp, settings.sync.__splitFiltersValidation),
|
|
64
|
-
segments: new SegmentCacheInLocalStorage(_keys),
|
|
65
|
-
impressions: new ImpressionsCacheInMemory(),
|
|
66
|
-
metrics: new LatencyCacheInMemory(),
|
|
67
|
-
count: new CountCacheInMemory(),
|
|
68
|
-
events: new EventsCacheInMemory(context),
|
|
69
|
-
// When using shared instanciation with MEMORY we reuse everything but segments (they are customer per key).
|
|
70
|
-
shared: function shared(settings) {
|
|
71
|
-
var childKeysBuilder = new KeyBuilderLocalStorage(settings);
|
|
72
|
-
return {
|
|
73
|
-
splits: this.splits,
|
|
74
|
-
segments: new SegmentCacheInLocalStorage(childKeysBuilder),
|
|
75
|
-
impressions: this.impressions,
|
|
76
|
-
metrics: this.metrics,
|
|
77
|
-
count: this.count,
|
|
78
|
-
events: this.events,
|
|
79
|
-
destroy: function destroy() {
|
|
80
|
-
this.splits = new SplitCacheInMemory();
|
|
81
|
-
this.segments = new SegmentCacheInMemory(childKeysBuilder);
|
|
82
|
-
}
|
|
83
|
-
};
|
|
84
|
-
},
|
|
85
|
-
destroy: function destroy() {
|
|
86
|
-
this.splits = new SplitCacheInMemory();
|
|
87
|
-
this.segments = new SegmentCacheInMemory(new KeyBuilder(settings));
|
|
88
|
-
this.impressions.clear();
|
|
89
|
-
this.metrics.clear();
|
|
90
|
-
this.count.clear();
|
|
91
|
-
this.events.clear();
|
|
92
|
-
}
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
default:
|
|
97
|
-
throw new Error('Unsupported storage type');
|
|
98
|
-
}
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
export default BrowserStorageFactory;
|
package/es/storage/node.js
DELETED
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
import RedisAdapter from './RedisAdapter';
|
|
2
|
-
import SplitCacheInMemory from './SplitCache/InMemory';
|
|
3
|
-
import SplitCacheInRedis from './SplitCache/InRedis';
|
|
4
|
-
import SegmentCacheInMemory from './SegmentCache/InMemory';
|
|
5
|
-
import SegmentCacheInRedis from './SegmentCache/InRedis';
|
|
6
|
-
import ImpressionsCacheInMemory from './ImpressionsCache/InMemory';
|
|
7
|
-
import ImpressionsCacheInRedis from './ImpressionsCache/InRedis';
|
|
8
|
-
import LatencyCacheInMemory from './LatencyCache/InMemory';
|
|
9
|
-
import LatencyCacheInRedis from './LatencyCache/InRedis';
|
|
10
|
-
import CountCacheInMemory from './CountCache/InMemory';
|
|
11
|
-
import CountCacheInRedis from './CountCache/InRedis';
|
|
12
|
-
import EventsCacheInMemory from './EventsCache/InMemory';
|
|
13
|
-
import EventsCacheInRedis from './EventsCache/InRedis';
|
|
14
|
-
import KeyBuilder from './Keys';
|
|
15
|
-
import MetaBuilder from './Meta';
|
|
16
|
-
import { STORAGE_MEMORY, STORAGE_REDIS } from '../utils/constants';
|
|
17
|
-
|
|
18
|
-
var NodeStorageFactory = function NodeStorageFactory(context) {
|
|
19
|
-
var settings = context.get(context.constants.SETTINGS);
|
|
20
|
-
var storage = settings.storage;
|
|
21
|
-
var keys = new KeyBuilder(settings);
|
|
22
|
-
|
|
23
|
-
switch (storage.type) {
|
|
24
|
-
case STORAGE_REDIS:
|
|
25
|
-
{
|
|
26
|
-
var redis = new RedisAdapter(storage.options);
|
|
27
|
-
var meta = MetaBuilder(settings); // subscription to Redis connect event in order to emit SDK_READY
|
|
28
|
-
|
|
29
|
-
var _context$get = context.get(context.constants.READINESS),
|
|
30
|
-
splits = _context$get.splits,
|
|
31
|
-
segments = _context$get.segments;
|
|
32
|
-
|
|
33
|
-
redis.on('connect', function () {
|
|
34
|
-
splits.emit(splits.SDK_SPLITS_ARRIVED);
|
|
35
|
-
segments.emit(segments.SDK_SEGMENTS_ARRIVED);
|
|
36
|
-
});
|
|
37
|
-
return {
|
|
38
|
-
splits: new SplitCacheInRedis(keys, redis),
|
|
39
|
-
segments: new SegmentCacheInRedis(keys, redis),
|
|
40
|
-
impressions: new ImpressionsCacheInRedis(keys, redis, meta),
|
|
41
|
-
metrics: new LatencyCacheInRedis(keys, redis),
|
|
42
|
-
count: new CountCacheInRedis(keys, redis),
|
|
43
|
-
events: new EventsCacheInRedis(keys, redis, meta),
|
|
44
|
-
// When using REDIS we should:
|
|
45
|
-
// 1- Disconnect from the storage
|
|
46
|
-
// 2- Stop sending data to Redis and instance using empty in memory implementation
|
|
47
|
-
destroy: function destroy() {
|
|
48
|
-
redis.disconnect();
|
|
49
|
-
this.splits = new SplitCacheInMemory();
|
|
50
|
-
this.segments = new SegmentCacheInMemory(keys);
|
|
51
|
-
this.impressions = new ImpressionsCacheInMemory();
|
|
52
|
-
this.metrics = new LatencyCacheInMemory();
|
|
53
|
-
this.count = new CountCacheInMemory();
|
|
54
|
-
this.events = new EventsCacheInMemory(context);
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
case STORAGE_MEMORY:
|
|
60
|
-
default:
|
|
61
|
-
return {
|
|
62
|
-
splits: new SplitCacheInMemory(),
|
|
63
|
-
segments: new SegmentCacheInMemory(keys),
|
|
64
|
-
impressions: new ImpressionsCacheInMemory(),
|
|
65
|
-
metrics: new LatencyCacheInMemory(),
|
|
66
|
-
count: new CountCacheInMemory(),
|
|
67
|
-
events: new EventsCacheInMemory(context),
|
|
68
|
-
// When using MEMORY we should flush all the storages and leave them empty
|
|
69
|
-
destroy: function destroy() {
|
|
70
|
-
this.splits.flush();
|
|
71
|
-
this.segments.flush();
|
|
72
|
-
this.impressions.clear();
|
|
73
|
-
this.metrics.clear();
|
|
74
|
-
this.count.clear();
|
|
75
|
-
this.events.clear();
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
}
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
export default NodeStorageFactory;
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import objectAssign from 'object-assign';
|
|
2
|
-
import authService from '../../services/auth';
|
|
3
|
-
import authRequest from '../../services/auth/auth';
|
|
4
|
-
import { decodeJWTtoken } from '../../utils/jwt';
|
|
5
|
-
/**
|
|
6
|
-
* Run authentication requests to Auth Server, and handle response decoding the JTW token.
|
|
7
|
-
* Precondition:
|
|
8
|
-
*
|
|
9
|
-
* @param {Object} settings Split factory config, used to get authorizationKey and other params required by authRequest.
|
|
10
|
-
* @param {string[] | undefined} userKeys set of user Keys to track MY_SEGMENTS_CHANGES. It is undefined for Node.
|
|
11
|
-
* @throws {ReferenceError} if `atob` function is not defined
|
|
12
|
-
*/
|
|
13
|
-
|
|
14
|
-
export default function authenticate(settings, userKeys) {
|
|
15
|
-
var authPromise = authService(authRequest(settings, userKeys)); // errors handled by authService
|
|
16
|
-
|
|
17
|
-
return authPromise // no need to handle json parsing errors as SplitError, since no user callbacks are executed after this promise is resolved
|
|
18
|
-
.then(function (resp) {
|
|
19
|
-
return resp.json();
|
|
20
|
-
}).then(function (json) {
|
|
21
|
-
if (json.token) {
|
|
22
|
-
// empty token when `"pushEnabled": false`
|
|
23
|
-
var decodedToken = decodeJWTtoken(json.token);
|
|
24
|
-
if (typeof decodedToken.iat !== 'number' || typeof decodedToken.exp !== 'number') throw new Error('token properties "issuedAt" (iat) or "expiration" (exp) are missing or invalid');
|
|
25
|
-
var channels = JSON.parse(decodedToken['x-ably-capability']);
|
|
26
|
-
return objectAssign({
|
|
27
|
-
decodedToken: decodedToken,
|
|
28
|
-
channels: channels
|
|
29
|
-
}, json);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
return json;
|
|
33
|
-
});
|
|
34
|
-
}
|
|
@@ -1,315 +0,0 @@
|
|
|
1
|
-
import EventEmitter from 'events';
|
|
2
|
-
import objectAssign from 'object-assign';
|
|
3
|
-
import authenticate from '../AuthClient';
|
|
4
|
-
import { checkPushRequirements } from './pushRequirements';
|
|
5
|
-
import SegmentUpdateWorker from '../SegmentUpdateWorker';
|
|
6
|
-
import SplitUpdateWorker from '../SplitUpdateWorker';
|
|
7
|
-
import SSEClient from '../SSEClient';
|
|
8
|
-
import SSEHandlerFactory from '../SSEHandler';
|
|
9
|
-
import Backoff from '../../utils/backoff';
|
|
10
|
-
import { hashUserKey } from '../../utils/jwt/hashUserKey';
|
|
11
|
-
import logFactory from '../../utils/logger';
|
|
12
|
-
import { SECONDS_BEFORE_EXPIRATION, PUSH_SUBSYSTEM_DOWN, PUSH_SUBSYSTEM_UP, PUSH_NONRETRYABLE_ERROR, PUSH_RETRYABLE_ERROR, SPLIT_KILL, SPLIT_UPDATE, SEGMENT_UPDATE, MY_SEGMENTS_UPDATE, MY_SEGMENTS_UPDATE_V2, ControlTypes } from '../constants';
|
|
13
|
-
import { parseBitmap, parseKeyList, isInBitmap } from './mySegmentsV2utils';
|
|
14
|
-
import { forOwn } from '../../utils/lang';
|
|
15
|
-
import { _Set } from '../../utils/lang/Sets';
|
|
16
|
-
import { hash64 } from '../../engine/engine/murmur3/murmur3_64';
|
|
17
|
-
var log = logFactory('splitio-sync:push-manager'); // const UnboundedFetchRequest = 0;
|
|
18
|
-
|
|
19
|
-
var BoundedFetchRequest = 1;
|
|
20
|
-
var KeyList = 2;
|
|
21
|
-
var SegmentRemoval = 3;
|
|
22
|
-
|
|
23
|
-
function fallbackWarning(notificationType, e) {
|
|
24
|
-
return "Fetching MySegments due to an error processing " + notificationType + " notification: " + e;
|
|
25
|
-
}
|
|
26
|
-
/**
|
|
27
|
-
* Factory of the push mode manager.
|
|
28
|
-
*
|
|
29
|
-
* @param {Object} context context of main client.
|
|
30
|
-
* @param {Object | undefined} clientContexts map of user keys to client contexts to handle sync of MySegments. undefined for node.
|
|
31
|
-
*/
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
export default function PushManagerFactory(context, clientContexts
|
|
35
|
-
/* undefined for node */
|
|
36
|
-
) {
|
|
37
|
-
// No return a PushManager if PUSH mode is not supported.
|
|
38
|
-
if (!checkPushRequirements(log)) return;
|
|
39
|
-
var pushEmitter = new EventEmitter();
|
|
40
|
-
|
|
41
|
-
var _context$get = context.get(context.constants.READINESS),
|
|
42
|
-
splitsEventEmitter = _context$get.splits;
|
|
43
|
-
|
|
44
|
-
var settings = context.get(context.constants.SETTINGS);
|
|
45
|
-
var storage = context.get(context.constants.STORAGE);
|
|
46
|
-
var sseClient = SSEClient.getInstance(settings, clientContexts ? false : true);
|
|
47
|
-
var sseHandler = SSEHandlerFactory(pushEmitter);
|
|
48
|
-
sseClient.setEventHandler(sseHandler); // map of hashes to user keys, to dispatch MY_SEGMENTS_UPDATE events to the corresponding MySegmentsUpdateWorker
|
|
49
|
-
|
|
50
|
-
var userKeyHashes = {}; // map of user keys to their corresponding hash64 and MySegmentsUpdateWorker.
|
|
51
|
-
// Hash64 is used to process MY_SEGMENTS_UPDATE_V2 events and dispatch actions to the corresponding worker.
|
|
52
|
-
|
|
53
|
-
var clients = {}; // variable used on browser to reconnect only when a new client was added, saving some authentication and sse connections.
|
|
54
|
-
|
|
55
|
-
var connectForNewClient = false; // flag that indicates if `disconnectPush` was called, either by the SyncManager (when the client is destroyed) or by a PUSH_NONRETRYABLE_ERROR error
|
|
56
|
-
|
|
57
|
-
var disconnected;
|
|
58
|
-
/** PushManager functions related to initialization */
|
|
59
|
-
|
|
60
|
-
var connectPushRetryBackoff = new Backoff(connectPush, settings.scheduler.pushRetryBackoffBase);
|
|
61
|
-
var timeoutIdTokenRefresh;
|
|
62
|
-
var timeoutIdSseOpen;
|
|
63
|
-
|
|
64
|
-
function scheduleTokenRefreshAndSse(authData) {
|
|
65
|
-
// clear scheduled tasks if exist
|
|
66
|
-
if (timeoutIdTokenRefresh) clearTimeout(timeoutIdTokenRefresh);
|
|
67
|
-
if (timeoutIdSseOpen) clearTimeout(timeoutIdSseOpen); // Set token refresh 10 minutes before expirationTime - issuedAt
|
|
68
|
-
|
|
69
|
-
var decodedToken = authData.decodedToken;
|
|
70
|
-
var refreshTokenDelay = decodedToken.exp - decodedToken.iat - SECONDS_BEFORE_EXPIRATION; // Default connDelay of 60 secs
|
|
71
|
-
|
|
72
|
-
var connDelay = typeof authData.connDelay === 'number' && authData.connDelay >= 0 ? authData.connDelay : 60;
|
|
73
|
-
log.info("Refreshing streaming token in " + refreshTokenDelay + " seconds, and connecting streaming in " + connDelay + " seconds");
|
|
74
|
-
timeoutIdTokenRefresh = setTimeout(connectPush, refreshTokenDelay * 1000);
|
|
75
|
-
timeoutIdSseOpen = setTimeout(function () {
|
|
76
|
-
// halt if disconnected
|
|
77
|
-
if (disconnected) return;
|
|
78
|
-
sseClient.open(authData);
|
|
79
|
-
}, connDelay * 1000);
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
function connectPush() {
|
|
83
|
-
// Halt connecting in case `stop/disconnectPush` has been called
|
|
84
|
-
if (disconnected) return;
|
|
85
|
-
log.info((disconnected === undefined ? 'Connecting' : 'Re-connecting') + " to push streaming.");
|
|
86
|
-
disconnected = false;
|
|
87
|
-
var userKeys = clientContexts ? Object.keys(clientContexts) : undefined;
|
|
88
|
-
authenticate(settings, userKeys).then(function (authData) {
|
|
89
|
-
if (disconnected) return; // 'pushEnabled: false' is handled as a PUSH_NONRETRYABLE_ERROR instead of PUSH_SUBSYSTEM_DOWN, in order to
|
|
90
|
-
// close the sseClient in case the org has been bloqued while the instance was connected to streaming
|
|
91
|
-
|
|
92
|
-
if (!authData.pushEnabled) {
|
|
93
|
-
log.info('Streaming is not available. Switching to polling mode.');
|
|
94
|
-
pushEmitter.emit(PUSH_NONRETRYABLE_ERROR);
|
|
95
|
-
return;
|
|
96
|
-
} // don't open SSE connection if a new shared client was added, since it means that a new authentication is taking place
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
if (userKeys && userKeys.length < Object.keys(clientContexts).length) return; // Schedule SSE connection and refresh token
|
|
100
|
-
|
|
101
|
-
scheduleTokenRefreshAndSse(authData);
|
|
102
|
-
}).catch(function (error) {
|
|
103
|
-
if (disconnected) return;
|
|
104
|
-
log.error("Failed to authenticate for streaming. Error: " + error.message + "."); // Handle 4XX HTTP errors: 401 (invalid API Key) or 400 (using incorrect API Key, i.e., client-side API Key on server-side)
|
|
105
|
-
|
|
106
|
-
if (error.statusCode >= 400 && error.statusCode < 500) {
|
|
107
|
-
pushEmitter.emit(PUSH_NONRETRYABLE_ERROR);
|
|
108
|
-
return;
|
|
109
|
-
} // Handle other HTTP and network errors as recoverable errors
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
pushEmitter.emit(PUSH_RETRYABLE_ERROR);
|
|
113
|
-
});
|
|
114
|
-
} // close SSE connection and cancel scheduled tasks
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
function disconnectPush() {
|
|
118
|
-
// Halt disconnecting, just to avoid redundant logs if called multiple times
|
|
119
|
-
if (disconnected) return;
|
|
120
|
-
disconnected = true;
|
|
121
|
-
sseClient.close();
|
|
122
|
-
log.info('Disconnecting from push streaming.');
|
|
123
|
-
if (timeoutIdTokenRefresh) clearTimeout(timeoutIdTokenRefresh);
|
|
124
|
-
if (timeoutIdSseOpen) clearTimeout(timeoutIdSseOpen);
|
|
125
|
-
connectPushRetryBackoff.reset();
|
|
126
|
-
stopWorkers();
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
pushEmitter.on(PUSH_SUBSYSTEM_DOWN, stopWorkers); // Only required when streaming connects after a PUSH_RETRYABLE_ERROR.
|
|
130
|
-
// Otherwise it is unnecessary (e.g, STREAMING_RESUMED).
|
|
131
|
-
|
|
132
|
-
pushEmitter.on(PUSH_SUBSYSTEM_UP, function () {
|
|
133
|
-
connectPushRetryBackoff.reset();
|
|
134
|
-
stopWorkers();
|
|
135
|
-
});
|
|
136
|
-
/** Fallbacking without retry due to STREAMING_DISABLED control event, 'pushEnabled: false', and non-recoverable SSE and Authentication errors */
|
|
137
|
-
|
|
138
|
-
pushEmitter.on(PUSH_NONRETRYABLE_ERROR, function handleNonRetryableError() {
|
|
139
|
-
// Note: `stopWorkers` is been called twice, but it is not harmful
|
|
140
|
-
disconnectPush();
|
|
141
|
-
pushEmitter.emit(PUSH_SUBSYSTEM_DOWN); // no harm if polling already
|
|
142
|
-
});
|
|
143
|
-
/** Fallbacking with retry due to recoverable SSE and Authentication errors */
|
|
144
|
-
|
|
145
|
-
pushEmitter.on(PUSH_RETRYABLE_ERROR, function handleRetryableError() {
|
|
146
|
-
// HTTP or network error in SSE connection
|
|
147
|
-
// SSE connection is closed to avoid repeated errors due to retries
|
|
148
|
-
sseClient.close(); // retry streaming reconnect with backoff algorithm
|
|
149
|
-
|
|
150
|
-
var delayInMillis = connectPushRetryBackoff.scheduleCall();
|
|
151
|
-
log.info("Attempting to reconnect in " + delayInMillis / 1000 + " seconds.");
|
|
152
|
-
pushEmitter.emit(PUSH_SUBSYSTEM_DOWN); // no harm if polling already
|
|
153
|
-
});
|
|
154
|
-
/** STREAMING_RESET notification. Unlike a PUSH_RETRYABLE_ERROR, it doesn't emit PUSH_SUBSYSTEM_DOWN to fallback polling */
|
|
155
|
-
|
|
156
|
-
pushEmitter.on(ControlTypes.STREAMING_RESET, function handleStreamingReset() {
|
|
157
|
-
if (disconnected) return; // should never happen
|
|
158
|
-
// Minimum required clean-up.
|
|
159
|
-
// `disconnectPush` cannot be called because it sets `disconnected` and thus `connectPush` will not execute
|
|
160
|
-
|
|
161
|
-
if (timeoutIdTokenRefresh) clearTimeout(timeoutIdTokenRefresh);
|
|
162
|
-
connectPush();
|
|
163
|
-
});
|
|
164
|
-
/** Functions related to synchronization (Queues and Workers in the spec) */
|
|
165
|
-
|
|
166
|
-
var producer = context.get(context.constants.PRODUCER);
|
|
167
|
-
var splitUpdateWorker = new SplitUpdateWorker(storage.splits, producer, splitsEventEmitter);
|
|
168
|
-
var segmentUpdateWorker; // used in Node
|
|
169
|
-
// cancel scheduled fetch retries of Split, Segment, and MySegment Update Workers
|
|
170
|
-
|
|
171
|
-
function stopWorkers() {
|
|
172
|
-
splitUpdateWorker.backoff.reset();
|
|
173
|
-
if (segmentUpdateWorker) segmentUpdateWorker.backoff.reset();
|
|
174
|
-
forOwn(clients, function (_ref) {
|
|
175
|
-
var worker = _ref.worker;
|
|
176
|
-
return worker.backoff.reset();
|
|
177
|
-
});
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
pushEmitter.on(SPLIT_KILL, splitUpdateWorker.killSplit);
|
|
181
|
-
pushEmitter.on(SPLIT_UPDATE, splitUpdateWorker.put);
|
|
182
|
-
|
|
183
|
-
if (clientContexts) {
|
|
184
|
-
// browser
|
|
185
|
-
pushEmitter.on(MY_SEGMENTS_UPDATE, function handleMySegmentsUpdate(parsedData, channel) {
|
|
186
|
-
var userKeyHash = channel.split('_')[2];
|
|
187
|
-
var userKey = userKeyHashes[userKeyHash];
|
|
188
|
-
|
|
189
|
-
if (userKey && clientContexts[userKey]) {
|
|
190
|
-
// check context since it can be undefined if client has been destroyed
|
|
191
|
-
var mySegmentSync = clientContexts[userKey].get(context.constants.MY_SEGMENTS_CHANGE_WORKER, true);
|
|
192
|
-
mySegmentSync && mySegmentSync.put(parsedData.changeNumber, parsedData.includesPayload ? parsedData.segmentList ? parsedData.segmentList : [] : undefined);
|
|
193
|
-
}
|
|
194
|
-
});
|
|
195
|
-
pushEmitter.on(MY_SEGMENTS_UPDATE_V2, function handleMySegmentsUpdate(parsedData) {
|
|
196
|
-
switch (parsedData.u) {
|
|
197
|
-
case BoundedFetchRequest:
|
|
198
|
-
{
|
|
199
|
-
var bitmap;
|
|
200
|
-
|
|
201
|
-
try {
|
|
202
|
-
bitmap = parseBitmap(parsedData.d, parsedData.c);
|
|
203
|
-
} catch (e) {
|
|
204
|
-
log.warn(fallbackWarning('BoundedFetchRequest', e));
|
|
205
|
-
break;
|
|
206
|
-
}
|
|
207
|
-
|
|
208
|
-
forOwn(clients, function (_ref2) {
|
|
209
|
-
var hash64 = _ref2.hash64,
|
|
210
|
-
worker = _ref2.worker;
|
|
211
|
-
|
|
212
|
-
if (isInBitmap(bitmap, hash64.hex)) {
|
|
213
|
-
worker.put(parsedData.changeNumber); // fetch mySegments
|
|
214
|
-
}
|
|
215
|
-
});
|
|
216
|
-
return;
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
case KeyList:
|
|
220
|
-
{
|
|
221
|
-
var keyList, added, removed;
|
|
222
|
-
|
|
223
|
-
try {
|
|
224
|
-
keyList = parseKeyList(parsedData.d, parsedData.c);
|
|
225
|
-
added = new _Set(keyList.a);
|
|
226
|
-
removed = new _Set(keyList.r);
|
|
227
|
-
} catch (e) {
|
|
228
|
-
log.warn(fallbackWarning('KeyList', e));
|
|
229
|
-
break;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
forOwn(clients, function (_ref3) {
|
|
233
|
-
var hash64 = _ref3.hash64,
|
|
234
|
-
worker = _ref3.worker;
|
|
235
|
-
var add = added.has(hash64.dec) ? true : removed.has(hash64.dec) ? false : undefined;
|
|
236
|
-
|
|
237
|
-
if (add !== undefined) {
|
|
238
|
-
worker.put(parsedData.changeNumber, {
|
|
239
|
-
name: parsedData.segmentName,
|
|
240
|
-
add: add
|
|
241
|
-
});
|
|
242
|
-
}
|
|
243
|
-
});
|
|
244
|
-
return;
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
case SegmentRemoval:
|
|
248
|
-
if (!parsedData.segmentName) {
|
|
249
|
-
log.warn(fallbackWarning('SegmentRemoval', 'No segment name was provided'));
|
|
250
|
-
break;
|
|
251
|
-
}
|
|
252
|
-
|
|
253
|
-
forOwn(clients, function (_ref4) {
|
|
254
|
-
var worker = _ref4.worker;
|
|
255
|
-
worker.put(parsedData.changeNumber, {
|
|
256
|
-
name: parsedData.segmentName,
|
|
257
|
-
add: false
|
|
258
|
-
});
|
|
259
|
-
});
|
|
260
|
-
return;
|
|
261
|
-
} // `UpdateStrategy.UnboundedFetchRequest` and fallbacks of other cases
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
forOwn(clients, function (_ref5) {
|
|
265
|
-
var worker = _ref5.worker;
|
|
266
|
-
worker.put(parsedData.changeNumber);
|
|
267
|
-
});
|
|
268
|
-
});
|
|
269
|
-
} else {
|
|
270
|
-
// node
|
|
271
|
-
segmentUpdateWorker = new SegmentUpdateWorker(storage.segments, producer);
|
|
272
|
-
pushEmitter.on(SEGMENT_UPDATE, segmentUpdateWorker.put);
|
|
273
|
-
}
|
|
274
|
-
|
|
275
|
-
return objectAssign( // Expose Event Emitter functionality and Event constants
|
|
276
|
-
Object.create(pushEmitter), {
|
|
277
|
-
// Expose functionality for starting and stoping push mode:
|
|
278
|
-
stop: disconnectPush,
|
|
279
|
-
// `handleNonRetryableError` cannot be used as `stop`, because it emits PUSH_SUBSYSTEM_DOWN event, which start polling.
|
|
280
|
-
// used in node
|
|
281
|
-
start: connectPush,
|
|
282
|
-
// used in browser
|
|
283
|
-
startNewClient: function startNewClient(userKey, context) {
|
|
284
|
-
var hash = hashUserKey(userKey);
|
|
285
|
-
var storage = context.get(context.constants.STORAGE);
|
|
286
|
-
var producer = context.get(context.constants.PRODUCER);
|
|
287
|
-
|
|
288
|
-
if (!userKeyHashes[hash]) {
|
|
289
|
-
userKeyHashes[hash] = userKey;
|
|
290
|
-
connectForNewClient = true; // we must reconnect on start, to listen the channel for the new user key
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
var mySegmentSync = new SegmentUpdateWorker(storage.segments, producer);
|
|
294
|
-
clients[userKey] = {
|
|
295
|
-
worker: mySegmentSync,
|
|
296
|
-
hash64: hash64(userKey)
|
|
297
|
-
};
|
|
298
|
-
context.put(context.constants.MY_SEGMENTS_CHANGE_WORKER, mySegmentSync); // Reconnects in case of a new client.
|
|
299
|
-
// Run in next event-loop cycle to save authentication calls
|
|
300
|
-
// in case the user is creating several clients in the current cycle.
|
|
301
|
-
|
|
302
|
-
setTimeout(function checkForReconnect() {
|
|
303
|
-
if (connectForNewClient) {
|
|
304
|
-
connectForNewClient = false;
|
|
305
|
-
connectPush();
|
|
306
|
-
}
|
|
307
|
-
}, 0);
|
|
308
|
-
},
|
|
309
|
-
removeClient: function removeClient(userKey) {
|
|
310
|
-
var hash = hashUserKey(userKey);
|
|
311
|
-
delete userKeyHashes[hash];
|
|
312
|
-
delete clients[userKey];
|
|
313
|
-
}
|
|
314
|
-
});
|
|
315
|
-
}
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import { algorithms } from '../../utils/decompress';
|
|
2
|
-
import { decodeFromBase64 } from '../../utils/base64';
|
|
3
|
-
var GZIP = 1;
|
|
4
|
-
var ZLIB = 2;
|
|
5
|
-
|
|
6
|
-
function Uint8ArrayToString(myUint8Arr) {
|
|
7
|
-
return String.fromCharCode.apply(null, myUint8Arr);
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
function StringToUint8Array(myString) {
|
|
11
|
-
var charCodes = myString.split('').map(function (e) {
|
|
12
|
-
return e.charCodeAt();
|
|
13
|
-
});
|
|
14
|
-
return new Uint8Array(charCodes);
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* Decode and decompress 'data' with 'compression' algorithm
|
|
18
|
-
*
|
|
19
|
-
* @param {string} data
|
|
20
|
-
* @param {number} compression 1 GZIP, 2 ZLIB
|
|
21
|
-
* @returns {Uint8Array}
|
|
22
|
-
* @throws if data string cannot be decoded, decompressed or the provided compression value is invalid (not 1 or 2)
|
|
23
|
-
*/
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
function decompress(data, compression) {
|
|
27
|
-
var compressData = decodeFromBase64(data);
|
|
28
|
-
var binData = StringToUint8Array(compressData);
|
|
29
|
-
if (typeof algorithms === 'string') throw new Error(algorithms);
|
|
30
|
-
if (compression === GZIP) return algorithms.gunzipSync(binData);
|
|
31
|
-
if (compression === ZLIB) return algorithms.unzlibSync(binData);
|
|
32
|
-
throw new Error("Invalid compression algorithm #" + compression);
|
|
33
|
-
}
|
|
34
|
-
/**
|
|
35
|
-
* Decode, decompress and parse the provided 'data' into a KeyList object
|
|
36
|
-
*
|
|
37
|
-
* @param {string} data
|
|
38
|
-
* @param {number} compression
|
|
39
|
-
* @returns {{a?: string[], r?: string[] }}
|
|
40
|
-
* @throws if data string cannot be decoded, decompressed or parsed
|
|
41
|
-
*/
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
export function parseKeyList(data, compression) {
|
|
45
|
-
var binKeyList = decompress(data, compression);
|
|
46
|
-
var strKeyList = Uint8ArrayToString(binKeyList); // replace numbers to strings, to avoid losing precision
|
|
47
|
-
|
|
48
|
-
return JSON.parse(strKeyList.replace(/\d+/g, '"$&"'));
|
|
49
|
-
}
|
|
50
|
-
/**
|
|
51
|
-
* Decode, decompress and parse the provided 'data' into a Bitmap object
|
|
52
|
-
*
|
|
53
|
-
* @param {string} data
|
|
54
|
-
* @param {number} compression
|
|
55
|
-
* @returns {Uint8Array}
|
|
56
|
-
* @throws if data string cannot be decoded or decompressed
|
|
57
|
-
*/
|
|
58
|
-
|
|
59
|
-
export function parseBitmap(data, compression) {
|
|
60
|
-
return decompress(data, compression);
|
|
61
|
-
}
|
|
62
|
-
/**
|
|
63
|
-
* Check if the 'bitmap' bit at 'hash64hex' position is 1
|
|
64
|
-
*
|
|
65
|
-
* @param {Uint8Array} bitmap
|
|
66
|
-
* @param {string} hash64hex 16-chars string, representing a number in hexa
|
|
67
|
-
* @returns {boolean}
|
|
68
|
-
*/
|
|
69
|
-
|
|
70
|
-
export function isInBitmap(bitmap, hash64hex) {
|
|
71
|
-
// using the lowest 32 bits as index, to avoid losing precision when converting to number
|
|
72
|
-
var index = parseInt(hash64hex.slice(8), 16) % (bitmap.length * 8);
|
|
73
|
-
var internal = Math.floor(index / 8);
|
|
74
|
-
var offset = index % 8;
|
|
75
|
-
return (bitmap[internal] & 1 << offset) > 0;
|
|
76
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import getEventSource from '../../../services/getEventSource/browser';
|
|
2
|
-
/**
|
|
3
|
-
* Check if the JS environment has the necessary features to run in PUSH mode,
|
|
4
|
-
* i.e., EventSource, base64 encoder and decoder.
|
|
5
|
-
*
|
|
6
|
-
* @return {boolean} if push is supported
|
|
7
|
-
*/
|
|
8
|
-
|
|
9
|
-
export function checkPushRequirements(logger) {
|
|
10
|
-
var esReference = getEventSource();
|
|
11
|
-
|
|
12
|
-
if (!esReference) {
|
|
13
|
-
logger.warn('EventSource API is not available. Falling back to polling mode.');
|
|
14
|
-
return false;
|
|
15
|
-
}
|
|
16
|
-
|
|
17
|
-
if (typeof atob !== 'function' || typeof btoa !== 'function') {
|
|
18
|
-
logger.warn('"atob" and "btoa" functions for Base64 encoding are not available. Falling back to polling mode.');
|
|
19
|
-
return false;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
return true;
|
|
23
|
-
}
|