live-build/helpers/lh_binary_encryption

156 lines
3.2 KiB
Plaintext
Raw Normal View History

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
2007-09-23 08:04:52 +00:00
Read_conffile config/common
2007-09-23 08:04:49 +00:00
Read_conffile config/bootstrap
Read_conffile config/chroot
2007-09-23 08:04:52 +00:00
Read_conffile config/binary
Read_conffile config/source
2007-09-23 08:05:18 +00:00
Read_conffile "${LH_CONFIG}"
2007-09-23 08:04:46 +00:00
Set_defaults
2007-09-23 08:05:17 +00:00
if [ -z "${LH_ENCRYPTION}" ]
2007-09-23 08:04:48 +00:00
then
2007-09-23 08:04:49 +00:00
exit 0
fi
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
Require_stagefile .stage/bootstrap
Require_stagefile .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:05:17 +00:00
case "${LH_CHROOT_FILESYSTEM}" in
2007-09-23 08:04:49 +00:00
ext2)
ROOTFS="ext2"
;;
2007-09-23 08:04:46 +00:00
jffs2)
Echo_warning "encryption not yet supported on jffs2 filesystem."
exit 0
;;
2007-09-23 08:04:49 +00:00
plain)
2007-09-23 08:04:50 +00:00
Echo_warning "encryption not supported on plain filesystem."
2007-09-23 08:04:49 +00:00
exit 0
;;
2007-09-23 08:04:48 +00:00
2007-09-23 08:04:49 +00:00
squashfs)
ROOTFS="squashfs"
;;
esac
2007-09-23 08:04:48 +00:00
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
Echo_message "Encrypting binary/${INITFS}/filesystem.${LH_CHROOT_FILESYSTEM} with ${LH_ENCRYPTION}..."
2007-09-23 08:04:49 +00: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
echo
echo " **************************************"
echo " ** Configuring encrypted filesystem **"
echo " **************************************"
echo " (Passwords must be at least 20 characters long)"
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
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
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
# 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