- 
      
- 
        Save lthrhx/610e94b03bed193f4a2e486baf20e477 to your computer and use it in GitHub Desktop. 
    WebRTC and video blob record (compatible with DRM and any videos like Facebook / Instagram stories)
  
        
  
    
      This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
      Learn more about bidirectional Unicode characters
    
  
  
    
  | // SOURCE= https://gist.github.com/baptx/8a1549d91996a37378faca159b3adc17 | |
| // Discussion that started it's creation = https://github.com/BrowserWorks/Waterfox/issues/1895 | |
| /* Customized code to allow WebRTC record on existing page or HTML5 video blob download (based on https://github.com/webrtc/samples/blob/409d5631f38f2bdc4dafb5275d1bc77738fbb1ba/src/content/getusermedia/record/js/main.js) | |
| * Recording will start when executing this script and you will have to execute manually startDownload() function when needed in web console with or without stopRecording() | |
| * Recording should ideally start before playing video manually and in case controls are hidden, you can record from the start with a command like document.getElementsByTagName("video")[0].currentTime = 0 | |
| * By default, the script targets the first video element document.getElementsByTagName("video")[0] but you can change the code if needed. | |
| */ | |
| // If there is an error due to DRM, capture the stream by executing the following 2 lines before playing / loading the video: | |
| var video = document.getElementsByTagName("video")[0]; | |
| var stream = video.captureStream ? video.captureStream() : video.mozCaptureStream(); | |
| var mediaSource = new MediaSource(); | |
| mediaSource.addEventListener('sourceopen', handleSourceOpen, false); | |
| var mediaRecorder; | |
| var recordedBlobs; | |
| var sourceBuffer; | |
| function startDownload() { | |
| var blob = new Blob(recordedBlobs, {type: 'video/webm'}); | |
| var url = window.URL.createObjectURL(blob); | |
| var a = document.createElement('a'); | |
| a.style.display = 'none'; | |
| a.href = url; | |
| a.download = 'test.webm'; | |
| document.body.appendChild(a); | |
| a.click(); | |
| setTimeout(() => { | |
| document.body.removeChild(a); | |
| window.URL.revokeObjectURL(url); | |
| }, 100); | |
| } | |
| function handleSourceOpen(event) { | |
| console.log('MediaSource opened'); | |
| sourceBuffer = mediaSource.addSourceBuffer('video/webm; codecs="vp8"'); | |
| console.log('Source buffer: ', sourceBuffer); | |
| } | |
| function handleDataAvailable(event) { | |
| console.log('handleDataAvailable', event); | |
| if (event.data && event.data.size > 0) { | |
| recordedBlobs.push(event.data); | |
| } | |
| } | |
| function startRecording() { | |
| recordedBlobs = []; | |
| try { | |
| mediaRecorder = new MediaRecorder(stream); | |
| } catch (e) { | |
| console.error('Exception while creating MediaRecorder:', e); | |
| return; | |
| } | |
| mediaRecorder.onstop = (event) => { | |
| console.log('Recorder stopped: ', event); | |
| console.log('Recorded Blobs: ', recordedBlobs); | |
| }; | |
| mediaRecorder.ondataavailable = handleDataAvailable; | |
| mediaRecorder.start(1000); // collect 1000ms of data (to be able to download every second even if recording is not stopped) | |
| console.log('MediaRecorder started', mediaRecorder); | |
| } | |
| function stopRecording() { | |
| mediaRecorder.stop(); | |
| } | |
| // Initiate recording | |
| startRecording(); | |
| // Play the video | |
| video.play(); | |
| // Check when video is done playing and save file | |
| video.onended = (event) => { | |
| startDownload() | |
| console.log( | |
| "Video stopped either because it has finished playing or no further data is available.", | |
| ); | |
| }; | 
  
    Sign up for free
    to join this conversation on GitHub.
    Already have an account?
    Sign in to comment