source: client/engine/UEFI.lib @ a31f7a9

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacion
Last change on this file since a31f7a9 was a31f7a9, checked in by Irina Gómez <irinagomez@…>, 6 years ago

#802 #889 ogHidePartition and ogUnhidePartition: Add Windows and Windows Reserved Partitions. ogSaveImageInfo and ogRestoreUuidPartitions: Only save/restore GUID Partition Table.

  • Property mode set to 100644
File size: 10.5 KB
Line 
1#!/bin/bash
2# Libreria provisional para uso de UEFI
3# Las funciones se incluirán las librerías ya existentes
4
5#/**
6#         ogGrubUefiConf int_ndisk int_part str_dir_grub
7#@brief   Genera el fichero grub.cfg de la ESP
8#@param   int_ndisk    nº de orden del disco
9#@param   int_part     nº de partición
10#@param   str_dir_grub nombre del directorio de grub en la partición de sistema. ej: grubPARTITION
11#@return  (nada, por determinar)
12#@exception OG_ERR_FORMAT    formato incorrecto.
13#@exception OG_ERR_NOTFOUND  fichero o dispositivo no encontrado.
14#@TODO    Confirmar si el fichero "$EFIDIR/EFI/$BOOTLABEL/grub.cfg" es necesario.
15#*/ ##
16function ogGrubUefiConf () {
17local EFIDIR BOOTLABEL GRUBEFI UUID DEVICE DIRGRUB
18
19# Si se solicita, mostrar ayuda.
20if [ "$*" == "help" ]; then
21    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part [ str_dir_grub ]" \
22           "$FUNCNAME 1 2" \
23           "$FUNCNAME 1 3 grubPARTITION/boot/grub"
24    return
25fi
26
27# Error si no se reciben al menos 2 parámetros.
28[ $# -ge 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part [ str_dir_grub ]" || return $?
29
30# Directorio del grub en la partición de sistema
31DIRGRUB="${3:-boot/grub}"
32
33EFIDIR=$(ogMount $(ogGetEsp)) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
34BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
35GRUBDIR="$EFIDIR/EFI/$BOOTLABEL/boot/grub"
36# Comprobamos que existe directorio
37[ -d "$GRUBDIR" ] || mkdir -p "$GRUBDIR"
38# Parcheamos uuid y particion en grub.cfg
39UUID=$(blkid -o value -s UUID $(ogDiskToDev $1 $2))
40DEVICE="hd$(expr $1 - 1 ),gpt$2"
41
42cat << EOT > $GRUBDIR/grub.cfg
43set root='$DEVICE'
44set prefix=(\$root)'/$DIRGRUB'
45configfile \$prefix/grub.cfg
46EOT
47
48# Provisional: confirmar si el segundo archivo se utiliza
49cp $GRUBDIR/grub.cfg "$EFIDIR/EFI/$BOOTLABEL/grub.cfg"
50}
51
52#/**
53#         ogUuidChange int_ndisk str_repo
54#@brief   Reemplaza el UUID de un sistema de ficheros.
55#@param   int_ndisk    nº de orden del disco
56#@param   int_part     nº de partición
57#@return  (nada, por determinar)
58#@exception OG_ERR_FORMAT    formato incorrecto.
59#@exception OG_ERR_NOTFOUND  fichero o dispositivo no encontrado.
60#@TODO    Se utiliza el comando uuidgen que no existe en el ogLive
61#*/ ##
62function ogUuidChange () {
63local MNTDIR DEVICE UUID NEWUUID f
64
65# Si se solicita, mostrar ayuda.
66if [ "$*" == "help" ]; then
67    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part" \
68           "$FUNCNAME 1 2"
69    return
70fi
71
72# Error si no se reciben al menos 2 parámetros.
73[ $# -eq 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part" || return $?
74
75# Comprobamos que exista la partición
76MNTDIR=$(ogMount $1 $2) || ogRaiseError $OG_ERR_NOTFOUND "Device $1 $2" || return $?
77DEVICE=$(ogDiskToDev $1 $2)
78UUID=$(blkid -o value -s UUID $DEVICE)
79NEWUUID=$(uuidgen)
80
81# Cambiamos UUID a la partición
82ogUnmount $1 $2
83tune2fs $DEVICE -U $NEWUUID
84
85# Cambiamos UUID en la configuración (fstab y grub)
86ogMount $1 $2
87for f in $MNTDIR/etc/fstab $MNTDIR/{,boot/}{{grubMBR,grubPARTITION}/boot/,}{grub{,2},{,efi/}EFI/*}/{menu.lst,grub.cfg}; do
88        [ -r $f ] && echo sed -i s/$UUID/$NEWUUID/g $f
89        [ -r $f ] && sed -i s/$UUID/$NEWUUID/g $f
90done
91}
92
93#/**
94#         ogCopyEfiBootLoader int_ndisk str_repo path_image
95#@brief   Copia el cargador de arranque desde la partición EFI a la de sistema.
96#@param   int_ndisk    nº de orden del disco
97#@param   int_part     nº de partición
98#@return  (nada, por determinar)
99#@exception OG_ERR_FORMAT    formato incorrecto.
100#@exception OG_ERR_NOTFOUND  fichero o dispositivo no encontrado.
101#@note    Si existe el cargador en la partición de sistema no es válido
102#*/ ##
103function ogCopyEfiBootLoader () {
104# Variables locales
105local MNTDIR EFIDIR BOOTLABEL OSVERSION LOADER f
106
107# Si se solicita, mostrar ayuda.
108if [ "$*" == "help" ]; then
109    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part" \
110           "$FUNCNAME 1 2"
111    return
112fi
113
114# Error si no se reciben 2 arámetros.
115[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part" || return $?
116
117# Comprobamos que exista partición de sistema y la  ESP
118MNTDIR=$(ogMount $1 $2) || ogRaiseError $OG_ERR_PARTITION "$DISK $PART" || return $?
119EFIDIR=$(ogMount $(ogGetEsp)) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
120
121# Comprobamos que exista el cargador
122BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
123OSVERSION=$(ogGetOsVersion $1 $2)
124case $OSVERSION in
125    *Windows\ 10*)
126        for f in $EFIDIR/EFI/{$BOOTLABEL,Microsoft}/Boot/bootmgfw.efi; do
127            [ -r $f ] && LOADER=$f
128        done
129        [ -n "$LOADER" ] || ogRaiseError $OG_ERR_NOTOS "$1 $2 ($OSVERSION, EFI)" || return $?
130        # Si existe el directorio Boot lo borramos
131        [ -d $MNTDIR/Boot ] && rm -rf $MNTDIR/Boot
132        DIRLOADER=$(realpath "${LOADER%/*}/..")
133        cp -r ${DIRLOADER}/Boot $MNTDIR
134        ;;
135esac
136}
137
138#/**
139#         ogRestoreEfiBootLoader int_ndisk str_repo
140#@brief   Copia el cargador de arranque de la partición de sistema a la partición EFI.
141#@param   int_ndisk    nº de orden del disco
142#@param   int_part     nº de partición
143#@return  (nada, por determinar)
144#@exception OG_ERR_FORMAT    formato incorrecto.
145#@exception OG_ERR_NOTFOUND  fichero o dispositivo no encontrado (partición de sistema o EFI).
146#@exception OG_ERR_NOTOS     sin sistema operativo.
147#@note    Si existe el cargador en la partición de sistema puede no ser válido
148#*/ ##
149function ogRestoreEfiBootLoader () {
150# Variables locales
151local MNTDIR EFIDIR BOOTLABEL OSVERSION LOADER f UUID DEVICE
152
153# Si se solicita, mostrar ayuda.
154if [ "$*" == "help" ]; then
155    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part" \
156           "$FUNCNAME 1 2"
157    return
158fi
159
160# Error si no se reciben 2 arámetros.
161[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part" || return $?
162
163# Comprobamos que exista partición de sistema y la  ESP
164MNTDIR=$(ogMount $1 $2) || ogRaiseError $OG_ERR_PARTITION "$DISK $PART" || return $?
165EFIDIR=$(ogMount $(ogGetEsp)) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
166
167# Comprobamos que exista el cargador
168#BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
169OSVERSION=$(ogGetOsVersion $1 $2)
170case $OSVERSION in
171    *Windows\ 10*)
172        BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
173        LOADER=$(ogGetPath $MNTDIR/Boot/bootmgfw.efi)
174        [ -n "$LOADER" ] || ogRaiseError $OG_ERR_NOTOS "$1 $2 ($OSVERSION, EFI)" || return $?
175        [ -r $EFIDIR/$BOOTLABEL ] && rm -rf $EFIDIR/$BOOTLABEL
176        mkdir -p $EFIDIR/EFI/$BOOTLABEL
177        cp -r "${LOADER%/*}" $EFIDIR/EFI/$BOOTLABEL
178        ;;
179esac
180}
181
182
183#         ogRestoreUuidPartitions
184#@brief   Restaura los uuid de las particiones y la tabla de particiones
185#@param   int_ndisk      nº de orden del disco
186#@param   int_nfilesys   nº de orden del sistema de archivos
187#@param   REPO|CACHE     repositorio
188#@param   str_imgname    nombre de la imagen
189#@exception OG_ERR_FORMAT    Formato incorrecto.
190#@exception OG_ERR_NOTFOUND  No encontrado fichero de información de la imagen (con uuid)
191function ogRestoreUuidPartitions () {
192local DISK PART IMGNAME INFOFILE DEVICE DATA GUID UUID IMGGUID
193local EFIDEVICE EFIDATA EFIGUID EFIUUID EFIUUID IMGEFIGUID
194
195# Si se solicita, mostrar ayuda.
196if [ "$*" == "help" ]; then
197    ogHelp "$FUNCNAME" "$FUNCNAME REPO|CACHE str_imgname int_ndisk int_npart" \
198           "$FUNCNAME REPO Windows 1 2"
199    return
200fi
201# Error si no se reciben 4 parámetros.
202[ $# -eq 4 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME REPO|CACHE str_imgname int_ndisk int_npart" || return $?
203
204# Sólo se ejecuta si es UEFI
205[ ogIsEfiActive ] || return
206
207# Parámetros de entrada
208IMGNAME="$2"
209INFOFILE="$OGIMG/.$IMGNAME.img.json"
210[ "${1^^}" == "CACHE" ] && INFOFILE="$OGCAC$INFOFILE"
211# TODO: que la función getPath soporte archivos ocultos
212ls $INFOFILE &>/dev/null || ogRaiseError $OG_ERR_NOTFOUND "$INFOFILE" || return $?
213DISK=$3
214PART=$4
215
216DEVICE=$(ogDiskToDev $DISK)
217read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
218
219# Datos de la imagen
220IMGGUID=$(jq .guid $INFOFILE|tr -d \")
221IMGEFIGUID=$(jq .espguid $INFOFILE|tr -d \")
222
223# Datos actuales
224DATA=$(sfdisk -J $DEVICE)
225GUID=$(echo $DATA|jq ".partitiontable|.id"|tr -d \")
226
227if [ "$IMGGUID" != "$GUID" ]; then
228    echo sgdisk -U "$IMGGUID"  "$DEVICE"
229    sgdisk -U "$IMGGUID"  "$DEVICE"
230    partprobe
231fi
232
233if [ $DISK -eq $EFIDISK ]; then
234    EFIDATA=$DATA
235    EFIDEVICE=$DEVICE
236else
237    EFIDEVICE=$(ogDiskToDev $EFIDISK) || return $?
238    EFIDATA=$(sfdisk -J $EFIDEVICE)
239    EFIGUID=$(echo $EFIDATA|jq ".partitiontable|.id"|tr -d \")
240    if [ "$IMGEFIGUID" != "$EFIGUID" ]; then
241echo         sgdisk -U "$IMGEFIGUID"  "$EFIDEVICE"
242       sgdisk -U "$IMGEFIGUID"  "$EFIDEVICE"
243       partprobe
244   fi
245fi
246
247}
248
249#         ogSaveImageInfo
250#@brief   Crea un fichero con la información de la imagen.
251#@param   int_ndisk      nº de orden del disco
252#@param   int_nfilesys   nº de orden del sistema de archivos
253#@param   REPO|CACHE     repositorio
254#@param   str_imgname    nombre de la imagen
255#@exception OG_ERR_FORMAT    formato incorrecto.
256#@exception OG_ERR_NOTFOUND  fichero o dispositivo no encontrado.
257function ogSaveImageInfo () {
258local DISK PART IMGDIR IMGNAME INFO INFOFILE DEVICE DATA GUID
259local EFIPARTDEVICE EFIDEVICE EFIDATA EFIGUID
260
261# Si se solicita, mostrar ayuda.
262if [ "$*" == "help" ]; then
263    ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_nfilesys REPO|CACHE str_imgname" \
264           "$FUNCNAME 1 2 REPO Windows"
265    return
266fi
267# Error si no se reciben 4 parámetros.
268[ $# -eq 4 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_nfilesys REPO|CACHE str_imgname" || return $?
269
270DISK=$1
271PART=$2
272IMGDIR="$(ogGetParentPath "$3" "/$4")"
273# Si no existe el directorio de la imagen me salgo
274[ "$IMGDIR" != "" ] || ogRaiseError $OG_ERR_NOTFOUND "$3 $(dirname $4)" || return $?
275IMGNAME="$(basename "$4")"
276INFOFILE="$IMGDIR/.$IMGNAME.img.json"
277
278DEVICE=$(ogDiskToDev $DISK) || return $?
279DATA=$(sfdisk -J $DEVICE)
280GUID=$(echo $DATA|jq ".partitiontable|.id"|tr -d \")
281
282# Información de la imagen. Valor inicial de efi: false
283INFO=$(cat << EOT | jq .
284{"name":"$IMGNAME","efi":"false","guid":"$GUID"}
285EOT
286     )
287
288if ogIsEfiActive; then
289    # Cambio valor de efi a true
290    INFO=$(echo $INFO|  jq --arg aux true '. + {efi: $aux}')
291
292    # Obtener partición EFI.
293    read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
294    EFIPARTDEVICE=$(ogDiskToDev $EFIDISK $EFIPART) || return $?
295    if [ $DISK -eq $EFIDISK ]; then
296        EFIDEVICE=$DEVICE
297        EFIDATA=$DATA
298        EFIGUID=$GUID
299    else
300        EFIDEVICE=$(ogDiskToDev $EFIDISK)
301        EFIDATA=$(sfdisk -J $EFIDEVICE)
302        EFIGUID=$(echo $EFIDATA|jq ".partitiontable|.id"|tr -d \")
303    fi
304
305    # Incluyo valor de EFIGUID (por si partición EFI en distinto disco que la de sistema)
306    INFO=$(echo $INFO|  jq --arg aux $EFIGUID '. + {espguid: $aux}')
307fi
308
309cat << EOT | jq . > $INFOFILE
310$INFO
311EOT
312}
Note: See TracBrowser for help on using the repository browser.