Added the multipeer connections support
This commit is contained in:
parent
4fec0ee71d
commit
99b81128fd
4 changed files with 125 additions and 78 deletions
|
|
@ -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>
|
||||||
|
|
|
||||||
|
|
@ -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();
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
|
||||||
|
|
@ -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);
|
||||||
|
|
|
||||||
|
|
@ -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) {
|
|
||||||
console.log('------ new data ------');
|
|
||||||
console.log(data);
|
|
||||||
|
|
||||||
|
for ( var i = 0; i < b.length; i++)
|
||||||
|
seen[b[i]] = true;
|
||||||
|
|
||||||
console.log(peer.connections);
|
for ( var i = 0; i < a.length; i++)
|
||||||
|
if (!seen[a[i]])
|
||||||
|
diff.push(a[i]);
|
||||||
|
|
||||||
|
return diff;
|
||||||
|
};
|
||||||
|
|
||||||
c.on('close', function() {
|
var _sender = function(pid, data) {
|
||||||
alert(c.peer + ' has left the wallet.');
|
if (pid !== $rootScope.peerId) {
|
||||||
delete connectedPeers[c.peer];
|
console.log('-------- sending data to: ' + pid + ' --------');
|
||||||
|
var conns = peer.connections[pid];
|
||||||
|
|
||||||
|
if (conns) {
|
||||||
|
var str = JSON.stringify({
|
||||||
|
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
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue