diff options
author | Nick Mathewson <nickm@torproject.org> | 2011-06-30 14:01:02 -0400 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2011-07-19 01:58:43 -0400 |
commit | ddc65e2b3303559ab7b842a176ee6c2eda9e4027 (patch) | |
tree | 79acda709f16d4a8ba2dca99ad81e3c708358e17 /src/or/router.c | |
parent | 2163e420b2aea36b57a620eb4bb2ff1e7c9e966f (diff) | |
download | tor-ddc65e2b3303559ab7b842a176ee6c2eda9e4027.tar.gz tor-ddc65e2b3303559ab7b842a176ee6c2eda9e4027.zip |
Parse prop171 options; refactor listener/port option code
Proposal 171 gives us a new syntax for parsing client port options.
You can now have as many FooPort options as you want (for Foo in
Socks, Trans, DNS, NATD), and they can have address:port arguments,
and you can specify the level of isolation on those ports.
Additionally, this patch refactors the client port parsing logic to
use a new type, port_cfg_t. Previously, ports to be bound were
half-parsed in config.c, and later re-parsed in connection.c when
we're about to bind them. Now, parsing a port means converting it
into a port_cfg_t, and binding it uses only a port_cfg_t, without
needing to parse the user-provided strings at all.
We should do a related refactoring on other port types. For
control ports, that'll be easy enough. For ORPort and DirPort,
we'll want to do this when we solve proposal 118 (letting servers
bind to and advertise multiple ports).
This implements tickets 3514 and 3515.
Diffstat (limited to 'src/or/router.c')
-rw-r--r-- | src/or/router.c | 8 |
1 files changed, 3 insertions, 5 deletions
diff --git a/src/or/router.c b/src/or/router.c index eaad57bb99..531d3fb40f 100644 --- a/src/or/router.c +++ b/src/or/router.c @@ -1116,14 +1116,12 @@ set_server_advertised(int s) server_is_advertised = s; } -/** Return true iff we are trying to be a socks proxy. */ +/** Return true iff we are trying to proxy client connections. */ int proxy_mode(const or_options_t *options) { - return (options->SocksPort != 0 || - options->TransPort != 0 || - options->NATDPort != 0 || - options->DNSPort != 0); + (void)options; + return smartlist_len(get_configured_client_ports()) > 0; } /** Decide if we're a publishable server. We are a publishable server if: |