summaryrefslogtreecommitdiffstats
path: root/usr.sbin
diff options
context:
space:
mode:
authorpeter <peter@FreeBSD.org>1996-09-07 01:43:08 +0000
committerpeter <peter@FreeBSD.org>1996-09-07 01:43:08 +0000
commit7e1f106f1d60201fe697397cad2462f3f8b9ec68 (patch)
tree9473cf7ff18075ce63a9347953c8dae40df4e6b1 /usr.sbin
parent91405059905f25dd66e22d489907b1e7d64d903e (diff)
downloadFreeBSD-src-7e1f106f1d60201fe697397cad2462f3f8b9ec68.zip
FreeBSD-src-7e1f106f1d60201fe697397cad2462f3f8b9ec68.tar.gz
When looking for "group daemon" (since that's what's in mtree), make sure
we actually look for the *group* and not the user's gid. user daemon has traditionally been group 31 (guest). Also clear out the groups vector so that it doesn't inherit the groups of the invoking user (ever run rwhod by hand before?) Unfortunately, we can't empty the supplemental groups list because the !&@^#! egid is stored in there! :-(
Diffstat (limited to 'usr.sbin')
-rw-r--r--usr.sbin/rwhod/rwhod.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/usr.sbin/rwhod/rwhod.c b/usr.sbin/rwhod/rwhod.c
index c52b12e..c5605e2 100644
--- a/usr.sbin/rwhod/rwhod.c
+++ b/usr.sbin/rwhod/rwhod.c
@@ -66,6 +66,7 @@ static char sccsid[] = "@(#)rwhod.c 8.1 (Berkeley) 6/6/93";
#include <unistd.h>
#include <utmp.h>
#include <pwd.h>
+#include <grp.h>
/*
* This version of Berkeley's rwhod has been modified to use IP multicast
@@ -246,6 +247,7 @@ usage: fprintf(stderr, "usage: rwhod [ -m [ ttl ] ]\n");
exit(1);
}
setgid(unpriv_gid);
+ setgroups(1, &unpriv_gid); /* XXX BOGUS groups[0] = egid */
setuid(unpriv_uid);
if (!configure(s))
exit(1);
@@ -320,6 +322,7 @@ run_as(uid, gid)
gid_t *gid;
{
struct passwd *pw;
+ struct group *gr;
pw = getpwnam(UNPRIV_USER);
if (!pw) {
@@ -328,12 +331,12 @@ run_as(uid, gid)
}
*uid = pw->pw_uid;
- pw = getpwnam(UNPRIV_GROUP);
- if (!pw) {
- syslog(LOG_ERR, "getpwnam(%s): %m", UNPRIV_GROUP);
+ gr = getgrnam(UNPRIV_GROUP);
+ if (!gr) {
+ syslog(LOG_ERR, "getgrnam(%s): %m", UNPRIV_GROUP);
exit(1);
}
- *gid = pw->pw_gid;
+ *gid = gr->gr_gid;
}
/*
OpenPOWER on IntegriCloud