From a66039373b81679d8af3ae6da347b1ebf0aedcc2 Mon Sep 17 00:00:00 2001 From: Ben Lindstrom Date: Wed, 15 Aug 2001 23:14:49 +0000 Subject: - markus@cvs.openbsd.org 2001/08/08 18:20:15 [uidswap.c] permanently_set_uid is a noop if user is not privilegued; fixes bug on solaris; from sbi@uchicago.edu --- uidswap.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'uidswap.c') diff --git a/uidswap.c b/uidswap.c index 941d6f19..32305a7d 100644 --- a/uidswap.c +++ b/uidswap.c @@ -12,7 +12,7 @@ */ #include "includes.h" -RCSID("$OpenBSD: uidswap.c,v 1.16 2001/04/20 16:32:22 markus Exp $"); +RCSID("$OpenBSD: uidswap.c,v 1.17 2001/08/08 18:20:15 markus Exp $"); #include "log.h" #include "uidswap.h" @@ -145,6 +145,9 @@ restore_uid(void) void permanently_set_uid(struct passwd *pw) { + /* it's a no-op unless privileged */ + if (!privileged) + return; if (temporarily_use_uid_effective) fatal("restore_uid: temporarily_use_uid effective"); if (setgid(pw->pw_gid) < 0) -- cgit v1.2.3