diff options
Diffstat (limited to 'src/feature')
-rw-r--r-- | src/feature/relay/relay_config.c | 5 | ||||
-rw-r--r-- | src/feature/relay/router.c | 15 |
2 files changed, 12 insertions, 8 deletions
diff --git a/src/feature/relay/relay_config.c b/src/feature/relay/relay_config.c index 9895485c83..8d20e97eb6 100644 --- a/src/feature/relay/relay_config.c +++ b/src/feature/relay/relay_config.c @@ -468,7 +468,6 @@ compute_publishserverdescriptor(or_options_t *options) * - "https" * - "email" * - "moat" - * - "hyphae" * * If the option string is unrecognised, a warning will be logged and 0 is * returned. If the option string contains an invalid character, -1 is @@ -481,11 +480,11 @@ check_bridge_distribution_setting(const char *bd) return 0; const char *RECOGNIZED[] = { - "none", "any", "https", "email", "moat", "hyphae" + "none", "any", "https", "email", "moat" }; unsigned i; for (i = 0; i < ARRAY_LENGTH(RECOGNIZED); ++i) { - if (!strcmp(bd, RECOGNIZED[i])) + if (!strcasecmp(bd, RECOGNIZED[i])) return 0; } diff --git a/src/feature/relay/router.c b/src/feature/relay/router.c index e547b5a553..e24e499971 100644 --- a/src/feature/relay/router.c +++ b/src/feature/relay/router.c @@ -2908,15 +2908,20 @@ router_dump_router_to_string(routerinfo_t *router, } if (options->BridgeRelay) { - const char *bd; + char *bd = NULL; + if (options->BridgeDistribution && strlen(options->BridgeDistribution)) { - bd = options->BridgeDistribution; + bd = tor_strdup(options->BridgeDistribution); } else { - bd = "any"; + bd = tor_strdup("any"); } - if (strchr(bd, '\n') || strchr(bd, '\r')) - bd = escaped(bd); + + // Make sure our value is lowercased in the descriptor instead of just + // forwarding what the user wrote in their torrc directly. + tor_strlower(bd); + smartlist_add_asprintf(chunks, "bridge-distribution-request %s\n", bd); + tor_free(bd); } if (router->onion_curve25519_pkey) { |