2024-08-25 00:28:11 -05:00
|
|
|
{ lib, ... }:
|
|
|
|
let
|
|
|
|
root-disk = "/dev/nvme0n1";
|
|
|
|
persist-dir = "/persist";
|
|
|
|
in
|
2024-05-03 14:35:00 -05:00
|
|
|
{
|
|
|
|
services = {
|
|
|
|
fstrim.enable = true;
|
|
|
|
btrfs.autoScrub = {
|
|
|
|
enable = true;
|
|
|
|
fileSystems = [
|
|
|
|
"/"
|
|
|
|
"/nix"
|
|
|
|
"/persist"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-08-25 00:28:11 -05:00
|
|
|
environment.etc.machine-id.source = "${persist-dir}/ephemeral/etc/machine-id";
|
|
|
|
environment.persistence.save = {
|
|
|
|
hideMounts = true;
|
|
|
|
persistentStoragePath = "${persist-dir}/save";
|
|
|
|
};
|
|
|
|
environment.persistence.ephemeral = {
|
|
|
|
persistentStoragePath = "${persist-dir}/ephemeral";
|
|
|
|
hideMounts = true;
|
|
|
|
directories = [
|
|
|
|
"/var/lib"
|
|
|
|
"/etc/nixos"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
|
2024-05-03 14:35:00 -05:00
|
|
|
fileSystems."${persist-dir}".neededForBoot = true;
|
|
|
|
|
|
|
|
disko.devices = {
|
|
|
|
disk.${lib.removePrefix "/dev/" root-disk} = {
|
|
|
|
type = "disk";
|
|
|
|
device = "${root-disk}";
|
|
|
|
content = {
|
|
|
|
type = "gpt";
|
|
|
|
partitions = {
|
|
|
|
esp =
|
|
|
|
let
|
|
|
|
label = "NixOS-Boot";
|
|
|
|
in
|
|
|
|
{
|
|
|
|
priority = 1;
|
|
|
|
size = "512M";
|
|
|
|
type = "EF00";
|
|
|
|
content = {
|
|
|
|
extraArgs = [
|
|
|
|
"-n ${label}"
|
|
|
|
"-F 32"
|
|
|
|
];
|
|
|
|
type = "filesystem";
|
|
|
|
format = "vfat";
|
|
|
|
mountpoint = "/boot";
|
|
|
|
mountOptions = [
|
|
|
|
"umask=0077"
|
|
|
|
"defaults"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
root =
|
|
|
|
let
|
|
|
|
label = "NixOS-Primary";
|
|
|
|
in
|
|
|
|
{
|
|
|
|
size = "100%";
|
|
|
|
content = {
|
|
|
|
type = "luks";
|
|
|
|
name = "crypted";
|
|
|
|
settings = {
|
|
|
|
allowDiscards = true;
|
|
|
|
};
|
|
|
|
content = {
|
|
|
|
type = "btrfs";
|
|
|
|
extraArgs = [
|
|
|
|
"-f"
|
|
|
|
"--label ${label}"
|
|
|
|
];
|
|
|
|
postCreateHook = ''
|
|
|
|
MOUNT="$(mktemp -d)"
|
|
|
|
mount "/dev/disk/by-label/${label}" "$MOUNT" -o subvol=/
|
|
|
|
trap 'umount $MOUNT; rm -rf $MOUNT' EXIT
|
|
|
|
btrfs subvolume snapshot -r "$MOUNT/root" "$MOUNT/root-base"
|
|
|
|
'';
|
|
|
|
subvolumes = {
|
|
|
|
"/root" = {
|
|
|
|
mountpoint = "/";
|
|
|
|
};
|
|
|
|
"/nix" = {
|
|
|
|
mountpoint = "/nix";
|
|
|
|
mountOptions = [
|
|
|
|
"compress=zstd"
|
|
|
|
"noatime"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
"/persist" = {
|
|
|
|
mountpoint = "/persist";
|
|
|
|
mountOptions = [
|
|
|
|
"compress=zstd"
|
|
|
|
"noatime"
|
|
|
|
];
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2024-06-02 12:56:44 -05:00
|
|
|
}
|