@flashphoner/websdk 2.0.260 → 2.0.261
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/docTemplate/README.md +1 -1
- package/flashphoner-no-flash.js +768 -81
- package/flashphoner-no-flash.min.js +2 -2
- package/flashphoner-no-webrtc.js +666 -9
- package/flashphoner-no-webrtc.min.js +2 -2
- package/flashphoner-no-wsplayer.js +767 -80
- package/flashphoner-no-wsplayer.min.js +2 -2
- package/flashphoner-room-api-webrtc-only.js +768 -81
- package/flashphoner-room-api-webrtc-only.min.js +1 -1
- package/flashphoner-room-api.js +516 -60
- package/flashphoner-room-api.min.js +2 -2
- package/flashphoner-temasys-flash-websocket-without-adapterjs.js +667 -10
- package/flashphoner-temasys-flash-websocket.js +667 -10
- package/flashphoner-temasys-flash-websocket.min.js +1 -1
- package/flashphoner-webrtc-only.js +767 -80
- package/flashphoner-webrtc-only.min.js +1 -1
- package/flashphoner.js +768 -81
- package/flashphoner.min.js +2 -2
- package/package.json +1 -1
- package/src/constants.d.ts +6 -0
- package/src/constants.js +6 -0
- package/src/flashphoner-core.js +60 -5
- package/src/stats-collector.js +318 -0
- package/src/util.js +61 -1
- package/src/webrtc-media-provider.js +64 -48
|
@@ -7632,6 +7632,12 @@ var ERROR_INFO = Object.freeze({
|
|
|
7632
7632
|
* @memberOf Flashphoner.constants.ERROR_INFO
|
|
7633
7633
|
*/
|
|
7634
7634
|
CAN_NOT_SET_RESOLUTION: 'Cannot switch a published stream resolution',
|
|
7635
|
+
/**
|
|
7636
|
+
* Error if cannot get peer connection stats
|
|
7637
|
+
* @event CAN_NOT_GET_STATS
|
|
7638
|
+
* @memberOf Flashphoner.constants.ERROR_INFO
|
|
7639
|
+
*/
|
|
7640
|
+
CAN_NOT_GET_STATS: 'Cannot get PeerConnection stats',
|
|
7635
7641
|
/**
|
|
7636
7642
|
* Local browser error detected
|
|
7637
7643
|
* @event LOCAL_ERROR
|
|
@@ -7831,6 +7837,12 @@ module.exports = {
|
|
|
7831
7837
|
},{}],40:[function(require,module,exports){
|
|
7832
7838
|
'use strict';
|
|
7833
7839
|
|
|
7840
|
+
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
7841
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
7842
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
7843
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
7844
|
+
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
7845
|
+
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
7834
7846
|
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
7835
7847
|
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
7836
7848
|
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
@@ -7842,6 +7854,7 @@ var constants = require("./constants");
|
|
|
7842
7854
|
var util = require('./util');
|
|
7843
7855
|
var LoggerObject = require('./util').logger;
|
|
7844
7856
|
var clientInfo = require('./client-info');
|
|
7857
|
+
var StatsCollector = require('./stats-collector');
|
|
7845
7858
|
var _Promise = require('promise-polyfill');
|
|
7846
7859
|
var KalmanFilter = require('kalmanjs');
|
|
7847
7860
|
var browserDetails = require('webrtc-adapter')["default"].browserDetails;
|
|
@@ -8385,6 +8398,9 @@ var createSession = function createSession(options) {
|
|
|
8385
8398
|
//callbacks added using session.on()
|
|
8386
8399
|
var callbacks = {};
|
|
8387
8400
|
var wsConnection;
|
|
8401
|
+
|
|
8402
|
+
// WebRTC metrics sending description
|
|
8403
|
+
var webRTCMetricsServerDescription;
|
|
8388
8404
|
if (lbUrl) {
|
|
8389
8405
|
requestURL(lbUrl);
|
|
8390
8406
|
} else {
|
|
@@ -8487,6 +8503,7 @@ var createSession = function createSession(options) {
|
|
|
8487
8503
|
case 'getUserData':
|
|
8488
8504
|
authToken = obj.authToken;
|
|
8489
8505
|
cConfig = obj;
|
|
8506
|
+
webRTCMetricsServerDescription = obj.webRTCMetricsServerDescription;
|
|
8490
8507
|
onSessionStatusChange(SESSION_STATUS.ESTABLISHED, obj);
|
|
8491
8508
|
break;
|
|
8492
8509
|
case 'setRemoteSDP':
|
|
@@ -8591,6 +8608,37 @@ var createSession = function createSession(options) {
|
|
|
8591
8608
|
streamRefreshHandlers[obj.mediaSessionId](obj);
|
|
8592
8609
|
}
|
|
8593
8610
|
break;
|
|
8611
|
+
case "webRTCMetricsDescriptionUpdate":
|
|
8612
|
+
if (obj.ids) {
|
|
8613
|
+
obj.ids.forEach(function (id) {
|
|
8614
|
+
if (streamRefreshHandlers[id]) {
|
|
8615
|
+
streamRefreshHandlers[id](obj);
|
|
8616
|
+
}
|
|
8617
|
+
});
|
|
8618
|
+
} else {
|
|
8619
|
+
if (obj.compression) {
|
|
8620
|
+
webRTCMetricsServerDescription.compression = obj.compression;
|
|
8621
|
+
}
|
|
8622
|
+
if (obj.batchSize) {
|
|
8623
|
+
webRTCMetricsServerDescription.batchSize = obj.batchSize;
|
|
8624
|
+
}
|
|
8625
|
+
if (obj.sampling) {
|
|
8626
|
+
webRTCMetricsServerDescription.sampling = obj.sampling;
|
|
8627
|
+
}
|
|
8628
|
+
if (obj.types) {
|
|
8629
|
+
webRTCMetricsServerDescription.types = obj.types;
|
|
8630
|
+
}
|
|
8631
|
+
if (obj.collect) {
|
|
8632
|
+
webRTCMetricsServerDescription.collect = obj.collect;
|
|
8633
|
+
}
|
|
8634
|
+
for (var _i = 0, _Object$entries = Object.entries(streamRefreshHandlers); _i < _Object$entries.length; _i++) {
|
|
8635
|
+
var _Object$entries$_i = _slicedToArray(_Object$entries[_i], 2),
|
|
8636
|
+
_id = _Object$entries$_i[0],
|
|
8637
|
+
handler = _Object$entries$_i[1];
|
|
8638
|
+
handler(obj);
|
|
8639
|
+
}
|
|
8640
|
+
}
|
|
8641
|
+
break;
|
|
8594
8642
|
default:
|
|
8595
8643
|
logger.info(LOG_PREFIX, "Unknown server message " + data.message);
|
|
8596
8644
|
}
|
|
@@ -8602,10 +8650,12 @@ var createSession = function createSession(options) {
|
|
|
8602
8650
|
|
|
8603
8651
|
//WebSocket send helper
|
|
8604
8652
|
function send(message, data) {
|
|
8605
|
-
wsConnection.
|
|
8606
|
-
|
|
8607
|
-
|
|
8608
|
-
|
|
8653
|
+
if (wsConnection.readyState === WebSocket.OPEN) {
|
|
8654
|
+
wsConnection.send(JSON.stringify({
|
|
8655
|
+
message: message,
|
|
8656
|
+
data: [data]
|
|
8657
|
+
}));
|
|
8658
|
+
}
|
|
8609
8659
|
}
|
|
8610
8660
|
|
|
8611
8661
|
//Session status update helper
|
|
@@ -9636,6 +9686,7 @@ var createSession = function createSession(options) {
|
|
|
9636
9686
|
var videoState_;
|
|
9637
9687
|
var connectionQuality;
|
|
9638
9688
|
var videoBytes = 0;
|
|
9689
|
+
var statsCollector = null;
|
|
9639
9690
|
|
|
9640
9691
|
/**
|
|
9641
9692
|
* Represents media stream.
|
|
@@ -9668,7 +9719,7 @@ var createSession = function createSession(options) {
|
|
|
9668
9719
|
mediaConnection.setRemoteSdp(_sdp).then(function () {});
|
|
9669
9720
|
return;
|
|
9670
9721
|
}
|
|
9671
|
-
if (streamInfo.available
|
|
9722
|
+
if (streamInfo.available !== undefined) {
|
|
9672
9723
|
for (var i = 0; i < availableCallbacks.length; i++) {
|
|
9673
9724
|
info_ = streamInfo.reason;
|
|
9674
9725
|
if (streamInfo.available == "true") {
|
|
@@ -9714,10 +9765,28 @@ var createSession = function createSession(options) {
|
|
|
9714
9765
|
if (mediaConnection) {
|
|
9715
9766
|
mediaConnection.close(cacheLocalResources);
|
|
9716
9767
|
}
|
|
9768
|
+
if (statsCollector) {
|
|
9769
|
+
statsCollector.stop();
|
|
9770
|
+
statsCollector = null;
|
|
9771
|
+
}
|
|
9717
9772
|
}
|
|
9718
9773
|
if (record_ && typeof streamInfo.recordName !== 'undefined') {
|
|
9719
9774
|
recordFileName = streamInfo.recordName;
|
|
9720
9775
|
}
|
|
9776
|
+
|
|
9777
|
+
// Set up metrics collection
|
|
9778
|
+
if (event === STREAM_STATUS.PUBLISHING || event === STREAM_STATUS.PLAYING) {
|
|
9779
|
+
if (webRTCMetricsServerDescription && !statsCollector) {
|
|
9780
|
+
statsCollector = StatsCollector.StreamStatsCollector(webRTCMetricsServerDescription, id_, mediaConnection, wsConnection, logger);
|
|
9781
|
+
statsCollector.start();
|
|
9782
|
+
}
|
|
9783
|
+
}
|
|
9784
|
+
|
|
9785
|
+
// Pause or resume metrics collection
|
|
9786
|
+
if (!streamInfo.status && streamInfo.collect !== undefined && statsCollector) {
|
|
9787
|
+
statsCollector.update(streamInfo);
|
|
9788
|
+
}
|
|
9789
|
+
|
|
9721
9790
|
//fire stream event
|
|
9722
9791
|
if (callbacks[event]) {
|
|
9723
9792
|
callbacks[event](stream);
|
|
@@ -10951,9 +11020,531 @@ module.exports = {
|
|
|
10951
11020
|
Browser: util.Browser
|
|
10952
11021
|
};
|
|
10953
11022
|
|
|
10954
|
-
},{"./client-info":38,"./constants":39,"./media-source-media-provider":1,"./temasys-media-provider":1,"./util":
|
|
11023
|
+
},{"./client-info":38,"./constants":39,"./media-source-media-provider":1,"./stats-collector":41,"./temasys-media-provider":1,"./util":42,"./webrtc-media-provider":43,"./websocket-media-provider":1,"kalmanjs":2,"promise-polyfill":4,"uuid":8,"webrtc-adapter":23}],41:[function(require,module,exports){
|
|
11024
|
+
'use strict';
|
|
11025
|
+
|
|
11026
|
+
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
11027
|
+
function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
11028
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
11029
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
11030
|
+
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
11031
|
+
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
11032
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
11033
|
+
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
11034
|
+
var util = require('./util');
|
|
11035
|
+
var LOG_PREFIX = "stats-collector";
|
|
11036
|
+
|
|
11037
|
+
// Collect and send WebRTC statistics periodically
|
|
11038
|
+
var StreamStatsCollector = function StreamStatsCollector(description, id, mediaConnection, wsConnection, logger) {
|
|
11039
|
+
var statCollector = {
|
|
11040
|
+
description: description,
|
|
11041
|
+
id: id,
|
|
11042
|
+
mediaConnection: mediaConnection,
|
|
11043
|
+
wsConnection: wsConnection,
|
|
11044
|
+
logger: getLogger(logger),
|
|
11045
|
+
headers: "",
|
|
11046
|
+
compression: "none",
|
|
11047
|
+
metricsBatch: null,
|
|
11048
|
+
timer: null,
|
|
11049
|
+
batchCount: 0,
|
|
11050
|
+
start: function () {
|
|
11051
|
+
var _start = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee() {
|
|
11052
|
+
var error;
|
|
11053
|
+
return _regenerator().w(function (_context) {
|
|
11054
|
+
while (1) switch (_context.n) {
|
|
11055
|
+
case 0:
|
|
11056
|
+
error = "Can't collect WebRTC stats to send: ";
|
|
11057
|
+
if (statCollector.description.types) {
|
|
11058
|
+
_context.n = 1;
|
|
11059
|
+
break;
|
|
11060
|
+
}
|
|
11061
|
+
throw new Error(error + "no report types defined");
|
|
11062
|
+
case 1:
|
|
11063
|
+
if (statCollector.description.sampling) {
|
|
11064
|
+
_context.n = 2;
|
|
11065
|
+
break;
|
|
11066
|
+
}
|
|
11067
|
+
throw new Error(error + "no sampling interval defined");
|
|
11068
|
+
case 2:
|
|
11069
|
+
if (statCollector.description.batchSize) {
|
|
11070
|
+
_context.n = 3;
|
|
11071
|
+
break;
|
|
11072
|
+
}
|
|
11073
|
+
throw new Error(error + "no metrics batch size defined");
|
|
11074
|
+
case 3:
|
|
11075
|
+
if (statCollector.mediaConnection) {
|
|
11076
|
+
_context.n = 4;
|
|
11077
|
+
break;
|
|
11078
|
+
}
|
|
11079
|
+
throw new Error(error + "no media connection available");
|
|
11080
|
+
case 4:
|
|
11081
|
+
if (statCollector.wsConnection) {
|
|
11082
|
+
_context.n = 5;
|
|
11083
|
+
break;
|
|
11084
|
+
}
|
|
11085
|
+
throw new Error(error + "no websocket connection available");
|
|
11086
|
+
case 5:
|
|
11087
|
+
_context.n = 6;
|
|
11088
|
+
return statCollector.updateHeaders();
|
|
11089
|
+
case 6:
|
|
11090
|
+
_context.n = 7;
|
|
11091
|
+
return statCollector.updateCompression();
|
|
11092
|
+
case 7:
|
|
11093
|
+
statCollector.sendHeaders();
|
|
11094
|
+
if (statCollector.description.collect === "on") {
|
|
11095
|
+
statCollector.collect(true);
|
|
11096
|
+
}
|
|
11097
|
+
case 8:
|
|
11098
|
+
return _context.a(2);
|
|
11099
|
+
}
|
|
11100
|
+
}, _callee);
|
|
11101
|
+
}));
|
|
11102
|
+
function start() {
|
|
11103
|
+
return _start.apply(this, arguments);
|
|
11104
|
+
}
|
|
11105
|
+
return start;
|
|
11106
|
+
}(),
|
|
11107
|
+
collect: function collect(enable) {
|
|
11108
|
+
if (enable) {
|
|
11109
|
+
statCollector.startTimer();
|
|
11110
|
+
} else {
|
|
11111
|
+
statCollector.stopTimer();
|
|
11112
|
+
}
|
|
11113
|
+
},
|
|
11114
|
+
stop: function stop() {
|
|
11115
|
+
statCollector.stopTimer();
|
|
11116
|
+
statCollector.headers = "";
|
|
11117
|
+
},
|
|
11118
|
+
update: function () {
|
|
11119
|
+
var _update = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2(description) {
|
|
11120
|
+
var _t;
|
|
11121
|
+
return _regenerator().w(function (_context2) {
|
|
11122
|
+
while (1) switch (_context2.n) {
|
|
11123
|
+
case 0:
|
|
11124
|
+
if (description) {
|
|
11125
|
+
_context2.n = 1;
|
|
11126
|
+
break;
|
|
11127
|
+
}
|
|
11128
|
+
if (!statCollector.logger) {
|
|
11129
|
+
_context2.n = 1;
|
|
11130
|
+
break;
|
|
11131
|
+
}
|
|
11132
|
+
statCollector.logger.error(LOG_PREFIX, "Can't update WebRTC metrics sending: no parameters passed");
|
|
11133
|
+
return _context2.a(2);
|
|
11134
|
+
case 1:
|
|
11135
|
+
if (!(description.types || description.compression)) {
|
|
11136
|
+
_context2.n = 4;
|
|
11137
|
+
break;
|
|
11138
|
+
}
|
|
11139
|
+
statCollector.stop();
|
|
11140
|
+
if (!description.types) {
|
|
11141
|
+
_context2.n = 2;
|
|
11142
|
+
break;
|
|
11143
|
+
}
|
|
11144
|
+
statCollector.description.types = description.types;
|
|
11145
|
+
_context2.n = 2;
|
|
11146
|
+
return statCollector.updateHeaders();
|
|
11147
|
+
case 2:
|
|
11148
|
+
if (!description.compression) {
|
|
11149
|
+
_context2.n = 3;
|
|
11150
|
+
break;
|
|
11151
|
+
}
|
|
11152
|
+
statCollector.description.compression = description.compression;
|
|
11153
|
+
_context2.n = 3;
|
|
11154
|
+
return statCollector.updateCompression();
|
|
11155
|
+
case 3:
|
|
11156
|
+
statCollector.sendHeaders();
|
|
11157
|
+
_context2.n = 5;
|
|
11158
|
+
break;
|
|
11159
|
+
case 4:
|
|
11160
|
+
statCollector.collect(false);
|
|
11161
|
+
case 5:
|
|
11162
|
+
if (description.batchSize) {
|
|
11163
|
+
statCollector.description.batchSize = description.batchSize;
|
|
11164
|
+
}
|
|
11165
|
+
if (description.sampling) {
|
|
11166
|
+
statCollector.description.sampling = description.sampling;
|
|
11167
|
+
}
|
|
11168
|
+
if (description.collect) {
|
|
11169
|
+
statCollector.description.collect = description.collect;
|
|
11170
|
+
}
|
|
11171
|
+
_t = statCollector.description.collect;
|
|
11172
|
+
_context2.n = _t === "on" ? 6 : _t === "off" ? 7 : 8;
|
|
11173
|
+
break;
|
|
11174
|
+
case 6:
|
|
11175
|
+
statCollector.collect(true);
|
|
11176
|
+
return _context2.a(3, 8);
|
|
11177
|
+
case 7:
|
|
11178
|
+
statCollector.collect(false);
|
|
11179
|
+
return _context2.a(3, 8);
|
|
11180
|
+
case 8:
|
|
11181
|
+
return _context2.a(2);
|
|
11182
|
+
}
|
|
11183
|
+
}, _callee2);
|
|
11184
|
+
}));
|
|
11185
|
+
function update(_x) {
|
|
11186
|
+
return _update.apply(this, arguments);
|
|
11187
|
+
}
|
|
11188
|
+
return update;
|
|
11189
|
+
}(),
|
|
11190
|
+
updateHeaders: function () {
|
|
11191
|
+
var _updateHeaders = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee3() {
|
|
11192
|
+
var stats;
|
|
11193
|
+
return _regenerator().w(function (_context3) {
|
|
11194
|
+
while (1) switch (_context3.n) {
|
|
11195
|
+
case 0:
|
|
11196
|
+
_context3.n = 1;
|
|
11197
|
+
return statCollector.mediaConnection.getWebRTCStats();
|
|
11198
|
+
case 1:
|
|
11199
|
+
stats = _context3.v;
|
|
11200
|
+
Object.keys(statCollector.description.types).forEach(function (type) {
|
|
11201
|
+
var typeDescriptor = statCollector.description.types[type];
|
|
11202
|
+
var metricsString = "";
|
|
11203
|
+
var contentFilters = null;
|
|
11204
|
+
if (typeDescriptor.metrics) {
|
|
11205
|
+
metricsString = typeDescriptor.metrics;
|
|
11206
|
+
}
|
|
11207
|
+
if (typeDescriptor.contains) {
|
|
11208
|
+
contentFilters = typeDescriptor.contains;
|
|
11209
|
+
}
|
|
11210
|
+
if (stats[type]) {
|
|
11211
|
+
stats[type].forEach(function (report) {
|
|
11212
|
+
statCollector.logger.debug(LOG_PREFIX, type + " report: " + JSON.stringify(report));
|
|
11213
|
+
if (contentFilters) {
|
|
11214
|
+
var filtersMatched = true;
|
|
11215
|
+
for (var filter in contentFilters) {
|
|
11216
|
+
statCollector.logger.debug(LOG_PREFIX, type + " filter by " + filter + ": " + JSON.stringify(contentFilters[filter]));
|
|
11217
|
+
var filterMatched = false;
|
|
11218
|
+
if (report[filter]) {
|
|
11219
|
+
var _iterator = _createForOfIteratorHelper(contentFilters[filter]),
|
|
11220
|
+
_step;
|
|
11221
|
+
try {
|
|
11222
|
+
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
11223
|
+
var value = _step.value;
|
|
11224
|
+
statCollector.logger.debug(LOG_PREFIX, filter + ": " + value + " <> " + report[filter]);
|
|
11225
|
+
if (report[filter] === value) {
|
|
11226
|
+
filterMatched = true;
|
|
11227
|
+
break;
|
|
11228
|
+
}
|
|
11229
|
+
}
|
|
11230
|
+
} catch (err) {
|
|
11231
|
+
_iterator.e(err);
|
|
11232
|
+
} finally {
|
|
11233
|
+
_iterator.f();
|
|
11234
|
+
}
|
|
11235
|
+
}
|
|
11236
|
+
filtersMatched = filtersMatched && filterMatched;
|
|
11237
|
+
if (!filterMatched) {
|
|
11238
|
+
break;
|
|
11239
|
+
}
|
|
11240
|
+
}
|
|
11241
|
+
if (filtersMatched) {
|
|
11242
|
+
statCollector.addHeaders(report, metricsString);
|
|
11243
|
+
}
|
|
11244
|
+
} else {
|
|
11245
|
+
statCollector.addHeaders(report, metricsString);
|
|
11246
|
+
}
|
|
11247
|
+
});
|
|
11248
|
+
} else {
|
|
11249
|
+
statCollector.logger.warn(LOG_PREFIX, "No report type found in RTC stats: '" + type + "'");
|
|
11250
|
+
}
|
|
11251
|
+
});
|
|
11252
|
+
case 2:
|
|
11253
|
+
return _context3.a(2);
|
|
11254
|
+
}
|
|
11255
|
+
}, _callee3);
|
|
11256
|
+
}));
|
|
11257
|
+
function updateHeaders() {
|
|
11258
|
+
return _updateHeaders.apply(this, arguments);
|
|
11259
|
+
}
|
|
11260
|
+
return updateHeaders;
|
|
11261
|
+
}(),
|
|
11262
|
+
addHeaders: function addHeaders(report, metricsString) {
|
|
11263
|
+
if (metricsString) {
|
|
11264
|
+
var metrics = metricsString.split(",");
|
|
11265
|
+
metrics.forEach(function (metric) {
|
|
11266
|
+
var metricFound = false;
|
|
11267
|
+
for (var _i = 0, _Object$keys = Object.keys(report); _i < _Object$keys.length; _i++) {
|
|
11268
|
+
var key = _Object$keys[_i];
|
|
11269
|
+
if (metric === key) {
|
|
11270
|
+
statCollector.headers = util.addFieldToCsvString(statCollector.headers, report.type + "." + report.id + "." + metric, ",");
|
|
11271
|
+
metricFound = true;
|
|
11272
|
+
break;
|
|
11273
|
+
}
|
|
11274
|
+
}
|
|
11275
|
+
if (!metricFound) {
|
|
11276
|
+
statCollector.logger.warn(LOG_PREFIX, "No metric found in RTC stats report '" + report.type + "': '" + metric + "'");
|
|
11277
|
+
}
|
|
11278
|
+
});
|
|
11279
|
+
}
|
|
11280
|
+
},
|
|
11281
|
+
updateCompression: function () {
|
|
11282
|
+
var _updateCompression = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee4() {
|
|
11283
|
+
return _regenerator().w(function (_context4) {
|
|
11284
|
+
while (1) switch (_context4.n) {
|
|
11285
|
+
case 0:
|
|
11286
|
+
if (!statCollector.description.compression) {
|
|
11287
|
+
_context4.n = 3;
|
|
11288
|
+
break;
|
|
11289
|
+
}
|
|
11290
|
+
if (!(statCollector.description.compression.indexOf("gzip") >= 0)) {
|
|
11291
|
+
_context4.n = 2;
|
|
11292
|
+
break;
|
|
11293
|
+
}
|
|
11294
|
+
_context4.n = 1;
|
|
11295
|
+
return statCollector.checkForCompression("gzip");
|
|
11296
|
+
case 1:
|
|
11297
|
+
_context4.n = 3;
|
|
11298
|
+
break;
|
|
11299
|
+
case 2:
|
|
11300
|
+
if (!(statCollector.description.compression.indexOf("deflate") >= 0)) {
|
|
11301
|
+
_context4.n = 3;
|
|
11302
|
+
break;
|
|
11303
|
+
}
|
|
11304
|
+
_context4.n = 3;
|
|
11305
|
+
return statCollector.checkForCompression("deflate");
|
|
11306
|
+
case 3:
|
|
11307
|
+
return _context4.a(2);
|
|
11308
|
+
}
|
|
11309
|
+
}, _callee4);
|
|
11310
|
+
}));
|
|
11311
|
+
function updateCompression() {
|
|
11312
|
+
return _updateCompression.apply(this, arguments);
|
|
11313
|
+
}
|
|
11314
|
+
return updateCompression;
|
|
11315
|
+
}(),
|
|
11316
|
+
checkForCompression: function () {
|
|
11317
|
+
var _checkForCompression = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee5(compression) {
|
|
11318
|
+
var _t2;
|
|
11319
|
+
return _regenerator().w(function (_context5) {
|
|
11320
|
+
while (1) switch (_context5.p = _context5.n) {
|
|
11321
|
+
case 0:
|
|
11322
|
+
_context5.p = 0;
|
|
11323
|
+
_context5.n = 1;
|
|
11324
|
+
return util.compress(compression, "test", false);
|
|
11325
|
+
case 1:
|
|
11326
|
+
statCollector.compression = compression;
|
|
11327
|
+
_context5.n = 3;
|
|
11328
|
+
break;
|
|
11329
|
+
case 2:
|
|
11330
|
+
_context5.p = 2;
|
|
11331
|
+
_t2 = _context5.v;
|
|
11332
|
+
statCollector.logger.warn(LOG_PREFIX, "Can't compress metrics data using " + compression + ": " + _t2);
|
|
11333
|
+
statCollector.compression = "none";
|
|
11334
|
+
case 3:
|
|
11335
|
+
return _context5.a(2);
|
|
11336
|
+
}
|
|
11337
|
+
}, _callee5, null, [[0, 2]]);
|
|
11338
|
+
}));
|
|
11339
|
+
function checkForCompression(_x2) {
|
|
11340
|
+
return _checkForCompression.apply(this, arguments);
|
|
11341
|
+
}
|
|
11342
|
+
return checkForCompression;
|
|
11343
|
+
}(),
|
|
11344
|
+
sendHeaders: function sendHeaders() {
|
|
11345
|
+
var data = {
|
|
11346
|
+
mediaSessionId: statCollector.id,
|
|
11347
|
+
compression: statCollector.compression,
|
|
11348
|
+
headers: statCollector.headers
|
|
11349
|
+
};
|
|
11350
|
+
statCollector.send("webRTCMetricsClientDescription", data);
|
|
11351
|
+
},
|
|
11352
|
+
send: function send(message, data) {
|
|
11353
|
+
statCollector.logger.debug(LOG_PREFIX, data);
|
|
11354
|
+
if (statCollector.wsConnection.readyState === WebSocket.OPEN) {
|
|
11355
|
+
statCollector.wsConnection.send(JSON.stringify({
|
|
11356
|
+
message: message,
|
|
11357
|
+
data: [data]
|
|
11358
|
+
}));
|
|
11359
|
+
}
|
|
11360
|
+
},
|
|
11361
|
+
startTimer: function startTimer() {
|
|
11362
|
+
if (!statCollector.timer && statCollector.headers) {
|
|
11363
|
+
statCollector.batchCount = statCollector.description.batchSize;
|
|
11364
|
+
statCollector.timer = setInterval(statCollector.collectMetrics, statCollector.description.sampling);
|
|
11365
|
+
}
|
|
11366
|
+
},
|
|
11367
|
+
stopTimer: function stopTimer() {
|
|
11368
|
+
if (statCollector.timer) {
|
|
11369
|
+
clearInterval(statCollector.timer);
|
|
11370
|
+
statCollector.timer = null;
|
|
11371
|
+
statCollector.metricsBatch = null;
|
|
11372
|
+
}
|
|
11373
|
+
},
|
|
11374
|
+
collectMetrics: function () {
|
|
11375
|
+
var _collectMetrics = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee6() {
|
|
11376
|
+
var stats, metrics;
|
|
11377
|
+
return _regenerator().w(function (_context6) {
|
|
11378
|
+
while (1) switch (_context6.n) {
|
|
11379
|
+
case 0:
|
|
11380
|
+
if (!statCollector.timer) {
|
|
11381
|
+
_context6.n = 2;
|
|
11382
|
+
break;
|
|
11383
|
+
}
|
|
11384
|
+
_context6.n = 1;
|
|
11385
|
+
return statCollector.mediaConnection.getWebRTCStats();
|
|
11386
|
+
case 1:
|
|
11387
|
+
stats = _context6.v;
|
|
11388
|
+
if (!statCollector.metricsBatch) {
|
|
11389
|
+
statCollector.metricsBatch = [];
|
|
11390
|
+
}
|
|
11391
|
+
metrics = [];
|
|
11392
|
+
statCollector.headers.split(",").forEach(function (header) {
|
|
11393
|
+
var components = header.split(".");
|
|
11394
|
+
var descriptor = {
|
|
11395
|
+
type: components[0],
|
|
11396
|
+
id: components[1],
|
|
11397
|
+
name: components[2]
|
|
11398
|
+
};
|
|
11399
|
+
var value = "undefined";
|
|
11400
|
+
if (stats[descriptor.type]) {
|
|
11401
|
+
var _iterator2 = _createForOfIteratorHelper(stats[descriptor.type]),
|
|
11402
|
+
_step2;
|
|
11403
|
+
try {
|
|
11404
|
+
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
11405
|
+
var report = _step2.value;
|
|
11406
|
+
if (report.id === descriptor.id) {
|
|
11407
|
+
value = report[descriptor.name];
|
|
11408
|
+
break;
|
|
11409
|
+
}
|
|
11410
|
+
}
|
|
11411
|
+
} catch (err) {
|
|
11412
|
+
_iterator2.e(err);
|
|
11413
|
+
} finally {
|
|
11414
|
+
_iterator2.f();
|
|
11415
|
+
}
|
|
11416
|
+
}
|
|
11417
|
+
metrics.push(value);
|
|
11418
|
+
});
|
|
11419
|
+
statCollector.metricsBatch.push(metrics);
|
|
11420
|
+
statCollector.batchCount--;
|
|
11421
|
+
if (!(statCollector.batchCount === 0)) {
|
|
11422
|
+
_context6.n = 2;
|
|
11423
|
+
break;
|
|
11424
|
+
}
|
|
11425
|
+
_context6.n = 2;
|
|
11426
|
+
return statCollector.sendMetrics();
|
|
11427
|
+
case 2:
|
|
11428
|
+
return _context6.a(2);
|
|
11429
|
+
}
|
|
11430
|
+
}, _callee6);
|
|
11431
|
+
}));
|
|
11432
|
+
function collectMetrics() {
|
|
11433
|
+
return _collectMetrics.apply(this, arguments);
|
|
11434
|
+
}
|
|
11435
|
+
return collectMetrics;
|
|
11436
|
+
}(),
|
|
11437
|
+
sendMetrics: function () {
|
|
11438
|
+
var _sendMetrics = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee7() {
|
|
11439
|
+
var previous, metricsToSend, metricsData, i, metricsString, j, valueString, previousString, separator, data, _t3;
|
|
11440
|
+
return _regenerator().w(function (_context7) {
|
|
11441
|
+
while (1) switch (_context7.p = _context7.n) {
|
|
11442
|
+
case 0:
|
|
11443
|
+
metricsToSend = [];
|
|
11444
|
+
for (i = 0; i < statCollector.metricsBatch.length; i++) {
|
|
11445
|
+
metricsString = "";
|
|
11446
|
+
for (j = 0; j < statCollector.metricsBatch[i].length; j++) {
|
|
11447
|
+
valueString = valueToString(statCollector.metricsBatch[i][j]);
|
|
11448
|
+
previousString = "";
|
|
11449
|
+
separator = ";";
|
|
11450
|
+
if (previous) {
|
|
11451
|
+
previousString = valueToString(previous[j]);
|
|
11452
|
+
}
|
|
11453
|
+
if (valueString === previousString) {
|
|
11454
|
+
valueString = "";
|
|
11455
|
+
}
|
|
11456
|
+
metricsString = util.addFieldToCsvString(metricsString, valueString, separator);
|
|
11457
|
+
}
|
|
11458
|
+
previous = statCollector.metricsBatch[i];
|
|
11459
|
+
metricsToSend.push(metricsString);
|
|
11460
|
+
}
|
|
11461
|
+
if (!(statCollector.compression !== "none")) {
|
|
11462
|
+
_context7.n = 5;
|
|
11463
|
+
break;
|
|
11464
|
+
}
|
|
11465
|
+
_context7.p = 1;
|
|
11466
|
+
_context7.n = 2;
|
|
11467
|
+
return util.compress(statCollector.compression, JSON.stringify(metricsToSend), true);
|
|
11468
|
+
case 2:
|
|
11469
|
+
metricsData = _context7.v;
|
|
11470
|
+
_context7.n = 4;
|
|
11471
|
+
break;
|
|
11472
|
+
case 3:
|
|
11473
|
+
_context7.p = 3;
|
|
11474
|
+
_t3 = _context7.v;
|
|
11475
|
+
statCollector.logger.warn(LOG_PREFIX, "Can't send metrics data using" + statCollector.compression + ": " + _t3);
|
|
11476
|
+
metricsData = null;
|
|
11477
|
+
case 4:
|
|
11478
|
+
_context7.n = 6;
|
|
11479
|
+
break;
|
|
11480
|
+
case 5:
|
|
11481
|
+
metricsData = metricsToSend;
|
|
11482
|
+
case 6:
|
|
11483
|
+
if (metricsData) {
|
|
11484
|
+
data = {
|
|
11485
|
+
mediaSessionId: statCollector.id,
|
|
11486
|
+
metrics: metricsData
|
|
11487
|
+
};
|
|
11488
|
+
statCollector.send("webRTCMetricsBatch", data);
|
|
11489
|
+
}
|
|
11490
|
+
statCollector.metricsBatch = null;
|
|
11491
|
+
statCollector.batchCount = statCollector.description.batchSize;
|
|
11492
|
+
case 7:
|
|
11493
|
+
return _context7.a(2);
|
|
11494
|
+
}
|
|
11495
|
+
}, _callee7, null, [[1, 3]]);
|
|
11496
|
+
}));
|
|
11497
|
+
function sendMetrics() {
|
|
11498
|
+
return _sendMetrics.apply(this, arguments);
|
|
11499
|
+
}
|
|
11500
|
+
return sendMetrics;
|
|
11501
|
+
}()
|
|
11502
|
+
};
|
|
11503
|
+
return statCollector;
|
|
11504
|
+
};
|
|
11505
|
+
|
|
11506
|
+
// Helper function to stringify a value
|
|
11507
|
+
var valueToString = function valueToString(value) {
|
|
11508
|
+
var valueString = "undefined";
|
|
11509
|
+
if (_typeof(value) === "object") {
|
|
11510
|
+
valueString = JSON.stringify(value);
|
|
11511
|
+
} else {
|
|
11512
|
+
valueString = value.toString();
|
|
11513
|
+
}
|
|
11514
|
+
return valueString;
|
|
11515
|
+
};
|
|
11516
|
+
|
|
11517
|
+
// Helper function to get logger object
|
|
11518
|
+
var getLogger = function getLogger(logger) {
|
|
11519
|
+
if (logger) {
|
|
11520
|
+
if (logger.info !== undefined && logger.warn !== undefined && logger.error !== undefined && logger.debug !== undefined) {
|
|
11521
|
+
return logger;
|
|
11522
|
+
}
|
|
11523
|
+
}
|
|
11524
|
+
return {
|
|
11525
|
+
info: function info() {},
|
|
11526
|
+
warn: function warn() {},
|
|
11527
|
+
error: function error() {},
|
|
11528
|
+
debug: function debug() {}
|
|
11529
|
+
};
|
|
11530
|
+
};
|
|
11531
|
+
module.exports = {
|
|
11532
|
+
StreamStatsCollector: StreamStatsCollector
|
|
11533
|
+
};
|
|
11534
|
+
|
|
11535
|
+
},{"./util":42}],42:[function(require,module,exports){
|
|
10955
11536
|
'use strict';
|
|
10956
11537
|
|
|
11538
|
+
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
11539
|
+
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
11540
|
+
function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
|
|
11541
|
+
function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
11542
|
+
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
11543
|
+
function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
|
|
11544
|
+
function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
|
|
11545
|
+
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
11546
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
11547
|
+
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
10957
11548
|
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
10958
11549
|
var isEmptyObject = function isEmptyObject(obj) {
|
|
10959
11550
|
for (var name in obj) {
|
|
@@ -11433,6 +12024,70 @@ var setPublishingBitrate = function setPublishingBitrate(sdp, mediaConnection, m
|
|
|
11433
12024
|
}
|
|
11434
12025
|
return sdp;
|
|
11435
12026
|
};
|
|
12027
|
+
var addFieldToCsvString = function addFieldToCsvString(csvString, field, separator) {
|
|
12028
|
+
if (field !== "" && field.indexOf(separator) >= 0) {
|
|
12029
|
+
field = '"' + field + '"';
|
|
12030
|
+
}
|
|
12031
|
+
if (csvString === "" && field !== "") {
|
|
12032
|
+
csvString = field;
|
|
12033
|
+
} else {
|
|
12034
|
+
csvString = csvString + separator + field;
|
|
12035
|
+
}
|
|
12036
|
+
return csvString;
|
|
12037
|
+
};
|
|
12038
|
+
var compress = /*#__PURE__*/function () {
|
|
12039
|
+
var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(compression, data, base64) {
|
|
12040
|
+
var stream, compressedReadableStream, compressedResponse, blob, buffer, compressedBase64;
|
|
12041
|
+
return _regenerator().w(function (_context) {
|
|
12042
|
+
while (1) switch (_context.n) {
|
|
12043
|
+
case 0:
|
|
12044
|
+
if (!(typeof CompressionStream === "undefined")) {
|
|
12045
|
+
_context.n = 1;
|
|
12046
|
+
break;
|
|
12047
|
+
}
|
|
12048
|
+
throw new Error("Compression is not available");
|
|
12049
|
+
case 1:
|
|
12050
|
+
if (typeof data == "string") {
|
|
12051
|
+
stream = new Blob([data], {
|
|
12052
|
+
type: 'text/plain'
|
|
12053
|
+
}).stream();
|
|
12054
|
+
} else {
|
|
12055
|
+
// Assume blog
|
|
12056
|
+
stream = data.stream();
|
|
12057
|
+
}
|
|
12058
|
+
|
|
12059
|
+
// gzip stream
|
|
12060
|
+
compressedReadableStream = stream.pipeThrough(new CompressionStream(compression)); // create Response
|
|
12061
|
+
_context.n = 2;
|
|
12062
|
+
return new Response(compressedReadableStream);
|
|
12063
|
+
case 2:
|
|
12064
|
+
compressedResponse = _context.v;
|
|
12065
|
+
_context.n = 3;
|
|
12066
|
+
return compressedResponse.blob();
|
|
12067
|
+
case 3:
|
|
12068
|
+
blob = _context.v;
|
|
12069
|
+
if (!base64) {
|
|
12070
|
+
_context.n = 5;
|
|
12071
|
+
break;
|
|
12072
|
+
}
|
|
12073
|
+
_context.n = 4;
|
|
12074
|
+
return blob.arrayBuffer();
|
|
12075
|
+
case 4:
|
|
12076
|
+
buffer = _context.v;
|
|
12077
|
+
// convert ArrayBuffer to base64 encoded string
|
|
12078
|
+
compressedBase64 = btoa(String.fromCharCode.apply(String, _toConsumableArray(new Uint8Array(buffer))));
|
|
12079
|
+
return _context.a(2, compressedBase64);
|
|
12080
|
+
case 5:
|
|
12081
|
+
return _context.a(2, blob);
|
|
12082
|
+
case 6:
|
|
12083
|
+
return _context.a(2);
|
|
12084
|
+
}
|
|
12085
|
+
}, _callee);
|
|
12086
|
+
}));
|
|
12087
|
+
return function compress(_x, _x2, _x3) {
|
|
12088
|
+
return _ref.apply(this, arguments);
|
|
12089
|
+
};
|
|
12090
|
+
}();
|
|
11436
12091
|
module.exports = {
|
|
11437
12092
|
isEmptyObject: isEmptyObject,
|
|
11438
12093
|
copyObjectToArray: copyObjectToArray,
|
|
@@ -11444,22 +12099,24 @@ module.exports = {
|
|
|
11444
12099
|
stripCodecs: stripCodecs,
|
|
11445
12100
|
getCurrentCodecAndSampleRate: getCurrentCodecAndSampleRate,
|
|
11446
12101
|
isPromise: isPromise,
|
|
11447
|
-
setPublishingBitrate: setPublishingBitrate
|
|
12102
|
+
setPublishingBitrate: setPublishingBitrate,
|
|
12103
|
+
addFieldToCsvString: addFieldToCsvString,
|
|
12104
|
+
compress: compress
|
|
11448
12105
|
};
|
|
11449
12106
|
|
|
11450
|
-
},{}],
|
|
12107
|
+
},{}],43:[function(require,module,exports){
|
|
11451
12108
|
function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
|
|
11452
12109
|
function _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
|
|
11453
|
-
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
11454
|
-
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
11455
|
-
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
11456
|
-
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
11457
12110
|
function _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
|
|
11458
12111
|
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
11459
12112
|
function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
|
|
11460
12113
|
function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
|
|
11461
12114
|
function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
|
|
11462
12115
|
function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
|
|
12116
|
+
function _regenerator() { /*! regenerator-runtime -- Copyright (c) 2014-present, Facebook, Inc. -- license (MIT): https://github.com/babel/babel/blob/main/packages/babel-helpers/LICENSE */ var e, t, r = "function" == typeof Symbol ? Symbol : {}, n = r.iterator || "@@iterator", o = r.toStringTag || "@@toStringTag"; function i(r, n, o, i) { var c = n && n.prototype instanceof Generator ? n : Generator, u = Object.create(c.prototype); return _regeneratorDefine2(u, "_invoke", function (r, n, o) { var i, c, u, f = 0, p = o || [], y = !1, G = { p: 0, n: 0, v: e, a: d, f: d.bind(e, 4), d: function d(t, r) { return i = t, c = 0, u = e, G.n = r, a; } }; function d(r, n) { for (c = r, u = n, t = 0; !y && f && !o && t < p.length; t++) { var o, i = p[t], d = G.p, l = i[2]; r > 3 ? (o = l === n) && (u = i[(c = i[4]) ? 5 : (c = 3, 3)], i[4] = i[5] = e) : i[0] <= d && ((o = r < 2 && d < i[1]) ? (c = 0, G.v = n, G.n = i[1]) : d < l && (o = r < 3 || i[0] > n || n > l) && (i[4] = r, i[5] = n, G.n = l, c = 0)); } if (o || r > 1) return a; throw y = !0, n; } return function (o, p, l) { if (f > 1) throw TypeError("Generator is already running"); for (y && 1 === p && d(p, l), c = p, u = l; (t = c < 2 ? e : u) || !y;) { i || (c ? c < 3 ? (c > 1 && (G.n = -1), d(c, u)) : G.n = u : G.v = u); try { if (f = 2, i) { if (c || (o = "next"), t = i[o]) { if (!(t = t.call(i, u))) throw TypeError("iterator result is not an object"); if (!t.done) return t; u = t.value, c < 2 && (c = 0); } else 1 === c && (t = i["return"]) && t.call(i), c < 2 && (u = TypeError("The iterator does not provide a '" + o + "' method"), c = 1); i = e; } else if ((t = (y = G.n < 0) ? u : r.call(n, G)) !== a) break; } catch (t) { i = e, c = 1, u = t; } finally { f = 1; } } return { value: t, done: y }; }; }(r, o, i), !0), u; } var a = {}; function Generator() {} function GeneratorFunction() {} function GeneratorFunctionPrototype() {} t = Object.getPrototypeOf; var c = [][n] ? t(t([][n]())) : (_regeneratorDefine2(t = {}, n, function () { return this; }), t), u = GeneratorFunctionPrototype.prototype = Generator.prototype = Object.create(c); function f(e) { return Object.setPrototypeOf ? Object.setPrototypeOf(e, GeneratorFunctionPrototype) : (e.__proto__ = GeneratorFunctionPrototype, _regeneratorDefine2(e, o, "GeneratorFunction")), e.prototype = Object.create(u), e; } return GeneratorFunction.prototype = GeneratorFunctionPrototype, _regeneratorDefine2(u, "constructor", GeneratorFunctionPrototype), _regeneratorDefine2(GeneratorFunctionPrototype, "constructor", GeneratorFunction), GeneratorFunction.displayName = "GeneratorFunction", _regeneratorDefine2(GeneratorFunctionPrototype, o, "GeneratorFunction"), _regeneratorDefine2(u), _regeneratorDefine2(u, o, "Generator"), _regeneratorDefine2(u, n, function () { return this; }), _regeneratorDefine2(u, "toString", function () { return "[object Generator]"; }), (_regenerator = function _regenerator() { return { w: i, m: f }; })(); }
|
|
12117
|
+
function _regeneratorDefine2(e, r, n, t) { var i = Object.defineProperty; try { i({}, "", {}); } catch (e) { i = 0; } _regeneratorDefine2 = function _regeneratorDefine(e, r, n, t) { function o(r, n) { _regeneratorDefine2(e, r, function (e) { return this._invoke(r, n, e); }); } r ? i ? i(e, r, { value: n, enumerable: !t, configurable: !t, writable: !t }) : e[r] = n : (o("next", 0), o("throw", 1), o("return", 2)); }, _regeneratorDefine2(e, r, n, t); }
|
|
12118
|
+
function asyncGeneratorStep(n, t, e, r, o, a, c) { try { var i = n[a](c), u = i.value; } catch (n) { return void e(n); } i.done ? t(u) : Promise.resolve(u).then(r, o); }
|
|
12119
|
+
function _asyncToGenerator(n) { return function () { var t = this, e = arguments; return new Promise(function (r, o) { var a = n.apply(t, e); function _next(n) { asyncGeneratorStep(a, r, o, _next, _throw, "next", n); } function _throw(n) { asyncGeneratorStep(a, r, o, _next, _throw, "throw", n); } _next(void 0); }); }; }
|
|
11463
12120
|
-'use strict';
|
|
11464
12121
|
var browserDetails = require('webrtc-adapter')["default"].browserDetails;
|
|
11465
12122
|
var _require = require('uuid'),
|
|
@@ -11904,67 +12561,70 @@ var createConnection = function createConnection(options) {
|
|
|
11904
12561
|
}
|
|
11905
12562
|
return true;
|
|
11906
12563
|
};
|
|
11907
|
-
var getStat = function
|
|
11908
|
-
var
|
|
11909
|
-
|
|
11910
|
-
|
|
11911
|
-
|
|
11912
|
-
|
|
11913
|
-
|
|
11914
|
-
|
|
11915
|
-
|
|
11916
|
-
|
|
11917
|
-
|
|
11918
|
-
|
|
11919
|
-
|
|
11920
|
-
|
|
11921
|
-
|
|
11922
|
-
|
|
11923
|
-
|
|
11924
|
-
|
|
11925
|
-
|
|
11926
|
-
|
|
11927
|
-
|
|
12564
|
+
var getStat = /*#__PURE__*/function () {
|
|
12565
|
+
var _ref = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee(callbackFn, nativeStats) {
|
|
12566
|
+
var result, rawStat;
|
|
12567
|
+
return _regenerator().w(function (_context) {
|
|
12568
|
+
while (1) switch (_context.n) {
|
|
12569
|
+
case 0:
|
|
12570
|
+
result = {
|
|
12571
|
+
outboundStream: {},
|
|
12572
|
+
inboundStream: {},
|
|
12573
|
+
otherStats: []
|
|
12574
|
+
};
|
|
12575
|
+
_context.n = 1;
|
|
12576
|
+
return getWebRTCStats();
|
|
12577
|
+
case 1:
|
|
12578
|
+
rawStat = _context.v;
|
|
12579
|
+
if (nativeStats) {
|
|
12580
|
+
callbackFn(rawStat);
|
|
12581
|
+
} else {
|
|
12582
|
+
if (rawStat["candidate-pair"]) {
|
|
12583
|
+
rawStat["candidate-pair"].forEach(function (report) {
|
|
12584
|
+
if (report.state === 'succeeded' && report.nominated) {
|
|
12585
|
+
if (report.availableIncomingBitrate) {
|
|
12586
|
+
result.otherStats.availableIncomingBitrate = report.availableIncomingBitrate;
|
|
12587
|
+
} else if (localVideo && report.availableOutgoingBitrate) {
|
|
12588
|
+
// availableOutgoingBitrate is defined for incoming stream too #WCS-4175
|
|
12589
|
+
result.otherStats.availableOutgoingBitrate = report.availableOutgoingBitrate;
|
|
12590
|
+
}
|
|
11928
12591
|
}
|
|
11929
|
-
}
|
|
11930
|
-
|
|
11931
|
-
|
|
11932
|
-
|
|
11933
|
-
|
|
12592
|
+
});
|
|
12593
|
+
}
|
|
12594
|
+
if (rawStat["outbound-rtp"]) {
|
|
12595
|
+
rawStat["outbound-rtp"].forEach(function (report) {
|
|
12596
|
+
fillStatObject(result.outboundStream, report, report.kind);
|
|
12597
|
+
if (report.kind === "video") {
|
|
12598
|
+
getVideoSize(result.outboundStream[report.kind], report.type, report);
|
|
11934
12599
|
}
|
|
11935
|
-
}
|
|
11936
|
-
|
|
11937
|
-
|
|
11938
|
-
|
|
11939
|
-
|
|
11940
|
-
|
|
12600
|
+
});
|
|
12601
|
+
}
|
|
12602
|
+
if (rawStat["inbound-rtp"]) {
|
|
12603
|
+
rawStat["inbound-rtp"].forEach(function (report) {
|
|
12604
|
+
fillStatObject(result.inboundStream, report, report.kind);
|
|
12605
|
+
if (report.kind === "video") {
|
|
12606
|
+
getVideoSize(result.inboundStream["video"], report.type, report);
|
|
11941
12607
|
}
|
|
11942
|
-
}
|
|
12608
|
+
});
|
|
11943
12609
|
}
|
|
11944
|
-
|
|
11945
|
-
|
|
11946
|
-
|
|
11947
|
-
|
|
11948
|
-
|
|
11949
|
-
|
|
11950
|
-
|
|
11951
|
-
|
|
11952
|
-
|
|
11953
|
-
|
|
11954
|
-
|
|
11955
|
-
|
|
11956
|
-
return report.kind;
|
|
11957
|
-
}
|
|
11958
|
-
logger.warn(LOG_PREFIX, "No media type provided in WebRTC statistics");
|
|
11959
|
-
return "media";
|
|
11960
|
-
};
|
|
11961
|
-
var getVideoSize = function getVideoSize(obj, report) {
|
|
12610
|
+
callbackFn(result);
|
|
12611
|
+
}
|
|
12612
|
+
case 2:
|
|
12613
|
+
return _context.a(2);
|
|
12614
|
+
}
|
|
12615
|
+
}, _callee);
|
|
12616
|
+
}));
|
|
12617
|
+
return function getStat(_x, _x2) {
|
|
12618
|
+
return _ref.apply(this, arguments);
|
|
12619
|
+
};
|
|
12620
|
+
}();
|
|
12621
|
+
var getVideoSize = function getVideoSize(obj, type, report) {
|
|
11962
12622
|
var videoSize = {};
|
|
11963
|
-
if (
|
|
12623
|
+
if (type === 'outbound-rtp') {
|
|
11964
12624
|
if (localVideo !== undefined && localVideo != null) {
|
|
11965
12625
|
videoSize = localVideo.srcObject.getVideoTracks()[0].getSettings();
|
|
11966
12626
|
}
|
|
11967
|
-
} else if (
|
|
12627
|
+
} else if (type === 'inbound-rtp') {
|
|
11968
12628
|
if (remoteVideo !== undefined && remoteVideo != null) {
|
|
11969
12629
|
videoSize.width = remoteVideo.videoWidth;
|
|
11970
12630
|
videoSize.height = remoteVideo.videoHeight;
|
|
@@ -12367,25 +13027,25 @@ var createConnection = function createConnection(options) {
|
|
|
12367
13027
|
return zoom;
|
|
12368
13028
|
};
|
|
12369
13029
|
var setZoom = /*#__PURE__*/function () {
|
|
12370
|
-
var
|
|
13030
|
+
var _ref2 = _asyncToGenerator(/*#__PURE__*/_regenerator().m(function _callee2(value) {
|
|
12371
13031
|
var _localVideo$srcObject3, _localVideo$srcObject4, track;
|
|
12372
|
-
return _regenerator().w(function (
|
|
12373
|
-
while (1) switch (
|
|
13032
|
+
return _regenerator().w(function (_context2) {
|
|
13033
|
+
while (1) switch (_context2.n) {
|
|
12374
13034
|
case 0:
|
|
12375
13035
|
if (!zoom) {
|
|
12376
|
-
|
|
13036
|
+
_context2.n = 6;
|
|
12377
13037
|
break;
|
|
12378
13038
|
}
|
|
12379
13039
|
if (!(value >= zoom.min && value <= zoom.max)) {
|
|
12380
|
-
|
|
13040
|
+
_context2.n = 4;
|
|
12381
13041
|
break;
|
|
12382
13042
|
}
|
|
12383
13043
|
if (!(localVideo && localVideo.srcObject)) {
|
|
12384
|
-
|
|
13044
|
+
_context2.n = 2;
|
|
12385
13045
|
break;
|
|
12386
13046
|
}
|
|
12387
13047
|
_localVideo$srcObject3 = localVideo.srcObject.getVideoTracks(), _localVideo$srcObject4 = _slicedToArray(_localVideo$srcObject3, 1), track = _localVideo$srcObject4[0];
|
|
12388
|
-
|
|
13048
|
+
_context2.n = 1;
|
|
12389
13049
|
return track.applyConstraints({
|
|
12390
13050
|
advanced: [{
|
|
12391
13051
|
zoom: value
|
|
@@ -12393,27 +13053,27 @@ var createConnection = function createConnection(options) {
|
|
|
12393
13053
|
});
|
|
12394
13054
|
case 1:
|
|
12395
13055
|
zoom.value = value;
|
|
12396
|
-
|
|
13056
|
+
_context2.n = 3;
|
|
12397
13057
|
break;
|
|
12398
13058
|
case 2:
|
|
12399
13059
|
logger.warn(LOG_PREFIX, "Can't set zoom value: no local video");
|
|
12400
13060
|
case 3:
|
|
12401
|
-
|
|
13061
|
+
_context2.n = 5;
|
|
12402
13062
|
break;
|
|
12403
13063
|
case 4:
|
|
12404
13064
|
logger.info(LOG_PREFIX, "Zoom value " + value + "is out of range: " + zoom.min + "-" + zoom.max);
|
|
12405
13065
|
case 5:
|
|
12406
|
-
|
|
13066
|
+
_context2.n = 7;
|
|
12407
13067
|
break;
|
|
12408
13068
|
case 6:
|
|
12409
13069
|
logger.info(LOG_PREFIX, "Zoom is not supported or zoom capabilities unknown yet");
|
|
12410
13070
|
case 7:
|
|
12411
|
-
return
|
|
13071
|
+
return _context2.a(2);
|
|
12412
13072
|
}
|
|
12413
|
-
},
|
|
13073
|
+
}, _callee2);
|
|
12414
13074
|
}));
|
|
12415
|
-
return function setZoom(
|
|
12416
|
-
return
|
|
13075
|
+
return function setZoom(_x3) {
|
|
13076
|
+
return _ref2.apply(this, arguments);
|
|
12417
13077
|
};
|
|
12418
13078
|
}();
|
|
12419
13079
|
var getZoom = function getZoom() {
|
|
@@ -12422,6 +13082,32 @@ var createConnection = function createConnection(options) {
|
|
|
12422
13082
|
}
|
|
12423
13083
|
return -1;
|
|
12424
13084
|
};
|
|
13085
|
+
var getWebRTCStats = function getWebRTCStats() {
|
|
13086
|
+
return new Promise(function (resolve, reject) {
|
|
13087
|
+
var browser = browserDetails.browser;
|
|
13088
|
+
if (connection && validBrowsers.includes(browser)) {
|
|
13089
|
+
connection.getStats(null).then(function (stats) {
|
|
13090
|
+
var statObject = {};
|
|
13091
|
+
if (stats) {
|
|
13092
|
+
stats.forEach(function (report) {
|
|
13093
|
+
if (report) {
|
|
13094
|
+
if (statObject[report.type] === undefined) {
|
|
13095
|
+
statObject[report.type] = [];
|
|
13096
|
+
}
|
|
13097
|
+
statObject[report.type].push(report);
|
|
13098
|
+
}
|
|
13099
|
+
});
|
|
13100
|
+
}
|
|
13101
|
+
resolve(statObject);
|
|
13102
|
+
})["catch"](function (reason) {
|
|
13103
|
+
logger.error(LOG_PREFIX, reason);
|
|
13104
|
+
reject(reason);
|
|
13105
|
+
});
|
|
13106
|
+
} else {
|
|
13107
|
+
reject(constants.ERROR_INFO.CAN_NOT_GET_STATS);
|
|
13108
|
+
}
|
|
13109
|
+
});
|
|
13110
|
+
};
|
|
12425
13111
|
var exports = {};
|
|
12426
13112
|
exports.state = state;
|
|
12427
13113
|
exports.createOffer = createOffer;
|
|
@@ -12454,6 +13140,7 @@ var createConnection = function createConnection(options) {
|
|
|
12454
13140
|
exports.getZoomCapabilities = getZoomCapabilities;
|
|
12455
13141
|
exports.setZoom = setZoom;
|
|
12456
13142
|
exports.getZoom = getZoom;
|
|
13143
|
+
exports.getWebRTCStats = getWebRTCStats;
|
|
12457
13144
|
connections[id] = exports;
|
|
12458
13145
|
resolve(exports);
|
|
12459
13146
|
});
|
|
@@ -13227,5 +13914,5 @@ module.exports = {
|
|
|
13227
13914
|
getVideoElement: getVideoElement
|
|
13228
13915
|
};
|
|
13229
13916
|
|
|
13230
|
-
},{"./constants":39,"./util":
|
|
13917
|
+
},{"./constants":39,"./util":42,"uuid":8,"webrtc-adapter":23}]},{},[40])(40)
|
|
13231
13918
|
});
|