mirror of https://github.com/BTCPrivate/copay.git
added support for localstorage
This commit is contained in:
parent
910906664c
commit
c08eda28ab
|
@ -205,6 +205,7 @@
|
||||||
<script src="js/filters.js"></script>
|
<script src="js/filters.js"></script>
|
||||||
|
|
||||||
<script src="js/services/network.js"></script>
|
<script src="js/services/network.js"></script>
|
||||||
|
<script src="js/services/storage.js"></script>
|
||||||
|
|
||||||
<script src="js/controllers/header.js"></script>
|
<script src="js/controllers/header.js"></script>
|
||||||
<script src="js/controllers/home.js"></script>
|
<script src="js/controllers/home.js"></script>
|
||||||
|
|
|
@ -11,7 +11,8 @@ angular.module('copay',[
|
||||||
'copay.backup',
|
'copay.backup',
|
||||||
'copay.network',
|
'copay.network',
|
||||||
'copay.signin',
|
'copay.signin',
|
||||||
'copay.peer'
|
'copay.peer',
|
||||||
|
'copay.storage'
|
||||||
]);
|
]);
|
||||||
|
|
||||||
angular.module('copay.header', []);
|
angular.module('copay.header', []);
|
||||||
|
@ -22,4 +23,5 @@ angular.module('copay.backup', []);
|
||||||
angular.module('copay.network', []);
|
angular.module('copay.network', []);
|
||||||
angular.module('copay.signin', []);
|
angular.module('copay.signin', []);
|
||||||
angular.module('copay.peer', []);
|
angular.module('copay.peer', []);
|
||||||
|
angular.module('copay.storage', []);
|
||||||
|
|
||||||
|
|
|
@ -4,7 +4,6 @@ angular.module('copay.peer').controller('PeerController',
|
||||||
function($scope, $rootScope, $location, $routeParams, Network) {
|
function($scope, $rootScope, $location, $routeParams, Network) {
|
||||||
|
|
||||||
$scope.init = function() {
|
$scope.init = function() {
|
||||||
console.log('connecting peer init');
|
|
||||||
//Network.connect($rootScope.masterId);
|
//Network.connect($rootScope.masterId);
|
||||||
};
|
};
|
||||||
});
|
});
|
||||||
|
|
|
@ -1,15 +1,16 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
angular.module('copay.signin').controller('SigninController',
|
angular.module('copay.signin').controller('SigninController',
|
||||||
function($scope, $rootScope, $location, Network) {
|
function($scope, $rootScope, $location, Network, Storage) {
|
||||||
|
var peerData = Storage.get('peerData');
|
||||||
|
|
||||||
$scope.loading = false;
|
$scope.loading = false;
|
||||||
$rootScope.peerId = null;
|
$rootScope.peerId = peerData ? peerData.peerId : null;
|
||||||
|
|
||||||
$scope.create = function() {
|
$scope.create = function() {
|
||||||
$scope.loading = true;
|
$scope.loading = true;
|
||||||
|
|
||||||
Network.init(function(pid) {
|
Network.init(function() {
|
||||||
$rootScope.masterId = pid;
|
|
||||||
$location.path('peer');
|
$location.path('peer');
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
|
@ -17,12 +18,26 @@ angular.module('copay.signin').controller('SigninController',
|
||||||
$scope.join = function(cid) {
|
$scope.join = function(cid) {
|
||||||
$scope.loading = true;
|
$scope.loading = true;
|
||||||
|
|
||||||
|
if (cid) {
|
||||||
|
$rootScope.connectedTo.push(cid);
|
||||||
|
|
||||||
Network.init(function() {
|
Network.init(function() {
|
||||||
Network.connect(cid, function() {
|
Network.connect(cid, function() {
|
||||||
$rootScope.masterId = cid;
|
|
||||||
$location.path('peer');
|
$location.path('peer');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (peerData && peerData.peerId) {
|
||||||
|
console.log('------- reloaded ----------');
|
||||||
|
console.log(peerData);
|
||||||
|
$rootScope.peerId = peerData.peerId;
|
||||||
|
$rootScope.connectedPeers = peerData.connectedPeers;
|
||||||
|
|
||||||
|
console.log(peerData.connectedTo[0]);
|
||||||
|
|
||||||
|
$scope.join(peerData.connectedTo[0]);
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
'use strict';
|
'use strict';
|
||||||
|
|
||||||
angular.module('copay.network')
|
angular.module('copay.network')
|
||||||
.factory('Network', function($rootScope) {
|
.factory('Network', function($rootScope, Storage) {
|
||||||
var peer;
|
var peer;
|
||||||
$rootScope.connectedPeers = [];
|
$rootScope.connectedPeers = [];
|
||||||
$rootScope.connectedTo = [];
|
$rootScope.connectedTo = [];
|
||||||
$rootScope.masterId = null;
|
|
||||||
$rootScope.peerId = null;
|
$rootScope.peerId = null;
|
||||||
|
|
||||||
var _arrayDiff = function(a, b) {
|
var _arrayDiff = function(a, b) {
|
||||||
|
@ -22,6 +21,18 @@ angular.module('copay.network')
|
||||||
return diff;
|
return diff;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var _isInArray = function(i, array) {
|
||||||
|
return array.indexOf(i) > -1;
|
||||||
|
};
|
||||||
|
|
||||||
|
var _saveDataStorage = function() {
|
||||||
|
Storage.save('peerData', {
|
||||||
|
peerId: $rootScope.peerId,
|
||||||
|
connectedTo: $rootScope.connectedTo,
|
||||||
|
connectedPeers: $rootScope.connectedPeers
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
var _sender = function(pid, data) {
|
var _sender = function(pid, data) {
|
||||||
if (pid !== $rootScope.peerId) {
|
if (pid !== $rootScope.peerId) {
|
||||||
console.log('-------- sending data to: ' + pid + ' --------');
|
console.log('-------- sending data to: ' + pid + ' --------');
|
||||||
|
@ -46,9 +57,14 @@ angular.module('copay.network')
|
||||||
console.log(data);
|
console.log(data);
|
||||||
var obj = JSON.parse(data);
|
var obj = JSON.parse(data);
|
||||||
|
|
||||||
if (obj.data.peers) {
|
if (obj.data.type === 'connectToPeers')
|
||||||
_connectToPeers(obj.data.peers);
|
_connectToPeers(obj.data.peers);
|
||||||
}
|
|
||||||
|
if (obj.data.type === 'getPeers')
|
||||||
|
_send(obj.sender, {
|
||||||
|
type: 'connectToPeers',
|
||||||
|
peers: $rootScope.connectedPeers
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|
||||||
var _connectToPeers = function(peers) {
|
var _connectToPeers = function(peers) {
|
||||||
|
@ -67,9 +83,13 @@ angular.module('copay.network')
|
||||||
|
|
||||||
peer.on('open', function(pid) {
|
peer.on('open', function(pid) {
|
||||||
$rootScope.peerId = pid;
|
$rootScope.peerId = pid;
|
||||||
|
|
||||||
|
if (!_isInArray(pid, $rootScope.connectedPeers))
|
||||||
$rootScope.connectedPeers.push(pid);
|
$rootScope.connectedPeers.push(pid);
|
||||||
|
|
||||||
cb(pid);
|
_saveDataStorage();
|
||||||
|
|
||||||
|
cb();
|
||||||
|
|
||||||
$rootScope.$digest();
|
$rootScope.$digest();
|
||||||
});
|
});
|
||||||
|
@ -77,25 +97,26 @@ angular.module('copay.network')
|
||||||
peer.on('connection', function(conn) {
|
peer.on('connection', function(conn) {
|
||||||
if (conn.label === 'wallet') {
|
if (conn.label === 'wallet') {
|
||||||
conn.on('open', function() {
|
conn.on('open', function() {
|
||||||
console.log('-------- ' + conn.peer + ' conected to me --------');
|
console.log('<<<<<<<<<<< ' + conn.peer + ' conected to me --------');
|
||||||
|
|
||||||
console.log($rootScope.masterId);
|
var isConnected = $rootScope.connectedTo.indexOf(conn.peer);
|
||||||
console.log($rootScope.peerId);
|
if (isConnected === -1) {
|
||||||
|
|
||||||
if ($rootScope.masterId === $rootScope.peerId) {
|
|
||||||
console.log('-------- I am the master --------');
|
|
||||||
var c = peer.connect(conn.peer, {
|
var c = peer.connect(conn.peer, {
|
||||||
label: 'wallet',
|
label: 'wallet',
|
||||||
serialization: 'none',
|
serialization: 'none',
|
||||||
reliable: false,
|
reliable: false,
|
||||||
metadata: { message: 'hi peer!' }
|
metadata: { message: 'hi copayer!' }
|
||||||
});
|
});
|
||||||
|
|
||||||
c.on('open', function() {
|
c.on('open', function() {
|
||||||
|
console.log('>>>>>>>>> i am connected to ' + conn.peer);
|
||||||
|
if (!_isInArray(conn.peer, $rootScope.connectedPeers))
|
||||||
$rootScope.connectedPeers.push(conn.peer);
|
$rootScope.connectedPeers.push(conn.peer);
|
||||||
|
|
||||||
|
if (!_isInArray(conn.peer, $rootScope.connectedTo))
|
||||||
$rootScope.connectedTo.push(conn.peer);
|
$rootScope.connectedTo.push(conn.peer);
|
||||||
|
|
||||||
_send($rootScope.connectedPeers, { peers: $rootScope.connectedPeers });
|
_saveDataStorage();
|
||||||
|
|
||||||
$rootScope.$digest();
|
$rootScope.$digest();
|
||||||
});
|
});
|
||||||
|
@ -104,6 +125,8 @@ angular.module('copay.network')
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
peer.on('data', _onData);
|
||||||
|
|
||||||
peer.on('close', function() {
|
peer.on('close', function() {
|
||||||
console.log('------- connection closed ---------');
|
console.log('------- connection closed ---------');
|
||||||
});
|
});
|
||||||
|
@ -121,19 +144,14 @@ angular.module('copay.network')
|
||||||
|
|
||||||
c.on('open', function() {
|
c.on('open', function() {
|
||||||
console.log('-------- I\'m connected to ' + pid + ' ------');
|
console.log('-------- I\'m connected to ' + pid + ' ------');
|
||||||
console.log($rootScope.connectedPeers);
|
|
||||||
console.log($rootScope.connectedTo);
|
|
||||||
|
|
||||||
$rootScope.connectedPeers.push(pid);
|
$rootScope.connectedPeers.push(pid);
|
||||||
$rootScope.connectedTo.push(pid);
|
$rootScope.connectedTo.push(pid);
|
||||||
|
|
||||||
if (typeof cb === 'function')
|
if (typeof cb === 'function') cb();
|
||||||
cb();
|
|
||||||
|
_send(c.peer, { type: 'getPeers' });
|
||||||
|
|
||||||
$rootScope.$digest();
|
$rootScope.$digest();
|
||||||
|
|
||||||
console.log($rootScope.connectedPeers);
|
|
||||||
console.log($rootScope.connectedTo);
|
|
||||||
});
|
});
|
||||||
|
|
||||||
c.on('data', _onData);
|
c.on('data', _onData);
|
||||||
|
@ -150,13 +168,14 @@ angular.module('copay.network')
|
||||||
_sender(pid, data);
|
_sender(pid, data);
|
||||||
});
|
});
|
||||||
} else if (typeof pids === 'string') {
|
} else if (typeof pids === 'string') {
|
||||||
_sender(pid, data);
|
_sender(pids, data);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
var _disconnect = function() {
|
var _disconnect = function() {
|
||||||
peer.disconnect();
|
peer.disconnect();
|
||||||
peer.destroy();
|
peer.destroy();
|
||||||
|
Storage.remove('peerData');
|
||||||
console.log('Disconnected and destroyed connection');
|
console.log('Disconnected and destroyed connection');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
angular.module('copay.storage')
|
||||||
|
.factory('Storage', function($rootScope) {
|
||||||
|
return {
|
||||||
|
get: function(key) {
|
||||||
|
return JSON.parse(localStorage.getItem(key));
|
||||||
|
},
|
||||||
|
|
||||||
|
save: function(key, data) {
|
||||||
|
localStorage.setItem(key, JSON.stringify(data));
|
||||||
|
},
|
||||||
|
|
||||||
|
remove: function(key) {
|
||||||
|
localStorage.removeItem(key);
|
||||||
|
},
|
||||||
|
|
||||||
|
clearAll: function() {
|
||||||
|
localStorage.clear();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
});
|
Loading…
Reference in New Issue