diff options
author | Nick Mathewson <nickm@torproject.org> | 2008-11-09 16:54:54 +0000 |
---|---|---|
committer | Nick Mathewson <nickm@torproject.org> | 2008-11-09 16:54:54 +0000 |
commit | 13e079f9ec3ea937730fd83ea75c96f7bb49f42b (patch) | |
tree | 72e95b0c215f1127a6671b184b7522fec6ce172a /src | |
parent | dcfbd1e024d732ff11d62751a44692f0b3c105d1 (diff) | |
download | tor-13e079f9ec3ea937730fd83ea75c96f7bb49f42b.tar.gz tor-13e079f9ec3ea937730fd83ea75c96f7bb49f42b.zip |
Log a little more when credential-switching fails.
svn:r17228
Diffstat (limited to 'src')
-rw-r--r-- | src/common/compat.c | 26 |
1 files changed, 14 insertions, 12 deletions
diff --git a/src/common/compat.c b/src/common/compat.c index 763a7c95b8..42d1754ee1 100644 --- a/src/common/compat.c +++ b/src/common/compat.c @@ -1052,32 +1052,32 @@ switch_id(const char *user) /* Properly switch egid,gid,euid,uid here or bail out */ if (setgroups(1, &pw->pw_gid)) { - log_warn(LD_GENERAL, "Error setting configured groups: %s", - strerror(errno)); + log_warn(LD_GENERAL, "Error setting groups to gid %d: %s", + (int)pw->pw_gid, strerror(errno)); return -1; } if (setegid(pw->pw_gid)) { - log_warn(LD_GENERAL, "Error setting configured egid: %s", - strerror(errno)); + log_warn(LD_GENERAL, "Error setting egid to %d: %s", + (int)pw->pw_gid, strerror(errno)); return -1; } if (setgid(pw->pw_gid)) { - log_warn(LD_GENERAL, "Error setting configured gid: %s", - strerror(errno)); + log_warn(LD_GENERAL, "Error setting gid to %d: %s", + (int)pw->pw_gid, strerror(errno)); return -1; } if (setuid(pw->pw_uid)) { - log_warn(LD_GENERAL, "Error setting configured uid: %s", - strerror(errno)); + log_warn(LD_GENERAL, "Error setting configured uid to %s (%d): %s", + user, (int)pw->pw_uid, strerror(errno)); return -1; } if (seteuid(pw->pw_uid)) { - log_warn(LD_GENERAL, "Error setting configured euid: %s", - strerror(errno)); + log_warn(LD_GENERAL, "Error setting configured euid to %s (%d): %s", + user, (int)pw->pw_uid, strerror(errno)); return -1; } @@ -1103,14 +1103,16 @@ switch_id(const char *user) /* Try changing GID/EGID */ if (pw->pw_gid != old_gid && (setgid(old_gid) != -1 || setegid(old_gid) != -1)) { - log_warn(LD_GENERAL, "Was able to restore group credentials"); + log_warn(LD_GENERAL, "Was able to restore group credentials even after " + "switching GID: this means that the setgid code didn't work."); return -1; } /* Try changing UID/EUID */ if (pw->pw_uid != old_uid && (setuid(old_uid) != -1 || seteuid(old_uid) != -1)) { - log_warn(LD_GENERAL, "Was able to restore user credentials"); + log_warn(LD_GENERAL, "Was able to restore user credentials even after " + "switching UID: this means that the setuid code didn't work."); return -1; } } |