From f6291c034cd3e8d672ee98afef1d7c86bba555cd Mon Sep 17 00:00:00 2001 From: Nick Couchman Date: Tue, 2 Jan 2018 11:43:24 -0500 Subject: [PATCH] GUACAMOLE-237: Define navigator.mediaDevices and getUserMedia when undefined. --- .../src/main/webapp/modules/AudioRecorder.js | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/guacamole-common-js/src/main/webapp/modules/AudioRecorder.js b/guacamole-common-js/src/main/webapp/modules/AudioRecorder.js index f925716ca..3a73d1dac 100644 --- a/guacamole-common-js/src/main/webapp/modules/AudioRecorder.js +++ b/guacamole-common-js/src/main/webapp/modules/AudioRecorder.js @@ -187,11 +187,15 @@ Guacamole.RawAudioRecorder = function RawAudioRecorder(stream, mimetype) { * * @type Function */ - var getUserMedia = (navigator.mediaDevices.getUserMedia - || navigator.getUserMedia - || navigator.webkitGetUserMedia - || navigator.mozGetUserMedia - || navigator.msGetUserMedia).bind(navigator); + + if (navigator.mediaDevices === undefined) + navigator.mediaDevices = {}; + + if (navigator.mediaDevices.getUserMedia === undefined) + navigator.mediaDevices.getUserMedia = (navigator.getUserMedia + || navigator.webkitGetUserMedia + || navigator.mozGetUserMedia + || navigator.msGetUserMedia).bind(navigator); /** * Guacamole.ArrayBufferWriter wrapped around the audio output stream @@ -420,7 +424,7 @@ Guacamole.RawAudioRecorder = function RawAudioRecorder(stream, mimetype) { var beginAudioCapture = function beginAudioCapture() { // Attempt to retrieve an audio input stream from the browser - getUserMedia({ 'audio' : true }, function streamReceived(stream) { + navigator.mediaDevices.getUserMedia({ 'audio' : true }, function streamReceived(stream) { // Create processing node which receives appropriately-sized audio buffers processor = context.createScriptProcessor(BUFFER_SIZE, format.channels, format.channels);