@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,104 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
exports.__esModule = true;
|
|
4
|
-
exports.default = notificationKeeperFactory;
|
|
5
|
-
|
|
6
|
-
var _constants = require("../constants");
|
|
7
|
-
|
|
8
|
-
var CONTROL_CHANNEL_REGEXS = [/control_pri$/, /control_sec$/];
|
|
9
|
-
|
|
10
|
-
function notificationKeeperFactory(feedbackLoopEmitter) {
|
|
11
|
-
var channels = CONTROL_CHANNEL_REGEXS.map(function (regex) {
|
|
12
|
-
return {
|
|
13
|
-
regex: regex,
|
|
14
|
-
hasPublishers: true,
|
|
15
|
-
// keep track of publishers presence per channel, in order to compute `hasPublishers`. Init with true, to emit PUSH_SUBSYSTEM_UP if initial OCCUPANCY notifications have 0 publishers
|
|
16
|
-
oTime: -1,
|
|
17
|
-
// keep track of most recent occupancy notification timestamp per channel
|
|
18
|
-
cTime: -1 // keep track of most recent control notification timestamp per channel
|
|
19
|
-
|
|
20
|
-
};
|
|
21
|
-
}); // false if the number of publishers is equal to 0 in all regions
|
|
22
|
-
|
|
23
|
-
var hasPublishers = true; // false if last CONTROL event was STREAMING_PAUSED or STREAMING_DISABLED
|
|
24
|
-
|
|
25
|
-
var hasResumed = true;
|
|
26
|
-
|
|
27
|
-
function getHasPublishers() {
|
|
28
|
-
// computes the value of `hasPublishers`
|
|
29
|
-
return channels.some(function (c) {
|
|
30
|
-
return c.hasPublishers;
|
|
31
|
-
});
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
return {
|
|
35
|
-
handleOpen: function handleOpen() {
|
|
36
|
-
feedbackLoopEmitter.emit(_constants.PUSH_SUBSYSTEM_UP);
|
|
37
|
-
},
|
|
38
|
-
isStreamingUp: function isStreamingUp() {
|
|
39
|
-
return hasResumed && hasPublishers;
|
|
40
|
-
},
|
|
41
|
-
handleOccupancyEvent: function handleOccupancyEvent(publishers, channel, timestamp) {
|
|
42
|
-
for (var i = 0; i < channels.length; i++) {
|
|
43
|
-
var c = channels[i];
|
|
44
|
-
|
|
45
|
-
if (c.regex.test(channel)) {
|
|
46
|
-
if (timestamp > c.oTime) {
|
|
47
|
-
c.oTime = timestamp;
|
|
48
|
-
c.hasPublishers = publishers !== 0;
|
|
49
|
-
var hasPublishersNow = getHasPublishers();
|
|
50
|
-
|
|
51
|
-
if (hasResumed) {
|
|
52
|
-
if (!hasPublishersNow && hasPublishers) {
|
|
53
|
-
feedbackLoopEmitter.emit(_constants.PUSH_SUBSYSTEM_DOWN);
|
|
54
|
-
} else if (hasPublishersNow && !hasPublishers) {
|
|
55
|
-
feedbackLoopEmitter.emit(_constants.PUSH_SUBSYSTEM_UP);
|
|
56
|
-
} // nothing to do when hasResumed === false:
|
|
57
|
-
// streaming is already down for `!hasPublishersNow`, and cannot be up for `hasPublishersNow`
|
|
58
|
-
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
hasPublishers = hasPublishersNow;
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
}
|
|
67
|
-
},
|
|
68
|
-
handleControlEvent: function handleControlEvent(controlType, channel, timestamp) {
|
|
69
|
-
/* STREAMING_RESET event is handled by PushManager directly since it doesn't require
|
|
70
|
-
* tracking timestamp and state like OCCUPANCY or CONTROL. It also ignores previous
|
|
71
|
-
* OCCUPANCY and CONTROL notifications, and whether PUSH_SUBSYSTEM_DOWN has been emitted or not */
|
|
72
|
-
if (controlType === _constants.ControlTypes.STREAMING_RESET) {
|
|
73
|
-
feedbackLoopEmitter.emit(controlType);
|
|
74
|
-
return;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
for (var i = 0; i < channels.length; i++) {
|
|
78
|
-
var c = channels[i];
|
|
79
|
-
|
|
80
|
-
if (c.regex.test(channel)) {
|
|
81
|
-
if (timestamp > c.cTime) {
|
|
82
|
-
c.cTime = timestamp;
|
|
83
|
-
|
|
84
|
-
if (controlType === _constants.ControlTypes.STREAMING_DISABLED) {
|
|
85
|
-
feedbackLoopEmitter.emit(_constants.PUSH_NONRETRYABLE_ERROR);
|
|
86
|
-
} else if (hasPublishers) {
|
|
87
|
-
if (controlType === _constants.ControlTypes.STREAMING_PAUSED && hasResumed) {
|
|
88
|
-
feedbackLoopEmitter.emit(_constants.PUSH_SUBSYSTEM_DOWN);
|
|
89
|
-
} else if (controlType === _constants.ControlTypes.STREAMING_RESUMED && !hasResumed) {
|
|
90
|
-
feedbackLoopEmitter.emit(_constants.PUSH_SUBSYSTEM_UP);
|
|
91
|
-
} // nothing to do when hasPublishers === false:
|
|
92
|
-
// streaming is already down for `STREAMING_PAUSED`, and cannot be up for `STREAMING_RESUMED`
|
|
93
|
-
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
hasResumed = controlType === _constants.ControlTypes.STREAMING_RESUMED;
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}
|
|
103
|
-
};
|
|
104
|
-
}
|
|
@@ -1,39 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
exports.__esModule = true;
|
|
4
|
-
exports.errorParser = errorParser;
|
|
5
|
-
exports.messageParser = messageParser;
|
|
6
|
-
|
|
7
|
-
var _constants = require("../constants");
|
|
8
|
-
|
|
9
|
-
var _lang = require("../../utils/lang");
|
|
10
|
-
|
|
11
|
-
/**
|
|
12
|
-
* Parses the `data` JSON string, if exists, of a given SSE error notifications.
|
|
13
|
-
* HTTP errors handled by Ably (e.g., 400 due to invalid token, 401 due to expired token, 500) have the `data` property.
|
|
14
|
-
* Other network and HTTP errors do not have this property.
|
|
15
|
-
*
|
|
16
|
-
* @param {Object} error
|
|
17
|
-
* @throws {SyntaxError} if `error.data` is an invalid JSON string
|
|
18
|
-
*/
|
|
19
|
-
function errorParser(error) {
|
|
20
|
-
if ((0, _lang.isString)(error.data)) error.parsedData = JSON.parse(error.data); // cannot assign to read only property 'data'
|
|
21
|
-
|
|
22
|
-
return error;
|
|
23
|
-
}
|
|
24
|
-
/**
|
|
25
|
-
* Parses the `data` JSON string of a given SSE message notifications.
|
|
26
|
-
* Also assigns the type OCCUPANCY, if it corresponds, so that all supported messages (e.g., SPLIT_UPDATE, CONTROL) have a type.
|
|
27
|
-
*
|
|
28
|
-
* @param {Object} message
|
|
29
|
-
* @throws {SyntaxError} if `message.data` or `JSON.parse(message.data).data` are invalid JSON strings
|
|
30
|
-
*/
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
function messageParser(message) {
|
|
34
|
-
var messageData = JSON.parse(message.data);
|
|
35
|
-
messageData.parsedData = JSON.parse(messageData.data); // set the event type to OCCUPANCY, to handle all events uniformely
|
|
36
|
-
|
|
37
|
-
if (messageData.name && messageData.name === '[meta]occupancy') messageData.parsedData.type = _constants.OCCUPANCY;
|
|
38
|
-
return messageData;
|
|
39
|
-
}
|
|
@@ -1,121 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.default = SSEHandlerFactory;
|
|
7
|
-
|
|
8
|
-
var _NotificationParser = require("./NotificationParser");
|
|
9
|
-
|
|
10
|
-
var _NotificationKeeper = _interopRequireDefault(require("./NotificationKeeper"));
|
|
11
|
-
|
|
12
|
-
var _constants = require("../constants");
|
|
13
|
-
|
|
14
|
-
var _logger = _interopRequireDefault(require("../../utils/logger"));
|
|
15
|
-
|
|
16
|
-
var log = (0, _logger.default)('splitio-sync:sse-handler');
|
|
17
|
-
|
|
18
|
-
function isRetryableError(error) {
|
|
19
|
-
if (error.parsedData && error.parsedData.code) {
|
|
20
|
-
var code = error.parsedData.code; // 401 errors due to invalid or expired token (e.g., if refresh token coudn't be executed)
|
|
21
|
-
|
|
22
|
-
if (40140 <= code && code <= 40149) return true; // Others 4XX errors (e.g., bad request from the SDK)
|
|
23
|
-
|
|
24
|
-
if (40000 <= code && code <= 49999) return false;
|
|
25
|
-
} // network errors or 5XX HTTP errors
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
return true;
|
|
29
|
-
}
|
|
30
|
-
/**
|
|
31
|
-
* Factory for SSEHandler
|
|
32
|
-
*
|
|
33
|
-
* @param {Object} pushEmitter emitter for emitting events related to feedback-loop & update queues
|
|
34
|
-
*/
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
function SSEHandlerFactory(pushEmitter) {
|
|
38
|
-
var notificationKeeper = (0, _NotificationKeeper.default)(pushEmitter);
|
|
39
|
-
return {
|
|
40
|
-
handleOpen: function handleOpen() {
|
|
41
|
-
notificationKeeper.handleOpen();
|
|
42
|
-
},
|
|
43
|
-
|
|
44
|
-
/* HTTP & Network errors */
|
|
45
|
-
handleError: function handleError(error) {
|
|
46
|
-
var errorWithParsedData = error;
|
|
47
|
-
|
|
48
|
-
try {
|
|
49
|
-
errorWithParsedData = (0, _NotificationParser.errorParser)(error);
|
|
50
|
-
} catch (err) {
|
|
51
|
-
log.warn("Error parsing SSE error notification: " + err);
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
var errorMessage = errorWithParsedData.parsedData && errorWithParsedData.parsedData.message;
|
|
55
|
-
log.error("Fail to connect to streaming" + (errorMessage ? ", with error message: \"" + errorMessage + "\"" : ''));
|
|
56
|
-
|
|
57
|
-
if (isRetryableError(errorWithParsedData)) {
|
|
58
|
-
pushEmitter.emit(_constants.PUSH_RETRYABLE_ERROR);
|
|
59
|
-
} else {
|
|
60
|
-
pushEmitter.emit(_constants.PUSH_NONRETRYABLE_ERROR);
|
|
61
|
-
}
|
|
62
|
-
},
|
|
63
|
-
|
|
64
|
-
/* NotificationProcessor */
|
|
65
|
-
handleMessage: function handleMessage(message) {
|
|
66
|
-
var messageWithParsedData;
|
|
67
|
-
|
|
68
|
-
try {
|
|
69
|
-
messageWithParsedData = (0, _NotificationParser.messageParser)(message);
|
|
70
|
-
} catch (err) {
|
|
71
|
-
log.warn("Error parsing new SSE message notification: " + err);
|
|
72
|
-
return;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
var _messageWithParsedDat = messageWithParsedData,
|
|
76
|
-
parsedData = _messageWithParsedDat.parsedData,
|
|
77
|
-
data = _messageWithParsedDat.data,
|
|
78
|
-
channel = _messageWithParsedDat.channel,
|
|
79
|
-
timestamp = _messageWithParsedDat.timestamp;
|
|
80
|
-
log.debug("New SSE message received, with data: " + data + "."); // we only handle update events if streaming is up.
|
|
81
|
-
|
|
82
|
-
if (!notificationKeeper.isStreamingUp() && [_constants.OCCUPANCY, _constants.CONTROL].indexOf(parsedData.type) === -1) return;
|
|
83
|
-
|
|
84
|
-
switch (parsedData.type) {
|
|
85
|
-
/* update events */
|
|
86
|
-
case _constants.SPLIT_UPDATE:
|
|
87
|
-
pushEmitter.emit(_constants.SPLIT_UPDATE, parsedData.changeNumber);
|
|
88
|
-
break;
|
|
89
|
-
|
|
90
|
-
case _constants.SEGMENT_UPDATE:
|
|
91
|
-
pushEmitter.emit(_constants.SEGMENT_UPDATE, parsedData.changeNumber, parsedData.segmentName);
|
|
92
|
-
break;
|
|
93
|
-
|
|
94
|
-
case _constants.MY_SEGMENTS_UPDATE:
|
|
95
|
-
pushEmitter.emit(_constants.MY_SEGMENTS_UPDATE, parsedData, channel);
|
|
96
|
-
break;
|
|
97
|
-
|
|
98
|
-
case _constants.MY_SEGMENTS_UPDATE_V2:
|
|
99
|
-
pushEmitter.emit(_constants.MY_SEGMENTS_UPDATE_V2, parsedData);
|
|
100
|
-
break;
|
|
101
|
-
|
|
102
|
-
case _constants.SPLIT_KILL:
|
|
103
|
-
pushEmitter.emit(_constants.SPLIT_KILL, parsedData.changeNumber, parsedData.splitName, parsedData.defaultTreatment);
|
|
104
|
-
break;
|
|
105
|
-
|
|
106
|
-
/* occupancy & control events, handled by NotificationManagerKeeper */
|
|
107
|
-
|
|
108
|
-
case _constants.OCCUPANCY:
|
|
109
|
-
notificationKeeper.handleOccupancyEvent(parsedData.metrics.publishers, channel, timestamp);
|
|
110
|
-
break;
|
|
111
|
-
|
|
112
|
-
case _constants.CONTROL:
|
|
113
|
-
notificationKeeper.handleControlEvent(parsedData.controlType, channel, timestamp);
|
|
114
|
-
break;
|
|
115
|
-
|
|
116
|
-
default:
|
|
117
|
-
break;
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
};
|
|
121
|
-
}
|
|
@@ -1,81 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _backoff = _interopRequireDefault(require("../../utils/backoff"));
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* MySegmentUpdateWorker class
|
|
12
|
-
*/
|
|
13
|
-
var MySegmentUpdateWorker = /*#__PURE__*/function () {
|
|
14
|
-
/**
|
|
15
|
-
*
|
|
16
|
-
* @param {Object} mySegmentsStorage
|
|
17
|
-
* @param {Object} mySegmentsProducer
|
|
18
|
-
*/
|
|
19
|
-
function MySegmentUpdateWorker(mySegmentsStorage, mySegmentsProducer) {
|
|
20
|
-
this.mySegmentsStorage = mySegmentsStorage;
|
|
21
|
-
this.mySegmentsProducer = mySegmentsProducer;
|
|
22
|
-
this.maxChangeNumber = 0; // keeps the maximum changeNumber among queued events
|
|
23
|
-
|
|
24
|
-
this.segmentsData = undefined; // keeps the segmentsData (if included in notification payload) from the queued event with maximum changeNumber
|
|
25
|
-
|
|
26
|
-
this.currentChangeNumber = -1; // @TODO: remove once `/mySegments` endpoint provides the changeNumber
|
|
27
|
-
|
|
28
|
-
this.put = this.put.bind(this);
|
|
29
|
-
this.__handleMySegmentUpdateCall = this.__handleMySegmentUpdateCall.bind(this);
|
|
30
|
-
this.backoff = new _backoff.default(this.__handleMySegmentUpdateCall);
|
|
31
|
-
} // Private method
|
|
32
|
-
// Preconditions: this.mySegmentsProducer.isSynchronizingMySegments === false
|
|
33
|
-
// @TODO update this block similar to SplitUpdateWorker, once `/mySegments` endpoint provides the changeNumber
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
var _proto = MySegmentUpdateWorker.prototype;
|
|
37
|
-
|
|
38
|
-
_proto.__handleMySegmentUpdateCall = function __handleMySegmentUpdateCall() {
|
|
39
|
-
var _this = this;
|
|
40
|
-
|
|
41
|
-
if (this.maxChangeNumber > this.currentChangeNumber) {
|
|
42
|
-
this.handleNewEvent = false;
|
|
43
|
-
var currentMaxChangeNumber = this.maxChangeNumber; // fetch mySegments revalidating data if cached
|
|
44
|
-
|
|
45
|
-
this.mySegmentsProducer.synchronizeMySegments(this.segmentsData, true).then(function (result) {
|
|
46
|
-
if (result !== false) // Unlike `Split\SegmentUpdateWorker`, we cannot use `mySegmentsStorage.getChangeNumber` since `/mySegments` endpoint doesn't provide this value.
|
|
47
|
-
_this.currentChangeNumber = Math.max(_this.currentChangeNumber, currentMaxChangeNumber); // use `currentMaxChangeNumber`, in case that `this.maxChangeNumber` was updated during fetch.
|
|
48
|
-
|
|
49
|
-
if (_this.handleNewEvent) {
|
|
50
|
-
_this.__handleMySegmentUpdateCall();
|
|
51
|
-
} else {
|
|
52
|
-
_this.backoff.scheduleCall();
|
|
53
|
-
}
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
/**
|
|
58
|
-
* Invoked by NotificationProcessor on MY_SEGMENTS_UPDATE event
|
|
59
|
-
*
|
|
60
|
-
* @param {number} changeNumber change number of the MY_SEGMENTS_UPDATE notification
|
|
61
|
-
* @param {string[] | { name: string, add: boolean } | undefined} segmentsData might be undefined
|
|
62
|
-
*/
|
|
63
|
-
;
|
|
64
|
-
|
|
65
|
-
_proto.put = function put(changeNumber, segmentsData) {
|
|
66
|
-
// @TODO uncomment next line once `/mySegments` endpoint provides the changeNumber
|
|
67
|
-
// const currentChangeNumber = this.mySegmentsStorage.getChangeNumber();
|
|
68
|
-
if (changeNumber <= this.currentChangeNumber || changeNumber <= this.maxChangeNumber) return;
|
|
69
|
-
this.maxChangeNumber = changeNumber;
|
|
70
|
-
this.handleNewEvent = true;
|
|
71
|
-
this.backoff.reset();
|
|
72
|
-
this.segmentsData = segmentsData;
|
|
73
|
-
if (this.mySegmentsProducer.isSynchronizingMySegments()) return;
|
|
74
|
-
|
|
75
|
-
this.__handleMySegmentUpdateCall();
|
|
76
|
-
};
|
|
77
|
-
|
|
78
|
-
return MySegmentUpdateWorker;
|
|
79
|
-
}();
|
|
80
|
-
|
|
81
|
-
exports.default = MySegmentUpdateWorker;
|
|
@@ -1,86 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _backoff = _interopRequireDefault(require("../../utils/backoff"));
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* SegmentUpdateWorker class
|
|
12
|
-
*/
|
|
13
|
-
var SegmentUpdateWorker = /*#__PURE__*/function () {
|
|
14
|
-
/**
|
|
15
|
-
* @param {Object} segmentsStorage
|
|
16
|
-
* @param {Object} segmentsProducer
|
|
17
|
-
*/
|
|
18
|
-
function SegmentUpdateWorker(segmentsStorage, segmentsProducer) {
|
|
19
|
-
this.segmentsStorage = segmentsStorage;
|
|
20
|
-
this.segmentsProducer = segmentsProducer;
|
|
21
|
-
this.maxChangeNumbers = {};
|
|
22
|
-
this.put = this.put.bind(this);
|
|
23
|
-
this.__handleSegmentUpdateCall = this.__handleSegmentUpdateCall.bind(this);
|
|
24
|
-
this.backoff = new _backoff.default(this.__handleSegmentUpdateCall);
|
|
25
|
-
} // Private method
|
|
26
|
-
// Preconditions: this.segmentsProducer.isSynchronizingSegments === false
|
|
27
|
-
// Approach similar to MySegmentUpdateWorker due to differences on Segments notifications and endpoint changeNumbers
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
var _proto = SegmentUpdateWorker.prototype;
|
|
31
|
-
|
|
32
|
-
_proto.__handleSegmentUpdateCall = function __handleSegmentUpdateCall() {
|
|
33
|
-
var _this = this;
|
|
34
|
-
|
|
35
|
-
var segmentsToFetch = Object.keys(this.maxChangeNumbers).filter(function (segmentName) {
|
|
36
|
-
return _this.maxChangeNumbers[segmentName] > _this.segmentsStorage.getChangeNumber(segmentName);
|
|
37
|
-
});
|
|
38
|
-
|
|
39
|
-
if (segmentsToFetch.length > 0) {
|
|
40
|
-
this.handleNewEvent = false;
|
|
41
|
-
var currentMaxChangeNumbers = segmentsToFetch.map(function (segmentToFetch) {
|
|
42
|
-
return _this.maxChangeNumbers[segmentToFetch];
|
|
43
|
-
}); // fetch segments revalidating data if cached
|
|
44
|
-
|
|
45
|
-
this.segmentsProducer.synchronizeSegment(segmentsToFetch, true).then(function (result) {
|
|
46
|
-
// Unlike `SplitUpdateWorker` where changeNumber is consistent between notification and endpoint, if there is no error,
|
|
47
|
-
// we must clean the `maxChangeNumbers` of those segments that didn't receive a new update notification during the fetch.
|
|
48
|
-
if (result !== false) {
|
|
49
|
-
segmentsToFetch.forEach(function (fetchedSegment, index) {
|
|
50
|
-
if (_this.maxChangeNumbers[fetchedSegment] === currentMaxChangeNumbers[index]) _this.maxChangeNumbers[fetchedSegment] = -1;
|
|
51
|
-
});
|
|
52
|
-
} else {
|
|
53
|
-
// recursive invocation with backoff if there was some error
|
|
54
|
-
_this.backoff.scheduleCall();
|
|
55
|
-
} // immediate recursive invocation if a new notification was queued during fetch
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
if (_this.handleNewEvent) {
|
|
59
|
-
_this.__handleSegmentUpdateCall();
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
/**
|
|
65
|
-
* Invoked by NotificationProcessor on SEGMENT_UPDATE event
|
|
66
|
-
*
|
|
67
|
-
* @param {number} changeNumber change number of the SEGMENT_UPDATE notification
|
|
68
|
-
* @param {string} segmentName segment name of the SEGMENT_UPDATE notification
|
|
69
|
-
*/
|
|
70
|
-
;
|
|
71
|
-
|
|
72
|
-
_proto.put = function put(changeNumber, segmentName) {
|
|
73
|
-
var currentChangeNumber = this.segmentsStorage.getChangeNumber(segmentName);
|
|
74
|
-
if (changeNumber <= currentChangeNumber || changeNumber <= this.maxChangeNumbers[segmentName]) return;
|
|
75
|
-
this.maxChangeNumbers[segmentName] = changeNumber;
|
|
76
|
-
this.handleNewEvent = true;
|
|
77
|
-
this.backoff.reset();
|
|
78
|
-
if (this.segmentsProducer.isSynchronizingSegments()) return;
|
|
79
|
-
|
|
80
|
-
this.__handleSegmentUpdateCall();
|
|
81
|
-
};
|
|
82
|
-
|
|
83
|
-
return SegmentUpdateWorker;
|
|
84
|
-
}();
|
|
85
|
-
|
|
86
|
-
exports.default = SegmentUpdateWorker;
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.default = void 0;
|
|
7
|
-
|
|
8
|
-
var _backoff = _interopRequireDefault(require("../../utils/backoff"));
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* SplitUpdateWorker class
|
|
12
|
-
*/
|
|
13
|
-
var SplitUpdateWorker = /*#__PURE__*/function () {
|
|
14
|
-
/**
|
|
15
|
-
* @param {Object} splitStorage splits cache
|
|
16
|
-
* @param {Object} splitProducer node producer or full browser producer
|
|
17
|
-
* @param {Object} splitsEventEmitter
|
|
18
|
-
*/
|
|
19
|
-
function SplitUpdateWorker(splitStorage, splitProducer, splitsEventEmitter) {
|
|
20
|
-
this.splitStorage = splitStorage;
|
|
21
|
-
this.splitProducer = splitProducer;
|
|
22
|
-
this.maxChangeNumber = 0;
|
|
23
|
-
this.splitsEventEmitter = splitsEventEmitter;
|
|
24
|
-
this.put = this.put.bind(this);
|
|
25
|
-
this.killSplit = this.killSplit.bind(this);
|
|
26
|
-
this.__handleSplitUpdateCall = this.__handleSplitUpdateCall.bind(this);
|
|
27
|
-
this.backoff = new _backoff.default(this.__handleSplitUpdateCall);
|
|
28
|
-
} // Private method
|
|
29
|
-
// Preconditions: this.splitProducer.isSynchronizingSplits === false
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
var _proto = SplitUpdateWorker.prototype;
|
|
33
|
-
|
|
34
|
-
_proto.__handleSplitUpdateCall = function __handleSplitUpdateCall() {
|
|
35
|
-
var _this = this;
|
|
36
|
-
|
|
37
|
-
if (this.maxChangeNumber > this.splitStorage.getChangeNumber()) {
|
|
38
|
-
this.handleNewEvent = false; // fetch splits revalidating data if cached
|
|
39
|
-
|
|
40
|
-
this.splitProducer.synchronizeSplits(true).then(function () {
|
|
41
|
-
if (_this.handleNewEvent) {
|
|
42
|
-
_this.__handleSplitUpdateCall();
|
|
43
|
-
} else {
|
|
44
|
-
// fetch new registered segments for server-side API. Not retrying on error
|
|
45
|
-
if (_this.splitProducer.synchronizeSegment) _this.splitProducer.synchronizeSegment(undefined, false, true);
|
|
46
|
-
|
|
47
|
-
_this.backoff.scheduleCall();
|
|
48
|
-
}
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Invoked by NotificationProcessor on SPLIT_UPDATE event
|
|
54
|
-
*
|
|
55
|
-
* @param {number} changeNumber change number of the SPLIT_UPDATE notification
|
|
56
|
-
*/
|
|
57
|
-
;
|
|
58
|
-
|
|
59
|
-
_proto.put = function put(changeNumber) {
|
|
60
|
-
var currentChangeNumber = this.splitStorage.getChangeNumber();
|
|
61
|
-
if (changeNumber <= currentChangeNumber || changeNumber <= this.maxChangeNumber) return;
|
|
62
|
-
this.maxChangeNumber = changeNumber;
|
|
63
|
-
this.handleNewEvent = true;
|
|
64
|
-
this.backoff.reset();
|
|
65
|
-
if (this.splitProducer.isSynchronizingSplits()) return;
|
|
66
|
-
|
|
67
|
-
this.__handleSplitUpdateCall();
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Invoked by NotificationProcessor on SPLIT_KILL event
|
|
71
|
-
*
|
|
72
|
-
* @param {number} changeNumber change number of the SPLIT_UPDATE notification
|
|
73
|
-
* @param {string} splitName name of split to kill
|
|
74
|
-
* @param {string} defaultTreatment default treatment value
|
|
75
|
-
*/
|
|
76
|
-
;
|
|
77
|
-
|
|
78
|
-
_proto.killSplit = function killSplit(changeNumber, splitName, defaultTreatment) {
|
|
79
|
-
var _this2 = this;
|
|
80
|
-
|
|
81
|
-
// @TODO handle retry due to errors in storage, once we allow the definition of custom async storages
|
|
82
|
-
this.splitStorage.killLocally(splitName, defaultTreatment, changeNumber).then(function (updated) {
|
|
83
|
-
// trigger an SDK_UPDATE if Split was killed locally
|
|
84
|
-
if (updated) _this2.splitsEventEmitter.emit(_this2.splitsEventEmitter.SDK_SPLITS_ARRIVED, true); // queues the SplitChanges fetch (only if changeNumber is newer)
|
|
85
|
-
|
|
86
|
-
_this2.put(changeNumber);
|
|
87
|
-
});
|
|
88
|
-
};
|
|
89
|
-
|
|
90
|
-
return SplitUpdateWorker;
|
|
91
|
-
}();
|
|
92
|
-
|
|
93
|
-
exports.default = SplitUpdateWorker;
|
package/lib/sync/browser.js
DELETED
|
@@ -1,139 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
|
|
3
|
-
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
-
|
|
5
|
-
exports.__esModule = true;
|
|
6
|
-
exports.default = BrowserSyncManagerFactory;
|
|
7
|
-
|
|
8
|
-
var _PushManager = _interopRequireDefault(require("./PushManager"));
|
|
9
|
-
|
|
10
|
-
var _producer = _interopRequireDefault(require("../producer"));
|
|
11
|
-
|
|
12
|
-
var _Partial = _interopRequireDefault(require("../producer/browser/Partial"));
|
|
13
|
-
|
|
14
|
-
var _factory = require("../utils/key/factory");
|
|
15
|
-
|
|
16
|
-
var _lang = require("../utils/lang");
|
|
17
|
-
|
|
18
|
-
var _logger = _interopRequireDefault(require("../utils/logger"));
|
|
19
|
-
|
|
20
|
-
var _constants = require("./constants");
|
|
21
|
-
|
|
22
|
-
var log = (0, _logger.default)('splitio-sync:sync-manager');
|
|
23
|
-
/**
|
|
24
|
-
* Factory of sync manager for browser
|
|
25
|
-
*
|
|
26
|
-
* @param context main client context
|
|
27
|
-
*/
|
|
28
|
-
|
|
29
|
-
function BrowserSyncManagerFactory(mainContext) {
|
|
30
|
-
// map of user keys to client contexts
|
|
31
|
-
var contexts = {};
|
|
32
|
-
var settings = mainContext.get(mainContext.constants.SETTINGS); // call `createInstance` before creating PushManager, since it is in charge of creating the full producer and adding it into the main context.
|
|
33
|
-
|
|
34
|
-
var syncManager = createInstance(false, mainContext);
|
|
35
|
-
var pushManager = settings.streamingEnabled ? (0, _PushManager.default)(mainContext, contexts) : undefined;
|
|
36
|
-
var mainProducer = mainContext.get(mainContext.constants.PRODUCER);
|
|
37
|
-
|
|
38
|
-
function startPolling() {
|
|
39
|
-
if (!mainProducer.isRunning()) {
|
|
40
|
-
log.info('Streaming not available. Starting periodic fetch of data.');
|
|
41
|
-
(0, _lang.forOwn)(contexts, function (context) {
|
|
42
|
-
var producer = context.get(context.constants.PRODUCER);
|
|
43
|
-
producer.start();
|
|
44
|
-
});
|
|
45
|
-
} else {
|
|
46
|
-
log.info('Streaming couldn\'t connect. Continue periodic fetch of data.');
|
|
47
|
-
}
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
function stopPollingAndSyncAll() {
|
|
51
|
-
if (mainProducer.isRunning()) {
|
|
52
|
-
log.info('PUSH (re)connected. Syncing and stopping periodic fetch of data.'); // if polling, stop
|
|
53
|
-
|
|
54
|
-
(0, _lang.forOwn)(contexts, function (context) {
|
|
55
|
-
var producer = context.get(context.constants.PRODUCER);
|
|
56
|
-
producer.stop();
|
|
57
|
-
});
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
syncAll();
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
function syncAll() {
|
|
64
|
-
// fetch splits and segments
|
|
65
|
-
var mainProducer = mainContext.get(mainContext.constants.PRODUCER);
|
|
66
|
-
mainProducer.synchronizeSplits();
|
|
67
|
-
(0, _lang.forOwn)(contexts, function (context) {
|
|
68
|
-
var producer = context.get(context.constants.PRODUCER);
|
|
69
|
-
producer.synchronizeMySegments();
|
|
70
|
-
});
|
|
71
|
-
}
|
|
72
|
-
/**
|
|
73
|
-
* Creates a SyncManager that handles the synchronization of clients (main and shared ones).
|
|
74
|
-
* Internally, it creates the client producer, adds it into its context, and defines the `start` and `stop` methods that handle synchronization.
|
|
75
|
-
*
|
|
76
|
-
* @param {Object} context
|
|
77
|
-
* @param {boolean} isSharedClient
|
|
78
|
-
*/
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
function createInstance(isSharedClient, context) {
|
|
82
|
-
var producer = isSharedClient ? (0, _Partial.default)(context) : (0, _producer.default)(context);
|
|
83
|
-
var settings = context.get(context.constants.SETTINGS); // we need to stringify the user key (or matching key) in case it is not an string, to hash and pass as query param for authentication
|
|
84
|
-
|
|
85
|
-
var userKey = (0, _lang.toString)((0, _factory.matching)(settings.core.key));
|
|
86
|
-
context.put(context.constants.PRODUCER, producer);
|
|
87
|
-
if (contexts[userKey]) log.warn('A client with the same user key has already been created. Only the new instance will be properly synchronized.');
|
|
88
|
-
contexts[userKey] = context;
|
|
89
|
-
return {
|
|
90
|
-
start: function start() {
|
|
91
|
-
// start syncing
|
|
92
|
-
if (pushManager) {
|
|
93
|
-
if (!isSharedClient) {
|
|
94
|
-
syncAll(); // initial syncAll (only when main client is created)
|
|
95
|
-
|
|
96
|
-
pushManager.on(_constants.PUSH_SUBSYSTEM_UP, stopPollingAndSyncAll);
|
|
97
|
-
pushManager.on(_constants.PUSH_SUBSYSTEM_DOWN, startPolling);
|
|
98
|
-
} else {
|
|
99
|
-
if (mainProducer.isRunning()) {
|
|
100
|
-
// if doing polling, we must start the producer periodic fetch of data
|
|
101
|
-
producer.start();
|
|
102
|
-
} else {
|
|
103
|
-
// if not doing polling, we must perform a `producer.synchronizeMySegments` for the initial fetch
|
|
104
|
-
// of segments since `syncAll` was already executed when starting the main client
|
|
105
|
-
producer.synchronizeMySegments();
|
|
106
|
-
}
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
pushManager.startNewClient(userKey, context);
|
|
110
|
-
} else {
|
|
111
|
-
producer.start();
|
|
112
|
-
}
|
|
113
|
-
},
|
|
114
|
-
stop: function stop() {
|
|
115
|
-
var context = contexts[userKey];
|
|
116
|
-
|
|
117
|
-
if (context) {
|
|
118
|
-
// check in case `client.destroy()` has been invoked more than once for the same client
|
|
119
|
-
delete contexts[userKey];
|
|
120
|
-
|
|
121
|
-
if (pushManager) {
|
|
122
|
-
pushManager.removeClient(userKey); // stop push if stoping main client
|
|
123
|
-
|
|
124
|
-
if (!isSharedClient) pushManager.stop(); // We don't reconnect pushmanager when removing a shared client,
|
|
125
|
-
// since it is more costly than continue listening the channel
|
|
126
|
-
}
|
|
127
|
-
|
|
128
|
-
if (producer.isRunning()) producer.stop();
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
};
|
|
132
|
-
} // For the main client we return a SyncManager with 3 methods: start, stop and shared. The last is used to instantiate "partial SyncManagers".
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
syncManager.shared = createInstance.bind(null, true); // pushManager is exposed to close SSE connection in browser on 'unload' DOM event.
|
|
136
|
-
|
|
137
|
-
syncManager.pushManager = pushManager;
|
|
138
|
-
return syncManager;
|
|
139
|
-
}
|