mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
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:
@@ -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
@@ -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,
|
||||
|
||||
2314
webapp/non_npm_dependencies/janus/index.js
Normal file
2314
webapp/non_npm_dependencies/janus/index.js
Normal file
File diff suppressed because it is too large
Load Diff
@@ -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": {
|
||||
|
||||
Reference in New Issue
Block a user