2007-09-23 08:04:46 +00:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
# lh_binary_encryption(1) - encrypts rootfs
|
2008-03-06 14:43:00 -01:00
|
|
|
# Copyright (C) 2006-2008 Daniel Baumann <daniel@debian.org>
|
2007-09-23 08:04:48 +00:00
|
|
|
#
|
|
|
|
# live-helper comes with ABSOLUTELY NO WARRANTY; for details see COPYING.
|
|
|
|
# This is free software, and you are welcome to redistribute it
|
|
|
|
# under certain conditions; see COPYING for details.
|
2007-09-23 08:04:46 +00:00
|
|
|
|
|
|
|
set -e
|
|
|
|
|
2007-09-23 08:05:11 +00:00
|
|
|
# Including common functions
|
|
|
|
LH_BASE="${LH_BASE:-/usr/share/live-helper}"
|
|
|
|
|
|
|
|
for FUNCTION in "${LH_BASE}"/functions/*.sh
|
2007-09-23 08:04:46 +00:00
|
|
|
do
|
2007-09-23 08:05:11 +00:00
|
|
|
. "${FUNCTION}"
|
2007-09-23 08:04:46 +00:00
|
|
|
done
|
|
|
|
|
2007-09-23 08:05:11 +00:00
|
|
|
# Setting static variables
|
2007-09-23 08:04:48 +00:00
|
|
|
DESCRIPTION="encrypts rootfs"
|
|
|
|
HELP=""
|
|
|
|
USAGE="${PROGRAM} [--force]"
|
|
|
|
|
|
|
|
Arguments "${@}"
|
|
|
|
|
2007-09-23 08:04:46 +00:00
|
|
|
# Reading configuration files
|
2008-04-07 10:10:21 +00:00
|
|
|
Read_conffile config/all config/common config/bootstrap config/chroot config/binary config/source
|
2007-09-23 08:04:46 +00:00
|
|
|
Set_defaults
|
|
|
|
|
2008-03-23 03:21:47 -01:00
|
|
|
case "${LH_ENCRYPTION}" in
|
|
|
|
aes128|aes192|aes256)
|
|
|
|
;;
|
|
|
|
""|disabled)
|
|
|
|
exit 0
|
|
|
|
;;
|
|
|
|
*)
|
2008-08-11 20:28:54 +00:00
|
|
|
Echo_error "Encryption type %s not supported." "${LH_ENCRYPTION}"
|
2008-03-23 03:21:47 -01:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
|
|
|
case "${LH_CHROOT_FILESYSTEM}" in
|
|
|
|
ext2|squashfs)
|
|
|
|
;;
|
|
|
|
|
|
|
|
*)
|
2008-08-11 20:28:54 +00:00
|
|
|
Echo_error "Encryption not yet supported on %s filesystems." "${LH_CHROOT_FILESYSTEM}"
|
2008-03-23 03:21:47 -01:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:05:11 +00:00
|
|
|
Echo_message "Begin encrypting root filesystem image..."
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:49 +00:00
|
|
|
# Requiring stage file
|
2008-10-14 19:32:50 +00:00
|
|
|
Require_stagefile .stage/config .stage/bootstrap .stage/binary_rootfs
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:50 +00:00
|
|
|
# Checking stage file
|
|
|
|
Check_stagefile .stage/binary_encryption
|
|
|
|
|
2007-09-23 08:04:49 +00:00
|
|
|
# Checking lock file
|
|
|
|
Check_lockfile .lock
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:49 +00:00
|
|
|
# Creating lock file
|
|
|
|
Create_lockfile .lock
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:52 +00:00
|
|
|
case "${LH_INITRAMFS}" in
|
|
|
|
casper)
|
|
|
|
INITFS="casper"
|
|
|
|
;;
|
|
|
|
|
|
|
|
live-initramfs)
|
|
|
|
INITFS="live"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2007-09-23 08:04:51 +00:00
|
|
|
# Checking depends
|
|
|
|
Check_package chroot/usr/bin/aespipe aespipe
|
2007-09-23 08:04:48 +00:00
|
|
|
|
2007-09-23 08:05:15 +00:00
|
|
|
# Restoring cache
|
|
|
|
Restore_cache cache/packages_binary
|
|
|
|
|
2007-09-23 08:04:51 +00:00
|
|
|
# Installing depends
|
|
|
|
Install_package
|
2007-09-23 08:04:49 +00:00
|
|
|
|
2008-08-11 20:28:54 +00:00
|
|
|
Echo_message "Encrypting binary/%s/filesystem.%s with %s..." "${INITFS}" "${LH_CHROOT_FILESYSTEM}" "${LH_ENCRYPTION}"
|
2007-09-23 08:04:49 +00:00
|
|
|
|
2008-03-23 03:20:31 -01:00
|
|
|
if [ "${LH_CHROOT_BUILD}" = "enabled" ]
|
|
|
|
then
|
|
|
|
# Moving image
|
|
|
|
mv binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM} chroot
|
|
|
|
fi
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:48 +00:00
|
|
|
while true
|
|
|
|
do
|
2008-03-23 03:20:31 -01:00
|
|
|
echo
|
2008-08-14 19:48:51 +00:00
|
|
|
Echo " **************************************"
|
|
|
|
Echo " ** Configuring encrypted filesystem **"
|
|
|
|
Echo " **************************************"
|
|
|
|
Echo " (Passwords must be at least 20 characters long)"
|
2008-03-23 03:20:31 -01:00
|
|
|
echo
|
|
|
|
|
|
|
|
case "${LH_CHROOT_BUILD}" in
|
|
|
|
enabled)
|
|
|
|
if Chroot aespipe -e ${LH_ENCRYPTION} -T \
|
|
|
|
< chroot/filesystem.${LH_CHROOT_FILESYSTEM} \
|
|
|
|
> chroot/filesystem.${LH_CHROOT_FILESYSTEM}.tmp
|
|
|
|
then
|
|
|
|
mv chroot/filesystem.${LH_CHROOT_FILESYSTEM}.tmp binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM}
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
disabled)
|
|
|
|
if aespipe -e ${LH_ENCRYPTION} -T \
|
|
|
|
< binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM} \
|
|
|
|
> binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM}.tmp
|
|
|
|
then
|
|
|
|
mv binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM}.tmp binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM}
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
;;
|
|
|
|
esac
|
2007-09-23 08:04:48 +00:00
|
|
|
|
2008-03-23 03:20:31 -01:00
|
|
|
printf "\nThere was an error configuring encryption ... Retry? [Y/n] "
|
2007-09-23 08:04:48 +00:00
|
|
|
read ANSWER
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2008-03-23 03:20:31 -01:00
|
|
|
if [ "$(echo "${ANSWER}" | cut -b1 | tr A-Z a-z)" = "n" ]
|
2007-09-23 08:04:48 +00:00
|
|
|
then
|
|
|
|
unset ANSWER
|
|
|
|
break
|
|
|
|
fi
|
|
|
|
done
|
2008-03-23 03:20:31 -01:00
|
|
|
|
|
|
|
# Cleanup temporary filesystems
|
|
|
|
rm -f chroot/filesystem.${LH_CHROOT_FILESYSTEM}
|
|
|
|
rm -f chroot/filesystem.${LH_CHROOT_FILESYSTEM}.tmp
|
|
|
|
rm -f binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM}.tmp
|
2007-09-23 08:04:48 +00:00
|
|
|
|
2007-09-23 08:05:15 +00:00
|
|
|
# Saving cache
|
|
|
|
Save_cache cache/packages_binary
|
2007-09-23 08:04:46 +00:00
|
|
|
|
2007-09-23 08:04:51 +00:00
|
|
|
# Removing depends
|
|
|
|
Remove_package
|
2007-09-23 08:04:49 +00:00
|
|
|
|
|
|
|
# Creating stage file
|
|
|
|
Create_stagefile .stage/binary_encryption
|