Browse Source

various fixes

activeAddress
Ivan Socolsky 10 years ago
parent
commit
75a834c4cf
  1. 3
      bcmonitor/bcmonitor.js
  2. 15
      bws.js
  3. 18
      lib/blockchainmonitor.js
  4. 4
      lib/messagebroker.js
  5. 37
      lib/server.js
  6. 6
      lib/storage.js
  7. 2
      lib/wsapp.js

3
bcmonitor/bcmonitor.js

@ -14,7 +14,4 @@ bcm.start(config, function(err) {
if (err) throw err; if (err) throw err;
console.log('Blockchain monitor started'); console.log('Blockchain monitor started');
_.each(bcm.explorers, function(explorer) {
console.log('\t' + explorer.network.name + ': ' + explorer.url);
});
}); });

15
bws.js

@ -37,8 +37,10 @@ var start = function(cb) {
if (err) return cb(err); if (err) return cb(err);
var server = config.https ? serverModule.createServer(serverOpts, app) : var server = config.https ? serverModule.createServer(serverOpts, app) :
serverModule.Server(app); serverModule.Server(app);
new WsApp().start(server, config); var wsApp = new WsApp();
return server; wsApp.start(server, config, function(err) {
return server;
});
}); });
}); });
return cb(null, server); return cb(null, server);
@ -47,8 +49,10 @@ var start = function(cb) {
if (err) return cb(err); if (err) return cb(err);
server = config.https ? serverModule.createServer(serverOpts, app) : server = config.https ? serverModule.createServer(serverOpts, app) :
serverModule.Server(app); serverModule.Server(app);
new WsApp().start(server, config); var wsApp = new WsApp();
return cb(null, server); wsApp.start(server, config, function(err) {
return cb(err, server);
});
}); });
}; };
}; };
@ -56,6 +60,9 @@ var start = function(cb) {
if (config.cluster && !config.lockOpts.lockerServer) if (config.cluster && !config.lockOpts.lockerServer)
throw 'When running in cluster mode, locker server need to be configured'; throw 'When running in cluster mode, locker server need to be configured';
if (config.cluster && !config.messageBrokerOpts.messageBrokerServer)
throw 'When running in cluster mode, message broker server need to be configured';
start(function(err, server) { start(function(err, server) {
if (err) { if (err) {
console.log('Could not start BWS:', err); console.log('Could not start BWS:', err);

18
lib/blockchainmonitor.js

@ -54,6 +54,14 @@ BlockchainMonitor.prototype._initExplorer = function(provider, network, url) {
}); });
var socket = explorer.initSocket(); var socket = explorer.initSocket();
var connectionInfo = provider + ' (' + network + ') @ ' + url;
socket.on('connect', function() {
log.info('Connected to ' + connectionInfo);
});
socket.on('connect_error', function() {
log.error('Error connecting to ' + connectionInfo);
});
socket.emit('subscribe', 'inv'); socket.emit('subscribe', 'inv');
socket.on('tx', _.bind(self._handleIncommingTx, self)); socket.on('tx', _.bind(self._handleIncommingTx, self));
@ -67,7 +75,8 @@ BlockchainMonitor.prototype._handleIncommingTx = function(data) {
var outs = _.compact(_.map(data.vout, function(v) { var outs = _.compact(_.map(data.vout, function(v) {
var addr = _.keys(v)[0]; var addr = _.keys(v)[0];
if (addr.indexOf('3') != 0 && addr.indexOf('2') != 0) return; var startingChar = addr.charAt(0);
if (startingChar != '2' && startingChar != '3') return;
return { return {
address: addr, address: addr,
@ -78,8 +87,11 @@ BlockchainMonitor.prototype._handleIncommingTx = function(data) {
async.each(outs, function(out, next) { async.each(outs, function(out, next) {
self.storage.fetchAddress(out.address, function(err, address) { self.storage.fetchAddress(out.address, function(err, address) {
if (err || !address) return next(err); if (err) {
if (address.isChange) return next(); log.error('Could not fetch addresses from the db');
return next(err);
}
if (!address || address.isChange) return next();
var walletId = address.walletId; var walletId = address.walletId;
log.info('Incoming tx for wallet ' + walletId + ' [' + out.amount + 'sat -> ' + out.address + ']'); log.info('Incoming tx for wallet ' + walletId + ' [' + out.amount + 'sat -> ' + out.address + ']');

4
lib/messagebroker.js

@ -18,14 +18,14 @@ function MessageBroker(opts) {
this.mq = require('socket.io-client').connect(url); this.mq = require('socket.io-client').connect(url);
this.mq.on('connect', function() {}); this.mq.on('connect', function() {});
this.mq.on('connect_error', function() { this.mq.on('connect_error', function() {
log.warn('Message queue server connection error'); log.warn('Error connecting to message broker server @ ' + url);
}); });
this.mq.on('msg', function(data) { this.mq.on('msg', function(data) {
self.emit('msg', data); self.emit('msg', data);
}); });
log.info('Using message queue server at ' + url); log.info('Using message broker server at ' + url);
} }
}; };

37
lib/server.js

@ -282,7 +282,7 @@ WalletService.prototype.replaceTemporaryRequestKey = function(opts, cb) {
walletId: opts.walletId, walletId: opts.walletId,
copayerId: self.copayerId, copayerId: self.copayerId,
copayerName: opts.name, copayerName: opts.name,
}, false, function() { }, function() {
return cb(null, { return cb(null, {
copayerId: self.copayerId, copayerId: self.copayerId,
wallet: wallet wallet: wallet
@ -308,11 +308,18 @@ WalletService.prototype._verifySignature = function(text, signature, pubKey) {
* *
* @param {String} type * @param {String} type
* @param {Object} data * @param {Object} data
* @param {Boolean} isGlobal - If true, the notification is not issued on behalf of any particular copayer (defaults to false) * @param {Object} opts
* @param {Boolean} opts.isGlobal - If true, the notification is not issued on behalf of any particular copayer (defaults to false)
*/ */
WalletService.prototype._notify = function(type, data, isGlobal, cb) { WalletService.prototype._notify = function(type, data, opts, cb) {
var self = this; var self = this;
if (_.isFunction(opts)) {
cb = opts;
opts = {};
}
opts = opts || {};
log.debug('Notification', type, data); log.debug('Notification', type, data);
var walletId = self.walletId || data.walletId; var walletId = self.walletId || data.walletId;
@ -324,7 +331,7 @@ WalletService.prototype._notify = function(type, data, isGlobal, cb) {
type: type, type: type,
data: data, data: data,
ticker: this.notifyTicker++, ticker: this.notifyTicker++,
creatorId: isGlobal ? null : copayerId, creatorId: opts.isGlobal ? null : copayerId,
walletId: walletId, walletId: walletId,
}); });
this.storage.storeNotification(walletId, n, function() { this.storage.storeNotification(walletId, n, function() {
@ -393,7 +400,7 @@ WalletService.prototype.joinWallet = function(opts, cb) {
walletId: opts.walletId, walletId: opts.walletId,
copayerId: copayer.id, copayerId: copayer.id,
copayerName: copayer.name, copayerName: copayer.name,
}, false, function() { }, function() {
return cb(null, { return cb(null, {
copayerId: copayer.id, copayerId: copayer.id,
wallet: wallet wallet: wallet
@ -426,7 +433,7 @@ WalletService.prototype.createAddress = function(opts, cb) {
self._notify('NewAddress', { self._notify('NewAddress', {
address: address.address, address: address.address,
}, false, function() { }, function() {
return cb(null, address); return cb(null, address);
}); });
}); });
@ -726,7 +733,7 @@ WalletService.prototype.createTx = function(opts, cb) {
self._notify('NewTxProposal', { self._notify('NewTxProposal', {
amount: opts.amount amount: opts.amount
}, false, function() { }, function() {
return cb(null, txp); return cb(null, txp);
}); });
}); });
@ -800,7 +807,7 @@ WalletService.prototype.removePendingTx = function(opts, cb) {
if (actors.length > 1 || (actors.length == 1 && actors[0] !== self.copayerId)) if (actors.length > 1 || (actors.length == 1 && actors[0] !== self.copayerId))
return cb(new ClientError('TXACTIONED', 'Cannot remove a proposal signed/rejected by other copayers')); return cb(new ClientError('TXACTIONED', 'Cannot remove a proposal signed/rejected by other copayers'));
self._notify('TxProposalRemoved', {}, false, function() { self._notify('TxProposalRemoved', {}, function() {
self.storage.removeTx(self.walletId, txp.id, cb); self.storage.removeTx(self.walletId, txp.id, cb);
}); });
}); });
@ -863,13 +870,13 @@ WalletService.prototype.signTx = function(opts, cb) {
self._notify('TxProposalAcceptedBy', { self._notify('TxProposalAcceptedBy', {
txProposalId: opts.txProposalId, txProposalId: opts.txProposalId,
copayerId: self.copayerId, copayerId: self.copayerId,
}, false, done); }, done);
}, },
function(done) { function(done) {
if (txp.isAccepted()) { if (txp.isAccepted()) {
self._notify('TxProposalFinallyAccepted', { self._notify('TxProposalFinallyAccepted', {
txProposalId: opts.txProposalId, txProposalId: opts.txProposalId,
}, false, done); }, done);
} else { } else {
done(); done();
} }
@ -918,7 +925,7 @@ WalletService.prototype.broadcastTx = function(opts, cb) {
self._notify('NewOutgoingTx', { self._notify('NewOutgoingTx', {
txProposalId: opts.txProposalId, txProposalId: opts.txProposalId,
txid: txid txid: txid
}, false, function() { }, function() {
return cb(null, txp); return cb(null, txp);
}); });
}); });
@ -964,13 +971,13 @@ WalletService.prototype.rejectTx = function(opts, cb) {
self._notify('TxProposalRejectedBy', { self._notify('TxProposalRejectedBy', {
txProposalId: opts.txProposalId, txProposalId: opts.txProposalId,
copayerId: self.copayerId, copayerId: self.copayerId,
}, false, done); }, done);
}, },
function(done) { function(done) {
if (txp.status == 'rejected') { if (txp.status == 'rejected') {
self._notify('TxProposalFinallyRejected', { self._notify('TxProposalFinallyRejected', {
txProposalId: opts.txProposalId, txProposalId: opts.txProposalId,
}, false, done); }, done);
} else { } else {
done(); done();
} }
@ -1319,7 +1326,9 @@ WalletService.prototype.startScan = function(opts, cb) {
result: err ? 'error' : 'success', result: err ? 'error' : 'success',
}; };
if (err) data.error = err; if (err) data.error = err;
self._notify('ScanFinished', data, true); self._notify('ScanFinished', data, {
isGlobal: true
});
}; };
self.getWallet({}, function(err, wallet) { self.getWallet({}, function(err, wallet) {

6
lib/storage.js

@ -100,6 +100,9 @@ Storage.prototype.storeWalletAndUpdateCopayersLookup = function(wallet, cb) {
}; };
Storage.prototype.fetchCopayerLookup = function(copayerId, cb) { Storage.prototype.fetchCopayerLookup = function(copayerId, cb) {
this.db.collection(collections.COPAYERS_LOOKUP).createIndex({
copayerId: 1
});
this.db.collection(collections.COPAYERS_LOOKUP).findOne({ this.db.collection(collections.COPAYERS_LOOKUP).findOne({
copayerId: copayerId copayerId: copayerId
}, function(err, result) { }, function(err, result) {
@ -315,6 +318,9 @@ Storage.prototype.storeAddressAndWallet = function(wallet, addresses, cb) {
Storage.prototype.fetchAddress = function(address, cb) { Storage.prototype.fetchAddress = function(address, cb) {
var self = this; var self = this;
this.db.collection(collections.ADDRESSES).createIndex({
address: 1
});
this.db.collection(collections.ADDRESSES).findOne({ this.db.collection(collections.ADDRESSES).findOne({
address: address, address: address,
}, function(err, result) { }, function(err, result) {

2
lib/wsapp.js

@ -53,8 +53,8 @@ WsApp.prototype.start = function(server, opts, cb) {
}); });
socket.emit('challenge', socket.nonce); socket.emit('challenge', socket.nonce);
done();
}); });
done();
}, },
], function(err) { ], function(err) {
if (cb) return cb(err); if (cb) return cb(err);

Loading…
Cancel
Save