summaryrefslogtreecommitdiff
path: root/src/or/config.c
diff options
context:
space:
mode:
authorRobert Hogan <robert@roberthogan.net>2010-12-27 17:35:16 +0000
committerNick Mathewson <nickm@torproject.org>2011-11-30 14:08:10 -0500
commit53ce6bb52d29e80c7efd29b8604bdd680c9515ea (patch)
tree2e0f5c939c8e13549ea51e00980916ab828799e8 /src/or/config.c
parent909e9769ece9e89ad0c4bbb558a6f8247c6a62bd (diff)
downloadtor-53ce6bb52d29e80c7efd29b8604bdd680c9515ea.tar.gz
tor-53ce6bb52d29e80c7efd29b8604bdd680c9515ea.zip
Address nickm's comments at https://trac.torproject.org/projects/tor/ticket/933#comment:8
1. Only allow '*.' in MapAddress expressions. Ignore '*ample.com' and '.example.com'. This has resulted in a slight refactoring of config_register_addressmaps. 2. Add some more detail to the man page entry for AddressMap. 3. Fix initialization of a pointer to NULL rather than 0. 4. Update the unit tests to cater for the changes in 1 and test more explicitly for recursive mapping.
Diffstat (limited to 'src/or/config.c')
-rw-r--r--src/or/config.c62
1 files changed, 38 insertions, 24 deletions
diff --git a/src/or/config.c b/src/or/config.c
index 1744b84c48..1d42413c16 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -4461,33 +4461,47 @@ config_register_addressmaps(const or_options_t *options)
for (opt = options->AddressMap; opt; opt = opt->next) {
smartlist_split_string(elts, opt->value, NULL,
SPLIT_SKIP_SPACE|SPLIT_IGNORE_BLANK, 2);
- if (smartlist_len(elts) >= 2) {
- from = smartlist_get(elts,0);
- to = smartlist_get(elts,1);
-
- /* Remove leading asterisk in expressions of type: '*.example.com' */
- if (from[0] == '*' && strlen(from) > 1)
- from++;
- if (to[0] == '*' && strlen(to) > 1)
- to++;
- if (to[0] == '.' && from[0] != '.') {
- log_warn(LD_CONFIG,
- "Skipping invalid argument '%s' to MapAddress: "
- "can only use wildcard (i.e. '.' or '*.') if 'from' address "
- "uses wildcard also", to);
- } else if (address_is_invalid_destination(to, 1)) {
- log_warn(LD_CONFIG,
- "Skipping invalid argument '%s' to MapAddress", to);
- } else {
- addressmap_register(from, tor_strdup(to), 0, ADDRMAPSRC_TORRC);
- if (smartlist_len(elts)>2) {
- log_warn(LD_CONFIG,"Ignoring extra arguments to MapAddress.");
- }
- }
- } else {
+ if (smartlist_len(elts) < 2) {
log_warn(LD_CONFIG,"MapAddress '%s' has too few arguments. Ignoring.",
opt->value);
+ goto cleanup;
+ }
+
+ from = smartlist_get(elts,0);
+ to = smartlist_get(elts,1);
+
+ if (to[0] == '.' || from[0] == '.') {
+ log_warn(LD_CONFIG,"MapAddress '%s' is ambiguous - address starts with a"
+ "'.'. Ignoring.",opt->value);
+ goto cleanup;
+ }
+
+ /* Remove leading asterisk in expressions of type: '*.example.com' */
+ if (!strncmp(from,"*.",2))
+ from++;
+ if (!strncmp(to,"*.",2))
+ to++;
+
+ if (to[0] == '.' && from[0] != '.') {
+ log_warn(LD_CONFIG,
+ "Skipping invalid argument '%s' to MapAddress: "
+ "can only use wildcard (i.e. '*.') if 'from' address "
+ "uses wildcard also", to);
+ goto cleanup;
+ }
+
+ if (address_is_invalid_destination(to, 1)) {
+ log_warn(LD_CONFIG,
+ "Skipping invalid argument '%s' to MapAddress", to);
+ goto cleanup;
}
+
+ addressmap_register(from, tor_strdup(to), 0, ADDRMAPSRC_TORRC);
+
+ if (smartlist_len(elts) > 2)
+ log_warn(LD_CONFIG,"Ignoring extra arguments to MapAddress.");
+
+ cleanup:
SMARTLIST_FOREACH(elts, char*, cp, tor_free(cp));
smartlist_clear(elts);
}