Added the multipeer connections support

This commit is contained in:
Mario Colque 2014-03-31 16:48:43 -03:00
commit 99b81128fd
4 changed files with 125 additions and 78 deletions

View file

@ -26,8 +26,8 @@
<!-- Templates --> <!-- Templates -->
<script type="text/ng-template" id="signin.html"> <script type="text/ng-template" id="signin.html">
<div class="text-center" ng-controller="SigninController"> <div class="text-center" ng-controller="SigninController">
<div ng-if="!peerReady">Opening peers...</div> <div ng-if="!$root.peerId">Opening peers...</div>
<div ng-if="peerReady"> <div ng-if="$root.peerId">
<h1>Join or Create a New Connection</h1> <h1>Join or Create a New Connection</h1>
<div class="col-lg-12"> <div class="col-lg-12">
<div class="input-group"> <div class="input-group">
@ -48,11 +48,11 @@
<h1>Joined to <span class="text-muted">{{connectionId}}</span></h1> <h1>Joined to <span class="text-muted">{{connectionId}}</span></h1>
<div class="panel panel-default"> <div class="panel panel-default">
<div class="panel-heading"> <div class="panel-heading">
<h3 class="panel-title">Cosigners ({{cosigners.length}}/5)</h3> <h3 class="panel-title">Cosigners ({{$root.connectedPeers.length}}/5)</h3>
</div> </div>
<div class="panel-body"> <div class="panel-body">
<ul> <ul>
<li ng-repeat="cosigner in cosigners"> <li ng-repeat="cosigner in $root.connectedPeers">
<span ng-if="cosigner == $root.peerId">You ({{$root.peerId}})</span> <span ng-if="cosigner == $root.peerId">You ({{$root.peerId}})</span>
<span ng-if="cosigner != $root.peerId">{{cosigner}}</span> <span ng-if="cosigner != $root.peerId">{{cosigner}}</span>
</li> </li>

View file

@ -2,20 +2,12 @@
angular.module('cosign.join').controller('JoinController', angular.module('cosign.join').controller('JoinController',
function($scope, $rootScope, $routeParams, Network) { function($scope, $rootScope, $routeParams, Network) {
$rootScope.masterId = $routeParams.id;
$scope.connectionId = $routeParams.id;
$scope.cosigners = [];
$scope.init = function() { $scope.init = function() {
console.log('-------- init --------'); console.log('-------- init --------');
console.log($rootScope.peerId); console.log($rootScope.peerId);
$scope.cosigners.push($rootScope.peerId);
Network.connect($scope.connectionId, function(cosigner) { Network.connect($rootScope.masterId);
console.log('----- join connect --------');
console.log(cosigner);
$scope.cosigners.push(cosigner);
$scope.$digest();
});
}; };
}); });

View file

@ -2,21 +2,12 @@
angular.module('cosign.signin').controller('SigninController', angular.module('cosign.signin').controller('SigninController',
function($scope, $rootScope, $location, Network) { function($scope, $rootScope, $location, Network) {
$rootScope.peerId = null;
$scope.peerReady = false;
// Init peer // Init peer
Network.init(function(pid) { Network.init();
$rootScope.peerId = pid;
$rootScope.$digest();
$scope.peerReady = true;
$scope.$digest();
});
$scope.join = function(cid) { $scope.join = function(cid) {
console.log('------- join --------'); console.log('------- joining to ' + cid + ' --------');
console.log(cid);
var pid = cid || $rootScope.peerId; var pid = cid || $rootScope.peerId;
$location.path('join/' + pid); $location.path('join/' + pid);

View file

@ -1,90 +1,154 @@
'use strict'; 'use strict';
angular.module('cosign.network') angular.module('cosign.network')
.factory('NetworkTest', function() { .factory('Network', function($rootScope) {
this.f = function() {
return 2;
};
})
.factory('Network', function() {
var peer; var peer;
var connectedPeers = {}; $rootScope.connectedPeers = [];
$rootScope.connectedTo = [];
$rootScope.masterId = null;
$rootScope.peerId = null;
var _onConnect = function(c, cb) { var _arrayDiff = function(a, b) {
if (c.label === 'wallet') { var seen = [];
var a = peer.connections[c.peer][0]; var diff = [];
console.log(peer.connections[c.peer]);
a.send('------ origin recived -------');
c.on('data', function(data) { for ( var i = 0; i < b.length; i++)
console.log('------ new data ------'); seen[b[i]] = true;
console.log(data);
for ( var i = 0; i < a.length; i++)
if (!seen[a[i]])
diff.push(a[i]);
console.log(peer.connections); return diff;
};
var _sender = function(pid, data) {
if (pid !== $rootScope.peerId) {
console.log('-------- sending data to: ' + pid + ' --------');
var conns = peer.connections[pid];
c.on('close', function() { if (conns) {
alert(c.peer + ' has left the wallet.'); var str = JSON.stringify({
delete connectedPeers[c.peer]; sender: $rootScope.peerId,
data: data
}); });
});
setTimeout(function() { for (var i = 0; i < conns.length; i++) {
a.send('.........................'); var conn = conns[i];
cb(c.peer); conn.send(str);
}, 1000); }
}
} }
}; };
var _init = function(cb) { var _onData = function(data) {
peer = new Peer({ console.log('-------- Data received --------');
key: 'lwjd5qra8257b9', console.log(data);
var obj = JSON.parse(data);
if (obj.data.peers) {
_connectToPeers(obj.data.peers);
}
};
var _connectToPeers = function(peers) {
var arrayDiff = _arrayDiff(peers, $rootScope.connectedTo);
arrayDiff.forEach(function(pid) {
_connect(pid);
});
};
var _init = function() {
peer = new Peer($rootScope.peerId, {
key: 'lwjd5qra8257b9', // TODO: we need our own PeerServer KEY (http://peerjs.com/peerserver)
debug: 3 debug: 3
}); });
peer.on('open', cb); peer.on('open', function(pid) {
}; $rootScope.$apply(function() {
$rootScope.peerId = pid;
$rootScope.connectedPeers.push(pid);
});
});
var _connect = function(pid, cb) {
peer.on('connection', function(conn) { peer.on('connection', function(conn) {
_onConnect(conn, cb); if (conn.label === 'wallet') {
conn.on('open', function() {
console.log('-------- ' + conn.peer + ' conected to me --------');
if ($rootScope.masterId === $rootScope.peerId) {
var c = peer.connect(conn.peer, {
label: 'wallet',
serialization: 'none',
reliable: false,
metadata: { message: 'hi peer!' }
});
c.on('open', function() {
$rootScope.$apply(function() {
$rootScope.connectedPeers.push(conn.peer);
$rootScope.connectedTo.push(conn.peer);
});
_send($rootScope.connectedPeers, { peers: $rootScope.connectedPeers });
});
}
});
}
}); });
var c = peer.connect(pid, { peer.on('close', function() {
label: 'wallet', console.log('------- connection closed ---------');
serialization: 'none',
reliable: false,
metadata: { message: 'hi! cosigners' }
});
c.on('open', function() {
c.send('-------oopen-------');
});
c.on('data', function(data) {
if (data)
console.log(data);
});
c.on('error', function(err) {
console.error(err);
}); });
}; };
var _sendTo = function(pid, data) { var _connect = function(pid) {
if (typeof pids === 'string') { if (pid !== $rootScope.peerId) {
// just send console.log('------- conecting to ' + pid + ' ------');
} else if (typeof pids === 'array') { var c = peer.connect(pid, {
// iter label: 'wallet',
serialization: 'none',
reliable: false,
metadata: { message: 'hi copayer!' }
});
c.on('open', function() {
console.log('-------- I\'m connected to ' + pid + ' ------');
console.log($rootScope.connectedPeers);
console.log($rootScope.connectedTo);
$rootScope.$apply(function() {
$rootScope.connectedPeers.push(pid);
$rootScope.connectedTo.push(pid);
});
console.log($rootScope.connectedPeers);
console.log($rootScope.connectedTo);
});
c.on('data', _onData);
c.on('error', function(err) {
console.error('-------- Error --------')
});
}
};
var _send = function(pids, data) {
if (Array.isArray(pids)) {
pids.forEach(function(pid) {
_sender(pid, data);
});
} else if (typeof pids === 'string') {
_sender(pid, data);
} }
console.log(data);
}; };
return { return {
init: _init, init: _init,
connect: _connect, connect: _connect,
sendTo: _sendTo send: _send
} }
}); });