machine: aramis: add installer script
This is the first time that I am setting up LVM-on-LUKS with NixOS, so a VM came in handy to test it out.
This commit is contained in:
parent
5041fc7472
commit
817ca1e9df
51
machines/aramis/install.sh
Executable file
51
machines/aramis/install.sh
Executable file
|
@ -0,0 +1,51 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
if [ "$(id -u)" -ne 0 ]; then
|
||||||
|
echo "This script must be run as root" >&2
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
SWAP_SIZE=16GiB
|
||||||
|
|
||||||
|
parted /dev/nvme0n1 --script -- \
|
||||||
|
mklabel gpt \
|
||||||
|
mkpart primary 512MiB 100% \
|
||||||
|
mkpart ESP fat32 1MiB 512MiB \
|
||||||
|
set 2 esp on
|
||||||
|
|
||||||
|
cryptsetup luksFormat /dev/nvme0n1p1
|
||||||
|
cryptsetup open /dev/nvme0n1p1 crypt
|
||||||
|
|
||||||
|
pvcreate /dev/mapper/crypt
|
||||||
|
vgcreate lvm /dev/mapper/crypt
|
||||||
|
lvcreate -L "$SWAP_SIZE" -n swap lvm
|
||||||
|
lvcreate -l 100%FREE -n root lvm
|
||||||
|
|
||||||
|
mkfs.ext4 -L nixos /dev/lvm/root
|
||||||
|
mkswap -L swap /dev/lvm/swap
|
||||||
|
mkfs.vfat -n boot /dev/nvme0n1p2
|
||||||
|
|
||||||
|
mount /dev/disk/by-label/nixos /mnt
|
||||||
|
mkdir /mnt/boot
|
||||||
|
mount /dev/nvme0n1p2 /mnt/boot
|
||||||
|
swapon /dev/lvm/swap
|
||||||
|
|
||||||
|
cat << EOF
|
||||||
|
# Run the following commands as setup user
|
||||||
|
nixos-generate-config --root /mnt
|
||||||
|
|
||||||
|
# Change uuids to labels
|
||||||
|
vim /mnt/etc/nixos/hardware-configuration.nix
|
||||||
|
|
||||||
|
# Install system
|
||||||
|
mkdir -p /mnt/home/ambroisie/git/nix/config
|
||||||
|
cd /mnt/home/ambroisie/git/nix/config
|
||||||
|
|
||||||
|
git clone <this-repo> .
|
||||||
|
# Assuming you set up GPG key correctly
|
||||||
|
git crypt unlock
|
||||||
|
|
||||||
|
# Setup LUKS with 'boot.initrd.luks.devices.crypt', device is /dev/nvme0n1p1, preLVM = true
|
||||||
|
|
||||||
|
# Use 'nixos-install --flake .#aramis --root /mnt --impure' because of home-manager issue
|
||||||
|
EOF
|
Loading…
Reference in a new issue