Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/unsetbit/p
Peer-to-peer networking with browsers
https://github.com/unsetbit/p
networking p2p webrtc
Last synced: 2 days ago
JSON representation
Peer-to-peer networking with browsers
- Host: GitHub
- URL: https://github.com/unsetbit/p
- Owner: unsetbit
- License: other
- Created: 2013-04-24T08:13:41.000Z (almost 12 years ago)
- Default Branch: master
- Last Pushed: 2015-08-09T00:17:19.000Z (over 9 years ago)
- Last Synced: 2024-04-13T01:04:11.450Z (10 months ago)
- Topics: networking, p2p, webrtc
- Language: JavaScript
- Homepage: http://unsetbit.com/p
- Size: 1.18 MB
- Stars: 407
- Watchers: 27
- Forks: 26
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE-APACHE2
Awesome Lists containing this project
README
# P is for peer-to-peer networking with browsers
P is a small framework used to create browser-to-browser networks (as opposed to just a connection). With P, you can:
* Connect to other browsers using [a simple WebSocket server](https://github.com/unsetbit/onramp).
* Connect to other browsers using your established connections to other browsers. This is what makes P unique: it allows for transitive connections across peers, allowing easy creation of mesh networks.After a connection is established the middleman is no longer necessary – no proxies are involved.
This is made possible by an unstable and young technology -- [WebRTC](http://www.webrtc.org/).
Currently, only Chrome and Firefox support this technology.[onramp](https://github.com/unsetbit/onramp), a simple WebSocket server, is used as the signaling channel
to establish initial connections.## API
```javascript
// Initializing
var rootNode = P.create(); // create the root node// Connection management
var webSocketNode = rootNode.connect(address); // connect to an onramp WebSocket server
var webRtcNode = webSocketNode.connect(address); // connect to a peer using an onramp connection
var webRtcNode = webRtcNode.connect(address); // connect to a peer using an existing peer connection
anyNode.close(); // close the connection
anyNode.isOpen(); // return true if the connection is open
var nodeArray = anyNode.getPeers(); // returns an array of all peer connections// Firewalling connections
var protectedNode = P.create({
firewall: function(offerData){
// Only accept RTC connection offers which send 'secret' as the offer data
// this firewall rule will apply to any child nodes as well
return offerData === 'secret';
}
});// Send offerData with a connection request
anyNode.connect({address: address, offerData: 'secret'});// Sending and receiving messages
webRtcNode.send(message); // send a message to a peer; can be json, string, or arraybuffer
webRtcNode.on('message', function(message){}); // listens for messages from a peer
webRtcNode.on('array buffer', function(arrayBuffer){}); // listens for array buffers from a peer// Events
anyNode.on('connection', function(peerNode){}); // emitted when a connection is made via this peer
anyNode.on('open', function(){}); // emitted when this connection is open and ready
anyNode.on('close', function(){}); // emitted when this connection is closed
anyNode.on('error', function(err){}); // listens for errors for this connection
anyNode.removeListener(eventName, optionalCallback); // stops listening to an event
```## Documentation
* [Example with walkthrough](http://unsetbit.com/p/#walkthrough)
* [API](http://unsetbit.com/p/#use)
* [Cookbook](http://unsetbit.com/p/#cookbook)
* [Contribute](http://unsetbit.com/p/#contribute)## Release Notes
* 0.3.3 - Fixed an issue in FF which caused disconnections shorting after successful connections due to a GC miscommunication which seems to clean up DataChannels which are still in use (thereby closing them).
* 0.3.2 - Updated the library to align it with the latest WebRTC standards -- mainly changes in configuration objects.
* 0.3.1 - Added 'firewall' option to firewall RTC requests.
* 0.3 - Major refactor of internals and simplification of API, Firefox support, and respectable unit test coverage.
* 0.2 - Public release