|
@@ -2,6 +2,7 @@
|
2
|
2
|
var JitsiTrack = require("./JitsiTrack");
|
3
|
3
|
var RTCBrowserType = require("./RTCBrowserType");
|
4
|
4
|
var JitsiTrackEvents = require('../../JitsiTrackEvents');
|
|
5
|
+var JitsiTrackErrors = require("../../JitsiTrackErrors");
|
5
|
6
|
var RTCUtils = require("./RTCUtils");
|
6
|
7
|
|
7
|
8
|
/**
|
|
@@ -28,26 +29,92 @@ function JitsiLocalTrack(stream, videoType,
|
28
|
29
|
this.dontFireRemoveEvent = false;
|
29
|
30
|
}.bind(this));
|
30
|
31
|
this.initialMSID = this.getMSID();
|
|
32
|
+ this.inMuteOrUnmuteProcess = false;
|
31
|
33
|
}
|
32
|
34
|
|
33
|
35
|
JitsiLocalTrack.prototype = Object.create(JitsiTrack.prototype);
|
34
|
36
|
JitsiLocalTrack.prototype.constructor = JitsiLocalTrack;
|
35
|
37
|
|
|
38
|
+/**
|
|
39
|
+ * Mutes the track. Will reject the Promise if there is mute/unmute operation
|
|
40
|
+ * in progress.
|
|
41
|
+ * @returns {Promise}
|
|
42
|
+ */
|
|
43
|
+JitsiLocalTrack.prototype.mute = function () {
|
|
44
|
+ return new Promise(function (resolve, reject) {
|
|
45
|
+
|
|
46
|
+ if(this.inMuteOrUnmuteProcess) {
|
|
47
|
+ reject(new Error(JitsiTrackErrors.TRACK_MUTE_UNMUTE_IN_PROGRESS));
|
|
48
|
+ return;
|
|
49
|
+ }
|
|
50
|
+ this.inMuteOrUnmuteProcess = true;
|
|
51
|
+
|
|
52
|
+ this._setMute(true,
|
|
53
|
+ function(){
|
|
54
|
+ this.inMuteOrUnmuteProcess = false;
|
|
55
|
+ resolve();
|
|
56
|
+ }.bind(this),
|
|
57
|
+ function(status){
|
|
58
|
+ this.inMuteOrUnmuteProcess = false;
|
|
59
|
+ reject(status);
|
|
60
|
+ }.bind(this));
|
|
61
|
+ }.bind(this));
|
|
62
|
+}
|
|
63
|
+
|
|
64
|
+/**
|
|
65
|
+ * Unmutes the stream. Will reject the Promise if there is mute/unmute operation
|
|
66
|
+ * in progress.
|
|
67
|
+ * @returns {Promise}
|
|
68
|
+ */
|
|
69
|
+JitsiLocalTrack.prototype.unmute = function () {
|
|
70
|
+ return new Promise(function (resolve, reject) {
|
|
71
|
+
|
|
72
|
+ if(this.inMuteOrUnmuteProcess) {
|
|
73
|
+ reject(new Error(JitsiTrackErrors.TRACK_MUTE_UNMUTE_IN_PROGRESS));
|
|
74
|
+ return;
|
|
75
|
+ }
|
|
76
|
+ this.inMuteOrUnmuteProcess = true;
|
|
77
|
+
|
|
78
|
+ this._setMute(false,
|
|
79
|
+ function(){
|
|
80
|
+ this.inMuteOrUnmuteProcess = false;
|
|
81
|
+ resolve();
|
|
82
|
+ }.bind(this),
|
|
83
|
+ function(status){
|
|
84
|
+ this.inMuteOrUnmuteProcess = false;
|
|
85
|
+ reject(status);
|
|
86
|
+ }.bind(this));
|
|
87
|
+ }.bind(this));
|
|
88
|
+}
|
|
89
|
+
|
36
|
90
|
/**
|
37
|
91
|
* Mutes / unmutes the track.
|
38
|
92
|
* @param mute {boolean} if true the track will be muted. Otherwise the track will be unmuted.
|
39
|
93
|
*/
|
40
|
|
-JitsiLocalTrack.prototype._setMute = function (mute) {
|
|
94
|
+JitsiLocalTrack.prototype._setMute = function (mute, resolve, reject) {
|
41
|
95
|
if (this.isMuted() === mute) {
|
|
96
|
+ resolve();
|
42
|
97
|
return;
|
43
|
98
|
}
|
44
|
99
|
if(!this.rtc) {
|
45
|
100
|
this.startMuted = mute;
|
|
101
|
+ resolve();
|
46
|
102
|
return;
|
47
|
103
|
}
|
48
|
104
|
var isAudio = this.type === JitsiTrack.AUDIO;
|
49
|
105
|
this.dontFireRemoveEvent = false;
|
50
|
106
|
|
|
107
|
+ var setStreamToNull = false;
|
|
108
|
+ // the callback that will notify that operation had finished
|
|
109
|
+ var callbackFunction = function() {
|
|
110
|
+
|
|
111
|
+ if(setStreamToNull)
|
|
112
|
+ this.stream = null;
|
|
113
|
+ this.eventEmitter.emit(JitsiTrackEvents.TRACK_MUTE_CHANGED);
|
|
114
|
+
|
|
115
|
+ resolve();
|
|
116
|
+ }.bind(this);
|
|
117
|
+
|
51
|
118
|
if ((window.location.protocol != "https:") ||
|
52
|
119
|
(isAudio) || this.videoType === "desktop" ||
|
53
|
120
|
// FIXME FF does not support 'removeStream' method used to mute
|
|
@@ -58,22 +125,20 @@ JitsiLocalTrack.prototype._setMute = function (mute) {
|
58
|
125
|
tracks[idx].enabled = !mute;
|
59
|
126
|
}
|
60
|
127
|
if(isAudio)
|
61
|
|
- this.rtc.room.setAudioMute(mute);
|
|
128
|
+ this.rtc.room.setAudioMute(mute, callbackFunction);
|
62
|
129
|
else
|
63
|
|
- this.rtc.room.setVideoMute(mute);
|
64
|
|
- this.eventEmitter.emit(JitsiTrackEvents.TRACK_MUTE_CHANGED);
|
|
130
|
+ this.rtc.room.setVideoMute(mute, callbackFunction);
|
65
|
131
|
} else {
|
66
|
132
|
if (mute) {
|
67
|
133
|
this.dontFireRemoveEvent = true;
|
68
|
134
|
this.rtc.room.removeStream(this.stream, function () {},
|
69
|
135
|
{mtype: this.type, type: "mute", ssrc: this.ssrc});
|
70
|
136
|
RTCUtils.stopMediaStream(this.stream);
|
|
137
|
+ setStreamToNull = true;
|
71
|
138
|
if(isAudio)
|
72
|
|
- this.rtc.room.setAudioMute(mute);
|
|
139
|
+ this.rtc.room.setAudioMute(mute, callbackFunction);
|
73
|
140
|
else
|
74
|
|
- this.rtc.room.setVideoMute(mute);
|
75
|
|
- this.stream = null;
|
76
|
|
- this.eventEmitter.emit(JitsiTrackEvents.TRACK_MUTE_CHANGED);
|
|
141
|
+ this.rtc.room.setVideoMute(mute, callbackFunction);
|
77
|
142
|
//FIXME: Maybe here we should set the SRC for the containers to something
|
78
|
143
|
} else {
|
79
|
144
|
var self = this;
|
|
@@ -98,8 +163,10 @@ JitsiLocalTrack.prototype._setMute = function (mute) {
|
98
|
163
|
}
|
99
|
164
|
}
|
100
|
165
|
|
101
|
|
- if(!stream)
|
|
166
|
+ if(!stream) {
|
|
167
|
+ reject(new Error('track.no_stream_found'));
|
102
|
168
|
return;
|
|
169
|
+ }
|
103
|
170
|
|
104
|
171
|
for(var i = 0; i < self.containers.length; i++)
|
105
|
172
|
{
|
|
@@ -111,11 +178,11 @@ JitsiLocalTrack.prototype._setMute = function (mute) {
|
111
|
178
|
self.rtc.room.addStream(self.stream,
|
112
|
179
|
function () {
|
113
|
180
|
if(isAudio)
|
114
|
|
- self.rtc.room.setAudioMute(mute);
|
|
181
|
+ self.rtc.room.setAudioMute(
|
|
182
|
+ mute, callbackFunction);
|
115
|
183
|
else
|
116
|
|
- self.rtc.room.setVideoMute(mute);
|
117
|
|
- self.eventEmitter.emit(
|
118
|
|
- JitsiTrackEvents.TRACK_MUTE_CHANGED);
|
|
184
|
+ self.rtc.room.setVideoMute(
|
|
185
|
+ mute, callbackFunction);
|
119
|
186
|
}, {
|
120
|
187
|
mtype: self.type,
|
121
|
188
|
type: "unmute",
|