#!/bin/sh # $FreeBSD$ desc="chflags returns EPERM when one of SF_IMMUTABLE, SF_APPEND, or SF_NOUNLINK is set and securelevel is greater than 0" dir=`dirname $0` . ${dir}/../misc.sh require chflags echo "1..102" n0=`namegen` n1=`namegen` n2=`namegen` old=`sysctl -n security.jail.chflags_allowed` sysctl security.jail.chflags_allowed=1 >/dev/null expect 0 mkdir ${n0} 0755 cdir=`pwd` cd ${n0} expect 0 create ${n1} 0644 expect 0 chown ${n1} 65534 65534 for flag in SF_IMMUTABLE SF_APPEND SF_NOUNLINK; do expect 0 chflags ${n1} ${flag} jexpect 1 `pwd` EPERM chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags jexpect 1 `pwd` EPERM -u 65533 -g 65533 chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags jexpect 1 `pwd` EPERM -u 65534 -g 65534 chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags done expect 0 chflags ${n1} none expect 0 unlink ${n1} expect 0 mkdir ${n1} 0755 expect 0 chown ${n1} 65534 65534 for flag in SF_IMMUTABLE SF_APPEND SF_NOUNLINK; do expect 0 chflags ${n1} ${flag} jexpect 1 `pwd` EPERM chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags jexpect 1 `pwd` EPERM -u 65533 -g 65533 chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags jexpect 1 `pwd` EPERM -u 65534 -g 65534 chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags done expect 0 chflags ${n1} none expect 0 rmdir ${n1} expect 0 mkfifo ${n1} 0644 expect 0 chown ${n1} 65534 65534 for flag in SF_IMMUTABLE SF_APPEND SF_NOUNLINK; do expect 0 chflags ${n1} ${flag} jexpect 1 `pwd` EPERM chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags jexpect 1 `pwd` EPERM -u 65533 -g 65533 chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags jexpect 1 `pwd` EPERM -u 65534 -g 65534 chflags ${n1} UF_IMMUTABLE expect ${flag} stat ${n1} flags done expect 0 chflags ${n1} none expect 0 unlink ${n1} expect 0 symlink ${n2} ${n1} expect 0 lchown ${n1} 65534 65534 for flag in SF_IMMUTABLE SF_APPEND SF_NOUNLINK; do expect 0 lchflags ${n1} ${flag} jexpect 1 `pwd` EPERM lchflags ${n1} UF_IMMUTABLE expect ${flag} lstat ${n1} flags jexpect 1 `pwd` EPERM -u 65533 -g 65533 lchflags ${n1} UF_IMMUTABLE expect ${flag} lstat ${n1} flags jexpect 1 `pwd` EPERM -u 65534 -g 65534 lchflags ${n1} UF_IMMUTABLE expect ${flag} lstat ${n1} flags done expect 0 lchflags ${n1} none expect 0 unlink ${n1} sysctl security.jail.chflags_allowed=${old} >/dev/null cd ${cdir} expect 0 rmdir ${n0}