Browse Source

Merge pull request #481 from isocolsky/ref/backoff-time

Simplify penalties and make them harder to trigger
activeAddress
Matias Alejo Garcia 9 years ago
parent
commit
1af3d53801
  1. 8
      lib/common/defaults.js
  2. 2
      lib/server.js
  3. 29
      test/integration/server.js

8
lib/common/defaults.js

@ -11,13 +11,13 @@ Defaults.MAX_TX_SIZE_IN_KB = 100;
Defaults.MAX_KEYS = 100; Defaults.MAX_KEYS = 100;
// Time after which a Tx proposal can be erased by any copayer. in seconds // Time after which a Tx proposal can be erased by any copayer. in seconds
Defaults.DELETE_LOCKTIME = 24 * 3600; Defaults.DELETE_LOCKTIME = 1 * 3600;
// Allowed consecutive txp rejections before backoff is applied. // Allowed consecutive txp rejections before backoff is applied.
Defaults.BACKOFF_OFFSET = 3; Defaults.BACKOFF_OFFSET = 10;
// Time a copayer need to wait to create a new TX after her tx previous proposal we rejected. (incremental). in Minutes. // Time a copayer need to wait to create a new TX after her tx previous proposal we rejected. in seconds.
Defaults.BACKOFF_TIME = 2; Defaults.BACKOFF_TIME = 1 * 3600;
Defaults.MAX_MAIN_ADDRESS_GAP = 20; Defaults.MAX_MAIN_ADDRESS_GAP = 20;

2
lib/server.js

@ -1532,7 +1532,7 @@ WalletService.prototype._canCreateTx = function(cb) {
var lastTxTs = txs[0].createdOn; var lastTxTs = txs[0].createdOn;
var now = Math.floor(Date.now() / 1000); var now = Math.floor(Date.now() / 1000);
var timeSinceLastRejection = now - lastTxTs; var timeSinceLastRejection = now - lastTxTs;
var backoffTime = 60 * Math.pow(Defaults.BACKOFF_TIME, exceededRejections); var backoffTime = Defaults.BACKOFF_TIME;
if (timeSinceLastRejection <= backoffTime) if (timeSinceLastRejection <= backoffTime)
log.debug('Not allowing to create TX: timeSinceLastRejection/backoffTime', timeSinceLastRejection, backoffTime); log.debug('Not allowing to create TX: timeSinceLastRejection/backoffTime', timeSinceLastRejection, backoffTime);

29
test/integration/server.js

@ -3116,9 +3116,10 @@ describe('Wallet service', function() {
}); });
describe('Backoff time', function(done) { describe('Backoff time', function(done) {
var server, wallet, txid; var server, wallet, txid, clock;
var _oldBackoffOffset = Defaults.BACKOFF_OFFSET;
beforeEach(function(done) { beforeEach(function(done) {
Defaults.BACKOFF_OFFSET = 3;
helpers.createAndJoinWallet(2, 2, function(s, w) { helpers.createAndJoinWallet(2, 2, function(s, w) {
server = s; server = s;
wallet = w; wallet = w;
@ -3127,8 +3128,14 @@ describe('Wallet service', function() {
}); });
}); });
}); });
afterEach(function(done) {
Defaults.BACKOFF_OFFSET = _oldBackoffOffset;
clock.restore();
done();
});
it('should follow backoff time after consecutive rejections', function(done) { it('should follow backoff time after consecutive rejections', function(done) {
clock = sinon.useFakeTimers(Date.now(), 'Date');
async.series([ async.series([
function(next) { function(next) {
@ -3164,10 +3171,10 @@ describe('Wallet service', function() {
}); });
}, },
function(next) { function(next) {
var clock = sinon.useFakeTimers(Date.now() + (Defaults.BACKOFF_TIME + 2) * 60 * 1000, 'Date'); clock.tick((Defaults.BACKOFF_TIME + 1) * 1000);
var txOpts = helpers.createSimpleProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 1, TestData.copayers[0].privKey_1H_0); var txOpts = helpers.createSimpleProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 1, TestData.copayers[0].privKey_1H_0);
server.createTxLegacy(txOpts, function(err, tx) { server.createTxLegacy(txOpts, function(err, tx) {
clock.restore(); should.not.exist(err);
server.rejectTx({ server.rejectTx({
txProposalId: tx.id, txProposalId: tx.id,
reason: 'some reason', reason: 'some reason',
@ -3176,15 +3183,25 @@ describe('Wallet service', function() {
}, },
function(next) { function(next) {
// Do not allow a 5th tx before backoff time // Do not allow a 5th tx before backoff time
var clock = sinon.useFakeTimers(Date.now() + (Defaults.BACKOFF_TIME + 2) * 60 * 1000 + 1, 'Date'); clock.tick((Defaults.BACKOFF_TIME - 1) * 1000);
var txOpts = helpers.createSimpleProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 1, TestData.copayers[0].privKey_1H_0); var txOpts = helpers.createSimpleProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 1, TestData.copayers[0].privKey_1H_0);
server.createTxLegacy(txOpts, function(err, tx) { server.createTxLegacy(txOpts, function(err, tx) {
clock.restore();
should.exist(err); should.exist(err);
err.code.should.equal('TX_CANNOT_CREATE'); err.code.should.equal('TX_CANNOT_CREATE');
next(); next();
}); });
}, },
function(next) {
clock.tick(2000);
var txOpts = helpers.createSimpleProposalOpts('18PzpUFkFZE8zKWUPvfykkTxmB9oMR8qP7', 1, TestData.copayers[0].privKey_1H_0);
server.createTxLegacy(txOpts, function(err, tx) {
should.not.exist(err);
server.rejectTx({
txProposalId: tx.id,
reason: 'some reason',
}, next);
});
},
], function(err) { ], function(err) {
should.not.exist(err); should.not.exist(err);
done(); done();

Loading…
Cancel
Save