attachmediastream
Advanced tools
Comparing version 1.3.2 to 1.3.3
@@ -71,2 +71,12 @@ !function(e){"object"==typeof exports?module.exports=e():"function"==typeof define&&define.amd?define(e):"undefined"!=typeof window?window.attachMediaStream=e():"undefined"!=typeof global?global.attachMediaStream=e():"undefined"!=typeof self&&(self.attachMediaStream=e())}(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);throw new Error("Cannot find module '"+o+"'")}var f=n[o]={exports:{}};t[o][0].call(f.exports,function(e){var n=t[o][1][e];return s(n?n:e)},f,f.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ | ||
var webrtcMinimumVersion = null; | ||
var webrtcUtils = { | ||
log: function() { | ||
// suppress console.log output when being included as a module. | ||
if (typeof module !== 'undefined' || | ||
typeof require === 'function' && typeof define === 'function') { | ||
return; | ||
} | ||
console.log.apply(console, arguments); | ||
} | ||
}; | ||
@@ -80,10 +90,13 @@ function trace(text) { | ||
var now = (window.performance.now() / 1000).toFixed(3); | ||
console.log(now + ': ' + text); | ||
webrtcUtils.log(now + ': ' + text); | ||
} else { | ||
console.log(text); | ||
webrtcUtils.log(text); | ||
} | ||
} | ||
if (navigator.mozGetUserMedia) { | ||
console.log('This appears to be Firefox'); | ||
if (typeof window === 'undefined' || !window.navigator) { | ||
webrtcUtils.log('This does not appear to be a browser'); | ||
webrtcDetectedBrowser = 'not a browser'; | ||
} else if (navigator.mozGetUserMedia && window.mozRTCPeerConnection) { | ||
webrtcUtils.log('This appears to be Firefox'); | ||
@@ -126,3 +139,3 @@ webrtcDetectedBrowser = 'firefox'; | ||
} | ||
return new mozRTCPeerConnection(pcConfig, pcConstraints); | ||
return new mozRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors | ||
}; | ||
@@ -137,4 +150,3 @@ | ||
// getUserMedia constraints shim. | ||
getUserMedia = (webrtcDetectedVersion < 38) ? | ||
function(c, onSuccess, onError) { | ||
getUserMedia = function(constraints, onSuccess, onError) { | ||
var constraintsToFF37 = function(c) { | ||
@@ -146,15 +158,27 @@ if (typeof c !== 'object' || c.require) { | ||
Object.keys(c).forEach(function(key) { | ||
if (key === 'require' || key === 'advanced' || key === 'mediaSource') { | ||
return; | ||
} | ||
var r = c[key] = (typeof c[key] === 'object') ? | ||
c[key] : {ideal: c[key]}; | ||
if (r.min !== undefined || | ||
r.max !== undefined || r.exact !== undefined) { | ||
require.push(key); | ||
} | ||
if (r.exact !== undefined) { | ||
r.min = r.max = r.exact; | ||
if (typeof r.exact === 'number') { | ||
r.min = r.max = r.exact; | ||
} else { | ||
c[key] = r.exact; | ||
} | ||
delete r.exact; | ||
} | ||
if (r.min !== undefined || r.max !== undefined) { | ||
require.push(key); | ||
} | ||
if (r.ideal !== undefined) { | ||
c.advanced = c.advanced || []; | ||
var oc = {}; | ||
oc[key] = {min: r.ideal, max: r.ideal}; | ||
if (typeof r.ideal === 'number') { | ||
oc[key] = {min: r.ideal, max: r.ideal}; | ||
} else { | ||
oc[key] = r.ideal; | ||
} | ||
c.advanced.push(oc); | ||
@@ -172,8 +196,14 @@ delete r.ideal; | ||
}; | ||
console.log('spec: ' + JSON.stringify(c)); | ||
c.audio = constraintsToFF37(c.audio); | ||
c.video = constraintsToFF37(c.video); | ||
console.log('ff37: ' + JSON.stringify(c)); | ||
return navigator.mozGetUserMedia(c, onSuccess, onError); | ||
} : navigator.mozGetUserMedia.bind(navigator); | ||
if (webrtcDetectedVersion < 38) { | ||
webrtcUtils.log('spec: ' + JSON.stringify(constraints)); | ||
if (constraints.audio) { | ||
constraints.audio = constraintsToFF37(constraints.audio); | ||
} | ||
if (constraints.video) { | ||
constraints.video = constraintsToFF37(constraints.video); | ||
} | ||
webrtcUtils.log('ff37: ' + JSON.stringify(constraints)); | ||
} | ||
return navigator.mozGetUserMedia(constraints, onSuccess, onError); | ||
}; | ||
@@ -193,4 +223,4 @@ navigator.getUserMedia = getUserMedia; | ||
var infos = [ | ||
{kind: 'audioinput', deviceId: 'default', label:'', groupId:''}, | ||
{kind: 'videoinput', deviceId: 'default', label:'', groupId:''} | ||
{kind: 'audioinput', deviceId: 'default', label: '', groupId: ''}, | ||
{kind: 'videoinput', deviceId: 'default', label: '', groupId: ''} | ||
]; | ||
@@ -214,15 +244,22 @@ resolve(infos); | ||
} | ||
Object.defineProperty(HTMLVideoElement.prototype, 'srcObject', { | ||
get: function() { | ||
return this.mozSrcObject; | ||
}, | ||
set: function(stream) { | ||
this.mozSrcObject = stream; | ||
} | ||
}); | ||
// Attach a media stream to an element. | ||
attachMediaStream = function(element, stream) { | ||
console.log('Attaching media stream'); | ||
element.mozSrcObject = stream; | ||
element.srcObject = stream; | ||
}; | ||
reattachMediaStream = function(to, from) { | ||
console.log('Reattaching media stream'); | ||
to.mozSrcObject = from.mozSrcObject; | ||
to.srcObject = from.srcObject; | ||
}; | ||
} else if (navigator.webkitGetUserMedia) { | ||
console.log('This appears to be Chrome'); | ||
webrtcUtils.log('This appears to be Chrome'); | ||
@@ -240,8 +277,17 @@ webrtcDetectedBrowser = 'chrome'; | ||
window.RTCPeerConnection = function(pcConfig, pcConstraints) { | ||
var pc = new webkitRTCPeerConnection(pcConfig, pcConstraints); | ||
// Translate iceTransportPolicy to iceTransports, | ||
// see https://code.google.com/p/webrtc/issues/detail?id=4869 | ||
if (pcConfig && pcConfig.iceTransportPolicy) { | ||
pcConfig.iceTransports = pcConfig.iceTransportPolicy; | ||
} | ||
var pc = new webkitRTCPeerConnection(pcConfig, pcConstraints); // jscs:ignore requireCapitalizedConstructors | ||
var origGetStats = pc.getStats.bind(pc); | ||
pc.getStats = function(selector, successCallback, errorCallback) { // jshint ignore: line | ||
var self = this; | ||
var args = arguments; | ||
// If selector is a function then we are in the old style stats so just | ||
// pass back the original getStats format to avoid breaking old users. | ||
if (typeof selector === 'function') { | ||
if (arguments.length > 0 && typeof selector === 'function') { | ||
return origGetStats(selector, successCallback); | ||
@@ -267,6 +313,22 @@ } | ||
}; | ||
var successCallbackWrapper = function(response) { | ||
successCallback(fixChromeStats(response)); | ||
}; | ||
return origGetStats(successCallbackWrapper, selector); | ||
if (arguments.length >= 2) { | ||
var successCallbackWrapper = function(response) { | ||
args[1](fixChromeStats(response)); | ||
}; | ||
return origGetStats.apply(this, [successCallbackWrapper, arguments[0]]); | ||
} | ||
// promise-support | ||
return new Promise(function(resolve, reject) { | ||
if (args.length === 1 && selector === null) { | ||
origGetStats.apply(self, [ | ||
function(response) { | ||
resolve.apply(null, [fixChromeStats(response)]); | ||
}, reject]); | ||
} else { | ||
origGetStats.apply(self, [resolve, reject]); | ||
} | ||
}); | ||
}; | ||
@@ -320,76 +382,65 @@ | ||
// getUserMedia constraints shim. | ||
getUserMedia = function(c, onSuccess, onError) { | ||
var constraintsToChrome = function(c) { | ||
if (typeof c !== 'object' || c.mandatory || c.optional) { | ||
return c; | ||
var constraintsToChrome = function(c) { | ||
if (typeof c !== 'object' || c.mandatory || c.optional) { | ||
return c; | ||
} | ||
var cc = {}; | ||
Object.keys(c).forEach(function(key) { | ||
if (key === 'require' || key === 'advanced' || key === 'mediaSource') { | ||
return; | ||
} | ||
var cc = {}; | ||
Object.keys(c).forEach(function(key) { | ||
if (key === 'require' || key === 'advanced') { | ||
return; | ||
var r = (typeof c[key] === 'object') ? c[key] : {ideal: c[key]}; | ||
if (r.exact !== undefined && typeof r.exact === 'number') { | ||
r.min = r.max = r.exact; | ||
} | ||
var oldname = function(prefix, name) { | ||
if (prefix) { | ||
return prefix + name.charAt(0).toUpperCase() + name.slice(1); | ||
} | ||
var r = (typeof c[key] === 'object') ? c[key] : {ideal: c[key]}; | ||
if (r.exact !== undefined && typeof r.exact === 'number') { | ||
r.min = r.max = r.exact; | ||
} | ||
var oldname = function(prefix, name) { | ||
if (prefix) { | ||
return prefix + name.charAt(0).toUpperCase() + name.slice(1); | ||
} | ||
return (name === 'deviceId') ? 'sourceId' : name; | ||
}; | ||
if (r.ideal !== undefined) { | ||
cc.optional = cc.optional || []; | ||
var oc = {}; | ||
if (typeof r.ideal === 'number') { | ||
oc[oldname('min', key)] = r.ideal; | ||
cc.optional.push(oc); | ||
oc = {}; | ||
oc[oldname('max', key)] = r.ideal; | ||
cc.optional.push(oc); | ||
} else { | ||
oc[oldname('', key)] = r.ideal; | ||
cc.optional.push(oc); | ||
} | ||
} | ||
if (r.exact !== undefined && typeof r.exact !== 'number') { | ||
cc.mandatory = cc.mandatory || {}; | ||
cc.mandatory[oldname('', key)] = r.exact; | ||
return (name === 'deviceId') ? 'sourceId' : name; | ||
}; | ||
if (r.ideal !== undefined) { | ||
cc.optional = cc.optional || []; | ||
var oc = {}; | ||
if (typeof r.ideal === 'number') { | ||
oc[oldname('min', key)] = r.ideal; | ||
cc.optional.push(oc); | ||
oc = {}; | ||
oc[oldname('max', key)] = r.ideal; | ||
cc.optional.push(oc); | ||
} else { | ||
['min', 'max'].forEach(function(mix) { | ||
if (r[mix] !== undefined) { | ||
cc.mandatory = cc.mandatory || {}; | ||
cc.mandatory[oldname(mix, key)] = r[mix]; | ||
} | ||
}); | ||
oc[oldname('', key)] = r.ideal; | ||
cc.optional.push(oc); | ||
} | ||
}); | ||
if (c.advanced) { | ||
cc.optional = (cc.optional || []).concat(c.advanced); | ||
} | ||
return cc; | ||
}; | ||
console.log('spec: ' + JSON.stringify(c)); // whitespace for alignment | ||
c.audio = constraintsToChrome(c.audio); | ||
c.video = constraintsToChrome(c.video); | ||
console.log('chrome: ' + JSON.stringify(c)); | ||
return navigator.webkitGetUserMedia(c, onSuccess, onError); | ||
if (r.exact !== undefined && typeof r.exact !== 'number') { | ||
cc.mandatory = cc.mandatory || {}; | ||
cc.mandatory[oldname('', key)] = r.exact; | ||
} else { | ||
['min', 'max'].forEach(function(mix) { | ||
if (r[mix] !== undefined) { | ||
cc.mandatory = cc.mandatory || {}; | ||
cc.mandatory[oldname(mix, key)] = r[mix]; | ||
} | ||
}); | ||
} | ||
}); | ||
if (c.advanced) { | ||
cc.optional = (cc.optional || []).concat(c.advanced); | ||
} | ||
return cc; | ||
}; | ||
navigator.getUserMedia = getUserMedia; | ||
// Attach a media stream to an element. | ||
attachMediaStream = function(element, stream) { | ||
if (typeof element.srcObject !== 'undefined') { | ||
element.srcObject = stream; | ||
} else if (typeof element.src !== 'undefined') { | ||
element.src = URL.createObjectURL(stream); | ||
} else { | ||
console.log('Error attaching stream to element.'); | ||
getUserMedia = function(constraints, onSuccess, onError) { | ||
if (constraints.audio) { | ||
constraints.audio = constraintsToChrome(constraints.audio); | ||
} | ||
if (constraints.video) { | ||
constraints.video = constraintsToChrome(constraints.video); | ||
} | ||
webrtcUtils.log('chrome: ' + JSON.stringify(constraints)); | ||
return navigator.webkitGetUserMedia(constraints, onSuccess, onError); | ||
}; | ||
navigator.getUserMedia = getUserMedia; | ||
reattachMediaStream = function(to, from) { | ||
to.src = from.src; | ||
}; | ||
if (!navigator.mediaDevices) { | ||
@@ -410,9 +461,69 @@ navigator.mediaDevices = {getUserMedia: requestUserMedia, | ||
}}; | ||
// in case someone wants to listen for the devicechange event. | ||
navigator.mediaDevices.addEventListener = function() { }; | ||
navigator.mediaDevices.removeEventListener = function() { }; | ||
} | ||
// A shim for getUserMedia method on the mediaDevices object. | ||
// TODO(KaptenJansson) remove once implemented in Chrome stable. | ||
if (!navigator.mediaDevices.getUserMedia) { | ||
navigator.mediaDevices.getUserMedia = function(constraints) { | ||
return requestUserMedia(constraints); | ||
}; | ||
} else { | ||
// Even though Chrome 45 has navigator.mediaDevices and a getUserMedia | ||
// function which returns a Promise, it does not accept spec-style | ||
// constraints. | ||
var origGetUserMedia = navigator.mediaDevices.getUserMedia. | ||
bind(navigator.mediaDevices); | ||
navigator.mediaDevices.getUserMedia = function(c) { | ||
webrtcUtils.log('spec: ' + JSON.stringify(c)); // whitespace for alignment | ||
c.audio = constraintsToChrome(c.audio); | ||
c.video = constraintsToChrome(c.video); | ||
webrtcUtils.log('chrome: ' + JSON.stringify(c)); | ||
return origGetUserMedia(c); | ||
}; | ||
} | ||
// Dummy devicechange event methods. | ||
// TODO(KaptenJansson) remove once implemented in Chrome stable. | ||
if (typeof navigator.mediaDevices.addEventListener === 'undefined') { | ||
navigator.mediaDevices.addEventListener = function() { | ||
webrtcUtils.log('Dummy mediaDevices.addEventListener called.'); | ||
}; | ||
} | ||
if (typeof navigator.mediaDevices.removeEventListener === 'undefined') { | ||
navigator.mediaDevices.removeEventListener = function() { | ||
webrtcUtils.log('Dummy mediaDevices.removeEventListener called.'); | ||
}; | ||
} | ||
Object.defineProperty(HTMLVideoElement.prototype, 'srcObject', { | ||
get: function() { | ||
return this._srcObject; | ||
}, | ||
set: function(stream) { | ||
this._srcObject = stream; | ||
this.src = URL.createObjectURL(stream); | ||
} | ||
}); | ||
// Attach a media stream to an element. | ||
attachMediaStream = function(element, stream) { | ||
if (webrtcDetectedVersion >= 43) { | ||
element.srcObject = stream; | ||
} else if (typeof element.src !== 'undefined') { | ||
element.src = URL.createObjectURL(stream); | ||
} else { | ||
webrtcUtils.log('Error attaching stream to element.'); | ||
} | ||
}; | ||
reattachMediaStream = function(to, from) { | ||
if (webrtcDetectedVersion >= 43) { | ||
to.srcObject = from.srcObject; | ||
} else { | ||
to.src = from.src; | ||
} | ||
}; | ||
} else if (navigator.mediaDevices && navigator.userAgent.match( | ||
/Edge\/(\d+).(\d+)$/)) { | ||
console.log('This appears to be Edge'); | ||
webrtcUtils.log('This appears to be Edge'); | ||
webrtcDetectedBrowser = 'edge'; | ||
@@ -426,2 +537,4 @@ | ||
getUserMedia = navigator.getUserMedia; | ||
attachMediaStream = function(element, stream) { | ||
@@ -434,3 +547,3 @@ element.srcObject = stream; | ||
} else { | ||
console.log('Browser does not appear to be WebRTC-capable'); | ||
webrtcUtils.log('Browser does not appear to be WebRTC-capable'); | ||
} | ||
@@ -445,5 +558,16 @@ | ||
var webrtcTesting = {}; | ||
Object.defineProperty(webrtcTesting, 'version', { | ||
set: function(version) { | ||
webrtcDetectedVersion = version; | ||
} | ||
}); | ||
if (typeof module !== 'undefined') { | ||
var RTCPeerConnection; | ||
if (typeof window !== 'undefined') { | ||
RTCPeerConnection = window.RTCPeerConnection; | ||
} | ||
module.exports = { | ||
RTCPeerConnection: window.RTCPeerConnection, | ||
RTCPeerConnection: RTCPeerConnection, | ||
getUserMedia: getUserMedia, | ||
@@ -454,3 +578,4 @@ attachMediaStream: attachMediaStream, | ||
webrtcDetectedVersion: webrtcDetectedVersion, | ||
webrtcMinimumVersion: webrtcMinimumVersion | ||
webrtcMinimumVersion: webrtcMinimumVersion, | ||
webrtcTesting: webrtcTesting | ||
//requestUserMedia: not exposed on purpose. | ||
@@ -469,3 +594,4 @@ //trace: not exposed on purpose. | ||
webrtcDetectedVersion: webrtcDetectedVersion, | ||
webrtcMinimumVersion: webrtcMinimumVersion | ||
webrtcMinimumVersion: webrtcMinimumVersion, | ||
webrtcTesting: webrtcTesting | ||
//requestUserMedia: not exposed on purpose. | ||
@@ -472,0 +598,0 @@ //trace: not exposed on purpose. |
{ | ||
"name": "attachmediastream", | ||
"version": "1.3.2", | ||
"version": "1.3.3", | ||
"description": "cross-browser way to attach a media stream to a video element.", | ||
@@ -20,3 +20,3 @@ "main": "attachmediastream.js", | ||
"dependencies": { | ||
"webrtc-adapter-test": "^0.1.4" | ||
"webrtc-adapter-test": "^0.2.1" | ||
}, | ||
@@ -23,0 +23,0 @@ "devDependencies": { |
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
License Policy Violation
LicenseThis package is not allowed per your license policy. Review the package's license to ensure compliance.
Found 1 instance in 1 package
640
28231
8
+ Addedwebrtc-adapter-test@0.2.10(transitive)
- Removedwebrtc-adapter-test@0.1.9(transitive)
Updatedwebrtc-adapter-test@^0.2.1