[tor-commits] [flashproxy/master] Add a ratelimit parameter.
dcf at torproject.org
dcf at torproject.org
Thu Dec 22 17:48:04 UTC 2011
commit cbb7fd82306fe7231136a8b5d1cfaf56c7820f9a
Author: David Fifield <david at bamsoftware.com>
Date: Wed Nov 16 04:40:17 2011 -0800
Add a ratelimit parameter.
---
swfcat.as | 69 ++++++++++++++++++++++++++++++++++++++++++++++++++++++------
1 files changed, 62 insertions(+), 7 deletions(-)
diff --git a/swfcat.as b/swfcat.as
index b83dc2f..478b97c 100644
--- a/swfcat.as
+++ b/swfcat.as
@@ -24,6 +24,10 @@
* facilitator_poll_interval=<FLOAT>
* How often to poll the facilitator, in seconds. The default is
* DEFAULT_FACILITATOR_POLL_INTERVAL. There is a sanity-check minimum of 1.0 s.
+ *
+ * ratelimit=<FLOAT>(<UNIT>)?
+ * What rate to limit all proxy traffic combined to. The default is
+ * DEFAULT_RATE_LIMIT. There is a sanity-check minimum of "10K".
*
* client=1
* If set (to any value), run in client RTMFP mode. In this mode, rather than
@@ -78,7 +82,8 @@ package
private const MIN_FACILITATOR_POLL_INTERVAL:Number = 1.0;
// Bytes per second. Set to undefined to disable limit.
- public static const RATE_LIMIT:Number = undefined;
+ public static const DEFAULT_RATE_LIMIT:Number = undefined;
+ public static const MIN_RATE_LIMIT:Number = 10 * 1024;
// Seconds.
private static const RATE_LIMIT_HISTORY:Number = 5.0;
@@ -117,18 +122,13 @@ package
proxy_pairs = [];
- if (RATE_LIMIT)
- rate_limit = new BucketRateLimit(RATE_LIMIT * RATE_LIMIT_HISTORY, RATE_LIMIT_HISTORY);
- else
- rate_limit = new RateUnlimit();
-
// Wait until the query string parameters are loaded.
this.loaderInfo.addEventListener(Event.COMPLETE, loaderinfo_complete);
}
private function loaderinfo_complete(e:Event):void
{
- var tmp:Object;
+ var tmp:*;
debug = this.loaderInfo.parameters["debug"];
@@ -166,6 +166,18 @@ package
}
facilitator_poll_interval = Number(tmp);
+ tmp = get_param_byte_count("ratelimit", DEFAULT_RATE_LIMIT);
+ if (tmp === undefined) {
+ /* No rate limit. */
+ } else if (tmp == null || tmp < MIN_FACILITATOR_POLL_INTERVAL) {
+ puts("Error: ratelimit must be a nonnegative number at least " + MIN_RATE_LIMIT + ".");
+ return;
+ }
+ if (tmp)
+ rate_limit = new BucketRateLimit(Number(tmp) * RATE_LIMIT_HISTORY, RATE_LIMIT_HISTORY);
+ else
+ rate_limit = new RateUnlimit();
+
local_addr = get_param_addr("local", DEFAULT_LOCAL_TOR_CLIENT_ADDR);
if (!local_addr) {
puts("Error: Local spec must be in the form \"host:port\".");
@@ -219,6 +231,19 @@ package
return get_param_number(param, default_val);
}
+ /* Get a count of bytes from a string specification like "100" or
+ "1.3m". Returns null on error. */
+ private function get_param_byte_count(param:String, default_val:Number):Object
+ {
+ var spec:String;
+
+ spec = this.loaderInfo.parameters[param];
+ if (spec)
+ return parse_byte_count(spec);
+ else
+ return default_val;
+ }
+
/* The main logic begins here, after start-up issues are taken care of. */
private function proxy_main():void
{
@@ -411,6 +436,36 @@ package
return addr;
}
+
+ /* Parse a count of bytes. A suffix of "k", "m", or "g" (or uppercase)
+ does what you would think. Returns null on error. */
+ private static function parse_byte_count(spec:String):Object
+ {
+ const UNITS:Object = {
+ k: 1024, m: 1024 * 1024, g: 1024 * 1024 * 1024,
+ K: 1024, M: 1024 * 1024, G: 1024 * 1024 * 1024
+ };
+ var count:Number, units:Object;
+ var matches:Array;
+
+ matches = spec.match(/^(\d+(?:\.\d*)?)(\w*)$/);
+ if (matches == null)
+ return null;
+
+ count = Number(matches[1]);
+ if (isNaN(count))
+ return null;
+
+ if (matches[2] == "") {
+ units = 1;
+ } else {
+ units = UNITS[matches[2]];
+ if (units == null)
+ return null;
+ }
+
+ return count * Number(units);
+ }
}
}
More information about the tor-commits
mailing list