diff options
author | adv <adv@uma.es> | 2019-12-09 16:55:33 +0100 |
---|---|---|
committer | adv <adv@uma.es> | 2019-12-09 21:09:55 +0100 |
commit | 20c44413e5b4bb31223e43f7750f001cae86c4f6 (patch) | |
tree | 5dca3432b52834c0a5d10e15c171957f6cfb3669 /client | |
parent | 0be201458ad4f35f8a1aedaea8d042bbeead9228 (diff) |
#938 ogBurgInstallMbr() add control error for PC with MSDOS partition
Diffstat (limited to 'client')
-rwxr-xr-x | client/engine/Boot.lib | 43 |
1 files changed, 20 insertions, 23 deletions
diff --git a/client/engine/Boot.lib b/client/engine/Boot.lib index f0e5f7d0..875fa29b 100755 --- a/client/engine/Boot.lib +++ b/client/engine/Boot.lib @@ -1609,7 +1609,7 @@ function ogBurgInstallMbr () { # Variables locales. -local BINARYAVAILABLE PART DISK FIRSTAGE SECONSTAGE PREFIXSECONDSTAGE CHECKOS KERNELPARAM BACKUPNAME FILECFG +local BINARYAVAILABLE PART DISK DEVICE MOUNTDISK FIRSTAGE SECONSTAGE PREFIXSECONDSTAGE CHECKOS KERNELPARAM BACKUPNAME FILECFG # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then @@ -1637,27 +1637,30 @@ CHECKOS=${3:-"FALSE"} KERNELPARAM=$4 BACKUPNAME=".backup.og" -#Error si no es linux. -ogCheckStringInGroup $(ogGetFsType $DISK $PART) "CACHE EXT4 EXT3 EXT2" || return $(ogRaiseError $OG_ERR_PARTITION "burg no soporta esta particion"; echo $?) - - -#La primera etapa del grub se fija en el primer disco duro +#Controlar disco no uefi +ogIsEfiActive && return $(ogRaiseError $OG_ERR_NOTBIOS " : grub4dos solo soporta PC con bios legacy"; echo $?) +#Controlar particionado tipo msdos +ogCheckStringInGroup $(ogGetPartitionTableType $DISK) "MSDOS" || return $(ogRaiseError $OG_ERR_NOMSDOS ": grub2dos requiere particionado tipo MSDOS"; echo $?) +#Controlar existencia de disco y particion +DEVICE=$(ogDiskToDev $DISK) || ogRaiseError $OG_ERR_NOTFOUND || return $? +MOUNTDISK=$(ogMount $DISK $PART) || ogRaiseError $OG_ERR_PARTITION "$MSG_ERROR " || return $? +#Controlar particion segunda etapa del burg +ogCheckStringInGroup $(ogGetFsType $DISK $PART) "CACHE EXT4 EXT3 EXT2" || return $(ogRaiseError $OG_ERR_PARTITION "burg.cfg soporta solo particiones linux"; echo $?) +#Controlar acceso de escritura a la particion segunda etapa del burg +ogIsReadonly $DISK $PART && return $(ogRaiseError $OG_ERR_NOTWRITE ": $DISK $PART" || echo $?) + +#Asigar la primera etapa del grub en el primer disco duro FIRSTSTAGE=$(ogDiskToDev 1) - -#localizar disco segunda etapa del grub +#Localizar disco segunda etapa del grub SECONDSTAGE=$(ogMount $DISK $PART) -# prepara el directorio principal de la segunda etapa (y copia los binarios) +#Preparar el directorio principal de la segunda etapa (y copia los binarios) [ -d ${SECONDSTAGE}/boot/burg/ ] || mkdir -p ${SECONDSTAGE}/boot/burg/; cp -prv /boot/burg/* ${SECONDSTAGE}/boot/burg/ 2>&1>/dev/null; cp -prv $OGLIB/burg/themes ${SECONDSTAGE}/boot/burg/ 2>&1>/dev/null; #*/ ## (comentario Dogygen) #*/ ## (comentario Dogygen) - -#Copiamos el tema +#Copiar el tema de opengnsys mkdir -p ${SECONDSTAGE}/boot/burg/themes/OpenGnsys cp -prv "$OGLIB/burg/themes" "${SECONDSTAGE}/boot/burg/" 2>&1>/dev/null -#Localizar directorio segunda etapa del grub -#PREFIXSECONDSTAGE="/boot/burg/" - -# Si Reconfigurar segunda etapa (grub.cfg) == FALSE +# No configurar la segunda etapa (grub.cfg). Parámetro FALSE if [ -f ${SECONDSTAGE}/boot/burg/burg.cfg -o -f ${SECONDSTAGE}/boot/burg/burg.cfg$BACKUPNAME ]; then if [ "$CHECKOS" == "false" -o "$CHECKOS" == "FALSE" ] @@ -1667,24 +1670,19 @@ then fi fi -# SI Reconfigurar segunda etapa (burg.cfg) == TRUE +# Configurrar la segunda etapa (burg.cfg) == tercer parámetro TRUE -#llamada a updateBootCache para que aloje la primera fase del ogLive +#llamar a updateBootCache para que aloje la primera fase del ogLive updateBootCache #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/burg/ - #Preparar configuración segunda etapa: crear cabecera del fichero -#/etc/burg.d/00_header > ${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/burg/burg.cfg - FILECFG=${SECONDSTAGE}${PREFIXSECONDSTAGE}/boot/burg/burg.cfg - #/* ## (comentario Dogygen) cat > "$FILECFG" << EOF @@ -1772,7 +1770,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 } |