[tor-commits] [tor/master] Have get_parent_directory() handle "/foo" and "/" correctly.
nickm at torproject.org
nickm at torproject.org
Thu May 31 20:26:22 UTC 2012
commit 254504fc1494b1ca4eea14eb71bd5b4b5d0d2765
Author: Nick Mathewson <nickm at torproject.org>
Date: Thu May 24 12:56:31 2012 -0400
Have get_parent_directory() handle "/foo" and "/" correctly.
The parent of "/foo" is "/"; and "/" is its own parent.
This would cause Tor to fail if you tried to have a PF_UNIX control
socket in the root directory. That would be a stupid thing to do
for other reasons, but there's no reason to fail like _this_.
Bug found by Esteban Manchado Velázquez. Fix for bug 5089; bugfix on
Tor 0.2.2.26-beta. Unit test included.
---
changes/bug5089 | 5 +++++
src/common/compat.c | 13 +++++++++++--
src/test/test_util.c | 5 +++--
3 files changed, 19 insertions(+), 4 deletions(-)
diff --git a/changes/bug5089 b/changes/bug5089
new file mode 100644
index 0000000..2062885
--- /dev/null
+++ b/changes/bug5089
@@ -0,0 +1,5 @@
+ o Minor bugfixes:
+ - Correctly handle checking the permissions on the parent
+ directory of a control socket in the root directory. Bug found
+ by Esteban Manchado Velázquez. Fix for bug 5089; bugfix on Tor
+ 0.2.2.26-beta.
diff --git a/src/common/compat.c b/src/common/compat.c
index a4e5074..ffd9724 100644
--- a/src/common/compat.c
+++ b/src/common/compat.c
@@ -1481,7 +1481,11 @@ get_user_homedir(const char *username)
}
#endif
-/** Modify <b>fname</b> to contain the name of the directory */
+/** Modify <b>fname</b> to contain the name of its parent directory. Doesn't
+ * actually examine the filesystem; does a purely syntactic modification.
+ *
+ * The parent of the root director is considered to be iteself.
+ * */
int
get_parent_directory(char *fname)
{
@@ -1503,13 +1507,18 @@ get_parent_directory(char *fname)
*/
cp = fname + strlen(fname);
at_end = 1;
- while (--cp > fname) {
+ while (--cp >= fname) {
int is_sep = (*cp == '/'
#ifdef MS_WINDOWS
|| *cp == '\\'
#endif
);
if (is_sep) {
+ if (cp == fname) {
+ /* This is the first separator in the file name; don't remove it! */
+ cp[1] = '\0';
+ return 0;
+ }
*cp = '\0';
if (! at_end)
return 0;
diff --git a/src/test/test_util.c b/src/test/test_util.c
index f9a83a3..1c7c2fe 100644
--- a/src/test/test_util.c
+++ b/src/test/test_util.c
@@ -1299,11 +1299,12 @@ test_util_parent_dir(void *ptr)
T("/home/wombat/knish", 0, "/home/wombat");
T("/home/wombat/knish/", 0, "/home/wombat");
+ T("/home", 0, "/");
T("./home/wombat/knish/", 0, "./home/wombat");
T("./wombat", 0, ".");
T("", -1, "");
- T("/", -1, "");
- T("////", -1, "");
+ T("/", 0, "/");
+ T("////", 0, "/");
done:
tor_free(cp);
More information about the tor-commits
mailing list