Here we go
This commit is contained in:
commit
bb046d1a21
9
Makefile
Executable file
9
Makefile
Executable 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
42
ezjail
Executable 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
55
ezjail-admin
Executable 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
32
ezjail.conf.sample
Executable 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"
|
||||
|
Loading…
x
Reference in New Issue
Block a user