summaryrefslogtreecommitdiff
path: root/src/common/address.c
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2014-02-12 15:59:04 -0500
committerNick Mathewson <nickm@torproject.org>2014-02-12 16:00:26 -0500
commitecd16edafe5afbf00c5775d9f41457d4b015dc2c (patch)
tree51fb4f6bdc1b3194913e82c93d7e5d158e2e4d29 /src/common/address.c
parent2c0088b8aa360c8dfa4c38c45d50542fa9aae8fb (diff)
downloadtor-ecd16edafe5afbf00c5775d9f41457d4b015dc2c.tar.gz
tor-ecd16edafe5afbf00c5775d9f41457d4b015dc2c.zip
Disallow "*/maskbits" as an address pattern.
Fixes bug 7484. We've had this bug back in a8eaa79e031ee04d44 in 0.0.2pre14, when we first started allowing address masks.
Diffstat (limited to 'src/common/address.c')
-rw-r--r--src/common/address.c5
1 files changed, 5 insertions, 0 deletions
diff --git a/src/common/address.c b/src/common/address.c
index b9f2d93154..be41cc73ac 100644
--- a/src/common/address.c
+++ b/src/common/address.c
@@ -714,6 +714,11 @@ tor_addr_parse_mask_ports(const char *s,
/* XXXX_IP6 is this really what we want? */
bits = 96 + bits%32; /* map v4-mapped masks onto 96-128 bits */
}
+ if (any_flag) {
+ log_warn(LD_GENERAL,
+ "Found bit prefix with wildcard address; rejecting");
+ goto err;
+ }
} else { /* pick an appropriate mask, as none was given */
if (any_flag)
bits = 0; /* This is okay whether it's V6 or V4 (FIX V4-mapped V6!) */