|
|
@@ -3,7 +3,6 @@
|
|
3
|
3
|
var EventEmitter = require("events");
|
|
4
|
4
|
var eventEmitter = new EventEmitter();
|
|
5
|
5
|
var CQEvents = require("../../service/connectionquality/CQEvents");
|
|
6
|
|
-var XMPPEvents = require("../../service/xmpp/XMPPEvents");
|
|
7
|
6
|
var StatisticsEvents = require("../../service/statistics/Events");
|
|
8
|
7
|
|
|
9
|
8
|
/**
|
|
|
@@ -18,43 +17,6 @@ var stats = {};
|
|
18
|
17
|
*/
|
|
19
|
18
|
var remoteStats = {};
|
|
20
|
19
|
|
|
21
|
|
-/**
|
|
22
|
|
- * Interval for sending statistics to other participants
|
|
23
|
|
- * @type {null}
|
|
24
|
|
- */
|
|
25
|
|
-var sendIntervalId = null;
|
|
26
|
|
-
|
|
27
|
|
-
|
|
28
|
|
-/**
|
|
29
|
|
- * Start statistics sending.
|
|
30
|
|
- */
|
|
31
|
|
-function startSendingStats() {
|
|
32
|
|
- sendStats();
|
|
33
|
|
- sendIntervalId = setInterval(sendStats, 10000);
|
|
34
|
|
-}
|
|
35
|
|
-
|
|
36
|
|
-/**
|
|
37
|
|
- * Sends statistics to other participants
|
|
38
|
|
- */
|
|
39
|
|
-function sendStats() {
|
|
40
|
|
- APP.xmpp.addToPresence("connectionQuality", convertToMUCStats(stats));
|
|
41
|
|
-}
|
|
42
|
|
-
|
|
43
|
|
-/**
|
|
44
|
|
- * Converts statistics to format for sending through XMPP
|
|
45
|
|
- * @param stats the statistics
|
|
46
|
|
- * @returns {{bitrate_donwload: *, bitrate_uplpoad: *, packetLoss_total: *, packetLoss_download: *, packetLoss_upload: *}}
|
|
47
|
|
- */
|
|
48
|
|
-function convertToMUCStats(stats) {
|
|
49
|
|
- return {
|
|
50
|
|
- "bitrate_download": stats.bitrate.download,
|
|
51
|
|
- "bitrate_upload": stats.bitrate.upload,
|
|
52
|
|
- "packetLoss_total": stats.packetLoss.total,
|
|
53
|
|
- "packetLoss_download": stats.packetLoss.download,
|
|
54
|
|
- "packetLoss_upload": stats.packetLoss.upload
|
|
55
|
|
- };
|
|
56
|
|
-}
|
|
57
|
|
-
|
|
58
|
20
|
/**
|
|
59
|
21
|
* Converts statistics to format used by VideoLayout
|
|
60
|
22
|
* @param stats
|
|
|
@@ -76,11 +38,12 @@ function parseMUCStats(stats) {
|
|
76
|
38
|
|
|
77
|
39
|
var ConnectionQuality = {
|
|
78
|
40
|
init: function () {
|
|
79
|
|
- APP.xmpp.addListener(XMPPEvents.REMOTE_STATS, this.updateRemoteStats);
|
|
80
|
|
- APP.statistics.addListener(StatisticsEvents.CONNECTION_STATS,
|
|
81
|
|
- this.updateLocalStats);
|
|
82
|
|
- APP.statistics.addListener(StatisticsEvents.STOP,
|
|
83
|
|
- this.stopSendingStats);
|
|
|
41
|
+ APP.statistics.addListener(
|
|
|
42
|
+ StatisticsEvents.CONNECTION_STATS, this.updateLocalStats
|
|
|
43
|
+ );
|
|
|
44
|
+ APP.statistics.addListener(
|
|
|
45
|
+ StatisticsEvents.STOP, this.stopSendingStats
|
|
|
46
|
+ );
|
|
84
|
47
|
},
|
|
85
|
48
|
|
|
86
|
49
|
/**
|
|
|
@@ -90,33 +53,29 @@ var ConnectionQuality = {
|
|
90
|
53
|
updateLocalStats: function (data) {
|
|
91
|
54
|
stats = data;
|
|
92
|
55
|
eventEmitter.emit(CQEvents.LOCALSTATS_UPDATED, 100 - stats.packetLoss.total, stats);
|
|
93
|
|
- if (!sendIntervalId) {
|
|
94
|
|
- startSendingStats();
|
|
95
|
|
- }
|
|
96
|
56
|
},
|
|
97
|
57
|
|
|
98
|
58
|
/**
|
|
99
|
59
|
* Updates remote statistics
|
|
100
|
|
- * @param jid the jid associated with the statistics
|
|
|
60
|
+ * @param id the id associated with the statistics
|
|
101
|
61
|
* @param data the statistics
|
|
102
|
62
|
*/
|
|
103
|
|
- updateRemoteStats: function (jid, data) {
|
|
|
63
|
+ updateRemoteStats: function (id, data) {
|
|
104
|
64
|
if (!data || !data.packetLoss_total) {
|
|
105
|
|
- eventEmitter.emit(CQEvents.REMOTESTATS_UPDATED, jid, null, null);
|
|
|
65
|
+ eventEmitter.emit(CQEvents.REMOTESTATS_UPDATED, id, null, null);
|
|
106
|
66
|
return;
|
|
107
|
67
|
}
|
|
108
|
|
- remoteStats[jid] = parseMUCStats(data);
|
|
|
68
|
+ remoteStats[id] = parseMUCStats(data);
|
|
109
|
69
|
|
|
110
|
|
- eventEmitter.emit(CQEvents.REMOTESTATS_UPDATED,
|
|
111
|
|
- jid, 100 - data.packetLoss_total, remoteStats[jid]);
|
|
|
70
|
+ eventEmitter.emit(
|
|
|
71
|
+ CQEvents.REMOTESTATS_UPDATED, id, 100 - data.packetLoss_total, remoteStats[id]
|
|
|
72
|
+ );
|
|
112
|
73
|
},
|
|
113
|
74
|
|
|
114
|
75
|
/**
|
|
115
|
76
|
* Stops statistics sending.
|
|
116
|
77
|
*/
|
|
117
|
78
|
stopSendingStats: function () {
|
|
118
|
|
- clearInterval(sendIntervalId);
|
|
119
|
|
- sendIntervalId = null;
|
|
120
|
79
|
//notify UI about stopping statistics gathering
|
|
121
|
80
|
eventEmitter.emit(CQEvents.STOP);
|
|
122
|
81
|
},
|
|
|
@@ -127,11 +86,25 @@ var ConnectionQuality = {
|
|
127
|
86
|
getStats: function () {
|
|
128
|
87
|
return stats;
|
|
129
|
88
|
},
|
|
130
|
|
-
|
|
|
89
|
+
|
|
131
|
90
|
addListener: function (type, listener) {
|
|
132
|
91
|
eventEmitter.on(type, listener);
|
|
133
|
|
- }
|
|
|
92
|
+ },
|
|
134
|
93
|
|
|
|
94
|
+ /**
|
|
|
95
|
+ * Converts statistics to format for sending through XMPP
|
|
|
96
|
+ * @param stats the statistics
|
|
|
97
|
+ * @returns {{bitrate_donwload: *, bitrate_uplpoad: *, packetLoss_total: *, packetLoss_download: *, packetLoss_upload: *}}
|
|
|
98
|
+ */
|
|
|
99
|
+ convertToMUCStats: function (stats) {
|
|
|
100
|
+ return {
|
|
|
101
|
+ "bitrate_download": stats.bitrate.download,
|
|
|
102
|
+ "bitrate_upload": stats.bitrate.upload,
|
|
|
103
|
+ "packetLoss_total": stats.packetLoss.total,
|
|
|
104
|
+ "packetLoss_download": stats.packetLoss.download,
|
|
|
105
|
+ "packetLoss_upload": stats.packetLoss.upload
|
|
|
106
|
+ };
|
|
|
107
|
+ }
|
|
135
|
108
|
};
|
|
136
|
109
|
|
|
137
|
110
|
module.exports = ConnectionQuality;
|