aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRoger Dingledine <arma@torproject.org>2003-11-20 17:49:45 +0000
committerRoger Dingledine <arma@torproject.org>2003-11-20 17:49:45 +0000
commit975bb680106f58bc1fced05a932f452e661e0157 (patch)
tree878045d9301df8eca9aaa957fd0134d14e963aff
parent84fffd3652edf6381a487d5b3b08023e39dab763 (diff)
downloadtor-975bb680106f58bc1fced05a932f452e661e0157.tar.gz
tor-975bb680106f58bc1fced05a932f452e661e0157.zip
simplify: options.OnionRouter==1 iff options.ORPort>0
svn:r857
-rw-r--r--src/or/circuit.c2
-rw-r--r--src/or/config.c21
-rw-r--r--src/or/connection_or.c4
-rw-r--r--src/or/directory.c2
-rw-r--r--src/or/main.c12
-rw-r--r--src/or/onion.c7
-rw-r--r--src/or/or.h1
7 files changed, 18 insertions, 31 deletions
diff --git a/src/or/circuit.c b/src/or/circuit.c
index 0455b8d274..3a352f9c43 100644
--- a/src/or/circuit.c
+++ b/src/or/circuit.c
@@ -748,7 +748,7 @@ int circuit_establish_circuit(void) {
if(!n_conn || n_conn->state != OR_CONN_STATE_OPEN) { /* not currently connected */
circ->n_addr = firsthop->addr;
circ->n_port = firsthop->or_port;
- if(options.OnionRouter) { /* we would be connected if he were up. but he's not. */
+ if(options.ORPort) { /* we would be connected if he were up. and he's not. */
log_fn(LOG_INFO,"Route's firsthop isn't connected.");
circuit_close(circ);
return -1;
diff --git a/src/or/config.c b/src/or/config.c
index 423fa40451..36eed86536 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -182,7 +182,6 @@ static void config_assign(or_options_t *options, struct config_line *list) {
config_compare(list, "ORPort", CONFIG_TYPE_INT, &options->ORPort) ||
config_compare(list, "ORBindAddress", CONFIG_TYPE_STRING, &options->ORBindAddress) ||
- config_compare(list, "OnionRouter", CONFIG_TYPE_BOOL, &options->OnionRouter) ||
config_compare(list, "PidFile", CONFIG_TYPE_STRING, &options->PidFile) ||
config_compare(list, "PathlenCoinWeight",CONFIG_TYPE_DOUBLE, &options->PathlenCoinWeight) ||
@@ -283,7 +282,6 @@ int getconfig(int argc, char **argv, or_options_t *options) {
static int backup_argc;
char *previous_pidfile = NULL;
int previous_runasdaemon = 0;
- int previous_onionrouter = -1;
if(first_load) { /* first time we're called. save commandline args */
backup_argv = argv;
@@ -296,7 +294,6 @@ int getconfig(int argc, char **argv, or_options_t *options) {
/* record some previous values, so we can fail if they change */
previous_pidfile = tor_strdup(options->PidFile);
previous_runasdaemon = options->RunAsDaemon;
- previous_onionrouter = options->OnionRouter;
free_options(options);
}
init_options(options);
@@ -349,11 +346,6 @@ int getconfig(int argc, char **argv, or_options_t *options) {
log_fn(LOG_WARN,"During reload, change from RunAsDaemon=1 to =0 not allowed. Failing.");
return -1;
}
- if(previous_onionrouter >= 0 && previous_onionrouter != options->OnionRouter) {
- log_fn(LOG_WARN,"During reload, OnionRouter changed from %d to %d. Failing.",
- previous_onionrouter, options->OnionRouter);
- return -1;
- }
if(options->LogLevel) {
if(!strcmp(options->LogLevel,"err"))
@@ -380,18 +372,13 @@ int getconfig(int argc, char **argv, or_options_t *options) {
result = -1;
}
- if(options->OnionRouter && options->ORPort == 0) {
- log(LOG_WARN,"If OnionRouter is set, then ORPort must be positive.");
- result = -1;
- }
-
- if(options->OnionRouter && options->DataDirectory == NULL) {
- log(LOG_WARN,"DataDirectory option required for OnionRouter, but not found.");
+ if(options->ORPort && options->DataDirectory == NULL) {
+ log(LOG_WARN,"DataDirectory option required if ORPort is set, but not found.");
result = -1;
}
- if(options->OnionRouter && options->Nickname == NULL) {
- log_fn(LOG_WARN,"Nickname required for OnionRouter, but not found.");
+ if(options->ORPort && options->Nickname == NULL) {
+ log_fn(LOG_WARN,"Nickname required if ORPort is set, but not found.");
result = -1;
}
diff --git a/src/or/connection_or.c b/src/or/connection_or.c
index 8ba16a9195..212453411b 100644
--- a/src/or/connection_or.c
+++ b/src/or/connection_or.c
@@ -186,7 +186,7 @@ static int connection_tls_finish_handshake(connection_t *conn) {
connection_watch_events(conn, POLLIN);
log_fn(LOG_DEBUG,"tls handshake done. verifying.");
if (! tor_tls_peer_has_cert(conn->tls)) { /* It's an OP. */
- if (options.OnionRouter) { /* I'm an OR; good. */
+ if (options.ORPort) { /* I'm an OR; good. */
conn->receiver_bucket = conn->bandwidth = DEFAULT_BANDWIDTH_OP;
return 0;
} else { /* Neither side sent a certificate: ouch. */
@@ -236,7 +236,7 @@ static int connection_tls_finish_handshake(connection_t *conn) {
nickname, conn->nickname);
return -1;
}
- if (!options.OnionRouter) { /* If I'm an OP... */
+ if (!options.ORPort) { /* If I'm an OP... */
conn->receiver_bucket = conn->bandwidth = DEFAULT_BANDWIDTH_OP;
circuit_n_conn_open(conn); /* send the pending creates, if any. */
}
diff --git a/src/or/directory.c b/src/or/directory.c
index 258b0b548e..2c7cdf7255 100644
--- a/src/or/directory.c
+++ b/src/or/directory.c
@@ -125,7 +125,7 @@ int connection_dir_process_inbuf(connection_t *conn) {
} else {
log_fn(LOG_INFO,"updated routers.");
}
- if(options.OnionRouter) { /* connect to them all */
+ if(options.ORPort) { /* connect to them all */
router_retry_connections();
}
return -1;
diff --git a/src/or/main.c b/src/or/main.c
index 52242653f4..1e82ed1493 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -292,7 +292,7 @@ static void run_connection_housekeeping(int i, time_t now) {
return;
if(now >= conn->timestamp_lastwritten + options.KeepalivePeriod) {
- if((!options.OnionRouter && !circuit_get_by_conn(conn)) ||
+ if((!options.ORPort && !circuit_get_by_conn(conn)) ||
(!connection_state_is_open(conn))) {
/* we're an onion proxy, with no circuits; or our handshake has expired. kill it. */
log_fn(LOG_INFO,"Expiring connection to %d (%s:%d).",
@@ -322,7 +322,7 @@ static void run_scheduled_events(time_t now) {
* our descriptor (if any). */
if(time_to_fetch_directory < now) {
/* it's time to fetch a new directory and/or post our descriptor */
- if(options.OnionRouter) {
+ if(options.ORPort) {
router_rebuild_descriptor();
router_upload_desc_to_dirservers();
}
@@ -485,7 +485,7 @@ static int init_keys(void)
crypto_pk_env_t *prkey;
/* OP's don't need keys. Just initialize the TLS context.*/
- if (!options.OnionRouter) {
+ if (!options.ORPort) {
assert(!options.DirPort);
if (tor_tls_context_new(NULL, 0, NULL)<0) {
log_fn(LOG_ERR, "Error creating TLS context for OP.");
@@ -652,7 +652,7 @@ static int do_main_loop(void) {
return -1;
}
- if(options.OnionRouter) {
+ if(options.ORPort) {
cpu_init(); /* launch cpuworkers. Need to do this *after* we've read the onion key. */
router_upload_desc_to_dirservers(); /* upload our descriptor to all dirservers */
}
@@ -674,7 +674,7 @@ static int do_main_loop(void) {
please_dumpstats = 0;
}
if(please_reset) {
- log_fn(LOG_INFO,"Hupped. Reloading config.");
+ log_fn(LOG_WARN,"Received sighup. Reloading config.");
/* first, reload config variables, in case they've changed */
if (init_from_config(0, NULL) < 0) {
/* no need to provide argc/v, they've been cached inside init_from_config */
@@ -828,7 +828,7 @@ int tor_main(int argc, char *argv[]) {
if (init_from_config(argc,argv) < 0)
return -1;
- if(options.OnionRouter) { /* only spawn dns handlers if we're a router */
+ if(options.ORPort) { /* only spawn dns handlers if we're a router */
dns_init(); /* initialize the dns resolve tree, and spawn workers */
}
if(options.SocksPort) {
diff --git a/src/or/onion.c b/src/or/onion.c
index 5cb8c42d89..ebda1f4f74 100644
--- a/src/or/onion.c
+++ b/src/or/onion.c
@@ -386,7 +386,7 @@ static int count_acceptable_routers(routerinfo_t **rarray, int rarray_len) {
log_fn(LOG_DEBUG,"Nope, the directory says %d is not running.",i);
goto next_i_loop;
}
- if(options.OnionRouter) {
+ if(options.ORPort) {
conn = connection_exact_get_by_addr_port(rarray[i]->addr, rarray[i]->or_port);
if(!conn || conn->type != CONN_TYPE_OR || conn->state != OR_CONN_STATE_OPEN) {
log_fn(LOG_DEBUG,"Nope, %d is not connected.",i);
@@ -457,6 +457,7 @@ int onion_extend_cpath(crypt_path_t **head_ptr, cpath_build_state_t *state, rout
return -1;
}
start:
+ /* XXX through each of these, don't pick nodes that are down */
if(cur_len == 0) { /* picking entry node */
log_fn(LOG_DEBUG, "Contemplating first hop: random choice.");
choice = rarray[crypto_pseudo_rand_int(rarray_len)];
@@ -474,7 +475,7 @@ int onion_extend_cpath(crypt_path_t **head_ptr, cpath_build_state_t *state, rout
!strcasecmp(choice->nickname, state->chosen_exit)) {
goto again;
}
-
+
for (i = 0, cpath = *head_ptr; i < cur_len; ++i, cpath=cpath->next) {
r = router_get_by_addr_port(cpath->addr, cpath->port);
if ((r && !crypto_pk_cmp_keys(r->onion_pkey, choice->onion_pkey))
@@ -482,7 +483,7 @@ int onion_extend_cpath(crypt_path_t **head_ptr, cpath_build_state_t *state, rout
!strcasecmp(choice->nickname, state->chosen_exit))
|| (cpath->addr == choice->addr &&
cpath->port == choice->or_port)
- || (options.OnionRouter &&
+ || (options.ORPort &&
!(connection_twin_get_by_addr_port(choice->addr,
choice->or_port)))) {
goto again;
diff --git a/src/or/or.h b/src/or/or.h
index b677d2d955..38ec73b30c 100644
--- a/src/or/or.h
+++ b/src/or/or.h
@@ -451,7 +451,6 @@ typedef struct {
int SocksPort;
int DirPort;
int MaxConn;
- int OnionRouter;
int TrafficShaping;
int LinkPadding;
int IgnoreVersion;