diff options
Diffstat (limited to 'modules/home/impermanence/default.nix')
| -rw-r--r-- | modules/home/impermanence/default.nix | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/modules/home/impermanence/default.nix b/modules/home/impermanence/default.nix new file mode 100644 index 0000000..081946c --- /dev/null +++ b/modules/home/impermanence/default.nix @@ -0,0 +1,52 @@ +{ options, config, osConfig, lib, namespace, inputs, host, ... }: + +with lib; with lib.${namespace}; let + cfg = config.${namespace}.impermanence // { + inherit (osConfig.${namespace}.system.impermanence.home) enable location secure; + }; +in { + imports = [ + inputs.impermanence.nixosModules.home-manager.impermanence + ]; + + options.${namespace}.impermanence = with types; { + skeleton = mkOption { + type = bool; + default = true; + }; + + enable = mkOption { type = uniq bool; }; + location = mkOption { type = uniq str; }; + secure.location = mkOption { type = uniq str; }; + }; + + config = { + ${namespace}.impermanence = { + inherit (cfg) enable location secure; + }; + + home.persistence.${cfg.location} = { + enable = cfg.enable; + allowOther = true; + + directories = mkIf cfg.skeleton [ + ".local/share/applications" + ".local/bin" + + "Downloads" + "Documents" + "Pictures" + "Videos" + "Music" + "Games" + "Links" + "Persist" + ]; + }; + + home.persistence.${cfg.secure.location} = { + enable = cfg.enable; + allowOther = false; + }; + }; +} |