2017-09-24 17:24:24 +00:00
|
|
|
#!/bin/false
|
2017-07-03 01:04:47 +00:00
|
|
|
|
2017-09-25 16:39:31 +00:00
|
|
|
export QUILT_PATCHES="$BASE_DIR/patches"
|
|
|
|
export QUILT_NO_DIFF_INDEX=1
|
|
|
|
export QUILT_NO_DIFF_TIMESTAMPS=1
|
|
|
|
export QUILT_REFRESH_ARGS='-p ab'
|
|
|
|
|
2017-07-04 13:39:31 +00:00
|
|
|
on_chroot() {
|
2017-07-09 20:52:11 +00:00
|
|
|
capsh --drop=cap_setfcap --chroot="$ROOTFS_DIR" -- "$@"
|
2017-07-03 06:50:15 +00:00
|
|
|
}
|
|
|
|
|
2017-07-06 00:52:50 +00:00
|
|
|
apply_patch() {
|
2017-07-03 06:48:36 +00:00
|
|
|
pushd "$ROOTFS_DIR" > /dev/null
|
|
|
|
|
|
|
|
quilt upgrade
|
|
|
|
RC=0
|
2017-07-04 19:44:58 +00:00
|
|
|
quilt push "$1" || RC=$?
|
2017-07-03 06:48:36 +00:00
|
|
|
|
|
|
|
case "$RC" in
|
|
|
|
0|2)
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
false
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
popd > /dev/null
|
|
|
|
}
|
2017-07-03 01:04:47 +00:00
|
|
|
|
2017-07-06 20:59:06 +00:00
|
|
|
apply_dir() {
|
|
|
|
install -d "$ROOTFS_DIR/$1"
|
|
|
|
}
|
|
|
|
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file() {
|
|
|
|
local MODE="$1"
|
|
|
|
local FILE="$2"
|
|
|
|
|
|
|
|
local SRC="$FILES_DIR/$FILE"
|
|
|
|
local DST="$ROOTFS_DIR/$FILE"
|
|
|
|
|
|
|
|
if [ ! -f "$SRC" ]; then
|
|
|
|
tput setaf 1 # Red color
|
|
|
|
echo "Source file $FILE does not exist"
|
|
|
|
tput sgr0 # No color
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
|
|
|
|
install -m "$MODE" "$SRC" "$DST"
|
|
|
|
}
|
|
|
|
|
2017-07-03 06:28:10 +00:00
|
|
|
if [ "$(id -u)" != '0' ]; then
|
|
|
|
echo 'Please run as root' 1>&2
|
|
|
|
exit 1
|
|
|
|
fi
|
2017-07-03 00:56:30 +00:00
|
|
|
|
2017-09-25 16:28:33 +00:00
|
|
|
if [ -e "$ROOTFS_DIR" ]; then
|
2017-09-25 16:32:37 +00:00
|
|
|
rm -rf "$ROOTFS_DIR"
|
2017-09-25 16:08:16 +00:00
|
|
|
fi
|
2017-07-02 11:30:26 +00:00
|
|
|
|
2017-09-25 16:08:16 +00:00
|
|
|
mkdir "$ROOTFS_DIR"
|
2017-09-24 15:12:24 +00:00
|
|
|
|
2017-07-03 11:51:22 +00:00
|
|
|
##
|
|
|
|
# Bootstrap a basic Debian system.
|
|
|
|
#
|
2017-09-24 15:13:15 +00:00
|
|
|
ARCH="$(dpkg --print-architecture)"
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-09-24 15:13:15 +00:00
|
|
|
if [ "$ARCH" != 'armhf' ]; then
|
|
|
|
BOOTSTRAP_CMD='qemu-debootstrap'
|
|
|
|
else
|
|
|
|
BOOTSTRAP_CMD='debootstrap'
|
2017-07-03 06:42:46 +00:00
|
|
|
fi
|
|
|
|
|
2017-09-24 15:13:15 +00:00
|
|
|
capsh --drop=cap_setfcap -- -c "$BOOTSTRAP_CMD \
|
|
|
|
--components=main,contrib,non-free \
|
|
|
|
--arch armhf \
|
|
|
|
--keyring $KEYS_DIR/raspbian-archive-keyring.gpg \
|
|
|
|
jessie \
|
|
|
|
$ROOTFS_DIR \
|
|
|
|
http://mirrordirector.raspbian.org/raspbian/" || rmdir "$ROOTFS_DIR/debootstrap/"
|
|
|
|
|
2017-07-04 19:44:58 +00:00
|
|
|
##
|
|
|
|
# Prepare for Quilt patching.
|
|
|
|
#
|
2017-07-06 16:01:25 +00:00
|
|
|
rm -rf "$ROOTFS_DIR/.pc/"
|
|
|
|
mkdir "$ROOTFS_DIR/.pc/"
|
2017-07-04 19:44:58 +00:00
|
|
|
|
2017-07-05 07:19:20 +00:00
|
|
|
##
|
|
|
|
# Prevent services to start after package installation in chroot environment.
|
|
|
|
#
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file 744 '/usr/sbin/policy-rc.d'
|
2017-07-05 07:19:20 +00:00
|
|
|
|
2017-07-03 11:51:22 +00:00
|
|
|
##
|
|
|
|
# Mount virtual file systems.
|
|
|
|
#
|
2017-07-03 09:53:52 +00:00
|
|
|
mount --bind /dev "$ROOTFS_DIR/dev"
|
|
|
|
mount --bind /dev/pts "$ROOTFS_DIR/dev/pts"
|
|
|
|
mount -t proc /proc "$ROOTFS_DIR/proc"
|
|
|
|
mount --bind /sys "$ROOTFS_DIR/sys"
|
2017-07-03 09:48:00 +00:00
|
|
|
|
2017-07-09 20:02:44 +00:00
|
|
|
##
|
|
|
|
# Add /etc/environment
|
|
|
|
#
|
|
|
|
apply_file 644 '/etc/environment'
|
|
|
|
|
2017-07-05 07:09:58 +00:00
|
|
|
##
|
2017-07-05 07:33:27 +00:00
|
|
|
# Add /etc/fstab and /etc/mtab
|
2017-07-05 07:09:58 +00:00
|
|
|
#
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file 644 '/etc/fstab'
|
|
|
|
ln -nsf /proc/mounts "$ROOTFS_DIR/etc/mtab"
|
2017-07-05 07:09:58 +00:00
|
|
|
|
2017-07-03 11:51:22 +00:00
|
|
|
##
|
|
|
|
# Prepare package manager.
|
|
|
|
#
|
2017-07-06 21:33:48 +00:00
|
|
|
apply_file 644 '/etc/apt/sources.list'
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-09-23 17:07:33 +00:00
|
|
|
on_chroot apt-key add - < "$KEYS_DIR/raspberrypi-archive-keyring.gpg"
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file 644 '/etc/apt/apt.conf.d/50raspi'
|
2017-07-05 08:02:03 +00:00
|
|
|
|
2017-07-04 13:39:31 +00:00
|
|
|
on_chroot << EOF
|
2017-07-03 06:42:46 +00:00
|
|
|
apt-get update
|
2017-09-24 08:51:51 +00:00
|
|
|
apt-get upgrade -y
|
2017-07-03 06:42:46 +00:00
|
|
|
apt-get dist-upgrade -y
|
2017-09-24 09:12:04 +00:00
|
|
|
apt-get autoremove -y --purge
|
2017-07-03 06:42:46 +00:00
|
|
|
EOF
|
|
|
|
|
2017-07-05 07:26:31 +00:00
|
|
|
##
|
2017-07-06 00:29:17 +00:00
|
|
|
# Install kernel and bootloader.
|
2017-07-05 07:26:31 +00:00
|
|
|
#
|
2017-07-06 00:29:17 +00:00
|
|
|
on_chroot << EOF
|
|
|
|
apt-get install -y raspberrypi-kernel raspberrypi-bootloader
|
|
|
|
EOF
|
2017-07-05 07:26:31 +00:00
|
|
|
|
2017-07-06 00:29:17 +00:00
|
|
|
##
|
|
|
|
# Prepare Raspberry Pi boot partition.
|
|
|
|
#
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file 644 '/boot/cmdline.txt'
|
|
|
|
apply_file 644 '/boot/config.txt'
|
2017-07-05 07:26:31 +00:00
|
|
|
|
2017-07-05 07:22:54 +00:00
|
|
|
##
|
|
|
|
# This script is executed at the end of each multiuser runlevel.
|
|
|
|
#
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file 755 '/etc/rc.local'
|
2017-07-05 07:22:54 +00:00
|
|
|
|
2017-07-05 07:31:01 +00:00
|
|
|
##
|
|
|
|
# Install SSH server
|
|
|
|
#
|
|
|
|
on_chroot << EOF
|
|
|
|
apt-get install -y ssh
|
|
|
|
EOF
|
|
|
|
|
2017-09-24 06:43:31 +00:00
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_key"
|
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_key.pub"
|
2017-07-06 03:37:44 +00:00
|
|
|
|
2017-09-24 06:43:31 +00:00
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_dsa_key"
|
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_dsa_key.pub"
|
2017-07-06 03:37:44 +00:00
|
|
|
|
2017-09-24 06:43:31 +00:00
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_ecdsa_key"
|
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_ecdsa_key.pub"
|
2017-07-06 03:37:44 +00:00
|
|
|
|
2017-09-24 06:43:31 +00:00
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_ed25519_key"
|
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_ed25519_key.pub"
|
2017-07-06 03:37:44 +00:00
|
|
|
|
2017-09-24 06:43:31 +00:00
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_rsa_key"
|
|
|
|
rm -fv "$ROOTFS_DIR/etc/ssh/ssh_host_rsa_key.pub"
|
2017-07-06 03:37:44 +00:00
|
|
|
|
2017-07-03 11:51:22 +00:00
|
|
|
##
|
2017-07-10 00:28:06 +00:00
|
|
|
# Assign device names by part-UUID
|
2017-07-03 11:51:22 +00:00
|
|
|
#
|
2017-07-10 00:28:06 +00:00
|
|
|
apply_file 644 '/lib/udev/rules.d/61-partuuid.rules'
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-07-05 07:44:31 +00:00
|
|
|
##
|
|
|
|
# Configure network.
|
|
|
|
#
|
2017-07-06 22:56:08 +00:00
|
|
|
apply_file 644 '/etc/hostname'
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-07-06 22:56:08 +00:00
|
|
|
apply_patch '02-hosts.diff'
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-07-06 20:57:44 +00:00
|
|
|
apply_file 644 '/etc/network/interfaces'
|
2017-07-06 21:01:16 +00:00
|
|
|
apply_file 644 '/etc/network/interfaces.d/eth0'
|
2017-07-06 06:51:52 +00:00
|
|
|
|
2017-07-05 07:44:31 +00:00
|
|
|
##
|
|
|
|
# Add user.
|
|
|
|
#
|
2017-07-05 08:12:25 +00:00
|
|
|
on_chroot << EOF
|
|
|
|
apt-get install -y sudo
|
|
|
|
EOF
|
|
|
|
|
2017-07-09 20:00:43 +00:00
|
|
|
apply_patch '03-passwordless-sudo.diff'
|
|
|
|
apply_patch '04-bashrc.diff'
|
|
|
|
apply_patch '05-useradd.diff'
|
2017-07-05 07:38:56 +00:00
|
|
|
|
2017-07-04 13:39:31 +00:00
|
|
|
on_chroot << EOF
|
2017-07-03 06:42:46 +00:00
|
|
|
if ! id -u $USERNAME >/dev/null 2>&1; then
|
|
|
|
adduser --disabled-password --gecos "" $USERNAME
|
|
|
|
fi
|
|
|
|
echo "$USERNAME:$PASSWORD" | chpasswd
|
|
|
|
passwd -d root
|
2017-07-05 07:48:04 +00:00
|
|
|
adduser $USERNAME sudo
|
2017-07-03 06:42:46 +00:00
|
|
|
EOF
|
|
|
|
|
2017-07-05 07:44:31 +00:00
|
|
|
##
|
|
|
|
# Configure time zone.
|
|
|
|
#
|
2017-07-04 13:39:31 +00:00
|
|
|
on_chroot << EOF
|
2017-07-03 06:42:46 +00:00
|
|
|
debconf-set-selections <<SELEOF
|
|
|
|
tzdata tzdata/Areas select Etc
|
|
|
|
tzdata tzdata/Zones/Etc select UTC
|
|
|
|
SELEOF
|
2017-07-05 07:50:44 +00:00
|
|
|
|
|
|
|
apt-get install -y tzdata
|
2017-07-03 06:42:46 +00:00
|
|
|
EOF
|
|
|
|
|
2017-07-05 07:47:28 +00:00
|
|
|
##
|
|
|
|
# Configure environment.
|
|
|
|
#
|
2017-07-09 20:00:43 +00:00
|
|
|
apply_patch '07-path.diff'
|
2017-07-03 06:42:46 +00:00
|
|
|
|
2017-07-06 03:52:17 +00:00
|
|
|
##
|
|
|
|
# Make user-friendly environment.
|
|
|
|
#
|
|
|
|
on_chroot << EOF
|
|
|
|
apt-get install -y \
|
|
|
|
bash-completion \
|
2017-07-11 22:28:56 +00:00
|
|
|
colordiff \
|
2017-09-24 06:35:11 +00:00
|
|
|
curl \
|
2017-07-06 03:52:17 +00:00
|
|
|
less \
|
|
|
|
vim
|
|
|
|
|
|
|
|
update-alternatives --set editor /usr/bin/vim.basic
|
|
|
|
EOF
|
|
|
|
|
2017-07-04 13:37:52 +00:00
|
|
|
##
|
|
|
|
# Save fake hardware clock time for more realistic time after startup.
|
|
|
|
#
|
2017-07-05 07:53:08 +00:00
|
|
|
on_chroot << EOF
|
2017-07-05 08:14:11 +00:00
|
|
|
apt-get install -y fake-hwclock ntp
|
2017-07-05 07:53:08 +00:00
|
|
|
systemctl disable hwclock.sh
|
|
|
|
fake-hwclock save
|
|
|
|
EOF
|
2017-07-04 13:37:52 +00:00
|
|
|
|
2017-07-03 11:38:42 +00:00
|
|
|
##
|
|
|
|
# Unmount virtual file systems.
|
|
|
|
#
|
2017-07-04 16:34:06 +00:00
|
|
|
umount "$ROOTFS_DIR/sys"
|
|
|
|
umount "$ROOTFS_DIR/proc"
|
|
|
|
umount "$ROOTFS_DIR/dev/pts"
|
|
|
|
umount "$ROOTFS_DIR/dev"
|
2017-07-03 11:38:42 +00:00
|
|
|
|
2017-07-04 19:44:58 +00:00
|
|
|
##
|
|
|
|
# Cleanup after Quilt patching.
|
|
|
|
#
|
2017-07-06 16:01:25 +00:00
|
|
|
rm -rf "$ROOTFS_DIR/.pc/"
|
2017-07-04 19:44:58 +00:00
|
|
|
|
2017-07-05 07:19:20 +00:00
|
|
|
##
|
|
|
|
# Allow services to start.
|
|
|
|
#
|
|
|
|
rm -f "$ROOTFS_DIR/usr/sbin/policy-rc.d"
|
|
|
|
|
2017-09-24 13:03:25 +00:00
|
|
|
##
|
|
|
|
# Clean Apt cache.
|
|
|
|
#
|
|
|
|
rm -rf "$ROOTFS_DIR/var/cache/apt/archives/*"
|