From 1e85600b9d609cb1d8343b858d390d6b16d5dfb1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Krizs=C3=A1n=20P=C3=A9ter?= Date: Fri, 22 Nov 2024 18:51:08 +0100 Subject: [PATCH] Update createFstab function --- libs/functions.sh | 39 ++++++++++++++++++++++++++------------- 1 file changed, 26 insertions(+), 13 deletions(-) diff --git a/libs/functions.sh b/libs/functions.sh index a21d8d7..21c4683 100644 --- a/libs/functions.sh +++ b/libs/functions.sh @@ -31,39 +31,52 @@ patchKernelVersion() createFstab() {( # Get mount info from lsblk output + local DIR_ROOT + local DIR_BOOT local LSBLK_INFO LSBLK_INFO=$(lsblk -l -o MOUNTPOINT,PATH,NAME,PKNAME,PARTUUID,FSTYPE,PTTYPE | sed "/^ /d") + # Check if we got a mount point as a parameter + if [ -n "$1" ] ; then + # In case of an invalid mount point (not existing folder) we return here + if [ ! -d "$1" ] ; then + echo "The given mount point is invalid: $1" + return 1 + fi + + # If a mount point is given then we generate fstab based on that mount point. + DIR_ROOT="^$1 " + DIR_BOOT="^$1/boot " + else + # No mount point is given. We generate fstab for the current running system. + DIR_ROOT="^/ " + DIR_BOOT="^/boot " + fi + + # Print out the header part of our fstab printf "# Begin /etc/fstab\n\n" printf '%-45s %-11s %-4s %-16s %-4s %-10s\n' "# File system (PARTUUID)" "mount-point" "type" "options" "dump" "fsck" printf '#%104s\n\n' "order" - # Find the root mount point - local DIR_ROOT - DIR_ROOT=$(grep "^$1 " <<< "$LSBLK_INFO") - if [ -z "$DIR_ROOT" ] ; then - DIR_ROOT=$(grep "^/ " <<< "$LSBLK_INFO") - fi + # Find the root mount point and print out if found + DIR_ROOT=$(grep "$DIR_ROOT" <<< "$LSBLK_INFO") if [ -n "$DIR_ROOT" ] ; then printf '%-45s %-11s %-4s %-16s %-4s %-10s\n' "PARTUUID=$(awk '{print $5}' <<< "$DIR_ROOT")" / "$(awk '{print $6}' <<< "$DIR_ROOT")" defaults 1 1 fi - # Find if there is a separate boot drive - local DIR_BOOT - DIR_BOOT=$(grep "^$1/boot " <<< "$LSBLK_INFO") - if [ -z "$DIR_BOOT" ] && [ -z "$1" ]; then - DIR_BOOT=$(grep "^/boot " <<< "$LSBLK_INFO") - fi + # Find the boot mount point and print out if found + DIR_BOOT=$(grep "$DIR_BOOT" <<< "$LSBLK_INFO") if [ -n "$DIR_BOOT" ] ; then printf '%-45s %-11s %-4s %-16s %-4s %-10s\n' "PARTUUID=$(awk '{print $5}' <<< "$DIR_BOOT")" /boot "$(awk '{print $6}' <<< "$DIR_BOOT")" noauto,defaults 0 0 fi - # Find if there is a swap partition + # Find the swap partition and print out if found local DIR_SWAP DIR_SWAP=$(grep "^\[SWAP\] " <<< "$LSBLK_INFO") if [ -n "$DIR_SWAP" ] ; then printf '%-45s %-11s %-4s %-16s %-4s %-10s\n' "PARTUUID=$(awk '{print $5}' <<< "$DIR_SWAP")" swap "$(awk '{print $6}' <<< "$DIR_SWAP")" pri=1 0 0 fi + # Print out the closing line of out fstab printf "\n# End /etc/fstab\n" )} \ No newline at end of file