diff options
author | Irina Gómez <irinagomez@us.es> | 2019-04-03 09:59:14 +0200 |
---|---|---|
committer | Irina Gómez <irinagomez@us.es> | 2019-04-03 09:59:14 +0200 |
commit | da53464c601bdab21e4155e21c7e2db76474cd5f (patch) | |
tree | ba1549c514e286be0b4a5c11b948c2bd0785172f | |
parent | 5c2fe9b80b8cc48d9ac2c72b14f7c7ecfc3e9e03 (diff) |
ogRefindInstall, with paremeter FALSE, does not configure menu entry of directory microsoft or ubuntu. Fixs PXE template of refind. Creates auxiliary functions for rEFInd.
-rwxr-xr-x | client/engine/Boot.lib | 297 | ||||
-rw-r--r-- | client/shared/etc/lang.ca_ES.conf | 7 | ||||
-rw-r--r-- | client/shared/etc/lang.en_GB.conf | 7 | ||||
-rw-r--r-- | client/shared/etc/lang.es_ES.conf | 7 | ||||
-rw-r--r-- | server/tftpboot/grub/templates/refind | 2 |
5 files changed, 254 insertions, 66 deletions
diff --git a/client/engine/Boot.lib b/client/engine/Boot.lib index d98b972f..396b92d7 100755 --- a/client/engine/Boot.lib +++ b/client/engine/Boot.lib @@ -1386,7 +1386,7 @@ function ogBootLoaderHidePartitions () # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$MSG_SEE ogGrubHidePartitions ogBurgHidePartitions" + ogHelp "$FUNCNAME" "$MSG_SEE ogGrubHidePartitions or ogBurgHidePartitions." return fi @@ -1485,13 +1485,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. @@ -1503,11 +1522,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 @@ -1521,7 +1540,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" @@ -1529,26 +1548,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)" @@ -1785,6 +1811,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 @@ -1808,11 +1855,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 @@ -1827,7 +1874,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" @@ -1835,8 +1882,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 @@ -1845,19 +1895,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%%\.}: $@" } @@ -1896,6 +1956,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. @@ -1921,7 +2003,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 @@ -1934,7 +2016,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" @@ -1942,8 +2024,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 @@ -1957,8 +2042,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%%\.}: $@" @@ -2005,7 +2096,7 @@ function ogBurgSetTheme () #/** -# ogRefindSetTheme int_ndiskESP int_partitionESP str_theme +# ogRefindSetTheme str_theme #@brief ver ogBootLoaderSetTheme #@see ogBootLoaderSetTheme #*/ ## @@ -2013,27 +2104,30 @@ function ogRefindSetTheme () { local PART DIRTHEME CFGFILE # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then - ogHelp "$FUNCNAME" "$FUNCNAME int_ndiskESP int_partitionESP str_themeName" \ - "$FUNCNAME 1 1 ThemeBasic" - echo -e "\nThemes in $OGLIB/refind:\n$(ls $OGLIB/refind/themes/)" + ogHelp "$FUNCNAME" "$FUNCNAME str_themeName" \ + "$FUNCNAME ThemeBasic" + echo -e "\nThemes in $OGLIB/refind:\n$(ls $OGLIB/refind/themes/ 2>/dev/null)" return fi - PART=$(ogMount $1 $2) || return $? + # 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 '/showtools/i\set theme_name=none' $CFGFILE + 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 $@ + ogBootLoaderSetTheme $EFIDISK $EFIPART $@ return $? } @@ -2066,7 +2160,7 @@ 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 @@ -2084,10 +2178,10 @@ FUNC="${FUNC%%\ *}" # 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" + BOOTLOADER="grub" BOOTLOADERDIR="boot/grubMBR" CFGFILE="$PART/boot/grubMBR/boot/grub/grub.cfg" ogRaiseError $OG_ERR_FORMAT "ogGrubSetTheme not sopported" @@ -2220,7 +2314,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" @@ -2295,6 +2389,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 @@ -2319,7 +2432,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 @@ -2334,20 +2447,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 @@ -2356,7 +2474,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 } @@ -2422,7 +2544,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 @@ -2437,10 +2559,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" @@ -2452,7 +2574,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 @@ -2498,6 +2620,45 @@ fi sed -i s/gfxmode=.*$/gfxmode=$NEWRESOLUTION/g $CFGFILE } + + + +#/** +# 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 bolean_Check__auto_config true | false[default] @@ -2522,7 +2683,7 @@ local CONFIG EFIDISK EFIPART EFIDEVICE EFIMNT EFIDIR SHIM DIRREFIND CFGFILE DIR # Si se solicita, mostrar ayuda. if [ "$*" == "help" ]; then ogHelp "$FUNCNAME" "$FUNCNAME boolean_autoconfig " \ - "$FUNCNAME 1 TRUE" + "$FUNCNAME TRUE" return fi @@ -2556,27 +2717,33 @@ else fi # Configuramos rEFInd si es necesario -if [ "$CONFIG" == "FALSE" ]; then +CFGFILE="${EFIDIR}/refind/refind.conf" +#if [ "$CONFIG" == "TRUE" ]; then +if [ "$CONFIG" == "TRUE" ]; then + echo "dont_scan_dirs /EFI/microsoft, /EFI/ubuntu, /EFI/fedora, /EFI/opensuse" >> $CFGFILE +else # Renombramos la configuración por defecto - mv ${EFIDIR}/refind/refind.conf ${EFIDIR}/refind/refind.conf.auto + mv $CFGFILE ${CFGFILE}.auto # Creamos nueva configuración - CFGFILE="${EFIDIR}/refind/refind.conf" echo "timeout 20" > $CFGFILE echo "showtools reboot, shutdown" >> $CFGFILE echo -e "scanfor manual\n" >> $CFGFILE - if [ -a ${EFIDIR}/Microsoft ]; then - echo "menuentry \"Windows\" {" >> $CFGFILE - echo " loader /EFI/Microsoft/Boot/bootmgfw.efi" >> $CFGFILE - echo " icon /EFI/refind/icons/os_win8.png" >> $CFGFILE - echo "}" >> $CFGFILE - fi - if [ -a ${EFIDIR}/ubuntu ]; then - echo "menuentry \"Ubuntu\" {" >> $CFGFILE - echo " loader /EFI/ubuntu/grubx64.efi" >> $CFGFILE - echo " icon /EFI/refind/icons/os_ubuntu.png" >> $CFGFILE - echo "}" >> $CFGFILE - fi + # Configuración para Windows + #if [ -a ${EFIDIR}/Microsoft ]; then + # echo "menuentry \"Windows\" {" >> $CFGFILE + # echo " loader /EFI/Microsoft/Boot/bootmgfw.efi" >> $CFGFILE + # echo " icon /EFI/refind/icons/os_win8.png" >> $CFGFILE + # echo "}" >> $CFGFILE + #fi + # Configuración para Ubuntu + #if [ -a ${EFIDIR}/ubuntu ]; then + # echo "menuentry \"Ubuntu\" {" >> $CFGFILE + # echo " loader /EFI/ubuntu/grubx64.efi" >> $CFGFILE + # echo " icon /EFI/refind/icons/os_ubuntu.png" >> $CFGFILE + # echo "}" >> $CFGFILE + #fi + # 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 @@ -2591,7 +2758,7 @@ if [ "$CONFIG" == "FALSE" ]; then # Obtenemos parametros del kernel y sustituimos root CMDLINE="$(cat /proc/cmdline)" CMDLINE="root=$(ogDiskToDev $CACDISK $CACPART) ${CMDLINE#*ogvmlinuz}" - echo "menuentry \"OpenGnsys Client\" {" >> $CFGFILE + echo "menuentry \"OpenGnsys Live\" {" >> $CFGFILE echo " volume CACHE" >> $CFGFILE echo " ostype Linux" >> $CFGFILE echo " loader /boot/$(basename ${OGLIVE%/*})/ogvmlinuz" >> $CFGFILE @@ -2601,7 +2768,7 @@ if [ "$CONFIG" == "FALSE" ]; then echo "}" >> $CFGFILE # Ponemos ogLive como la entrada por defecto - sed -i '/showtools/i\default_selection "OpenGnsys Client"' $CFGFILE + sed -i '1 i\default_selection "OpenGnsys Live"' $CFGFILE fi fi } diff --git a/client/shared/etc/lang.ca_ES.conf b/client/shared/etc/lang.ca_ES.conf index 7dd96c72..517a1911 100644 --- a/client/shared/etc/lang.ca_ES.conf +++ b/client/shared/etc/lang.ca_ES.conf @@ -247,6 +247,13 @@ MSG_HELP_ogMount="Monta un sistema de archivos y devuelve el punto de montaje." MSG_HELP_ogRaiseError="Muestra y registra mensajes de error y devuelve el código correspondiente." MSG_HELP_ogReduceFs="Reduce el tamaño del sistema de archivos al mínimo ocupado por sus datos." MSG_HELP_ogReduceImage="Reduce el tamaño de la imagen" +MSG_HELP_ogRefindDeleteEntry="Borra en rEFInd las entradas para el inicio en una particion." +MSG_HELP_ogRefindDefaultEntry="Configura la entrada por defecto de rEFInd." +MSG_HELP_ogRefindOgliveDefaultEntry="Configura la entrada de ogLive como la entrada por defecto de rEFInd." +MSG_HELP_ogRefindSetTheme="Asigna un tema al rEFInd." +MSG_HELP_ogRefindSetTimeOut="Define el tiempo (segundos) que se muestran las opciones de inicio de rEFInd." +MSG_HELP_ogRefindSetResolution="Define la resolución que usuará el thema del gestor de arranque rEFInd." +MSG_HELP_ogRefindInstall="Instala y configura el gestor rEFInd en la particion EFI" MSG_HELP_ogRestoreAclImage="" MSG_HELP_ogRestoreBootLoaderImage="" MSG_HELP_ogRestoreDiskImage="Restaura una imagen de un disco completo." diff --git a/client/shared/etc/lang.en_GB.conf b/client/shared/etc/lang.en_GB.conf index 9059e573..c16926d6 100644 --- a/client/shared/etc/lang.en_GB.conf +++ b/client/shared/etc/lang.en_GB.conf @@ -250,6 +250,13 @@ MSG_HELP_ogMount="Mounts file system and returns mount point." MSG_HELP_ogRaiseError="Displays and registers error messages and returns code." MSG_HELP_ogReduceFs="Reduces file system size to minimum." MSG_HELP_ogReduceImage="Reduces image size." +MSG_HELP_ogRefindDeleteEntry="Deletes the menu entry of a partition in rEFInd." +MSG_HELP_ogRefindDefaultEntry="Configures default menu entry in rEFInd."" +MSG_HELP_ogRefindOgliveDefaultEntry="Configures ogLive menu entry as default menu entry in rEFInd." +MSG_HELP_ogRefindSetTheme="Configures rEFInd's theme." +MSG_HELP_ogRefindSetTimeOut="Defines the time that rEFInd shows the menu." +MSG_HELP_ogRefindSetResolution="Defines the resolucion of rEFInd's theme." +MSG_HELP_ogRefindInstall="Installs and configures rEFInd boot loader in ESP." MSG_HELP_ogRestoreAclImage="Restores Windows ACL (Inf. must be on /tmp)." MSG_HELP_ogRestoreBootLoaderImage="" MSG_HELP_ogRestoreDiskImage="Restores disk image." diff --git a/client/shared/etc/lang.es_ES.conf b/client/shared/etc/lang.es_ES.conf index 7766e923..e82f84e8 100644 --- a/client/shared/etc/lang.es_ES.conf +++ b/client/shared/etc/lang.es_ES.conf @@ -247,6 +247,13 @@ MSG_HELP_ogMount="Monta un sistema de archivos y devuelve el punto de montaje." MSG_HELP_ogRaiseError="Muestra y registra mensajes de error y devuelve el código correspondiente." MSG_HELP_ogReduceFs="Reduce el tamaño del sistema de archivos al mínimo ocupado por sus datos." MSG_HELP_ogReduceImage="Reduce el tamaño de la imagen" +MSG_HELP_ogRefindDeleteEntry="Borra en rEFInd las entradas para el inicio en una particion." +MSG_HELP_ogRefindDefaultEntry="Configura la entrada por defecto de rEFInd." +MSG_HELP_ogRefindOgliveDefaultEntry="Configura la entrada de ogLive como la entrada por defecto de rEFInd." +MSG_HELP_ogRefindSetTheme="Asigna un tema al rEFInd." +MSG_HELP_ogRefindSetTimeOut="Define el tiempo (segundos) que se muestran las opciones de inicio de rEFInd." +MSG_HELP_ogRefindSetResolution="Define la resolución que usuará el thema del gestor de arranque rEFInd." +MSG_HELP_ogRefindInstall="Instala y configura el gestor rEFInd en la particion EFI" MSG_HELP_ogRestoreAclImage="Restaura las ACL de Windows (La informacion debe estar copiada en /tmp)." MSG_HELP_ogRestoreBootLoaderImage="" MSG_HELP_ogRestoreDiskImage="Restaura una imagen de un disco completo." diff --git a/server/tftpboot/grub/templates/refind b/server/tftpboot/grub/templates/refind index 4ada28d0..e37d0ac1 100644 --- a/server/tftpboot/grub/templates/refind +++ b/server/tftpboot/grub/templates/refind @@ -1,4 +1,4 @@ ##NO-TOCAR-ESTA-LINEA refind root='hd0,gpt1' -chainloader /EFI/refind/shimx64.efi +chainloader /EFI/refind/grubx64.efi boot |