dotfiles/systems/laptop/filesystem.nix

67 lines
1.7 KiB
Nix
Raw Normal View History

2024-10-06 15:25:05 -05:00
{
flake,
config,
...
}: let
inherit (flake.config.people) user0 user1 user2;
inherit (flake.config.system.device) laptop nas server;
2024-10-09 23:26:43 -05:00
synologySecrets = config.sops.secrets."network/synology".path;
serverSecrets = config.sops.secrets."network/server".path;
2024-10-06 15:25:05 -05:00
in {
fileSystems = let
synologyDrives = [
"folder0"
"folder1"
"folder4"
];
sambaDrives = [
"samba0"
];
synologyMounts = folder: {
name = "${nas.${folder}.mount}";
value = {
device = nas.${folder}.device;
fsType = "cifs";
2024-10-09 23:26:43 -05:00
options = nas.${folder}.options ++ ["credentials=${synologySecrets}"];
2024-10-06 15:25:05 -05:00
};
};
sambaMounts = samba: {
name = "${server.${samba}.mount}";
value = {
device = server.${samba}.device;
fsType = "cifs";
2024-10-09 23:26:43 -05:00
options = server.${samba}.options ++ ["credentials=${serverSecrets}"];
2024-10-06 15:25:05 -05:00
};
};
in
{
"/" = {
2024-10-12 14:14:47 -05:00
device = "/dev/disk/by-uuid/aae33e00-125e-4f1c-b9aa-9fc512335b7f";
2024-10-06 15:25:05 -05:00
fsType = "ext4";
};
"/boot" = {
2024-10-12 14:14:47 -05:00
device = "/dev/disk/by-uuid/C506-9E18";
2024-10-06 15:25:05 -05:00
fsType = "vfat";
options = laptop.boot.options;
};
}
// (builtins.listToAttrs (map synologyMounts synologyDrives))
// (builtins.listToAttrs (map sambaMounts sambaDrives));
swapDevices = [
2024-10-12 14:14:47 -05:00
{device = "/dev/disk/by-uuid/68d6072a-e21b-4d11-88fd-22c5b9932a50";}
2024-10-06 15:25:05 -05:00
];
systemd.tmpfiles.rules = [
"Z ${config.home-manager.users.${user0}.home.homeDirectory} 0755 ${user0} users -"
"Z ${config.home-manager.users.${user1}.home.homeDirectory} 0755 ${user1} users -"
"Z ${config.home-manager.users.${user2}.home.homeDirectory} 0755 ${user2} users -"
];
services.udisks2.enable = true;
}