adapter.js 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156
  1. var RTCPeerConnection = null;
  2. var getUserMedia = null;
  3. var attachMediaStream = null;
  4. var reattachMediaStream = null;
  5. var webrtcDetectedBrowser = null;
  6. var webrtcDetectedVersion = null;
  7. function trace(text) {
  8. // This function is used for logging.
  9. if (text[text.length - 1] == '\n') {
  10. text = text.substring(0, text.length - 1);
  11. }
  12. // console.log((performance.now() / 1000).toFixed(3) + ": " + text);
  13. }
  14. console.log( navigator.userAgent );
  15. if (navigator.mozGetUserMedia) {
  16. console.log( "This appears to be Firefox: " + navigator.vendor );
  17. webrtcDetectedBrowser = "firefox";
  18. webrtcDetectedVersion =
  19. parseInt(navigator.userAgent.match(/Firefox\/([0-9]+)\./)[1]);
  20. // The RTCPeerConnection object.
  21. RTCPeerConnection = mozRTCPeerConnection;
  22. // The RTCSessionDescription object.
  23. RTCSessionDescription = mozRTCSessionDescription;
  24. // The RTCIceCandidate object.
  25. RTCIceCandidate = mozRTCIceCandidate;
  26. // Get UserMedia (only difference is the prefix).
  27. // Code from Adam Barth.
  28. getUserMedia = navigator.mozGetUserMedia.bind(navigator);
  29. // Creates iceServer from the url for FF.
  30. createIceServer = function(url, username, password) {
  31. var iceServer = null;
  32. var url_parts = url.split(':');
  33. if (url_parts[0].indexOf('stun') === 0) {
  34. // Create iceServer with stun url.
  35. iceServer = { 'url': url };
  36. } else if (url_parts[0].indexOf('turn') === 0 &&
  37. (url.indexOf('transport=udp') !== -1 ||
  38. url.indexOf('?transport') === -1)) {
  39. // Create iceServer with turn url.
  40. // Ignore the transport parameter from TURN url.
  41. var turn_url_parts = url.split("?");
  42. iceServer = { 'url': turn_url_parts[0],
  43. 'credential': password,
  44. 'username': username };
  45. }
  46. return iceServer;
  47. };
  48. // Attach a media stream to an element.
  49. attachMediaStream = function(element, stream) {
  50. console.log("Attaching media stream");
  51. element.mozSrcObject = stream;
  52. element.play();
  53. };
  54. reattachMediaStream = function(to, from) {
  55. console.log("Reattaching media stream");
  56. to.mozSrcObject = from.mozSrcObject;
  57. to.play();
  58. };
  59. // Fake get{Video,Audio}Tracks
  60. MediaStream.prototype.getVideoTracks = function() {
  61. return [];
  62. };
  63. MediaStream.prototype.getAudioTracks = function() {
  64. return [];
  65. };
  66. } else if (navigator.webkitGetUserMedia) {
  67. console.log("This appears to be Chrome: " + navigator.vendor);
  68. webrtcDetectedBrowser = "chrome";
  69. webrtcDetectedVersion =
  70. parseInt(navigator.userAgent.match(/Chrom(e|ium)\/([0-9]+)\./)[2]);
  71. // Creates iceServer from the url for Chrome.
  72. createIceServer = function(url, username, password) {
  73. var iceServer = null;
  74. var url_parts = url.split(':');
  75. if (url_parts[0].indexOf('stun') === 0) {
  76. // Create iceServer with stun url.
  77. iceServer = { 'url': url };
  78. } else if (url_parts[0].indexOf('turn') === 0) {
  79. if (webrtcDetectedVersion < 28) {
  80. // For pre-M28 chrome versions use old TURN format.
  81. var url_turn_parts = url.split("turn:");
  82. iceServer = { 'url': 'turn:' + username + '@' + url_turn_parts[1],
  83. 'credential': password };
  84. } else {
  85. // For Chrome M28 & above use new TURN format.
  86. iceServer = { 'url': url,
  87. 'credential': password,
  88. 'username': username };
  89. }
  90. }
  91. return iceServer;
  92. };
  93. // The RTCPeerConnection object.
  94. RTCPeerConnection = webkitRTCPeerConnection;
  95. // Get UserMedia (only difference is the prefix).
  96. // Code from Adam Barth.
  97. getUserMedia = navigator.webkitGetUserMedia.bind(navigator);
  98. // Attach a media stream to an element.
  99. attachMediaStream = function(element, stream) {
  100. if (typeof element.srcObject !== 'undefined') {
  101. element.srcObject = stream;
  102. } else if (typeof element.mozSrcObject !== 'undefined') {
  103. element.mozSrcObject = stream;
  104. } else if (typeof element.src !== 'undefined') {
  105. element.src = URL.createObjectURL(stream);
  106. } else {
  107. console.log('Error attaching stream to element.');
  108. }
  109. };
  110. reattachMediaStream = function(to, from) {
  111. to.src = from.src;
  112. };
  113. // The representation of tracks in a stream is changed in M26.
  114. // Unify them for earlier Chrome versions in the coexisting period.
  115. if (!webkitMediaStream.prototype.getVideoTracks) {
  116. webkitMediaStream.prototype.getVideoTracks = function() {
  117. return this.videoTracks;
  118. };
  119. webkitMediaStream.prototype.getAudioTracks = function() {
  120. return this.audioTracks;
  121. };
  122. }
  123. // New syntax of getXXXStreams method in M26.
  124. if (!webkitRTCPeerConnection.prototype.getLocalStreams) {
  125. webkitRTCPeerConnection.prototype.getLocalStreams = function() {
  126. return this.localStreams;
  127. };
  128. webkitRTCPeerConnection.prototype.getRemoteStreams = function() {
  129. return this.remoteStreams;
  130. };
  131. }
  132. } else {
  133. console.log("Browser does not appear to be WebRTC-capable: " + navigator.vendor);
  134. }