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