diff options
author | Nick Mathewson <nickm@torproject.org> | 2006-01-10 20:00:20 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2006-01-10 20:00:20 +0000 |
commit | 7fc62029d4d3d7de526b7aa679b96a7da9824aa2 (patch) | |
tree | 0054e39e46b236532cbb9b27f0eb4b100941c6fe /src | |
parent | e1d1ce3da83a8cb2e4e321e6dd5f03d9e3f847ba (diff) | |
download | tor-7fc62029d4d3d7de526b7aa679b96a7da9824aa2.tar.gz tor-7fc62029d4d3d7de526b7aa679b96a7da9824aa2.zip |
Refuse to use RunAsDaemon when torrc is a relative path. Fixes bug 229.
svn:r5767
Diffstat (limited to 'src')
-rw-r--r-- | src/common/util.c | 11 | ||||
-rw-r--r-- | src/common/util.h | 1 | ||||
-rw-r--r-- | src/or/config.c | 10 |
3 files changed, 20 insertions, 2 deletions
diff --git a/src/common/util.c b/src/common/util.c index 5ef705f4fc..caa7c47675 100644 --- a/src/common/util.c +++ b/src/common/util.c @@ -1314,6 +1314,17 @@ tor_listdir(const char *dirname) return result; } +/** Return true iff <b>filename</b> is a relative path. (XXXX doesn't work on + * windows.) */ +int +path_is_relative(const char *filename) +{ + if (filename && filename[0] == '/') + return 0; + else + return 1; +} + /* ===== * Net helpers * ===== */ diff --git a/src/common/util.h b/src/common/util.h index 37327bf6cc..bb127da559 100644 --- a/src/common/util.h +++ b/src/common/util.h @@ -158,6 +158,7 @@ char *read_file_to_str(const char *filename, int bin); char *parse_line_from_str(char *line, char **key_out, char **value_out); char *expand_filename(const char *filename); struct smartlist_t *tor_listdir(const char *dirname); +int path_is_relative(const char *filename); /* Net helpers */ int is_internal_IP(uint32_t ip, int for_listening); diff --git a/src/or/config.c b/src/or/config.c index 6f0772a45d..aeff69feb0 100644 --- a/src/or/config.c +++ b/src/or/config.c @@ -1887,6 +1887,11 @@ options_validate(or_options_t *old_options, or_options_t *options) result = -1; } +#ifndef MS_WINDOWS + if (options->RunAsDaemon && torrc_fname && path_is_relative(torrc_fname)) + REJECT("Can't use a relative path to torrc when RunAsDaemon is set."); +#endif + if (options->SocksPort < 0 || options->SocksPort > 65535) REJECT("SocksPort option out of bounds."); @@ -2502,6 +2507,9 @@ options_init_from_torrc(int argc, char **argv) tor_assert(fname); log(LOG_DEBUG, LD_CONFIG, "Opening config file \"%s\"", fname); + tor_free(torrc_fname); + torrc_fname = fname; + /* get config lines, assign them */ if (file_status(fname) != FN_FILE || !(cf = read_file_to_str(fname,0))) { @@ -2543,8 +2551,6 @@ options_init_from_torrc(int argc, char **argv) if (set_options(newoptions)) goto err; /* frees and replaces old options */ - tor_free(torrc_fname); - torrc_fname = fname; return 0; err: tor_free(fname); |