diff options
Diffstat (limited to 'client/engine/Boot.lib')
-rwxr-xr-x | client/engine/Boot.lib | 907 |
1 files changed, 685 insertions, 222 deletions
diff --git a/client/engine/Boot.lib b/client/engine/Boot.lib index e9ddf38e..6808f094 100755 --- a/client/engine/Boot.lib +++ b/client/engine/Boot.lib @@ -37,12 +37,15 @@ #@version 1.1.0 - Nuevo parámetro opcional con opciones de arranque del Kernel. #@author Ramon Gomez, ETSII Universidad de Sevilla #@date 2015-07-15 +#@version 1.1.1 - UEFI: Permite iniciar linux recien instalados (ticket #802 #890) +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-03-13 #*/ ## function ogBoot () { # Variables locales. local PART TYPE MNTDIR PARAMS KERNEL INITRD APPEND FILE LOADER f -local EFIDISK EFIPART EFIDIR BOOTLABEL BOOTNO +local EFIDISK EFIPART EFIDIR BOOTLABEL BOOTLOADER BOOTNO DIRGRUB b # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -63,6 +66,8 @@ case "$TYPE" in Linux|Android) # Si no se indican, obtiene los parámetros de arranque para Linux. PARAMS="${3:-$(ogLinuxBootParameters $1 $2 2>/dev/null)}" + # Si no existe y el UEFI buscar en particion ESP + [ -z "$PARAMS" ] && ogIsEfiActive && PARAMS="$(ogLinuxBootParameters $(ogGetEsp))" # Si no existe, buscar sistema de archivo /boot en /etc/fstab. if [ -z "$PARAMS" -a -e $MNTDIR/etc/fstab ]; then # Localizar S.F. /boot en /etc/fstab del S.F. actual. @@ -79,28 +84,39 @@ case "$TYPE" in [ -e "$MNTDIR/etc" ] && APPEND=$(echo $APPEND | awk -v P="$PART " '{sub (/root=[-+=_/a-zA-Z0-9]* /,"root="P);print}') # Comprobar tipo de sistema. if ogIsEfiActive; then - # Obtener parcición EFI. - read -e EFIDISK EFIPART <<<"$(ogGetEsp)" - [ -n "$EFIPART" ] || ogRaiseError $OG_ERR_PARTITION "ESP" || return $? # Comprobar si el Kernel está firmado. if ! file -k "$MNTDIR/$KERNEL" | grep -q "EFI app"; then ogRaiseError $OG_ERR_NOTOS "$1 $2 ($TYPE, EFI)" return $? fi - # Crear directorio para el cargador y copiar los ficheros. - EFIDIR=$(ogMount $EFIDISK $EFIPART) || exit $? + BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2) - mkdir -p $EFIDIR/EFI/$BOOTLABEL - cp $MNTDIR/$KERNEL $EFIDIR/EFI/$BOOTLABEL/vmlinuz.efi - cp $MNTDIR/$INITRD $EFIDIR/EFI/$BOOTLABEL/initrd.img - # Borrar cargador guardado con la misma etiqueta. - BOOTNO=$(efibootmgr -v | awk -v L=$BOOTLABEL '{if ($2==L) print $1}') - [ -n "$BOOTNO" ] && efibootmgr -B -b ${BOOTNO:4:4} + BOOTLOADER="shimx64.efi" + # Obtener parcición EFI. + read -e EFIDISK EFIPART <<<"$(ogGetEsp)" + # TODO: Comprobamos que existe la BOOTLABEL, si no buscamos por sistema operativo + if [ "$(ogGetPath $EFIDISK $EFIPART EFI/$BOOTLABEL)" == "" ]; then + OSVERSION="$(ogGetOsVersion $1 $2)" + case $OSVERSION in + *SUSE*) + BOOTLABEL="opensuse" + ;; + *Fedora*) + BOOTLABEL="fedora" + ;; + *Ubuntu*) + BOOTLABEL="ubuntu" + ;; + *) + ogRaiseError $OG_ERR_NOTFOUND "$EFIDISK $EFIPART Boot loader"; return $? + ;; + esac + fi + # Crear orden de arranque (con unos valores por defecto). - efibootmgr -C -d $(ogDiskToDev $EFIDISK) -p $EFIPART -L "$BOOTLABEL" -l /EFI/$BOOTLABEL/vmlinuz.efi -u "initrd=/EFI/$BOOTLABEL/initrd.img $APPEND" + ogNvramAddEntry $BOOTLABEL "/EFI/$BOOTLABEL/Boot/$BOOTLOADER" # Marcar próximo arranque y reiniciar. - BOOTNO=$(efibootmgr -v | awk -v L="$BOOTLABEL" '{if ($2==L) print $1}') - [ -n "$BOOTNO" ] && efibootmgr -n ${BOOTNO:4:4} + ogNvramSetNext "$BOOTLABEL" reboot else # Arranque BIOS: configurar kernel Linux con los parámetros leídos de su GRUB. @@ -111,29 +127,23 @@ case "$TYPE" in Windows) # Comprobar tipo de sistema. if ogIsEfiActive; then + BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2) # Obtener parcición EFI. read -e EFIDISK EFIPART <<<"$(ogGetEsp)" [ -n "$EFIPART" ] || ogRaiseError $OG_ERR_PARTITION "ESP" || return $? EFIDIR=$(ogMount $EFIDISK $EFIPART) || exit $? # Comprobar cargador (si no existe buscar por defecto en ESP). - LOADER=$(ogGetPath $1 $2 /Boot/bootmgfw.efi) - [ -z "$LOADER" ] && LOADER=$(ogGetPath $EFIDIR/EFI/Microsoft/Boot/bootmgfw.efi) + LOADER=$(ogGetPath $EFIDIR/EFI/$BOOTLABEL/Boot/bootmgfw.efi) + [ -z "$LOADER" ] && BOOTLABEL=Microsoft && LOADER=$(ogGetPath $EFIDIR/EFI/Microsoft/Boot/bootmgfw.efi) [ -n "$LOADER" ] || ogRaiseError $OG_ERR_NOTOS "$1 $2 ($TYPE, EFI)" || return $? - # Crear directorio para el cargador y copiar los ficheros. - BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2) - mkdir -p $EFIDIR/EFI/$BOOTLABEL - cp -a $(dirname "$LOADER") $EFIDIR/EFI/$BOOTLABEL - # Borrar cargador guardado con la misma etiqueta. - BOOTNO=$(efibootmgr -v | awk -v L=$BOOTLABEL '{if ($2==L) print $1}') - [ -n "$BOOTNO" ] && efibootmgr -B -b ${BOOTNO:4:4} + # Crear orden de arranque (con unos valores por defecto). - efibootmgr -C -d $(ogDiskToDev $EFIDISK) -p $EFIPART -L "$BOOTLABEL" -l "/EFI/$BOOTLABEL/Boot/BOOTMGFW.EFI" + ogNvramAddEntry $BOOTLABEL "/EFI${LOADER#*EFI}" # Marcar próximo arranque y reiniciar. - BOOTNO=$(efibootmgr -v | awk -v L="$BOOTLABEL" '{if ($2==L) print $1}') - [ -n "$BOOTNO" ] && efibootmgr -n ${BOOTNO:4:4} + ogNvramSetNext "$BOOTLABEL" reboot else - # Arranque BIOS: compruebar si hay un cargador de Windows. + # Arranque BIOS: comprueba si hay un cargador de Windows. for f in io.sys ntldr bootmgr; do FILE="$(ogGetPath $1 $2 $f 2>/dev/null)" [ -n "$FILE" ] && LOADER="$f" @@ -167,7 +177,7 @@ case "$TYPE" in ;; GrubLoader) # Reiniciar. - reboot + #reboot ;; *) ogRaiseError $OG_ERR_NOTOS "$1 $2 ${TYPE:+($TYPE)}" return $? @@ -471,7 +481,7 @@ fi #TODO, solo si es ntfs o fat PARTYPE=$(ogGetPartitionId $1 $2) case "$PARTYPE" in - 1|4|6|7|b|c|e|f|17|700) + 1|4|6|7|b|c|e|f|17|700|EF00) ;; *) return $(ogRaiseError $OG_ERR_PARTITION; echo $?) @@ -490,9 +500,7 @@ main_part=$PART fix_first_sector=yes EOF -spartlnx.run -cui -nm -a -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -a -f $FILE rm -f $FILE } @@ -518,12 +526,15 @@ rm -f $FILE #@version 1.1.0 - Soporte para Windows 10. #@author Ramon Gomez, ETSII Universidad de Sevilla #@date 2016-01-19 +#@version 1.1.1 - Compatibilidad con UEFI (ticket #802 #889) +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-01-28 #*/ ## function ogWindowsBootParameters () { # Variables locales. -local PART DISK FILE WINVER MOUNT +local PART DISK BOOTLABEL BCDFILE BOOTDISK BOOTPART FILE WINVER MOUNT # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -541,6 +552,19 @@ ogDiskToDev $1 $2 || return $(ogRaiseError $OG_ERR_PARTITION; echo $?) let DISK=$1-1 PART=$2 FILE=/tmp/temp$$ +if ogIsEfiActive; then + read BOOTDISK BOOTPART <<< $(ogGetEsp) + ogUnmount $BOOTDISK $BOOTPART || ogRaiseError $OG_ERR_PARTITION "ESP: $BOOTDISK $BOOTPART" || return $? + + let BOOTDISK=$BOOTDISK-1 + BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2) + BCDFILE="boot_BCD_file=/EFI/$BOOTLABEL/Boot/BCD" +else + BOOTDISK=$DISK + BOOTPART=$PART + BCDFILE="" +fi + # Obtener versión de Windows. WINVER=$(ogGetOsVersion $1 $2 | awk -F"[: ]" '$1=="Windows" {if ($3=="Server") print $2,$3,$4; else print $2,$3;}') @@ -559,69 +583,94 @@ ogUnmount $1 $2 || return $(ogRaiseError $OG_ERR_PARTITION; echo $?) #Preparando instruccion Windows Resume Application cat > $FILE <<EOF -boot_disk=$DISK -boot_main_part=$PART +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE disk=$DISK main_part=$PART boot_entry=Windows Resume Application EOF -spartlnx.run -cui -nm -w -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE - #Preparando instruccion tipo windows cat > $FILE <<EOF -boot_disk=$DISK -boot_main_part=$PART +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE disk=$DISK main_part=$PART boot_entry=$WINVER EOF -spartlnx.run -cui -nm -w -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null - +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE ##Preparando instruccion Ramdisk Options cat > $FILE <<EOF -boot_disk=$DISK -boot_main_part=$PART +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE disk=$DISK main_part=$PART boot_entry=Ramdisk Options EOF -spartlnx.run -cui -nm -w -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE +##Preparando instruccion Recovery Environment +cat > $FILE <<EOF +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE +disk=$DISK +main_part=$PART +boot_entry=Windows Recovery Environment +EOF +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE -#Preparando instruccion Windows Boot Manager +##Preparando instruccion Recovery cat > $FILE <<EOF -boot_disk=$DISK -boot_main_part=$PART +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE disk=$DISK main_part=$PART -boot_entry=Windows Boot Manager +boot_entry=Windows Recovery EOF -spartlnx.run -cui -nm -w -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE +#Preparando instruccion Windows Boot Manager +cat > $FILE <<EOF +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE +disk=$BOOTDISK +main_part=$BOOTPART +boot_entry=Windows Boot Manager +EOF +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE #Preparando instruccion Herramienta de diagnóstico de memoria de Windows cat > $FILE <<EOF -boot_disk=$DISK -boot_main_part=$PART -disk=$DISK -main_part=$PART +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE +disk=$BOOTDISK +main_part=$BOOTPART boot_entry=Herramienta de diagnóstico de memoria de Windows EOF -spartlnx.run -cui -nm -w -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE + +#Preparando instruccion Herramienta de diagnóstico de memoria de Windows +cat > $FILE <<EOF +boot_disk=$BOOTDISK +boot_main_part=$BOOTPART +$BCDFILE +disk=$BOOTDISK +main_part=$BOOTPART +boot_entry=Herramienta de diagn<f3>stico de memoria de Windows +EOF +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -w -f $FILE +rm -f $FILE } @@ -695,9 +744,7 @@ main_part=$REGISTREDPART ;ext_part part_letter=$REGISTREDVOL EOF -spartlnx.run -cui -nm -u -f $FILE & -sleep 5 -ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null +timeout --foreground --signal=SIGKILL 5s spartlnx.run -cui -nm -u -f $FILE } @@ -724,6 +771,12 @@ ps aux > /dev/null | grep $! | grep -E "T|S" | kill -9 $! > /dev/null #@version 1.1.0 - #827 Entrada para el ogLive si el equipo tiene partición cache. #@author Antonio J. Doblas Viso. Universidad de Malaga. #@date 2018-01-21 +#@version 1.1.1 - #802 Equipos EFI: Se crea el grub.cfg de la partición EFI +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-01-08 +#@version 1.1.1 - #890 UEFI: el grub.cfg original es necesario para obtener los datos del kernel efi: se mueve al final. +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-03-05 #*/ ## function ogGrubInstallMbr () @@ -731,6 +784,7 @@ function ogGrubInstallMbr () # Variables locales. local PART DISK VERSION FIRSTAGE SECONSTAGE CHECKOS KERNELPARAM BACKUPNAME +local EFIDISK EFIPART EFISECONDSTAGE EFISUBDIR EFIOPTGRUB # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -758,7 +812,7 @@ BACKUPNAME=".backup.og" FIRSTSTAGE=$(ogDiskToDev 1) #localizar disco segunda etapa del grub -SECONDSTAGE=$(ogMount $DISK $PART) +SECONDSTAGE=$(ogMount "$DISK" "$PART") || return $? # prepara el directorio principal de la segunda etapa [ -d ${SECONDSTAGE}/boot/grub/ ] || mkdir -p ${SECONDSTAGE}/boot/grub/ @@ -766,43 +820,82 @@ SECONDSTAGE=$(ogMount $DISK $PART) #Localizar directorio segunda etapa del grub PREFIXSECONDSTAGE="/boot/grubMBR" +# Instalamos grub para EFI en ESP +EFIOPTGRUB="" +if ogIsEfiActive; then + read EFIDISK EFIPART <<< $(ogGetEsp) + # Comprobamos que exista ESP y el directorio para ubuntu + EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART) + if [ $? -ne 0 ]; then + ogFormat $EFIDISK $EFIPART FAT32 + EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $? + fi + EFISUBDIR="grub" + # Borramos la configuración anterior + [ -d ${EFISECONDSTAGE}/EFI/$EFISUBDIR ] && rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR + mkdir -p ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot + EFIOPTGRUB=" --removable --no-nvram --uefi-secure-boot --target $(ogGetArch)-efi --efi-directory=${EFISECONDSTAGE}/EFI/$EFISUBDIR " +fi + # Si Reconfigurar segunda etapa (grub.cfg) == FALSE -if [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] +if [ "${CHECKOS^^}" == "FALSE" ] && [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] then - if [ "$CHECKOS" == "false" -o "$CHECKOS" == "FALSE" ] - then # Si no se reconfigura se utiliza el grub.cfg orginal [ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg - # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys. + # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys. [ -d ${SECONDSTAGE}${PREFIXSECONDSTAGE} ] && rm -fr ${SECONDSTAGE}${PREFIXSECONDSTAGE} - # Reactivamos el grub con el grub.cfg original. - grub-install --force --root-directory=${SECONDSTAGE} $FIRSTSTAGE - return $? - fi -fi + PREFIXSECONDSTAGE="" +else + # SI Reconfigurar segunda etapa (grub.cfg) == TRUE -# SI Reconfigurar segunda etapa (grub.cfg) == TRUE + #llamada a updateBootCache para que aloje la primera fase del ogLive + updateBootCache -#llamada a updateBootCache para que aloje la primera fase del ogLive -updateBootCache + if ogIsEfiActive; then + # UEFI: grubSintax necesita grub.cfg para detectar los kernels: si no existe recupero backup. + if ! [ -f ${SECONDSTAGE}/boot/grub/grub.cfg ]; then + [ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg + fi + else + #Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup + mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME + fi -#Configur la sintaxis grub para evitar menus de "recovery" en el OGLive -echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub -echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub + #Configur la sintaxis grub para evitar menus de "recovery" en el OGLive + echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub + echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub -#Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup -[ -f ${SECONDSTAGE}/boot/grub/grub.cfg ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME -#Preparar configuración segunda etapa: crear ubicacion -mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/ -#Preparar configuración segunda etapa: crear cabecera del fichero (ignorar errores) -sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header -/etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null -#Preparar configuración segunda etapa: crear entrada del sistema operativo -grubSyntax "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg + #Preparar configuración segunda etapa: crear ubicacion + mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/ + #Preparar configuración segunda etapa: crear cabecera del fichero (ignorar errores) + sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header + # (ogLive 5.0) Si 'pkgdatadir' está vacía ponemos valor de otros ogLive + sed -i '/grub-mkconfig_lib/i\pkgdatadir=${pkgdatadir:-"${datarootdir}/grub"}' /etc/grub.d/00_header + /etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null + + #Preparar configuración segunda etapa: crear entrada del sistema operativo + grubSyntax "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg + + # Renombramos la configuración de grub antigua + [ -f ${SECONDSTAGE}/boot/grub/grub.cfg ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME + +fi + +#Instalar el grub +grub-install --force ${EFIOPTGRUB} --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE +EVAL=$? + +# Movemos el grubx64.efi +if ogIsEfiActive; then + mv ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI/BOOT/* ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot + rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI + cp /usr/lib/shim/shimx64.efi.signed ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot + # Nombre OpenGnsys para cargador + cp ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot/{shimx64.efi.signed,ogloader.efi} +fi +return $EVAL -#Instalar el grub -grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE } @@ -824,6 +917,12 @@ grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTS #@version 1.0.3 - Ficheros de configuracion independientes segun ubicación de la priemra etapa #@author Antonio J. Doblas Viso. Universidad de Malaga. #@date 2012-03-13 +#@version 1.1.1 - #802 Equipos EFI: Se crea el grub.cfg de la partición EFI +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-01-08 +#@version 1.1.1 - #890 UEFI: el grub.cfg original es necesario para obtener los datos del kernel efi: se mueve al final. +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-03-05 #*/ ## function ogGrubInstallPartition () @@ -831,6 +930,7 @@ function ogGrubInstallPartition () # Variables locales. local PART DISK VERSION FIRSTAGE SECONSTAGE CHECKOS KERNELPARAM BACKUPNAME +local EFIDISK EFIPART EFISECONDSTAGE EFISUBDIR EFIOPTGRUB EFIBOOTDIR # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -861,39 +961,77 @@ SECONDSTAGE=$(ogMount $DISK $PART) #Localizar directorio segunda etapa del grub PREFIXSECONDSTAGE="/boot/grubPARTITION" +# Si es EFI instalamos el grub en la ESP +EFIOPTGRUB="" +# Desde el bootdir uefi y bios buscan el grub.cfg en subdirectorios distintos. +EFIBOOTDIR="" +if ogIsEfiActive; then + read EFIDISK EFIPART <<< $(ogGetEsp) + # Comprobamos que exista ESP y el directorio para ubuntu + EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART) + if [ $? -ne 0 ]; then + ogFormat $EFIDISK $EFIPART FAT32 + EFISECONDSTAGE=$(ogMount $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $? + fi + EFISUBDIR=$(printf "Part-%02d-%02d" $DISK $PART) + # Borramos la configuración anterior + [ -d ${EFISECONDSTAGE}/EFI/$EFISUBDIR ] && rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR + mkdir -p ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot + EFIOPTGRUB=" --removable --no-nvram --uefi-secure-boot --target $(ogGetArch)-efi --efi-directory=${EFISECONDSTAGE}/EFI/$EFISUBDIR " + EFIBOOTDIR="/boot" +fi + # Si Reconfigurar segunda etapa (grub.cfg) == FALSE -if [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] +if [ "${CHECKOS^^}" == "FALSE" ] && [ -f ${SECONDSTAGE}/boot/grub/grub.cfg -o -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] then - if [ "$CHECKOS" == "false" -o "$CHECKOS" == "FALSE" ] - then # Si no se reconfigura se utiliza el grub.cfg orginal [ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg - # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys. + # Si no se reconfigure se borra los ficheros previos de configuración específicos de opengnsys. [ -d ${SECONDSTAGE}${PREFIXSECONDSTAGE} ] && rm -fr ${SECONDSTAGE}${PREFIXSECONDSTAGE} # Reactivamos el grub con el grub.cfg original. - grub-install --force --root-directory=${SECONDSTAGE} $FIRSTSTAGE - return $? - fi -fi + PREFIXSECONDSTAGE="" +else + # SI Reconfigurar segunda etapa (grub.cfg) == TRUE -# SI Reconfigurar segunda etapa (grub.cfg) == TRUE -#Configur la sintaxis grub para evitar menus de "recovery" en el OGLive -echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub -echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub + if ogIsEfiActive; then + # UEFI: grubSintax necesita grub.cfg para detectar los kernels: si no existe recupero backup. + if ! [ -f ${SECONDSTAGE}/boot/grub/grub.cfg ]; then + [ -f ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME ${SECONDSTAGE}/boot/grub/grub.cfg + fi + else + #Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup + mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME + fi -#Evitar detectar modo recovery - mover grub.cfg original a grub.cfg.backup.og -[ -f ${SECONDSTAGE}/boot/grub/grub.cfg ] && mv ${SECONDSTAGE}/boot/grub/grub.cfg ${SECONDSTAGE}/boot/grub/grub.cfg$BACKUPNAME + #Configur la sintaxis grub para evitar menus de "recovery" en el OGLive + echo "GRUB_DISABLE_RECOVERY=\"true\"" >> /etc/default/grub + echo "GRUB_DISABLE_LINUX_UUID=\"true\"" >> /etc/default/grub -#Preparar configuración segunda etapa: crear ubicacion -mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/ -#Preparar configuración segunda etapa: crear cabecera del fichero (ingnorar errores) -sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header -/etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null -#Preparar configuración segunda etapa: crear entrada del sistema operativo -grubSyntax $DISK $PART "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg + #Preparar configuración segunda etapa: crear ubicacion + mkdir -p ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/ + #Preparar configuración segunda etapa: crear cabecera del fichero (ingnorar errores) + sed -i 's/^set -e/#set -e/' /etc/grub.d/00_header + # (ogLive 5.0) Si 'pkgdatadir' está vacía ponemos valor de otros ogLive + sed -i '/grub-mkconfig_lib/i\pkgdatadir=${pkgdatadir:-"${datarootdir}/grub"}' /etc/grub.d/00_header + /etc/grub.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg 2>/dev/null + #Preparar configuración segunda etapa: crear entrada del sistema operativo + grubSyntax $DISK $PART "$KERNELPARAM" >> ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/grub/grub.cfg +fi #Instalar el grub -grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE +grub-install --force ${EFIOPTGRUB} --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTSTAGE +EVAL=$? + +# Movemos el grubx64.efi +if ogIsEfiActive; then + mv ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI/BOOT/* ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot + rm -rf ${EFISECONDSTAGE}/EFI/$EFISUBDIR/EFI + cp /usr/lib/shim/shimx64.efi.signed ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot/shimx64.efi + # Nombre OpenGnsys para cargador + cp ${EFISECONDSTAGE}/EFI/$EFISUBDIR/Boot/{shimx64.efi,ogloader.efi} +fi + +return $EVAL } @@ -912,11 +1050,15 @@ grub-install --force --root-directory=${SECONDSTAGE}${PREFIXSECONDSTAGE} $FIRSTS #@version 1.0.6b - correccion. Si no hay partición fisica para la SWAP, eliminar entrada del fstab. #@author Antonio J. Doblas Viso. Universidad de Malaga. #@date 2016-11-03 +#@version 1.1.1 - Se configura la partición ESP (para sistemas EFI) (ticket #802) +#@author Irina Gómez, ETSII Universidad de Sevilla +#@date 2018-12-13 #*/ ## function ogConfigureFstab () { # Variables locales. local FSTAB DEFROOT PARTROOT DEFSWAP PARTSWAP +local EFIDISK EFIPART EFIDEV EFIOPT # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -954,9 +1096,19 @@ else echo "No hay partición SWAP -> configuramos FSTAB" # Mensaje temporal. sed "/swap/d" ${FSTAB}.backup > ${FSTAB} fi -} +# Si es un sistema EFI incluimos partición ESP (Si existe la modificamos) +if ogIsEfiActive; then + read EFIDISK EFIPART <<< $(ogGetEsp) + EFIDEV=$(ogDiskToDev $EFIDISK $EFIPART) + # Opciones de la partición ESP: si no existe ponemos un valor por defecto + EFIOPT=$(awk '$1!~/#/ && $2=="/boot/efi" {print $3"\t"$4"\t"$5"\t"$6 }' ${FSTAB}) + [ "$EFIOPT" == "" ] && EFIOPT='vfat\tumask=0077\t0\t1' + sed -i /"boot\/efi"/d ${FSTAB} + echo -e "$EFIDEV\t/boot/efi\t$EFIOPT" >> ${FSTAB} +fi +} #/** # ogSetLinuxName int_ndisk int_nfilesys [str_name] @@ -1188,6 +1340,8 @@ function ogBurgHidePartitions () #@brief Configura el grub/burg para que oculte las particiones de windows que no se esten iniciando. #@param 1 Numero de disco #@param 2 Numero de particion +#@param 3 Numero de disco de la partición de datos (no ocultar) +#@param 4 Numero de particion de datos (no ocultar) #@return (nada) #@exception OG_ERR_FORMAT Formato incorrecto. #@exception No existe archivo de configuracion del grub/burg. @@ -1200,11 +1354,14 @@ function ogBurgHidePartitions () #@version 1.1.1 Se incluye comentarios en codigo para autodocuemtnacion con Doxygen #@author Antonio J. Doblas Viso, EVLT Univesidad de Malaga. #@date 2018-07-05 +#@version Se permite una partición de datos que no se ocultará. Soporta más de un disco. Compatible con grub.cfg creado por ogLive 5.0 +#@author Irina Gomez, ETSII Universidad de Sevilla +#@date 2019-08-26 #*/ function ogBootLoaderHidePartitions () { - local FUNC DIRMOUNT GFCFILE PARTTABLETYPE WINENTRY ENTRY PART TEXT LINE2 PART2 HIDDEN + local FUNC DIRMOUNT GFCFILE PARTTABLETYPE WINENTRY WINPART ENTRY LINE PART PARTDATA TEXT PARTHIDDEN HIDDEN # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -1217,11 +1374,13 @@ function ogBootLoaderHidePartitions () FUNC="${FUNC%%\ *}" # Error si no se reciben 2 parámetros. - [ $# -lt 2 ] && return $(ogRaiseError session $OG_ERR_FORMAT "$MSG_FORMAT: $FUNCNAME num_disk num_part"; echo $?) + [ $# -lt 2 ] && return $(ogRaiseError session $OG_ERR_FORMAT "$MSG_FORMAT: $FUNCNAME num_disk num_part [ num_disk_partdata num_partdata ]"; echo $?) + # Si no existe $4 pongo un valor imposible para la partición de datos + [ $# -eq 4 ] && PARTDATA=$(ogDiskToDev $3 $4) || PARTDATA=0 # Archivo de configuracion del grub DIRMOUNT=$(ogMount $1 $2) - # La función debe ser llamanda desde ogGrubHidePartitions or ogBurgHidePartitions. + # La función debe ser llamanda desde ogGrubHidePartitionsCdc or ogBurgHidePartitionsCdc. case "$FUNC" in ogGrubHidePartitions) CFGFILE="$DIRMOUNT/boot/grubMBR/boot/grub/grub.cfg" @@ -1230,7 +1389,7 @@ function ogBootLoaderHidePartitions () CFGFILE="$DIRMOUNT/boot/burg/burg.cfg" ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogGrubHidePartitions or ogBurgHidePartitions." + ogRaiseError $OG_ERR_FORMAT "Use ogGrubHidePartitionsCdc or ogBurgHidePartitionsCdc." return $? ;; esac @@ -1239,37 +1398,41 @@ function ogBootLoaderHidePartitions () [ -r $CFGFILE ] || return $(ogRaiseError log session $OG_ERR_NOTFOUND "$CFGFILE" 1>&2; echo $?) # Si solo hay una particion de Windows me salgo - [ $(fdisk -l $(ogDiskToDev $1) | grep 'NTFS' |wc -l) -eq 1 ] && return 0 + [ $(fdisk -l $(ogDiskToDev) | grep 'NTFS' |wc -l) -eq 1 ] && return 0 # Elimino llamadas a parttool, se han incluido en otras ejecuciones de esta funcion. sed -i '/parttool/d' $CFGFILE PARTTABLETYPE=$(ogGetPartitionTableType $1 | tr [:upper:] [:lower:]) + # /* (comentario de bloque para Doxygen) # Entradas de Windows: numero de linea y particion. De mayor a menor. - WINENTRY=$(awk '/menuentry.*Windows/ {gsub(/\)\"/, ""); print NR":"$6} ' $CFGFILE | sed -e '1!G;h;$!d' -e s/[a-z\/]//g) + WINENTRY=$(awk '/menuentry.*Windows/ {gsub(/\)\"/, ""); gsub(/^.*dev/,""); print NR":/dev"$1} ' $CFGFILE | sed -e '1!G;h;$!d') #*/ (comentario para bloque Doxygen) # Particiones de Windows, pueden no estar en el grub. - WINPART=$(fdisk -l $(ogDiskToDev $1)|awk '/NTFS/ {print substr($1,9,1)}' |sed '1!G;h;$!d') + WINPART=$(fdisk -l $(ogDiskToDev)|awk '/NTFS/ {print $1}'|sed '1!G;h;$!d') + + # Modifico todas las entradas de Windows. for ENTRY in $WINENTRY; do LINE=${ENTRY%:*} - PART=${ENTRY#*:} + PART=${ENTRY#*:} + # En cada entrada, oculto o muestro cada particion. TEXT="" - for PART2 in $WINPART; do - # Muestro solo la particion de la entrada actual. - [ $PART2 -eq $PART ] && HIDDEN="-" || HIDDEN="+" + for PARTHIDDEN in $WINPART; do + # Muestro la particion de la entrada actual y la de datos. + [ "$PARTHIDDEN" == "$PART" -o "$PARTHIDDEN" == "$PARTDATA" ] && HIDDEN="-" || HIDDEN="+" + read NUMDISK NUMPART <<< $(ogDevToDisk $PARTHIDDEN) - TEXT="\tparttool (hd0,$PARTTABLETYPE$PART2) hidden$HIDDEN \n$TEXT" + TEXT="\tparttool (hd$((NUMDISK-1)),$PARTTABLETYPE$NUMPART) hidden$HIDDEN \n$TEXT" done - + sed -i "${LINE}a\ $TEXT" $CFGFILE done # Activamos la particion que se inicia en todas las entradas de windows. sed -i "/chainloader/i\\\tparttool \$\{root\} boot+" $CFGFILE - } #/** @@ -1307,13 +1470,32 @@ function ogBurgDeleteEntry () } #/** +# ogRefindDeleteEntry num_disk_delete num_part_delete +#@brief ver ogBootLoaderDeleteEntry +#@see ogBootLoaderDeleteEntry +#*/ +function ogRefindDeleteEntry () +{ + local EFIDISK EFIPART + # Si se solicita, mostrar ayuda. + if [ "$*" == "help" ]; then + ogHelp "$FUNCNAME" "$FUNCNAME int_disk_delete int_npartition_delete" \ + "$FUNCNAME 2 1" + return + fi + read EFIDISK EFIPART <<< $(ogGetEsp) + ogBootLoaderDeleteEntry $EFIDISK $EFIPART $@ + return $? +} + +#/** # ogBootLoaderDeleteEntry num_disk num_part num_part_delete #@brief Borra en el grub las entradas para el inicio en una particion. #@param 1 Numero de disco donde esta el grub #@param 2 Numero de particion donde esta el grub #@param 3 Numero del disco del que borramos las entradas #@param 4 Numero de la particion de la que borramos las entradas -#@note Tiene que ser llamada desde ogGrubDeleteEntry o ogBurgDeleteEntry +#@note Tiene que ser llamada desde ogGrubDeleteEntry, ogBurgDeleteEntry o ogRefindDeleteEntry #@return (nada) #@exception OG_ERR_FORMAT Use ogGrubDeleteEntry or ogBurgDeleteEntry. #@exception OG_ERR_FORMAT Formato incorrecto. @@ -1325,11 +1507,11 @@ function ogBurgDeleteEntry () function ogBootLoaderDeleteEntry () { - local FUNC DIRMOUNT CFGFILE DEVICE MENUENTRY DELETEENTRY ENDENTRY ENTRY + local FUNC DIRMOUNT CFGFILE LABEL MENUENTRY DELETEENTRY ENDENTRY ENTRY # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogBurgDeleteEntry ogGrubDeleteEntry" + ogHelp "$FUNCNAME" "$MSG_SEE ogBurgDeleteEntry, ogGrubDeleteEntry or ogRefindDeleteEntry" return fi @@ -1343,7 +1525,7 @@ function ogBootLoaderDeleteEntry () # Archivo de configuracion del grub DIRMOUNT=$(ogMount $1 $2) - # La función debe ser llamanda desde ogGrubDeleteEntry or ogBurgDeleteEntry. + # La función debe ser llamanda desde ogGrubDeleteEntry, ogBurgDeleteEntry or ogRefindDeleteEntry. case "$FUNC" in ogGrubDeleteEntry) CFGFILE="$DIRMOUNT/boot/grubMBR/boot/grub/grub.cfg" @@ -1351,26 +1533,33 @@ function ogBootLoaderDeleteEntry () ogBurgDeleteEntry) CFGFILE="$DIRMOUNT/boot/burg/burg.cfg" ;; + ogRefindDeleteEntry) + CFGFILE="$DIRMOUNT/EFI/refind/refind.conf" + ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogGrubDeleteEntry or ogBurgDeleteEntry." + ogRaiseError $OG_ERR_FORMAT "Use ogGrubDeleteEntry, ogBurgDeleteEntry or ogRefindDeleteEntry." return $? ;; esac # Dispositivo - DEVICE=$(ogDiskToDev $3 $4) + if [ "$(basename $CFGFILE)" == "refind.conf" ]; then + LABEL=$(printf "Part-%02d-%02d" $3 $4) + else + LABEL=$(ogDiskToDev $3 $4) + fi - # Error si no existe archivo del grub) + # Error si no existe archivo de configuración [ -r $CFGFILE ] || ogRaiseError log session $OG_ERR_NOTFOUND "$CFGFILE" || return $? # Numero de linea de cada entrada. MENUENTRY="$(grep -n -e menuentry $CFGFILE| cut -d: -f1 | sed '1!G;h;$!d' )" # Entradas que hay que borrar. - DELETEENTRY=$(grep -n menuentry.*$DEVICE $CFGFILE| cut -d: -f1) + DELETEENTRY=$(grep -n menuentry.*$LABEL $CFGFILE| cut -d: -f1) # Si no hay entradas para borrar me salgo con aviso - [ "$DELETEENTRY" != "" ] || ogRaiseError log session $OG_ERR_NOTFOUND "Menuentry $DEVICE" || return $? + [ "$DELETEENTRY" != "" ] || ogRaiseError log session $OG_ERR_NOTFOUND "Menuentry $LABEL" || return $? # Recorremos el fichero del final hacia el principio. ENDENTRY="$(wc -l $CFGFILE|cut -d" " -f1)" @@ -1569,7 +1758,6 @@ EOF #Preparar configuración segunda etapa: crear entrada del sistema operativo grubSyntax "$KERNELPARAM" >> "$FILECFG" - #Instalar el burg burg-install --force --root-directory=${SECONDSTAGE} $FIRSTSTAGE 2>&1>/dev/null } @@ -1608,6 +1796,27 @@ function ogBurgDefaultEntry () return $? } + +#/** +# ogRefindDefaultEntry int_disk_default_entry int_npartition_default_entry +#@brief ver ogBootLoaderDefaultEntry +#@see ogBootLoaderDefaultEntry +#*/ ## +function ogRefindDefaultEntry () +{ + local EFIDISK EFIPART + # Si se solicita, mostrar ayuda. + if [ "$*" == "help" ]; then + ogHelp "$FUNCNAME" "$FUNCNAME int_disk_default_entry int_npartition_default_entry" \ + "$FUNCNAME 1 1" + return + fi + + read EFIDISK EFIPART <<< $(ogGetEsp) + ogBootLoaderDefaultEntry $EFIDISK $EFIPART $@ + return $? +} + #/** # ogBootLoaderDefaultEntry int_disk_CFG int_partition_CFG int_disk_default_entry int_npartition_default_entry #@brief Configura la entrada por defecto de Burg @@ -1631,11 +1840,11 @@ function ogBootLoaderDefaultEntry () { # Variables locales. -local PART CFGFILE DEFAULTENTRY MSG +local PART FUNC DIRMOUNT LABEL CFGFILE DEFAULTENTRY MENUENTRY MSG # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogGrubDefaultEntry ogBurgDefaultEntry" + ogHelp "$FUNCNAME" "$MSG_SEE ogGrubDefaultEntry, ogBurgDefaultEntry or ogRefindDefaultEntry." return fi @@ -1650,7 +1859,7 @@ FUNC="${FUNC%%\ *}" DIRMOUNT=$(ogMount $1 $2) || return $? # Comprobamos que exista fichero de configuración -# La función debe ser llamanda desde ogGrubDefaultEntry or ogBurgDefaultEntry. +# La función debe ser llamanda desde ogGrubDefaultEntry, ogBurgDefaultEntry or ogRefindDefaultEntry. case "$FUNC" in ogGrubDefaultEntry) CFGFILE="$DIRMOUNT/boot/grubMBR/boot/grub/grub.cfg" @@ -1658,8 +1867,11 @@ case "$FUNC" in ogBurgDefaultEntry) CFGFILE="$DIRMOUNT/boot/burg/burg.cfg" ;; + ogRefindDefaultEntry) + CFGFILE="$DIRMOUNT/EFI/refind/refind.conf" + ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogGrubDefaultEntry or ogBurgDefaultEntry." + ogRaiseError $OG_ERR_FORMAT "Use ogGrubDefaultEntry, ogBurgDefaultEntry or ogRefindDefaultEntry." return $? ;; esac @@ -1668,19 +1880,29 @@ esac [ -r $CFGFILE ] || ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $? # Dispositivo -DEVICE=$(ogDiskToDev $3 $4) +if [ "$(basename $CFGFILE)" == "refind.conf" ]; then + LABEL=$(printf "Part-%02d-%02d" $3 $4) +else + LABEL=$(ogDiskToDev $3 $4) +fi # Número de línea de la entrada por defecto en CFGFILE (primera de la partición). -DEFAULTENTRY=$(grep -n -m 1 menuentry.*$DEVICE $CFGFILE| cut -d: -f1) +DEFAULTENTRY=$(grep -n -m 1 menuentry.*$LABEL $CFGFILE| cut -d: -f1) # Si no hay entradas para borrar me salgo con aviso -[ "$DEFAULTENTRY" != "" ] || ogRaiseError session log $OG_ERR_NOTFOUND "No menuentry $DEVICE" || return $? +[ "$DEFAULTENTRY" != "" ] || ogRaiseError session log $OG_ERR_NOTFOUND "No menuentry $LABEL" || return $? # Número de la de linea por defecto en el menú de usuario MENUENTRY="$(grep -n -e menuentry $CFGFILE| cut -d: -f1 | grep -n $DEFAULTENTRY |cut -d: -f1)" -# Las líneas empiezan a contar desde cero -let MENUENTRY=$MENUENTRY-1 -sed --regexp-extended -i s/"set default=\"?[0-9]*\"?"/"set default=\"$MENUENTRY\""/g $CFGFILE + +if [ "$(basename $CFGFILE)" == "refind.conf" ]; then + sed -i /default_selection.*$/d $CFGFILE + sed -i "1 i\default_selection $MENUENTRY" $CFGFILE +else + # En grub y burg las líneas empiezan a contar desde cero + let MENUENTRY=$MENUENTRY-1 + sed --regexp-extended -i s/"set default=\"?[0-9]*\"?"/"set default=\"$MENUENTRY\""/g $CFGFILE +fi MSG="MSG_HELP_$FUNC" echo "${!MSG%%\.}: $@" } @@ -1719,6 +1941,28 @@ function ogBurgOgliveDefaultEntry () return $? } + +#/** +# ogRefindOgliveDefaultEntry +#@brief ver ogBootLoaderOgliveDefaultEntry +#@see ogBootLoaderOgliveDefaultEntry +#*/ ## +function ogRefindOgliveDefaultEntry () +{ + local EFIDISK EFIPART + # Si se solicita, mostrar ayuda. + if [ "$*" == "help" ]; then + ogHelp "$FUNCNAME" "$FUNCNAME" \ + "$FUNCNAME" + return + fi + + read EFIDISK EFIPART <<< $(ogGetEsp) + ogBootLoaderOgliveDefaultEntry $EFIDISK $EFIPART + return $? +} + + #/** # ogBootLoaderOgliveDefaultEntry #@brief Configura la entrada de ogLive como la entrada por defecto de Burg. @@ -1744,7 +1988,7 @@ local FUNC PART CFGFILE NUMENTRY MSG # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogGrubOgliveDefaultEntry ogBurgOgliveDefaultEntry" \ + ogHelp "$FUNCNAME" "$MSG_SEE ogGrubOgliveDefaultEntry, ogBurgOgliveDefaultEntry or ogRefindOgliveDefaultEntry" \ return fi @@ -1757,7 +2001,7 @@ FUNC="${FUNC%%\ *}" # Error si no puede montar sistema de archivos. PART=$(ogMount $1 $2) || return $? -# La función debe ser llamanda desde ogGrubOgliveDefaultEntry or ogBurgOgliveDefaultEntry. +# La función debe ser llamanda desde ogGrubOgliveDefaultEntry, ogBurgOgliveDefaultEntry or ogRefindOgliveDefaultEntry. case "$FUNC" in ogGrubOgliveDefaultEntry) CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg" @@ -1765,8 +2009,11 @@ case "$FUNC" in ogBurgOgliveDefaultEntry) CFGFILE="$PART/boot/burg/burg.cfg" ;; + ogRefindOgliveDefaultEntry) + CFGFILE="$PART/EFI/refind/refind.conf" + ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogGrubOgliveDefaultEntry or ogBurgOgliveDefaultEntry." + ogRaiseError $OG_ERR_FORMAT "Use ogGrubOgliveDefaultEntry, ogBurgOgliveDefaultEntry or ogRefindOgliveDefaultEntry." return $? ;; esac @@ -1780,8 +2027,14 @@ NUMENTRY=$(grep ^menuentry $CFGFILE| grep -n "OpenGnsys Live"|cut -d: -f1) # Si no existe entrada de ogLive nos salimos [ -z "$NUMENTRY" ] && (ogRaiseError $OG_ERR_NOTFOUND "menuentry OpenGnsys Live in $CFGFILE" || return $?) -let NUMENTRY=$NUMENTRY-1 -sed --regexp-extended -i s/"set default=\"?[0-9]+\"?"/"set default=\"$NUMENTRY\""/g $CFGFILE +if [ "$(basename $CFGFILE)" == "refind.conf" ]; then + sed -i /default_selection.*$/d $CFGFILE + + sed -i "1 i\default_selection $NUMENTRY" $CFGFILE +else + let NUMENTRY=$NUMENTRY-1 + sed --regexp-extended -i s/"set default=\"?[0-9]+\"?"/"set default=\"$NUMENTRY\""/g $CFGFILE +fi MSG="MSG_HELP_$FUNC" echo "${!MSG%%\.}: $@" @@ -1827,6 +2080,42 @@ function ogBurgSetTheme () } +#/** +# ogRefindSetTheme str_theme +#@brief ver ogBootLoaderSetTheme +#@see ogBootLoaderSetTheme +#*/ ## +function ogRefindSetTheme () { + local PART DIRTHEME CFGFILE + # Si se solicita, mostrar ayuda. + if [ "$*" == "help" ]; then + ogHelp "$FUNCNAME" "$FUNCNAME str_themeName" \ + "$FUNCNAME ThemeBasic" + echo -e "\nThemes in $OGLIB/refind:\n$(ls $OGLIB/refind/themes/ 2>/dev/null)" + + return + fi + + # Detectamos partición ESP + read EFIDISK EFIPART <<< $(ogGetEsp) + + PART=$(ogMount $EFIDISK $EFIPART) || return $? + DIRTHEME="$PART/EFI/refind/themes" + CFGFILE="$PART/EFI/refind/refind.conf" + + # Para utilizar ogBootLoaderSetTheme es necesario la entrada set theme_name + if [ -f $CFGFILE ]; then + sed -i '1 i\set theme_name=none' $CFGFILE + else + ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $? + fi + # Creamos el directorio para los temas + [ -d $DIRTHEME ] || mkdir $DIRTHEME + + ogBootLoaderSetTheme $EFIDISK $EFIPART $@ + return $? +} + #/** # ogBootLoaderSetTheme @@ -1837,21 +2126,26 @@ function ogBurgSetTheme () #@return #@exception OG_ERR_FORMAT Formato incorrecto. #@exception OG_ERR_PARTITION Partición errónea o desconocida (ogMount). -#@exception OG_ERR_NOTFOUND Fichero de configuración no encontrado: grub.cfg burg.cfg. +#@exception OG_ERR_NOTFOUND Fichero de configuración no encontrado: grub.cfg burg.cfg refind.conf. #@exception OG_ERR_NOTFOUND Entrada deltema no encontrada en burg.cfg. +#@exception OG_ERR_NOTFOUND Fichero de configuración del tema no encontrado: theme.conf (sólo refind). +#@note El tema debe situarse en OGLIB/BOOTLOADER/themes #@version 1.1.0 - Primeras pruebas con Burg. grub no soportado. #@author Antonio J. Doblas Viso. Universidad de Malaga #@date 2018-01-24 +#@version 1.1.1 - Soporta rEFInd (ticket #802 #888). +#@author Irina Gomez. Universidad de Sevilla +#@date 2019-03-22 #*/ ## function ogBootLoaderSetTheme () { # Variables locales. -local FUNC PART CFGFILE THEME NEWTHEME BOOTLOADER MSG +local FUNC PART CFGFILE THEME NEWTHEME BOOTLOADER MSG NEWTHEMECFG # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTheme ogBurgSetTheme" + ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTheme, ogBurgSetTheme or ogRefindSetTheme." return fi @@ -1864,27 +2158,32 @@ FUNC="${FUNC%%\ *}" -# Error si no se reciben 2 parametros. +# Error si no se reciben 3 parametros. [ $# -eq 3 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndiskSecondStage int_partitionSecondStage str_themeName" || return $? # Error si no puede montar sistema de archivos. PART=$(ogMount $1 $2) || return $? -# La función debe ser llamanda desde ogGrubSetTheme or ogBurgSetTheme. +# La función debe ser llamanda desde ogGrubSetTheme, ogBurgSetTheme or ogRefindSetTheme. case "$FUNC" in ogGrubSetTheme) - BOOTLOADER="grug" - BOOTLOADERDIR="grubMBR" + BOOTLOADER="grub" + BOOTLOADERDIR="boot/grubMBR" CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg" ogRaiseError $OG_ERR_FORMAT "ogGrubSetTheme not sopported" return $? ;; ogBurgSetTheme) BOOTLOADER="burg" - BOOTLOADERDIR="burg" + BOOTLOADERDIR="boot/burg" CFGFILE="$PART/boot/burg/burg.cfg" ;; + ogRefindSetTheme) + BOOTLOADER="refind" + BOOTLOADERDIR="EFI/refind" + CFGFILE="$PART/EFI/refind/refind.conf" + ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTheme or ogBurgSetTheme." + ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTheme, ogBurgSetTheme or ogRefindSetTheme." return $? ;; esac @@ -1894,22 +2193,29 @@ esac # Detectamos cual es el tema asignado THEME=$(grep "set theme_name=" $CFGFILE | grep ^set | cut -d= -f2) - # Si no existe entrada de theme_name nos salimos [ -z "$THEME" ] && (ogRaiseError $OG_ERR_NOTFOUND "theme_name in $CFGFILE" || return $?) #Actualizamos el tema del servidor a la particion if [ -d $OGLIB/$BOOTLOADER/themes/$NEWTHEME ]; then - cp -pr $OGLIB/$BOOTLOADER/themes/$NEWTHEME $PART/boot/$BOOTLOADERDIR/themes/ + # Para refind es necesario que exista theme.conf en el directorio del tema. + if [ "$BOOTLOADER" == "refind" ]; then + NEWTHEMECFG="$OGLIB/$BOOTLOADER/themes/$NEWTHEME/theme.conf" + [ -f $NEWTHEMECFG ] || ogRaiserError $OG_ERR_NOTFOUND "theme.conf" || return $? + grep -v "^#" $NEWTHEMECFG >> $CFGFILE + # eliminamos "set theme" es de grub y no de refind + sed -i '/theme_name/d' $CFGFILE + fi + cp -pr $OGLIB/$BOOTLOADER/themes/$NEWTHEME $PART/$BOOTLOADERDIR/themes/ fi #Verificamos que el tema esta en la particion -if ! [ -d $PART/boot/$BOOTLOADERDIR/themes/$NEWTHEME ]; then - ogRaiseError $OG_ERR_NOTFOUND "theme_name=$NEWTHEME in $PART/boot/$BOOTLOADERDIR/themes/" || return $? +if ! [ -d $PART/$BOOTLOADERDIR/themes/$NEWTHEME ]; then + ogRaiseError $OG_ERR_NOTFOUND "theme_name=$NEWTHEME in $PART/$BOOTLOADERDIR/themes/" || return $? fi #Cambiamos la entrada el fichero de configuración. -sed --regexp-extended -i s/"$THEME"/"$NEWTHEME"/g $CFGFILE +sed --regexp-extended -i s/"set theme_name=$THEME"/"set theme_name=$NEWTHEME"/g $CFGFILE } @@ -1993,7 +2299,7 @@ PART=$(ogMount $1 $2) || return $? # La función debe ser llamanda desde ogGrubSetAdminKeys or ogBurgSetAdminKeys. case "$FUNC" in ogGrubSetAdminKeys) - BOOTLOADER="grug" + BOOTLOADER="grub" BOOTLOADERDIR="grubMBR" CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg" ogRaiseError $OG_ERR_FORMAT "ogGrubSetAdminKeys not sopported" @@ -2068,6 +2374,25 @@ function ogBurgSetTimeOut () } +#/** +# ogRefindSetTimeOut int_timeout_second +#@brief ver ogBootLoaderSetTimeOut +#@see ogBootLoaderSetTimeOut +#*/ ## +function ogRefindSetTimeOut () +{ + local EFIDISK EFIPART + # Si se solicita, mostrar ayuda. + if [ "$*" == "help" ]; then + ogHelp "$FUNCNAME" "$FUNCNAME int_timeout_seconds" \ + "$FUNCNAME 50" + return + fi + + read EFIDISK EFIPART <<< $(ogGetEsp) + ogBootLoaderSetTimeOut $EFIDISK $EFIPART $@ + return $? +} #/** # ogBootLoaderSetTimeOut @@ -2092,7 +2417,7 @@ local FUNC PART CFGFILE TIMEOUT BOOTLOADER BOOTLOADERDIR CFGFILE MSG # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTimeOut ogBurgSetTimeOut" + ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetTimeOut, ogBurgSetTimeOut or ogRefindSetTimeOut" return fi @@ -2107,20 +2432,25 @@ FUNC="${FUNC%%\ *}" # Error si no puede montar sistema de archivos. PART=$(ogMount $1 $2) || return $? -# La función debe ser llamanda desde ogGrubSetTimeOut or ogBurgSetTimeOut. +# La función debe ser llamanda desde ogGrubSetTimeOut, ogBurgSetTimeOut or ogRefindSetTimeOut. case "$FUNC" in ogGrubSetTimeOut) - BOOTLOADER="grug" - BOOTLOADERDIR="grubMBR" + BOOTLOADER="grub" + BOOTLOADERDIR="boot/grubMBR" CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg" ;; ogBurgSetTimeOut) BOOTLOADER="burg" - BOOTLOADERDIR="burg" + BOOTLOADERDIR="boot/burg" CFGFILE="$PART/boot/burg/burg.cfg" ;; + ogRefindSetTimeOut) + BOOTLOADER="refind" + BOOTLOADERDIR="EFI/refind" + CFGFILE="$PART/EFI/refind/refind.conf" + ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTimeOut" + ogRaiseError $OG_ERR_FORMAT "Use ogGrubSetTimeOut, ogBurgSetTimeOut or ogRefindSetTimeOut." return $? ;; esac @@ -2129,7 +2459,11 @@ esac [ -f $CFGFILE ] || ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $? # Asignamos el timeOut. -sed -i s/timeout=.*$/timeout=$TIMEOUT/g $CFGFILE +if [ "$BOOTLOADER" == "refind" ]; then + sed -i s/timeout.*$/"timeout $TIMEOUT"/g $CFGFILE +else + sed -i s/timeout=.*$/timeout=$TIMEOUT/g $CFGFILE +fi } @@ -2195,7 +2529,7 @@ local FUNC PART CFGFILE RESOLUTION NEWRESOLUTION DEFAULTRESOLUTION BOOTLOADER BO # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetResolution ogBurgSetResolution" + ogHelp "$FUNCNAME" "$MSG_SEE ogGrubSetResolution, ogBurgSetResolution or ogRefindSetResolution." return fi @@ -2210,10 +2544,10 @@ FUNC="${FUNC%%\ *}" # Error si no puede montar sistema de archivos. PART=$(ogMount $1 $2) || return $? -# La función debe ser llamanda desde oogGrugSetResolution or ogBurgSetResolution. +# La función debe ser llamanda desde ogGrugSetResolution, ogBurgSetResolution or ogRefindSetResolution. case "$FUNC" in ogGrubSetResolution) - BOOTLOADER="grug" + BOOTLOADER="grub" BOOTLOADERDIR="grubMBR" CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg" ogRaiseError $OG_ERR_FORMAT "ogGrubSetResolution not sopported" @@ -2225,7 +2559,7 @@ case "$FUNC" in CFGFILE="$PART/boot/burg/burg.cfg" ;; *) - ogRaiseError $OG_ERR_FORMAT "Use ogBootLoaderSetResolution" + ogRaiseError $OG_ERR_FORMAT "Use GrugSetResolution, ogBurgSetResolution or ogRefindSetResolution." return $? ;; esac @@ -2271,61 +2605,190 @@ fi sed -i s/gfxmode=.*$/gfxmode=$NEWRESOLUTION/g $CFGFILE } + + + #/** -# ogRefindInstall int_ndisk bool_autoconfig +# ogBootLoaderSetResolution +#@brief Define la resolucion que usuara el thema del gestor de arranque +#@param int_resolution1 +#@param int_resolution2 (Opcional) +#@return +#@exception OG_ERR_FORMAT Formato incorrecto. +#@exception OG_ERR_PARTITION Partición errónea o desconocida (ogMount). +#@exception OG_ERR_NOTFOUND Fichero de configuración no encontrado: grub.cfg burg.cfg. +#*/ ## +function ogRefindSetResolution () { +local PART CFGFILE +# Si se solicita, mostrar ayuda. +if [ "$*" == "help" ]; then + ogHelp "$FUNCNAME" "$FUNCNAME int_resolution1 [int_resolution2]" \ + "$FUNCNAME 1366 768" \ + "$FUNCNAME 1" + return +fi + + # Error si no se reciben 2 parametros. +[ $# -ge 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_resolution1 [int_resolution2]" || return $? + +# Error si no puede montar sistema de archivos. +PART=$(ogMount $(ogGetEsp)) || return $? + +# Comprobamos que exista fichero de configuración +CFGFILE=$PART/EFI/refind/refind.conf +[ -f $CFGFILE ] || ogRaiseError $OG_ERR_NOTFOUND "$CFGFILE" || return $? + +# Borramos resolucion anterior y configuramos la nueva +sed -i /^resolution/d $CFGFILE + +sed -i "1 i\resolution $1 $2" $CFGFILE +} + +# ogRefindInstall bool_autoconfig #@brief Instala y actualiza el gestor rEFInd en la particion EFI -#@param int_ndisk #@param bolean_Check__auto_config true | false[default] #@return #@exception OG_ERR_FORMAT Formato incorrecto. +#@exception OG_ERR_NOTFOUND No se encuentra la partición ESP. +#@exception OG_ERR_NOTFOUND No se encuentra shimx64.efi.signed. +#@exception OG_ERR_NOTFOUND No se encuentra refind-install o refind en OGLIB +#@exception OG_ERR_PARTITION No se puede montar la partición ESP. +#@note Refind debe estar instalado en el ogLive o compartido en OGLIB #@version 1.1.0 - Primeras pruebas. #@author Juan Carlos Garcia. Universidad de ZAragoza. #@date 2017-06-26 +#@version 1.1.1 - Usa refind-install. Obtiene partición con ogGetEsp. Configura Part-X-Y y ogLive. +#@author Irina Gomez. Universidad de Sevilla. +#@date 2019-03-22 #*/ ## -function ogRefindInstall () -{ - +function ogRefindInstall () { # Variables locales. -local DISK EFIDIR CONFIG EFIPARTITIONID - +local CONFIG EFIDISK EFIPART EFIDEVICE EFIMNT EFIDIR SHIM REFINDDIR +local CACHEDEVICE OGLIVE OGLIVEDIR CMDLINE OGICON CFGFILE DEVICES +local LNXCFGFILE NUMENTRY DIR # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk boolean_autoconfig " \ - "$FUNCNAME 1 TRUE" + ogHelp "$FUNCNAME" "$FUNCNAME boolean_autoconfig " \ + "$FUNCNAME TRUE" return fi -# Error si no se recibe 1 parámetro. -[ $# -ge 1 ] || return $(ogRaiseError $OG_ERR_FORMAT; echo $?) - - -DISK=$1 -EFIDIR=/mnt/$(ogDiskToDev $1 1 | cut -c 6-8)$1/EFI -CONFIG=${2:-"FALSE"} -EFIPARTITIONID=$(ogGetPartitionId $1 1) -if [ "$EFIPARTITIONID" == "EF00" ] || [ "$EFIPARTITIONID" == "ef00" ]; then - cp -pr /opt/opengnsys/lib/refind ${EFIDIR} - case "$CONFIG" in - FALSE) - if [ -a ${EFIDIR}/ubuntu ]; then - echo "menuentry \"Ubuntu\" {" >> ${EFIDIR}/refind/refind.conf - echo "loader /EFI/ubuntu/grubx64.efi" >> ${EFIDIR}/refind/refind.conf - echo "icon /EFI/refind/icons/os_linux.png" >> ${EFIDIR}/refind/refind.conf - echo "}" >> ${EFIDIR}/refind/refind.conf - fi - if [ -a ${EFIDIR}/Microsoft ]; then - echo "menuentry \"Windows\" {" >> ${EFIDIR}/refind/refind.conf - echo "loader /EFI/Microsoft/Boot/bootmgfw.efi" >> ${EFIDIR}/refind/refind.conf - echo "}" >> ${EFIDIR}/refind/refind.conf - fi - ;; - TRUE) - cp ${EFIDIR}/refind/refind.conf.auto ${EFIDIR}/refind/refind.conf - ;; - esac +# Recogemos parametros +CONFIG=${1:-"FALSE"} + +read -e EFIDISK EFIPART <<< $(ogGetEsp) +EFIDEVICE=$(ogDiskToDev $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_NOTFOUND "ESP" || return $? +EFIMNT=$(ogMount $EFIDISK $EFIPART) || ogRaiseError $OG_ERR_PARTITION "$MSG_ERROR mount ESP" || return $? +EFIDIR="$EFIMNT/EFI" +[ -d $EFIDIR ] || mkdir $EFIDIR + +# Comprobamos que exista shimx64 +SHIM=$(ogGetPath /usr/lib/shim/shimx64.efi.signed) +[ "$SHIM" == "" ] && return $(ogRaiseError $OG_ERR_NOTFOUND "shimx64.efi.signed") + +# Si existe configuración anterior de refind la borro +[ -d "$EFIDIR/refind" ] && rm -rf $EFIDIR/refind + +# Instalamos rEFInd. +refind-install --yes --alldrivers --root $EFIMNT --shim $SHIM + +# Firmo refind con certificado de OpenGnsys +mv $EFIDIR/refind/grubx64.efi $EFIDIR/refind/grubx64.efi-unsigned +sbsign --key $OGETC/ssl/private/opengnsys.key --cert $OGETC/ssl/certs/opengnsys.crt --output $EFIDIR/refind/grubx64.efi $EFIDIR/refind/grubx64.efi-unsigned + +# Copio los certificados +cp /etc/refind.d/keys/* $EFIDIR/refind/keys +# Copio certificado opengnsys +cp $OGETC/ssl/certs/opengnsys.* $EFIDIR/refind/keys + +# Ponemos la entrada en NVRAM en el segundo lugar del orden de arranque +NEWORDER="$(ogNvramGetOrder|awk '{gsub(",", " "); printf "%x %x %s\n", $2, $1, substr($0, index($0,$3))}')" +ogNvramSetOrder $NEWORDER + +# Borramos configuración linux +[ -f $EFIMNT/boot/refind_linux.conf ] && mv $EFIMNT/boot/refind_linux.conf{,.ogbackup} + +# Eliminamos punto de motaje (por si ejecutamos más de una vez) +umount $EFIMNT/boot/efi + +# Para la configuración del ogLive +ogMountCache &>/dev/null +if [ $? -eq 0 ]; then + # Detectamos si hay ogLive + CACHEDEVICE=$(ogDiskToDev $(ogFindCache)) + OGLIVE=$(find $OGCAC/boot -name ogvmlinuz|head -1) + # Obtenemos parametros del kernel y sustituimos root + # La línea de opciones no puede contener la cadena initrd. + CMDLINE="$(cat /proc/cmdline|sed -e 's/^.*ogvmlinuz.efi //g' -e 's/^.*ogvmlinuz //g' -e 's|root=/dev/[a-z]* ||g' \ + -e 's/ogupdateinitrd=[a-z]* //g')" + CMDLINE="root=$CACHEDEVICE ${CMDLINE#*ogvmlinuz}" + + # Icono para la entrada de menú + OGICON=$(ls $OGLIB/refind/icons/so_opengnsys.png 2>/dev/null) + [ "$OGICON" == "" ] && OGICON="${EFIDIR}/refind/icons/os_unknown.png" + cp "$OGICON" "$OGCAC/.VolumeIcon.png" +fi + +# Configuramos rEFInd si es necesario +CFGFILE="${EFIDIR}/refind/refind.conf" +if [ "$CONFIG" == "TRUE" ]; then + echo -e "\n\n# Configuración OpenGnsys" >> $CFGFILE + # Excluimos dispositivos distintos de ESP y CACHE + DEVICES=$(blkid -s PARTUUID |awk -v D=$EFIDEVICE -v C=$CACHEDEVICE '$1!=D":" && $1!=C":" {gsub(/PARTUUID=/,"");gsub(/"/,""); aux = aux" "$2","} END {print aux}') + echo "dont_scan_volumes $DEVICES" >> $CFGFILE + # Excluimos en la ESP los directorios de los sistemas operativos + echo "dont_scan_dirs EFI/microsoft,EFI/ubuntu,EFI/grub" >> $CFGFILE + echo "use_graphics_for osx,linux,windows" >> $CFGFILE + echo "showtools reboot, shutdown" >> $CFGFILE + + # Configuramos ogLive + if [ "$OGLIVE" != "" ]; then + # Cambiamos nombre de kernel e initrd para que lo detecte refind + OGLIVEDIR="$(dirname $OGLIVE)" + cp "$OGLIVE" "${OGLIVE}.efi" + cp "$OGLIVEDIR/oginitrd.img" "$OGLIVEDIR/initrd.img" + + # Incluimos el directorio de ogLive. + echo "also_scan_dirs +,boot/$(basename $OGLIVEDIR)" >> $CFGFILE + # Fichero de configuración de refind para kernel de linux. + LNXCFGFILE="$OGLIVEDIR/refind_linux.conf" + echo "\"OpenGnsys Live\" \"$CMDLINE\"" > $LNXCFGFILE + + # Ponemos ogLive como la entrada por defecto + NUMENTRY=$(ls -d $EFIDIR/Part-??-??|wc -l) + echo "default_selection $((NUMENTRY+1))" >> $CFGFILE + fi else -$(ogRaiseError $OG_ERR_FORMAT; echo $?) + # Renombramos la configuración por defecto + mv $CFGFILE ${CFGFILE}.auto + + # Creamos nueva configuración + echo "# Configuración OpenGnsys" >> $CFGFILE + echo "timeout 20" > $CFGFILE + echo "showtools reboot, shutdown" >> $CFGFILE + echo -e "scanfor manual\n" >> $CFGFILE + # Configuración para sistemas restaurados con OpenGnsys + for DIR in $(ls -d /mnt/sda1/EFI/Part-*-* 2>/dev/null); do + echo "menuentry \"${DIR##*/}\" {" >> $CFGFILE + echo " loader /EFI/${DIR##*/}/Boot/ogloader.efi" >> $CFGFILE + [ -f $DIR/Boot/bootmgfw.efi ] && echo " icon /EFI/refind/icons/os_win8.png" >> $CFGFILE + [ -f $DIR/Boot/grubx64.efi ] && echo " icon /EFI/refind/icons/os_linux.png" >> $CFGFILE + echo "}" >> $CFGFILE + done + # Configuración ogLive + # Comantamos temporalmente: Con la versión nueva de refind falla + #if [ "$OGLIVE" != "" ]; then + # echo "menuentry \"OpenGnsys Live\" {" >> $CFGFILE + # echo " volume CACHE" >> $CFGFILE + # echo " ostype Linux" >> $CFGFILE + # echo " loader /boot/$(basename ${OGLIVE%/*})/ogvmlinuz" >> $CFGFILE + # echo " initrd /boot/$(basename ${OGLIVE%/*})/oginitrd.img" >> $CFGFILE + # echo " options \"$CMDLINE\"" >> $CFGFILE + # echo "}" >> $CFGFILE + + # # Ponemos ogLive como la entrada por defecto + # sed -i '1 i\default_selection "OpenGnsys Live"' $CFGFILE + #fi fi } - |