@splitsoftware/splitio 10.17.3-rc.0 → 10.17.3-rc.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (46) hide show
  1. package/client/package.json +5 -0
  2. package/es/factory/{clientSide.js → browser.js} +24 -11
  3. package/es/factory/{serverSide.js → node.js} +28 -11
  4. package/es/factory/package.json +2 -2
  5. package/es/platform/EventEmitter.js +412 -0
  6. package/es/platform/browser.js +2 -3
  7. package/es/platform/node.js +1 -2
  8. package/es/settings/{clientSide.js → browser.js} +0 -0
  9. package/es/settings/defaults/version.js +1 -1
  10. package/es/settings/{serverSide.js → node.js} +0 -0
  11. package/es/settings/package.json +2 -2
  12. package/es/settings/storage/browser.js +5 -4
  13. package/es/settings/storage/node.js +17 -9
  14. package/lib/factory/{clientSide.js → browser.js} +26 -12
  15. package/lib/factory/{serverSide.js → node.js} +30 -12
  16. package/lib/factory/package.json +2 -2
  17. package/lib/platform/EventEmitter.js +417 -0
  18. package/lib/platform/browser.js +5 -8
  19. package/lib/platform/node.js +3 -4
  20. package/lib/settings/{clientSide.js → browser.js} +0 -0
  21. package/lib/settings/defaults/version.js +1 -1
  22. package/lib/settings/{serverSide.js → node.js} +0 -0
  23. package/lib/settings/package.json +2 -2
  24. package/lib/settings/storage/browser.js +5 -4
  25. package/lib/settings/storage/node.js +17 -10
  26. package/package.json +5 -4
  27. package/server/package.json +5 -0
  28. package/src/.DS_Store +0 -0
  29. package/src/factory/{clientSide.js → browser.js} +31 -15
  30. package/src/factory/{serverSide.js → node.js} +34 -14
  31. package/src/factory/package.json +2 -2
  32. package/src/platform/EventEmitter.js +443 -0
  33. package/src/platform/browser.js +2 -3
  34. package/src/platform/node.js +1 -2
  35. package/src/settings/{clientSide.js → browser.js} +0 -0
  36. package/src/settings/defaults/version.js +1 -1
  37. package/src/settings/{serverSide.js → node.js} +0 -0
  38. package/src/settings/package.json +2 -2
  39. package/src/settings/storage/browser.js +4 -3
  40. package/src/settings/storage/node.js +15 -10
  41. package/types/client/index.d.ts +14 -0
  42. package/types/server/index.d.ts +20 -0
  43. package/types/splitio.d.ts +22 -5
  44. package/es/factory/commons.js +0 -16
  45. package/lib/factory/commons.js +0 -23
  46. package/src/factory/commons.js +0 -16
@@ -0,0 +1,5 @@
1
+ {
2
+ "main": "../lib/factory/browser.js",
3
+ "module": "../es/factory/browser.js",
4
+ "types": "../types/client/index.d.ts"
5
+ }
@@ -10,32 +10,45 @@ import { impressionObserverCSFactory } from '@splitsoftware/splitio-commons/esm/
10
10
  import { integrationsManagerFactory } from '@splitsoftware/splitio-commons/esm/integrations/browser';
11
11
  import { __InLocalStorageMockFactory } from '@splitsoftware/splitio-commons/esm/utils/settingsValidation/storage/storageCS';
12
12
  import { sdkFactory } from '@splitsoftware/splitio-commons/esm/sdkFactory';
13
- import { settingsFactory } from '../settings/clientSide';
14
- import { shouldAddPt } from './commons';
15
- import { platform, signalListener } from '../platform';
13
+ import { LOCALHOST_MODE, STORAGE_LOCALSTORAGE } from '@splitsoftware/splitio-commons/esm/utils/constants';
14
+ import { shouldAddPt } from '@splitsoftware/splitio-commons/esm/trackers/impressionObserver/utils';
15
+ import { settingsFactory } from '../settings/browser';
16
+ import { platform, SignalListener } from '../platform';
16
17
  var syncManagerOnlineCSFactory = syncManagerOnlineFactory(pollingManagerCSFactory, pushManagerFactory);
18
+
19
+ function getStorage(settings) {
20
+ return settings.storage.type === STORAGE_LOCALSTORAGE ? InLocalStorage(settings.storage) : settings.storage.__originalType === STORAGE_LOCALSTORAGE ? __InLocalStorageMockFactory : InMemoryStorageCSFactory;
21
+ }
17
22
  /**
18
23
  *
19
24
  * @param {import("@splitsoftware/splitio-commons/types/types").ISettings} settings
20
25
  */
21
26
 
27
+
22
28
  function getModules(settings) {
23
- return {
29
+ var modules = {
24
30
  settings: settings,
25
31
  platform: platform,
26
- storageFactory: settings.storage.type === 'LOCALSTORAGE' ? InLocalStorage({
27
- prefix: settings.storage.prefix
28
- }) : settings.storage.__originalType === 'LOCALSTORAGE' ? __InLocalStorageMockFactory : InMemoryStorageCSFactory,
29
- splitApiFactory: settings.mode === 'localhost' ? undefined : splitApiFactory,
30
- syncManagerFactory: settings.mode === 'localhost' ? settings.sync.localhostMode : syncManagerOnlineCSFactory,
32
+ storageFactory: getStorage(settings),
33
+ splitApiFactory: splitApiFactory,
34
+ syncManagerFactory: syncManagerOnlineCSFactory,
31
35
  sdkManagerFactory: sdkManagerFactory,
32
36
  sdkClientMethodFactory: sdkClientMethodCSFactory,
33
- SignalListener: settings.mode === 'localhost' ? undefined : signalListener,
37
+ SignalListener: SignalListener,
34
38
  impressionListener: settings.impressionListener,
35
39
  integrationsManagerFactory: settings.integrations && settings.integrations.length > 0 ? integrationsManagerFactory.bind(null, settings.integrations) : undefined,
36
- // @TODO consider not including in debug mode?
37
40
  impressionsObserverFactory: shouldAddPt(settings) ? impressionObserverCSFactory : undefined
38
41
  };
42
+
43
+ switch (settings.mode) {
44
+ case LOCALHOST_MODE:
45
+ modules.splitApiFactory = undefined;
46
+ modules.syncManagerFactory = settings.sync.localhostMode;
47
+ modules.SignalListener = undefined;
48
+ break;
49
+ }
50
+
51
+ return modules;
39
52
  }
40
53
 
41
54
  export function SplitFactory(config) {
@@ -8,31 +8,48 @@ import { sdkManagerFactory } from '@splitsoftware/splitio-commons/esm/sdkManager
8
8
  import { sdkClientMethodFactory } from '@splitsoftware/splitio-commons/esm/sdkClient/sdkClientMethod';
9
9
  import { impressionObserverSSFactory } from '@splitsoftware/splitio-commons/esm/trackers/impressionObserver/impressionObserverSS';
10
10
  import { sdkFactory } from '@splitsoftware/splitio-commons/esm/sdkFactory';
11
- import { settingsFactory } from '../settings/serverSide';
12
- import { shouldAddPt } from './commons';
13
- import { platform, signalListener } from '../platform';
11
+ import { CONSUMER_MODE, LOCALHOST_MODE } from '@splitsoftware/splitio-commons/esm/utils/constants';
12
+ import { shouldAddPt } from '@splitsoftware/splitio-commons/esm/trackers/impressionObserver/utils';
13
+ import { settingsFactory } from '../settings/node';
14
+ import { platform, SignalListener } from '../platform';
14
15
  var syncManagerOnlineSSFactory = syncManagerOnlineFactory(pollingManagerSSFactory, pushManagerFactory);
16
+
17
+ function getStorage(settings) {
18
+ return settings.storage.type === 'REDIS' ? InRedisStorage(settings.storage) : InMemoryStorageFactory;
19
+ }
15
20
  /**
16
21
  *
17
22
  * @param {import("@splitsoftware/splitio-commons/types/types").ISettings} settings
18
23
  */
19
24
 
25
+
20
26
  function getModules(settings) {
21
- return {
27
+ var modules = {
22
28
  settings: settings,
23
29
  platform: platform,
24
- storageFactory: settings.storage.type === 'REDIS' ? InRedisStorage({
25
- prefix: settings.storage.prefix,
26
- options: settings.storage.options
27
- }) : InMemoryStorageFactory,
28
- splitApiFactory: settings.mode === 'localhost' ? undefined : splitApiFactory,
29
- syncManagerFactory: settings.storage.type === 'REDIS' ? undefined : settings.mode === 'localhost' ? settings.sync.localhostMode : syncManagerOnlineSSFactory,
30
+ storageFactory: getStorage(settings),
31
+ splitApiFactory: splitApiFactory,
32
+ syncManagerFactory: syncManagerOnlineSSFactory,
30
33
  sdkManagerFactory: sdkManagerFactory,
31
34
  sdkClientMethodFactory: sdkClientMethodFactory,
32
- SignalListener: settings.mode === 'localhost' ? undefined : signalListener,
35
+ SignalListener: SignalListener,
33
36
  impressionListener: settings.impressionListener,
34
37
  impressionsObserverFactory: shouldAddPt(settings) ? impressionObserverSSFactory : undefined
35
38
  };
39
+
40
+ switch (settings.mode) {
41
+ case LOCALHOST_MODE:
42
+ modules.splitApiFactory = undefined;
43
+ modules.syncManagerFactory = settings.sync.localhostMode;
44
+ modules.SignalListener = undefined;
45
+ break;
46
+
47
+ case CONSUMER_MODE:
48
+ modules.syncManagerFactory = undefined;
49
+ break;
50
+ }
51
+
52
+ return modules;
36
53
  }
37
54
 
38
55
  export function SplitFactory(config) {
@@ -1,4 +1,4 @@
1
1
  {
2
- "main": "./serverSide.js",
3
- "browser": "./clientSide.js"
2
+ "main": "./node.js",
3
+ "browser": "./browser.js"
4
4
  }
@@ -0,0 +1,412 @@
1
+ // Copyright Joyent, Inc. and other Node contributors.
2
+ //
3
+ // Permission is hereby granted, free of charge, to any person obtaining a
4
+ // copy of this software and associated documentation files (the
5
+ // "Software"), to deal in the Software without restriction, including
6
+ // without limitation the rights to use, copy, modify, merge, publish,
7
+ // distribute, sublicense, and/or sell copies of the Software, and to permit
8
+ // persons to whom the Software is furnished to do so, subject to the
9
+ // following conditions:
10
+ //
11
+ // The above copyright notice and this permission notice shall be included
12
+ // in all copies or substantial portions of the Software.
13
+ //
14
+ // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
15
+ // OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
16
+ // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN
17
+ // NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,
18
+ // DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR
19
+ // OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE
20
+ // USE OR OTHER DEALINGS IN THE SOFTWARE.
21
+ // Adaptation of "events" library (https://www.npmjs.com/package/events)
22
+ // exported as an ES module instead of CommonJS, to avoid extra configuration steps when using
23
+ // the ESM build of the SDK with tools that doesn't support CommonJS by default (e.g. Rollup).
24
+ var R = typeof Reflect === 'object' ? Reflect : null;
25
+ var ReflectApply = R && typeof R.apply === 'function' ? R.apply : function ReflectApply(target, receiver, args) {
26
+ return Function.prototype.apply.call(target, receiver, args);
27
+ };
28
+ var ReflectOwnKeys;
29
+
30
+ if (R && typeof R.ownKeys === 'function') {
31
+ ReflectOwnKeys = R.ownKeys;
32
+ } else if (Object.getOwnPropertySymbols) {
33
+ ReflectOwnKeys = function ReflectOwnKeys(target) {
34
+ return Object.getOwnPropertyNames(target).concat(Object.getOwnPropertySymbols(target));
35
+ };
36
+ } else {
37
+ ReflectOwnKeys = function ReflectOwnKeys(target) {
38
+ return Object.getOwnPropertyNames(target);
39
+ };
40
+ }
41
+
42
+ function ProcessEmitWarning(warning) {
43
+ if (console && console.warn) console.warn(warning);
44
+ }
45
+
46
+ var NumberIsNaN = Number.isNaN || function NumberIsNaN(value) {
47
+ return value !== value;
48
+ };
49
+
50
+ export function EventEmitter() {
51
+ EventEmitter.init.call(this);
52
+ }
53
+ EventEmitter.prototype._events = undefined;
54
+ EventEmitter.prototype._eventsCount = 0;
55
+ EventEmitter.prototype._maxListeners = undefined; // By default EventEmitters will print a warning if more than 10 listeners are
56
+ // added to it. This is a useful default which helps finding memory leaks.
57
+
58
+ var defaultMaxListeners = 10;
59
+
60
+ function checkListener(listener) {
61
+ if (typeof listener !== 'function') {
62
+ throw new TypeError('The "listener" argument must be of type Function. Received type ' + typeof listener);
63
+ }
64
+ }
65
+
66
+ Object.defineProperty(EventEmitter, 'defaultMaxListeners', {
67
+ enumerable: true,
68
+ get: function get() {
69
+ return defaultMaxListeners;
70
+ },
71
+ set: function set(arg) {
72
+ if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {
73
+ throw new RangeError('The value of "defaultMaxListeners" is out of range. It must be a non-negative number. Received ' + arg + '.');
74
+ }
75
+
76
+ defaultMaxListeners = arg;
77
+ }
78
+ });
79
+
80
+ EventEmitter.init = function () {
81
+ if (this._events === undefined || this._events === Object.getPrototypeOf(this)._events) {
82
+ this._events = Object.create(null);
83
+ this._eventsCount = 0;
84
+ }
85
+
86
+ this._maxListeners = this._maxListeners || undefined;
87
+ }; // Obviously not all Emitters should be limited to 10. This function allows
88
+ // that to be increased. Set to zero for unlimited.
89
+
90
+
91
+ EventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {
92
+ if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {
93
+ throw new RangeError('The value of "n" is out of range. It must be a non-negative number. Received ' + n + '.');
94
+ }
95
+
96
+ this._maxListeners = n;
97
+ return this;
98
+ };
99
+
100
+ function _getMaxListeners(that) {
101
+ if (that._maxListeners === undefined) return EventEmitter.defaultMaxListeners;
102
+ return that._maxListeners;
103
+ }
104
+
105
+ EventEmitter.prototype.getMaxListeners = function getMaxListeners() {
106
+ return _getMaxListeners(this);
107
+ };
108
+
109
+ EventEmitter.prototype.emit = function emit(type) {
110
+ var args = [];
111
+
112
+ for (var i = 1; i < arguments.length; i++) {
113
+ args.push(arguments[i]);
114
+ }
115
+
116
+ var doError = type === 'error';
117
+ var events = this._events;
118
+ if (events !== undefined) doError = doError && events.error === undefined;else if (!doError) return false; // If there is no 'error' event listener then throw.
119
+
120
+ if (doError) {
121
+ var er;
122
+ if (args.length > 0) er = args[0];
123
+
124
+ if (er instanceof Error) {
125
+ // Note: The comments on the `throw` lines are intentional, they show
126
+ // up in Node's output if this results in an unhandled exception.
127
+ throw er; // Unhandled 'error' event
128
+ } // At least give some kind of context to the user
129
+
130
+
131
+ var err = new Error('Unhandled error.' + (er ? ' (' + er.message + ')' : ''));
132
+ err.context = er;
133
+ throw err; // Unhandled 'error' event
134
+ }
135
+
136
+ var handler = events[type];
137
+ if (handler === undefined) return false;
138
+
139
+ if (typeof handler === 'function') {
140
+ ReflectApply(handler, this, args);
141
+ } else {
142
+ var len = handler.length;
143
+ var listeners = arrayClone(handler, len); // eslint-disable-next-line no-redeclare
144
+
145
+ for (var i = 0; i < len; ++i) {
146
+ ReflectApply(listeners[i], this, args);
147
+ }
148
+ }
149
+
150
+ return true;
151
+ };
152
+
153
+ function _addListener(target, type, listener, prepend) {
154
+ var m;
155
+ var events;
156
+ var existing;
157
+ checkListener(listener);
158
+ events = target._events;
159
+
160
+ if (events === undefined) {
161
+ events = target._events = Object.create(null);
162
+ target._eventsCount = 0;
163
+ } else {
164
+ // To avoid recursion in the case that type === "newListener"! Before
165
+ // adding it to the listeners, first emit "newListener".
166
+ if (events.newListener !== undefined) {
167
+ target.emit('newListener', type, listener.listener ? listener.listener : listener); // Re-assign `events` because a newListener handler could have caused the
168
+ // this._events to be assigned to a new object
169
+
170
+ events = target._events;
171
+ }
172
+
173
+ existing = events[type];
174
+ }
175
+
176
+ if (existing === undefined) {
177
+ // Optimize the case of one listener. Don't need the extra array object.
178
+ existing = events[type] = listener;
179
+ ++target._eventsCount;
180
+ } else {
181
+ if (typeof existing === 'function') {
182
+ // Adding the second element, need to change to array.
183
+ existing = events[type] = prepend ? [listener, existing] : [existing, listener]; // If we've already got an array, just append.
184
+ } else if (prepend) {
185
+ existing.unshift(listener);
186
+ } else {
187
+ existing.push(listener);
188
+ } // Check for listener leak
189
+
190
+
191
+ m = _getMaxListeners(target);
192
+
193
+ if (m > 0 && existing.length > m && !existing.warned) {
194
+ existing.warned = true; // No error code for this since it is a Warning
195
+ // eslint-disable-next-line no-restricted-syntax
196
+
197
+ var w = new Error('Possible EventEmitter memory leak detected. ' + existing.length + ' ' + String(type) + ' listeners ' + 'added. Use emitter.setMaxListeners() to ' + 'increase limit');
198
+ w.name = 'MaxListenersExceededWarning';
199
+ w.emitter = target;
200
+ w.type = type;
201
+ w.count = existing.length;
202
+ ProcessEmitWarning(w);
203
+ }
204
+ }
205
+
206
+ return target;
207
+ }
208
+
209
+ EventEmitter.prototype.addListener = function addListener(type, listener) {
210
+ return _addListener(this, type, listener, false);
211
+ };
212
+
213
+ EventEmitter.prototype.on = EventEmitter.prototype.addListener;
214
+
215
+ EventEmitter.prototype.prependListener = function prependListener(type, listener) {
216
+ return _addListener(this, type, listener, true);
217
+ };
218
+
219
+ function onceWrapper() {
220
+ if (!this.fired) {
221
+ this.target.removeListener(this.type, this.wrapFn);
222
+ this.fired = true;
223
+ if (arguments.length === 0) return this.listener.call(this.target);
224
+ return this.listener.apply(this.target, arguments);
225
+ }
226
+ }
227
+
228
+ function _onceWrap(target, type, listener) {
229
+ var state = {
230
+ fired: false,
231
+ wrapFn: undefined,
232
+ target: target,
233
+ type: type,
234
+ listener: listener
235
+ };
236
+ var wrapped = onceWrapper.bind(state);
237
+ wrapped.listener = listener;
238
+ state.wrapFn = wrapped;
239
+ return wrapped;
240
+ }
241
+
242
+ EventEmitter.prototype.once = function once(type, listener) {
243
+ checkListener(listener);
244
+ this.on(type, _onceWrap(this, type, listener));
245
+ return this;
246
+ };
247
+
248
+ EventEmitter.prototype.prependOnceListener = function prependOnceListener(type, listener) {
249
+ checkListener(listener);
250
+ this.prependListener(type, _onceWrap(this, type, listener));
251
+ return this;
252
+ }; // Emits a 'removeListener' event if and only if the listener was removed.
253
+
254
+
255
+ EventEmitter.prototype.removeListener = function removeListener(type, listener) {
256
+ var list, events, position, i, originalListener;
257
+ checkListener(listener);
258
+ events = this._events;
259
+ if (events === undefined) return this;
260
+ list = events[type];
261
+ if (list === undefined) return this;
262
+
263
+ if (list === listener || list.listener === listener) {
264
+ if (--this._eventsCount === 0) this._events = Object.create(null);else {
265
+ delete events[type];
266
+ if (events.removeListener) this.emit('removeListener', type, list.listener || listener);
267
+ }
268
+ } else if (typeof list !== 'function') {
269
+ position = -1;
270
+
271
+ for (i = list.length - 1; i >= 0; i--) {
272
+ if (list[i] === listener || list[i].listener === listener) {
273
+ originalListener = list[i].listener;
274
+ position = i;
275
+ break;
276
+ }
277
+ }
278
+
279
+ if (position < 0) return this;
280
+ if (position === 0) list.shift();else {
281
+ spliceOne(list, position);
282
+ }
283
+ if (list.length === 1) events[type] = list[0];
284
+ if (events.removeListener !== undefined) this.emit('removeListener', type, originalListener || listener);
285
+ }
286
+
287
+ return this;
288
+ };
289
+
290
+ EventEmitter.prototype.off = EventEmitter.prototype.removeListener;
291
+
292
+ EventEmitter.prototype.removeAllListeners = function removeAllListeners(type) {
293
+ var listeners, events, i;
294
+ events = this._events;
295
+ if (events === undefined) return this; // not listening for removeListener, no need to emit
296
+
297
+ if (events.removeListener === undefined) {
298
+ if (arguments.length === 0) {
299
+ this._events = Object.create(null);
300
+ this._eventsCount = 0;
301
+ } else if (events[type] !== undefined) {
302
+ if (--this._eventsCount === 0) this._events = Object.create(null);else delete events[type];
303
+ }
304
+
305
+ return this;
306
+ } // emit removeListener for all listeners on all events
307
+
308
+
309
+ if (arguments.length === 0) {
310
+ var keys = Object.keys(events);
311
+ var key;
312
+
313
+ for (i = 0; i < keys.length; ++i) {
314
+ key = keys[i];
315
+ if (key === 'removeListener') continue;
316
+ this.removeAllListeners(key);
317
+ }
318
+
319
+ this.removeAllListeners('removeListener');
320
+ this._events = Object.create(null);
321
+ this._eventsCount = 0;
322
+ return this;
323
+ }
324
+
325
+ listeners = events[type];
326
+
327
+ if (typeof listeners === 'function') {
328
+ this.removeListener(type, listeners);
329
+ } else if (listeners !== undefined) {
330
+ // LIFO order
331
+ for (i = listeners.length - 1; i >= 0; i--) {
332
+ this.removeListener(type, listeners[i]);
333
+ }
334
+ }
335
+
336
+ return this;
337
+ };
338
+
339
+ function _listeners(target, type, unwrap) {
340
+ var events = target._events;
341
+ if (events === undefined) return [];
342
+ var evlistener = events[type];
343
+ if (evlistener === undefined) return [];
344
+ if (typeof evlistener === 'function') return unwrap ? [evlistener.listener || evlistener] : [evlistener];
345
+ return unwrap ? unwrapListeners(evlistener) : arrayClone(evlistener, evlistener.length);
346
+ }
347
+
348
+ EventEmitter.prototype.listeners = function listeners(type) {
349
+ return _listeners(this, type, true);
350
+ };
351
+
352
+ EventEmitter.prototype.rawListeners = function rawListeners(type) {
353
+ return _listeners(this, type, false);
354
+ };
355
+
356
+ EventEmitter.listenerCount = function (emitter, type) {
357
+ if (typeof emitter.listenerCount === 'function') {
358
+ return emitter.listenerCount(type);
359
+ } else {
360
+ return listenerCount.call(emitter, type);
361
+ }
362
+ };
363
+
364
+ EventEmitter.prototype.listenerCount = listenerCount;
365
+
366
+ function listenerCount(type) {
367
+ var events = this._events;
368
+
369
+ if (events !== undefined) {
370
+ var evlistener = events[type];
371
+
372
+ if (typeof evlistener === 'function') {
373
+ return 1;
374
+ } else if (evlistener !== undefined) {
375
+ return evlistener.length;
376
+ }
377
+ }
378
+
379
+ return 0;
380
+ }
381
+
382
+ EventEmitter.prototype.eventNames = function eventNames() {
383
+ return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];
384
+ };
385
+
386
+ function arrayClone(arr, n) {
387
+ var copy = new Array(n);
388
+
389
+ for (var i = 0; i < n; ++i) {
390
+ copy[i] = arr[i];
391
+ }
392
+
393
+ return copy;
394
+ }
395
+
396
+ function spliceOne(list, index) {
397
+ for (; index + 1 < list.length; index++) {
398
+ list[index] = list[index + 1];
399
+ }
400
+
401
+ list.pop();
402
+ }
403
+
404
+ function unwrapListeners(arr) {
405
+ var ret = new Array(arr.length);
406
+
407
+ for (var i = 0; i < ret.length; ++i) {
408
+ ret[i] = arr[i].listener || arr[i];
409
+ }
410
+
411
+ return ret;
412
+ }
@@ -1,5 +1,4 @@
1
- // @TODO check 'events': it is a CommonJS module. Can have issues with ESM bundlers.
2
- import EventEmitter from 'events';
1
+ import { EventEmitter } from './EventEmitter';
3
2
  import { getFetch } from '../platform/getFetch/browser';
4
3
  import { getEventSource } from '../platform/getEventSource/browser';
5
4
  import { BrowserSignalListener } from '@splitsoftware/splitio-commons/esm/listeners/browser';
@@ -8,4 +7,4 @@ export var platform = {
8
7
  getEventSource: getEventSource,
9
8
  EventEmitter: EventEmitter
10
9
  };
11
- export var signalListener = BrowserSignalListener;
10
+ export var SignalListener = BrowserSignalListener;
@@ -1,4 +1,3 @@
1
- // @TODO check 'events': Node is using events API or the installed dependency?
2
1
  import EventEmitter from 'events';
3
2
  import { getFetch } from '../platform/getFetch/node';
4
3
  import { getEventSource } from '../platform/getEventSource/node';
@@ -10,4 +9,4 @@ export var platform = {
10
9
  getEventSource: getEventSource,
11
10
  EventEmitter: EventEmitter
12
11
  };
13
- export var signalListener = NodeSignalListener;
12
+ export var SignalListener = NodeSignalListener;
File without changes
@@ -1 +1 @@
1
- export var packageVersion = '10.17.3-rc.0';
1
+ export var packageVersion = '10.17.3-rc.1';
File without changes
@@ -1,4 +1,4 @@
1
1
  {
2
- "main": "./serverSide.js",
3
- "browser": "./clientSide.js"
2
+ "main": "./node.js",
3
+ "browser": "./browser.js"
4
4
  }
@@ -17,7 +17,8 @@ import { isLocalStorageAvailable } from '@splitsoftware/splitio-commons/esm/util
17
17
  import { LOCALHOST_MODE, STORAGE_MEMORY } from '@splitsoftware/splitio-commons/esm/utils/constants';
18
18
  var STORAGE_LOCALSTORAGE = 'LOCALSTORAGE';
19
19
  export function validateStorage(settings) {
20
- var mode = settings.mode,
20
+ var log = settings.log,
21
+ mode = settings.mode,
21
22
  _settings$storage = settings.storage;
22
23
  _settings$storage = _settings$storage === void 0 ? {
23
24
  type: STORAGE_MEMORY
@@ -38,8 +39,8 @@ export function validateStorage(settings) {
38
39
  var fallbackToMemory = function fallbackToMemory() {
39
40
  __originalType = type;
40
41
  type = STORAGE_MEMORY;
41
- }; // In localhost mode, fallback to Memory storage and track original
42
- // type to emit SDK_READY_FROM_CACHE if corresponds
42
+ }; // In localhost mode, fallback to Memory storage and track original type to emit SDK_READY_FROM_CACHE if corresponds.
43
+ // ATM, other mode settings (e.g., 'consumer') are ignored in client-side API, and so treated as standalone.
43
44
 
44
45
 
45
46
  if (mode === LOCALHOST_MODE && type === STORAGE_LOCALSTORAGE) {
@@ -50,7 +51,7 @@ export function validateStorage(settings) {
50
51
 
51
52
  if (type !== STORAGE_MEMORY && type !== STORAGE_LOCALSTORAGE || type === STORAGE_LOCALSTORAGE && !isLocalStorageAvailable()) {
52
53
  fallbackToMemory();
53
- settings.log.warn('Invalid or unavailable storage. Fallbacking into MEMORY storage');
54
+ log.error('Invalid or unavailable storage. Fallbacking into MEMORY storage');
54
55
  }
55
56
 
56
57
  return {
@@ -13,10 +13,10 @@ WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13
13
  See the License for the specific language governing permissions and
14
14
  limitations under the License.
15
15
  **/
16
- import { LOCALHOST_MODE, STORAGE_MEMORY } from '@splitsoftware/splitio-commons/esm/utils/constants';
17
- var STORAGE_REDIS = 'REDIS';
16
+ import { LOCALHOST_MODE, STORAGE_MEMORY, STORAGE_REDIS, CONSUMER_MODE, STANDALONE_MODE } from '@splitsoftware/splitio-commons/esm/utils/constants';
18
17
  export function validateStorage(settings) {
19
- var mode = settings.mode,
18
+ var log = settings.log,
19
+ mode = settings.mode,
20
20
  _settings$storage = settings.storage;
21
21
  _settings$storage = _settings$storage === void 0 ? {
22
22
  type: STORAGE_MEMORY
@@ -30,17 +30,21 @@ export function validateStorage(settings) {
30
30
  prefix += '.SPLITIO';
31
31
  } else {
32
32
  prefix = 'SPLITIO';
33
- } // In localhost mode we should force the user to use the MEMORY storage
33
+ } // We can have MEMORY, REDIS or an invalid storage type
34
34
 
35
35
 
36
- if (mode === LOCALHOST_MODE) return {
37
- type: STORAGE_MEMORY,
38
- prefix: prefix
39
- }; // In other cases we can have MEMORY or REDIS
40
-
41
36
  switch (type) {
42
37
  case STORAGE_REDIS:
43
38
  {
39
+ // If passing REDIS storage in localhost or standalone mode, we log an error and fallback to MEMORY storage
40
+ if (mode === STANDALONE_MODE || mode === LOCALHOST_MODE) {
41
+ log.error('The provided REDIS storage is invalid for this mode. It requires consumer mode. Fallbacking into default MEMORY storage.');
42
+ return {
43
+ type: STORAGE_MEMORY,
44
+ prefix: prefix
45
+ };
46
+ }
47
+
44
48
  var host = options.host,
45
49
  port = options.port,
46
50
  db = options.db,
@@ -78,6 +82,10 @@ export function validateStorage(settings) {
78
82
  case STORAGE_MEMORY:
79
83
  default:
80
84
  {
85
+ // If passing MEMORY storage in consumer mode, throw an error (no way to fallback to REDIS storage)
86
+ if (mode === CONSUMER_MODE) throw new Error('A REDIS storage is required on consumer mode'); // If passing an invalid storage type, log an error
87
+
88
+ if (type !== STORAGE_MEMORY) log.error("The provided '" + type + "' storage type is invalid. Fallbacking into default MEMORY storage.");
81
89
  return {
82
90
  type: STORAGE_MEMORY,
83
91
  prefix: prefix