Nav apraksta

Jairo Caro-Accino Viciana 398f6a3a02 Merge pull request #387 from Enet4/typescript-types 7 gadi atpakaļ
dist 37016f06aa Better to avoid 'compress' option at all to keep it behave as by default 9 gadi atpakaļ
docs 70b0861488 Update docs 11 gadi atpakaļ
examples 141db74484 Fixes #232 by handling errors explicitly rather than trying to parse status codes and ready states. 11 gadi atpakaļ
lib 15e31a3fc2 Merge pull request #419 from DiThi/master 7 gadi atpakaļ
test 00e59f60be Make exports browserify compatible 11 gadi atpakaļ
.gitignore 81f3429c7c Add dist back 10 gadi atpakaļ
.npmignore 00e59f60be Make exports browserify compatible 11 gadi atpakaļ
Gruntfile.js 37016f06aa Better to avoid 'compress' option at all to keep it behave as by default 9 gadi atpakaļ
LICENSE fc7c88d3e3 Update LICENSE 10 gadi atpakaļ
Makefile 00e59f60be Make exports browserify compatible 11 gadi atpakaļ
README.md 9b962f1f9a Merge pull request #402 from arpit1997/master 7 gadi atpakaļ
changelog.md aa281474cf 0.3.14 10 gadi atpakaļ
index.d.ts 8ee1e46b29 Add module-based TypeScript declarations 8 gadi atpakaļ
package.json 8ee1e46b29 Add module-based TypeScript declarations 8 gadi atpakaļ

README.md

PeerJS: Simple peer-to-peer with WebRTC

PeerJS provides a complete, configurable, and easy-to-use peer-to-peer API built on top of WebRTC, supporting both data channels and media streams.

http://peerjs.com

Setup

Include the library

from the cdn:

<script src="http://cdn.peerjs.com/0.3/peer.js"></script>

with modules: npm install peerjs or yarn add peerjs

and the usage:
  import Peer from 'peerjs';

Create a Peer
Get a free API key. Your id only needs to be unique to the namespace of your API key.

var peer = new Peer('pick-an-id', {key: 'myapikey'}); 
// You can pick your own id or omit the id if you want to get a random one from the server.

Data connections

Connect

var conn = peer.connect('another-peers-id');
conn.on('open', function(){
  conn.send('hi!');
});

Receive

peer.on('connection', function(conn) {
  conn.on('data', function(data){
    // Will print 'hi!'
    console.log(data);
  });
});

Media calls

Call

navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
navigator.getUserMedia({video: true, audio: true}, function(stream) {
  var call = peer.call('another-peers-id', stream);
  call.on('stream', function(remoteStream) {
    // Show stream in some <video> element.
  });
}, function(err) {
  console.log('Failed to get local stream' ,err);
});

Answer

navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia;
peer.on('call', function(call) {
  navigator.getUserMedia({video: true, audio: true}, function(stream) {
    call.answer(stream); // Answer the call with an A/V stream.
    call.on('stream', function(remoteStream) {
      // Show stream in some <video> element.
    });
  }, function(err) {
    console.log('Failed to get local stream' ,err);
  });
});

Links

Documentation / API Reference

WebRTC Browser compatibility status

PeerServer

Discuss PeerJS on our Google Group

Changelog

License

PeerJS is licensed under the MIT License.