Browse Source

tx confirmation subs API endpoints

feat/estimateFee-limit
Ivan Socolsky 8 years ago
parent
commit
7803e4576b
No known key found for this signature in database GPG Key ID: FAECE6A05FAA4F56
  1. 26
      lib/blockchainmonitor.js
  2. 2
      lib/model/txconfirmationsub.js
  3. 33
      lib/server.js
  4. 111
      test/integration/server.js

26
lib/blockchainmonitor.js

@ -132,8 +132,6 @@ BlockchainMonitor.prototype._handleThirdPartyBroadcasts = function(data, process
}); });
}; };
BlockchainMonitor.prototype._handleIncomingPayments = function(data) { BlockchainMonitor.prototype._handleIncomingPayments = function(data) {
var self = this; var self = this;
@ -208,7 +206,7 @@ BlockchainMonitor.prototype._handleIncomingTx = function(data) {
this._handleIncomingPayments(data); this._handleIncomingPayments(data);
}; };
BlockchainMonitor.prototype._handleNewBlock = function(network, hash) { BlockchainMonitor.prototype._notifyNewBlock = function(network, hash) {
var self = this; var self = this;
log.info('New ' + network + ' block: ', hash); log.info('New ' + network + ' block: ', hash);
@ -228,6 +226,28 @@ BlockchainMonitor.prototype._handleNewBlock = function(network, hash) {
}); });
}; };
BlockchainMonitor.prototype._handleTxConfirmations = function(network, hash) {
var self = this;
var explorer = self.explorers[network];
if (!explorer) return;
explorer.getTxidsInBlock(hash, function(err, txids) {
if (err) {
log.error('Could not fetch txids from block ' + hash);
return;
}
// self.storage.fetchTx
});
};
BlockchainMonitor.prototype._handleNewBlock = function(network, hash) {
this._notifyNewBlock(network, hash);
this._handleTxConfirmations(network, hash);
};
BlockchainMonitor.prototype._storeAndBroadcastNotification = function(notification, cb) { BlockchainMonitor.prototype._storeAndBroadcastNotification = function(notification, cb) {
var self = this; var self = this;

2
lib/model/txconfirmationsub.js

@ -11,6 +11,7 @@ TxConfirmationSub.create = function(opts) {
x.createdOn = Math.floor(Date.now() / 1000); x.createdOn = Math.floor(Date.now() / 1000);
x.copayerId = opts.copayerId; x.copayerId = opts.copayerId;
x.txid = opts.txid; x.txid = opts.txid;
x.nbConfirmations = opts.nbConfirmations || 1;
x.isActive = true; x.isActive = true;
return x; return x;
}; };
@ -22,6 +23,7 @@ TxConfirmationSub.fromObj = function(obj) {
x.createdOn = obj.createdOn; x.createdOn = obj.createdOn;
x.copayerId = obj.copayerId; x.copayerId = obj.copayerId;
x.txid = obj.txid; x.txid = obj.txid;
x.nbConfirmations = obj.nbConfirmations;
x.isActive = obj.isActive; x.isActive = obj.isActive;
return x; return x;
}; };

33
lib/server.js

@ -3136,5 +3136,38 @@ WalletService.prototype.pushNotificationsUnsubscribe = function(opts, cb) {
self.storage.removePushNotificationSub(self.copayerId, opts.token, cb); self.storage.removePushNotificationSub(self.copayerId, opts.token, cb);
}; };
/**
* Subscribe this copayer to the specified tx to get a notification when the tx confirms.
* @param {Object} opts
* @param {string} opts.txid - The txid of the tx to be notified of.
* @param {string} [opts.nbConfirmations=1] - The number of confirmations to wait before sending the notification.
*/
WalletService.prototype.txConfirmationSubscribe = function(opts, cb) {
if (!checkRequired(opts, ['txid'], cb)) return;
var self = this;
var sub = Model.TxConfirmationSub.create({
copayerId: self.copayerId,
txid: opts.txid,
nbConfirmations: +opts.nbConfirmations || 1,
});
self.storage.storeTxConfirmationSub(sub, cb);
};
/**
* Unsubscribe this copayer to the Push Notifications service using the specified token.
* @param {Object} opts
* @param {string} opts.txid - The txid of the tx to be notified of.
*/
WalletService.prototype.txConfirmationUnsubscribe = function(opts, cb) {
if (!checkRequired(opts, ['txid'], cb)) return;
var self = this;
self.storage.removeTxConfirmationSub(self.copayerId, opts.txid, cb);
};
module.exports = WalletService; module.exports = WalletService;
module.exports.ClientError = ClientError; module.exports.ClientError = ClientError;

111
test/integration/server.js

@ -7341,4 +7341,115 @@ describe('Wallet service', function() {
}); });
}); });
}); });
describe('Tx confirmation notifications', function() {
var server, wallet;
beforeEach(function(done) {
helpers.createAndJoinWallet(2, 3, function(s, w) {
server = s;
wallet = w;
done();
});
});
it('should subscribe copayer to a tx confirmation', function(done) {
helpers.getAuthServer(wallet.copayers[0].id, function(server) {
should.exist(server);
server.txConfirmationSubscribe({
txid: '123',
}, function(err) {
should.not.exist(err);
server.storage.fetchActiveTxConfirmationSubs(wallet.copayers[0].id, function(err, subs) {
should.not.exist(err);
should.exist(subs);
subs.length.should.equal(1);
var s = subs[0];
s.txid.should.equal('123');
s.nbConfirmations.should.equal(1);
s.isActive.should.be.true;
done();
});
});
});
});
it('should overwrite last subscription', function(done) {
helpers.getAuthServer(wallet.copayers[0].id, function(server) {
should.exist(server);
server.txConfirmationSubscribe({
txid: '123',
}, function(err) {
server.txConfirmationSubscribe({
txid: '123',
nbConfirmations: 6,
}, function(err) {
should.not.exist(err);
server.storage.fetchActiveTxConfirmationSubs(wallet.copayers[0].id, function(err, subs) {
should.not.exist(err);
should.exist(subs);
subs.length.should.equal(1);
var s = subs[0];
s.txid.should.equal('123');
s.nbConfirmations.should.equal(6);
s.isActive.should.be.true;
done();
});
});
});
});
});
it('should unsubscribe copayer to the specified tx', function(done) {
helpers.getAuthServer(wallet.copayers[0].id, function(server) {
should.exist(server);
async.series([
function(next) {
server.txConfirmationSubscribe({
txid: '123',
}, next);
},
function(next) {
server.txConfirmationSubscribe({
txid: '456',
}, next);
},
function(next) {
server.txConfirmationUnsubscribe({
txid: '123',
}, next);
},
function(next) {
server.storage.fetchActiveTxConfirmationSubs(wallet.copayers[0].id, function(err, subs) {
should.not.exist(err);
should.exist(subs);
subs.length.should.equal(1);
var s = subs[0];
s.txid.should.equal('456');
next();
});
},
function(next) {
helpers.getAuthServer(wallet.copayers[1].id, function(server) {
server.txConfirmationUnsubscribe({
txid: '456'
}, next);
});
},
function(next) {
server.storage.fetchActiveTxConfirmationSubs(wallet.copayers[0].id, function(err, subs) {
should.not.exist(err);
should.exist(subs);
subs.length.should.equal(1);
var s = subs[0];
s.txid.should.equal('456');
next();
});
},
], function(err) {
should.not.exist(err);
done();
});
});
});
});
}); });

Loading…
Cancel
Save