added PeerJS and initial Network service

This commit is contained in:
Mario Colque 2014-03-27 16:31:42 -03:00
commit 76eadc17cf
6 changed files with 188 additions and 12 deletions

View file

@ -3,8 +3,14 @@
angular.module('cosign',[
'ngRoute',
'ui.bootstrap',
'cosign.header'
'cosign.header',
'cosign.signin',
'cosign.join',
'cosign.network'
]);
angular.module('cosign.header', []);
angular.module('cosign.signin', []);
angular.module('cosign.join', []);
angular.module('cosign.network', []);

View file

@ -6,11 +6,20 @@ angular
.config(function($routeProvider) {
$routeProvider
.when('/', {
templateUrl: 'signin.html'
})
.when('/signin', {
templateUrl: 'signin.html'
})
.when('/home', {
templateUrl: 'home.html'
})
.when('/join/:id', {
templateUrl: 'join.html'
})
.otherwise({
templateUrl: '404.html'
});
});

21
js/controllers/join.js Normal file
View file

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

24
js/controllers/signin.js Normal file
View file

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

View file

@ -1,8 +1,90 @@
'use strict';
angular.module('cosign.network').factory('Network',
function() {
angular.module('cosign.network')
.factory('NetworkTest', function() {
this.f = function() {
return 2;
};
});
})
.factory('Network', function() {
var peer;
var connectedPeers = {};
var _onConnect = function(c, cb) {
if (c.label === 'wallet') {
var a = peer.connections[c.peer][0];
console.log(peer.connections[c.peer]);
a.send('------ origin recived -------');
c.on('data', function(data) {
console.log('------ new data ------');
console.log(data);
console.log(peer.connections);
c.on('close', function() {
alert(c.peer + ' has left the wallet.');
delete connectedPeers[c.peer];
});
});
setTimeout(function() {
a.send('.........................');
cb(c.peer);
}, 1000);
}
};
var _init = function(cb) {
peer = new Peer({
key: 'lwjd5qra8257b9',
debug: 3
});
peer.on('open', cb);
};
var _connect = function(pid, cb) {
peer.on('connection', function(conn) {
_onConnect(conn, cb);
});
var c = peer.connect(pid, {
label: 'wallet',
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) {
if (typeof pids === 'string') {
// just send
} else if (typeof pids === 'array') {
// iter
}
console.log(data);
};
return {
init: _init,
connect: _connect,
sendTo: _sendTo
}
});