diff options
author | Roger Dingledine <arma@torproject.org> | 2004-08-18 21:13:58 +0000 |
---|---|---|
committer | Roger Dingledine <arma@torproject.org> | 2004-08-18 21:13:58 +0000 |
commit | 8ddc029d07d1a2cd71d2ffb1548f7e0cbca62d90 (patch) | |
tree | 815d911db942e9805437762c2b5a31b76d9bf056 /src | |
parent | 8798238af4ed63c113a45075ad56f11a6e0b2cc1 (diff) | |
download | tor-8ddc029d07d1a2cd71d2ffb1548f7e0cbca62d90.tar.gz tor-8ddc029d07d1a2cd71d2ffb1548f7e0cbca62d90.zip |
if options.FascistFirewall but none are running on port 80, try
the others before giving up.
svn:r2293
Diffstat (limited to 'src')
-rw-r--r-- | src/or/routerlist.c | 14 |
1 files changed, 7 insertions, 7 deletions
diff --git a/src/or/routerlist.c b/src/or/routerlist.c index cda2ef5fda..d2e93ee226 100644 --- a/src/or/routerlist.c +++ b/src/or/routerlist.c @@ -20,7 +20,7 @@ extern or_options_t options; /**< command-line and config-file options */ /* static function prototypes */ static routerinfo_t * -router_pick_directory_server_impl(int requireauth, int preferothers); +router_pick_directory_server_impl(int requireauth, int requireothers, int fascistfirewall); static void mark_all_authdirservers_up(void); static int router_resolve_routerlist(routerlist_t *dir); @@ -47,15 +47,15 @@ extern int has_fetched_directory; /**< from main.c */ routerinfo_t *router_pick_directory_server(int requireauth, int requireothers) { routerinfo_t *choice; - choice = router_pick_directory_server_impl(requireauth, requireothers); + choice = router_pick_directory_server_impl(requireauth, requireothers, options.FascistFirewall); if(choice) return choice; log_fn(LOG_INFO,"No dirservers are reachable. Trying them all again."); - /* mark all authdirservers are up again */ + /* mark all authdirservers as up again */ mark_all_authdirservers_up(); /* try again */ - choice = router_pick_directory_server_impl(requireauth, requireothers); + choice = router_pick_directory_server_impl(requireauth, requireothers, 0); if(choice) return choice; @@ -71,7 +71,7 @@ routerinfo_t *router_pick_directory_server(int requireauth, int requireothers) { return NULL; } /* give it one last try */ - choice = router_pick_directory_server_impl(requireauth, requireothers); + choice = router_pick_directory_server_impl(requireauth, requireothers, 0); return choice; } @@ -79,7 +79,7 @@ routerinfo_t *router_pick_directory_server(int requireauth, int requireothers) { * it has to be a trusted server. If requireothers, it cannot be us. */ static routerinfo_t * -router_pick_directory_server_impl(int requireauth, int requireothers) +router_pick_directory_server_impl(int requireauth, int requireothers, int fascistfirewall) { int i; routerinfo_t *router; @@ -99,7 +99,7 @@ router_pick_directory_server_impl(int requireauth, int requireothers) continue; if(requireothers && router_is_me(router)) continue; - if(options.FascistFirewall) { + if(fascistfirewall) { sprintf(buf,"%d",router->dir_port); if (!smartlist_string_isin(options.FirewallPorts, buf)) continue; |