diff options
author | Peter Palfrader <peter@palfrader.org> | 2008-08-13 19:25:18 +0000 |
---|---|---|
committer | Peter Palfrader <peter@palfrader.org> | 2008-08-13 19:25:18 +0000 |
commit | 171a7d4b0fb4341520dcf3ef512ad74eb9a86ed0 (patch) | |
tree | 2e830fe82ddbbfc5ab43a9f8831a017c71c5f3d8 /src/or/or.h | |
parent | 864b4a009d609841043402fa1572ab13cf59e5a1 (diff) | |
download | tor-171a7d4b0fb4341520dcf3ef512ad74eb9a86ed0.tar.gz tor-171a7d4b0fb4341520dcf3ef512ad74eb9a86ed0.zip |
Fix an overflow when counting rejects for *, truncate exit summaries after 1000 chars
svn:r16530
Diffstat (limited to 'src/or/or.h')
-rw-r--r-- | src/or/or.h | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/src/or/or.h b/src/or/or.h index a01441d989..c4995f405c 100644 --- a/src/or/or.h +++ b/src/or/or.h @@ -3208,11 +3208,19 @@ download_status_is_ready(download_status_t *dls, time_t now, } /********************************* dirserv.c ***************************/ +/** Maximum length of an exit policy summary. */ +#define MAX_EXITPOLICY_SUMMARY_LEN (1000) + /** Maximum allowable length of a version line in a networkstatus. */ #define MAX_V_LINE_LEN 128 /** Length of "r Authority BadDirectory BadExit Exit Fast Guard HSDir Named * Running Stable Unnamed V2Dir Valid\n". */ #define MAX_FLAG_LINE_LEN 96 +/** Length of "w" line for weighting. Currently at most + * "w Bandwidth=<uint32t>\n" */ +#define MAX_WEIGHT_LINE_LEN (13+10) +/** Maximum length of an exit policy summary line. */ +#define MAX_POLICY_LINE_LEN (3+MAX_EXITPOLICY_SUMMARY_LEN) /** Amount of space to allocate for each entry: r, s, and v lines. */ #define RS_ENTRY_LEN \ ( /* first line */ \ @@ -3220,6 +3228,10 @@ download_status_is_ready(download_status_t *dls, time_t now, 5*2 /* ports */ + 10 /* punctuation */ + \ /* second line */ \ MAX_FLAG_LINE_LEN + \ + /* weight line */ \ + MAX_WEIGHT_LINE_LEN + \ + /* p line. */ \ + MAX_POLICY_LINE_LEN + \ /* v line. */ \ MAX_V_LINE_LEN \ ) @@ -4108,6 +4120,7 @@ routerinfo_t *router_find_exact_exit_enclave(const char *address, int router_is_unreliable(routerinfo_t *router, int need_uptime, int need_capacity, int need_guard); uint32_t router_get_advertised_bandwidth(routerinfo_t *router); +uint32_t router_get_advertised_bandwidth_capped(routerinfo_t *router); typedef enum { NO_WEIGHTING, WEIGHT_FOR_EXIT, WEIGHT_FOR_GUARD |