nix-config/modules/nixos/programs/fail2ban/storage.nix

23 lines
630 B
Nix

{...}: {
flake.nixosModules.fail2ban-storage = {
lib,
config,
...
}: let
dataFolder = "/var/lib/fail2ban";
in {
options.services.fail2ban.impermanence.enable = lib.mkOption {
type = lib.types.bool;
default = config.services.fail2ban.enable && config.storage.impermanence.enable;
};
config = lib.mkIf config.services.fail2ban.enable {
storage.datasets.replicate."system/root" = {
directories."${dataFolder}" = lib.mkIf config.services.fail2ban.impermanence.enable {
owner.name = "fail2ban";
group.name = "fail2ban";
};
};
};
};
}