mail-server/clamav.nix

67 lines
1.5 KiB
Nix
Raw Normal View History

2023-09-17 09:57:55 -07:00
{ config, lib, pkgs, ... }:
with lib;
let cfg = config.fudo.mail.clamav;
in {
options.fudo.mail.clamav = with types; {
enable = mkEnableOption "Enable virus scanning with ClamAV.";
state-directory = mkOption {
type = str;
description = "Path at which to store ClamAV database.";
default = "/var/lib/clamav";
};
port = mkOption {
type = port;
description = "Port on which to listen for incoming requests.";
default = 15407;
};
};
config = mkIf cfg.enable {
users = {
users.clamav = {
isSystemUser = true;
uid = config.ids.uids.clamav;
home = mkForce cfg.state-directory;
description = "ClamAV daemon user";
group = "clamav";
};
groups.clamav = {
members = [ "clamav" ];
gid = config.ids.gids.clamav;
};
};
2023-09-28 12:31:03 -07:00
networking.firewall = {
enable = true;
allowedTCPPorts = [ cfg.port ];
allowedUDPPorts = [ cfg.port ];
};
2023-09-17 09:57:55 -07:00
systemd.tmpfiles.rules =
[ "d ${cfg.state-directory} 0750 clamav clamav - -" ];
services.clamav = {
2023-09-24 10:32:13 -07:00
daemon = {
enable = true;
settings = {
PhishingScanURLs = "no";
DatabaseDirectory = mkForce cfg.state-directory;
2023-09-24 10:34:08 -07:00
User = mkForce "clavmav";
2023-09-24 10:32:13 -07:00
TCPSocket = cfg.port;
};
2023-09-17 09:57:55 -07:00
};
2023-09-24 10:32:13 -07:00
updater = {
enable = true;
settings = {
DatabaseDirectory = mkForce cfg.state-directory;
DatabaseOwner = "clamav";
};
2023-09-17 09:57:55 -07:00
};
};
};
}