2013-02-27 23:22:10 +00:00
|
|
|
var RTCPeerConnection = null;
|
|
|
|
var getUserMedia = null;
|
|
|
|
var attachMediaStream = null;
|
|
|
|
var reattachMediaStream = null;
|
|
|
|
var webrtcDetectedBrowser = null;
|
2013-05-29 22:13:19 +00:00
|
|
|
var webrtcDetectedVersion = null;
|
2013-02-27 23:22:10 +00:00
|
|
|
|
2013-03-05 03:35:26 +00:00
|
|
|
function trace(text) {
|
|
|
|
// This function is used for logging.
|
|
|
|
if (text[text.length - 1] == '\n') {
|
|
|
|
text = text.substring(0, text.length - 1);
|
|
|
|
}
|
|
|
|
console.log((performance.now() / 1000).toFixed(3) + ": " + text);
|
|
|
|
}
|
|
|
|
|
2013-02-27 23:22:10 +00:00
|
|
|
if (navigator.mozGetUserMedia) {
|
|
|
|
console.log("This appears to be Firefox");
|
|
|
|
|
|
|
|
webrtcDetectedBrowser = "firefox";
|
|
|
|
|
2013-06-25 14:52:51 +00:00
|
|
|
webrtcDetectedVersion =
|
2013-10-22 18:02:41 +00:00
|
|
|
parseInt(navigator.userAgent.match(/Firefox\/([0-9]+)\./)[1], 10);
|
2013-06-25 14:52:51 +00:00
|
|
|
|
2013-02-27 23:22:10 +00:00
|
|
|
// The RTCPeerConnection object.
|
|
|
|
RTCPeerConnection = mozRTCPeerConnection;
|
|
|
|
|
|
|
|
// The RTCSessionDescription object.
|
|
|
|
RTCSessionDescription = mozRTCSessionDescription;
|
|
|
|
|
|
|
|
// The RTCIceCandidate object.
|
|
|
|
RTCIceCandidate = mozRTCIceCandidate;
|
|
|
|
|
|
|
|
// Get UserMedia (only difference is the prefix).
|
|
|
|
// Code from Adam Barth.
|
|
|
|
getUserMedia = navigator.mozGetUserMedia.bind(navigator);
|
2014-01-30 23:38:44 +00:00
|
|
|
navigator.getUserMedia = getUserMedia;
|
2013-02-27 23:22:10 +00:00
|
|
|
|
2013-06-25 14:52:51 +00:00
|
|
|
// Creates iceServer from the url for FF.
|
|
|
|
createIceServer = function(url, username, password) {
|
|
|
|
var iceServer = null;
|
|
|
|
var url_parts = url.split(':');
|
|
|
|
if (url_parts[0].indexOf('stun') === 0) {
|
|
|
|
// Create iceServer with stun url.
|
|
|
|
iceServer = { 'url': url };
|
2013-10-24 20:31:57 +00:00
|
|
|
} else if (url_parts[0].indexOf('turn') === 0) {
|
|
|
|
if (webrtcDetectedVersion < 27) {
|
|
|
|
// Create iceServer with turn url.
|
|
|
|
// Ignore the transport parameter from TURN url for FF version <=27.
|
|
|
|
var turn_url_parts = url.split("?");
|
|
|
|
// Return null for createIceServer if transport=tcp.
|
2013-12-20 22:10:17 +00:00
|
|
|
if (turn_url_parts.length === 1 ||
|
|
|
|
turn_url_parts[1].indexOf('transport=udp') === 0) {
|
2013-10-24 20:31:57 +00:00
|
|
|
iceServer = { 'url': turn_url_parts[0],
|
|
|
|
'credential': password,
|
|
|
|
'username': username };
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
// FF 27 and above supports transport parameters in TURN url,
|
|
|
|
// So passing in the full url to create iceServer.
|
|
|
|
iceServer = { 'url': url,
|
|
|
|
'credential': password,
|
|
|
|
'username': username };
|
|
|
|
}
|
2013-06-25 14:52:51 +00:00
|
|
|
}
|
2013-05-29 22:13:19 +00:00
|
|
|
return iceServer;
|
|
|
|
};
|
|
|
|
|
2013-02-27 23:22:10 +00:00
|
|
|
// Attach a media stream to an element.
|
|
|
|
attachMediaStream = function(element, stream) {
|
|
|
|
console.log("Attaching media stream");
|
|
|
|
element.mozSrcObject = stream;
|
|
|
|
element.play();
|
|
|
|
};
|
|
|
|
|
|
|
|
reattachMediaStream = function(to, from) {
|
|
|
|
console.log("Reattaching media stream");
|
|
|
|
to.mozSrcObject = from.mozSrcObject;
|
|
|
|
to.play();
|
|
|
|
};
|
|
|
|
|
|
|
|
// Fake get{Video,Audio}Tracks
|
2013-12-11 08:36:16 +00:00
|
|
|
if (!MediaStream.prototype.getVideoTracks) {
|
|
|
|
MediaStream.prototype.getVideoTracks = function() {
|
|
|
|
return [];
|
|
|
|
};
|
|
|
|
}
|
2013-02-27 23:22:10 +00:00
|
|
|
|
2013-12-11 08:36:16 +00:00
|
|
|
if (!MediaStream.prototype.getAudioTracks) {
|
|
|
|
MediaStream.prototype.getAudioTracks = function() {
|
|
|
|
return [];
|
|
|
|
};
|
|
|
|
}
|
2013-02-27 23:22:10 +00:00
|
|
|
} else if (navigator.webkitGetUserMedia) {
|
|
|
|
console.log("This appears to be Chrome");
|
|
|
|
|
|
|
|
webrtcDetectedBrowser = "chrome";
|
2013-05-29 22:13:19 +00:00
|
|
|
webrtcDetectedVersion =
|
2013-10-22 18:02:41 +00:00
|
|
|
parseInt(navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./)[2], 10);
|
2013-05-29 22:13:19 +00:00
|
|
|
|
2013-06-25 14:52:51 +00:00
|
|
|
// Creates iceServer from the url for Chrome.
|
|
|
|
createIceServer = function(url, username, password) {
|
|
|
|
var iceServer = null;
|
|
|
|
var url_parts = url.split(':');
|
|
|
|
if (url_parts[0].indexOf('stun') === 0) {
|
|
|
|
// Create iceServer with stun url.
|
|
|
|
iceServer = { 'url': url };
|
|
|
|
} else if (url_parts[0].indexOf('turn') === 0) {
|
2013-10-24 20:31:57 +00:00
|
|
|
// Chrome M28 & above uses below TURN format.
|
|
|
|
iceServer = { 'url': url,
|
|
|
|
'credential': password,
|
|
|
|
'username': username };
|
2013-06-25 14:52:51 +00:00
|
|
|
}
|
|
|
|
return iceServer;
|
|
|
|
};
|
2013-02-27 23:22:10 +00:00
|
|
|
|
|
|
|
// The RTCPeerConnection object.
|
|
|
|
RTCPeerConnection = webkitRTCPeerConnection;
|
2013-03-06 03:35:03 +00:00
|
|
|
|
2013-02-27 23:22:10 +00:00
|
|
|
// Get UserMedia (only difference is the prefix).
|
|
|
|
// Code from Adam Barth.
|
|
|
|
getUserMedia = navigator.webkitGetUserMedia.bind(navigator);
|
2014-01-30 23:38:44 +00:00
|
|
|
navigator.getUserMedia = getUserMedia;
|
2013-02-27 23:22:10 +00:00
|
|
|
|
|
|
|
// Attach a media stream to an element.
|
|
|
|
attachMediaStream = function(element, stream) {
|
2013-04-25 23:22:03 +00:00
|
|
|
if (typeof element.srcObject !== 'undefined') {
|
|
|
|
element.srcObject = stream;
|
|
|
|
} else if (typeof element.mozSrcObject !== 'undefined') {
|
|
|
|
element.mozSrcObject = stream;
|
|
|
|
} else if (typeof element.src !== 'undefined') {
|
|
|
|
element.src = URL.createObjectURL(stream);
|
|
|
|
} else {
|
|
|
|
console.log('Error attaching stream to element.');
|
|
|
|
}
|
2013-02-27 23:22:10 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
reattachMediaStream = function(to, from) {
|
|
|
|
to.src = from.src;
|
|
|
|
};
|
|
|
|
} else {
|
|
|
|
console.log("Browser does not appear to be WebRTC-capable");
|
|
|
|
}
|