[tor-commits] [tor/master] When ReloadTorrcOnSIGHUP=1, do non-reload activities anyway
nickm at torproject.org
nickm at torproject.org
Wed May 16 14:40:28 UTC 2012
commit b41dd8069f25ef6f6fdb22088291e23e0442476e
Author: Nick Mathewson <nickm at torproject.org>
Date: Wed Apr 11 14:47:42 2012 -0400
When ReloadTorrcOnSIGHUP=1, do non-reload activities anyway
Previously, we skipped everything that got invoked from
options_init_from_torrc. But some of the stuff in
options_act_reversible and options_act is actually important, like
reopening the logs.
Now, a SIGHUP always makes the effects of an options_set() happen,
even though the options haven't changed.
Fix for bug 5095; bugfix on 0.2.1.9-alpha, which introduced
__ReloadTorrcOnSIGHUP.
---
changes/bug5095 | 4 ++++
src/or/config.c | 6 ++++--
src/or/main.c | 8 ++++++++
3 files changed, 16 insertions(+), 2 deletions(-)
diff --git a/changes/bug5095 b/changes/bug5095
new file mode 100644
index 0000000..81801ec
--- /dev/null
+++ b/changes/bug5095
@@ -0,0 +1,4 @@
+ o Minor bugfixes:
+ - When we receive a SIGHUP and the controller-use __ReloadTorrcOnSIGHUP
+ option is set to 0, perform other actions that SIGHUP usually causes
+ (like reopening the logs). Fixes bug 5095; bugfix on 0.2.1.9-alpha.
diff --git a/src/or/config.c b/src/or/config.c
index dcc57f8..27aa8a2 100644
--- a/src/or/config.c
+++ b/src/or/config.c
@@ -748,7 +748,7 @@ set_options(or_options_t *new_val, char **msg)
}
/* Issues a CONF_CHANGED event to notify controller of the change. If Tor is
* just starting up then the old_options will be undefined. */
- if (old_options) {
+ if (old_options && old_options != global_options) {
elements = smartlist_new();
for (i=0; options_format.vars[i].name; ++i) {
const config_var_t *var = &options_format.vars[i];
@@ -774,7 +774,9 @@ set_options(or_options_t *new_val, char **msg)
control_event_conf_changed(elements);
smartlist_free(elements);
}
- config_free(&options_format, old_options);
+
+ if (old_options != global_options)
+ config_free(&options_format, old_options);
return 0;
}
diff --git a/src/or/main.c b/src/or/main.c
index 9022f2e..8308b3a 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -1773,8 +1773,16 @@ do_hup(void)
}
options = get_options(); /* they have changed now */
} else {
+ char *msg = NULL;
log_notice(LD_GENERAL, "Not reloading config file: the controller told "
"us not to.");
+ /* Make stuff get rescanned, reloaded, etc. */
+ if (set_options((or_options_t*)options, &msg) < 0) {
+ if (!msg)
+ msg = tor_strdup("Unknown error");
+ log_warn(LD_GENERAL, "Unable to re-set previous options: %s", msg);
+ tor_free(msg);
+ }
}
if (authdir_mode_handles_descs(options, -1)) {
/* reload the approved-routers file */
More information about the tor-commits
mailing list