This commit is contained in:
barisusakli
2014-11-19 15:55:01 -05:00
parent d5453efdac
commit 9c1216eb63
3 changed files with 53 additions and 11 deletions

View File

@@ -0,0 +1,35 @@
'use strict';
var winston = require('winston');
var ratelimit = {};
var allowedCallsPerSecond = 10;
ratelimit.isFlooding = function(socket) {
socket.callsPerSecond = socket.callsPerSecond || 0;
socket.elapsedTime = socket.elapsedTime || 0;
socket.lastCallTime = socket.lastCallTime || Date.now();
++socket.callsPerSecond;
var now = Date.now();
socket.elapsedTime += now - socket.lastCallTime;
if (socket.callsPerSecond > allowedCallsPerSecond && socket.elapsedTime < 1000) {
winston.warn('Flooding detected! Calls : ' + socket.callsPerSecond + ', Duration : ' + socket.elapsedTime);
return true;
}
if (socket.elapsedTime >= 1000) {
socket.elapsedTime = 0;
socket.callsPerSecond = 0;
}
socket.lastCallTime = now;
return false;
};
module.exports = ratelimit;