Here we go

This commit is contained in:
erdgeist 2005-09-03 15:42:28 +00:00
commit bb046d1a21
4 changed files with 138 additions and 0 deletions

9
Makefile Executable file
View File

@ -0,0 +1,9 @@
all:
install:
sed s:EZJAIL_PREFIX:${PREFIX}: ezjail > ${PREFIX}/etc/rc.d/ezjail
chmod 755 ${PREFIX}/etc/rc.d/ezjail
sed s:EZJAIL_PREFIX:${PREFIX}: ezjail-admin > ${PREFIX}/bin/ezjail-admin
chmod 755 ${PREFIX}/bin/ezjail-admin
cp -p ezjail.conf.sample ${PREFIX}/etc/
mkdir -p ${PREFIX}/etc/ezjail/

42
ezjail Executable file
View File

@ -0,0 +1,42 @@
#/bin/sh
# $FreeBSD$
#
# PROVIDE: ezjail
#
# Note: Add the following lines to $PREFIX/etc/rc.conf to enable ezjail,
#
#ezjail_enable="YES"
#
# Please do not change this file, configure in $PREFIX/etc/ezjail.conf
# ugly: this variable will be set on port install time
ezjail_prefix=EZJAIL_PREFIX
. /etc/rc.subr
name=ezjail
ezjail_enable=${ezjail_enable:-"NO"}
rcvar=`set_rcvar`
start_cmd="do_start"
stop_cmd="do_stop"
do_start()
{
jail_enable=${ezjail_enable}
jail_list=`ls ${ezjail_prefix}/etc/ezjail/`
for jail in $jail_list; do . ${ezjail_prefix}/etc/ezjail/${jail}; done
sh /etc/rc.d/jail start $*
}
do_stop()
{
jail_enable=${ezjail_enable}
jail_list=`ls ${ezjail_prefix}/etc/ezjail/`
for jail in $jail_list; do . ${ezjail_prefix}/etc/ezjail/${jail}; done
sh /etc/rc.d/jail stop $*
}
load_rc_config $name
run_rc_command $*

55
ezjail-admin Executable file
View File

@ -0,0 +1,55 @@
#!/bin/sh
# ugly: this variable is set during port install time
ezjail_prefix=EZJAIL_PREFIX
if [ "0" != "`id -u`" ]; then
echo "Retry as root"; exit 1;
fi
exit
if [ -f ${ezjail_prefix}/etc/ezjail.conf ]; then
. ${ezjail_prefix}/etc/ezjail.conf;
fi
if [ -z "$1" ];
then echo "Syntax: $0 [create|delete|list|update] {params}"; exit;
fi
case "$1" in
create)
mkdir ${newjail_root} && cd ${ezjail_jailtemplate} \
&& find * | cpio -p -v ${newjail_root}
;;
delete)
;;
list)
;;
update)
if [ ! -d ${ezjail_sourcetree} ]; then
echo "Cannot find your copy of the FreeBSD source tree in $ezjail_sourcetree."; exit 1;
fi
cd ${ezjail_sourcetree}
rm -r ${ezjail_jailfull}; mkdir -p ${ezjail_jailfull}
make world DESTDIR=${ezjail_jailfull}
make distribution DESTDIR=${ezjail_jailfull}
cd ${ezjail_jailfull}
mkdir -p ${ezjail_jailbase}
for a in bin sbin usr/bin usr/include usr/lib usr/libexec usr/sbin usr/src usr/share; do
find ${a} | cpio -d -p -v ${ezjail_jailbase};
chflags -R noschg ${a}; rm -r ${a}; ln -s /basejail/${a} ${a}
done
mkdir basejail
if [ -d ${ezjail_jailtemplate} ]; then
mv ${ezjail_jailtemplate} ${ezjail_jailtemplate}_old
fi
mv ${ezjail_jailfull} ${ezjail_jailtemplate}
;;
esac

32
ezjail.conf.sample Executable file
View File

@ -0,0 +1,32 @@
# ezjail.conf - Example file, see ezjail(x)
#
# Note: If you alter some of those variables AFTER creating your first
# jail, you may have to adapt /etc/fstab.* and ${PREFIX}/etc/ezjail/* by
# hand
# Location of jail root directories
#
# Note: If you habe spread your jails to multiple locations, use softlinks
# to collect them in this directory
ezjail_jaildir=/usr/jails/
# Location of the tiny skeleton jail template
ezjail_jailtemplate=$ezjail_jaildir/newjail
# Location of the huge base jail
ezjail_jailbase=$ezjail_jaildir/basejail
# Location of your copy of FreeBSD's source tree
ezjail_sourcetree=/usr/src
# Default options for newly created jails
#
# Note: Be VERY careful about disabling ezjail_mount_enable. Mounting
# basejail via nullfs depends on this. You will have to find other
# ways to provide your jail with essential system files
ezjail_mount_enable="YES"
ezjail_devfs_enable="YES"
ezjail_devfs_ruleset="devfsrules_jail"
ezjail_procfs_enable="YES"
ezjail_fdescfs_enable="YES"