@splitsoftware/splitio 10.17.3 → 10.17.4-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/CHANGES.txt +0 -4
- package/es/factory/browser.js +67 -0
- package/es/factory/node.js +63 -0
- package/es/{client → factory}/package.json +0 -0
- package/es/index.js +16 -132
- package/es/platform/EventEmitter.js +386 -0
- package/es/platform/browser.js +10 -0
- package/es/platform/getEventSource/browser.js +3 -0
- package/es/platform/getEventSource/node.js +19 -0
- package/es/{impressions/observer → platform/getEventSource}/package.json +0 -0
- package/es/platform/getFetch/browser.js +4 -0
- package/es/platform/getFetch/node.js +18 -0
- package/es/{integrations → platform/getFetch}/package.json +0 -0
- package/es/platform/node.js +12 -0
- package/es/{listeners → platform}/package.json +0 -0
- package/es/platform/request/options/node.js +13 -0
- package/es/settings/browser.js +20 -0
- package/es/settings/defaults/browser.js +18 -0
- package/es/settings/defaults/node.js +24 -0
- package/es/settings/defaults/version.js +1 -0
- package/es/settings/integrations/browser.js +5 -0
- package/es/settings/node.js +18 -0
- package/es/{producer/offline → settings}/package.json +0 -0
- package/es/settings/runtime/node.js +17 -0
- package/es/settings/storage/browser.js +29 -0
- package/es/settings/storage/node.js +60 -0
- package/es/umd.js +2 -1
- package/lib/factory/browser.js +71 -0
- package/lib/factory/node.js +67 -0
- package/{es/producer → lib/factory}/package.json +0 -0
- package/lib/index.js +19 -155
- package/lib/platform/EventEmitter.js +390 -0
- package/lib/platform/browser.js +13 -0
- package/lib/platform/getEventSource/browser.js +7 -0
- package/lib/platform/getEventSource/node.js +25 -0
- package/{es/services → lib/platform}/getEventSource/package.json +0 -0
- package/lib/platform/getFetch/browser.js +9 -0
- package/lib/platform/getFetch/node.js +23 -0
- package/{es/services → lib/platform}/getFetch/package.json +0 -0
- package/lib/platform/node.js +16 -0
- package/{es/services/request/options → lib/platform}/package.json +0 -0
- package/lib/platform/request/options/node.js +18 -0
- package/lib/settings/browser.js +24 -0
- package/lib/settings/defaults/browser.js +21 -0
- package/lib/settings/defaults/node.js +27 -0
- package/lib/settings/defaults/version.js +4 -0
- package/lib/settings/integrations/browser.js +9 -0
- package/lib/settings/node.js +22 -0
- package/{es/services/splitChanges/offline → lib/settings}/package.json +0 -0
- package/lib/settings/runtime/node.js +22 -0
- package/lib/settings/storage/browser.js +33 -0
- package/lib/settings/storage/node.js +64 -0
- package/lib/umd.js +4 -8
- package/package.json +26 -30
- package/src/.DS_Store +0 -0
- package/src/factory/browser.js +84 -0
- package/src/factory/node.js +78 -0
- package/{es/storage/SegmentCache/InMemory → src/factory}/package.json +0 -0
- package/src/index.js +13 -136
- package/src/platform/.DS_Store +0 -0
- package/src/platform/EventEmitter.js +443 -0
- package/src/platform/browser.js +12 -0
- package/{es/services → src/platform}/getEventSource/browser.js +2 -2
- package/src/{services → platform}/getEventSource/node.js +2 -2
- package/{es/storage → src/platform/getEventSource}/package.json +0 -0
- package/src/{services → platform}/getFetch/browser.js +2 -2
- package/src/{services → platform}/getFetch/node.js +1 -1
- package/{es/sync/PushManager/pushRequirements → src/platform/getFetch}/package.json +0 -0
- package/src/platform/node.js +14 -0
- package/{es/sync/SegmentUpdateWorker → src/platform}/package.json +0 -0
- package/src/platform/request/options/node.js +15 -0
- package/src/settings/.DS_Store +0 -0
- package/src/settings/browser.js +22 -0
- package/{lib/utils → src}/settings/defaults/browser.js +10 -6
- package/{lib/utils → src}/settings/defaults/node.js +6 -6
- package/src/settings/defaults/version.js +1 -0
- package/src/settings/integrations/browser.js +6 -0
- package/src/settings/node.js +20 -0
- package/{es/sync → src/settings}/package.json +0 -0
- package/src/settings/runtime/node.js +21 -0
- package/src/settings/storage/browser.js +43 -0
- package/src/{utils/settings → settings}/storage/node.js +18 -34
- package/src/umd.js +1 -0
- package/types/splitio.d.ts +77 -6
- package/es/client/attributesDecoration.js +0 -116
- package/es/client/browser.js +0 -39
- package/es/client/client.js +0 -155
- package/es/client/inputValidation.js +0 -117
- package/es/client/node.js +0 -6
- package/es/engine/combiners/and.js +0 -54
- package/es/engine/combiners/ifelseif.js +0 -73
- package/es/engine/condition/index.js +0 -62
- package/es/engine/convertions/index.js +0 -29
- package/es/engine/engine/index.js +0 -60
- package/es/engine/engine/legacy.js +0 -77
- package/es/engine/engine/murmur3/common.js +0 -40
- package/es/engine/engine/murmur3/murmur3.js +0 -83
- package/es/engine/engine/murmur3/murmur3_128.js +0 -250
- package/es/engine/engine/murmur3/murmur3_128_x86.js +0 -183
- package/es/engine/engine/murmur3/murmur3_64.js +0 -52
- package/es/engine/engine/murmur3/utfx.js +0 -112
- package/es/engine/evaluator/index.js +0 -111
- package/es/engine/index.js +0 -112
- package/es/engine/matchers/all.js +0 -32
- package/es/engine/matchers/between.js +0 -35
- package/es/engine/matchers/boolean.js +0 -35
- package/es/engine/matchers/cont_all.js +0 -51
- package/es/engine/matchers/cont_any.js +0 -47
- package/es/engine/matchers/cont_str.js +0 -38
- package/es/engine/matchers/dependency.js +0 -50
- package/es/engine/matchers/eq.js +0 -35
- package/es/engine/matchers/eq_set.js +0 -49
- package/es/engine/matchers/ew.js +0 -38
- package/es/engine/matchers/gte.js +0 -35
- package/es/engine/matchers/index.js +0 -65
- package/es/engine/matchers/lte.js +0 -35
- package/es/engine/matchers/part_of.js +0 -49
- package/es/engine/matchers/segment.js +0 -39
- package/es/engine/matchers/string.js +0 -44
- package/es/engine/matchers/sw.js +0 -38
- package/es/engine/matchers/types.js +0 -48
- package/es/engine/matchers/whitelist.js +0 -36
- package/es/engine/parser/index.js +0 -69
- package/es/engine/parser/segments.js +0 -22
- package/es/engine/transforms/matcherGroup.js +0 -43
- package/es/engine/transforms/matchers.js +0 -109
- package/es/engine/transforms/segment.js +0 -28
- package/es/engine/transforms/set.js +0 -20
- package/es/engine/transforms/unaryNumeric.js +0 -20
- package/es/engine/transforms/whitelist.js +0 -22
- package/es/engine/treatments/index.js +0 -67
- package/es/engine/value/index.js +0 -54
- package/es/engine/value/sanitize.js +0 -125
- package/es/events/index.js +0 -65
- package/es/factory/offline.js +0 -50
- package/es/factory/online.js +0 -113
- package/es/impressions/counter.js +0 -52
- package/es/impressions/hasher/buildKey.js +0 -3
- package/es/impressions/hasher/hashImpression128.js +0 -5
- package/es/impressions/hasher/hashImpression32.js +0 -5
- package/es/impressions/observer/browser.js +0 -9
- package/es/impressions/observer/node.js +0 -9
- package/es/impressions/observer/observer.js +0 -21
- package/es/integrations/browser.js +0 -62
- package/es/integrations/ga/GaToSplit.js +0 -246
- package/es/integrations/ga/SplitToGa.js +0 -127
- package/es/integrations/node.js +0 -3
- package/es/listeners/browser.js +0 -157
- package/es/listeners/node.js +0 -65
- package/es/manager/index.js +0 -104
- package/es/metrics/Collectors.js +0 -100
- package/es/metrics/index.js +0 -157
- package/es/producer/browser/Partial.js +0 -103
- package/es/producer/browser.js +0 -70
- package/es/producer/fetcher/MySegments.js +0 -47
- package/es/producer/fetcher/SegmentChanges.js +0 -52
- package/es/producer/fetcher/SplitChanges.js +0 -46
- package/es/producer/node.js +0 -130
- package/es/producer/offline/browser.js +0 -26
- package/es/producer/offline/node.js +0 -26
- package/es/producer/task.js +0 -50
- package/es/producer/updater/MySegments.js +0 -108
- package/es/producer/updater/SegmentChanges.js +0 -135
- package/es/producer/updater/SplitChanges.js +0 -131
- package/es/producer/updater/SplitChangesFromFeatures.js +0 -21
- package/es/producer/updater/SplitChangesFromFileSystem.js +0 -21
- package/es/producer/updater/SplitChangesFromObject.js +0 -73
- package/es/readiness/index.js +0 -123
- package/es/readiness/statusManager.js +0 -114
- package/es/services/auth/auth.js +0 -25
- package/es/services/auth/index.js +0 -2
- package/es/services/events/bulk.js +0 -22
- package/es/services/events/index.js +0 -17
- package/es/services/getEventSource/node.js +0 -18
- package/es/services/getFetch/browser.js +0 -4
- package/es/services/getFetch/node.js +0 -18
- package/es/services/impressions/bulk.js +0 -26
- package/es/services/impressions/count.js +0 -7
- package/es/services/impressions/dto.js +0 -73
- package/es/services/impressions/index.js +0 -17
- package/es/services/impressions/post.js +0 -22
- package/es/services/metrics/counters.js +0 -24
- package/es/services/metrics/dto.js +0 -38
- package/es/services/metrics/index.js +0 -17
- package/es/services/metrics/times.js +0 -24
- package/es/services/mySegments/get.js +0 -26
- package/es/services/mySegments/index.js +0 -17
- package/es/services/request/index.js +0 -43
- package/es/services/request/options/browser.js +0 -18
- package/es/services/request/options/node.js +0 -28
- package/es/services/segmentChanges/get.js +0 -21
- package/es/services/segmentChanges/index.js +0 -17
- package/es/services/splitChanges/get.js +0 -19
- package/es/services/splitChanges/index.js +0 -17
- package/es/services/splitChanges/offline/browser.js +0 -63
- package/es/services/splitChanges/offline/node.js +0 -176
- package/es/services/splitChanges/offline/parseCondition.js +0 -43
- package/es/services/transport/index.js +0 -51
- package/es/storage/AttributesCache/InMemory.js +0 -85
- package/es/storage/BaseMetricsAsyncCache.js +0 -23
- package/es/storage/CountCache/InMemory.js +0 -48
- package/es/storage/CountCache/InRedis.js +0 -42
- package/es/storage/EventsCache/InMemory.js +0 -109
- package/es/storage/EventsCache/InRedis.js +0 -65
- package/es/storage/ImpressionsCache/InMemory.js +0 -71
- package/es/storage/ImpressionsCache/InRedis.js +0 -73
- package/es/storage/Keys.js +0 -125
- package/es/storage/KeysLocalStorage.js +0 -58
- package/es/storage/LatencyCache/InMemory.js +0 -56
- package/es/storage/LatencyCache/InRedis.js +0 -44
- package/es/storage/LatencyCache/findIndex.js +0 -2
- package/es/storage/Meta.js +0 -7
- package/es/storage/RedisAdapter.js +0 -198
- package/es/storage/SegmentCache/InLocalStorage/index.js +0 -162
- package/es/storage/SegmentCache/InMemory/browser.js +0 -107
- package/es/storage/SegmentCache/InMemory/node.js +0 -82
- package/es/storage/SegmentCache/InRedis/index.js +0 -81
- package/es/storage/SplitCache/InLocalStorage.js +0 -332
- package/es/storage/SplitCache/InMemory.js +0 -162
- package/es/storage/SplitCache/InRedis.js +0 -214
- package/es/storage/SplitCache/killLocally.js +0 -35
- package/es/storage/browser.js +0 -101
- package/es/storage/node.js +0 -81
- package/es/sync/AuthClient/index.js +0 -34
- package/es/sync/PushManager/index.js +0 -315
- package/es/sync/PushManager/mySegmentsV2utils.js +0 -76
- package/es/sync/PushManager/pushRequirements/browser.js +0 -23
- package/es/sync/PushManager/pushRequirements/node.js +0 -18
- package/es/sync/SSEClient/index.js +0 -93
- package/es/sync/SSEHandler/NotificationKeeper.js +0 -97
- package/es/sync/SSEHandler/NotificationParser.js +0 -31
- package/es/sync/SSEHandler/index.js +0 -110
- package/es/sync/SegmentUpdateWorker/browser.js +0 -74
- package/es/sync/SegmentUpdateWorker/node.js +0 -79
- package/es/sync/SplitUpdateWorker/index.js +0 -86
- package/es/sync/browser.js +0 -125
- package/es/sync/constants.js +0 -42
- package/es/sync/node.js +0 -60
- package/es/trackers/event.js +0 -53
- package/es/trackers/impressions.js +0 -132
- package/es/utils/backoff/index.js +0 -51
- package/es/utils/base64/browser.js +0 -19
- package/es/utils/base64/node.js +0 -19
- package/es/utils/base64/package.json +0 -4
- package/es/utils/binarySearch/index.js +0 -50
- package/es/utils/constants/index.js +0 -38
- package/es/utils/context/constants.js +0 -30
- package/es/utils/context/index.js +0 -101
- package/es/utils/decompress/index.js +0 -476
- package/es/utils/fn/repeat.js +0 -58
- package/es/utils/inputValidation/apiKey.js +0 -39
- package/es/utils/inputValidation/attribute.js +0 -22
- package/es/utils/inputValidation/attributes.js +0 -19
- package/es/utils/inputValidation/event.js +0 -23
- package/es/utils/inputValidation/eventProperties.js +0 -69
- package/es/utils/inputValidation/eventValue.js +0 -9
- package/es/utils/inputValidation/index.js +0 -11
- package/es/utils/inputValidation/isOperational.js +0 -14
- package/es/utils/inputValidation/key.js +0 -50
- package/es/utils/inputValidation/split.js +0 -47
- package/es/utils/inputValidation/splitFilters.js +0 -121
- package/es/utils/inputValidation/splits.js +0 -27
- package/es/utils/inputValidation/trafficType.js +0 -55
- package/es/utils/jwt/hashUserKey.js +0 -11
- package/es/utils/jwt/index.js +0 -14
- package/es/utils/key/factory.js +0 -38
- package/es/utils/key/parser.js +0 -34
- package/es/utils/labels/index.js +0 -7
- package/es/utils/lang/Errors.js +0 -41
- package/es/utils/lang/Sets.js +0 -114
- package/es/utils/lang/index.js +0 -305
- package/es/utils/localstorage/isAvailable.js +0 -26
- package/es/utils/logger/LoggerFactory.js +0 -86
- package/es/utils/logger/index.js +0 -97
- package/es/utils/lrucache/linkedlist.js +0 -122
- package/es/utils/lrucache/lru.spec.js +0 -24
- package/es/utils/lrucache/lrucache.js +0 -80
- package/es/utils/now/browser.js +0 -27
- package/es/utils/now/node.js +0 -19
- package/es/utils/now/package.json +0 -4
- package/es/utils/promise/thenable.js +0 -3
- package/es/utils/promise/timeout.js +0 -34
- package/es/utils/promise/wrapper.js +0 -58
- package/es/utils/settings/defaults/browser.js +0 -12
- package/es/utils/settings/defaults/node.js +0 -21
- package/es/utils/settings/defaults/package.json +0 -4
- package/es/utils/settings/impressionsMode.js +0 -16
- package/es/utils/settings/index.js +0 -194
- package/es/utils/settings/integrations/browser.js +0 -8
- package/es/utils/settings/integrations/common.js +0 -30
- package/es/utils/settings/integrations/node.js +0 -7
- package/es/utils/settings/integrations/package.json +0 -4
- package/es/utils/settings/language/browser.js +0 -16
- package/es/utils/settings/language/node.js +0 -16
- package/es/utils/settings/language/package.json +0 -4
- package/es/utils/settings/mode.js +0 -10
- package/es/utils/settings/runtime/browser.js +0 -21
- package/es/utils/settings/runtime/node.js +0 -33
- package/es/utils/settings/runtime/package.json +0 -4
- package/es/utils/settings/storage/browser.js +0 -64
- package/es/utils/settings/storage/node.js +0 -86
- package/es/utils/settings/storage/package.json +0 -4
- package/es/utils/splits/usesSegments.js +0 -21
- package/es/utils/time/index.js +0 -8
- package/es/utils/timeTracker/index.js +0 -216
- package/es/utils/timeTracker/timer.js +0 -25
- package/lib/client/attributesDecoration.js +0 -128
- package/lib/client/browser.js +0 -50
- package/lib/client/client.js +0 -174
- package/lib/client/inputValidation.js +0 -129
- package/lib/client/node.js +0 -14
- package/lib/client/package.json +0 -4
- package/lib/engine/combiners/and.js +0 -65
- package/lib/engine/combiners/ifelseif.js +0 -88
- package/lib/engine/condition/index.js +0 -76
- package/lib/engine/convertions/index.js +0 -36
- package/lib/engine/engine/index.js +0 -71
- package/lib/engine/engine/legacy.js +0 -83
- package/lib/engine/engine/murmur3/common.js +0 -52
- package/lib/engine/engine/murmur3/murmur3.js +0 -90
- package/lib/engine/engine/murmur3/murmur3_128.js +0 -256
- package/lib/engine/engine/murmur3/murmur3_128_x86.js +0 -189
- package/lib/engine/engine/murmur3/murmur3_64.js +0 -57
- package/lib/engine/engine/murmur3/utfx.js +0 -121
- package/lib/engine/evaluator/index.js +0 -129
- package/lib/engine/index.js +0 -128
- package/lib/engine/matchers/all.js +0 -41
- package/lib/engine/matchers/between.js +0 -44
- package/lib/engine/matchers/boolean.js +0 -44
- package/lib/engine/matchers/cont_all.js +0 -61
- package/lib/engine/matchers/cont_any.js +0 -57
- package/lib/engine/matchers/cont_str.js +0 -48
- package/lib/engine/matchers/dependency.js +0 -60
- package/lib/engine/matchers/eq.js +0 -44
- package/lib/engine/matchers/eq_set.js +0 -59
- package/lib/engine/matchers/ew.js +0 -48
- package/lib/engine/matchers/gte.js +0 -44
- package/lib/engine/matchers/index.js +0 -90
- package/lib/engine/matchers/lte.js +0 -44
- package/lib/engine/matchers/part_of.js +0 -59
- package/lib/engine/matchers/segment.js +0 -49
- package/lib/engine/matchers/string.js +0 -53
- package/lib/engine/matchers/sw.js +0 -48
- package/lib/engine/matchers/types.js +0 -57
- package/lib/engine/matchers/whitelist.js +0 -46
- package/lib/engine/parser/index.js +0 -84
- package/lib/engine/parser/segments.js +0 -28
- package/lib/engine/transforms/matcherGroup.js +0 -54
- package/lib/engine/transforms/matchers.js +0 -124
- package/lib/engine/transforms/segment.js +0 -34
- package/lib/engine/transforms/set.js +0 -26
- package/lib/engine/transforms/unaryNumeric.js +0 -26
- package/lib/engine/transforms/whitelist.js +0 -28
- package/lib/engine/treatments/index.js +0 -73
- package/lib/engine/value/index.js +0 -64
- package/lib/engine/value/sanitize.js +0 -137
- package/lib/events/index.js +0 -80
- package/lib/factory/offline.js +0 -62
- package/lib/factory/online.js +0 -129
- package/lib/impressions/counter.js +0 -61
- package/lib/impressions/hasher/buildKey.js +0 -8
- package/lib/impressions/hasher/hashImpression128.js +0 -12
- package/lib/impressions/hasher/hashImpression32.js +0 -14
- package/lib/impressions/observer/browser.js +0 -19
- package/lib/impressions/observer/node.js +0 -19
- package/lib/impressions/observer/observer.js +0 -29
- package/lib/impressions/observer/package.json +0 -4
- package/lib/integrations/browser.js +0 -72
- package/lib/integrations/ga/GaToSplit.js +0 -267
- package/lib/integrations/ga/SplitToGa.js +0 -138
- package/lib/integrations/node.js +0 -9
- package/lib/integrations/package.json +0 -4
- package/lib/listeners/browser.js +0 -173
- package/lib/listeners/node.js +0 -74
- package/lib/listeners/package.json +0 -4
- package/lib/manager/index.js +0 -115
- package/lib/metrics/Collectors.js +0 -118
- package/lib/metrics/index.js +0 -182
- package/lib/producer/browser/Partial.js +0 -114
- package/lib/producer/browser.js +0 -82
- package/lib/producer/fetcher/MySegments.js +0 -59
- package/lib/producer/fetcher/SegmentChanges.js +0 -62
- package/lib/producer/fetcher/SplitChanges.js +0 -58
- package/lib/producer/node.js +0 -142
- package/lib/producer/offline/browser.js +0 -35
- package/lib/producer/offline/node.js +0 -35
- package/lib/producer/offline/package.json +0 -4
- package/lib/producer/package.json +0 -4
- package/lib/producer/task.js +0 -61
- package/lib/producer/updater/MySegments.js +0 -119
- package/lib/producer/updater/SegmentChanges.js +0 -148
- package/lib/producer/updater/SplitChanges.js +0 -145
- package/lib/producer/updater/SplitChangesFromFeatures.js +0 -30
- package/lib/producer/updater/SplitChangesFromFileSystem.js +0 -30
- package/lib/producer/updater/SplitChangesFromObject.js +0 -84
- package/lib/readiness/index.js +0 -132
- package/lib/readiness/statusManager.js +0 -124
- package/lib/services/auth/auth.js +0 -32
- package/lib/services/auth/index.js +0 -11
- package/lib/services/events/bulk.js +0 -31
- package/lib/services/events/index.js +0 -26
- package/lib/services/getEventSource/browser.js +0 -8
- package/lib/services/getEventSource/node.js +0 -26
- package/lib/services/getEventSource/package.json +0 -4
- package/lib/services/getFetch/browser.js +0 -12
- package/lib/services/getFetch/node.js +0 -24
- package/lib/services/getFetch/package.json +0 -4
- package/lib/services/impressions/bulk.js +0 -36
- package/lib/services/impressions/count.js +0 -16
- package/lib/services/impressions/dto.js +0 -81
- package/lib/services/impressions/index.js +0 -26
- package/lib/services/impressions/post.js +0 -31
- package/lib/services/metrics/counters.js +0 -33
- package/lib/services/metrics/dto.js +0 -46
- package/lib/services/metrics/index.js +0 -26
- package/lib/services/metrics/times.js +0 -33
- package/lib/services/mySegments/get.js +0 -35
- package/lib/services/mySegments/index.js +0 -26
- package/lib/services/request/index.js +0 -53
- package/lib/services/request/options/browser.js +0 -23
- package/lib/services/request/options/node.js +0 -37
- package/lib/services/request/options/package.json +0 -4
- package/lib/services/segmentChanges/get.js +0 -29
- package/lib/services/segmentChanges/index.js +0 -26
- package/lib/services/splitChanges/get.js +0 -27
- package/lib/services/splitChanges/index.js +0 -26
- package/lib/services/splitChanges/offline/browser.js +0 -71
- package/lib/services/splitChanges/offline/node.js +0 -189
- package/lib/services/splitChanges/offline/package.json +0 -4
- package/lib/services/splitChanges/offline/parseCondition.js +0 -49
- package/lib/services/transport/index.js +0 -62
- package/lib/storage/AttributesCache/InMemory.js +0 -93
- package/lib/storage/BaseMetricsAsyncCache.js +0 -28
- package/lib/storage/CountCache/InMemory.js +0 -54
- package/lib/storage/CountCache/InRedis.js +0 -50
- package/lib/storage/EventsCache/InMemory.js +0 -118
- package/lib/storage/EventsCache/InRedis.js +0 -74
- package/lib/storage/ImpressionsCache/InMemory.js +0 -77
- package/lib/storage/ImpressionsCache/InRedis.js +0 -79
- package/lib/storage/Keys.js +0 -132
- package/lib/storage/KeysLocalStorage.js +0 -69
- package/lib/storage/LatencyCache/InMemory.js +0 -64
- package/lib/storage/LatencyCache/InRedis.js +0 -53
- package/lib/storage/LatencyCache/findIndex.js +0 -12
- package/lib/storage/Meta.js +0 -12
- package/lib/storage/RedisAdapter.js +0 -212
- package/lib/storage/SegmentCache/InLocalStorage/index.js +0 -171
- package/lib/storage/SegmentCache/InMemory/browser.js +0 -113
- package/lib/storage/SegmentCache/InMemory/node.js +0 -89
- package/lib/storage/SegmentCache/InMemory/package.json +0 -4
- package/lib/storage/SegmentCache/InRedis/index.js +0 -87
- package/lib/storage/SplitCache/InLocalStorage.js +0 -344
- package/lib/storage/SplitCache/InMemory.js +0 -172
- package/lib/storage/SplitCache/InRedis.js +0 -224
- package/lib/storage/SplitCache/killLocally.js +0 -42
- package/lib/storage/browser.js +0 -122
- package/lib/storage/node.js +0 -104
- package/lib/storage/package.json +0 -4
- package/lib/sync/AuthClient/index.js +0 -44
- package/lib/sync/PushManager/index.js +0 -340
- package/lib/sync/PushManager/mySegmentsV2utils.js +0 -87
- package/lib/sync/PushManager/pushRequirements/browser.js +0 -30
- package/lib/sync/PushManager/pushRequirements/node.js +0 -25
- package/lib/sync/PushManager/pushRequirements/package.json +0 -4
- package/lib/sync/SSEClient/index.js +0 -101
- package/lib/sync/SSEHandler/NotificationKeeper.js +0 -104
- package/lib/sync/SSEHandler/NotificationParser.js +0 -39
- package/lib/sync/SSEHandler/index.js +0 -121
- package/lib/sync/SegmentUpdateWorker/browser.js +0 -81
- package/lib/sync/SegmentUpdateWorker/node.js +0 -86
- package/lib/sync/SegmentUpdateWorker/package.json +0 -4
- package/lib/sync/SplitUpdateWorker/index.js +0 -93
- package/lib/sync/browser.js +0 -139
- package/lib/sync/constants.js +0 -59
- package/lib/sync/node.js +0 -71
- package/lib/sync/package.json +0 -4
- package/lib/trackers/event.js +0 -64
- package/lib/trackers/impressions.js +0 -146
- package/lib/utils/backoff/index.js +0 -57
- package/lib/utils/base64/browser.js +0 -26
- package/lib/utils/base64/node.js +0 -26
- package/lib/utils/base64/package.json +0 -4
- package/lib/utils/binarySearch/index.js +0 -56
- package/lib/utils/constants/index.js +0 -60
- package/lib/utils/context/constants.js +0 -49
- package/lib/utils/context/index.js +0 -111
- package/lib/utils/decompress/index.js +0 -483
- package/lib/utils/fn/repeat.js +0 -64
- package/lib/utils/inputValidation/apiKey.js +0 -51
- package/lib/utils/inputValidation/attribute.js +0 -32
- package/lib/utils/inputValidation/attributes.js +0 -32
- package/lib/utils/inputValidation/event.js +0 -33
- package/lib/utils/inputValidation/eventProperties.js +0 -78
- package/lib/utils/inputValidation/eventValue.js +0 -19
- package/lib/utils/inputValidation/index.js +0 -48
- package/lib/utils/inputValidation/isOperational.js +0 -25
- package/lib/utils/inputValidation/key.js +0 -59
- package/lib/utils/inputValidation/split.js +0 -60
- package/lib/utils/inputValidation/splitFilters.js +0 -134
- package/lib/utils/inputValidation/splits.js +0 -38
- package/lib/utils/inputValidation/trafficType.js +0 -68
- package/lib/utils/jwt/hashUserKey.js +0 -19
- package/lib/utils/jwt/index.js +0 -19
- package/lib/utils/key/factory.js +0 -46
- package/lib/utils/key/parser.js +0 -42
- package/lib/utils/labels/index.js +0 -18
- package/lib/utils/lang/Errors.js +0 -58
- package/lib/utils/lang/Sets.js +0 -127
- package/lib/utils/lang/index.js +0 -350
- package/lib/utils/localstorage/isAvailable.js +0 -31
- package/lib/utils/logger/LoggerFactory.js +0 -98
- package/lib/utils/logger/index.js +0 -109
- package/lib/utils/lrucache/linkedlist.js +0 -132
- package/lib/utils/lrucache/lru.spec.js +0 -30
- package/lib/utils/lrucache/lrucache.js +0 -88
- package/lib/utils/now/browser.js +0 -33
- package/lib/utils/now/node.js +0 -24
- package/lib/utils/now/package.json +0 -4
- package/lib/utils/promise/thenable.js +0 -10
- package/lib/utils/promise/timeout.js +0 -40
- package/lib/utils/promise/wrapper.js +0 -63
- package/lib/utils/settings/defaults/package.json +0 -4
- package/lib/utils/settings/impressionsMode.js +0 -26
- package/lib/utils/settings/index.js +0 -214
- package/lib/utils/settings/integrations/browser.js +0 -17
- package/lib/utils/settings/integrations/common.js +0 -40
- package/lib/utils/settings/integrations/node.js +0 -13
- package/lib/utils/settings/integrations/package.json +0 -4
- package/lib/utils/settings/language/browser.js +0 -22
- package/lib/utils/settings/language/node.js +0 -22
- package/lib/utils/settings/language/package.json +0 -4
- package/lib/utils/settings/mode.js +0 -16
- package/lib/utils/settings/runtime/browser.js +0 -26
- package/lib/utils/settings/runtime/node.js +0 -43
- package/lib/utils/settings/runtime/package.json +0 -4
- package/lib/utils/settings/storage/browser.js +0 -75
- package/lib/utils/settings/storage/node.js +0 -92
- package/lib/utils/settings/storage/package.json +0 -4
- package/lib/utils/splits/usesSegments.js +0 -27
- package/lib/utils/time/index.js +0 -12
- package/lib/utils/timeTracker/index.js +0 -213
- package/lib/utils/timeTracker/timer.js +0 -33
- package/src/client/attributesDecoration.js +0 -112
- package/src/client/browser.js +0 -41
- package/src/client/client.js +0 -131
- package/src/client/inputValidation.js +0 -130
- package/src/client/node.js +0 -8
- package/src/client/package.json +0 -4
- package/src/engine/combiners/and.js +0 -55
- package/src/engine/combiners/ifelseif.js +0 -74
- package/src/engine/condition/index.js +0 -65
- package/src/engine/convertions/index.js +0 -22
- package/src/engine/engine/index.js +0 -63
- package/src/engine/engine/legacy.js +0 -66
- package/src/engine/engine/murmur3/common.js +0 -54
- package/src/engine/engine/murmur3/murmur3.js +0 -79
- package/src/engine/engine/murmur3/murmur3_128.js +0 -273
- package/src/engine/engine/murmur3/murmur3_128_x86.js +0 -188
- package/src/engine/engine/murmur3/murmur3_64.js +0 -34
- package/src/engine/engine/murmur3/utfx.js +0 -111
- package/src/engine/evaluator/index.js +0 -148
- package/src/engine/index.js +0 -123
- package/src/engine/matchers/all.js +0 -29
- package/src/engine/matchers/between.js +0 -30
- package/src/engine/matchers/boolean.js +0 -29
- package/src/engine/matchers/cont_all.js +0 -40
- package/src/engine/matchers/cont_any.js +0 -35
- package/src/engine/matchers/cont_str.js +0 -31
- package/src/engine/matchers/dependency.js +0 -52
- package/src/engine/matchers/eq.js +0 -30
- package/src/engine/matchers/eq_set.js +0 -37
- package/src/engine/matchers/ew.js +0 -31
- package/src/engine/matchers/gte.js +0 -30
- package/src/engine/matchers/index.js +0 -71
- package/src/engine/matchers/lte.js +0 -30
- package/src/engine/matchers/part_of.js +0 -37
- package/src/engine/matchers/segment.js +0 -41
- package/src/engine/matchers/string.js +0 -39
- package/src/engine/matchers/sw.js +0 -31
- package/src/engine/matchers/types.js +0 -52
- package/src/engine/matchers/whitelist.js +0 -30
- package/src/engine/parser/index.js +0 -79
- package/src/engine/parser/segments.js +0 -31
- package/src/engine/transforms/matcherGroup.js +0 -45
- package/src/engine/transforms/matchers.js +0 -118
- package/src/engine/transforms/segment.js +0 -23
- package/src/engine/transforms/set.js +0 -20
- package/src/engine/transforms/unaryNumeric.js +0 -20
- package/src/engine/transforms/whitelist.js +0 -22
- package/src/engine/treatments/index.js +0 -67
- package/src/engine/value/index.js +0 -53
- package/src/engine/value/sanitize.js +0 -117
- package/src/events/index.js +0 -62
- package/src/factory/offline.js +0 -60
- package/src/factory/online.js +0 -127
- package/src/impressions/counter.js +0 -43
- package/src/impressions/hasher/buildKey.js +0 -3
- package/src/impressions/hasher/hashImpression128.js +0 -6
- package/src/impressions/hasher/hashImpression32.js +0 -6
- package/src/impressions/observer/browser.js +0 -8
- package/src/impressions/observer/node.js +0 -8
- package/src/impressions/observer/observer.js +0 -17
- package/src/impressions/observer/package.json +0 -4
- package/src/integrations/browser.js +0 -57
- package/src/integrations/ga/GaToSplit.js +0 -278
- package/src/integrations/ga/SplitToGa.js +0 -125
- package/src/integrations/node.js +0 -4
- package/src/integrations/package.json +0 -4
- package/src/listeners/browser.js +0 -137
- package/src/listeners/node.js +0 -59
- package/src/listeners/package.json +0 -4
- package/src/manager/index.js +0 -103
- package/src/metrics/Collectors.js +0 -77
- package/src/metrics/index.js +0 -174
- package/src/producer/browser/Partial.js +0 -104
- package/src/producer/browser.js +0 -82
- package/src/producer/fetcher/MySegments.js +0 -40
- package/src/producer/fetcher/SegmentChanges.js +0 -52
- package/src/producer/fetcher/SplitChanges.js +0 -39
- package/src/producer/node.js +0 -142
- package/src/producer/offline/browser.js +0 -28
- package/src/producer/offline/node.js +0 -28
- package/src/producer/offline/package.json +0 -4
- package/src/producer/package.json +0 -4
- package/src/producer/task.js +0 -57
- package/src/producer/updater/MySegments.js +0 -104
- package/src/producer/updater/SegmentChanges.js +0 -126
- package/src/producer/updater/SplitChanges.js +0 -138
- package/src/producer/updater/SplitChangesFromFeatures.js +0 -23
- package/src/producer/updater/SplitChangesFromFileSystem.js +0 -23
- package/src/producer/updater/SplitChangesFromObject.js +0 -81
- package/src/readiness/index.js +0 -125
- package/src/readiness/statusManager.js +0 -121
- package/src/services/auth/auth.js +0 -21
- package/src/services/auth/index.js +0 -3
- package/src/services/events/bulk.js +0 -23
- package/src/services/events/index.js +0 -18
- package/src/services/getEventSource/browser.js +0 -3
- package/src/services/getEventSource/package.json +0 -4
- package/src/services/getFetch/package.json +0 -4
- package/src/services/impressions/bulk.js +0 -26
- package/src/services/impressions/count.js +0 -8
- package/src/services/impressions/dto.js +0 -71
- package/src/services/impressions/index.js +0 -18
- package/src/services/impressions/post.js +0 -23
- package/src/services/metrics/counters.js +0 -25
- package/src/services/metrics/dto.js +0 -44
- package/src/services/metrics/index.js +0 -18
- package/src/services/metrics/times.js +0 -25
- package/src/services/mySegments/get.js +0 -27
- package/src/services/mySegments/index.js +0 -18
- package/src/services/request/index.js +0 -43
- package/src/services/request/options/browser.js +0 -18
- package/src/services/request/options/node.js +0 -30
- package/src/services/request/options/package.json +0 -4
- package/src/services/segmentChanges/get.js +0 -20
- package/src/services/segmentChanges/index.js +0 -18
- package/src/services/splitChanges/get.js +0 -20
- package/src/services/splitChanges/index.js +0 -18
- package/src/services/splitChanges/offline/browser.js +0 -66
- package/src/services/splitChanges/offline/node.js +0 -190
- package/src/services/splitChanges/offline/package.json +0 -4
- package/src/services/splitChanges/offline/parseCondition.js +0 -52
- package/src/services/transport/index.js +0 -44
- package/src/storage/AttributesCache/InMemory.js +0 -76
- package/src/storage/BaseMetricsAsyncCache.js +0 -14
- package/src/storage/CountCache/InMemory.js +0 -48
- package/src/storage/CountCache/InRedis.js +0 -32
- package/src/storage/EventsCache/InMemory.js +0 -99
- package/src/storage/EventsCache/InRedis.js +0 -62
- package/src/storage/ImpressionsCache/InMemory.js +0 -62
- package/src/storage/ImpressionsCache/InRedis.js +0 -65
- package/src/storage/Keys.js +0 -122
- package/src/storage/KeysLocalStorage.js +0 -52
- package/src/storage/LatencyCache/InMemory.js +0 -56
- package/src/storage/LatencyCache/InRedis.js +0 -35
- package/src/storage/LatencyCache/findIndex.js +0 -7
- package/src/storage/Meta.js +0 -7
- package/src/storage/RedisAdapter.js +0 -170
- package/src/storage/SegmentCache/InLocalStorage/index.js +0 -140
- package/src/storage/SegmentCache/InMemory/browser.js +0 -99
- package/src/storage/SegmentCache/InMemory/node.js +0 -84
- package/src/storage/SegmentCache/InMemory/package.json +0 -4
- package/src/storage/SegmentCache/InRedis/index.js +0 -71
- package/src/storage/SplitCache/InLocalStorage.js +0 -324
- package/src/storage/SplitCache/InMemory.js +0 -145
- package/src/storage/SplitCache/InRedis.js +0 -187
- package/src/storage/SplitCache/killLocally.js +0 -33
- package/src/storage/browser.js +0 -110
- package/src/storage/node.js +0 -83
- package/src/storage/package.json +0 -4
- package/src/sync/AuthClient/index.js +0 -31
- package/src/sync/PushManager/index.js +0 -328
- package/src/sync/PushManager/mySegmentsV2utils.js +0 -76
- package/src/sync/PushManager/pushRequirements/browser.js +0 -20
- package/src/sync/PushManager/pushRequirements/node.js +0 -16
- package/src/sync/PushManager/pushRequirements/package.json +0 -4
- package/src/sync/SSEClient/index.js +0 -92
- package/src/sync/SSEHandler/NotificationKeeper.js +0 -90
- package/src/sync/SSEHandler/NotificationParser.js +0 -35
- package/src/sync/SSEHandler/index.js +0 -110
- package/src/sync/SegmentUpdateWorker/browser.js +0 -67
- package/src/sync/SegmentUpdateWorker/node.js +0 -73
- package/src/sync/SegmentUpdateWorker/package.json +0 -4
- package/src/sync/SplitUpdateWorker/index.js +0 -79
- package/src/sync/browser.js +0 -130
- package/src/sync/constants.js +0 -43
- package/src/sync/node.js +0 -66
- package/src/sync/package.json +0 -4
- package/src/trackers/event.js +0 -47
- package/src/trackers/impressions.js +0 -123
- package/src/utils/backoff/index.js +0 -46
- package/src/utils/base64/browser.js +0 -19
- package/src/utils/base64/node.js +0 -19
- package/src/utils/base64/package.json +0 -4
- package/src/utils/binarySearch/index.js +0 -50
- package/src/utils/constants/index.js +0 -41
- package/src/utils/context/constants.js +0 -18
- package/src/utils/context/index.js +0 -84
- package/src/utils/decompress/index.js +0 -428
- package/src/utils/fn/repeat.js +0 -48
- package/src/utils/inputValidation/apiKey.js +0 -42
- package/src/utils/inputValidation/attribute.js +0 -22
- package/src/utils/inputValidation/attributes.js +0 -26
- package/src/utils/inputValidation/event.js +0 -23
- package/src/utils/inputValidation/eventProperties.js +0 -65
- package/src/utils/inputValidation/eventValue.js +0 -11
- package/src/utils/inputValidation/index.js +0 -11
- package/src/utils/inputValidation/isOperational.js +0 -16
- package/src/utils/inputValidation/key.js +0 -53
- package/src/utils/inputValidation/split.js +0 -42
- package/src/utils/inputValidation/splitFilters.js +0 -108
- package/src/utils/inputValidation/splits.js +0 -21
- package/src/utils/inputValidation/trafficType.js +0 -58
- package/src/utils/jwt/hashUserKey.js +0 -11
- package/src/utils/jwt/index.js +0 -15
- package/src/utils/key/factory.js +0 -34
- package/src/utils/key/parser.js +0 -34
- package/src/utils/labels/index.js +0 -7
- package/src/utils/lang/Errors.js +0 -19
- package/src/utils/lang/Sets.js +0 -94
- package/src/utils/lang/index.js +0 -291
- package/src/utils/localstorage/isAvailable.js +0 -26
- package/src/utils/logger/LoggerFactory.js +0 -90
- package/src/utils/logger/index.js +0 -93
- package/src/utils/lrucache/linkedlist.js +0 -116
- package/src/utils/lrucache/lru.spec.js +0 -26
- package/src/utils/lrucache/lrucache.js +0 -49
- package/src/utils/now/browser.js +0 -29
- package/src/utils/now/node.js +0 -21
- package/src/utils/now/package.json +0 -4
- package/src/utils/promise/thenable.js +0 -1
- package/src/utils/promise/timeout.js +0 -38
- package/src/utils/promise/wrapper.js +0 -60
- package/src/utils/settings/defaults/browser.js +0 -12
- package/src/utils/settings/defaults/node.js +0 -21
- package/src/utils/settings/defaults/package.json +0 -4
- package/src/utils/settings/impressionsMode.js +0 -15
- package/src/utils/settings/index.js +0 -217
- package/src/utils/settings/integrations/browser.js +0 -8
- package/src/utils/settings/integrations/common.js +0 -32
- package/src/utils/settings/integrations/node.js +0 -7
- package/src/utils/settings/integrations/package.json +0 -4
- package/src/utils/settings/language/browser.js +0 -17
- package/src/utils/settings/language/node.js +0 -17
- package/src/utils/settings/language/package.json +0 -4
- package/src/utils/settings/mode.js +0 -12
- package/src/utils/settings/runtime/browser.js +0 -22
- package/src/utils/settings/runtime/node.js +0 -34
- package/src/utils/settings/runtime/package.json +0 -4
- package/src/utils/settings/storage/browser.js +0 -70
- package/src/utils/settings/storage/package.json +0 -4
- package/src/utils/splits/usesSegments.js +0 -17
- package/src/utils/time/index.js +0 -8
- package/src/utils/timeTracker/index.js +0 -223
- package/src/utils/timeTracker/timer.js +0 -27
package/src/producer/node.js
DELETED
|
@@ -1,142 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import logFactory from '../utils/logger';
|
|
18
|
-
const log = logFactory('splitio-producer:updater');
|
|
19
|
-
import repeat from '../utils/fn/repeat';
|
|
20
|
-
import SplitChangesUpdater from './updater/SplitChanges';
|
|
21
|
-
import SegmentChangesUpdater from './updater/SegmentChanges';
|
|
22
|
-
|
|
23
|
-
/**
|
|
24
|
-
* Expose start / stop mechanism for pulling data from services.
|
|
25
|
-
*/
|
|
26
|
-
const NodeUpdater = (context) => {
|
|
27
|
-
const splitsUpdater = SplitChangesUpdater(context, true /* tell split updater we are in node */);
|
|
28
|
-
const segmentsUpdater = SegmentChangesUpdater(context);
|
|
29
|
-
const settings = context.get(context.constants.SETTINGS);
|
|
30
|
-
|
|
31
|
-
let stopSplitsUpdate = false;
|
|
32
|
-
let stopSegmentsUpdate = false;
|
|
33
|
-
let splitFetchCompleted = false;
|
|
34
|
-
let isRunning = false;
|
|
35
|
-
let isSynchronizingSplits = false;
|
|
36
|
-
let isSynchronizingSegments = false;
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* @param {boolean | undefined} noCache true to revalidate data to fetch
|
|
40
|
-
*/
|
|
41
|
-
function synchronizeSplits(noCache) {
|
|
42
|
-
isSynchronizingSplits = true;
|
|
43
|
-
// `splitsUpdater` promise always resolves, and with a false value if it fails to fetch or store splits
|
|
44
|
-
return splitsUpdater(0, noCache).then(function (res) {
|
|
45
|
-
// Mark splits as ready (track first successfull call to start downloading segments)
|
|
46
|
-
splitFetchCompleted = true;
|
|
47
|
-
isSynchronizingSplits = false;
|
|
48
|
-
return res;
|
|
49
|
-
});
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* @param {string[] | undefined} segmentNames list of segment names to fetch. By passing `undefined` it fetches the list of segments registered at the storage
|
|
54
|
-
* @param {boolean | undefined} noCache true to revalidate data to fetch on a SEGMENT_UPDATE notifications.
|
|
55
|
-
* @param {boolean | undefined} fetchOnlyNew if true, only fetch the segments that not exists, i.e., which `changeNumber` is equal to -1.
|
|
56
|
-
* This param is used by SplitUpdateWorker on server-side SDK, to fetch new registered segments on SPLIT_UPDATE notifications.
|
|
57
|
-
*/
|
|
58
|
-
function synchronizeSegment(segmentNames, noCache, fetchOnlyNew) {
|
|
59
|
-
isSynchronizingSegments = true;
|
|
60
|
-
// `segmentsUpdater` promise always resolves, and with a false value if it fails to fetch or store some segment
|
|
61
|
-
return segmentsUpdater(segmentNames, noCache, fetchOnlyNew).then(function (res) {
|
|
62
|
-
isSynchronizingSegments = false;
|
|
63
|
-
return res;
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
return {
|
|
68
|
-
// Start periodic fetching (polling)
|
|
69
|
-
start() {
|
|
70
|
-
log.info('Starting NODEJS updater');
|
|
71
|
-
log.debug(`Splits will be refreshed each ${settings.scheduler.featuresRefreshRate} millis`);
|
|
72
|
-
log.debug(`Segments will be refreshed each ${settings.scheduler.segmentsRefreshRate} millis`);
|
|
73
|
-
|
|
74
|
-
// Schedule incremental update of segments only if needed
|
|
75
|
-
const spinUpSegmentUpdater = () => {
|
|
76
|
-
// We must check that Split polling is running (i.e. `stopSplitsUpdate !== false`),
|
|
77
|
-
// in case that `spinUpSegmentUpdater` is called once the client has been destroyed.
|
|
78
|
-
if (stopSplitsUpdate && !stopSegmentsUpdate) {
|
|
79
|
-
stopSegmentsUpdate = repeat(
|
|
80
|
-
scheduleSegmentsUpdate => {
|
|
81
|
-
if (splitFetchCompleted) {
|
|
82
|
-
log.debug('Fetching segments');
|
|
83
|
-
synchronizeSegment().then(() => scheduleSegmentsUpdate());
|
|
84
|
-
} else {
|
|
85
|
-
scheduleSegmentsUpdate();
|
|
86
|
-
}
|
|
87
|
-
},
|
|
88
|
-
settings.scheduler.segmentsRefreshRate
|
|
89
|
-
);
|
|
90
|
-
}
|
|
91
|
-
};
|
|
92
|
-
|
|
93
|
-
stopSplitsUpdate = repeat(
|
|
94
|
-
scheduleSplitsUpdate => {
|
|
95
|
-
log.debug('Fetching splits');
|
|
96
|
-
|
|
97
|
-
synchronizeSplits()
|
|
98
|
-
.then(() => {
|
|
99
|
-
// Spin up the segments update if needed
|
|
100
|
-
spinUpSegmentUpdater();
|
|
101
|
-
// Re-schedule update
|
|
102
|
-
scheduleSplitsUpdate();
|
|
103
|
-
});
|
|
104
|
-
},
|
|
105
|
-
settings.scheduler.featuresRefreshRate
|
|
106
|
-
);
|
|
107
|
-
|
|
108
|
-
isRunning = true;
|
|
109
|
-
},
|
|
110
|
-
|
|
111
|
-
// Stop periodic fetching (polling)
|
|
112
|
-
stop() {
|
|
113
|
-
log.info('Stopping NODEJS updater');
|
|
114
|
-
|
|
115
|
-
stopSplitsUpdate && stopSplitsUpdate();
|
|
116
|
-
stopSplitsUpdate = false; // Mark polling stopped, to be able to call `start` again and to avoid polling segments if `spinUpSegmentUpdater` is called after the client has been destroyed.
|
|
117
|
-
stopSegmentsUpdate && stopSegmentsUpdate();
|
|
118
|
-
stopSegmentsUpdate = false;
|
|
119
|
-
|
|
120
|
-
isRunning = false;
|
|
121
|
-
},
|
|
122
|
-
|
|
123
|
-
// Used by SyncManager to know if running in polling mode.
|
|
124
|
-
isRunning() {
|
|
125
|
-
return isRunning;
|
|
126
|
-
},
|
|
127
|
-
|
|
128
|
-
// Used by SplitUpdateWorker
|
|
129
|
-
isSynchronizingSplits() {
|
|
130
|
-
return isSynchronizingSplits;
|
|
131
|
-
},
|
|
132
|
-
synchronizeSplits,
|
|
133
|
-
|
|
134
|
-
// Used by SegmentUpdateWorker
|
|
135
|
-
isSynchronizingSegments() {
|
|
136
|
-
return isSynchronizingSegments;
|
|
137
|
-
},
|
|
138
|
-
synchronizeSegment
|
|
139
|
-
};
|
|
140
|
-
};
|
|
141
|
-
|
|
142
|
-
export default NodeUpdater;
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import TaskFactory from '../task';
|
|
18
|
-
import FromFeaturesUpdater from '../updater/SplitChangesFromFeatures';
|
|
19
|
-
|
|
20
|
-
const OfflineFeatureProducer = (context) => {
|
|
21
|
-
const settings = context.get(context.constants.SETTINGS);
|
|
22
|
-
const updater = FromFeaturesUpdater(context);
|
|
23
|
-
const updaterTask = TaskFactory(updater, settings.scheduler.offlineRefreshRate);
|
|
24
|
-
|
|
25
|
-
return updaterTask;
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
export default OfflineFeatureProducer;
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import TaskFactory from '../task';
|
|
18
|
-
import FromFileSystemUpdater from '../updater/SplitChangesFromFileSystem';
|
|
19
|
-
|
|
20
|
-
const OfflineFileSystemProducer = (context) => {
|
|
21
|
-
const settings = context.get(context.constants.SETTINGS);
|
|
22
|
-
const updater = FromFileSystemUpdater(context);
|
|
23
|
-
const updaterTask = TaskFactory(updater, settings.scheduler.offlineRefreshRate);
|
|
24
|
-
|
|
25
|
-
return updaterTask;
|
|
26
|
-
};
|
|
27
|
-
|
|
28
|
-
export default OfflineFileSystemProducer;
|
package/src/producer/task.js
DELETED
|
@@ -1,57 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import logFactory from '../utils/logger';
|
|
18
|
-
const log = logFactory('splitio-producer:task');
|
|
19
|
-
import repeat from '../utils/fn/repeat';
|
|
20
|
-
import { getFnName } from '../utils/lang';
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Startable task factory.
|
|
24
|
-
*/
|
|
25
|
-
const TaskFactory = (updater, period) => {
|
|
26
|
-
const updaterName = getFnName(updater);
|
|
27
|
-
let stopUpdater = false;
|
|
28
|
-
|
|
29
|
-
return {
|
|
30
|
-
start() {
|
|
31
|
-
if (!stopUpdater) {
|
|
32
|
-
log.debug(`Starting ${updaterName} refreshing each ${period}`);
|
|
33
|
-
|
|
34
|
-
stopUpdater = repeat(
|
|
35
|
-
reschedule => {
|
|
36
|
-
log.debug(`Running ${updaterName}`);
|
|
37
|
-
updater().then(() => reschedule());
|
|
38
|
-
},
|
|
39
|
-
period
|
|
40
|
-
);
|
|
41
|
-
}
|
|
42
|
-
},
|
|
43
|
-
|
|
44
|
-
stop() {
|
|
45
|
-
log.debug(`Stopping ${updaterName}`);
|
|
46
|
-
|
|
47
|
-
stopUpdater && stopUpdater();
|
|
48
|
-
stopUpdater = false;
|
|
49
|
-
},
|
|
50
|
-
|
|
51
|
-
isRunning() {
|
|
52
|
-
return stopUpdater ? true : false;
|
|
53
|
-
}
|
|
54
|
-
};
|
|
55
|
-
};
|
|
56
|
-
|
|
57
|
-
export default TaskFactory;
|
|
@@ -1,104 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import logFactory from '../../utils/logger';
|
|
18
|
-
import { SplitError } from '../../utils/lang/Errors';
|
|
19
|
-
const log = logFactory('splitio-producer:my-segments');
|
|
20
|
-
import mySegmentsFetcher from '../fetcher/MySegments';
|
|
21
|
-
|
|
22
|
-
export default function MySegmentsUpdaterFactory(context) {
|
|
23
|
-
const {
|
|
24
|
-
[context.constants.SETTINGS]: settings,
|
|
25
|
-
[context.constants.READINESS]: readiness,
|
|
26
|
-
[context.constants.STORAGE]: storage,
|
|
27
|
-
[context.constants.COLLECTORS]: metricCollectors
|
|
28
|
-
} = context.getAll();
|
|
29
|
-
|
|
30
|
-
const segmentsEventEmitter = readiness.segments;
|
|
31
|
-
|
|
32
|
-
let readyOnAlreadyExistentState = true;
|
|
33
|
-
let startingUp = true;
|
|
34
|
-
|
|
35
|
-
// @TODO if allowing custom storages, handle async execution and wrap errors as SplitErrors to distinguish from user callback errors
|
|
36
|
-
function updateSegments(segmentsData) {
|
|
37
|
-
|
|
38
|
-
const mySegmentsCache = storage.segments;
|
|
39
|
-
let shouldNotifyUpdate;
|
|
40
|
-
if (Array.isArray(segmentsData)) {
|
|
41
|
-
// Update the list of segment names available
|
|
42
|
-
shouldNotifyUpdate = mySegmentsCache.resetSegments(segmentsData);
|
|
43
|
-
} else {
|
|
44
|
-
// Add/Delete the segment
|
|
45
|
-
const { name, add } = segmentsData;
|
|
46
|
-
if (mySegmentsCache.isInSegment(name) !== add) {
|
|
47
|
-
shouldNotifyUpdate = true;
|
|
48
|
-
if (add) mySegmentsCache.addToSegment(name);
|
|
49
|
-
else mySegmentsCache.removeFromSegment(name);
|
|
50
|
-
} else {
|
|
51
|
-
shouldNotifyUpdate = false;
|
|
52
|
-
}
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
// Notify update if required
|
|
56
|
-
if (storage.splits.usesSegments() && (shouldNotifyUpdate || readyOnAlreadyExistentState)) {
|
|
57
|
-
readyOnAlreadyExistentState = false;
|
|
58
|
-
segmentsEventEmitter.emit(segmentsEventEmitter.SDK_SEGMENTS_ARRIVED);
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
/**
|
|
63
|
-
* MySegments updater returns a promise that resolves with a `false` boolean value if it fails to fetch mySegments or synchronize them with the storage.
|
|
64
|
-
*
|
|
65
|
-
* @param {number | undefined} retry current number of retry attemps. this param is only set by SplitChangesUpdater itself.
|
|
66
|
-
* @param {string[] | { name: string, add: boolean } | undefined} segmentsData it can be:
|
|
67
|
-
* (1) the list of segment names to sync in the storage,
|
|
68
|
-
* (2) an object with a segment name and action (true: add, or false: delete) to update the storage,
|
|
69
|
-
* (3) or `undefined`, for which the updater will fetch mySegments in order to sync the storage.
|
|
70
|
-
* @param {boolean | undefined} noCache true to revalidate data to fetch
|
|
71
|
-
*/
|
|
72
|
-
return function MySegmentsUpdater(retry = 0, segmentsData, noCache) {
|
|
73
|
-
let updaterPromise;
|
|
74
|
-
|
|
75
|
-
if (segmentsData) {
|
|
76
|
-
// If segmentsData is provided, there is no need to fetch mySegments
|
|
77
|
-
updaterPromise = new Promise((res) => { updateSegments(segmentsData); res(); });
|
|
78
|
-
} else {
|
|
79
|
-
// NOTE: We only collect metrics on startup.
|
|
80
|
-
updaterPromise = mySegmentsFetcher(settings, startingUp, metricCollectors, noCache).then(segments => {
|
|
81
|
-
// Only when we have downloaded segments completely, we should not keep retrying anymore
|
|
82
|
-
startingUp = false;
|
|
83
|
-
|
|
84
|
-
updateSegments(segments);
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
return updaterPromise.catch(error => {
|
|
89
|
-
// handle user callback errors
|
|
90
|
-
if (!(error instanceof SplitError)) setTimeout(() => { throw error; }, 0);
|
|
91
|
-
|
|
92
|
-
if (startingUp && settings.startup.retriesOnFailureBeforeReady > retry) {
|
|
93
|
-
retry += 1;
|
|
94
|
-
log.warn(`Retrying download of segments #${retry}. Reason: ${error}`);
|
|
95
|
-
return MySegmentsUpdater(retry);
|
|
96
|
-
} else {
|
|
97
|
-
startingUp = false;
|
|
98
|
-
}
|
|
99
|
-
|
|
100
|
-
return false; // shouldUpdate = false
|
|
101
|
-
});
|
|
102
|
-
};
|
|
103
|
-
|
|
104
|
-
}
|
|
@@ -1,126 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import logFactory from '../../utils/logger';
|
|
18
|
-
const log = logFactory('splitio-producer:segment-changes');
|
|
19
|
-
const inputValidationLog = logFactory('', { displayAllErrors: true });
|
|
20
|
-
import segmentChangesFetcher from '../fetcher/SegmentChanges';
|
|
21
|
-
import { findIndex } from '../../utils/lang';
|
|
22
|
-
import { SplitError } from '../../utils/lang/Errors';
|
|
23
|
-
import thenable from '../../utils/promise/thenable';
|
|
24
|
-
|
|
25
|
-
export default function SegmentChangesUpdaterFactory(context) {
|
|
26
|
-
const {
|
|
27
|
-
[context.constants.SETTINGS]: settings,
|
|
28
|
-
[context.constants.READINESS]: readiness,
|
|
29
|
-
[context.constants.STORAGE]: storage,
|
|
30
|
-
[context.constants.COLLECTORS]: metricCollectors
|
|
31
|
-
} = context.getAll();
|
|
32
|
-
const segmentsEventEmitter = readiness.segments;
|
|
33
|
-
const segmentsStorage = storage.segments;
|
|
34
|
-
|
|
35
|
-
let readyOnAlreadyExistentState = true;
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* Segments updater returns a promise that resolves with a `false` boolean value if it fails at least to fetch a segment or synchronize it with the storage.
|
|
39
|
-
* Thus, a false result doesn't imply that SDK_SEGMENTS_ARRIVED was not emitted.
|
|
40
|
-
*
|
|
41
|
-
* @param {string[] | undefined} segmentNames list of segment names to fetch. By passing `undefined` it fetches the list of segments registered at the storage
|
|
42
|
-
* @param {boolean | undefined} noCache true to revalidate data to fetch on a SEGMENT_UPDATE notifications.
|
|
43
|
-
* @param {boolean | undefined} fetchOnlyNew if true, only fetch the segments that not exists, i.e., which `changeNumber` is equal to -1.
|
|
44
|
-
* This param is used by SplitUpdateWorker on server-side SDK, to fetch new registered segments on SPLIT_UPDATE notifications.
|
|
45
|
-
*/
|
|
46
|
-
return function SegmentChangesUpdater(segmentNames, noCache, fetchOnlyNew) {
|
|
47
|
-
log.debug('Started segments update');
|
|
48
|
-
|
|
49
|
-
// Async fetchers are collected here.
|
|
50
|
-
const updaters = [];
|
|
51
|
-
|
|
52
|
-
function segmentsUpdater(segments) {
|
|
53
|
-
const sincePromises = [];
|
|
54
|
-
|
|
55
|
-
for (let index = 0; index < segments.length; index++) {
|
|
56
|
-
const segmentName = segments[index];
|
|
57
|
-
|
|
58
|
-
const segmentUpdater = function (since) {
|
|
59
|
-
log.debug(`Processing segment ${segmentName}`);
|
|
60
|
-
|
|
61
|
-
updaters.push(segmentChangesFetcher(settings, segmentName, since, metricCollectors, noCache).then(function (changes) {
|
|
62
|
-
let changeNumber = -1;
|
|
63
|
-
const changePromises = [];
|
|
64
|
-
changes.forEach(x => {
|
|
65
|
-
let promises = [];
|
|
66
|
-
if (x.added.length > 0) {
|
|
67
|
-
const result = segmentsStorage.addToSegment(segmentName, x.added);
|
|
68
|
-
if (thenable(result)) promises.push(result);
|
|
69
|
-
}
|
|
70
|
-
if (x.removed.length > 0) {
|
|
71
|
-
const result = segmentsStorage.removeFromSegment(segmentName, x.removed);
|
|
72
|
-
if (thenable(result)) promises.push(result);
|
|
73
|
-
}
|
|
74
|
-
if (x.added.length > 0 || x.removed.length > 0) {
|
|
75
|
-
const result = segmentsStorage.setChangeNumber(segmentName, x.till);
|
|
76
|
-
if (thenable(result)) promises.push(result);
|
|
77
|
-
changeNumber = x.till;
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
log.debug(`Processed ${segmentName} with till = ${x.till}. Added: ${x.added.length}. Removed: ${x.removed.length}`);
|
|
81
|
-
|
|
82
|
-
if (promises.length > 0) changePromises.push(...promises);
|
|
83
|
-
});
|
|
84
|
-
|
|
85
|
-
return Promise.all(changePromises).then(function () {
|
|
86
|
-
return changeNumber;
|
|
87
|
-
});
|
|
88
|
-
}));
|
|
89
|
-
};
|
|
90
|
-
|
|
91
|
-
const since = segmentsStorage.getChangeNumber(segmentName);
|
|
92
|
-
const sincePromise = thenable(since) ? since.then(segmentUpdater) : segmentUpdater(since);
|
|
93
|
-
sincePromises.push(sincePromise);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
return Promise.all(sincePromises).then(function () {
|
|
97
|
-
return Promise.all(updaters).then(shouldUpdateFlags => {
|
|
98
|
-
// if at least one segment fetch successes, mark segments ready
|
|
99
|
-
if (findIndex(shouldUpdateFlags, v => v !== -1) !== -1 || readyOnAlreadyExistentState) {
|
|
100
|
-
readyOnAlreadyExistentState = false;
|
|
101
|
-
segmentsEventEmitter.emit(segmentsEventEmitter.SDK_SEGMENTS_ARRIVED);
|
|
102
|
-
}
|
|
103
|
-
// if at least one segment fetch fails, return false to indicate that there was some error (e.g., invalid json, HTTP error, etc)
|
|
104
|
-
if (shouldUpdateFlags.indexOf(-1) !== -1) return false;
|
|
105
|
-
}).catch(error => {
|
|
106
|
-
// handle user callback errors
|
|
107
|
-
if (!(error instanceof SplitError)) setTimeout(() => { throw error; }, 0);
|
|
108
|
-
|
|
109
|
-
if (error.statusCode === 403) {
|
|
110
|
-
context.put(context.constants.DESTROYED, true);
|
|
111
|
-
inputValidationLog.error('Factory instantiation: you passed a Browser type authorizationKey, please grab an Api Key from the Split web console that is of type SDK.');
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
return false;
|
|
115
|
-
});
|
|
116
|
-
});
|
|
117
|
-
}
|
|
118
|
-
|
|
119
|
-
// If not a segment name provided, read list of available segments names to be updated.
|
|
120
|
-
let segments = segmentNames ? segmentNames : segmentsStorage.getRegisteredSegments();
|
|
121
|
-
if(fetchOnlyNew) segments = segments.filter(segmentName => segmentsStorage.getChangeNumber(segmentName) === -1 );
|
|
122
|
-
|
|
123
|
-
return thenable(segments) ? segments.then(segmentsUpdater) : segmentsUpdater(segments);
|
|
124
|
-
};
|
|
125
|
-
|
|
126
|
-
}
|
|
@@ -1,138 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import logFactory from '../../utils/logger';
|
|
18
|
-
const log = logFactory('splitio-producer:split-changes');
|
|
19
|
-
import splitChangesFetcher from '../fetcher/SplitChanges';
|
|
20
|
-
import parseSegments from '../../engine/parser/segments';
|
|
21
|
-
import { SplitError } from '../../utils/lang/Errors';
|
|
22
|
-
import { _Set, setToArray } from '../../utils/lang/Sets';
|
|
23
|
-
import thenable from '../../utils/promise/thenable';
|
|
24
|
-
|
|
25
|
-
// For server-side segments storage, returns true if all registered segments have been fetched (changeNumber !== -1)
|
|
26
|
-
function checkAllSegmentsExist(segmentsStorage) {
|
|
27
|
-
return segmentsStorage.getRegisteredSegments().every(segmentName => segmentsStorage.getChangeNumber(segmentName) !== -1);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
function computeSplitsMutation(entries) {
|
|
31
|
-
const computed = entries.reduce((accum, split) => {
|
|
32
|
-
if (split.status === 'ACTIVE') {
|
|
33
|
-
accum.added.push([split.name, JSON.stringify(split)]);
|
|
34
|
-
|
|
35
|
-
parseSegments(split.conditions).forEach(segmentName => {
|
|
36
|
-
accum.segments.add(segmentName);
|
|
37
|
-
});
|
|
38
|
-
} else {
|
|
39
|
-
accum.removed.push(split.name);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
return accum;
|
|
43
|
-
}, {
|
|
44
|
-
added: [],
|
|
45
|
-
removed: [],
|
|
46
|
-
segments: new _Set()
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
computed.segments = setToArray(computed.segments);
|
|
50
|
-
|
|
51
|
-
return computed;
|
|
52
|
-
}
|
|
53
|
-
|
|
54
|
-
export default function SplitChangesUpdaterFactory(context, isNode = false) {
|
|
55
|
-
const {
|
|
56
|
-
[context.constants.SETTINGS]: settings,
|
|
57
|
-
[context.constants.READINESS]: readiness,
|
|
58
|
-
[context.constants.STORAGE]: storage,
|
|
59
|
-
[context.constants.COLLECTORS]: metricCollectors
|
|
60
|
-
} = context.getAll();
|
|
61
|
-
const splitsEventEmitter = readiness.splits;
|
|
62
|
-
|
|
63
|
-
let startingUp = true;
|
|
64
|
-
let readyOnAlreadyExistentState = true;
|
|
65
|
-
|
|
66
|
-
/**
|
|
67
|
-
* Split updater returns a promise that resolves with a `false` boolean value if it fails to fetch splits or synchronize them with the storage.
|
|
68
|
-
*
|
|
69
|
-
* @param {number | undefined} retry current number of retry attemps. this param is only set by SplitChangesUpdater itself.
|
|
70
|
-
* @param {boolean | undefined} noCache true to revalidate data to fetch
|
|
71
|
-
*/
|
|
72
|
-
return function SplitChangesUpdater(retry = 0, noCache) {
|
|
73
|
-
|
|
74
|
-
function splitChanges(since) {
|
|
75
|
-
log.debug(`Spin up split update using since = ${since}`);
|
|
76
|
-
|
|
77
|
-
const fetcherPromise = splitChangesFetcher(settings, since, startingUp, metricCollectors, isNode, noCache)
|
|
78
|
-
.then(splitChanges => {
|
|
79
|
-
startingUp = false;
|
|
80
|
-
|
|
81
|
-
const mutation = computeSplitsMutation(splitChanges.splits);
|
|
82
|
-
|
|
83
|
-
log.debug(`New splits ${mutation.added.length}`);
|
|
84
|
-
log.debug(`Removed splits ${mutation.removed.length}`);
|
|
85
|
-
log.debug(`Segment names collected ${mutation.segments}`);
|
|
86
|
-
|
|
87
|
-
// Write into storage
|
|
88
|
-
// @TODO if allowing custom storages, wrap errors as SplitErrors to distinguish from user callback errors
|
|
89
|
-
return Promise.all([
|
|
90
|
-
// calling first `setChangenumber` method, to perform cache flush if split filter queryString changed
|
|
91
|
-
storage.splits.setChangeNumber(splitChanges.till),
|
|
92
|
-
storage.splits.addSplits(mutation.added),
|
|
93
|
-
storage.splits.removeSplits(mutation.removed),
|
|
94
|
-
storage.segments.registerSegments(mutation.segments)
|
|
95
|
-
]).then(() => {
|
|
96
|
-
// On server-side SDK, we must check that all registered segments have been fetched
|
|
97
|
-
if (readyOnAlreadyExistentState || (since !== splitChanges.till && (!isNode || checkAllSegmentsExist(storage.segments)))) {
|
|
98
|
-
readyOnAlreadyExistentState = false;
|
|
99
|
-
splitsEventEmitter.emit(splitsEventEmitter.SDK_SPLITS_ARRIVED);
|
|
100
|
-
}
|
|
101
|
-
});
|
|
102
|
-
})
|
|
103
|
-
.catch(error => {
|
|
104
|
-
// handle user callback errors
|
|
105
|
-
if (!(error instanceof SplitError)) {
|
|
106
|
-
setTimeout(() => { throw error; }, 0);
|
|
107
|
-
startingUp = false; // Stop retrying.
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
log.warn(`Error while doing fetch of Splits. ${error}`);
|
|
111
|
-
|
|
112
|
-
if (startingUp && settings.startup.retriesOnFailureBeforeReady > retry) {
|
|
113
|
-
retry += 1;
|
|
114
|
-
log.info(`Retrying download of splits #${retry}. Reason: ${error}`);
|
|
115
|
-
return SplitChangesUpdater(retry, noCache);
|
|
116
|
-
} else {
|
|
117
|
-
startingUp = false;
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
return false;
|
|
121
|
-
});
|
|
122
|
-
|
|
123
|
-
// After triggering the requests, if we have cached splits information let's notify that.
|
|
124
|
-
// There is no need to emit the event asynchronously to let attach a listener for SDK_READY_FROM_CACHE,
|
|
125
|
-
// because the current event-loop callback executes after SplitFactory is created.
|
|
126
|
-
if (startingUp && storage.splits.checkCache()) {
|
|
127
|
-
splitsEventEmitter.emit(splitsEventEmitter.SDK_SPLITS_CACHE_LOADED);
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
return fetcherPromise;
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
// @TODO check why e2e tests take so much time when sync storage result is not handled in a promise
|
|
134
|
-
const since = storage.splits.getChangeNumber();
|
|
135
|
-
const sincePromise = thenable(since) ? since : Promise.resolve(since);
|
|
136
|
-
return sincePromise.then(splitChanges);
|
|
137
|
-
};
|
|
138
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import FromSettingsFetcher from '../../services/splitChanges/offline';
|
|
18
|
-
import SplitChangesFromObject from './SplitChangesFromObject';
|
|
19
|
-
|
|
20
|
-
export default function createSplitChangesFromObject(context) {
|
|
21
|
-
const fetcher = FromSettingsFetcher();
|
|
22
|
-
return SplitChangesFromObject(fetcher, context);
|
|
23
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
Copyright 2016 Split Software
|
|
3
|
-
|
|
4
|
-
Licensed under the Apache License, Version 2.0 (the "License");
|
|
5
|
-
you may not use this file except in compliance with the License.
|
|
6
|
-
You may obtain a copy of the License at
|
|
7
|
-
|
|
8
|
-
http://www.apache.org/licenses/LICENSE-2.0
|
|
9
|
-
|
|
10
|
-
Unless required by applicable law or agreed to in writing, software
|
|
11
|
-
distributed under the License is distributed on an "AS IS" BASIS,
|
|
12
|
-
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
13
|
-
See the License for the specific language governing permissions and
|
|
14
|
-
limitations under the License.
|
|
15
|
-
**/
|
|
16
|
-
|
|
17
|
-
import FromFileSystemFetcher from '../../services/splitChanges/offline';
|
|
18
|
-
import SplitChangesFromObject from './SplitChangesFromObject';
|
|
19
|
-
|
|
20
|
-
export default function createSplitChangesFromObject(context) {
|
|
21
|
-
const fetcher = FromFileSystemFetcher();
|
|
22
|
-
return SplitChangesFromObject(fetcher, context);
|
|
23
|
-
}
|