Price Hiller
02334f5601
All checks were successful
Check Formatting of Files / Check-Formatting (push) Successful in 1m14s
113 lines
2.8 KiB
Nix
113 lines
2.8 KiB
Nix
{
|
|
modulesPath,
|
|
config,
|
|
lib,
|
|
root-disk,
|
|
persist-dir,
|
|
...
|
|
}:
|
|
{
|
|
services = {
|
|
fstrim.enable = true;
|
|
btrfs.autoScrub = {
|
|
enable = true;
|
|
fileSystems = [
|
|
"/"
|
|
"/nix"
|
|
"/persist"
|
|
];
|
|
};
|
|
snapper = {
|
|
# NOTE: According to `snapper-config(5)` the default timeline count for all timelines is 10
|
|
# (see TIMELINE_LIMIT_HOURLY, ...DAILY, etc.)
|
|
configs.persist = {
|
|
TIMELINE_CREATE = true;
|
|
TIMELINE_CLEANUP = true;
|
|
SUBVOLUME = "${persist-dir}";
|
|
};
|
|
};
|
|
};
|
|
|
|
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"
|
|
];
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
};
|
|
}
|