@splitsoftware/splitio 10.18.2 → 10.18.3-rc.2

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 CHANGED
@@ -1,3 +1,9 @@
1
+ 10.19.0 (May 24, 2022)
2
+ - Added `scheduler.telemetryRefreshRate` property to SDK configuration, and deprecated `scheduler.metricsRefreshRate` property.
3
+ - Updated SDK telemetry storage, metrics and updater to be more effective and send less often.
4
+ - Updated EventSource dependency used for streaming support in NodeJS, to fix vulnerabilities.
5
+ - Bugfixing - Updated default values for `scheduler.impressionsRefreshRate` config parameter: 300s for OPTIMIZED impression mode and 60s for DEBUG impression mode.
6
+
1
7
  10.18.2 (May 6, 2022)
2
8
  - Bugfixing - Removed "ip" dependency to use an inline copy of it that fixes an error when using it in Node v18 (https://github.com/indutny/node-ip/issues/113).
3
9
 
@@ -2,9 +2,11 @@ import { EventEmitter } from './EventEmitter';
2
2
  import { getFetch } from '../platform/getFetch/browser';
3
3
  import { getEventSource } from '../platform/getEventSource/browser';
4
4
  import { BrowserSignalListener } from '@splitsoftware/splitio-commons/esm/listeners/browser';
5
+ import { now } from '@splitsoftware/splitio-commons/esm/utils/timeTracker/now/browser';
5
6
  export var platform = {
6
7
  getFetch: getFetch,
7
8
  getEventSource: getEventSource,
8
- EventEmitter: EventEmitter
9
+ EventEmitter: EventEmitter,
10
+ now: now
9
11
  };
10
12
  export var SignalListener = BrowserSignalListener;
@@ -3,10 +3,12 @@ import { getFetch } from '../platform/getFetch/node';
3
3
  import { getEventSource } from '../platform/getEventSource/node';
4
4
  import { getOptions } from '../platform/request/options/node';
5
5
  import { NodeSignalListener } from '@splitsoftware/splitio-commons/esm/listeners/node';
6
+ import { now } from '@splitsoftware/splitio-commons/esm/utils/timeTracker/now/node';
6
7
  export var platform = {
7
8
  getOptions: getOptions,
8
9
  getFetch: getFetch,
9
10
  getEventSource: getEventSource,
10
- EventEmitter: EventEmitter
11
+ EventEmitter: EventEmitter,
12
+ now: now
11
13
  };
12
14
  export var SignalListener = NodeSignalListener;
@@ -15,8 +15,7 @@ export var defaults = {
15
15
  eventsFirstPushWindow: 0
16
16
  },
17
17
  scheduler: {
18
- featuresRefreshRate: 5,
19
- impressionsRefreshRate: 300
18
+ featuresRefreshRate: 5
20
19
  },
21
20
  features: '.split',
22
21
  // Instance version.
@@ -1 +1 @@
1
- export var packageVersion = '10.18.2';
1
+ export var packageVersion = '10.18.3-rc.2';
@@ -5,9 +5,11 @@ var EventEmitter_1 = require("./EventEmitter");
5
5
  var browser_1 = require("../platform/getFetch/browser");
6
6
  var browser_2 = require("../platform/getEventSource/browser");
7
7
  var browser_3 = require("@splitsoftware/splitio-commons/cjs/listeners/browser");
8
+ var browser_4 = require("@splitsoftware/splitio-commons/cjs/utils/timeTracker/now/browser");
8
9
  exports.platform = {
9
10
  getFetch: browser_1.getFetch,
10
11
  getEventSource: browser_2.getEventSource,
11
- EventEmitter: EventEmitter_1.EventEmitter
12
+ EventEmitter: EventEmitter_1.EventEmitter,
13
+ now: browser_4.now
12
14
  };
13
15
  exports.SignalListener = browser_3.BrowserSignalListener;
@@ -7,10 +7,12 @@ var node_1 = require("../platform/getFetch/node");
7
7
  var node_2 = require("../platform/getEventSource/node");
8
8
  var node_3 = require("../platform/request/options/node");
9
9
  var node_4 = require("@splitsoftware/splitio-commons/cjs/listeners/node");
10
+ var node_5 = require("@splitsoftware/splitio-commons/cjs/utils/timeTracker/now/node");
10
11
  exports.platform = {
11
12
  getOptions: node_3.getOptions,
12
13
  getFetch: node_1.getFetch,
13
14
  getEventSource: node_2.getEventSource,
14
- EventEmitter: events_1.default
15
+ EventEmitter: events_1.default,
16
+ now: node_5.now
15
17
  };
16
18
  exports.SignalListener = node_4.NodeSignalListener;
@@ -18,8 +18,7 @@ exports.defaults = {
18
18
  eventsFirstPushWindow: 0
19
19
  },
20
20
  scheduler: {
21
- featuresRefreshRate: 5,
22
- impressionsRefreshRate: 300
21
+ featuresRefreshRate: 5
23
22
  },
24
23
  features: '.split',
25
24
  // Instance version.
@@ -1,4 +1,4 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.packageVersion = void 0;
4
- exports.packageVersion = '10.18.2';
4
+ exports.packageVersion = '10.18.3-rc.2';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@splitsoftware/splitio",
3
- "version": "10.18.2",
3
+ "version": "10.18.3-rc.2",
4
4
  "description": "Split SDK",
5
5
  "files": [
6
6
  "README.md",
@@ -32,7 +32,7 @@
32
32
  "node": ">=6"
33
33
  },
34
34
  "dependencies": {
35
- "@splitsoftware/splitio-commons": "1.3.1",
35
+ "@splitsoftware/splitio-commons": "1.3.2-rc.7",
36
36
  "@types/google.analytics": "0.0.40",
37
37
  "@types/ioredis": "^4.28.0",
38
38
  "ioredis": "^4.28.0",
@@ -41,7 +41,7 @@
41
41
  "unfetch": "^4.2.0"
42
42
  },
43
43
  "optionalDependencies": {
44
- "eventsource": "^1.0.7"
44
+ "eventsource": "^2.0.2"
45
45
  },
46
46
  "devDependencies": {
47
47
  "@types/node-fetch": "^2.5.12",
@@ -2,11 +2,13 @@ import { EventEmitter } from './EventEmitter';
2
2
  import { getFetch } from '../platform/getFetch/browser';
3
3
  import { getEventSource } from '../platform/getEventSource/browser';
4
4
  import { BrowserSignalListener } from '@splitsoftware/splitio-commons/src/listeners/browser';
5
+ import { now } from '@splitsoftware/splitio-commons/src/utils/timeTracker/now/browser';
5
6
 
6
7
  export const platform = {
7
8
  getFetch,
8
9
  getEventSource,
9
- EventEmitter
10
+ EventEmitter,
11
+ now
10
12
  };
11
13
 
12
14
  export const SignalListener = BrowserSignalListener;
@@ -3,12 +3,14 @@ import { getFetch } from '../platform/getFetch/node';
3
3
  import { getEventSource } from '../platform/getEventSource/node';
4
4
  import { getOptions } from '../platform/request/options/node';
5
5
  import { NodeSignalListener } from '@splitsoftware/splitio-commons/src/listeners/node';
6
+ import { now } from '@splitsoftware/splitio-commons/src/utils/timeTracker/now/node';
6
7
 
7
8
  export const platform = {
8
9
  getOptions,
9
10
  getFetch,
10
11
  getEventSource,
11
- EventEmitter
12
+ EventEmitter,
13
+ now
12
14
  };
13
15
 
14
16
  export const SignalListener = NodeSignalListener;
@@ -16,8 +16,7 @@ export const defaults = {
16
16
  eventsFirstPushWindow: 0
17
17
  },
18
18
  scheduler: {
19
- featuresRefreshRate: 5,
20
- impressionsRefreshRate: 300
19
+ featuresRefreshRate: 5
21
20
  },
22
21
  features: '.split',
23
22
 
@@ -1 +1 @@
1
- export const packageVersion = '10.18.2';
1
+ export const packageVersion = '10.18.3-rc.2';
@@ -71,7 +71,11 @@ interface ISettings {
71
71
  featuresRefreshRate: number,
72
72
  impressionsRefreshRate: number,
73
73
  impressionsQueueSize: number,
74
- metricsRefreshRate: number,
74
+ /**
75
+ * @deprecated
76
+ */
77
+ metricsRefreshRate?: number,
78
+ telemetryRefreshRate: number,
75
79
  segmentsRefreshRate: number,
76
80
  offlineRefreshRate: number,
77
81
  eventsPushRate: number,
@@ -93,7 +97,8 @@ interface ISettings {
93
97
  events: string,
94
98
  sdk: string,
95
99
  auth: string,
96
- streaming: string
100
+ streaming: string,
101
+ telemetry: string
97
102
  },
98
103
  readonly debug: boolean | LogLevel,
99
104
  readonly version: string,
@@ -297,8 +302,15 @@ interface INodeBasicSettings extends ISharedSettings {
297
302
  * The SDK sends diagnostic metrics to Split servers. This parameters controls this metric flush period in seconds.
298
303
  * @property {number} metricsRefreshRate
299
304
  * @default 120
305
+ * @deprecated This parameter is ignored now. Use `telemetryRefreshRate` instead.
300
306
  */
301
307
  metricsRefreshRate?: number,
308
+ /**
309
+ * The SDK sends diagnostic metrics to Split servers. This parameters controls this metric flush period in seconds.
310
+ * @property {number} telemetryRefreshRate
311
+ * @default 3600
312
+ */
313
+ telemetryRefreshRate?: number,
302
314
  /**
303
315
  * The SDK polls Split servers for changes to segment definitions. This parameter controls this polling period in seconds.
304
316
  * @property {number} segmentsRefreshRate
@@ -843,7 +855,13 @@ declare namespace SplitIO {
843
855
  * @property {string} streaming
844
856
  * @default 'https://streaming.split.io'
845
857
  */
846
- streaming?: string
858
+ streaming?: string,
859
+ /**
860
+ * String property to override the base URL where the SDK will post telemetry data.
861
+ * @property {string} telemetry
862
+ * @default 'https://telemetry.split.io/api'
863
+ */
864
+ telemetry?: string
847
865
  };
848
866
 
849
867
  /**
@@ -947,8 +965,15 @@ declare namespace SplitIO {
947
965
  * The SDK sends diagnostic metrics to Split servers. This parameters controls this metric flush period in seconds.
948
966
  * @property {number} metricsRefreshRate
949
967
  * @default 120
968
+ * @deprecated This parameter is ignored now. Use `telemetryRefreshRate` instead.
950
969
  */
951
970
  metricsRefreshRate?: number,
971
+ /**
972
+ * The SDK sends diagnostic metrics to Split servers. This parameters controls this metric flush period in seconds.
973
+ * @property {number} telemetryRefreshRate
974
+ * @default 3600
975
+ */
976
+ telemetryRefreshRate?: number,
952
977
  /**
953
978
  * The SDK polls Split servers for changes to segment definitions. This parameter controls this polling period in seconds.
954
979
  * @property {number} segmentsRefreshRate