PLT-4644 Update webrtc client (#4922)

* PLT-4644 Update webrtc client

* update webrtc-adapter

* Use default ice server if none is provided
This commit is contained in:
enahum
2017-01-03 12:08:21 -03:00
committed by Corey Hulen
parent 7cdfba62ef
commit 1442199647
5 changed files with 2346 additions and 2118 deletions

View File

@@ -1,145 +0,0 @@
// Copyright (c) 2016 Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.
export default class WebrtcClient {
constructor() {
this.init = this.init.bind(this);
this.listDevices = this.listDevices.bind(this);
this.isExtensionEnabled = this.isExtensionEnabled.bind(this);
this.isWebrtcSupported = this.isWebrtcSupported.bind(this);
this.initDone = false;
this.sessions = {};
}
noop() {} //eslint-disable-line no-empty-function
// this function is going to be needed when we enable screen sharing
isExtensionEnabled() {
if (window.navigator.userAgent.match('Chrome')) {
const chromever = parseInt(window.navigator.userAgent.match(/Chrome\/(.*) /)[1], 10);
let maxver = 33;
if (window.navigator.userAgent.match('Linux')) {
maxver = 35; // "known" crash in chrome 34 and 35 on linux
}
if (chromever >= 26 && chromever <= maxver) {
// Older versions of Chrome don't support this extension-based approach, so lie
return true;
}
return (document.getElementById('mattermost-extension-installed') !== null);
}
// Firefox of others, no need for the extension (but this doesn't mean it will work)
return true;
}
init(opts) {
const options = opts || {};
if (this.initDone === true) {
// Already initialized
return;
}
this.trace = this.noop;
this.debug = this.noop;
this.log = this.noop;
this.warn = this.noop;
this.error = this.noop;
/* eslint-disable */
if (options.debug === true || options.debug === 'all') {
// Enable all debugging levels
this.trace = console.trace.bind(console);
this.debug = console.debug.bind(console);
this.log = console.log.bind(console);
this.warn = console.warn.bind(console);
this.error = console.error.bind(console);
} else if (Array.isArray(options.debug)) {
for (const i in options.debug) {
if (options.debug.hasOwnProperty(i)) {
const d = options.debug[i];
switch (d) {
case 'trace':
this.trace = console.trace.bind(console);
break;
case 'debug':
this.debug = console.debug.bind(console);
break;
case 'log':
this.log = console.log.bind(console);
break;
case 'warn':
this.warn = console.warn.bind(console);
break;
case 'error':
this.error = console.error.bind(console);
break;
default:
console.error("Unknown debugging option '" + d + "' (supported: 'trace', 'debug', 'log', warn', 'error')");
break;
}
}
}
}
/* eslint-enable */
this.log('Initializing WebRTC Client library');
// Detect tab close
window.onbeforeunload = () => {
this.log('Closing window');
for (const s in this.sessions) {
if (this.sessions.hasOwnProperty(s)) {
if (this.sessions[s] && this.sessions[s].destroyOnUnload) {
this.log('Destroying session ' + s);
this.sessions[s].destroy();
}
}
}
};
this.initDone = true;
}
// Helper method to enumerate devices
listDevices(cb) {
const callback = (typeof cb == 'function') ? cb : this.noop;
if (navigator.mediaDevices) {
navigator.getUserMedia({audio: true, video: true}, (stream) => {
navigator.mediaDevices.enumerateDevices().then((devices) => {
this.debug(devices);
callback(devices);
// Get rid of the now useless stream
try {
stream.stop();
} catch (e) {
this.error(e);
}
this.stopMedia(stream);
});
}, (err) => {
this.error(err);
callback([]);
});
} else {
this.warn('navigator.mediaDevices unavailable');
callback([]);
}
}
// Helper method to check whether WebRTC is supported by this browser
isWebrtcSupported() {
return window.RTCPeerConnection && navigator.getUserMedia;
}
stopMedia(stream) {
const tracks = stream.getTracks();
tracks.forEach((track) => {
track.stop();
});
}
}

File diff suppressed because it is too large Load Diff

View File

@@ -7,7 +7,7 @@ import WebrtcStore from 'stores/webrtc_store.jsx';
import Client from 'client/web_client.jsx';
import WebSocketClient from 'client/web_websocket_client.jsx';
import WebrtcSession from 'client/webrtc_session.jsx';
import Janus from 'janus';
import SearchBox from '../search_bar.jsx';
import WebrtcHeader from './components/webrtc_header.jsx';
@@ -44,6 +44,8 @@ export default class WebrtcController extends React.Component {
this.close = this.close.bind(this);
this.clearError = this.clearError.bind(this);
this.getLocalMedia = this.getLocalMedia.bind(this);
this.stopMediaStream = this.stopMediaStream.bind(this);
this.previewVideo = this.previewVideo.bind(this);
this.stopRinging = this.stopRinging.bind(this);
@@ -160,6 +162,30 @@ export default class WebrtcController extends React.Component {
}, Constants.WEBRTC_CLEAR_ERROR_DELAY);
}
getLocalMedia(constraints, element, callback) {
const media = constraints || {audio: true, video: true};
navigator.mediaDevices.getUserMedia(media).
then((stream) => {
if (element) {
element.srcObject = stream;
}
if (callback && typeof callback === 'function') {
callback(null, stream);
}
}).
catch((error) => {
callback(error);
});
}
stopMediaStream(stream) {
const tracks = stream.getTracks();
tracks.forEach((track) => {
track.stop();
});
}
previewVideo() {
if (this.mounted) {
if (this.localMedia) {
@@ -169,7 +195,7 @@ export default class WebrtcController extends React.Component {
});
this.localMedia.enabled = true;
} else {
WebrtcSession.getLocalMedia(
this.getLocalMedia(
{
audio: true,
video: {
@@ -399,12 +425,11 @@ export default class WebrtcController extends React.Component {
if (this.session) {
this.session.destroy();
this.session.disconnect();
this.session = null;
}
if (this.localMedia) {
WebrtcSession.stopMediaStream(this.localMedia);
this.stopMediaStream(this.localMedia);
this.localMedia = null;
}
@@ -648,8 +673,8 @@ export default class WebrtcController extends React.Component {
});
}
this.session = new WebrtcSession({
debug: global.mm_config.EnableDeveloper === 'true',
Janus.init({debug: global.mm_config.EnableDeveloper === 'true'});
this.session = new Janus({
server: info.gateway_url,
iceServers,
token: info.token,

File diff suppressed because it is too large Load Diff

View File

@@ -32,7 +32,7 @@
"superagent": "2.3.0",
"twemoji": "2.2.0",
"velocity-animate": "1.3.1",
"webrtc-adapter": "2.0.8",
"webrtc-adapter": "2.1.0",
"xregexp": "3.1.1"
},
"devDependencies": {