53 lines
1.3 KiB
Plaintext
53 lines
1.3 KiB
Plaintext
|
#!/bin/sh
|
||
|
|
||
|
set -e
|
||
|
|
||
|
cd $(dirname $0)
|
||
|
|
||
|
. ../../common/config.sh
|
||
|
. ../../common/log.sh
|
||
|
|
||
|
log_start "$0" "setup uid mapping when primary groups don't match"
|
||
|
|
||
|
save_config
|
||
|
|
||
|
unpriv_userns=$( sysctl -n kernel.unprivileged_userns_clone )
|
||
|
|
||
|
# restore the files on exit
|
||
|
trap 'log_status "$0" "FAILURE"; restore_config; \
|
||
|
rm -rf /tmp/test-uidmap; \
|
||
|
sysctl -q kernel.unprivileged_userns_clone=$unpriv_userns' 0
|
||
|
|
||
|
change_config
|
||
|
|
||
|
sysctl -q kernel.unprivileged_userns_clone=1
|
||
|
|
||
|
echo -n "Create world writable tmp directory..."
|
||
|
mkdir -m 0777 /tmp/test-uidmap
|
||
|
echo "OK"
|
||
|
|
||
|
echo -n "setup uidmapping... "
|
||
|
runuser foo -g foo -c "unshare -U sleep 10 & pid=\$!; \
|
||
|
newuidmap \$pid 0 1000 1 1 1000000 1000; ret=\$?; \
|
||
|
cat /proc/\$pid/uid_map >/tmp/test-uidmap/uid_map;
|
||
|
kill \$pid; exit \$ret"
|
||
|
../../common/compare_file.pl /tmp/test-uidmap/uid_map data/uid_map
|
||
|
echo "OK"
|
||
|
|
||
|
echo -n "setup uidmapping with different primary group... "
|
||
|
runuser foo -g bar -c "unshare -U sleep 10 & pid=\$!; \
|
||
|
newuidmap \$pid 0 1000 1 1 1000000 1000; ret=\$?; \
|
||
|
cat /proc/\$pid/uid_map >/tmp/test-uidmap/uid_map;
|
||
|
kill \$pid; exit \$ret"
|
||
|
../../common/compare_file.pl /tmp/test-uidmap/uid_map data/uid_map
|
||
|
echo "OK"
|
||
|
|
||
|
log_status "$0" "SUCCESS"
|
||
|
|
||
|
sysctl -q kernel.unprivileged_userns_clone=$unpriv_userns
|
||
|
rm -rf /tmp/test-uidmap;
|
||
|
|
||
|
restore_config
|
||
|
trap '' 0
|
||
|
|