summaryrefslogtreecommitdiffstats
path: root/client
diff options
context:
space:
mode:
Diffstat (limited to 'client')
-rwxr-xr-xclient/boot-tools/boottoolsfunctions.lib18
-rwxr-xr-xclient/boot-tools/boottoolsgenerator.sh2
-rw-r--r--client/boot-tools/includes/etc/initramfs-tools/modules10
-rw-r--r--client/boot-tools/includes/etc/initramfs-tools/scripts/VERSION.txt2
-rw-r--r--client/boot-tools/includes/etc/initramfs-tools/scripts/ogfunctions2
-rwxr-xr-xclient/boot-tools/includes/usr/bin/boot-tools/boottoolsFsOpengnsys.sh19
-rwxr-xr-xclient/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareCompile.sh24
-rwxr-xr-xclient/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareInstall.sh25
-rw-r--r--client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.basic5
-rw-r--r--client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.cloning2
-rw-r--r--client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.testing7
-rwxr-xr-xclient/boot-tools/ogclientImg2Sqfs2
-rwxr-xr-xclient/boot-tools/ogclientSqfs2Img2
-rw-r--r--client/browser/po/ca.po68
-rw-r--r--client/browser/po/en.po72
-rw-r--r--client/browser/src/mainwindow.cpp258
-rw-r--r--client/browser/src/mainwindow.h13
-rwxr-xr-xclient/engine/Boot.lib907
-rwxr-xr-xclient/engine/Cache.lib23
-rwxr-xr-xclient/engine/Disk.lib70
-rwxr-xr-xclient/engine/FileSystem.lib36
-rwxr-xr-xclient/engine/Inventory.lib16
-rwxr-xr-xclient/engine/PostConf.lib103
-rwxr-xr-xclient/engine/Protocol.lib2
-rwxr-xr-xclient/engine/Registry.lib2
-rwxr-xr-xclient/engine/System.lib1
-rw-r--r--client/engine/UEFI.lib645
-rwxr-xr-xclient/shared/bin/browserbin430012 -> 554987 bytes
-rwxr-xr-xclient/shared/bin/ld-macbin87872 -> 0 bytes
-rw-r--r--client/shared/etc/lang.ca_ES.conf27
-rw-r--r--client/shared/etc/lang.en_GB.conf26
-rw-r--r--client/shared/etc/lang.es_ES.conf26
-rwxr-xr-xclient/shared/etc/preinit/fileslinks.sh13
-rwxr-xr-xclient/shared/etc/preinit/loadenviron.sh1
-rw-r--r--client/shared/lib/grub4dos/chinese/badgrub.exebin250689 -> 0 bytes
-rw-r--r--client/shared/lib/grub4dos/chinese/grldrbin235297 -> 0 bytes
-rw-r--r--client/shared/lib/grub4dos/chinese/grub.exebin252225 -> 0 bytes
-rw-r--r--client/shared/lib/locale/ca/LC_MESSAGES/browser.mobin899 -> 1021 bytes
-rw-r--r--client/shared/lib/locale/en/LC_MESSAGES/browser.mobin2134 -> 2251 bytes
-rwxr-xr-xclient/shared/lib/ogclient/ogAdmLnxClientbin713996 -> 0 bytes
-rw-r--r--client/shared/lib/ogclient/ogAdmWinClient.exebin73728 -> 0 bytes
-rwxr-xr-xclient/shared/lib/os-probes/mounted/efi/31part-x-y28
-rwxr-xr-xclient/shared/scripts/bootOsCustom.template57
-rwxr-xr-xclient/shared/scripts/cloneRemoteFromMaster7
-rwxr-xr-xclient/shared/scripts/configureOs21
-rw-r--r--client/shared/scripts/configureOsCustom.template4
-rwxr-xr-xclient/shared/scripts/createImage15
-rwxr-xr-xclient/shared/scripts/deployImage6
-rwxr-xr-xclient/shared/scripts/grubSyntax31
-rwxr-xr-xclient/shared/scripts/initCache6
-rwxr-xr-xclient/shared/scripts/updateCache2
51 files changed, 1971 insertions, 635 deletions
diff --git a/client/boot-tools/boottoolsfunctions.lib b/client/boot-tools/boottoolsfunctions.lib
index 15478248..3ad38d15 100755
--- a/client/boot-tools/boottoolsfunctions.lib
+++ b/client/boot-tools/boottoolsfunctions.lib
@@ -116,13 +116,27 @@ case "${1,,}" in
OSARCH="amd64"
OSHTTP="http://es.archive.ubuntu.com/ubuntu/"
;;
- bionic) # ogLive 1.1.1-rc1 basado en Ubuntu 18.04 y Kernel 4.15.
+ bionic|bionic-4.15) # ogLive 1.1.1-rc1 basado en Ubuntu 18.04 y Kernel 4.15.
OSDISTRIB="ubuntu"
OSCODENAME="bionic"
OSRELEASE="4.15.0-32-generic"
OSARCH="amd64"
OSHTTP="http://es.archive.ubuntu.com/ubuntu/"
;;
+ bionic-4.18) # ogLive 1.1.1-rc3 basado en Ubuntu 18.04 y Kernel 4.18.
+ OSDISTRIB="ubuntu"
+ OSCODENAME="bionic"
+ OSRELEASE="4.18.0-20-generic"
+ OSARCH="amd64"
+ OSHTTP="http://es.archive.ubuntu.com/ubuntu/"
+ ;;
+ bionic-5.0) # ogLive 1.1.1-rc5 basado en Ubuntu 18.04 y Kernel 5.0.
+ OSDISTRIB="ubuntu"
+ OSCODENAME="bionic"
+ OSRELEASE="5.0.0-27-generic"
+ OSARCH="amd64"
+ OSHTTP="http://es.archive.ubuntu.com/ubuntu/"
+ ;;
host) # ogLive basado en la distribución del servidor.
OSDISTRIB=$(lsb_release -is)
OSCODENAME=$(lsb_release -cs)
@@ -137,7 +151,7 @@ case "${1,,}" in
esac
BRANCH="devel"
GITURL="https://api.github.com/repos/opengnsys/OpenGnsys/commits?sha=$BRANCH&path=/client"
-GITRELEASE=$(curl -s "$GITURL" | jq -r '"r" + (.[0].commit.committer.date | gsub("-"; "")[:8]) + "." + (.[0].sha[:7])')
+GITRELEASE=$(curl -s "$GITURL" | jq -r '"r" + (.[0].commit.committer.date | split("-") | join("")[:8]) + "." + (.[0].sha[:7])')
NAMEISOCLIENT="$VERSIONBOOTTOOLS-$OSCODENAME-$OSRELEASE-$OSARCH-$GITRELEASE"
NAMEHOSTCLIENT="$VERSIONBOOTTOOLS-$OSCODENAME-$GITRELEASE"
export OSDISTRIB OSCODENAME OSRELEASE OSARCH OSHTTP
diff --git a/client/boot-tools/boottoolsgenerator.sh b/client/boot-tools/boottoolsgenerator.sh
index fb749a7b..79646a4a 100755
--- a/client/boot-tools/boottoolsgenerator.sh
+++ b/client/boot-tools/boottoolsgenerator.sh
@@ -75,7 +75,7 @@ echo "FASE 5 - Incorporando ficheros OpenGnsys al sistema raíz rootfs "
cp -a ${BTDIR}/includes/usr/bin/* /tmp
chmod +x /tmp/boot-tools/*.sh
# Incluir revisión.
-sed -i "1 s/$/ $GITRELEASE/" ${BTDIR}/includes/etc/initramfs-tools/scripts/VERSION.txt
+sed -i "1 s/$/ $GITRELEASE ($OSRELEASE)/" ${BTDIR}/includes/etc/initramfs-tools/scripts/VERSION.txt
# En Ubuntu 13.04+ es necesario matar proceso de "udev" antes de desmontar.
umount $BTROOTFSMNT 2>/dev/null || (kill -9 $(lsof -t $BTROOTFSMNT); umount $BTROOTFSMNT 2>/dev/null)
schroot -p -c IMGogclient -- /tmp/boot-tools/boottoolsFsOpengnsys.sh
diff --git a/client/boot-tools/includes/etc/initramfs-tools/modules b/client/boot-tools/includes/etc/initramfs-tools/modules
index 8300452a..78a25980 100644
--- a/client/boot-tools/includes/etc/initramfs-tools/modules
+++ b/client/boot-tools/includes/etc/initramfs-tools/modules
@@ -17,10 +17,12 @@
# Kernel 3.7+ video.
uvesafb
-#generales
-usbcore
-uhci_hcd
-ehci_hcd
+# Generales
+#usbcore
+#uhci_hcd
+#ehci_hcd
usbhid
usbmouse
mac-hid
+arc4
+cmac
diff --git a/client/boot-tools/includes/etc/initramfs-tools/scripts/VERSION.txt b/client/boot-tools/includes/etc/initramfs-tools/scripts/VERSION.txt
index 45805bd6..73b6a464 100644
--- a/client/boot-tools/includes/etc/initramfs-tools/scripts/VERSION.txt
+++ b/client/boot-tools/includes/etc/initramfs-tools/scripts/VERSION.txt
@@ -1 +1 @@
-OpenGnsys Client 1.1.1-rc2
+OpenGnsys Client 1.1.1-rc5
diff --git a/client/boot-tools/includes/etc/initramfs-tools/scripts/ogfunctions b/client/boot-tools/includes/etc/initramfs-tools/scripts/ogfunctions
index 62f0524a..4d96f7eb 100644
--- a/client/boot-tools/includes/etc/initramfs-tools/scripts/ogfunctions
+++ b/client/boot-tools/includes/etc/initramfs-tools/scripts/ogfunctions
@@ -123,7 +123,7 @@ ogExportVarEnvironment ()
OGPROTOCOL="${ogprotocol:-smb}"
[ "$ogunit" != "" ] && OGUNIT="/$ogunit"
# OPTIONS Para samba y local (a nfs no le afecta)
- export OPTIONS=" -o vers=1.0,sec=ntlm,user=opengnsys,pass=og"
+ export OPTIONS=" -o user=opengnsys,pass=og"
DEFOGLIVE="ogclient"
export OGLIVEDIR="${oglivedir:-$DEFOGLIVE}" && echo "OGLIVEDIR=$OGLIVEDIR" >> $CFGINITRD
case "$OGPROTOCOL" in
diff --git a/client/boot-tools/includes/usr/bin/boot-tools/boottoolsFsOpengnsys.sh b/client/boot-tools/includes/usr/bin/boot-tools/boottoolsFsOpengnsys.sh
index 85b00b69..62962927 100755
--- a/client/boot-tools/includes/usr/bin/boot-tools/boottoolsFsOpengnsys.sh
+++ b/client/boot-tools/includes/usr/bin/boot-tools/boottoolsFsOpengnsys.sh
@@ -34,8 +34,6 @@ then
exit 1
fi
-
-
#damos permiso al directorio de scripts
chmod -R 775 ${SVNCLIENTDIR}/includes/usr/bin/*
@@ -43,6 +41,7 @@ chmod -R 775 ${SVNCLIENTDIR}/includes/usr/bin/*
cp -av ${SVNCLIENTDIR}/includes/* ${OGCLIENTMOUNT}/
mkdir -p ${OGCLIENTMOUNT}/opt/opengnsys/
cp -av ${SVNCLIENTSTRUCTURE}/* ${OGCLIENTMOUNT}/opt/opengnsys/
+mkdir -p ${OGCLIENTMOUNT}/opt/opengnsys/lib/engine/bin/
cp -av ${SVNCLIENTENGINE}/* ${OGCLIENTMOUNT}/opt/opengnsys/lib/engine/bin/
if [ $? -ne 0 ]
@@ -62,19 +61,9 @@ cp -av ${SVNCLIENTSTRUCTURE}/lib/fonts $OGCLIENTMOUNT/usr/local/lib
cp -av ${SVNCLIENTSTRUCTURE}/lib/qtplugins/* $OGCLIENTMOUNT/usr/local/plugins
cp -av ${SVNCLIENTSTRUCTURE}/etc/*.qmap $OGCLIENTMOUNT/usr/local/etc
-# Browser.
-cp -av ${SVNCLIENTSTRUCTURE}/bin/browser $OGCLIENTMOUNT/bin
-if [ $? -ne 0 ]; then
- echo "$FUNCNAME(): Copying Browser : ERROR"
- exit 1
-fi
-
-# ogAdmClient.
-cp -av ${SVNCLIENTSTRUCTURE}/bin/ogAdmClient $OGCLIENTMOUNT/bin
-if [ $? -ne 0 ]; then
- echo "$FUNCNAME(): Copying ogAdmClient: ERROR"
- exit 1
-fi
+# Browser y ogAdmClient.
+[ -x ${SVNCLIENTSTRUCTURE}/bin/browser ] && cp -av ${SVNCLIENTSTRUCTURE}/bin/browser $OGCLIENTMOUNT/bin
+[ -x ${SVNCLIENTSTRUCTURE}/bin/ogAdmClient ] && cp -av ${SVNCLIENTSTRUCTURE}/bin/ogAdmClient $OGCLIENTMOUNT/bin
# El fichero de configuración debe sustituir a los 2 ficheros (borrar las 2 líneas).
echo "${VERSIONBOOTTOOLS}-${OSCODENAME}-${OSRELEASE}-${GITRELEASE}" > /$NAMEISOCLIENTFILE
diff --git a/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareCompile.sh b/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareCompile.sh
index 9a9fb764..6c27f300 100755
--- a/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareCompile.sh
+++ b/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareCompile.sh
@@ -13,32 +13,12 @@ export LANG=C
source /opt/opengnsys/lib/engine/bin/ToolsGNU.c &>/dev/null
pushd /tmp
-echo "ms-sys "
-which ms-sys || ms-sys install &>/dev/null
+echo "ms-sys"
+which ms-sys || (wget https://sourceforge.net/projects/ms-sys/files/latest/download -O ms-sys.tar.gz; tar xpvzf ms-sys.tar.gz; cd $(tar tzf ms-sys.tar.gz|head -1); make install; cd ..)
echo "spartlnx"
which spartlnx.run || $(wget http://damien.guibouret.free.fr/savepart.zip &>/dev/null; unzip -o savepart.zip -d /sbin/)
-# Mach-O loader for Linux
-#echo "maloader"
-#apt-get install -y uuid-dev lib64z1 lib32z1
-#wget https://github.com/shinh/maloader/archive/master.zip
-#unzip master.zip
-#cd maloader-master
-#perl -pi -le 'print "#include <unistd.h>" if $. == 45' ld-mac.cc
-#if [ "$(arch)" == "x86_64" ]; then
-# ln -fs /lib/x86_64-linux-gnu/libcrypto.so.1.0.0 /lib/libcrypto.so 2>/dev/null
-# make release
-#else
-# ln -fs /lib/i386-linux-gnu/libcrypto.so.1.0.0 /lib/libcrypto.so 2>/dev/null
-# make clean
-# make all BITS=32
-#fi
-#cp -va ld-mac /usr/bin
-#cp -va libmac.so /usr/lib
-#cd ..
-#rm -fr master.zip maloader-master
-
popd
export LANGUAGE=$OLDLANGUAGE
export LC_ALL=$OLDLC_ALL
diff --git a/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareInstall.sh b/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareInstall.sh
index 95a64cf9..301cd991 100755
--- a/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareInstall.sh
+++ b/client/boot-tools/includes/usr/bin/boot-tools/boottoolsSoftwareInstall.sh
@@ -35,25 +35,9 @@ echo "/dev/sda1 / ext4 rw,errors=remount-ro 0 0" > /etc/mtab
OGCLIENTCFG=${OGCLIENTCFG:-/tmp/ogclient.cfg}
[ -f $OGCLIENTCFG ] && source $OGCLIENTCFG
OSRELEASE=${OSRELEASE:-$(uname -r)}
-# inicio de la instalacion
-if [ "$OSRELEASE" == "3.7.6-030706-generic" ]; then
- # Descargar e instalar Kernel 3.7.
- mkdir -p /tmp/kernel
- pushd /tmp/kernel
- apt-get -y --force-yes install wget crda libnl-3-200 libnl-genl-3-200 wireless-regdb
- wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v3.7.6-raring/linux-image-3.7.6-030706-generic_3.7.6-030706.201302040006_$OSARCH.deb
- wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v3.7.6-raring/linux-image-extra-3.7.6-030706-generic_3.7.6-030706.201302040006_$OSARCH.deb
- wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v3.7.6-raring/linux-headers-3.7.6-030706-generic_3.7.6-030706.201302040006_$OSARCH.deb
- wget http://kernel.ubuntu.com/~kernel-ppa/mainline/v3.7.6-raring/linux-headers-3.7.6-030706_3.7.6-030706.201302040006_all.deb
- dpkg -i *.deb
- apt-get -y --force-yes install dkms
- popd
- rm -fr /tmp/kernel
-else
- # Instalar Kernel firmado del repositorio de paquetes.
- apt-get -y --force-yes install linux-image-${OSRELEASE} linux-headers-${OSRELEASE} dkms shim-signed
- apt-get -y --force-yes install linux-modules-${OSRELEASE} linux-modules-extra-${OSRELEASE} 2>/dev/null
-fi
+# Instalar Kernel firmado del repositorio de paquetes.
+apt-get -y --force-yes install linux-image-${OSRELEASE} linux-headers-${OSRELEASE} dkms shim-signed
+apt-get -y --force-yes install linux-modules-${OSRELEASE} linux-modules-extra-${OSRELEASE} 2>/dev/null
# Valores para paquetes interactivos.
cat << EOT | debconf-set-selections --
@@ -64,7 +48,8 @@ kexec-tools kexec-tools/load_kexec boolean true
openssh-server openssh-server/permit-root-login boolean true
refind refind/install_to_esp boolean false
EOT
-apt-get -y install sshfs console-data kexec-tools davfs2 $PKGS32
+apt-get -y install sshfs console-data kexec-tools $PKGS32
+#apt-get -y install davfs2
#comenzamos con la instalación de los paquetes a instalar.
for group in `find /usr/bin/boot-tools/listpackages/ -name sw.*`
diff --git a/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.basic b/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.basic
index afd8ff4c..73e1c2b9 100644
--- a/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.basic
+++ b/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.basic
@@ -4,12 +4,13 @@ install man-db
install fbset
install gdebi-core
install bash-static
-install busybox-static
+install busybox-static
install console-data
install locales
install lshw
install gawk
-install subversion
+#install subversion # ogLive anterior a Ubuntu 18.04
+install git # ogLive a partir de Ubuntu 18.04
install python-openssl
install python
#install php5-cli # ogLive anterior a Ubuntu 16.04
diff --git a/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.cloning b/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.cloning
index 0092bd29..3e6a7666 100644
--- a/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.cloning
+++ b/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.cloning
@@ -5,7 +5,7 @@ install pxe-kexec
install mbuffer
install parted
install gdisk
-install chntpw
+install chntpw
install clonezilla
install registry-tools
install reglookup
diff --git a/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.testing b/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.testing
index 13cd2665..93012f4a 100644
--- a/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.testing
+++ b/client/boot-tools/includes/usr/bin/boot-tools/listpackages/sw.testing
@@ -1,12 +1,14 @@
#sw.other
install screen
install schroot
-#install grub
install xmlstarlet
############# UEFI
install efibootmgr
install efitools
install refind
+install grub-efi-amd64-bin
+install grub-efi-ia32-bin
+install grub-pc-bin
############# OGAgent
install libxss1
install python-prctl
@@ -16,7 +18,7 @@ install python-requests
install fusioninventory-agent
install nvme-cli
install disktype
-install laptop-detect
+install laptop-detect
#install discover
#install casper
#install lupin-casper
@@ -51,7 +53,6 @@ install laptop-detect
#install nitrogen
#install ttf-ubuntu-font-family
#install time
-#install openssh-client
#install synaptic
#install libglib-perl
#install libgtk2-perl
diff --git a/client/boot-tools/ogclientImg2Sqfs b/client/boot-tools/ogclientImg2Sqfs
index 5dfb2b00..ea6f9509 100755
--- a/client/boot-tools/ogclientImg2Sqfs
+++ b/client/boot-tools/ogclientImg2Sqfs
@@ -26,7 +26,7 @@ OGCLIENTBASEDIR=$OPENGNSYS/tftpboot/ogclient/;
OGCLIENTFILE=${OGCLIENTBASEDIR}ogclient.img;
OGCLIENTSQFS=${OGCLIENTBASEDIR}ogclient.sqfs
OGCLIENTMOUNT=${OGCLIENTBASEDIR}ogclientmount;
-OGCLIENTSIZEMB=1900;
+OGCLIENTSIZEMB=2100;
OGCLIENTLABEL=ogClient;
# Comprobamos que existe el cliente .sqfs
diff --git a/client/boot-tools/ogclientSqfs2Img b/client/boot-tools/ogclientSqfs2Img
index 4f8447da..e52b677c 100755
--- a/client/boot-tools/ogclientSqfs2Img
+++ b/client/boot-tools/ogclientSqfs2Img
@@ -29,7 +29,7 @@ OGCLIENTBASEDIR=$OPENGNSYS/tftpboot/ogclient/;
OGCLIENTSQFS=${OGCLIENTBASEDIR}ogclient.sqfs
OGCLIENTFILE=${OGCLIENTBASEDIR}ogclient.img;
OGCLIENTMOUNT=${OGCLIENTBASEDIR}ogclientmount;
-OGCLIENTSIZEMB=1900;
+OGCLIENTSIZEMB=2100;
OGCLIENTLABEL=ogClient;
# Comprobamos que existe el cliente .sqfs
diff --git a/client/browser/po/ca.po b/client/browser/po/ca.po
index 8e5e0b7c..1e76b18b 100644
--- a/client/browser/po/ca.po
+++ b/client/browser/po/ca.po
@@ -7,8 +7,8 @@
msgid ""
msgstr ""
"Project-Id-Version: OpenGnsys Client Browser 1.1.0\n"
-"Report-Msgid-Bugs-To: https://opengnsys.es\n"
-"POT-Creation-Date: 2017-05-11 11:51+0000\n"
+"Report-Msgid-Bugs-To: https://opengnsys.es/\n"
+"POT-Creation-Date: 2019-09-11 15:48+0000\n"
"PO-Revision-Date: 2016-05-03 10:25+0200\n"
"Last-Translator: Ramón M. Gómez <ramongomez@us.es>\n"
"Language-Team: CATALAN <LL@li.org>\n"
@@ -17,94 +17,102 @@ msgstr ""
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
-#: ../src/main.cpp:20
+#: src/main.cpp:20
#, c-format
msgid "Uso: %s -qws http://sitioweb.com/\n"
msgstr "Ús: %s -qws http://web.com/\n"
-#: ../src/mainwindow.cpp:55
+#: src/mainwindow.cpp:47
+msgid "El fichero de log no ha podido ser abierto: "
+msgstr "Log file could not be opened: "
+
+#: src/mainwindow.cpp:68
msgid "&Nueva Terminal"
msgstr "&Nova Terminal"
-#: ../src/mainwindow.cpp:60
+#: src/mainwindow.cpp:72
msgid "Salida"
msgstr "Sortida"
-#: ../src/mainwindow.cpp:97
+#: src/mainwindow.cpp:104
msgid "Proyecto OpenGnsys"
msgstr "Projecte OpenGnsys"
-#: ../src/mainwindow.cpp:145
-msgid "El fichero de log no ha podido ser abierto: "
-msgstr ""
-
-#: ../src/mainwindow.cpp:174
+#: src/mainwindow.cpp:167
msgid "Hay otro proceso en ejecución. Por favor espere."
msgstr ""
-#: ../src/mainwindow.cpp:189 ../src/mainwindow.cpp:228
+#: src/mainwindow.cpp:183 src/mainwindow.cpp:250
msgid "AVISO"
msgstr "AVIS"
-#: ../src/mainwindow.cpp:191
+#: src/mainwindow.cpp:186
msgid ""
"La siguiente acci&oacute;n puede modificar datos o tardar varios minutos. El "
"equipo no podr&aacute; ser utilizado durante su ejecuci&oacute;n."
msgstr ""
-#: ../src/mainwindow.cpp:192
+#: src/mainwindow.cpp:187
msgid "Ejecutar"
msgstr "Executar"
-#: ../src/mainwindow.cpp:193
+#: src/mainwindow.cpp:188
msgid "Cancelar"
msgstr "Cancel-lar"
-#: ../src/mainwindow.cpp:211
+#: src/mainwindow.cpp:233
#, c-format
msgid "%p% Cargando"
msgstr "%p% Carregat"
-#: ../src/mainwindow.cpp:230
+#: src/mainwindow.cpp:253
msgid "La p&aacute;gina no se puede cargar."
msgstr ""
-#: ../src/mainwindow.cpp:232
+#: src/mainwindow.cpp:255
msgid "Recargar"
msgstr "Recarregar"
-#: ../src/mainwindow.cpp:233
+#: src/mainwindow.cpp:256
msgid "Abortar"
msgstr "Avortar"
-#: ../src/mainwindow.cpp:264
-msgid "Lanzado satisfactoriamente."
+#: src/mainwindow.cpp:333 src/mainwindow.cpp:345
+msgid "Fin del proceso. Valor de retorno: "
msgstr ""
-#: ../src/mainwindow.cpp:298
-msgid "Proceso acabado correctamente. Valor de retorno: "
+#: src/mainwindow.cpp:338
+msgid "El proceso ha fallado inesperadamente. Salida: "
msgstr ""
-#: ../src/mainwindow.cpp:302
-msgid "El proceso ha fallado inesperadamente. Salida: "
+#: src/mainwindow.cpp:347
+msgid "AVISO: Pulsar el botón superior derecho para cerrar"
msgstr ""
-#: ../src/mainwindow.cpp:313
+#: src/mainwindow.cpp:353
+msgid "Código de salida: "
+msgstr ""
+
+#: src/mainwindow.cpp:364
msgid "Imposible lanzar el proceso."
msgstr ""
-#: ../src/mainwindow.cpp:316
+#: src/mainwindow.cpp:367
msgid "Error de escritura en el proceso."
msgstr ""
-#: ../src/mainwindow.cpp:319
+#: src/mainwindow.cpp:370
msgid "Error de lectura del proceso."
msgstr ""
-#: ../src/mainwindow.cpp:327
+#: src/mainwindow.cpp:378
msgid "Error desconocido."
msgstr ""
-#: ../src/mainwindow.cpp:460
+#: src/mainwindow.cpp:530 src/mainwindow.cpp:535
msgid "Lanzando el comando: "
msgstr ""
+
+#: src/mainwindow.cpp:563
+msgid "ERROR"
+msgstr "ERROR"
diff --git a/client/browser/po/en.po b/client/browser/po/en.po
index 68ab13c5..08c26b96 100644
--- a/client/browser/po/en.po
+++ b/client/browser/po/en.po
@@ -7,8 +7,8 @@
msgid ""
msgstr ""
"Project-Id-Version: OpenGnsys Client Browser 1.1.0\n"
-"Report-Msgid-Bugs-To: https://opengnsys.es\n"
-"POT-Creation-Date: 2017-05-11 11:51+0000\n"
+"Report-Msgid-Bugs-To: https://opengnsys.es/\n"
+"POT-Creation-Date: 2019-09-11 15:48+0000\n"
"PO-Revision-Date: 2016-05-03 10:16+0200\n"
"Last-Translator: Ramón M. Gómez <ramongomez@us.es>\n"
"Language-Team: ENGLISH <LL@li.org>\n"
@@ -17,36 +17,36 @@ msgstr ""
"Content-Type: text/plain; charset=UTF-8\n"
"Content-Transfer-Encoding: 8bit\n"
-#: ../src/main.cpp:20
+#: src/main.cpp:20
#, c-format
msgid "Uso: %s -qws http://sitioweb.com/\n"
msgstr "Usage: %s -qws http://website.com/\n"
-#: ../src/mainwindow.cpp:55
+#: src/mainwindow.cpp:47
+msgid "El fichero de log no ha podido ser abierto: "
+msgstr "Log file could not be opened: "
+
+#: src/mainwindow.cpp:68
msgid "&Nueva Terminal"
msgstr "&New Terminal"
-#: ../src/mainwindow.cpp:60
+#: src/mainwindow.cpp:72
msgid "Salida"
msgstr "Output"
-#: ../src/mainwindow.cpp:97
+#: src/mainwindow.cpp:104
msgid "Proyecto OpenGnsys"
msgstr "OpenGnsys Project"
-#: ../src/mainwindow.cpp:145
-msgid "El fichero de log no ha podido ser abierto: "
-msgstr "The log file could not be opened: "
-
-#: ../src/mainwindow.cpp:174
+#: src/mainwindow.cpp:167
msgid "Hay otro proceso en ejecución. Por favor espere."
msgstr "There is another process running. Please wait."
-#: ../src/mainwindow.cpp:189 ../src/mainwindow.cpp:228
+#: src/mainwindow.cpp:183 src/mainwindow.cpp:250
msgid "AVISO"
msgstr "WARNING"
-#: ../src/mainwindow.cpp:191
+#: src/mainwindow.cpp:186
msgid ""
"La siguiente acci&oacute;n puede modificar datos o tardar varios minutos. El "
"equipo no podr&aacute; ser utilizado durante su ejecuci&oacute;n."
@@ -54,59 +54,67 @@ msgstr ""
"Following action can modify some data or take several minutes. This computer "
"may not be used during execution."
-#: ../src/mainwindow.cpp:192
+#: src/mainwindow.cpp:187
msgid "Ejecutar"
msgstr "Run"
-#: ../src/mainwindow.cpp:193
+#: src/mainwindow.cpp:188
msgid "Cancelar"
msgstr "Cancel"
-#: ../src/mainwindow.cpp:211
+#: src/mainwindow.cpp:233
#, c-format
msgid "%p% Cargando"
msgstr "%p% Loaded"
-#: ../src/mainwindow.cpp:230
+#: src/mainwindow.cpp:253
msgid "La p&aacute;gina no se puede cargar."
msgstr "Page can not be loaded."
-#: ../src/mainwindow.cpp:232
+#: src/mainwindow.cpp:255
msgid "Recargar"
msgstr "Reload"
-#: ../src/mainwindow.cpp:233
+#: src/mainwindow.cpp:256
msgid "Abortar"
msgstr "Abort"
-#: ../src/mainwindow.cpp:264
-msgid "Lanzado satisfactoriamente."
-msgstr "Successfully launched."
+#: src/mainwindow.cpp:333 src/mainwindow.cpp:345
+msgid "Fin del proceso. Valor de retorno: "
+msgstr "End of process. Return value: "
-#: ../src/mainwindow.cpp:298
-msgid "Proceso acabado correctamente. Valor de retorno: "
-msgstr "Process completed successfully. Return value: "
-
-#: ../src/mainwindow.cpp:302
+#: src/mainwindow.cpp:338
msgid "El proceso ha fallado inesperadamente. Salida: "
msgstr "The process crashed unexpectedly. Return value: "
-#: ../src/mainwindow.cpp:313
+#: src/mainwindow.cpp:347
+msgid "AVISO: Pulsar el botón superior derecho para cerrar"
+msgstr "WARNING: Press the upper right button to close"
+
+#: src/mainwindow.cpp:353
+msgid "Código de salida: "
+msgstr "Exit code: "
+
+#: src/mainwindow.cpp:364
msgid "Imposible lanzar el proceso."
msgstr "Unable to launch the process."
-#: ../src/mainwindow.cpp:316
+#: src/mainwindow.cpp:367
msgid "Error de escritura en el proceso."
msgstr "Error writing to the process."
-#: ../src/mainwindow.cpp:319
+#: src/mainwindow.cpp:370
msgid "Error de lectura del proceso."
msgstr "Error reading from the process."
-#: ../src/mainwindow.cpp:327
+#: src/mainwindow.cpp:378
msgid "Error desconocido."
msgstr "Unknown error."
-#: ../src/mainwindow.cpp:460
+#: src/mainwindow.cpp:530 src/mainwindow.cpp:535
msgid "Lanzando el comando: "
msgstr "Launching command: "
+
+#: src/mainwindow.cpp:563
+msgid "ERROR"
+msgstr "ERROR"
diff --git a/client/browser/src/mainwindow.cpp b/client/browser/src/mainwindow.cpp
index 2e799c5e..1d89a1a8 100644
--- a/client/browser/src/mainwindow.cpp
+++ b/client/browser/src/mainwindow.cpp
@@ -12,10 +12,10 @@
#include <QDateTime>
#include <QProgressBar>
#include <QTabWidget>
-#include <QWebView>
#include <QLineEdit>
#include <QNetworkReply>
#include <QSslError>
+#include <QTimer>
#include <libintl.h>
#include "qtermwidget.h"
@@ -24,7 +24,7 @@
#define BUFFERSIZE 2048
#define REGEXP_STRING "^\\[(\\d+)\\]"
-#define CURRENT_TIME() QDateTime::currentDateTime().toString("dd/MM/yy hh:mm:ss")
+#define CURRENT_TIME() QDateTime::currentDateTime().toString("dd/MM/yyyy hh:mm:ss")
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent),m_web(new QWebView()),m_output(new QTextEdit()),
@@ -33,15 +33,28 @@ MainWindow::MainWindow(QWidget *parent)
{
// Graphic
showFullScreen();
-
setWindowTitle(tr("OpenGnsys Browser"));
-
setCentralWidget(m_web);
-
readEnvironmentValues();
+ // Open the log file for append
+ if(m_env.contains("OGLOGFILE") && m_env["OGLOGFILE"]!="")
+ {
+ QFile* m_logfile=new QFile(m_env["OGLOGFILE"]);
+ if(!m_logfile->open(QIODevice::WriteOnly | QIODevice::Text | QIODevice::Append))
+ {
+ delete m_logfile;
+ print(tr(gettext("El fichero de log no ha podido ser abierto: "))+m_env["OGLOGFILE"]+".");
+ }
+ else
+ {
+ m_logstream=new QTextStream(m_logfile);
+ }
+ }
+
// Output
m_output->setReadOnly(true);
+ m_output->setFontPointSize(16);
// Button Dock
QDockWidget* dock=new QDockWidget();
@@ -56,16 +69,13 @@ MainWindow::MainWindow(QWidget *parent)
button->setFocusPolicy(Qt::TabFocus);
m_tabs->setCornerWidget(button);
m_tabs->setFocusPolicy(Qt::NoFocus);
-
m_tabs->addTab(m_output,tr(gettext("Salida")));
slotCreateTerminal();
-
// Assign tabs to dock
dock->setWidget(m_tabs);
-
// Assign tabs dock to the mainwindow if admin mode is active
if(m_env.contains("ogactiveadmin") && m_env["ogactiveadmin"] == "true")
- addDockWidget(Qt::BottomDockWidgetArea,dock);
+ addDockWidget(Qt::BottomDockWidgetArea,dock);
// Top Dock
dock=new QDockWidget();
@@ -73,16 +83,13 @@ MainWindow::MainWindow(QWidget *parent)
QWidget* dummy2=new QWidget();
dummy2->setMaximumHeight(0);
dock->setTitleBarWidget(dummy2);
-
// WebBar
m_webBar=new QLineEdit(dock);
-
// WebBar to dock
dock->setWidget(m_webBar);
-
// Assign top dock to the mainwindow if admin mode is active
if(m_env.contains("ogactiveadmin") && m_env["ogactiveadmin"] == "true")
- addDockWidget(Qt::TopDockWidgetArea,dock);
+ addDockWidget(Qt::TopDockWidgetArea,dock);
// Status bar
QStatusBar* st=statusBar();
@@ -91,9 +98,9 @@ MainWindow::MainWindow(QWidget *parent)
m_logo=new QLabel();
QPixmap logo;
if(logo.load("/opt/opengnsys/lib/pictures/oglogo.png"))
- m_logo->setPixmap(logo);
+ m_logo->setPixmap(logo);
else
- m_logo->setText("OG");
+ m_logo->setText("OG");
m_logo->setToolTip(tr(gettext("Proyecto OpenGnsys"))+"\nhttps://opengnsys.es");
// Progress bar
m_progressBar=new QProgressBar(this);
@@ -103,8 +110,8 @@ MainWindow::MainWindow(QWidget *parent)
m_speedInfo=new QLabel(speed);
m_speedInfo->setAlignment(Qt::AlignCenter);
if(m_env.contains("DEFAULTSPEED") && m_env["DEFAULTSPEED"]!="")
- if(speed.compare(m_env["DEFAULTSPEED"])!=0)
- m_speedInfo->setStyleSheet("background-color: darkred; color: white; font-weight: bold;");
+ if(speed.compare(m_env["DEFAULTSPEED"])!=0)
+ m_speedInfo->setStyleSheet("background-color: darkred; color: white; font-weight: bold;");
// Clock
m_clock=new DigitalClock(this);
@@ -126,10 +133,8 @@ MainWindow::MainWindow(QWidget *parent)
connect(m_process,SIGNAL(started()),this,SLOT(slotProcessStarted()));
connect(m_process,SIGNAL(finished(int,QProcess::ExitStatus)),
this,SLOT(slotProcessFinished(int,QProcess::ExitStatus)));
-
connect(m_process,SIGNAL(error(QProcess::ProcessError)),
this,SLOT(slotProcessError(QProcess::ProcessError)));
-
connect(m_process,SIGNAL(readyReadStandardOutput()),this,SLOT(slotProcessOutput()));
connect(m_process,SIGNAL(readyReadStandardError()),
this,SLOT(slotProcessErrorOutput()));
@@ -138,21 +143,6 @@ MainWindow::MainWindow(QWidget *parent)
connect(button,SIGNAL(clicked()),this,SLOT(slotCreateTerminal()));
connect(m_webBar,SIGNAL(returnPressed()),this,SLOT(slotWebBarReturnPressed()));
- // Open the log file for append
- if(m_env.contains("OGLOGFILE") && m_env["OGLOGFILE"]!="")
- {
- QFile* m_logfile=new QFile(m_env["OGLOGFILE"]);
- if(!m_logfile->open(QIODevice::WriteOnly | QIODevice::Text | QIODevice::Append))
- {
- delete m_logfile;
- print(tr(gettext("El fichero de log no ha podido ser abierto: "))+m_env["OGLOGFILE"]+".");
- }
- else
- {
- m_logstream=new QTextStream(m_logfile);
- }
- }
-
QStringList arguments=QCoreApplication::arguments();
m_webBar->setText(arguments[1]);
m_web->load(QUrl(arguments[1]));
@@ -172,35 +162,64 @@ MainWindow::~MainWindow()
void MainWindow::slotLinkHandle(const QUrl &url)
{
// Check if it's executing another process
- if(m_process->state()!=QProcess::NotRunning)
+ if(m_process->state() != QProcess::NotRunning)
{
- print(tr(gettext("Hay otro proceso en ejecución. Por favor espere.")));
- return;
+ print(tr(gettext("Hay otro proceso en ejecución. Por favor espere.")));
+ return;
}
-
QString urlString = url.toString();
- if(urlString.startsWith(COMMAND))
+ QString urlScheme = url.scheme();
+ // Clear the output widget for a normal user
+ if(! m_env.contains("ogactiveadmin") || m_env["ogactiveadmin"] != "true")
{
- // For COMMAND link, execute
- executeCommand(urlString.remove(0,QString(COMMAND).length()));
+ m_output->clear();
}
- else if(urlString.startsWith(COMMAND_WITH_CONFIRMATION))
+ if(urlScheme == COMMAND_CONFIRM || urlScheme == COMMAND_CONFIRM_OUTPUT ||
+ urlScheme == COMMAND_OUTPUT_CONFIRM || urlScheme == COMMAND_WITH_CONFIRMATION)
{
- // For COMMAND_WITH_CONFIRMATION link, show confirmation box and execute, if accepted
+ // For all command with confirmation links, show a popup box
QMessageBox msgBox;
- msgBox.setIcon(QMessageBox::Question);
+ msgBox.setWindowFlags(Qt::CustomizeWindowHint | Qt::WindowTitleHint);
msgBox.setWindowTitle(tr(gettext("AVISO")));
+ msgBox.setIcon(QMessageBox::Question);
msgBox.setTextFormat(Qt::RichText);
msgBox.setText(tr(gettext("La siguiente acci&oacute;n puede modificar datos o tardar varios minutos. El equipo no podr&aacute; ser utilizado durante su ejecuci&oacute;n.")));
QPushButton *execButton = msgBox.addButton(tr(gettext("Ejecutar")), QMessageBox::ActionRole);
msgBox.addButton(tr(gettext("Cancelar")), QMessageBox::RejectRole);
msgBox.setDefaultButton(execButton);
msgBox.exec();
+ // Continue if user press the execution button
if (msgBox.clickedButton() == execButton)
{
- executeCommand(urlString.remove(0,QString(COMMAND_WITH_CONFIRMATION).length()));
+ // For command with confirmation and output link, show an output window to non-admin user
+ if((urlScheme == COMMAND_CONFIRM_OUTPUT || urlScheme == COMMAND_OUTPUT_CONFIRM) &&
+ (! m_env.contains("ogactiveadmin") || m_env["ogactiveadmin"] != "true"))
+ {
+ int w=MainWindow::width(), h=MainWindow::height();
+ m_output->setWindowFlags(Qt::Window);
+ m_output->move(100, 100);
+ m_output->setFixedSize(w*0.8-100, h*0.8-100);
+ m_output->show();
+ }
+ // Execute the command
+ executeCommand(urlString.remove(0, urlScheme.length()+1));
}
}
+ else if(urlScheme == COMMAND || urlScheme == COMMAND_OUTPUT)
+ {
+ // For command with output link, show an output window to non-admin user
+ if(urlScheme == COMMAND_OUTPUT &&
+ (! m_env.contains("ogactiveadmin") || m_env["ogactiveadmin"] != "true"))
+ {
+ int w=MainWindow::width(), h=MainWindow::height();
+ m_output->setWindowFlags(Qt::Window);
+ m_output->move(100, 100);
+ m_output->setFixedSize(w*0.8-100, h*0.8-100);
+ m_output->show();
+ }
+ // Execute the command
+ executeCommand(urlString.remove(0, urlScheme.length()+1));
+ }
else
{
// For other link, load webpage
@@ -227,14 +246,14 @@ void MainWindow::slotWebLoadFinished(bool ok)
if(ok == false)
{
QMessageBox msgBox;
- msgBox.setIcon(QMessageBox::Question);
+ msgBox.setWindowFlags(Qt::CustomizeWindowHint | Qt::WindowTitleHint);
msgBox.setWindowTitle(tr(gettext("AVISO")));
+ msgBox.setIcon(QMessageBox::Question);
msgBox.setTextFormat(Qt::RichText);
msgBox.setText(tr(gettext("La p&aacute;gina no se puede cargar.")));
QPushButton *reloadButton = msgBox.addButton(tr(gettext("Recargar")), QMessageBox::ActionRole);
msgBox.addButton(tr(gettext("Abortar")), QMessageBox::RejectRole);
-
msgBox.exec();
if (msgBox.clickedButton() == reloadButton)
@@ -264,7 +283,6 @@ void MainWindow::slotSslErrors(QNetworkReply* reply)
void MainWindow::slotProcessStarted()
{
- m_output->insertPlainText(tr(gettext("Lanzado satisfactoriamente.")));
startProgressBar();
}
@@ -275,7 +293,11 @@ void MainWindow::slotProcessOutput()
while((m_process->readLine(buf,BUFFERSIZE) > 0))
{
QString s(buf);
- print(tr("Proc. stdout: ")+s);
+ if(m_env.contains("ogactiveadmin") && m_env["ogactiveadmin"] == "true")
+ {
+ m_output->insertPlainText(tr("Proc. stdout: "));
+ }
+ print(s);
captureOutputForStatusBar(s);
}
}
@@ -287,39 +309,65 @@ void MainWindow::slotProcessErrorOutput()
while((m_process->readLine(buf,BUFFERSIZE) > 0))
{
QString s(buf);
- m_output->insertPlainText(tr("Proc. stderr: "));
+ if(m_env.contains("ogactiveadmin") && m_env["ogactiveadmin"] == "true")
+ {
+ m_output->insertPlainText(tr("Proc. stderr: "));
+ }
m_output->setTextColor(QColor(Qt::darkBlue));
print(s);
m_output->setTextColor(QColor(Qt::black));
}
}
-void MainWindow::slotProcessFinished(int code,QProcess::ExitStatus status)
+void MainWindow::slotProcessFinished(int code, QProcess::ExitStatus status)
{
- if(status==QProcess::NormalExit)
+ if(m_env.contains("ogactiveadmin") && m_env["ogactiveadmin"] == "true")
{
- print(tr(gettext("Proceso acabado correctamente. Valor de retorno: "))+QString::number(code));
+ // Admin user: show process status
+ if(status==QProcess::NormalExit)
+ {
+ if(code > 0)
+ {
+ m_output->setTextColor(QColor(Qt::darkRed));
+ }
+ print("\n"+tr(gettext("Fin del proceso. Valor de retorno: "))+QString::number(code));
+ }
+ else
+ {
+ m_output->setTextColor(QColor(Qt::darkRed));
+ print("\n"+tr(gettext("El proceso ha fallado inesperadamente. Salida: ")+code));
+ }
+ m_output->setTextColor(QColor(Qt::black));
}
else
{
- print(tr(gettext("El proceso ha fallado inesperadamente. Salida: ")+code));
+ // Non-admin user: show instruction to close the popup window
+ write(tr(gettext("Fin del proceso. Valor de retorno: "))+QString::number(code));
+ m_output->setFontUnderline(true);
+ print("\n\n"+tr(gettext("AVISO: Pulsar el botón superior derecho para cerrar"))+" [X]");
+ m_output->setFontUnderline(false);
+ }
+ // On error, show a message box
+ if(code > 0 && ! m_output->isActiveWindow())
+ {
+ showErrorMessage(gettext("Código de salida: ")+QString::number(code));
}
finishProgressBar();
}
void MainWindow::slotProcessError(QProcess::ProcessError error)
{
- m_output->setTextColor(QColor(Qt::darkRed));
+ QString errorMsg;
switch(error)
{
case QProcess::FailedToStart:
- print(tr(gettext("Imposible lanzar el proceso.")));
+ errorMsg=tr(gettext("Imposible lanzar el proceso."));
break;
case QProcess::WriteError:
- print(tr(gettext("Error de escritura en el proceso.")));
+ errorMsg=tr(gettext("Error de escritura en el proceso."));
break;
case QProcess::ReadError:
- print(tr(gettext("Error de lectura del proceso.")));
+ errorMsg=tr(gettext("Error de lectura del proceso."));
break;
// No capturo crashed porque la pillo por finished
case QProcess::Crashed:
@@ -327,11 +375,17 @@ void MainWindow::slotProcessError(QProcess::ProcessError error)
break;
case QProcess::UnknownError:
default:
- print(tr(gettext("Error desconocido.")));
+ errorMsg=tr(gettext("Error desconocido."));
break;
}
+ // Print error and show message box with timeout.
+ if(!errorMsg.isNull()) {
+ m_output->setTextColor(QColor(Qt::darkRed));
+ print(errorMsg);
+ m_output->setTextColor(QColor(Qt::black));
+ showErrorMessage(errorMsg);
+ }
finishProgressBar();
- m_output->setTextColor(QColor(Qt::black));
}
void MainWindow::slotCreateTerminal()
@@ -343,8 +397,6 @@ void MainWindow::slotCreateTerminal()
console->setTerminalFont(font);
console->setFocusPolicy(Qt::StrongFocus);
-
- //console->setColorScheme(COLOR_SCHEME_BLACK_ON_LIGHT_YELLOW);
console->setScrollBarPosition(QTermWidget::ScrollBarRight);
++m_numberTerminal;
@@ -367,7 +419,7 @@ void MainWindow::slotWebBarReturnPressed()
{
QUrl url(m_webBar->text());
if(url.isValid())
- slotLinkHandle(url);
+ slotLinkHandle(url);
}
int MainWindow::readEnvironmentValues()
@@ -403,32 +455,42 @@ int MainWindow::readEnvironmentValues()
return ret;
}
+// Write a string to the log file
+void MainWindow::write(QString s)
+{
+ if(! s.endsWith("\n"))
+ s+="\n";
+ if(m_logstream)
+ {
+ *m_logstream<<CURRENT_TIME()<<": browser: "<<s;
+ m_logstream->flush();
+ }
+}
+
+// Print and log a string
void MainWindow::print(QString s)
{
- if(!s.endsWith("\n"))
- s+="\n";
- if(m_logstream)
- {
- *m_logstream<<CURRENT_TIME()<<": "<<s;
- m_logstream->flush();
- }
- if(m_output)
- m_output->insertPlainText(s);
+ if(! s.endsWith("\n"))
+ s+="\n";
+ write(s);
+ if(m_output)
+ m_output->insertPlainText(s);
}
+// Show message in status bar
void MainWindow::captureOutputForStatusBar(QString output)
{
- // Capturar para modificar status bar
- output=output.trimmed();
-
- QRegExp regexp(REGEXP_STRING);
- if(regexp.indexIn(output) != -1)
- {
- int pass=regexp.cap(1).toInt();
- output.replace(regexp,"");
- m_progressBar->setValue(pass);
- m_progressBar->setFormat("%p%"+output);
- }
+ // Modify the status bar
+ output=output.trimmed();
+ // Get percentage (string starts with "[Number]")
+ QRegExp regexp(REGEXP_STRING);
+ if(regexp.indexIn(output) != -1)
+ {
+ int pass=regexp.cap(1).toInt();
+ output.replace(regexp,"");
+ m_progressBar->setValue(pass);
+ m_progressBar->setFormat("%p%"+output);
+ }
}
// Init status bar
@@ -445,13 +507,14 @@ void MainWindow::startProgressBar()
m_web->setEnabled(false);
}
+// Reset status bar
void MainWindow::finishProgressBar()
{
m_progressBar->reset();
m_web->setEnabled(true);
}
-
+// Execute a command
void MainWindow::executeCommand(QString &string)
{
QStringList list=string.split(" ",QString::SkipEmptyParts);
@@ -460,10 +523,17 @@ void MainWindow::executeCommand(QString &string)
// Assign the same Browser's environment to the process
m_process->setEnvironment(QProcess::systemEnvironment());
m_process->start(program,list);
- print(tr(gettext("Lanzando el comando: ")));
- m_output->setTextColor(QColor(Qt::darkGreen));
- print(program+" "+list.join(" "));
- m_output->setTextColor(QColor(Qt::black));
+ // Only show the command line to admin user
+ if(m_env.contains("ogactiveadmin") && m_env["ogactiveadmin"] == "true")
+ {
+ m_output->setTextColor(QColor(Qt::darkGreen));
+ print(tr(gettext("Lanzando el comando: "))+string);
+ m_output->setTextColor(QColor(Qt::black));
+ }
+ else
+ {
+ write(tr(gettext("Lanzando el comando: "))+string);
+ }
startProgressBar();
}
@@ -484,3 +554,15 @@ QString MainWindow::readSpeed() {
return QString("");
}
}
+
+// Show an error box with timeout
+void MainWindow::showErrorMessage(QString text)
+{
+ QMessageBox* msgBox=new QMessageBox();
+ msgBox->setWindowFlags(Qt::CustomizeWindowHint | Qt::WindowTitleHint);
+ msgBox->setWindowTitle(gettext("ERROR"));
+ msgBox->setIcon(QMessageBox::Warning);
+ msgBox->setText(text);
+ msgBox->show();
+ QTimer::singleShot(5000, msgBox, SLOT(close()));
+}
diff --git a/client/browser/src/mainwindow.h b/client/browser/src/mainwindow.h
index e4e02fa3..664d2f00 100644
--- a/client/browser/src/mainwindow.h
+++ b/client/browser/src/mainwindow.h
@@ -1,8 +1,12 @@
#ifndef MAINWINDOW_H
#define MAINWINDOW_H
-#define COMMAND "command:"
-#define COMMAND_WITH_CONFIRMATION "commandwithconfirmation:"
+#define COMMAND "command"
+#define COMMAND_CONFIRM "command+confirm"
+#define COMMAND_WITH_CONFIRMATION "commandwithconfirmation" // Backwards compatibility
+#define COMMAND_OUTPUT "command+output"
+#define COMMAND_CONFIRM_OUTPUT "command+confirm+output"
+#define COMMAND_OUTPUT_CONFIRM "command+output+confirm"
#define ENVIRONMENT "OGLOGFILE,ogactiveadmin,DEFAULTSPEED"
#include <QWidget>
@@ -41,7 +45,7 @@ class MainWindow : public QMainWindow
void slotWebLoadStarted();
void slotWebLoadFinished(bool ok);
void slotWebLoadProgress(int progress);
- void slotSslErrors(QNetworkReply* reply);
+ void slotSslErrors(QNetworkReply* reply);
// Funciones que manejan cada vez que el proceso hace algo
void slotProcessStarted();
@@ -62,12 +66,13 @@ class MainWindow : public QMainWindow
protected:
int readEnvironmentValues();
void print(QString s);
+ void write(QString s);
void captureOutputForStatusBar(QString output);
void startProgressBar();
void finishProgressBar();
void executeCommand(QString &string);
QString readSpeed();
-
+ void showErrorMessage(QString string);
protected:
QWebView *m_web;
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
}
-
diff --git a/client/engine/Cache.lib b/client/engine/Cache.lib
index 0e7f51ef..40715946 100755
--- a/client/engine/Cache.lib
+++ b/client/engine/Cache.lib
@@ -4,7 +4,7 @@
#@brief Librería o clase Cache
#@class Cache
#@brief Funciones para gestión de la caché local de disco.
-#@version 1.1.0
+#@version 1.1.1
#@warning License: GNU GPLv3+
#*/
@@ -44,7 +44,8 @@
function ogCreateCache ()
{
# Variables locales.
-local FINDCACHE IOSIZE NDSK SIZECACHE PART DISK START END ENDPREVPART SIZE MINSIZE MAXSIZE PTTYPE ID TMPFILE
+local FINDCACHE IOSIZE NDSK SIZECACHE PART DISK START END ENDPREVPART SIZE MINSIZE MAXSIZE
+local PTTYPE ID TMPFILE NVME_PREFIX
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
ogHelp "$FUNCNAME" "$FUNCNAME [int_ndisk [int_npart]] int_partsize" \
@@ -81,6 +82,14 @@ esac
TMPFILE=/tmp/sfdisk$$
DISK=$(ogDiskToDev $NDSK) || return $?
+
+ # PATCH Para discos nvme la particion debe ser p1, p2, etc...en lugar de 1,2, sino falla sfdisk
+NVME_PREFIX=""
+if [[ $DISK == *"nvme"* ]]; then
+ NVME_PREFIX="p"
+fi
+
+
END=$[$(ogGetLastSector $NDSK 2>/dev/null)] # Sector final del disco.
SIZE=$[$SIZECACHE*2] # Tamaño en sectores de 512 B.
# Inicio partición cache según el disco tenga sectores de 4k o menores
@@ -116,7 +125,8 @@ case "$(ogGetPartitionTableType $NDSK)" in
# Si existe la cache se borra previamente
[ -n "$(ogFindCache)" ] && ogDeleteCache
# Capturamos el codigo de particion GPT para cache
- ID=$(ogTypeToId CACHE GPT)
+ # PATCH - Cuando es GPT, la particion con codigo CACHE (CA00) no existe y no puede crearse, se cambia por LINUX (8300)
+ ID=$(ogTypeToId LINUX GPT)
sgdisk $DISK -n$PART:$START:$END -c$PART:CACHE -t$PART:$ID 2>/dev/null
;;
MSDOS)
@@ -127,7 +137,7 @@ case "$(ogGetPartitionTableType $NDSK)" in
# Salvamos la configuración de las particiones e incluimos la cache.
trap "rm -f $TMPFILE" 1 2 3 9 15
sfdisk --dump $DISK | grep -v $DISK$PART > $TMPFILE
- echo "$DISK$PART : start= $START, size= $SIZE, Id=$ID" >> $TMPFILE
+ echo "$DISK$NVME_PREFIX$PART : start= $START, size= $SIZE, Id=$ID" >> $TMPFILE
# Ordenamos las líneas de los dispositivos
UNIT=$(grep unit $TMPFILE)
grep ^/dev $TMPFILE|sort -o $TMPFILE
@@ -226,7 +236,8 @@ if [ "$*" == "help" ]; then
fi
# Obtener el dispositivo del sistema de archivos etiquetado como "CACHE".
PART=$(blkid -L "CACHE")
-
+# En discos nvme con particiones GPT la partición se detecta usando el tag PARTLABEL
+PART=${PART:-$(blkid -t PARTLABEL=CACHE | awk -F: '{print $1}')}
# Si no se detecta, obtener particiones marcadas de tipo caché en discos MSDOS.
PART=${PART:-$(sfdisk -l 2>/dev/null | awk '$6~/ca|a7/ {print $1}')}
@@ -235,7 +246,7 @@ if [ -z "$PART" ]; then
for DISK in $(ogDiskToDev); do
# Nota: se añade espacio separador solo si existe valor previo.
PART="${PART:+"$PART "}$(sgdisk -p $DISK 2>/dev/null | awk -v d=$DISK '$7~/CACHE/ {printf "%s%s",d,$1;}')"
- done
+ done
fi
# Devolver número de disco y número de partición de la 1ª partición encontrada.
diff --git a/client/engine/Disk.lib b/client/engine/Disk.lib
index 06744bd9..f7def42e 100755
--- a/client/engine/Disk.lib
+++ b/client/engine/Disk.lib
@@ -4,7 +4,7 @@
#@brief Librería o clase Disk
#@class Disk
#@brief Funciones para gestión de discos y particiones.
-#@version 1.1.0
+#@version 1.1.1
#@warning License: GNU GPLv3+
#*/
@@ -47,7 +47,8 @@ timeout -k 5s -s KILL 3s $(which parted) "$@"
function ogCreatePartitions ()
{
# Variables locales.
-local ND DISK PTTYPE PART SECTORS START SIZE TYPE CACHEPART IODISCO IOSIZE CACHESIZE EXTSTART EXTSIZE tmpsfdisk
+local ND DISK PTTYPE PART SECTORS START SIZE TYPE CACHEPART IODISCO IOSIZE CACHESIZE
+local EXTSTART EXTSIZE NVME_PREFIX tmpsfdisk
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk str_parttype:int_partsize ..." \
@@ -94,12 +95,18 @@ trap "rm -f $tmpsfdisk" 1 2 3 9 15
echo "unit: sectors" >$tmpsfdisk
echo >>$tmpsfdisk
+NVME_PREFIX=""
+if [[ $DISK == *"nvme"* ]]; then
+ NVME_PREFIX="p"
+fi
+
+
# Generar fichero de entrada para "sfdisk" con las particiones.
shift
while [ $# -gt 0 ]; do
# Conservar los datos de la partición de caché.
if [ "$ND $PART" == "$CACHEPART" -a -n "$CACHESIZE" ]; then
- echo "$DISK$PART : start=$[SECTORS+1], size=$CACHESIZE, Id=ca" >>$tmpsfdisk
+ echo "$DISK$NVME_PREFIX$PART : start=$[SECTORS+1], size=$CACHESIZE, Id=ca" >>$tmpsfdisk
PART=$[PART+1]
fi
# Leer formato de cada parámetro - Tipo:Tamaño
@@ -125,7 +132,7 @@ while [ $# -gt 0 ]; do
SECTORS=$[EXTSTART+EXTSIZE]
fi
# Generar datos para la partición.
- echo "$DISK$PART : start=$START, size=$SIZE, Id=$ID" >>$tmpsfdisk
+ echo "$DISK$NVME_PREFIX$PART : start=$START, size=$SIZE, Id=$ID" >>$tmpsfdisk
# Error si se supera el nº total de sectores.
START=$[START+SIZE]
if [ "$IOSIZE" == "4096" -a $PART -gt 4 ]; then
@@ -138,9 +145,9 @@ done
# Si no se indican las 4 particiones primarias, definirlas como vacías, conservando la partición de caché.
while [ $PART -le 4 ]; do
if [ "$ND $PART" == "$CACHEPART" -a -n "$CACHESIZE" ]; then
- echo "$DISK$PART : start=$[SECTORS+1], size=$CACHESIZE, Id=ca" >>$tmpsfdisk
+ echo "$DISK$NVME_PREFIX$PART : start=$[SECTORS+1], size=$CACHESIZE, Id=ca" >>$tmpsfdisk
else
- echo "$DISK$PART : start=0, size=0, Id=0" >>$tmpsfdisk
+ echo "$DISK$NVME_PREFIX$PART : start=0, size=0, Id=0" >>$tmpsfdisk
fi
PART=$[PART+1]
done
@@ -258,7 +265,7 @@ ogCreatePartitionTable $ND
# Definir particiones y notificar al kernel.
# Borramos primero las particiones y luego creamos las nuevas
sgdisk $DELOPTIONS $OPTIONS $DISK 2>/dev/null && partprobe $DISK
-[ -n "$CACHESIZE" ] && ogMountCache 2>/dev/null
+[ -n "$CACHESIZE" ] && ogMountCache 2>/dev/null || return 0
}
@@ -396,7 +403,7 @@ esac
function ogDevToDisk ()
{
# Variables locales.
-local CACHEFILE DEV PART d n
+local CACHEFILE DEV PART NVME_PREFIX d n
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
ogHelp "$FUNCNAME" "$FUNCNAME path_device | LABEL=str_label | UUID=str_uuid" \
@@ -431,7 +438,13 @@ fi
# Si no se encuentra, procesa todos los discos para devolver su nº de orden y de partición.
n=1
for d in $(ogDiskToDev); do
- [ -n "$(echo $DEV | grep $d)" ] && echo "$n ${DEV#$d}" && return
+NVME_PREFIX=""
+if [[ $d == *"nvme"* ]]; then
+ NVME_PREFIX="p"
+fi
+
+
+ [ -n "$(echo $DEV | grep $d)" ] && echo "$n ${DEV#$d$NVME_PREFIX}" && return
n=$[n+1]
done
ogRaiseError $OG_ERR_NOTFOUND "$1"
@@ -684,11 +697,20 @@ echo $TYPE
function ogGetEsp ()
{
local PART d
-for d in $(blkid -t TYPE=vfat -o device); do
- PART="$(ogDevToDisk $d)"
- if [ "$(ogGetPartitionId $PART)" == "$(ogTypeToId EFI GPT)" ]; then
- echo $PART
- break
+for d in $(blkid -o device|sort); do
+ # Previene error para /dev/loop0
+ PART="$(ogDevToDisk $d 2>/dev/null)" || continue
+ # En discos NVMe blkid devuelve una salida del tipo:
+ # >/dev/loop0
+ # >/dev/nvme0n1
+ # >/dev/nvme0n1p1
+ # al analizar la particion nvme0n1, PART solo tiene un argumento y hace que ogGetPartitionId lance un error
+ LEN=$(echo $PART | awk '{ print length($0) }')
+ if [ $LEN -gt 1 ]; then
+ if [ "$(ogGetPartitionId $PART)" == "$(ogTypeToId EFI GPT)" ]; then
+ echo $PART
+ break
+ fi
fi
done
}
@@ -1024,6 +1046,9 @@ echo "$TYPE"
#@version 1.0 - Versión en pruebas.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2010/01/12
+#@version 1.1.1 - Se incluye tipo Windows para UEFI (ticket #802)
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019/01/18
#*/ ##
function ogHidePartition ()
{
@@ -1046,6 +1071,7 @@ case "$TYPE" in
FAT32) NEWTYPE="HFAT32" ;;
FAT16) NEWTYPE="HFAT16" ;;
FAT12) NEWTYPE="HFAT12" ;;
+ WINDOWS)NEWTYPE="WIN-RESERV";;
*) ogRaiseError $OG_ERR_PARTITION "$TYPE"
return $? ;;
esac
@@ -1314,6 +1340,10 @@ if [ "$*" == "help" ]; then
"$FUNCNAME 1 1"
return
fi
+
+# Si el EFI esta activo me salgo.
+ogIsEfiActive && ogEcho session log warning "EFI: $MSG_DONTUSE $FUNCNAME" && return
+
# Error si no se reciben 2 parámetros.
[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
@@ -1595,6 +1625,9 @@ echo $ID
#@version 1.0 - Versión en pruebas.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2010/01/12
+#@version 1.1.1 - Se incluye tipo Windows Reserver para UEFI (ticket #802)
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019/01/18
#*/ ##
function ogUnhidePartition ()
{
@@ -1613,10 +1646,11 @@ PART=$(ogDiskToDev "$1" "$2") || return $?
# Obtener tipo de partición.
TYPE=$(ogGetPartitionType "$1" "$2")
case "$TYPE" in
- HNTFS) NEWTYPE="NTFS" ;;
- HFAT32) NEWTYPE="FAT32" ;;
- HFAT16) NEWTYPE="FAT16" ;;
- HFAT12) NEWTYPE="FAT12" ;;
+ HNTFS) NEWTYPE="NTFS" ;;
+ HFAT32) NEWTYPE="FAT32" ;;
+ HFAT16) NEWTYPE="FAT16" ;;
+ HFAT12) NEWTYPE="FAT12" ;;
+ WIN-RESERV) NEWTYPE="WINDOWS" ;;
*) ogRaiseError $OG_ERR_PARTITION "$TYPE"
return $? ;;
esac
diff --git a/client/engine/FileSystem.lib b/client/engine/FileSystem.lib
index 0642a854..aa1778eb 100755
--- a/client/engine/FileSystem.lib
+++ b/client/engine/FileSystem.lib
@@ -55,24 +55,24 @@ PART="$(ogDiskToDev $1 $2)" || return $?
TYPE=$(ogGetFsType $1 $2)
case "$TYPE" in
- EXT[234]) PROG="e2fsck"; PARAMS="-y"; CODES=(1 2) ;;
- BTRFS) PROG="btrfsck"; CODES=(1) ;;
- REISERFS) PROG="fsck.reiserfs"; PARAMS="<<<\"Yes\""; CODES=(1 2) ;;
- REISER4) PROG="fsck.reiser4"; PARAMS="-ay" ;;
- JFS) PROG="fsck.jfs"; CODES=(1 2) ;;
- XFS) PROG="xfs_repair" ;;
- F2FS) PROG="fsck.f2fs" ;;
- NTFS) PROG="ntfsfix" ;;
- EXFAT) PROG="fsck.exfat" ;;
- FAT32) PROG="dosfsck"; PARAMS="-a"; CODES=(1) ;;
- FAT16) PROG="dosfsck"; PARAMS="-a"; CODES=(1) ;;
- FAT12) PROG="dosfsck"; PARAMS="-a"; CODES=(1) ;;
- HFS) PROG="fsck.hfs"; PARAMS="-f" ;;
- HFSPLUS) PROG="fsck.hfs"; PARAMS="-f" ;;
- UFS) PROG="fsck.ufs" ;;
- ZFS) PROG="fsck.zfs" ;;
- *) ogRaiseError $OG_ERR_PARTITION "$1, $2, $TYPE"
- return $? ;;
+ EXT[234]|CACHE) PROG="e2fsck"; PARAMS="-y"; CODES=(1 2) ;;
+ BTRFS) PROG="btrfsck"; CODES=(1) ;;
+ REISERFS) PROG="fsck.reiserfs"; PARAMS="<<<\"Yes\""; CODES=(1 2) ;;
+ REISER4) PROG="fsck.reiser4"; PARAMS="-ay" ;;
+ JFS) PROG="fsck.jfs"; CODES=(1 2) ;;
+ XFS) PROG="xfs_repair" ;;
+ F2FS) PROG="fsck.f2fs" ;;
+ NTFS) PROG="ntfsfix" ;;
+ EXFAT) PROG="fsck.exfat" ;;
+ FAT32) PROG="dosfsck"; PARAMS="-a"; CODES=(1) ;;
+ FAT16) PROG="dosfsck"; PARAMS="-a"; CODES=(1) ;;
+ FAT12) PROG="dosfsck"; PARAMS="-a"; CODES=(1) ;;
+ HFS) PROG="fsck.hfs"; PARAMS="-f" ;;
+ HFSPLUS) PROG="fsck.hfs"; PARAMS="-f" ;;
+ UFS) PROG="fsck.ufs" ;;
+ ZFS) PROG="fsck.zfs" ;;
+ *) ogRaiseError $OG_ERR_PARTITION "$1, $2, $TYPE"
+ return $? ;;
esac
# Error si el sistema de archivos esta montado o bloqueado.
ogUnmount $1 $2
diff --git a/client/engine/Inventory.lib b/client/engine/Inventory.lib
index 853f0d18..f3a779d7 100755
--- a/client/engine/Inventory.lib
+++ b/client/engine/Inventory.lib
@@ -90,7 +90,6 @@ esac
}
-
#/**
# ogGetSerialNumber
#@brief Obtiene el nº de serie del cliente.
@@ -98,17 +97,22 @@ esac
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2015-06-08
#*/ ##
-
function ogGetSerialNumber ()
{
+# Variables locales.
+local SERIALNO
# Si se solicita, mostrar ayuda.
if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$FUNCNAME"
+ ogHelp "$FUNCNAME" "$FUNCNAME" "$FUNCNAME => 123456"
return
fi
-# Obtener nº de serie (ignorar los no especificados)
-dmidecode -s system-serial-number | egrep -vi "(^[ 0]+$|not specified|filled by o.e.m.)"
+# Obtener nº de serie (ignorar los no especificados).
+SERIALNO=$(dmidecode -s system-serial-number | egrep -vi "(^[ 0]+$|not specified|to be filled|invalid entry|default string)")
+# Truncar cadena si >25 caracteres.
+[ ${#SERIALNO} -gt 25 ] && SERIALNO="${SERIALNO:0:22}..."
+[ -n "$SERIALNO" ] && echo "$SERIALNO"
+return 0
}
@@ -499,4 +503,4 @@ fi
# Mostrar resultado y salir sin errores.
[ -n "$VERSION" ] && echo "$TYPE:$VERSION $IS64BIT"
return 0
-} \ No newline at end of file
+}
diff --git a/client/engine/PostConf.lib b/client/engine/PostConf.lib
index 4e07f5a0..08f4621f 100755
--- a/client/engine/PostConf.lib
+++ b/client/engine/PostConf.lib
@@ -468,128 +468,41 @@ EOT
#/**
# ogInstallLinuxClient int_ndisk int_filesys
-#@brief Instala el cliente OpenGnSys para sistemas operativos GNU/Linux.
-#@param int_ndisk nº de orden del disco
-#@param int_filesys nº de orden del sistema de archivos
-#@return (nada)
-#@exception OG_ERR_FORMAT Formato incorrecto.
-#@exception OG_ERR_NOTFOUND Fichero o dispositivo no encontrado.
-#@exception OG_ERR_PARTITION Paritición o sistema de archivos incorrectos.
-#@exception OG_ERR_LOCKED Sistema de archivos bloqueado.
+#@brief Instala el cliente OpenGnSys para sistemas operativos GNU/Linux (obsoleta).
#@version 1.0.4 - Primera adaptación para OpenGnSys.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2012-04-10
#@version 1.0.5 - Evitar duplicidad de instalación del cliente.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2014-03-06
+#@version 1.1.1 - Marked as obsolete.
+#@author Ramon Gomez, ETSII Universidad de Sevilla
+#@date 2019-09-25
#*/ ##
function ogInstallLinuxClient ()
{
-# Variables locales.
-local MNTDIR CLIENTFILE i SBINDIR ETCDIR RCLOCAL
-# Si se solicita, mostrar ayuda.
-if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_filesys" \
- "$FUNCNAME 1 1"
- return
-fi
-
-# Error si no se reciben 2 parámetros.
-[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT || return $?
-# Obtener sistema de archvios.
-MNTDIR=$(ogMount $1 $2) || return $?
-
-# Comprobar si existe el cliente y los directorios y ficheros destino.
-CLIENTFILE=$OGLIB/ogclient/ogAdmLnxClient
-[ -f $CLIENTFILE ] || ogRaiseError $OG_ERR_FOUND "$CLIENTFILE" || return $?
-for i in /usr/local/sbin /sbin /usr/sbin; do
- [ -d $MNTDIR/$i ] && SBINDIR=$i
-done
-[ -n "$SBINDIR" ] || ogRaiseError $OG_ERR_NOTFOUND "$1 $2 sbin" || return $?
-for i in /usr/local/etc /etc; do
- [ -d $MNTDIR/$i ] && ETCDIR=$i
-done
-[ -n "$ETCDIR" ] || ogRaiseError $OG_ERR_NOTFOUND "$1 $2 etc" || return $?
-for i in $ETCDIR/rc.local $ETCDIR/rc.d/rc.local; do
- [ -f $i ] && RCLOCAL=$i
-done
-[ -n "$RCLOCAL" ] || ogRaiseError $OG_ERR_NOTFOUND "$1 $2 rc.local" || return $?
-# Realizar la instalación en modo uso exclusivo.
-ogLock $1 $2
-trap "ogUnlock $1 $2" 1 2 3 6 9
-# Copiar cliente, generar fichero de configuración e incluir en el arranque.
-cp -a $CLIENTFILE $MNTDIR/$SBINDIR
-cat > $MNTDIR/$ETCDIR/ogAdmLnxClient.cfg << EOT
-ServidorAdm=$(ogGetServerIp)
-PUERTO=2008
-IPLOCAL=$(ogGetIpAddress)
-EOT
-cp -a $MNTDIR/$RCLOCAL /tmp/rclocal
-awk -v sbin=$SBINDIR -v etc=$ETCDIR \
- '{ if (/^#/) { print; }
- else {
- if (loc==0) {
- printf "%s/ogAdmLnxClient -f %s/ogAdmLnxClient.cfg &\n",sbin,etc;
- loc=1; }
- if (! /ogAdmLnxClient/)
- print; }
- }' /tmp/rclocal > $MNTDIR/$RCLOCAL
-rm /tmp/rclocal
-ogUnlock $1 $2
}
#/**
# ogInstallWindowsClient int_ndisk int_filesys str_filename
-#@brief Instala el cliente OpenGnSys para sistemas operativos Windows.
-#@param int_ndisk nº de orden del disco
-#@param int_npartition nº de orden de la partición
-#@param str_filename nombre del fichero cmd donde deberemos introducir el comando de ejecutar el script vbs
-#@return (nada)
-#@exception OG_ERR_FORMAT Formato incorrecto.
-#@exception OG_ERR_NOTFOUND Fichero o dispositivo no encontrado.
-#@exception OG_ERR_PARTITION Paritición o sistema de archivos incorrectos.
-#@exception OG_ERR_LOCKED Sistema de archivos bloqueado.
+#@brief Instala el cliente OpenGnSys para sistemas operativos Windows (obsoleta).
#@version 1.0.4 - Primera adaptación para OpenGnSys.
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2012-04-11
#@version 1.0.5 - Cambios en los parametros de entrada y funcionamiento de la funcion
#@author Jonathan Alonso Martinez - Universidad Autonoma de Barcelona
#@date 2013-02-12
+#@version 1.1.1 - Marked as obsolete.
+#@author Ramon Gomez, ETSII Universidad de Sevilla
+#@date 2019-09-25
#*/ ##
function ogInstallWindowsClient ()
{
-# Variables locales.
-local MNTDIR CLIENTFILE i DIR WINDIR
-# Si se solicita, mostrar ayuda.
-if [ "$*" == "help" ]; then
- ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_filesys str_filename" \
- "$FUNCNAME 1 1 filename.cmd"
- return
-fi
-
-# Error si no se reciben 3 parámetros.
-[ $# == 3 ] || ogRaiseError $OG_ERR_FORMAT || return $?
-# Obtener sistema de archvios.
-MNTDIR=$(ogMount $1 $2) || return $?
-
-# Comprobar si existe el cliente y los directorios y ficheros destino.
-CLIENTFILE=$OGLIB/ogclient/ogAdmWinClient.exe
-[ -f $CLIENTFILE ] || ogRaiseError $OG_ERR_FOUND "$CLIENTFILE" || return $?
-for i in winnt windows; do
- DIR=$(ogGetPath $MNTDIR/$i)
- [ -n "$DIR" ] && WINDIR=$DIR
-done
-[ -n "$WINDIR " ] || ogRaiseError $OG_ERR_NOTFOUND "$1 $2 windows" || return $?
-# Copiar cliente e incluir en el fichero de configuracion dado que instale el cliente en el arranque.
-cp -a $CLIENTFILE "$WINDIR"
-ogAddCmd $1 $2 $3 "ogAdmWinClient -remove"
-ogAddCmd $1 $2 $3 "ogAdmWinClient -install -s $(ogGetServerIp) -p 2008 -i $(ogGetIpAddress)"
}
-
#/**
# ogUninstallLinuxClient int_ndisk int_filesys
#@brief Desinstala el cliente OpenGnSys para sistemas operativos GNU/Linux.
diff --git a/client/engine/Protocol.lib b/client/engine/Protocol.lib
index 279961a5..c58d262b 100755
--- a/client/engine/Protocol.lib
+++ b/client/engine/Protocol.lib
@@ -399,7 +399,7 @@ fi
##### BEGIN SERVER SESSION #####
# 2º param check: controlamos el primer componente comun de las sesiones de servidor y cliente: PORTBASE
PORTBASE=${SESSION[0]}
-ogCheckStringInGroup ${SESSION[0]} "$(seq 9000 2 9050)" || ogRaiseError $OG_ERR_FORMAT "McastSession portbase ${SESSION[0]}" || PERROR=3 #return $?
+ogCheckStringInGroup ${SESSION[0]} "$(seq 9000 2 9100)" || ogRaiseError $OG_ERR_FORMAT "McastSession portbase ${SESSION[0]}" || PERROR=3 #return $?
# 2º param check: Controlamos el resto de componenentes de la sesion del servidor.
if [ $MODE == "server" ]
then
diff --git a/client/engine/Registry.lib b/client/engine/Registry.lib
index dbe69aee..60f7124b 100755
--- a/client/engine/Registry.lib
+++ b/client/engine/Registry.lib
@@ -15,7 +15,7 @@ function chntpw ()
local CHNTPW
CHNTPW=$(which drbl-chntpw)
CHNTPW=${CHNTPW:-$(which chntpw)}
-timeout --foreground 5s $CHNTPW "$@"
+timeout --foreground 5s $CHNTPW -e "$@"
}
diff --git a/client/engine/System.lib b/client/engine/System.lib
index d016be13..77f77b48 100755
--- a/client/engine/System.lib
+++ b/client/engine/System.lib
@@ -243,6 +243,7 @@ case "$CODE" in
$OG_ERR_DONTSYNC_IMAGE) MSG="$MSG_ERR_DONTSYNC_IMAGE \"$2\"" ;;
$OG_ERR_NOTDIFFERENT) MSG="$MSG_ERR_NOTDIFFERENT \"$2\"" ;;
$OG_ERR_SYNCHRONIZING) MSG="$MSG_ERR_SYNCHRONIZING \"$2\"" ;;
+ $OG_ERR_NOTUEFI) MSG="$MSG_ERR_NOTUEFI \"$2\"" ;;
*) MSG="$MSG_ERR_GENERIC"; CODE=$OG_ERR_GENERIC ;;
esac
diff --git a/client/engine/UEFI.lib b/client/engine/UEFI.lib
new file mode 100644
index 00000000..cd7168e7
--- /dev/null
+++ b/client/engine/UEFI.lib
@@ -0,0 +1,645 @@
+#!/bin/bash
+# Libreria provisional para uso de UEFI
+# Las funciones se incluirán las librerías ya existentes
+
+#/**
+# ogNvramActiveEntry
+#@brief Activa entrada de la NVRAM identificada por la etiqueta o el orden
+#@param Num_order_entry | Label_entry Número de orden o la etiqueta de la entrada a borrar.
+#@return (nada)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#*/ ##
+function ogNvramActiveEntry () {
+local NUMENTRY
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME [ Num_order_entry | Label_entry ] " \
+ "$FUNCNAME 2" \
+ "$FUNCNAME \"Windows Boot Manager\""
+ return
+fi
+
+# Error si no se recibe 1 parámetro.
+[ $# -eq 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME [ Num_order_entry | Label_entry ]" || return $?
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+# Distingo si es número de orden o etiqueta
+if [[ $1 =~ ^([0-9a-fA-F]+)$ ]]; then
+ NUMENTRY=$( efibootmgr |awk -v NUM="$(printf %04x 0x$1|tr '[:lower:]' '[:upper:]')" '{ if($1~NUM) print substr($1,5,4)}')
+else
+ NUMENTRY=$(efibootmgr |awk -v LABEL="$1" '{ if(substr($0, index($0,$2))==LABEL) print substr($1,5,4)}')
+fi
+
+[ "$NUMENTRY" == "" ] && return $(ogRaiseError $OG_ERR_NOTFOUND "NVRAM entry '$1'")
+
+efibootmgr -a -b $NUMENTRY &>/dev/null
+}
+
+#/**
+# ogNvramAddEntry
+#@brief Crea nueva entrada en el gestor de arranque (NVRAM), opcionalmente la incluye al final del orden de arranque.
+#@param Str_Label_entry Número de disco o etiqueta de la entrada a crear.
+#@param Str_BootLoader Número de partición o cargador de arranque.
+#@param Bool_Incluir_Arranque Incluir en el orden de arranque (por defecto FALSE) (opcional)
+#@return (nada)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#*/ ##
+function ogNvramAddEntry () {
+local EFIDISK EFIPART BOOTLABEL BOOTLOADER ADDORDER
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME Str_label_entry Str_boot_loader [ Bool_add_bootorder ]" \
+ "$FUNCNAME 1 2 TRUE" \
+ "$FUNCNAME grub /EFI/grub/grubx64.efi TRUE" \
+ "$FUNCNAME Windows /EFI/Microsoft/Boot/bootmgfw.efi"
+ return
+fi
+
+# Error si no se recibe 1 parámetro.
+[ $# -ge 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME Str_label_entry Str_boot_locader" || return $?
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
+[ -n "$EFIPART" ] || ogRaiseError $OG_ERR_NOTFOUND "ESP" || return $?
+
+# Recogemos parámetros
+# Distinguimos si es disco/partición o etiqueta/cargador
+if [[ "$1$2" =~ ^([0-9]+)$ ]]; then
+ BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
+ BOOTLOADER="/EFI/$BOOTLABEL/Boot/ogloader.efi"
+else
+ BOOTLABEL="$1"
+ BOOTLOADER="$2"
+fi
+
+
+# Si existe entrada con la misma etiqueta la borramos
+ogNvramDeleteEntry "$BOOTLABEL" 2>/dev/null
+
+efibootmgr -C -d $(ogDiskToDev $EFIDISK) -p $EFIPART -L "$BOOTLABEL" -l "$BOOTLOADER" &>/dev/null
+
+# Incluimos la entrada en el orden de arranque (opcional)
+if [ "${3^^}" == "TRUE" ]; then
+ NUMENTRY=$(efibootmgr |awk -v LABEL="$BOOTLABEL" '{ if(substr($0, index($0,$2))==LABEL) print substr($1,5,4)}')
+ ogNvramSetOrder $(ogNvramGetOrder |tr , " ") $NUMENTRY
+fi
+}
+
+
+#/**
+# ogCopyEfiBootLoader int_ndisk str_repo path_image
+#@brief Copia el cargador de arranque desde la partición EFI a la de sistema.
+#@param int_ndisk nº de orden del disco
+#@param int_part nº de partición
+#@return (nada, por determinar)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#@note Si existe el cargador en la partición de sistema no es válido
+#*/ ##
+function ogCopyEfiBootLoader () {
+# Variables locales
+local MNTDIR EFIDIR BOOTLABEL OSVERSION LOADER f
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part" \
+ "$FUNCNAME 1 2"
+ return
+fi
+
+# Error si no se reciben 2 arámetros.
+[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part" || return $?
+
+# Comprobamos que exista partición de sistema y la ESP
+MNTDIR=$(ogMount $1 $2) || ogRaiseError $OG_ERR_PARTITION "$DISK $PART" || return $?
+EFIDIR=$(ogMount $(ogGetEsp)) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
+
+# Comprobamos que exista el cargador
+BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
+OSVERSION=$(ogGetOsVersion $1 $2)
+case $OSVERSION in
+ *Windows\ 10*)
+ for f in $EFIDIR/EFI/{$BOOTLABEL,Microsoft}/Boot/bootmgfw.efi; do
+ [ -r $f ] && LOADER=$f
+ done
+ [ -n "$LOADER" ] || ogRaiseError $OG_ERR_NOTOS "$1 $2 ($OSVERSION, EFI)" || return $?
+ # Si existe el directorio Boot lo borramos
+ [ -d $MNTDIR/Boot ] && rm -rf $MNTDIR/Boot
+ DIRLOADER=$(realpath "${LOADER%/*}/..")
+ cp -r ${DIRLOADER}/Boot $MNTDIR
+ ;;
+esac
+}
+
+
+#/**
+# ogNvramDeleteEntry
+#@brief Borra entrada de la NVRAM identificada por la etiqueta o el orden
+#@param Num_order_entry | Label_entry Número de orden o la etiqueta de la entrada a borrar.
+#@return (nada)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado (entrada en NVRAM).
+#*/ ##
+function ogNvramDeleteEntry () {
+local NUMENTRY n
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME [ Num_order_entry | Label_entry ] " \
+ "$FUNCNAME 2" \
+ "$FUNCNAME \"Windows Boot Manager\""
+ return
+fi
+
+# Error si no se recibe 1 parámetro.
+[ $# -eq 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME [ Num_order_entry | Label_entry ]" || return $?
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+# Distingo si es número de orden o etiqueta
+if [[ $1 =~ ^([0-9a-fA-F]+)$ ]]; then
+ NUMENTRY=$( efibootmgr |awk -v NUM="$(printf %04x 0x$1|tr '[:lower:]' '[:upper:]')" '{ if($1~NUM) print substr($1,5,4)}')
+else
+ NUMENTRY=$(efibootmgr |awk -v LABEL="$1" '{ if(substr($0, index($0,$2))==LABEL) print substr($1,5,4)}')
+fi
+
+[ "$NUMENTRY" == "" ] && return $(ogRaiseError $OG_ERR_NOTFOUND "NVRAM entry '$1'")
+
+for n in $NUMENTRY; do
+ efibootmgr -B -b $n &>/dev/null
+done
+}
+
+
+#/**
+# ogNvramGetCurrent
+#@brief Muestra la entrada del gestor de arranque (NVRAM) que ha iniciado el equipo.
+#@return Entrada con la que se ha iniciado el equipo
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#*/ ##
+function ogNvramGetCurrent () {
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME" \
+ "$FUNCNAME"
+ return
+fi
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+efibootmgr| awk -v bootentry=99999 '{if ($1~/BootCurrent/) bootentry=$2; if ($1~bootentry) printf "%s %s %s\n", gensub(/^0{1,3}/,"",1,substr($1,5,4))," ", substr($0, index($0,$2))}'
+}
+
+
+# ogNvramGetNext
+#@brief Muestra la entrada del gestor de arranque (NVRAM) que se utilizará en el próximo arranque.
+#@return Entrada que se utilizará en el próximo arranque
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#*/ ##
+function ogNvramGetNext () {
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME" \
+ "$FUNCNAME"
+ return
+fi
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+efibootmgr|awk '{ if ($1 == "BootNext:") print $2}'
+}
+
+
+# ogNvramGetOrder
+#@brief Muestra el orden de las entradas del gestor de arranque (NVRAM)
+#@return Orden de las entradas
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#*/ ##
+function ogNvramGetOrder () {
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME" \
+ "$FUNCNAME"
+ return
+fi
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+efibootmgr|awk '{ if ($1 == "BootOrder:") print $2}'
+}
+
+
+#/**
+# ogNvramGetTimeout
+#@brief Muestra el tiempo de espera del gestor de arranque (NVRAM)
+#@return Timeout de la NVRAM
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#*/ ##
+function ogNvramGetTimeout () {
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME" \
+ "$FUNCNAME"
+ return
+fi
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+efibootmgr|awk '{ if ($1 == "Timeout:") print substr($0, index($0,$2))}'
+}
+
+
+#/**
+# ogGrubUefiConf int_ndisk int_part str_dir_grub
+#@brief Genera el fichero grub.cfg de la ESP
+#@param int_ndisk nº de orden del disco
+#@param int_part nº de partición
+#@param str_dir_grub prefijo del directorio de grub en la partición de sistema. ej: /boot/grubPARTITION
+#@return (nada, por determinar)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#@TODO Confirmar si el fichero "$EFIDIR/EFI/$BOOTLABEL/grub.cfg" es necesario.
+#*/ ##
+function ogGrubUefiConf () {
+local EFIDIR BOOTLABEL GRUBEFI UUID DEVICE PREFIXSECONDSTAGE EFIGRUBDIR
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part [ str_dir_grub ]" \
+ "$FUNCNAME 1 2" \
+ "$FUNCNAME 1 3 /boot/grubPARTITION"
+ return
+fi
+
+# Error si no se reciben al menos 2 parámetros.
+[ $# -ge 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part [ str_dir_grub ]" || return $?
+
+# Directorio del grub en la partición de sistema
+PREFIXSECONDSTAGE="$3"
+
+EFIDIR=$(ogMount $(ogGetEsp)) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
+BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
+EFIGRUBDIR="$EFIDIR/EFI/$BOOTLABEL/boot/grub"
+# Comprobamos que existe directorio
+[ -d "$EFIGRUBDIR" ] || mkdir -p "$EFIGRUBDIR"
+# Parcheamos uuid y particion en grub.cfg
+UUID=$(blkid -o value -s UUID $(ogDiskToDev $1 $2))
+DEVICE="hd$(expr $1 - 1 ),gpt$2"
+
+cat << EOT > $EFIGRUBDIR/grub.cfg
+set root='$DEVICE'
+set prefix=(\$root)'${PREFIXSECONDSTAGE}/boot/grub'
+configfile \$prefix/grub.cfg
+EOT
+
+# Provisional: confirmar si el segundo archivo se utiliza
+cp $EFIGRUBDIR/grub.cfg "$EFIDIR/EFI/$BOOTLABEL/grub.cfg"
+}
+
+
+#/**
+# ogNvramInactiveEntry
+#@brief Inactiva entrada de la NVRAM identificada por la etiqueta o el orden
+#@param Num_order_entry | Label_entry Número de orden o la etiqueta de la entrada a borrar.
+#@return (nada)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#*/ ##
+function ogNvramInactiveEntry () {
+local NUMENTRY
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME [ Num_order_entry | Label_entry ] " \
+ "$FUNCNAME 2" \
+ "$FUNCNAME \"Windows Boot Manager\""
+ return
+fi
+
+# Error si no se recibe 1 parámetro.
+[ $# -eq 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME [ Num_order_entry | Label_entry ]" || return $?
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+# Distingo si es número de orden o etiqueta
+if [[ $1 =~ ^([0-9a-fA-F]+)$ ]]; then
+ NUMENTRY=$( efibootmgr |awk -v NUM="$(printf %04x 0x$1|tr '[:lower:]' '[:upper:]')" '{ if($1~NUM) print substr($1,5,4)}')
+else
+ NUMENTRY=$(efibootmgr |awk -v LABEL="$1" '{ if(substr($0, index($0,$2))==LABEL) print substr($1,5,4)}')
+fi
+
+[ "$NUMENTRY" == "" ] && return $(ogRaiseError $OG_ERR_NOTFOUND "NVRAM entry '$1'")
+
+efibootmgr -A -b $NUMENTRY &>/dev/null
+}
+
+
+#/**
+# ogNvramList
+#@brief Lista las entradas de la NVRAN (sólo equipos UEFI)
+#@return Entradas de la NVRAM con el formato: orden etiqueta [* (si está activa) ]
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#*/ ##
+function ogNvramList () {
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME" \
+ "$FUNCNAME"
+ return
+fi
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+efibootmgr |awk '{if($1~/Boot[[:digit:]]/) ; active="" ;if ($1~/*/) active="*"; if($1~/Boot[[:digit:]]/) printf "%4s %s %s %s\n", gensub(/^0{1,3}/,"",1,substr($1,5,4))," ", substr($0, index($0,$2)), active}'
+}
+
+
+#/**
+# ogRestoreEfiBootLoader int_ndisk str_repo
+#@brief Copia el cargador de arranque de la partición de sistema a la partición EFI.
+#@param int_ndisk nº de orden del disco
+#@param int_part nº de partición
+#@return (nada, por determinar)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado (partición de sistema o EFI).
+#@exception OG_ERR_NOTOS sin sistema operativo.
+#*/ ##
+function ogRestoreEfiBootLoader () {
+# Variables locales
+local MNTDIR EFIDIR BOOTLABEL OSVERSION LOADER f UUID DEVICE
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part" \
+ "$FUNCNAME 1 2"
+ return
+fi
+
+# Error si no se reciben 2 arámetros.
+[ $# == 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part" || return $?
+
+# Comprobamos que exista partición de sistema y la ESP
+MNTDIR=$(ogMount $1 $2) || ogRaiseError $OG_ERR_PARTITION "$DISK $PART" || return $?
+EFIDIR=$(ogMount $(ogGetEsp))
+if [ "$EFIDIR" == "" ]; then
+ ogFormat $(ogGetEsp) FAT32
+ EFIDIR=$(ogMount $(ogGetEsp)) || ogRaiseError $OG_ERR_PARTITION "ESP" || return $?
+fi
+
+# Comprobamos que exista el cargador
+#BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
+OSVERSION=$(ogGetOsVersion $1 $2)
+case $OSVERSION in
+ *Windows\ 10*)
+ BOOTLABEL=$(printf "Part-%02d-%02d" $1 $2)
+ LOADER=$(ogGetPath $MNTDIR/Boot/bootmgfw.efi)
+ [ -n "$LOADER" ] || ogRaiseError $OG_ERR_NOTOS "$1 $2 ($OSVERSION, EFI)" || return $?
+ [ -r $EFIDIR/$BOOTLABEL ] && rm -rf $EFIDIR/$BOOTLABEL
+ mkdir -p $EFIDIR/EFI/$BOOTLABEL
+ cp -r "${LOADER%/*}" $EFIDIR/EFI/$BOOTLABEL
+ # Nombre OpenGnsys para cargador
+ cp $LOADER $EFIDIR/EFI/$BOOTLABEL/Boot/ogloader.efi
+ ;;
+esac
+}
+
+
+#/**
+# ogRestoreUuidPartitions
+#@brief Restaura los uuid de las particiones y la tabla de particiones
+#@param int_ndisk nº de orden del disco
+#@param int_nfilesys nº de orden del sistema de archivos
+#@param REPO|CACHE repositorio
+#@param str_imgname nombre de la imagen
+#@return (nada)
+#@exception OG_ERR_FORMAT Formato incorrecto.
+#@exception OG_ERR_NOTFOUND No encontrado fichero de información de la imagen (con uuid)
+#*/ ##
+function ogRestoreUuidPartitions () {
+local DISK PART IMGNAME INFOFILE DEVICE DATA GUID UUID IMGGUID
+local EFIDEVICE EFIDATA EFIGUID EFIUUID EFIUUID IMGEFIGUID
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME REPO|CACHE str_imgname int_ndisk int_npart" \
+ "$FUNCNAME REPO Windows 1 2"
+ return
+fi
+# Error si no se reciben 4 parámetros.
+[ $# -eq 4 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME REPO|CACHE str_imgname int_ndisk int_npart" || return $?
+
+# Sólo se ejecuta si es UEFI
+ogIsEfiActive || return
+
+# Parámetros de entrada
+IMGNAME="$2"
+INFOFILE="$OGIMG/.$IMGNAME.img.json"
+[ "${1^^}" == "CACHE" ] && INFOFILE="$OGCAC$INFOFILE"
+# TODO: que la función getPath soporte archivos ocultos
+ls $INFOFILE &>/dev/null || ogRaiseError $OG_ERR_NOTFOUND "$INFOFILE" || return $?
+DISK=$3
+PART=$4
+
+DEVICE=$(ogDiskToDev $DISK)
+read -e EFIDISK EFIPART <<<"$(ogGetEsp)"
+
+# Datos de la imagen
+IMGGUID=$(jq .guid $INFOFILE|tr -d \")
+IMGEFIGUID=$(jq .espguid $INFOFILE|tr -d \")
+
+# Datos actuales
+DATA=$(sfdisk -J $DEVICE)
+GUID=$(echo $DATA|jq ".partitiontable|.id"|tr -d \")
+
+if [ "$IMGGUID" != "$GUID" ]; then
+ echo sgdisk -U "$IMGGUID" "$DEVICE"
+ sgdisk -U "$IMGGUID" "$DEVICE"
+ partprobe
+fi
+
+if [ $DISK -eq $EFIDISK ]; then
+ EFIDATA=$DATA
+ EFIDEVICE=$DEVICE
+else
+ EFIDEVICE=$(ogDiskToDev $EFIDISK) || return $?
+ EFIDATA=$(sfdisk -J $EFIDEVICE)
+ EFIGUID=$(echo $EFIDATA|jq ".partitiontable|.id"|tr -d \")
+ if [ "$IMGEFIGUID" != "$EFIGUID" ]; then
+echo sgdisk -U "$IMGEFIGUID" "$EFIDEVICE"
+ sgdisk -U "$IMGEFIGUID" "$EFIDEVICE"
+ partprobe
+ fi
+fi
+}
+
+
+#/**
+# ogNvramSetNext
+#@brief Configura el próximo arranque con la entrada del gestor de arranque (NVRAM) identificada por la etiqueta o el orden.
+#@param Num_order_entry | Label_entry Número de orden o la etiqueta de la entrada a borrar.
+#@return (nada)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#*/ ##
+function ogNvramSetNext () {
+local NUMENTRY
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME [ Num_order_entry | Label_entry ] " \
+ "$FUNCNAME 2" \
+ "$FUNCNAME \"Windows Boot Manager\""
+ return
+fi
+
+# Error si no se recibe 1 parámetro.
+[ $# -eq 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME [ Num_order_entry | Label_entry ]" || return $?
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+# Distingo si es número de orden o etiqueta
+if [[ $1 =~ ^([0-9a-fA-F]+)$ ]]; then
+ NUMENTRY=$( efibootmgr |awk -v NUM="$(printf %04x 0x$1|tr '[:lower:]' '[:upper:]')" '{ if($1~NUM) print substr($1,5,4)}')
+else
+ NUMENTRY=$(efibootmgr |awk -v LABEL="$1" '{ if(substr($0, index($0,$2))==LABEL) print substr($1,5,4)}')
+fi
+
+[ "$NUMENTRY" == "" ] && return $(ogRaiseError $OG_ERR_NOTFOUND "NVRAM entry '$1'")
+
+efibootmgr -n $NUMENTRY &>/dev/null
+}
+
+#/**
+# ogNvramSetOrder
+#@brief Configura el orden de las entradas de la NVRAM
+#@param Orden de las entradas separadas por espacios
+#@return (nada)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTUEFI UEFI no activa.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado (entrada NVRAM).
+#*/ ##
+function ogNvramSetOrder () {
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME Num_order1 [ Num_order2 ] ... " \
+ "$FUNCNAME 1 3"
+ return
+fi
+#
+# Error si no se recibe al menos 1 parámetro.
+[ $# -ge 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME Num_order1 [ Num_order2 ] ..." || return $?
+
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+# Comprobamos que sean números
+[[ "$@" =~ ^([0-9a-fA-F ]+)$ ]] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME Num_order1 [ Num_order2 ] ..." || return $?
+
+# Entradas de la NVRAM actuales
+NUMENTRYS=$(efibootmgr|awk '{ if ($1~/Boot[0-9a-fA-F]{4}/) printf "0%s ", substr($1,5,4)}')
+
+ORDER=""
+for ARG in $@; do
+ # Si no existe la entrada me salgo
+ ARG=$(printf %04X 0x$ARG)
+ echo $NUMENTRYS | grep "$ARG" &>/dev/null || ogRaiseError $OG_ERR_NOTFOUND "NVRAM entry order \"$ARG\"" || return $?
+ ORDER=${ORDER},$ARG
+done
+
+# Cambiamos el orden
+efibootmgr -o ${ORDER#,} &>/dev/null
+}
+
+
+#/**
+# ogNvramSetTimeout
+#@brief Configura el tiempo de espera de la NVRAM
+#@param Orden de las entradas separadas por espacios
+#@return (nada)
+
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#*/ ##
+function ogNvramSetTimeout () {
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_Timeout (seg)" \
+ "$FUNCNAME 2"
+ return
+fi
+#
+# Si no es equipo UEFI salir con error
+ogIsEfiActive || ogRaiseError $OG_ERR_NOTUEFI || return $?
+
+# Error si no se recibe 1 parámetro.
+[ $# -eq 1 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_Timeout (seg)" || return $?
+
+# Comprobamos que sea un número
+[[ "$1" =~ ^([0-9 ]+)*$ ]] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_Timeout (seg)" || return $?
+
+# Cambiamos el orden
+efibootmgr -t $1 &>/dev/null
+}
+
+
+#/**
+# ogUuidChange int_ndisk str_repo
+#@brief Reemplaza el UUID de un sistema de ficheros.
+#@param int_ndisk nº de orden del disco
+#@param int_part nº de partición
+#@return (nada, por determinar)
+#@exception OG_ERR_FORMAT formato incorrecto.
+#@exception OG_ERR_NOTFOUND fichero o dispositivo no encontrado.
+#*/ ##
+function ogUuidChange () {
+local MNTDIR DEVICE UUID NEWUUID f
+
+# Si se solicita, mostrar ayuda.
+if [ "$*" == "help" ]; then
+ ogHelp "$FUNCNAME" "$FUNCNAME int_ndisk int_part" \
+ "$FUNCNAME 1 2"
+ return
+fi
+
+# Error si no se reciben al menos 2 parámetros.
+[ $# -eq 2 ] || ogRaiseError $OG_ERR_FORMAT "$FUNCNAME int_ndisk int_part" || return $?
+
+# Comprobamos que exista la partición
+MNTDIR=$(ogMount $1 $2) || ogRaiseError $OG_ERR_NOTFOUND "Device $1 $2" || return $?
+DEVICE=$(ogDiskToDev $1 $2)
+UUID=$(blkid -o value -s UUID $DEVICE)
+NEWUUID=$(cat /proc/sys/kernel/random/uuid)
+
+# Cambiamos UUID a la partición
+ogUnmount $1 $2
+tune2fs $DEVICE -U $NEWUUID
+
+# Cambiamos UUID en la configuración (fstab y grub)
+ogMount $1 $2
+for f in $MNTDIR/etc/fstab $MNTDIR/{,boot/}{{grubMBR,grubPARTITION}/boot/,}{grub{,2},{,efi/}EFI/*}/{menu.lst,grub.cfg}; do
+ [ -r $f ] && sed -i s/$UUID/$NEWUUID/g $f
+done
+}
diff --git a/client/shared/bin/browser b/client/shared/bin/browser
index 4370974f..54663a5a 100755
--- a/client/shared/bin/browser
+++ b/client/shared/bin/browser
Binary files differ
diff --git a/client/shared/bin/ld-mac b/client/shared/bin/ld-mac
deleted file mode 100755
index 0152c7d5..00000000
--- a/client/shared/bin/ld-mac
+++ /dev/null
Binary files differ
diff --git a/client/shared/etc/lang.ca_ES.conf b/client/shared/etc/lang.ca_ES.conf
index ed20f3af..92e97598 100644
--- a/client/shared/etc/lang.ca_ES.conf
+++ b/client/shared/etc/lang.ca_ES.conf
@@ -16,6 +16,7 @@ MSG_ERR_IMAGE="No se puede crear o restaurar una image de sistema"
MSG_ERR_NOTEXEC="Programa o función no ejecutable"
MSG_ERR_NOTWRITE="No hay acceso de escritura"
MSG_ERR_NOTCACHE="No existe particion Cache en el cliente"
+MSG_ERR_NOTUEFI="La interfaz UEFI no está activa"
MSG_ERR_CACHESIZE="El espacio de la cache local o remota no es suficiente"
MSG_ERR_REDUCEFS="Error al reducir el sistema de archivos"
MSG_ERR_EXTENDFS="Error al expandir el sistema de archivos"
@@ -131,6 +132,7 @@ MSG_HELP_ogCreateMbrImage="Genera una imagen del sector de arranque (MBR)."
MSG_HELP_ogCreatePartitions="Define la estructura de particiones de un disco."
MSG_HELP_ogCreatePartitionTable="Genera una tabla de particiones en caso de que no sea valida."
MSG_HELP_ogCreateTorrent=""
+MSG_HELP_ogCopyEfiBootLoader="Copia el cargador de arranque desde la partición EFI a la de sistema."
MSG_HELP_ogDeleteCache="Elimina la partición de caché local."
MSG_HELP_ogDeleteFile="Borra un fichero de un espacio de almacenamiento."
MSG_HELP_ogDeletePartitionTable="Elimina la tabla de particiones del disco"
@@ -196,9 +198,23 @@ MSG_HELP_ogGrubHidePartitions="Configura el grub del MBR para que oculte las par
MSG_HELP_ogGrubInstallMbr="Instal·la el carregador d'arrencada GRUB al MBR del primer disc dur"
MSG_HELP_ogGrubInstallPartition="Instal·la el carregador d'arrencada BURG al BootSector"
MSG_HELP_ogGrubOgliveDefaultEntry="Configura la entrada de ogLive como la entrada por defecto de GRUB."
+MSG_HELP_ogGrubUefiConf="Genera el fichero grub.cfg de la partición EFI."
MSG_HELP_ogHelp="Muestra mensajes de ayudas para las funciones."
MSG_HELP_ogHidePartition="Oculta una partición de Windows."
MSG_HELP_ogIdToType="Devuelve el mnemónico asociado al identificador de tipo de partición."
+MSG_HELP_ogNvramActiveEntry="Configura a activa entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramAddEntry="Crea nueva entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramDeleteEntry="Borra entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramGetCurrent="Muestra la entrada del gestor de arranque (NVRAM) que ha iniciado el equipo."
+MSG_HELP_ogNvramGetNext="Muestra la entrada del gestor de arranque (NVRAM) que se utilizará en el próximo arranque."
+MSG_HELP_ogNvramGetOrder="Muestra el orden de las entradas del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramGetTimeout="Muestra el tiempo de espera del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramInactiveEntry="Configura a inactiva entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramList="Lista las entradas del gestor de arranque (NVRAN) marcando con un asterisco las activas"
+MSG_HELP_ogNvramSetNext="Configura el próximo arranque con la entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramSetOrder="Configura el orden de las entradas del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramSetTimeout="Configura el tiempo de espera del gestor de arranque (NVRAM)."
+MSG_HELP_ogGetOsType="Devuelve el tipo de un sistema operativo instalado."
MSG_HELP_ogInstallFirstBoot="Crea un archivo que se ejecutará en el primer arranque de Windows."
MSG_HELP_ogInstallLaunchDaemon="Instala un archivo que se ejecutará en el arranque de macOS."
MSG_HELP_ogInstallLinuxClient="$MSG_OBSOLETE."
@@ -245,12 +261,22 @@ 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."
+MSG_HELP_ogRestoreEfiBootLoader="Copia el cargador de arranque de la partición de sistema a la partición EFI."
MSG_HELP_ogRestoreImage="Restaura una imagen de sistema operativo."
MSG_HELP_ogRestoreInfoImage="Restablece informacion del sistema: acl y enlaces simbolicos"
MSG_HELP_ogRestoreMbrImage="Restaura una imagen del sector de arranque (MBR)."
+MSG_HELP_ogRestoreUuidPartitions="Restaura los uuid de las particiones y la tabla de particiones."
+MSG_HELP_ogSaveImageInfo="Crea un fichero con la información de la imagen."
MSG_HELP_ogSetLinuxName=""
MSG_HELP_ogSetPartitionActive="Establece el número de partición activa de un disco."
MSG_HELP_ogSetPartitionId="Modifica el tipo de una partición física usando el mnemónico del tipo."
@@ -282,6 +308,7 @@ MSG_HELP_ogUnmountImage="Desmonta la imagen"
MSG_HELP_ogUnsetDirtyBit=""
MSG_HELP_ogUpdateCacheIsNecesary="Comprueba si es necesario actualizar una archivo en la cache local."
MSG_HELP_ogUpdatePartitionTable="Actualiza informacion tabla particiones del disco"
+MSG_HELP_ogUuidChange="Reemplaza el UUID de un sistema de ficheros."
MSG_HELP_ogWaitSyncImage=""
MSG_HELP_ogWindowsBootParameters=""
MSG_HELP_ogWindowsRegisterPartition=""
diff --git a/client/shared/etc/lang.en_GB.conf b/client/shared/etc/lang.en_GB.conf
index 13365baf..b21a270f 100644
--- a/client/shared/etc/lang.en_GB.conf
+++ b/client/shared/etc/lang.en_GB.conf
@@ -19,6 +19,7 @@ MSG_ERR_IMAGE="Cannot create or restore a system image"
MSG_ERR_NOTEXEC="Non executable program or function"
MSG_ERR_NOTWRITE="Write access denied"
MSG_ERR_NOTCACHE="No client cache partition"
+MSG_ERR_NOTUEFI="UEFI isn't active"
MSG_ERR_CACHESIZE="Not enough space in local or remote cache"
MSG_ERR_REDUCEFS="Error when reducing file system"
MSG_ERR_EXTENDFS="Error when expanding file system"
@@ -134,6 +135,7 @@ MSG_HELP_ogCreateMbrImage="Creates MBR image."
MSG_HELP_ogCreatePartitions="Creates disk partition table."
MSG_HELP_ogCreatePartitionTable="Creates partition table, if necessary."
MSG_HELP_ogCreateTorrent=""
+MSG_HELP_ogCopyEfiBootLoader="Copy the boot loader from the EFI partition to system partition."
MSG_HELP_ogDeleteCache="Deletes local cache partition."
MSG_HELP_ogDeleteFile="Deletes file from storage."
MSG_HELP_ogDeletePartitionTable="Deletes disk table partition"
@@ -199,6 +201,7 @@ MSG_HELP_ogGrubHidePartitions="Sets MBR grub to hide non starting Windows partit
MSG_HELP_ogGrubInstallMbr="Installs GRUB boot loader on 1st HD MBR"
MSG_HELP_ogGrubInstallPartition="Installs GRUB boot loader on BootSector"
MSG_HELP_ogGrubOgliveDefaultEntry="Sets ogLive entry as default GRUB entry."
+MSG_HELP_ogGrubUefiConf="Generates the grub.cfg file of the EFI partition."
MSG_HELP_ogHelp="Shows functions help messages."
MSG_HELP_ogHidePartition="Hides Windows partition."
MSG_HELP_ogIdToType="Returns partition type identifier."
@@ -245,15 +248,37 @@ MSG_HELP_ogMountCdrom="Mounts default optical drive."
MSG_HELP_ogMountFs=$MSG_HELP_ogMount
MSG_HELP_ogMountImage="Mounts synchronizable image"
MSG_HELP_ogMount="Mounts file system and returns mount point."
+MSG_HELP_ogNvramActiveEntry="Sets active a bootloader (NVRAM) entry."
+MSG_HELP_ogNvramAddEntry="Creates new entry in bootloader (NVRAM)."
+MSG_HELP_ogNvramDeleteEntry="Deletes a bootloader (NVRAM) entry."
+MSG_HELP_ogNvramGetCurrent="Displays the bootloader (NVRAM) entry that was started by the computer."
+MSG_HELP_ogNvramGetNext="Displays the bootloader (NVRAM) entry for the boot next."
+MSG_HELP_ogNvramGetOrder="Displays the bootloader (NVRAM) entries order."
+MSG_HELP_ogNvramGetTimeout="Displays the bootloader (NVRAM) timeout."
+MSG_HELP_ogNvramInactiveEntry="Sets inactive bootloader (NVRAM) entry."
+MSG_HELP_ogNvramList="Lists bootloader (NVRAM) entries, by staring actives ones."
+MSG_HELP_ogNvramSetNext="Set the bootloader (NVRAM) entry for the boot next."
+MSG_HELP_ogNvramSetOrder="Sets the bootloader (NVRAM) entries order."
+MSG_HELP_ogNvramSetTimeout="Sets the bootloader (NVRAM) timeout."
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."
+MSG_HELP_ogRestoreEfiBootLoader="Copy the boot loader from the system partition to the EFI partition."
MSG_HELP_ogRestoreImage="Restore OS image."
MSG_HELP_ogRestoreInfoImage="Restores system information: ACL and symbolic links"
MSG_HELP_ogRestoreMbrImage="Restores boot sector image (MBR)."
+MSG_HELP_ogRestoreUuidPartitions="Restores UUID of partitions and partition table."
+MSG_HELP_ogSaveImageInfo="Creates the image information file."
MSG_HELP_ogSetLinuxName=""
MSG_HELP_ogSetPartitionActive="Sets active partition number of disk."
MSG_HELP_ogSetPartitionId="Changes partition ID using mnemonic."
@@ -285,6 +310,7 @@ MSG_HELP_ogUnmount="Unmounts file system."
MSG_HELP_ogUnsetDirtyBit=
MSG_HELP_ogUpdateCacheIsNecesary="Checks if necessary file update in local cache."
MSG_HELP_ogUpdatePartitionTable="Updates disk partition table info "
+MSG_HELP_ogUuidChange="Replaces the filesystem UUID"
MSG_HELP_ogWaitSyncImage=""
MSG_HELP_ogWindowsBootParameters=""
MSG_HELP_ogWindowsRegisterPartition=""
diff --git a/client/shared/etc/lang.es_ES.conf b/client/shared/etc/lang.es_ES.conf
index 782cb624..27d0cd64 100644
--- a/client/shared/etc/lang.es_ES.conf
+++ b/client/shared/etc/lang.es_ES.conf
@@ -16,6 +16,7 @@ MSG_ERR_IMAGE="No se puede crear o restaurar una image de sistema"
MSG_ERR_NOTEXEC="Programa o función no ejecutable"
MSG_ERR_NOTWRITE="No hay acceso de escritura"
MSG_ERR_NOTCACHE="No existe partición caché en el cliente"
+MSG_ERR_NOTUEFI="La interfaz UEFI no está activa"
MSG_ERR_CACHESIZE="El espacio de la caché local o remota no es suficiente"
MSG_ERR_REDUCEFS="Error al reducir el sistema de archivos"
MSG_ERR_EXTENDFS="Error al expandir el sistema de archivos"
@@ -131,6 +132,7 @@ MSG_HELP_ogCreateMbrImage="Genera una imagen del sector de arranque (MBR)."
MSG_HELP_ogCreatePartitions="Define la estructura de particiones de un disco."
MSG_HELP_ogCreatePartitionTable="Genera una tabla de particiones en caso de que no sea valida."
MSG_HELP_ogCreateTorrent=""
+MSG_HELP_ogCopyEfiBootLoader="Copia el cargador de arranque desde la partición EFI a la de sistema."
MSG_HELP_ogDeleteCache="Elimina la partición de caché local."
MSG_HELP_ogDeleteFile="Borra un fichero de un espacio de almacenamiento."
MSG_HELP_ogDeletePartitionTable="Elimina la tabla de particiones del disco"
@@ -172,6 +174,18 @@ MSG_HELP_ogGetMacAddress="Devuelve la dirección Ethernet del cliente."
MSG_HELP_ogGetMountImageDir="Devuelve el directorio de montaje de una imagen."
MSG_HELP_ogGetMountPoint="Devuelve el directorio donde está montado un sistema de archivos local."
MSG_HELP_ogGetNetInterface=""
+MSG_HELP_ogNvramActiveEntry="Configura a activa entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramAddEntry="Crea nueva entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramDeleteEntry="Borra entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramGetCurrent="Muestra la entrada del gestor de arranque (NVRAM) que ha iniciado el equipo."
+MSG_HELP_ogNvramGetNext="Muestra la entrada del gestor de arranque (NVRAM) que se utilizará en el próximo arranque."
+MSG_HELP_ogNvramGetOrder="Muestra el orden de las entradas del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramGetTimeout="Muestra el tiempo de espera del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramInactiveEntry="Configura a inactiva entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramList="Lista las entradas del gestor de arranque (NVRAN) marcando con un asterisco las activas"
+MSG_HELP_ogNvramSetNext="Configura el próximo arranque con la entrada del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramSetOrder="Configura el orden de las entradas del gestor de arranque (NVRAM)."
+MSG_HELP_ogNvramSetTimeout="Configura el tiempo de espera del gestor de arranque (NVRAM)."
MSG_HELP_ogGetOsType="Devuelve el tipo de un sistema operativo instalado."
MSG_HELP_ogGetOsUuid="Devuelve el UUID de un sistema operativo"
MSG_HELP_ogGetOsVersion="Devuelve el tipo y la versión de un sistema operativo instalado."
@@ -196,6 +210,7 @@ MSG_HELP_ogGrubHidePartitions="Configura el grub del MBR para que oculte las par
MSG_HELP_ogGrubInstallMbr="Instala el gestor de arranque GRUB en el MBR del primer disco duro"
MSG_HELP_ogGrubInstallPartition="Instala el gestor de arranque GRUB en el BootSector"
MSG_HELP_ogGrubOgliveDefaultEntry="Configura la entrada de ogLive como la entrada por defecto de GRUB."
+MSG_HELP_ogGrubUefiConf="Genera el fichero grub.cfg de la partición EFI."
MSG_HELP_ogHelp="Muestra mensajes de ayudas para las funciones."
MSG_HELP_ogHidePartition="Oculta una partición de Windows."
MSG_HELP_ogIdToType="Devuelve el mnemónico asociado al identificador de tipo de partición."
@@ -245,12 +260,22 @@ 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."
+MSG_HELP_ogRestoreEfiBootLoader="Copia el cargador de arranque de la partición de sistema a la partición EFI."
MSG_HELP_ogRestoreImage="Restaura una imagen de sistema operativo."
MSG_HELP_ogRestoreInfoImage="Restablece información del sistema: ACL y enlaces simbolicos"
MSG_HELP_ogRestoreMbrImage="Restaura una imagen del sector de arranque (MBR)."
+MSG_HELP_ogRestoreUuidPartitions="Restaura los uuid de las particiones y la tabla de particiones."
+MSG_HELP_ogSaveImageInfo="Crea un fichero con la información de la imagen."
MSG_HELP_ogSetLinuxName=""
MSG_HELP_ogSetPartitionActive="Establece el número de partición activa de un disco."
MSG_HELP_ogSetPartitionId="Modifica el tipo de una partición física usando el mnemónico del tipo."
@@ -282,6 +307,7 @@ MSG_HELP_ogUnmountImage="Desmonta la imagen."
MSG_HELP_ogUnsetDirtyBit=""
MSG_HELP_ogUpdateCacheIsNecesary="Comprueba si es necesario actualizar una archivo en la cache local."
MSG_HELP_ogUpdatePartitionTable="Actualiza información de la tabla de particiones del disco."
+MSG_HELP_ogUuidChange="Reemplaza el UUID de un sistema de ficheros."
MSG_HELP_ogWaitSyncImage=""
MSG_HELP_ogWindowsBootParameters=""
MSG_HELP_ogWindowsRegisterPartition=""
diff --git a/client/shared/etc/preinit/fileslinks.sh b/client/shared/etc/preinit/fileslinks.sh
index b6fc7e2f..826282da 100755
--- a/client/shared/etc/preinit/fileslinks.sh
+++ b/client/shared/etc/preinit/fileslinks.sh
@@ -6,9 +6,12 @@
#@version 0.9
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2009-10-10
-#@version 1.0.5 - Enlace para librería libmac.
+#@version 1.0.5 - Enlace para librería libmac (obsoleto en versión 1.1.1).
#@author Ramon Gomez, ETSII Universidad de Sevilla
#@date 2012-06-28
+#@version 1.1.2 - Autenticación con clave pública para SSH
+#@author Irina Gómez, ETSII Universidad de Sevilla
+#@date 2019-09-25
#*/
@@ -19,9 +22,6 @@ if [ -n "$OPENGNSYS" ]; then
# Shell BASH por defecto (para usar "runtest")
ln -fs /bin/bash /bin/sh 2>/dev/null
- # Enlace a la librería libmac para ld-mac.
- [ -f /usr/lib/libmac.so ] || ln -fs $OGLIB/libmac.so /usr/lib 2>/dev/null
-
# Crear directorio de bloqueos
mkdir -p /var/lock 2>/dev/null || mkdir -p /run/lock
@@ -32,7 +32,7 @@ if [ -n "$OPENGNSYS" ]; then
# Enlaces para Qt Embeded.
QTDIR="/usr/local"
mkdir -p $QTDIR/{etc,lib,plugins}
- for i in $OGLIB/qtlib/*; do
+ for i in $OGLIB/qtlib/* $OGLIB/fonts; do
[ -f $QTDIR/lib/$i ] || ln -fs $i $QTDIR/lib 2>/dev/null
done
for i in $OGLIB/qtplugins/*; do
@@ -42,6 +42,9 @@ if [ -n "$OPENGNSYS" ]; then
[ -f $QTDIR/etc/$i ] || ln -fs $i $QTDIR/etc 2>/dev/null
done
+ # Autenticación con clave pública para SSH
+ [ -f /scripts/ssl/authorized_keys ] && cp /scripts/ssl/* /root/.ssh
+
else
# FIXME Error: entorno de OpenGnsys no configurado.
echo "Error: OpenGnsys environment is not configured." # FIXME: definir mensaje.
diff --git a/client/shared/etc/preinit/loadenviron.sh b/client/shared/etc/preinit/loadenviron.sh
index 314fb872..c80043cf 100755
--- a/client/shared/etc/preinit/loadenviron.sh
+++ b/client/shared/etc/preinit/loadenviron.sh
@@ -141,3 +141,4 @@ export OG_ERR_DONTUNMOUNT_IMAGE=72 # Error al desmontar la imagen
export OG_ERR_NOTDIFFERENT=73 # No se detectan diferencias entre la imagen basica y la particion.
export OG_ERR_SYNCHRONIZING=74 # Error al sincronizar, puede afectar la creacion/restauracion de la imagen
+export OG_ERR_NOTUEFI=80 # La interfaz UEFI no está activa
diff --git a/client/shared/lib/grub4dos/chinese/badgrub.exe b/client/shared/lib/grub4dos/chinese/badgrub.exe
deleted file mode 100644
index 09daafee..00000000
--- a/client/shared/lib/grub4dos/chinese/badgrub.exe
+++ /dev/null
Binary files differ
diff --git a/client/shared/lib/grub4dos/chinese/grldr b/client/shared/lib/grub4dos/chinese/grldr
deleted file mode 100644
index f84d8475..00000000
--- a/client/shared/lib/grub4dos/chinese/grldr
+++ /dev/null
Binary files differ
diff --git a/client/shared/lib/grub4dos/chinese/grub.exe b/client/shared/lib/grub4dos/chinese/grub.exe
deleted file mode 100644
index f64b60b0..00000000
--- a/client/shared/lib/grub4dos/chinese/grub.exe
+++ /dev/null
Binary files differ
diff --git a/client/shared/lib/locale/ca/LC_MESSAGES/browser.mo b/client/shared/lib/locale/ca/LC_MESSAGES/browser.mo
index eda51ffb..61047594 100644
--- a/client/shared/lib/locale/ca/LC_MESSAGES/browser.mo
+++ b/client/shared/lib/locale/ca/LC_MESSAGES/browser.mo
Binary files differ
diff --git a/client/shared/lib/locale/en/LC_MESSAGES/browser.mo b/client/shared/lib/locale/en/LC_MESSAGES/browser.mo
index 9ac0ebbe..d6326d7a 100644
--- a/client/shared/lib/locale/en/LC_MESSAGES/browser.mo
+++ b/client/shared/lib/locale/en/LC_MESSAGES/browser.mo
Binary files differ
diff --git a/client/shared/lib/ogclient/ogAdmLnxClient b/client/shared/lib/ogclient/ogAdmLnxClient
deleted file mode 100755
index df8aa2cc..00000000
--- a/client/shared/lib/ogclient/ogAdmLnxClient
+++ /dev/null
Binary files differ
diff --git a/client/shared/lib/ogclient/ogAdmWinClient.exe b/client/shared/lib/ogclient/ogAdmWinClient.exe
deleted file mode 100644
index 56f1899d..00000000
--- a/client/shared/lib/ogclient/ogAdmWinClient.exe
+++ /dev/null
Binary files differ
diff --git a/client/shared/lib/os-probes/mounted/efi/31part-x-y b/client/shared/lib/os-probes/mounted/efi/31part-x-y
new file mode 100755
index 00000000..349c36d8
--- /dev/null
+++ b/client/shared/lib/os-probes/mounted/efi/31part-x-y
@@ -0,0 +1,28 @@
+#!/bin/sh
+# OG: Detects Microsoft bootloader on a EFI System Partition in directory Part-xx-yy (#802 #888)
+
+. /usr/share/os-prober/common.sh
+
+efi="$1"
+
+found=
+for microsoft in $(item_in_dir Part-..-.. "$efi"); do
+ for boot in $(item_in_dir boot "$efi/$microsoft"); do
+ bcd=$(item_in_dir bcd "$efi/$microsoft/$boot")
+ bootmgfw=$(item_in_dir bootmgfw.efi "$efi/$microsoft/$boot")
+ if [ -n "$bcd" -a -n "$bootmgfw" ]; then
+ long="Windows Boot Manager"
+ short=Windows
+ path="$microsoft/$boot/$bootmgfw"
+ found=true
+ break
+ fi
+ done
+done
+
+
+if [ -n "$found" ]; then
+ label="$(count_next_label "$short")"
+ result "${path}:${long}:${label}"
+fi
+exit 0
diff --git a/client/shared/scripts/bootOsCustom.template b/client/shared/scripts/bootOsCustom.template
index b457fde4..efd4c1fc 100755
--- a/client/shared/scripts/bootOsCustom.template
+++ b/client/shared/scripts/bootOsCustom.template
@@ -6,8 +6,11 @@
#@param $2 nº de partición
#@warning Renombrar este fichero como "bootOsCustom" para personalizar el script estándar "bootOs".
#@note La partición a inicializar debe estar montada
+#@version 1.1.1 Soporta varios discos
+#@date 2019/08/26
#**/
-# CONFIGURAR: Partición de datos de Windows que no queremos ocultar
+# CONFIGURAR: Partición de datos de Windows que no queremos ocultar (valor por defecto '0' no oculta nada)
+DISKDATA=0
PARTDATA=0
PROG="$(basename $0)"
@@ -22,51 +25,57 @@ DISK="$1" # Nº de disco.
PART="$2" # Nº de partición.
# Paso 0: Añadir código para realizar control de errores de los parámetros de entrada (recomendado).
+DEVICE=$(ogDiskToDev "$DISK" "$PART") || exit $?
-# Paso 1: Adaptar el código de ejemplo para postconfiguración personalizada.
+# Paso 1: Adaptar el código de ejemplo para arranque personalizado.
# Nota: el script "bootOs" llama al script "bootOsCustom" después de realizar la operaciones de inicio estándar y antes de desmontar las particiones e iniciar el sistema operativo.
-MNTDIR=$(ogMount $DISK $PART)
+MNTDIR=$(ogMount $DISK $PART) || exit $?
NAME="$(ogGetHostname)"
NAME=${NAME:-"pc"}
OSTYPE=$(ogGetOsType $DISK $PART)
case "$OSTYPE" in
Windows)
- ## Borrar marcas de arrranque de todos los Windows instalados en el disco.
- #echo "[30] Borrar marcas de arrranque de todos los Windows instalados en el disco."
- #for (( i=1; i<=$(ogGetPartitionsNumber $1); i++ )); do
- # [ "$(ogGetOsType $1 $i)" == "Windows" ] && ogMount $1 $i &>/dev/null
- #done
- #rm -f /mnt/*/ogboot.*
-
## Mostrar las particiones NTFS de sistema (dos opciones)
## Opción 1: SIN ocultar las demás.
- #echo "[40] Mostrar y activar particion de Windows $PART."
- #[ $(ogGetPartitionType $1 $2) == "HNTFS" ] && ogUnhidePartition $1 $2
+ #ogEcho log session "[40] Mostrar y activar particion de Windows $PART."
+ #[ $(ogGetPartitionType $DISK $PART) == "HNTFS" -o $(ogGetPartitionType $DISK $PART) == "WIN-RESERV" ] && ogUnhidePartition $DISK $PART
+
+ ## Recorremos los distintos discos
+ #for DEVICE in $(ogDiskToDev); do
+ # d=$(ogDevToDisk $DEVICE)
- ## Opción 2: Ocultamos las demás.
- #echo "[40] Activar particion de Windows $PART y ocultar las demás."
- #for (( i=1; i<=$(ogGetPartitionsNumber $DISK); i++ )); do
- # if [ $i == $PART -o $i == $PARTDATA ]; then
- # [ $(ogGetPartitionType $DISK $PART) == "HNTFS" ] && ogUnhidePartition $1 $PART
- # # Activo la particion si no es de datos
- # [ $i -ne $PARTDATA ] && ogSetPartitionActive $DISK $i
+ # ## Mostrar las particiones NTFS de sistema (dos opciones)
+ # ## Opción 2: Ocultamos las demás.
+ # ogEcho log session "[40] Activar particion de Windows $PART y ocultar las demás."
+ # for (( i=1; i<=$(ogGetPartitionsNumber $d); i++ )); do
+ # if [ $d == $DISK -a $i == $PART ] || [ $d == $DISKDATA -a $i == $PARTDATA ]; then
+ # [ $(ogGetPartitionType $d $i) == "HNTFS" -o $(ogGetPartitionType $d $i) == "WIN-RESERV" ] && ogUnhidePartition $d $i
# else
- # [ "$(ogGetPartitionType $DISK $i)" == NTFS ] && ogHidePartition $DISK $i
+ # [ "$(ogGetPartitionType $d $i)" == NTFS -o "$(ogGetPartitionType $d $i)" == "WINDOWS" ] && ogHidePartition $d $i
# fi
+ # done
+
+ # ## Borrar marcas de arrranque de todos los Windows instalados en el disco.
+ # ogEcho log session "[30] Borrar marcas de arrranque de todos los Windows instalados en el disco."
+ # for (( i=1; i<=$(ogGetPartitionsNumber $d); i++ )); do
+ # [ "$(ogGetOsType $d $i)" == "Windows" ] && ogMount $d $i &>/dev/null
+ # done
+ # rm -f /mnt/*/ogboot.*
+
#done
;;
Linux)
## Modificar el nombre del equipo
- #echo "[30] Asignar nombre Linux \"$NAME\"."
- #ETC=$(ogGetPath $1 $2 /etc)
+ #ogEcho log session "[30] Asignar nombre Linux \"$NAME\"."
+ #ETC=$(ogGetPath $DISK $PART /etc)
#[ -d "$ETC" ] && echo "$NAME" >$ETC/hostname 2>/dev/null
## Sustituir UUID o LABEL por su dispositivo en definición de sistema de archivo raíz.
#if [ -f "$ETC/fstab" ]; then
- # echo "[40] Actualizar fstab con particion raiz \"$PART\"."
+ # ogEcho log session "[40] Actualizar fstab con particion raíz \"$PART\"."
# awk -v P="$PART " '{ if ($2=="/" && $1!~/^#/) {sub(/^.*$/, P, $1)}
# print }' $ETC/fstab >/tmp/fstab
# mv /tmp/fstab $ETC/fstab
@@ -76,7 +85,7 @@ case "$OSTYPE" in
## En el servidor el nuevo fichero debe situarse en el directorio del grupo:
## /opt/opengnsys/images/groups/nombre_aula
#if [ -r $(ogGetGroupDir)/passwd ]; then
- # echo "[65] Cambiar claves de usuarios."
+ # ogEcho log session "[65] Cambiar claves de usuarios."
# cp $(ogGetGroupDir)/passwd $MNTDIR/etc
#fi
;;
diff --git a/client/shared/scripts/cloneRemoteFromMaster b/client/shared/scripts/cloneRemoteFromMaster
index b78bd629..6d8001d2 100755
--- a/client/shared/scripts/cloneRemoteFromMaster
+++ b/client/shared/scripts/cloneRemoteFromMaster
@@ -159,6 +159,13 @@ case $MASTERIP in
#Obtener tamaño de la partición.
SIZE=$(ogGetPartitionSize $2 $3) || exit $(ogRaiseError $OG_ERR_REDUCEFS "Error al detectar tamaño partcion $2 $3 l127"; echo $?)
+ # Si es UEFI copio el cargador de arranque a la partición
+ OSTYPE="$(ogGetOsType $2 $3)"
+ if ogIsEfiActive && [ "$OSTYPE" == "Windows" ]; then
+ ogEcho log session "[12] $MSG_HELP_ogCopyEfiBootLoader"
+ ogCopyEfiBootLoader $2 $3
+ fi
+
if [ "$OGWINREDUCE" == "TRUE" ]
then
ogEcho log session "[15]: Calculando la reduccion del sistema de archivos DISK:$DISKSOURCE PARTITION:$PARTSOURCE SIZE:$SIZE"
diff --git a/client/shared/scripts/configureOs b/client/shared/scripts/configureOs
index 4b7ec6f7..2e529c9e 100755
--- a/client/shared/scripts/configureOs
+++ b/client/shared/scripts/configureOs
@@ -32,6 +32,9 @@
#@version 1.0.6b - llamadas opcionales para mejoras varias. Descomentar la instruccion para su activacion. ogConfigureFstab
#@author Antonio J. Doblas Viso. Universidad de Malaga.
#@date 2016-11-03
+#@version 1.1.1 - Equipos UEFI: para Windows copia cargador de arranque a partición UEFI, para linux configura particion ESP en fstab. (ticket #802 #889 #890)
+#@author Irina Gomez, ETSII Universidad de Sevilla
+#@date 2019-01-08
#*/ ##
# Carga el configurador del engine y los parámetros de red.
@@ -67,8 +70,14 @@ case "$OSTYPE" in
# Cambiar nombre en sistemas Windows.
HOST=${HOST:-"pc"}
ogSetWindowsName $1 $2 "$HOST"
- # Configurar el boot sector de la partición Windows.
- ogFixBootSector $1 $2
+ # Si es UEFI copio el cargador de arranque a la partición EFI e instalo rEFInd.
+ if ogIsEfiActive; then
+ ogRestoreEfiBootLoader $1 $2
+ ogRefindInstall
+ else
+ # Configurar el boot sector de la partición Windows.
+ ogFixBootSector $1 $2
+ fi
# Configurar el gestor de arranque de Windows XP/Vista/7.
ogWindowsBootParameters $1 $2
# Registrar en Windows que la partición indicada es su nueva unidad C:\
@@ -82,12 +91,20 @@ case "$OSTYPE" in
fi
;;
Linux) # Postconfiguración de GNU/Linux.
+ # Configuro fstab: particion de Swap y si es UEFI además la partición EFI.
+ ogConfigureFstab $1 $2
## Instala (no configura) el codigo de arranque del Grub en la partición (no lo configura, se mantiene el original de la imagen)
ogGrubInstallPartition $1 $2
+ # Si es UEFI instalo rEFInd.
+ ogIsEfiActive && ogRefindInstall
# Eliminar el antiguo cliente de Linux.
[ -n "$(find $MNTDIR/usr/sbin $MNTDIR/sbin $MNTDIR/usr/local/sbin -name ogAdmLnxClient -print)" ] && ogUninstallLinuxClient $1 $2
# Configurar nuevo agente OGAgent.
ogConfigureOgagent $1 $2
+ ## Modificar el nombre del equipo
+ echo "Asignar nombre Linux \"$HOST\"."
+ ETC=$(ogGetPath $1 $2 /etc)
+ [ -d "$ETC" ] && echo "$HOST" >$ETC/hostname 2>/dev/null
;;
MacOS) # Postconfiguración de Mac OS X.
# Fichero indicador de activación de postconfiguración.
diff --git a/client/shared/scripts/configureOsCustom.template b/client/shared/scripts/configureOsCustom.template
index 66be3c63..f1c8e2a6 100644
--- a/client/shared/scripts/configureOsCustom.template
+++ b/client/shared/scripts/configureOsCustom.template
@@ -39,8 +39,8 @@ case "$OSTYPE" in
#ogLoadHiveWindows $1 $2; ogSetWindowsChkdisk $OGWINCHKDISK; ogUpdateHiveWindows
;;
Linux) # Postconfiguración de GNU/Linux.
- ##OPCIONAL: Configurar el FSTAB. En esta versión solo autoconfigura la partición SWAP
- #ogConfigureFstab $1 $2
+ ##OPCIONAL Para UEFI: cambia el UUID de la partición (para tener dos linux en un equipo)
+ #ogUuidChange $DISK $PART
##OPCIONAL Limpiar dispositivos reconocidos previamente
#ogCleanLinuxDevices $1 $2
## Instala (no configura) el codigo de arranque del Grub en la partición (no lo configura, se mantiene el original de la imagen)
diff --git a/client/shared/scripts/createImage b/client/shared/scripts/createImage
index 65da156b..be1cb439 100755
--- a/client/shared/scripts/createImage
+++ b/client/shared/scripts/createImage
@@ -35,6 +35,9 @@
#@version 1.1.0 - Se muestra el espacio necesario para alojar la imagen y el disponible (ticket #771)
#@author Irina Gomez - ETSII Universidad de Sevilla
#@date 2017-03-28
+#@version 1.1.1 - #802 Equipos EFI: se guarda el cargador de arranque y UUID de las particiones
+#@author Irina Gomez - ETSII Universidad de Sevilla
+#@date 2019-01-08
#*/ ##
# Test 1. crear una imagen en un REPO sin espacio libre.
@@ -123,10 +126,17 @@ ogEcho log session "[20] $MSG_HELP_ogCheckFs $PART $SIZEFS (KB)"
ogUnmount $1 $2 2>/dev/null
ogCheckFs $1 $2 || exit $(ogRaiseError $OG_ERR_PARTITION "ogCheckFs $1 $2" && echo $?)
+# Si es UEFI copio el cargador de arranque a la partición
+OSTYPE="$(ogGetOsType $1 $2)"
+if ogIsEfiActive && [ "$OSTYPE" == "Windows" ]; then
+ ogEcho log session "[25] $MSG_HELP_ogCopyEfiBootLoader"
+ ogCopyEfiBootLoader $1 $2
+fi
+
# Evaluar variable de engine.cfg para reducir el sistema de archivos en la creacion
if [ "$IMGREDUCE" == "TRUE" ]
then
- ogEcho log session "[30]: $MSG_HELP_ogReduceFs"
+ ogEcho log session "[30] $MSG_HELP_ogReduceFs"
ogReduceFs $1 $2 &>> $OGLOGCOMMAND || exit $(ogRaiseError $OG_ERR_REDUCEFS "$1 $2"; echo $?)
NEWSIZEFS=$(ogGetFsSize $1 $2)
TIMEAUX=$[SECONDS-TIME1]
@@ -135,7 +145,7 @@ fi
# Renombrar el fichero de imagen si ya existe.
if [ -f "$IMGFILE" ]; then
- ogEcho log session "[10] $MSG_SCRIPTS_FILE_RENAME \"$IMGFILE\" -> \"$IMGFILE.ant\"."
+ ogEcho log session "[35] $MSG_SCRIPTS_FILE_RENAME \"$IMGFILE\" -> \"$IMGFILE.ant\"."
mv "$IMGFILE" "$IMGFILE.ant"
mv "$IMGFILE.torrent" "$IMGFILE.torrent.ant" 2>/dev/null
mv "$IMGFILE.sum" "$IMGFILE.sum.ant" 2>/dev/null
@@ -170,4 +180,3 @@ TIME=$[SECONDS-TIME1]
ogEcho log session "[100] $MSG_SCRIPTS_TIME_TOTAL $[TIME/60]m $[TIME%60]s"
ogEcho log session " FileSystem $PART with $NEWSIZEFS KB data created onto file-image as $4 and used $IMGSIZE KB across DFS $ogprotocol"
ogEcho log session " Image-file $4 metada: $IMGOS"
-
diff --git a/client/shared/scripts/deployImage b/client/shared/scripts/deployImage
index 824da2af..9406d80e 100755
--- a/client/shared/scripts/deployImage
+++ b/client/shared/scripts/deployImage
@@ -119,6 +119,8 @@ case "$MODE" in
# Si protocolo es torrent|torrent-cache o multicast|multicast-cache
TORRENT|TORRENT-CACHE|MULTICAST|MULTICAST-CACHE|UNICAST|UNICAST-CACHE)
+ # Eliminamos CACHE o DIRECT
+ PROTO=${PROTO%%-*}
ogEcho log session "[2] updateCache "$REPO" \"/$IMGNAME.img\" $PROTO $PROTOOPT"
TIME2=$SECONDS
updateCache "$REPO" "/$IMGNAME.img" "$PROTO" "$PROTOOPT"
@@ -165,6 +167,10 @@ case "$MODE" in
# Time-out en la transferencia multicast (El mensaje de error está enviado)
exit $RETVAL
;;
+ *)
+ # Error desconocido
+ exit $RETVAL
+ ;;
esac
;;
*) # Error: protocolo desconocido.
diff --git a/client/shared/scripts/grubSyntax b/client/shared/scripts/grubSyntax
index 209cfc00..aa1adb2e 100755
--- a/client/shared/scripts/grubSyntax
+++ b/client/shared/scripts/grubSyntax
@@ -7,6 +7,8 @@ set -e
#basado en scripts del paquete de grub
#Antonio Doblas Viso
#Universidad de Málaga
+#@version 1.1.1 - En los parámetros del kernel se sustituye el UUID por el dispositivo.
+#@version 1.1.1 - Detecta cargador de Windows en directorio Part-xx-yy dentro de ESP (#802 #888)
DISK=
PART=
@@ -31,7 +33,13 @@ fi
grub_probe=${grub_probe:-$OGBIN/grub-probe1.99_$(arch)}
#librerias del osProber para kernel antiguos: detecta e identifica sistema operativos.
-grub-install --version | grep 1.99 && cp -r /opt/opengnsys/lib/os-probes/* /usr/lib/os-probes/
+if grub-install --version | grep 1.99 ; then
+ cp -r /opt/opengnsys/lib/os-probes/* /usr/lib/os-probes/
+else
+ # Librería os-probe para cargador de microsoft en dir part-x-y (uefi)
+ OSPROBE_MS_PART="/opt/opengnsys/lib/os-probes/mounted/efi/31part-x-y"
+ [ -f $OSPROBE_MS_PART ] && cp $OSPROBE_MS_PART /usr/lib/os-probes/mounted/efi
+fi
#Autoreconocimiento del ogLive en cache
@@ -341,6 +349,24 @@ EOF
}
EOF
;;
+ efi)
+
+ found_other_os=1
+ EFIPATH=${DEVICE#*@}
+ DEVICE=${DEVICE%@*}
+ onstr="$(gettext_printf "(on %s)" "${DEVICE}")"
+ cat << EOF
+menuentry '$(echo "${LONGNAME} $onstr" | grub_quote)' --class windows --class os \$menuentry_id_option 'osprober-efi-$(grub_get_device_id "${DEVICE}")' {
+EOF
+ save_default_entry | sed -e "s/^/\t/"
+#ADV prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
+ OG_prepare_grub_to_access_device ${DEVICE} | sed -e "s/^/\t/"
+
+ cat <<EOF
+ chainloader ${EFIPATH}
+}
+EOF
+ ;;
linux)
KERNELPARAM=""
#linuxprobed detecta todos los kernels de una partición.
@@ -358,6 +384,9 @@ EOF
LKERNEL="`echo ${LINUX} | cut -d ':' -f 4`"
LINITRD="`echo ${LINUX} | cut -d ':' -f 5`"
LPARAMS="`echo ${LINUX} | cut -d ':' -f 6- | tr '^' ' '`"
+ # En los parámetros cambiamos el UUID por el valor de LROOT
+ UUID=$(blkid -s UUID -o value $LROOT)
+ LPARAMS="$(echo $LPARAMS | sed "s|UUID=$UUID|$LROOT|g")"
if [ -z "${LLABEL}" ] ; then
LLABEL="${LONGNAME}"
fi
diff --git a/client/shared/scripts/initCache b/client/shared/scripts/initCache
index 796ab84f..9caf0be0 100755
--- a/client/shared/scripts/initCache
+++ b/client/shared/scripts/initCache
@@ -69,6 +69,8 @@ else
ogUnmountCache 2>/dev/null
ogDeleteCache
fi
+ # Tomamos el tamaño actual. Si no existe cache será 0.
+ OLDSIZE=$(ogGetCacheSize 2>/dev/null) || OLDSIZE=0
# Error si tamaño definido no es >0.
if [ ! $SIZE -gt 0 ]; then
@@ -83,9 +85,9 @@ else
ogCreateCache $NDISK $NPART $SIZE
ogUpdatePartitionTable $NDISK
fi
- # Si caché no montada y no formateada, formatear.
+ # Si caché no montada y no formateada o cambia el tamaño: formatear.
CACHE=$(ogFindCache) || exit $?
- if ! ogIsFormated $CACHE; then
+ if ! ogIsFormated $CACHE || [ $SIZE -ne $OLDSIZE ]; then
echo "[50] Formatear caché local."
ogFormatCache
fi
diff --git a/client/shared/scripts/updateCache b/client/shared/scripts/updateCache
index 0632365f..73086bb7 100755
--- a/client/shared/scripts/updateCache
+++ b/client/shared/scripts/updateCache
@@ -207,7 +207,7 @@ case "$PROTOCOLO" in
ogEcho log session "ogCopyFile $REPOSITORIO $2.torrent absolute $OGCAC/$OGIMG"
# tiempos
timewait=$(expr $(printf '%d\n' 0x$(ogGetMacAddress | awk -F: '{print $5$6}')) \* 120 / 65535)
- ogExecAndLog command ogCopyFile $REPOSITORIO "$2.torrent" "$IMGDIR"
+ ogExecAndLog command ogCopyFile $REPOSITORIO "$2.torrent" "$IMGDIR" || exit $?
#TODO: comprobar que el tracker definido en el fichero es correcto.
#TODO comprobar que el fichero torrent está en cache
# retardamos el inicio -aleatorio de 0 a 120 segundos- al tracker para gestionar mas de +-40 equipos