1
0
Fork 0
mirror of https://git.sr.ht/~neverness/ultima synced 2025-01-22 20:23:53 +00:00
ultima/modules/nixos/hardware/impermanence/default.nix

66 lines
1.5 KiB
Nix
Raw Normal View History

{ x, inputs, lib, config, ... }:
2024-11-21 09:24:15 +00:00
with lib;
2024-12-09 01:15:55 +00:00
with x;
2024-11-21 09:24:15 +00:00
let cfg = config.module.hardware.impermanence;
in {
2024-12-09 01:15:55 +00:00
options = { module.hardware.impermanence = { enable = mkBool; }; };
2024-11-21 09:24:15 +00:00
imports = [ inputs.impermanence.nixosModules.impermanence ];
config = mkIf cfg.enable {
programs.fuse.userAllowOther = true;
environment.persistence."/persistent" = {
enable = true; # NB: Defaults to true, not needed
hideMounts = true;
directories = [
"/var/log"
"/var/lib/bluetooth"
"/var/lib/nixos"
"/var/lib/systemd/coredump"
"/etc/NetworkManager/system-connections"
{
directory = "/var/lib/colord";
user = "colord";
group = "colord";
mode = "u=rwx,g=rx,o=";
}
];
files = [
"/etc/machine-id"
{
file = "/var/keys/secret_file";
parentDirectory = { mode = "u=rwx,g=,o="; };
}
];
users.talyz = {
directories = [
"Downloads"
"Music"
"Pictures"
"Documents"
"Videos"
"VirtualBox VMs"
{
directory = ".gnupg";
mode = "0700";
}
{
directory = ".ssh";
mode = "0700";
}
{
directory = ".nixops";
mode = "0700";
}
{
directory = ".local/share/keyrings";
mode = "0700";
}
".local/share/direnv"
];
files = [ ".screenrc" ];
};
};
};
}