From a0e0c6c5199c9a4a10baee14cf9f77f7b1e5b832 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Wed, 31 Mar 1999 18:09:54 +0000 Subject: [PATCH] Update. 1999-03-31 Mark Kettenis * login/programs/pt_chown.c (main): Save effective user ID before dropping priviliges and use this to check if the program is properly installed. --- ChangeLog | 6 ++++++ login/programs/pt_chown.c | 7 ++++--- 2 files changed, 10 insertions(+), 3 deletions(-) diff --git a/ChangeLog b/ChangeLog index 1dd54e8..ee77487 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,9 @@ +1999-03-31 Mark Kettenis + + * login/programs/pt_chown.c (main): Save effective user ID before + dropping priviliges and use this to check if the program is + properly installed. + 1999-03-31 Ulrich Drepper * iconvdata/testdata/CP1254: Update for charmap changes. diff --git a/login/programs/pt_chown.c b/login/programs/pt_chown.c index 4b78e34..faec86b 100644 --- a/login/programs/pt_chown.c +++ b/login/programs/pt_chown.c @@ -133,17 +133,18 @@ do_pt_chown (void) int main (int argc, char *argv[]) { + uid_t euid = geteuid (); int remaining; /* Normal invocation of this program is with no arguments and with privileges. FIXME: Should use capable (CAP_CHOWN|CAP_FOWNER). */ - if (argc == 1 && geteuid () == 0) + if (argc == 1 && euid == 0) return do_pt_chown (); /* We aren't going to be using privileges, so drop them right now. */ setuid (getuid ()); - + /* Set locale via LC_ALL. */ setlocale (LC_ALL, ""); @@ -163,7 +164,7 @@ main (int argc, char *argv[]) } /* Check if we are properly installed. */ - if (geteuid () != 0) + if (euid != 0) error (FAIL_EXEC, 0, gettext ("needs to be installed setuid `root'")); return EXIT_SUCCESS; -- 2.7.4