refactor: improve install bash script
This commit is contained in:
parent
328462ebcd
commit
c33d4044ae
238
install.bash
238
install.bash
@ -1,79 +1,191 @@
|
|||||||
#!/usr/env/bin bash
|
#!/usr/env/bin bash
|
||||||
|
|
||||||
set -euox pipefail
|
|
||||||
|
|
||||||
export DISK="/dev/vda"
|
install() {
|
||||||
export DISK_EXT="${DISK}"
|
set -euo pipefail
|
||||||
|
local disk="${1}"
|
||||||
|
local encrypt_disk="${2}"
|
||||||
|
local swap_size="${3}"
|
||||||
|
|
||||||
|
local boot_partition="${disk}1"
|
||||||
|
local swap_partition="${disk}2"
|
||||||
|
local primary_partition="${disk}3"
|
||||||
# The size is large because I'd like to be able to hibernate my laptop in its entirety. I have 64 GB of ram.
|
# The size is large because I'd like to be able to hibernate my laptop in its entirety. I have 64 GB of ram.
|
||||||
export SWAP_SIZE="32"
|
|
||||||
export SWAP_OFFSET="$(( SWAP_SIZE + 1 ))"
|
|
||||||
|
|
||||||
export LABEL_CRYPT_LUKS="NixOS-Crypt"
|
if [[ -z "${swap_size}" ]]; then
|
||||||
export LABEL_SWAP="NixOS-Swap"
|
swap_size="$(grep MemTotal /proc/meminfo | awk '{print int(sqrt($2 / 1024 / 1024) * 2)}')"
|
||||||
export LABEL_BTRFS="NixOS-Primary"
|
fi
|
||||||
export LABEL_BOOT="NixOS-Boot"
|
local swap_offset="$((swap_size + 1))"
|
||||||
|
|
||||||
swapoff -a || true
|
local label_crypt_luks="NixOS-Crypt"
|
||||||
umount /mnt/**/* || true
|
local label_swap="NixOS-Swap"
|
||||||
umount /mnt/* || true
|
local label_primary="NixOS-Primary"
|
||||||
umount /mnt || true
|
local label_boot="NixOS-Boot"
|
||||||
cryptsetup close enc || true
|
|
||||||
dd if=/dev/zero of="${DISK}" bs=512 count=1024 || true
|
|
||||||
|
|
||||||
### Partition The Disk
|
swapoff -a >/dev/null 2>&1 || true
|
||||||
parted "${DISK}" -- mklabel gpt
|
umount /mnt/**/* >/dev/null 2>&1 || true
|
||||||
# Boot partition
|
umount /mnt/* >/dev/null 2>&1 || true
|
||||||
parted -a optimal "${DISK}" -- mkpart ESP fat32 1MiB 1GiB
|
umount /mnt >/dev/null 2>&1 || true
|
||||||
parted "${DISK}" -- set 1 boot on
|
cryptsetup close >/dev/null 2>&1 enc || true
|
||||||
mkfs.vfat "${DISK_EXT}1"
|
dd if=/dev/zero of="${disk}" bs=512 count=1024 || true
|
||||||
fatlabel "${DISK_EXT}1" "${LABEL_BOOT}"
|
|
||||||
# Swap Partition
|
|
||||||
parted -a optimal "${DISK}" -- mkpart "${LABEL_SWAP}" linux-swap 1Gib "${SWAP_OFFSET}GB"
|
|
||||||
mkswap -L "${LABEL_SWAP}" "${DISK_EXT}2"
|
|
||||||
swapon "${DISK_EXT}2"
|
|
||||||
# Nix Partition, where the OS will reside with our data
|
|
||||||
parted -a optimal "${DISK}" -- mkpart "${LABEL_BTRFS}" "${SWAP_OFFSET}GiB" 100%
|
|
||||||
|
|
||||||
### Encrypt
|
### Partition The Disk
|
||||||
cryptsetup --verify-passphrase -v luksFormat "${DISK_EXT}3"
|
parted "${disk}" -- mklabel gpt
|
||||||
cryptsetup config "${DISK_EXT}3" --label "${LABEL_CRYPT_LUKS}"
|
# Boot partition
|
||||||
# Have to decrypt it so we can actually get other things setup
|
parted -a optimal "${disk}" -- mkpart ESP fat32 1MiB 1GiB
|
||||||
export CRYPT_OPEN_NAME="enc"
|
parted "${disk}" -- set 1 boot on
|
||||||
export CRYPT_PATH="/dev/mapper/${CRYPT_OPEN_NAME}"
|
mkfs.vfat "${boot_partition}"
|
||||||
cryptsetup open "${DISK_EXT}3" "${CRYPT_OPEN_NAME}"
|
fatlabel "${boot_partition}" "${label_boot}"
|
||||||
|
# Swap Partition
|
||||||
|
parted -a optimal "${disk}" -- mkpart "${label_swap}" linux-swap 1Gib "${swap_offset}GB"
|
||||||
|
mkswap -L "${label_swap}" "${swap_partition}"
|
||||||
|
swapon "${swap_partition}"
|
||||||
|
# Nix Partition, where the OS will reside with our data
|
||||||
|
parted -a optimal "${disk}" -- mkpart "${label_primary}" "${swap_offset}GiB" 100%
|
||||||
|
|
||||||
### BTRFS Setup
|
### Encrypt
|
||||||
# Go ahead and make the unerypted BTRFS
|
if [[ "${encrypt_disk}" == "yes" ]]; then
|
||||||
mkfs.btrfs -L "${LABEL_BTRFS}" "${CRYPT_PATH}"
|
cryptsetup --verify-passphrase -v luksFormat "${primary_partition}"
|
||||||
|
cryptsetup config "${primary_partition}" --label "${label_crypt_luks}"
|
||||||
|
# Have to decrypt it so we can actually get other things setup
|
||||||
|
local crypt_open_name="enc"
|
||||||
|
cryptsetup open "${primary_partition}" "${crypt_open_name}"
|
||||||
|
primary_partition="/dev/mapper/${crypt_open_name}"
|
||||||
|
fi
|
||||||
|
|
||||||
# Mount it
|
### BTRFS Setup
|
||||||
mount -t btrfs "${CRYPT_PATH}" /mnt
|
# Go ahead and make the unerypted BTRFS
|
||||||
|
mkfs.btrfs -f -L "${label_primary}" "${primary_partition}"
|
||||||
|
|
||||||
# Create our subvolumes
|
# Mount it
|
||||||
btrfs subvolume create "/mnt/@nix"
|
mount -t btrfs "${primary_partition}" /mnt
|
||||||
umount /mnt
|
|
||||||
|
|
||||||
### Final Mountings
|
# Create our subvolumes
|
||||||
# Mount tmpfs to mnt
|
btrfs subvolume create "/mnt/@nix"
|
||||||
mount -t tmpfs -o mode=755 none /mnt
|
umount /mnt
|
||||||
|
|
||||||
# Create our directories
|
### Final Mountings
|
||||||
mkdir /mnt/{"boot","nix"}
|
# Mount tmpfs to mnt
|
||||||
# Mount our boot partition
|
mount -t tmpfs -o mode=755 none /mnt
|
||||||
mount -t vfat -o defaults,noatime "${DISK_EXT}1" /mnt/boot
|
|
||||||
|
|
||||||
# Mount our btrfs subvolumes individually with some btrfs options
|
# Create our directories
|
||||||
# NOTE: On high performance NVME SSDs with a beefy CPU it may be worth considering ZLO compression instead of ZSTD. In
|
mkdir /mnt/{"boot","nix"}
|
||||||
# many cases ZLO is more performant, especially when writing, than ZSTD while having a somewhat worse comrpession ratio.
|
# Mount our boot partition
|
||||||
# WARN: ZLO *may* be a good solution, it can be VERY slow on incompressible data. Something to keep in mind.
|
mount -t vfat -o defaults,noatime "${boot_partition}" /mnt/boot
|
||||||
mount -t btrfs -o noatime,compress=zstd,subvol=@nix "${CRYPT_PATH}" /mnt/nix
|
|
||||||
|
|
||||||
mkdir -p /mnt/nix/persist
|
# Mount our btrfs subvolumes individually with some btrfs options
|
||||||
### Install NixOS
|
# NOTE: On high performance NVME SSDs with a beefy CPU it may be worth considering ZLO compression instead of ZSTD. In
|
||||||
# Gotta make sure current working tree isn't dirty for the flake
|
# many cases ZLO is more performant, especially when writing, than ZSTD while having a somewhat worse comrpession ratio.
|
||||||
git config --global user.email "m@m.com"; git config --global user.name "name"; git add .; git commit -m "Shit" >/dev/null 2>&1; \
|
# WARN: ZLO *may* be a good solution, it can be VERY slow on incompressible data. Something to keep in mind.
|
||||||
# Clone the flake into place
|
mount -t btrfs -o noatime,compress=zstd,subvol=@nix "${primary_partition}" /mnt/nix
|
||||||
git clone . /mnt/nix/persist/etc/nixos && cd /mnt/nix/persist/etc/nixos
|
|
||||||
# Finally, actually install NixOS
|
|
||||||
nixos-install --flake "git+file:.#orion"
|
|
||||||
|
|
||||||
|
mkdir -p /mnt/nix/persist
|
||||||
|
# Finally, actually install NixOS
|
||||||
|
nixos-install --flake "git+file:.#orion"
|
||||||
|
}
|
||||||
|
|
||||||
|
usage() {
|
||||||
|
cat <<-__EOF__
|
||||||
|
Usage: $(basename "${0}") -d "/dev/DISK_HERE" -s 32 -e
|
||||||
|
-h | -? | --help
|
||||||
|
Shows this menu.
|
||||||
|
Example:
|
||||||
|
$(basename "${0}") -h
|
||||||
|
|
||||||
|
-d <string> | --disk <string> [REQUIRED]
|
||||||
|
Path to a disk to install NixOS to.
|
||||||
|
Default: none
|
||||||
|
Example:
|
||||||
|
$(basename "${0}") -d /dev/vda
|
||||||
|
|
||||||
|
-e | --encrypt [OPTIONAL]
|
||||||
|
Enable disk encryption during install. Note, this will prompt you for the encryption password.
|
||||||
|
Default: disabled
|
||||||
|
Example:
|
||||||
|
$(basename "${0}") -e
|
||||||
|
|
||||||
|
-s <int> | --swap <int> [OPTIONAL]
|
||||||
|
The size of the swap partition in gigabytes.
|
||||||
|
Default: sqrt(Current system ram in GB) * 2
|
||||||
|
Example:
|
||||||
|
$(basename "${0}") -s 32
|
||||||
|
__EOF__
|
||||||
|
}
|
||||||
|
|
||||||
|
running_as_root() {
|
||||||
|
(( EUID == 0 ))
|
||||||
|
}
|
||||||
|
|
||||||
|
main() {
|
||||||
|
if ! running_as_root; then
|
||||||
|
printf "This script MUST be ran as root, exiting!\n"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
local disk=""
|
||||||
|
local encrypt_disk="no"
|
||||||
|
local swap_size=""
|
||||||
|
|
||||||
|
while :; do
|
||||||
|
case ${1} in
|
||||||
|
-h | -\? | --help)
|
||||||
|
usage # Display a usage synopsis.
|
||||||
|
exit
|
||||||
|
;;
|
||||||
|
--) # End of all options.
|
||||||
|
break
|
||||||
|
;;
|
||||||
|
-d | --disk)
|
||||||
|
shift
|
||||||
|
disk="${1}"
|
||||||
|
if [[ ! -b "${disk}" ]]; then
|
||||||
|
printf "Unable to read disk '%s', check that it exists, is a block device, and that you have write and read permissions for it!" "${disk}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
printf "Setting installation disk to '%s'\n" "${disk}"
|
||||||
|
;;
|
||||||
|
-e | --encrypt)
|
||||||
|
encrypt_disk="yes"
|
||||||
|
printf "Enabled disk encryption\n"
|
||||||
|
;;
|
||||||
|
-s | --swap)
|
||||||
|
shift
|
||||||
|
if [[ "${1}" =~ ^[0-9]+$ ]]; then
|
||||||
|
swap_size="${1}"
|
||||||
|
if ((swap_size <= 0)); then
|
||||||
|
printf "Invalid value passed for swap! Expected a non-zero positive number, got: %s\n" "${swap_size}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
printf "Set swap size to '%s'\n" "${swap_size}"
|
||||||
|
else
|
||||||
|
printf "Invalid value passed for swap! Expected a number got: %s\n" "${1}"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
-?*)
|
||||||
|
printf 'Unknown option: %s\n' "$1" >&2
|
||||||
|
usage
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
*) # Default case: No more options, so break out of the loop.
|
||||||
|
break ;;
|
||||||
|
esac
|
||||||
|
shift
|
||||||
|
done
|
||||||
|
|
||||||
|
set -euo pipefail
|
||||||
|
if [[ -z "${disk}" ]]; then
|
||||||
|
printf "Value for 'disk' (-d) was not provided! See '--help' for usage!\n"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
read -r -s -n 1 -p "Press any key to begin NixOS installation to '${disk}'!"
|
||||||
|
printf "Installing in "
|
||||||
|
for i in {3..1}; do
|
||||||
|
printf "%s.." "${i}"
|
||||||
|
sleep 1
|
||||||
|
done
|
||||||
|
printf "\n"
|
||||||
|
install "${disk}" "${encrypt_disk}" "${swap_size}"
|
||||||
|
}
|
||||||
|
|
||||||
|
main "${@}"
|
||||||
|
Loading…
Reference in New Issue
Block a user