summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorNick Mathewson <nickm@torproject.org>2008-11-09 16:54:54 +0000
committerNick Mathewson <nickm@torproject.org>2008-11-09 16:54:54 +0000
commit13e079f9ec3ea937730fd83ea75c96f7bb49f42b (patch)
tree72e95b0c215f1127a6671b184b7522fec6ce172a /src
parentdcfbd1e024d732ff11d62751a44692f0b3c105d1 (diff)
downloadtor-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.c26
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;
}
}