aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthew Wild <mwild1@gmail.com>2011-08-29 13:00:33 -0400
committerMatthew Wild <mwild1@gmail.com>2011-08-29 13:00:33 -0400
commitf9d0231beffb3358c51cddc0187093d6917448bb (patch)
tree1c494effeca2cc9c488de86aef634fc0ed17d25f
parentb17dbe08c55d3f6ff76ea55c0742d903f47288eb (diff)
downloadprosody-f9d0231beffb3358c51cddc0187093d6917448bb.tar.gz
prosody-f9d0231beffb3358c51cddc0187093d6917448bb.zip
util.throttle: Generic module by waqas to limit something over some time
-rw-r--r--util/throttle.lua44
1 files changed, 44 insertions, 0 deletions
diff --git a/util/throttle.lua b/util/throttle.lua
new file mode 100644
index 00000000..8b62e797
--- /dev/null
+++ b/util/throttle.lua
@@ -0,0 +1,44 @@
+
+local gettime = require "socket".gettime;
+
+module "throttle"
+
+local throttle = {};
+local throttle_mt = { __index = throttle };
+
+function throttle:update()
+ local newt = gettime();
+ local elapsed = newt - self.t;
+ self.t = newt;
+ local balance = self.rate * elapsed + self.balance;
+ if balance > self.max then
+ self.balance = self.max;
+ else
+ self.balance = balance;
+ end
+ return self.balance;
+end
+
+function throttle:peek(cost)
+ cost = cost or 1;
+ return self.balance >= cost or self:update() >= cost;
+end
+
+function throttle:poll(cost, split)
+ if self:peek(cost) then
+ self.balance = self.balance - cost;
+ return true;
+ else
+ local balance = self.balance;
+ if split then
+ self.balance = 0;
+ end
+ return false, balance, (cost-self.balance);
+ end
+end
+
+function create(max, period)
+ return setmetatable({ rate = max / period, max = max, t = 0, balance = max }, throttle_mt);
+end
+
+return _M;