From 2d1f3f125a165ff56121fdec1883b19426eafc0d Mon Sep 17 00:00:00 2001 From: Markus Friedl Date: Wed, 8 Aug 2001 18:20:16 +0000 Subject: permanently_set_uid is a noop if user is not privilegued; fixes bug on solaris; from sbi@uchicago.edu --- usr.bin/ssh/uidswap.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) (limited to 'usr.bin') diff --git a/usr.bin/ssh/uidswap.c b/usr.bin/ssh/uidswap.c index 39952e2b0fc..777d73c4bee 100644 --- a/usr.bin/ssh/uidswap.c +++ b/usr.bin/ssh/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" @@ -109,6 +109,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