Updated variable names and casing
This commit is contained in:
132
zfs.sh
132
zfs.sh
@@ -1,55 +1,55 @@
|
||||
#!/bin/bash
|
||||
set -euo pipefail
|
||||
|
||||
BASEDIR="$(dirname "${0}" | sed "s|^\.|${PWD}|")"
|
||||
baseDir="$(realpath "$(dirname "${0}")")"
|
||||
|
||||
source \
|
||||
/etc/os-release
|
||||
source \
|
||||
"${BASEDIR}/system.conf"
|
||||
"${baseDir}/system.conf"
|
||||
|
||||
|
||||
if [[ ! "${DISK}" == **/dev/disk/by-id/** ]]; then
|
||||
if [[ "${DISK}" == **/dev/nvme** ]]; then
|
||||
PART3='p3'
|
||||
if [[ ! "${disk}" == **/dev/disk/by-id/** ]]; then
|
||||
if [[ "${disk}" == **/dev/nvme** ]]; then
|
||||
part3='p3'
|
||||
else
|
||||
PART3='3'
|
||||
part3='3'
|
||||
fi
|
||||
else
|
||||
PART3='-part3'
|
||||
part3='-part3'
|
||||
fi
|
||||
|
||||
|
||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
||||
if [[ "${ENCRYPTION}" == 'yes' ]]; then
|
||||
ZPOOL_PASSWORD='A'
|
||||
ZPOOL_PASSWORD_VERIFY='B'
|
||||
if [[ "${encryption}" == 'yes' ]]; then
|
||||
zpoolPassword='A'
|
||||
zpoolPasswordVerify='B'
|
||||
|
||||
printf \
|
||||
'\033[?47h\033[2J\033[H'
|
||||
|
||||
while [[ ! "${ZPOOL_PASSWORD}" == "${ZPOOL_PASSWORD_VERIFY}" ]] || [[ -z "${ZPOOL_PASSWORD}" ]] || [[ "${#ZPOOL_PASSWORD}" -lt '8' ]]; do
|
||||
while [[ ! "${zpoolPassword}" == "${zpoolPasswordVerify}" ]] || [[ -z "${zpoolPassword}" ]] || [[ "${#zpoolPassword}" -lt '8' ]]; do
|
||||
printf \
|
||||
"\nEnter a password to encrypt your root pool (minimum 8 characters):\n"
|
||||
read \
|
||||
-r \
|
||||
-s \
|
||||
ZPOOL_PASSWORD
|
||||
zpoolPassword
|
||||
|
||||
printf \
|
||||
"\nVerify the password to encrypt your root pool:\n"
|
||||
read \
|
||||
-r \
|
||||
-s \
|
||||
ZPOOL_PASSWORD_VERIFY
|
||||
zpoolPasswordVerify
|
||||
|
||||
if [[ ! "${ZPOOL_PASSWORD}" == "${ZPOOL_PASSWORD_VERIFY}" ]]; then
|
||||
if [[ ! "${zpoolPassword}" == "${zpoolPasswordVerify}" ]]; then
|
||||
printf \
|
||||
"ERROR:\tPasswords do not match!\n"
|
||||
elif [[ -z "${ZPOOL_PASSWORD}" ]]; then
|
||||
elif [[ -z "${zpoolPassword}" ]]; then
|
||||
printf \
|
||||
"ERROR:\tPassword is empty!\n"
|
||||
elif [[ "${#ZPOOL_PASSWORD}" -lt '8' ]]; then
|
||||
elif [[ "${#zpoolPassword}" -lt '8' ]]; then
|
||||
printf \
|
||||
"ERROR:\tPassword is too short!\n"
|
||||
fi
|
||||
@@ -63,18 +63,18 @@ fi
|
||||
/etc/zfs/keys/
|
||||
|
||||
printf \
|
||||
"${ZPOOL_PASSWORD}\n" | tee /etc/zfs/keys/${HOSTNAME,,}.key &> /dev/null
|
||||
"${zpoolPassword}\n" | tee /etc/zfs/keys/${hostname,,}.key &> /dev/null
|
||||
|
||||
chmod \
|
||||
000 \
|
||||
/etc/zfs/keys/${HOSTNAME,,}.key
|
||||
/etc/zfs/keys/${hostname,,}.key
|
||||
|
||||
zpool create \
|
||||
-o ashift=12 \
|
||||
-o autotrim=on \
|
||||
-o compatibility=openzfs-2.1-linux \
|
||||
-O encryption=on \
|
||||
-O keylocation=file:///etc/zfs/keys/${HOSTNAME,,}.key \
|
||||
-O keylocation=file:///etc/zfs/keys/${hostname,,}.key \
|
||||
-O keyformat=passphrase \
|
||||
-O acltype=posixacl \
|
||||
-O xattr=sa \
|
||||
@@ -85,8 +85,8 @@ fi
|
||||
-O canmount=off \
|
||||
-O mountpoint=/ \
|
||||
-R /mnt \
|
||||
${HOSTNAME,,} \
|
||||
${DISK}${PART3}
|
||||
${hostname,,} \
|
||||
${disk}${part3}
|
||||
else
|
||||
zpool create \
|
||||
-o ashift=12 \
|
||||
@@ -102,42 +102,42 @@ fi
|
||||
-O canmount=off \
|
||||
-O mountpoint=/ \
|
||||
-R /mnt \
|
||||
${HOSTNAME,,} \
|
||||
${DISK}${PART3}
|
||||
${hostname,,} \
|
||||
${disk}${part3}
|
||||
fi
|
||||
|
||||
zfs create \
|
||||
-o canmount=off \
|
||||
-o mountpoint=none \
|
||||
${HOSTNAME,,}/ROOT
|
||||
${hostname,,}/ROOT
|
||||
# else
|
||||
# zpool import \
|
||||
# -N \
|
||||
# -R \
|
||||
# /mnt \
|
||||
# ${HOSTNAME,,}
|
||||
# ${hostname,,}
|
||||
#
|
||||
# zfs load-key \
|
||||
# -r \
|
||||
# -L prompt \
|
||||
# ${HOSTNAME,,}
|
||||
# ${hostname,,}
|
||||
# fi
|
||||
|
||||
zfs create \
|
||||
-o canmount=noauto \
|
||||
-o mountpoint=/ \
|
||||
${HOSTNAME,,}/ROOT/${ID}
|
||||
${hostname,,}/ROOT/${ID}
|
||||
|
||||
zfs mount \
|
||||
${HOSTNAME,,}/ROOT/${ID}
|
||||
${hostname,,}/ROOT/${ID}
|
||||
|
||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
||||
zfs create \
|
||||
${HOSTNAME,,}/home
|
||||
${hostname,,}/home
|
||||
|
||||
zfs create \
|
||||
-o mountpoint=/root \
|
||||
${HOSTNAME,,}/home/root
|
||||
${hostname,,}/home/root
|
||||
|
||||
chmod \
|
||||
700 \
|
||||
@@ -146,29 +146,29 @@ zfs mount \
|
||||
zfs create \
|
||||
-o canmount=off \
|
||||
-o mountpoint=/var \
|
||||
${HOSTNAME,,}/var
|
||||
${hostname,,}/var
|
||||
|
||||
zfs create \
|
||||
-o canmount=off \
|
||||
${HOSTNAME,,}/var/lib
|
||||
${hostname,,}/var/lib
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/log
|
||||
${hostname,,}/var/log
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/spool
|
||||
${hostname,,}/var/spool
|
||||
|
||||
zfs create \
|
||||
-o com.sun:auto-snapshot=false \
|
||||
${HOSTNAME,,}/var/cache
|
||||
${hostname,,}/var/cache
|
||||
|
||||
zfs create \
|
||||
-o com.sun:auto-snapshot=false \
|
||||
${HOSTNAME,,}/var/lib/nfs
|
||||
${hostname,,}/var/lib/nfs
|
||||
|
||||
zfs create \
|
||||
-o com.sun:auto-snapshot=false \
|
||||
${HOSTNAME,,}/var/tmp
|
||||
${hostname,,}/var/tmp
|
||||
|
||||
chmod \
|
||||
1777 \
|
||||
@@ -176,99 +176,99 @@ zfs mount \
|
||||
|
||||
zfs create \
|
||||
-o mountpoint=/srv \
|
||||
${HOSTNAME,,}/srv
|
||||
${hostname,,}/srv
|
||||
|
||||
zfs create \
|
||||
-o canmount=off \
|
||||
-o mountpoint=/usr \
|
||||
${HOSTNAME,,}/usr
|
||||
${hostname,,}/usr
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/usr/local
|
||||
${hostname,,}/usr/local
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/games
|
||||
${hostname,,}/var/games
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/lib/AccountsService
|
||||
${hostname,,}/var/lib/AccountsService
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/lib/NetworkManager
|
||||
${hostname,,}/var/lib/NetworkManager
|
||||
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/www
|
||||
${hostname,,}/var/www
|
||||
|
||||
zfs create \
|
||||
-o com.sun:auto-snapshot=false \
|
||||
-o mountpoint=/tmp \
|
||||
${HOSTNAME,,}/tmp
|
||||
${hostname,,}/tmp
|
||||
|
||||
if [[ "${ENCRYPTION}" == 'yes' ]]; then
|
||||
if [[ "${encryption}" == 'yes' ]]; then
|
||||
zfs create \
|
||||
-o com.sun:auto-snapshot=false \
|
||||
-o mountpoint=/etc/zfs/keys \
|
||||
${HOSTNAME,,}/keystore
|
||||
${hostname,,}/keystore
|
||||
fi
|
||||
|
||||
zpool set \
|
||||
bootfs=${HOSTNAME,,}/ROOT/${ID} \
|
||||
${HOSTNAME,,}
|
||||
bootfs=${hostname,,}/ROOT/${ID} \
|
||||
${hostname,,}
|
||||
# else
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/home
|
||||
# ${hostname,,}/home
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/home/root
|
||||
# ${hostname,,}/home/root
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/log
|
||||
# ${hostname,,}/var/log
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/spool
|
||||
# ${hostname,,}/var/spool
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/cache
|
||||
# ${hostname,,}/var/cache
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/lib/nfs
|
||||
# ${hostname,,}/var/lib/nfs
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/tmp
|
||||
# ${hostname,,}/var/tmp
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/srv
|
||||
# ${hostname,,}/srv
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/usr/local
|
||||
# ${hostname,,}/usr/local
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/games
|
||||
# ${hostname,,}/var/games
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/lib/AccountsService
|
||||
# ${hostname,,}/var/lib/AccountsService
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/lib/NetworkManager
|
||||
# ${hostname,,}/var/lib/NetworkManager
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/www
|
||||
# ${hostname,,}/var/www
|
||||
#
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/keystore
|
||||
# ${hostname,,}/keystore
|
||||
# fi
|
||||
|
||||
if [[ "${ID}" == 'fedora' ]]; then
|
||||
"${BASEDIR}/base-fedora.sh" -1
|
||||
"${baseDir}/fedora.sh" -1
|
||||
fi
|
||||
|
||||
# if [[ ! "${*}" = *--no-part* ]]; then
|
||||
zfs create \
|
||||
${HOSTNAME,,}/var/mail
|
||||
${hostname,,}/var/mail
|
||||
|
||||
chmod \
|
||||
1777 \
|
||||
/mnt/tmp
|
||||
# else
|
||||
# zfs mount \
|
||||
# ${HOSTNAME,,}/var/mail
|
||||
# ${hostname,,}/var/mail
|
||||
# fi
|
||||
|
||||
Reference in New Issue
Block a user