]> git.ipfire.org Git - thirdparty/coreutils.git/commitdiff
id: fail when getuid, getgid, etc. fail, e.g., on GNU/Hurd
authorLudovic Courtès <ludo@gnu.org>
Sat, 12 Nov 2011 00:25:45 +0000 (01:25 +0100)
committerJim Meyering <meyering@redhat.com>
Mon, 14 Nov 2011 08:52:42 +0000 (09:52 +0100)
POSIX-conforming getuid, geteuid, etc. functions cannot fail,
but on GNU/Hurd systems and some others, they may.
* src/id.c (main) [__GNU__]: Detect and diagnose any such failure.
* tests/id/gnu-zero-uids: New file.
* tests/Makefile.am (TESTS): Add it to the list.
* tests/init.cfg (require_gnu_): New function.

src/id.c
tests/Makefile.am
tests/id/gnu-zero-uids [new file with mode: 0755]
tests/init.cfg

index cfbaa296c43ddc8192b9259608136af6a0871f75..047e40b8874c1d6fd5aa090627491b5dd1660e25 100644 (file)
--- a/src/id.c
+++ b/src/id.c
   proper_name ("Arnold Robbins"), \
   proper_name ("David MacKenzie")
 
+/* Whether the functions getuid, geteuid, getgid and getegid may fail.  */
+#ifdef __GNU__
+# define GETID_MAY_FAIL 1
+#else
+# define GETID_MAY_FAIL 0
+#endif
+
 /* If nonzero, output only the SELinux context. -Z */
 static int just_context = 0;
 
@@ -202,9 +209,22 @@ main (int argc, char **argv)
   else
     {
       euid = geteuid ();
+      if (GETID_MAY_FAIL && euid == -1 && !use_real
+          && !just_group && !just_group_list && !just_context)
+        error (EXIT_FAILURE, errno, _("cannot get effective UID"));
+
       ruid = getuid ();
+      if (GETID_MAY_FAIL && ruid == -1 && use_real
+          && !just_group && !just_group_list && !just_context)
+        error (EXIT_FAILURE, errno, _("cannot get real UID"));
+
       egid = getegid ();
+      if (GETID_MAY_FAIL && egid == -1 && !use_real && !just_user)
+        error (EXIT_FAILURE, errno, _("cannot get effective GID"));
+
       rgid = getgid ();
+      if (GETID_MAY_FAIL && rgid == -1 && use_real && !just_user)
+        error (EXIT_FAILURE, errno, _("cannot get real GID"));
     }
 
   if (just_user)
index 64366a49156cb651b989043564f7eabcd6d35335..48c33cb9914759544319ad51aae29496e01ae0bc 100644 (file)
@@ -399,6 +399,7 @@ TESTS =                                             \
   du/slink                                     \
   du/trailing-slash                            \
   du/two-args                                  \
+  id/gnu-zero-uids                             \
   id/no-context                                        \
   install/basic-1                              \
   install/create-leading                       \
diff --git a/tests/id/gnu-zero-uids b/tests/id/gnu-zero-uids
new file mode 100755 (executable)
index 0000000..bc9043c
--- /dev/null
@@ -0,0 +1,29 @@
+#!/bin/sh
+# On GNU, `id' must fail for processes with zero UIDs.
+
+# Copyright (C) 2011 Free Software Foundation, Inc.
+
+# This program is free software: you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation, either version 3 of the License, or
+# (at your option) any later version.
+
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+
+# You should have received a copy of the GNU General Public License
+# along with this program.  If not, see <http://www.gnu.org/licenses/>.
+
+. "${srcdir=.}/init.sh"; path_prepend_ ../src
+print_ver_ id
+
+require_gnu_
+
+sush - true || skip_ "the \`sush' command does not work"
+
+# Run `id' with zero UIDs.  It should exit with a non-zero status.
+sush - id > out && fail=1
+
+Exit $fail
index 915f38a8d35ae1bc6ef268d81d09e8d213cbce75..9b05b341892568c6908d74c817fdb849a9ee5f94 100644 (file)
@@ -499,4 +499,11 @@ print_ver_()
   fi
 }
 
+# Are we running on GNU/Hurd?
+require_gnu_()
+{
+  test "$(uname)" = GNU \
+    || skip_ 'not running on GNU/Hurd'
+}
+
 sanitize_path_