oem-factory-reset: Allow use without an installed OS

If an installed OS is not detected, then skip setting the
default boot device or generating /boot checksums.

Signed-off-by: Matt DeVillier <matt.devillier@puri.sm>
This commit is contained in:
Matt DeVillier 2020-10-23 18:38:30 -05:00 committed by tlaurion
parent 1fc123df4a
commit e7faac20db

View File

@ -24,6 +24,7 @@ GPG_USER_NAME="OEM Key"
GPG_KEY_NAME=`date +%Y%m%d%H%M%S` GPG_KEY_NAME=`date +%Y%m%d%H%M%S`
GPG_USER_MAIL="oem-${GPG_KEY_NAME}@example.com" GPG_USER_MAIL="oem-${GPG_KEY_NAME}@example.com"
GPG_USER_COMMENT="OEM-generated key" GPG_USER_COMMENT="OEM-generated key"
SKIP_BOOT="n"
## External files sourced ## External files sourced
@ -368,14 +369,16 @@ fi
# detect and set /boot device # detect and set /boot device
echo -e "\nDetecting and setting boot device...\n" echo -e "\nDetecting and setting boot device...\n"
if ! detect_boot_device ; then if ! detect_boot_device ; then
whiptail_error_die "Unable to locate /boot files on any mounted disk" SKIP_BOOT="y"
else else
echo -e "Boot device set to $CONFIG_BOOT_DEV\n" echo -e "Boot device set to $CONFIG_BOOT_DEV\n"
fi fi
# update configs # update configs
replace_config /etc/config.user "CONFIG_BOOT_DEV" "$CONFIG_BOOT_DEV" if [[ "$SKIP_BOOT" == "n" ]]; then
combine_configs replace_config /etc/config.user "CONFIG_BOOT_DEV" "$CONFIG_BOOT_DEV"
combine_configs
fi
## reset TPM and set default password ## reset TPM and set default password
if [ "$CONFIG_TPM" = "y" ]; then if [ "$CONFIG_TPM" = "y" ]; then
@ -481,8 +484,10 @@ if ! /bin/flash.sh /tmp/oem-setup.rom >/dev/null 2>/tmp/error ; then
fi fi
## sign files in /boot and generate checksums ## sign files in /boot and generate checksums
echo -e "\nSigning boot files and generating checksums...\n" if [[ "$SKIP_BOOT" == "n" ]]; then
generate_checksums echo -e "\nSigning boot files and generating checksums...\n"
generate_checksums
fi
## all done -- reboot ## all done -- reboot
whiptail --msgbox " whiptail --msgbox "