jiti-meet/modules/RTC/MediaStream.js

49 lines
1.5 KiB
JavaScript
Raw Normal View History

var MediaStreamType = require("../../service/RTC/MediaStreamTypes");
2014-12-19 13:59:08 +00:00
/**
* Creates a MediaStream object for the given data, session id and ssrc.
* It is a wrapper class for the MediaStream.
*
* @param data the data object from which we obtain the stream,
* the peerjid, etc.
* @param sid the session id
* @param ssrc the ssrc corresponding to this MediaStream
* @param mute the whether this MediaStream is muted
2014-12-19 13:59:08 +00:00
*
* @constructor
*/
function MediaStream(data, sid, ssrc, browser, eventEmitter, mute) {
// XXX(gp) to minimize headaches in the future, we should build our
// abstractions around tracks and not streams. ORTC is track based API.
// Mozilla expects m-lines to represent media tracks.
//
// Practically, what I'm saying is that we should have a MediaTrack class
// and not a MediaStream class.
//
// Also, we should be able to associate multiple SSRCs with a MediaTrack as
// a track might have an associated RTX and FEC sources.
2014-12-19 13:59:08 +00:00
this.sid = sid;
this.stream = data.stream;
this.peerjid = data.peerjid;
this.videoType = data.videoType;
2014-12-19 13:59:08 +00:00
this.ssrc = ssrc;
this.type = (this.stream.getVideoTracks().length > 0)?
MediaStreamType.VIDEO_TYPE : MediaStreamType.AUDIO_TYPE;
this.muted = mute;
this.eventEmitter = eventEmitter;
2014-12-19 13:59:08 +00:00
}
2015-07-28 19:42:01 +00:00
MediaStream.prototype.getOriginalStream = function() {
2014-12-19 13:59:08 +00:00
return this.stream;
};
2014-12-19 13:59:08 +00:00
2015-07-28 19:42:01 +00:00
MediaStream.prototype.setMute = function (value) {
2014-12-19 13:59:08 +00:00
this.stream.muted = value;
this.muted = value;
};
2014-12-19 13:59:08 +00:00
module.exports = MediaStream;