2014-11-09 11:04:44 +01:00
|
|
|
#!/bin/sh
|
|
|
|
|
2015-01-03 19:46:33 +01:00
|
|
|
# Copyright (c) 2014-2015 Franco Fichtner <franco@opnsense.org>
|
2014-11-09 11:04:44 +01:00
|
|
|
#
|
|
|
|
# Redistribution and use in source and binary forms, with or without
|
|
|
|
# modification, are permitted provided that the following conditions
|
|
|
|
# are met:
|
|
|
|
#
|
|
|
|
# 1. Redistributions of source code must retain the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer.
|
2014-11-09 11:06:26 +01:00
|
|
|
#
|
2014-11-09 11:04:44 +01:00
|
|
|
# 2. Redistributions in binary form must reproduce the above copyright
|
|
|
|
# notice, this list of conditions and the following disclaimer in the
|
|
|
|
# documentation and/or other materials provided with the distribution.
|
|
|
|
#
|
|
|
|
# THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
|
|
|
|
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
|
|
|
# IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
|
|
|
# ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
|
|
|
|
# FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
|
|
# DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
|
|
# OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
# HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
|
|
|
|
# LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
|
|
|
|
# OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
|
|
|
|
# SUCH DAMAGE.
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2014-11-15 21:12:09 +01:00
|
|
|
# important build settings
|
|
|
|
export PRODUCT_NAME="OPNsense"
|
2015-01-24 13:11:19 +01:00
|
|
|
export PRODUCT_VERSION=${PRODUCT_VERSION:-"`date '+%Y%m%d%H%M'`"}
|
2014-11-15 21:12:09 +01:00
|
|
|
|
2014-11-09 13:14:07 +01:00
|
|
|
# build directories
|
|
|
|
export STAGEDIR="/usr/local/stage"
|
2014-11-15 08:55:43 +01:00
|
|
|
export PACKAGESDIR="/tmp/packages"
|
2014-11-09 13:14:07 +01:00
|
|
|
export IMAGESDIR="/tmp/images"
|
|
|
|
export SETSDIR="/tmp/sets"
|
|
|
|
|
|
|
|
# code reositories
|
2014-11-15 08:55:43 +01:00
|
|
|
export TOOLSDIR="/usr/tools"
|
|
|
|
export PORTSDIR="/usr/ports"
|
2014-11-15 11:06:04 +01:00
|
|
|
export COREDIR="/usr/core"
|
2014-11-09 13:14:07 +01:00
|
|
|
export SRCDIR="/usr/src"
|
|
|
|
|
|
|
|
# misc. foo
|
2014-11-09 11:04:44 +01:00
|
|
|
export CPUS=`sysctl kern.smp.cpus | awk '{ print $2 }'`
|
2014-11-15 15:54:43 +01:00
|
|
|
export ARCH=${ARCH:-"`uname -m`"}
|
|
|
|
export TARGET_ARCH=${ARCH}
|
2015-01-12 17:50:15 +01:00
|
|
|
export TARGETARCH=${ARCH}
|
|
|
|
export LABEL="OPNsense_Install"
|
2014-11-09 11:04:44 +01:00
|
|
|
|
2014-11-15 21:12:09 +01:00
|
|
|
# target files
|
2015-02-14 11:57:00 +01:00
|
|
|
export CDROM="${IMAGESDIR}/${PRODUCT_NAME}-${PRODUCT_VERSION}-cdrom-${ARCH}.iso"
|
|
|
|
export SERIALIMG="${IMAGESDIR}/${PRODUCT_NAME}-${PRODUCT_VERSION}-serial-${ARCH}.img"
|
|
|
|
export VGAIMG="${IMAGESDIR}/${PRODUCT_NAME}-${PRODUCT_VERSION}-vga-${ARCH}.img"
|
2014-11-15 21:12:09 +01:00
|
|
|
|
2014-11-09 11:06:26 +01:00
|
|
|
# print environment to showcase all of our variables
|
2014-11-09 11:04:44 +01:00
|
|
|
env
|
|
|
|
|
|
|
|
git_clear()
|
|
|
|
{
|
|
|
|
# Reset the git repository into a known state by
|
|
|
|
# enforcing a hard-reset to HEAD (so you keep your
|
|
|
|
# selected commit, but no manual changes) and all
|
|
|
|
# unknown files are cleared (so it looks like a
|
|
|
|
# freshly cloned repository).
|
|
|
|
|
|
|
|
echo -n ">>> Resetting ${1}... "
|
|
|
|
|
|
|
|
git -C ${1} reset --hard HEAD
|
|
|
|
git -C ${1} clean -xdqf .
|
|
|
|
}
|
2014-11-09 11:15:01 +01:00
|
|
|
|
2014-12-11 15:23:35 +01:00
|
|
|
git_describe()
|
|
|
|
{
|
|
|
|
VERSION=$(git -C ${1} describe --abbrev=0)
|
|
|
|
REVISION=$(git -C ${1} rev-list ${VERSION}.. --count)
|
2014-12-20 12:14:23 +01:00
|
|
|
COMMENT=$(git -C ${1} rev-list HEAD --max-count=1 | cut -c1-9)
|
2014-12-11 15:23:35 +01:00
|
|
|
if [ "${REVISION}" != "0" ]; then
|
|
|
|
# must construct full version string manually
|
|
|
|
VERSION=${VERSION}_${REVISION}
|
|
|
|
fi
|
|
|
|
|
|
|
|
export REPO_VERSION=${VERSION}
|
|
|
|
export REPO_COMMENT=${COMMENT}
|
|
|
|
}
|
|
|
|
|
2014-12-28 11:01:40 +01:00
|
|
|
setup_clone()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up ${2} in ${1}"
|
|
|
|
|
2015-01-07 06:56:10 +01:00
|
|
|
# repositories may be huge so avoid the copy :)
|
|
|
|
mkdir -p ${1}${2} && mount_unionfs -o below ${2} ${1}${2}
|
2014-12-28 11:01:40 +01:00
|
|
|
}
|
|
|
|
|
2014-12-20 22:34:42 +01:00
|
|
|
setup_chroot()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up chroot in ${1}"
|
|
|
|
|
|
|
|
cp /etc/resolv.conf ${1}/etc
|
|
|
|
mount -t devfs devfs ${1}/dev
|
|
|
|
chroot ${1} /etc/rc.d/ldconfig start
|
|
|
|
}
|
|
|
|
|
2014-11-09 13:14:07 +01:00
|
|
|
setup_base()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up world in ${1}"
|
|
|
|
|
2015-03-09 08:01:50 +01:00
|
|
|
# /home is needed for LiveCD images, and since it
|
|
|
|
# belongs to the base system, we create it from here.
|
2014-11-15 11:29:03 +01:00
|
|
|
mkdir -p ${1}/home
|
|
|
|
|
2015-01-03 18:54:57 +01:00
|
|
|
(cd ${1} && tar -Jxpf ${SETSDIR}/base-*-${ARCH}.txz)
|
2014-11-09 13:14:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
setup_kernel()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up kernel in ${1}"
|
|
|
|
|
2015-01-03 18:54:57 +01:00
|
|
|
(cd ${1} && tar -Jxpf ${SETSDIR}/kernel-*-${ARCH}.txz)
|
2014-11-09 13:14:07 +01:00
|
|
|
}
|
|
|
|
|
2014-11-15 10:55:32 +01:00
|
|
|
setup_packages()
|
|
|
|
{
|
|
|
|
echo ">>> Setting up packages in ${1}..."
|
|
|
|
|
2014-12-23 18:36:52 +01:00
|
|
|
BASEDIR=${1}
|
|
|
|
shift
|
|
|
|
PKGLIST=${@}
|
|
|
|
|
2015-01-03 20:12:59 +01:00
|
|
|
mkdir -p ${PACKAGESDIR}/${ARCH} ${BASEDIR}${PACKAGESDIR}/${ARCH}
|
|
|
|
cp ${PACKAGESDIR}/${ARCH}/* ${BASEDIR}${PACKAGESDIR}/${ARCH} || true
|
2014-12-23 18:36:52 +01:00
|
|
|
|
|
|
|
if [ -z "${PKGLIST}" ]; then
|
|
|
|
# forcefully add all available packages
|
2015-01-03 20:12:59 +01:00
|
|
|
pkg -c ${BASEDIR} add -f ${PACKAGESDIR}/${ARCH}/*.txz || true
|
2014-12-23 18:36:52 +01:00
|
|
|
else
|
|
|
|
# always bootstrap pkg
|
|
|
|
PKGLIST="pkg ${PKGLIST}"
|
|
|
|
|
|
|
|
for PKG in ${PKGLIST}; do
|
|
|
|
# must fail if packages aren't there
|
2015-01-03 20:12:59 +01:00
|
|
|
pkg -c ${BASEDIR} add ${PACKAGESDIR}/${ARCH}/${PKG}-*.txz
|
2014-12-23 18:36:52 +01:00
|
|
|
done
|
2015-02-19 08:38:53 +01:00
|
|
|
|
|
|
|
# collect all installed packages
|
|
|
|
PKGLIST="$(pkg -c ${BASEDIR} query %n)"
|
|
|
|
|
|
|
|
for PKG in ${PKGLIST}; do
|
|
|
|
# add, unlike install, is not aware of repositories :(
|
2015-02-23 23:12:56 +01:00
|
|
|
pkg -c ${BASEDIR} annotate -qyA ${PKG} repository OPNsense
|
2015-02-19 08:38:53 +01:00
|
|
|
done
|
2014-12-23 18:36:52 +01:00
|
|
|
fi
|
2014-11-15 10:55:32 +01:00
|
|
|
|
2015-01-03 20:04:44 +01:00
|
|
|
# keep the directory!
|
2015-01-03 20:12:59 +01:00
|
|
|
rm -rf ${BASEDIR}${PACKAGESDIR}/${ARCH}/*
|
2014-11-15 10:55:32 +01:00
|
|
|
}
|
|
|
|
|
2014-11-15 11:06:04 +01:00
|
|
|
setup_platform()
|
|
|
|
{
|
2014-12-09 17:11:54 +01:00
|
|
|
echo ">>> Setting up platform in ${1}..."
|
2014-11-15 11:06:04 +01:00
|
|
|
|
2015-03-05 08:16:19 +01:00
|
|
|
# XXX clean this up further maybe?
|
|
|
|
mkdir -p ${1}/conf
|
|
|
|
touch ${1}/conf/trigger_initial_wizard
|
|
|
|
|
2015-03-09 07:59:07 +01:00
|
|
|
# Let opnsense-update(8) know it's up to date
|
|
|
|
local MARKER="/usr/local/opnsense/version/os-update"
|
|
|
|
mkdir -p ${1}$(dirname ${MARKER})
|
|
|
|
echo ${PRODUCT_VERSION}-${ARCH} > ${1}${MARKER}
|
|
|
|
|
2014-12-10 17:13:01 +01:00
|
|
|
echo cdrom > ${1}/usr/local/etc/platform
|
2014-12-10 21:27:02 +01:00
|
|
|
|
|
|
|
# Set sane defaults via rc.conf(5)
|
|
|
|
cat > ${1}/etc/rc.conf <<EOF
|
|
|
|
tmpmfs="YES"
|
|
|
|
tmpsize="128m"
|
|
|
|
EOF
|
2014-11-15 11:06:04 +01:00
|
|
|
}
|
|
|
|
|
2014-11-16 16:20:27 +01:00
|
|
|
setup_mtree()
|
|
|
|
{
|
|
|
|
echo ">>> Creating mtree summary of files present..."
|
|
|
|
|
|
|
|
cat > ${1}/tmp/installed_filesystem.mtree.exclude <<EOF
|
|
|
|
./dev
|
|
|
|
./tmp
|
|
|
|
EOF
|
|
|
|
chroot ${1} /bin/sh -s <<EOF
|
|
|
|
/usr/sbin/mtree -c -k uid,gid,mode,size,sha256digest -p / -X /tmp/installed_filesystem.mtree.exclude > /tmp/installed_filesystem.mtree
|
|
|
|
/bin/chmod 600 /tmp/installed_filesystem.mtree
|
|
|
|
/bin/mv /tmp/installed_filesystem.mtree /etc/
|
|
|
|
/bin/rm /tmp/installed_filesystem.mtree.exclude
|
|
|
|
EOF
|
|
|
|
}
|
|
|
|
|
2014-11-09 11:15:01 +01:00
|
|
|
setup_stage()
|
|
|
|
{
|
2014-12-21 09:30:41 +01:00
|
|
|
echo ">>> Setting up stage in ${1}"
|
|
|
|
|
2015-01-07 07:01:24 +01:00
|
|
|
local MOUNTDIRS="/dev /usr/src /usr/ports /usr/core"
|
2015-01-07 06:56:10 +01:00
|
|
|
|
2014-12-20 22:31:37 +01:00
|
|
|
# might have been a chroot
|
2015-01-07 06:56:10 +01:00
|
|
|
for DIR in ${MOUNTDIRS}; do
|
|
|
|
if [ -d ${1}${DIR} ]; then
|
|
|
|
umount ${1}${DIR} 2> /dev/null || true
|
|
|
|
fi
|
|
|
|
done
|
|
|
|
|
2014-12-20 22:31:37 +01:00
|
|
|
# remove base system files
|
|
|
|
rm -rf ${1} 2> /dev/null ||
|
|
|
|
(chflags -R noschg ${1}; rm -rf ${1} 2> /dev/null)
|
2015-01-07 06:56:10 +01:00
|
|
|
|
2014-12-20 22:31:37 +01:00
|
|
|
# revive directory for next run
|
|
|
|
mkdir -p ${1}
|
2014-11-09 11:15:01 +01:00
|
|
|
}
|