Skip site navigation (1)Skip section navigation (2)
Date:      Fri, 14 May 2004 17:25:16 -0700 (PDT)
From:      Julian Elischer <julian@elischer.org>
To:        FreeBSD current users <current@FreeBSD.ORG>
Subject:   jail and chflags [patch]
Message-ID:  <Pine.BSF.4.21.0405141637420.85816-100000@InterJet.elischer.org>

next in thread | raw e-mail | index | archive | help

I have several situations where I use jails, but I also need to allow 
processes to do 'chflags'. 
I trust these jailed processes, as I'm using jails to allow different
versions of the same software to run, rather than to isolate untrusted
users from each other...

More confusingly it seems that chflags IS allowed in -current jails
despite the fact that teh comments say they are not..

At the bottom is a patch I propose (releative to 4.8 which I 
use in production) for allowing a sysctl that decides whether
chflags is permitted in a jail..

However, in -current the same code is:
                /*
                 * Unprivileged processes and privileged processes in
                 * jail() are not permitted to unset system flags, or
                 * modify flags if any system flags are set.
                 * Privileged non-jail processes may not modify system flags
                 * if securelevel > 0 and any existing system flags are set.
                 */
                if (!suser_cred(cred, PRISON_ROOT)) {
                        if (ip->i_flags
                            & (SF_NOUNLINK | SF_IMMUTABLE | SF_APPEND)) {
                                error = securelevel_gt(cred, 0);
                                if (error)
                                        return (error);
                        }
[...]
		} else {
[...]

which to me is confusing because suser_cred(cred, PRISON_ROOT)
should return 0 for a jailed root and thus allow it...
despite what the coment says.
"man 9 suser" says that the PRISON_ROOT flag should be used to ALLOW
root privs in a jail. (and the code seems to agree)

in fact experimentation in -current shows this to be correct..
in a jail:

xxx#  chflags noschg libthr.so.1
xxx# ls -lo libthr.so.1
-r--r--r--  1 root  wheel  - 611568 May 15 00:02 libthr.so.1
xxx# chflags schg libthr.so.1
xxx# ls -lo libthr.so.1
-r--r--r--  1 root  wheel  schg 611568 May 15 00:02 libthr.so.1
xxx#  

comments? yeahs? neys?



julian


Index: sys/ufs/ufs/ufs_vnops.c
===================================================================
RCS file: /repos/projects/mirrored/freebsd/src/sys/ufs/ufs/ufs_vnops.c,v
retrieving revision 1.131.2.8
diff -u -r1.131.2.8 ufs_vnops.c
--- sys/ufs/ufs/ufs_vnops.c     2003/01/02 17:26:19     1.131.2.8
+++ sys/ufs/ufs/ufs_vnops.c     2004/05/14 23:36:20
@@ -57,6 +57,7 @@
 #include <sys/malloc.h>
 #include <sys/dirent.h>
 #include <sys/lockf.h>
+#include <sys/sysctl.h>
 #include <sys/event.h>
 #include <sys/conf.h>
 
@@ -426,6 +427,11 @@
        return (0);
 }
 
+SYSCTL_DECL(_vfs_ufs);
+static int ufs_jail_flags = 0;
+SYSCTL_INT(_vfs_ufs, OID_AUTO, jail_flags, CTLFLAG_RW, &ufs_jail_flags,
+    0, "allow chflags in a jail");
+
 /*
  * Set attribute vnode op. called from several syscalls
  */
@@ -460,7 +466,8 @@
                if (cred->cr_uid != ip->i_uid &&
                    (error = suser_xxx(cred, p, PRISON_ROOT)))
                        return (error);
-               if ((cred->cr_uid == 0) && (p->p_prison == NULL)) {
+               if ((cred->cr_uid == 0) && ((p->p_prison == NULL) ||
+                   (ufs_jail_flags != 0))) {
                        if ((ip->i_flags
                            & (SF_NOUNLINK | SF_IMMUTABLE |
SF_APPEND)) &&
                            securelevel > 0)





Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?Pine.BSF.4.21.0405141637420.85816-100000>