@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,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
|
-
}
|
package/src/sync/constants.js
DELETED
|
@@ -1,43 +0,0 @@
|
|
|
1
|
-
// time for refresh token
|
|
2
|
-
export const SECONDS_BEFORE_EXPIRATION = 600;
|
|
3
|
-
|
|
4
|
-
// Internal SDK events, subscribed by SyncManager and PushManager
|
|
5
|
-
/**
|
|
6
|
-
* emitted on SSE and Authenticate non-recoverable errors, STREAMING_DISABLED control notification and authentication with pushEnabled false
|
|
7
|
-
* triggers `handleNonRetryableError` call
|
|
8
|
-
*/
|
|
9
|
-
export const PUSH_NONRETRYABLE_ERROR = 'PUSH_NONRETRYABLE_ERROR';
|
|
10
|
-
/**
|
|
11
|
-
* emitted on SSE and Authenticate recoverable errors
|
|
12
|
-
* triggers `handleRetryableError` call
|
|
13
|
-
*/
|
|
14
|
-
export const PUSH_RETRYABLE_ERROR = 'PUSH_RETRYABLE_ERROR';
|
|
15
|
-
/**
|
|
16
|
-
* emitted on STREAMING_RESUMED control notification, OCCUPANCY different than 0, and SSE onopen event
|
|
17
|
-
* triggers `stopPollingAndSyncAll` call
|
|
18
|
-
*/
|
|
19
|
-
export const PUSH_SUBSYSTEM_UP = 'PUSH_SUBSYSTEM_UP';
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* emitted on STREAMING_PAUSED control notification, OCCUPANCY equal to 0, PUSH_NONRETRYABLE_ERROR and PUSH_RETRYABLE_ERROR events.
|
|
23
|
-
* triggers `startPolling` and `stopWorkers` calls
|
|
24
|
-
*/
|
|
25
|
-
export const PUSH_SUBSYSTEM_DOWN = 'PUSH_SUBSYSTEM_DOWN';
|
|
26
|
-
|
|
27
|
-
// Update-type push notifications, handled by NotificationProcessor
|
|
28
|
-
export const MY_SEGMENTS_UPDATE = 'MY_SEGMENTS_UPDATE';
|
|
29
|
-
export const MY_SEGMENTS_UPDATE_V2 = 'MY_SEGMENTS_UPDATE_V2';
|
|
30
|
-
export const SEGMENT_UPDATE = 'SEGMENT_UPDATE';
|
|
31
|
-
export const SPLIT_KILL = 'SPLIT_KILL';
|
|
32
|
-
export const SPLIT_UPDATE = 'SPLIT_UPDATE';
|
|
33
|
-
|
|
34
|
-
// Control-type push notifications, handled by NotificationKeeper
|
|
35
|
-
export const CONTROL = 'CONTROL';
|
|
36
|
-
export const OCCUPANCY = 'OCCUPANCY';
|
|
37
|
-
|
|
38
|
-
export const ControlTypes = {
|
|
39
|
-
STREAMING_DISABLED: 'STREAMING_DISABLED',
|
|
40
|
-
STREAMING_PAUSED: 'STREAMING_PAUSED',
|
|
41
|
-
STREAMING_RESUMED: 'STREAMING_RESUMED',
|
|
42
|
-
STREAMING_RESET: 'STREAMING_RESET'
|
|
43
|
-
};
|
package/src/sync/node.js
DELETED
|
@@ -1,66 +0,0 @@
|
|
|
1
|
-
import PushManagerFactory from './PushManager';
|
|
2
|
-
import FullProducerFactory from '../producer';
|
|
3
|
-
import logFactory from '../utils/logger';
|
|
4
|
-
import { PUSH_SUBSYSTEM_DOWN, PUSH_SUBSYSTEM_UP } from './constants';
|
|
5
|
-
const log = logFactory('splitio-sync:sync-manager');
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* Factory of SyncManager for node
|
|
9
|
-
*
|
|
10
|
-
* @param context main client context
|
|
11
|
-
*/
|
|
12
|
-
export default function NodeSyncManagerFactory(context) {
|
|
13
|
-
|
|
14
|
-
const producer = FullProducerFactory(context);
|
|
15
|
-
const settings = context.get(context.constants.SETTINGS);
|
|
16
|
-
|
|
17
|
-
// add producer into the context before creating the PushManager
|
|
18
|
-
context.put(context.constants.PRODUCER, producer);
|
|
19
|
-
const pushManager = settings.streamingEnabled ? PushManagerFactory(context) : undefined;
|
|
20
|
-
|
|
21
|
-
function startPolling() {
|
|
22
|
-
if (!producer.isRunning()) {
|
|
23
|
-
log.info('Streaming not available. Starting periodic fetch of data.');
|
|
24
|
-
producer.start();
|
|
25
|
-
} else {
|
|
26
|
-
log.info('Streaming couldn\'t connect. Continue periodic fetch of data.');
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
function stopPollingAndSyncAll() {
|
|
31
|
-
log.info('PUSH (re)connected. Syncing and stopping periodic fetch of data.');
|
|
32
|
-
// if polling, stop
|
|
33
|
-
if (producer.isRunning())
|
|
34
|
-
producer.stop();
|
|
35
|
-
syncAll();
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
function syncAll() {
|
|
39
|
-
// fetch splits and segments. There is no need to catch this promise (it is handled by `SplitChangesUpdater`)
|
|
40
|
-
producer.synchronizeSplits().then(() => {
|
|
41
|
-
producer.synchronizeSegment();
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
return {
|
|
46
|
-
start() {
|
|
47
|
-
// start syncing
|
|
48
|
-
if (pushManager) {
|
|
49
|
-
syncAll();
|
|
50
|
-
pushManager.on(PUSH_SUBSYSTEM_UP, stopPollingAndSyncAll);
|
|
51
|
-
pushManager.on(PUSH_SUBSYSTEM_DOWN, startPolling);
|
|
52
|
-
setTimeout(pushManager.start); // Run in next event-loop cycle as in browser
|
|
53
|
-
} else {
|
|
54
|
-
producer.start();
|
|
55
|
-
}
|
|
56
|
-
},
|
|
57
|
-
stop() {
|
|
58
|
-
// stop syncing
|
|
59
|
-
if (pushManager)
|
|
60
|
-
pushManager.stop();
|
|
61
|
-
|
|
62
|
-
if (producer.isRunning())
|
|
63
|
-
producer.stop();
|
|
64
|
-
}
|
|
65
|
-
};
|
|
66
|
-
}
|
package/src/sync/package.json
DELETED
package/src/trackers/event.js
DELETED
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
import objectAssign from 'object-assign';
|
|
2
|
-
import logFactory from '../utils/logger';
|
|
3
|
-
import thenable from '../utils/promise/thenable';
|
|
4
|
-
const log = logFactory('splitio-client:event-tracker');
|
|
5
|
-
|
|
6
|
-
function EventTracker(context) {
|
|
7
|
-
const collector = context.get(context.constants.STORAGE).events;
|
|
8
|
-
const integrationsManager = context.get(context.constants.INTEGRATIONS_MANAGER, true);
|
|
9
|
-
|
|
10
|
-
function queueEventsCallback(eventData, tracked) {
|
|
11
|
-
const { eventTypeId, trafficTypeName, key, value, timestamp, properties } = eventData;
|
|
12
|
-
// Logging every prop would be too much.
|
|
13
|
-
const msg = `event of type "${eventTypeId}" for traffic type "${trafficTypeName}". Key: ${key}. Value: ${value}. Timestamp: ${timestamp}. ${properties ? 'With properties.' : 'With no properties.'}`;
|
|
14
|
-
|
|
15
|
-
if (tracked) {
|
|
16
|
-
log.info(`Successfully queued ${msg}`);
|
|
17
|
-
if (integrationsManager) {
|
|
18
|
-
// Wrap in a timeout because we don't want it to be blocking.
|
|
19
|
-
setTimeout(function () {
|
|
20
|
-
// copy of event, to avoid unexpected behaviour if modified by integrations
|
|
21
|
-
const eventDataCopy = objectAssign({}, eventData);
|
|
22
|
-
if (eventData.properties) eventDataCopy.properties = objectAssign({}, eventData.properties);
|
|
23
|
-
// integrationsManager does not throw errors (they are internally handled by each integration module)
|
|
24
|
-
integrationsManager.handleEvent(eventDataCopy);
|
|
25
|
-
}, 0);
|
|
26
|
-
}
|
|
27
|
-
} else {
|
|
28
|
-
log.warn(`Failed to queue ${msg}`);
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
return tracked;
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
return {
|
|
35
|
-
track: function (eventData, size) {
|
|
36
|
-
const tracked = collector.track(eventData, size);
|
|
37
|
-
|
|
38
|
-
if (thenable(tracked)) {
|
|
39
|
-
return tracked.then(queueEventsCallback.bind(null, eventData));
|
|
40
|
-
} else {
|
|
41
|
-
return queueEventsCallback(eventData, tracked);
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
export default EventTracker;
|