diff options
author | Soispha <soispha@vhack.eu> | 2023-07-07 08:06:27 +0200 |
---|---|---|
committer | Soispha <soispha@vhack.eu> | 2023-07-07 08:06:27 +0200 |
commit | 0cc2b1da5353721815e34b4b76664b9c80452abb (patch) | |
tree | f5a82cdc027768023e66aa31a61c2bf832a0b313 /system | |
parent | chore(version): v0.2.0 (diff) | |
parent | Refactor(system/impermanence): Move to own directory (diff) | |
download | nixos-server-0cc2b1da5353721815e34b4b76664b9c80452abb.tar.gz nixos-server-0cc2b1da5353721815e34b4b76664b9c80452abb.zip |
Merge branch 'disko'
Diffstat (limited to '')
-rw-r--r-- | system/default.nix | 2 | ||||
-rw-r--r-- | system/disks/default.nix | 64 | ||||
-rw-r--r-- | system/file_system_layouts/default.nix | 40 |
3 files changed, 65 insertions, 41 deletions
diff --git a/system/default.nix b/system/default.nix index e1cdb28..19c7b36 100644 --- a/system/default.nix +++ b/system/default.nix @@ -1,6 +1,6 @@ {...}: { imports = [ - ./file_system_layouts + ./disks ./impermanence ./packages ./services diff --git a/system/disks/default.nix b/system/disks/default.nix new file mode 100644 index 0000000..24898fe --- /dev/null +++ b/system/disks/default.nix @@ -0,0 +1,64 @@ +{ + config, + lib, + ... +}: +with lib; let + cfg = config.system.disks; + defaultMountOptions = ["compress-force=zstd:15"]; +in { + + options.system.disks = { + disk = mkOption { + type = lib.types.path; + example = literalExpression "/dev/disk/by-id/ata-WDC_WD10SDRW-11A0XS0_WD-WXP2A901KJN5"; + description = lib.mdDoc "Path to the disk"; + }; + }; + + config = { + disko.devices = { + disk.main = { + device = cfg.disk; + content = { + type = "btrfs"; + extraArgs = ["-f" "--label nixos"]; # f: Override existing partitions + subvolumes = { + "nix" = { + mountpoint = "/nix"; + mountOptions = defaultMountOptions; + }; + "persistent-storage" = { + mountpoint = "/srv"; + mountOptions = defaultMountOptions; + }; + "persistent-storage@snapshots" = { + mountpoint = "/srv/.snapshots"; + mountOptions = defaultMountOptions; + }; + "boot" = { + mountpoint = "/boot"; + mountOptions = defaultMountOptions; + }; + }; + }; + }; + nodev = { + "/" = { + fsType = "tmpfs"; + mountOptions = ["defaults" "size=2G" "mode=755"]; + }; + }; + }; + fileSystems = { + "/srv" = { + neededForBoot = true; + }; + "/boot" = { + neededForBoot = true; + }; + }; + }; +} +# vim: ts=2 + diff --git a/system/file_system_layouts/default.nix b/system/file_system_layouts/default.nix deleted file mode 100644 index 95400bd..0000000 --- a/system/file_system_layouts/default.nix +++ /dev/null @@ -1,40 +0,0 @@ -{ - config, - lib, - ... -}: -with lib; let - cfg = config.system.fileSystemLayouts; -in { - options.system.fileSystemLayouts = { - mainDisk = mkOption { - type = lib.types.path; - example = literalExpression "/dev/disk/by-uuid/0442cb6d-f13a-4635-b487-fa76189774c5"; - description = lib.mdDoc "Path to the main disk"; - }; - }; - config = { - fileSystems = { - "/" = { - device = "tmpfs"; - fsType = "tmpfs"; - options = ["defaults" "size=2G" "mode=755"]; - }; - "/nix" = { - device = cfg.mainDisk; - fsType = "btrfs"; - options = ["subvol=nix" "compress-force=zstd"]; - }; - "/srv" = { - device = cfg.mainDisk; - fsType = "btrfs"; - options = ["subvol=storage" "compress-force=zstd"]; - neededForBoot = true; - }; - "/boot" = { - device = cfg.mainDisk; - options = ["subvol=boot" "compress-force=zstd"]; - }; - }; - }; -} |