X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=modules%2Fprivate%2Fmail%2Fdefault.nix;h=1c64e158be5aa035a5718eb41fb55493c052d098;hb=981fa80354fd6f00f49446777c38f77bd8a65f65;hp=8be21a1ef5ce9af30d47ccdcb85136c754845445;hpb=d2e703c560bc029c3d607058de2935bbf1cb0559;p=perso%2FImmae%2FConfig%2FNix.git diff --git a/modules/private/mail/default.nix b/modules/private/mail/default.nix index 8be21a1..1c64e15 100644 --- a/modules/private/mail/default.nix +++ b/modules/private/mail/default.nix @@ -1,21 +1,25 @@ -{ lib, pkgs, config, myconfig, ... }: +{ lib, pkgs, config, ... }: { imports = [ ./milters.nix ./postfix.nix ./dovecot.nix + ./relay.nix ./rspamd.nix + ./opensmtpd.nix ]; options.myServices.mail.enable = lib.mkEnableOption "enable Mail services"; + options.myServices.mailRelay.enable = lib.mkEnableOption "enable Mail relay services"; + options.myServices.mailBackup.enable = lib.mkEnableOption "enable MX backup services"; config = lib.mkIf config.myServices.mail.enable { - security.acme.certs."mail" = config.myServices.certificates.certConfig // { - domain = "eldiron.immae.eu"; + security.acme2.certs."mail" = config.myServices.certificates.certConfig // { + domain = config.hostEnv.fqdn; extraDomains = let zonesWithMx = builtins.filter (zone: lib.attrsets.hasAttr "withEmail" zone && lib.lists.length zone.withEmail > 0 - ) myconfig.env.dns.masterZones; - mxs = map (zone: "mx-1.${zone.name}") zonesWithMx; + ) config.myEnv.dns.masterZones; + mxs = map (zone: "${config.hostEnv.mx.subdomain}.${zone.name}") zonesWithMx; in builtins.listToAttrs (map (mx: lib.attrsets.nameValuePair mx null) mxs); }; services.duplyBackup.profiles = {