diff options
| author | Alejandro Soto <alejandro@34project.org> | 2025-04-06 14:27:57 -0600 |
|---|---|---|
| committer | Alejandro Soto <alejandro@34project.org> | 2025-04-06 14:27:57 -0600 |
| commit | 5b01285ee33516cec607cbd069e06b4b8970c088 (patch) | |
| tree | a6befbaca9bfee6163579d235ae589cb29313269 /sys/mta/default.nix | |
| parent | 2585c96ff9b7945cab054e38fbbcaf760e3be38c (diff) | |
sys: reload services after certificate renewal
Diffstat (limited to '')
| -rw-r--r-- | sys/mta/default.nix | 310 |
1 files changed, 155 insertions, 155 deletions
diff --git a/sys/mta/default.nix b/sys/mta/default.nix index 35508e6..64e08f3 100644 --- a/sys/mta/default.nix +++ b/sys/mta/default.nix @@ -11,6 +11,13 @@ with lib; let allDomains = optional (! virtualDomains ? ${domain}) domain ++ attrNames virtualDomains; virtualDomains = filterAttrs (name: _: name != domain) virtual; + cert = config.security.acme.certs.${mtaDomain.main}.directory; + + mtaDomain = + if isPrimary + then domains.smtp + else domains.smtp-backup; + mdaTransport = if isPrimary then "lmtp:inet:${cfg.mdaAddr}:${toString cfg.lmtpPort}" @@ -60,162 +67,153 @@ in ''; }; - postfix = - let - cert = config.security.acme.certs.${mtaDomain.main}.directory; - - mtaDomain = - if isPrimary - then domains.smtp - else domains.smtp-backup; - in - { - enable = true; - enableSmtp = true; - enableSubmissions = isPrimary; - - inherit domain; - hostname = mtaDomain.main; - - #TODO: check_recipient_access para rechazar localhost desde afuera - destination = optionals isPrimary [ "localhost" "$mydomain" ]; - origin = "$mydomain"; - - networksStyle = "host"; - - relayHost = optionalString isBackup domains.smtp.main; - lookupMX = false; - - relayDomains = - if isBackup - then allDomains - else null; - - sslKey = "${cert}/key.pem"; - sslCert = "${cert}/fullchain.pem"; - - # También es postmaster - rootAlias = config.local.sysadmin; - - extraAliases = optionalString isPrimary - (concatLines (flatten (mapAttrsToList - (name: user: map - (alias: "${alias}: ${name}") - user.hardAliases) - users))); - - localRecipients = optionals isPrimary - (map (user: "${user}@${domain}") - (attrNames (users // virtual.${domain}.users))); - - virtual = optionalString isPrimary - (concatLines (flatten (mapAttrsToList - (name: virtual: mapAttrsToList - (alias: targets: "${alias}@${name} ${concatStringsSep ", " targets}") - virtual.aliases) - virtual))); - - mapFiles = optionalAttrs isPrimary { - sender_ccerts = - pkgs.writeText "postfix-sender_ccerts" - (concatLines (flatten (mapAttrsToList - (username: user: map - (alias: "${alias}@${domain} CCERTS ${concatStringsSep "," (map (certPath: config.local.pki.byPath.${certPath}.fingerprint.sha256) user.mail.certs)}") - ([ username ] ++ user.hardAliases)) - (filterAttrs (_: user: user.mail.certs != [ ]) users)))); - - sender_login = - pkgs.writeText "postfix-sender_login" - (concatLines (flatten (mapAttrsToList - (username: user: map - (alias: "${alias}@${domain} ${username}") - ([ username ] ++ user.hardAliases)) - users))); - - virtual_recipients = - pkgs.writeText "postfix-virtual_recipients" - (concatLines (flatten (mapAttrsToList - (virtualDomain: virtual: mapAttrsToList - # El lado derecho de esta tabla debe existir pero nunca se usa - (username: _: "${username}@${virtualDomain} foo") - virtual.users) - virtualDomains))); - - virtual_rules = - pkgs.writeText "postfix-virtual_rules" - (concatLines (flatten (mapAttrsToList - (name: virtual: map - (rule: "/^${rule.pattern}@${name}$/ ${concatStringsSep ", " rule.targets}") - virtual.rules) - virtual))); - }; - - config = { - # user+extension@domain.tld - recipient_delimiter = optionalString isPrimary "+"; - - message_size_limit = toString (50 * 1048576); - - local_transport = mdaTransport; - virtual_transport = mdaTransport; - - smtpd_tls_auth_only = true; - # Nota: smtpd_tls_dh1024_param_file fue deprecado en 3.9 - - tls_append_default_CA = false; # Crítico - } // optionalAttrs isPrimary { - virtual_alias_maps = mkAfter [ "pcre:/etc/postfix/virtual_rules" ]; - virtual_mailbox_domains = attrNames virtualDomains; - virtual_mailbox_maps = [ "hash:/etc/postfix/virtual_recipients" ]; - - smtpd_sasl_type = "dovecot"; - smtpd_sasl_path = "inet:${cfg.mdaAddr}:${toString cfg.saslPort}"; - smtpd_sasl_local_domain = "$mydomain"; - smtpd_sasl_security_options = [ "noanonymous" ]; - - smtpd_tls_CAfile = "${config.local.pki.ca.mail.fullchain}"; - smtpd_tls_ccert_verifydepth = "1"; - - # Inventado, no es parámetro de postfix - local_submission_client_restrictions = [ - "permit_tls_all_clientcerts" - "permit_sasl_authenticated" - "reject" - ]; - - smtpd_sender_login_maps = [ "hash:/etc/postfix/sender_login" ]; - - smtpd_relay_restrictions = [ - "permit_mynetworks" - "permit_tls_all_clientcerts" - "permit_sasl_authenticated" - "reject_unauth_destination" - ]; - - smtpd_sender_restrictions = [ - "check_sender_access hash:/etc/postfix/sender_ccerts" - "reject_sender_login_mismatch" - ]; - - smtpd_milters = "unix:/run/opendkim/opendkim.sock"; - non_smtpd_milters = "$smtpd_milters"; - milter_default_action = "accept"; - } // optionalAttrs isBackup { - inet_interfaces = [ cfg.relayListen ]; - - smtpd_relay_restrictions = [ - "reject_unauth_destination" - ]; - }; - - # Importante: existe submissionOptions por aparte, no son iguales - submissionsOptions = optionalAttrs isPrimary { - smtpd_client_restrictions = "$local_submission_client_restrictions"; - smtpd_sasl_auth_enable = "yes"; - smtpd_tls_ask_ccert = "yes"; - smtpd_tls_security_level = "encrypt"; - }; + postfix = { + enable = true; + enableSmtp = true; + enableSubmissions = isPrimary; + + inherit domain; + hostname = mtaDomain.main; + + #TODO: check_recipient_access para rechazar localhost desde afuera + destination = optionals isPrimary [ "localhost" "$mydomain" ]; + origin = "$mydomain"; + + networksStyle = "host"; + + relayHost = optionalString isBackup domains.smtp.main; + lookupMX = false; + + relayDomains = + if isBackup + then allDomains + else null; + + sslKey = "${cert}/key.pem"; + sslCert = "${cert}/fullchain.pem"; + + # También es postmaster + rootAlias = config.local.sysadmin; + + extraAliases = optionalString isPrimary + (concatLines (flatten (mapAttrsToList + (name: user: map + (alias: "${alias}: ${name}") + user.hardAliases) + users))); + + localRecipients = optionals isPrimary + (map (user: "${user}@${domain}") + (attrNames (users // virtual.${domain}.users))); + + virtual = optionalString isPrimary + (concatLines (flatten (mapAttrsToList + (name: virtual: mapAttrsToList + (alias: targets: "${alias}@${name} ${concatStringsSep ", " targets}") + virtual.aliases) + virtual))); + + mapFiles = optionalAttrs isPrimary { + sender_ccerts = + pkgs.writeText "postfix-sender_ccerts" + (concatLines (flatten (mapAttrsToList + (username: user: map + (alias: "${alias}@${domain} CCERTS ${concatStringsSep "," (map (certPath: config.local.pki.byPath.${certPath}.fingerprint.sha256) user.mail.certs)}") + ([ username ] ++ user.hardAliases)) + (filterAttrs (_: user: user.mail.certs != [ ]) users)))); + + sender_login = + pkgs.writeText "postfix-sender_login" + (concatLines (flatten (mapAttrsToList + (username: user: map + (alias: "${alias}@${domain} ${username}") + ([ username ] ++ user.hardAliases)) + users))); + + virtual_recipients = + pkgs.writeText "postfix-virtual_recipients" + (concatLines (flatten (mapAttrsToList + (virtualDomain: virtual: mapAttrsToList + # El lado derecho de esta tabla debe existir pero nunca se usa + (username: _: "${username}@${virtualDomain} foo") + virtual.users) + virtualDomains))); + + virtual_rules = + pkgs.writeText "postfix-virtual_rules" + (concatLines (flatten (mapAttrsToList + (name: virtual: map + (rule: "/^${rule.pattern}@${name}$/ ${concatStringsSep ", " rule.targets}") + virtual.rules) + virtual))); + }; + + config = { + # user+extension@domain.tld + recipient_delimiter = optionalString isPrimary "+"; + + message_size_limit = toString (50 * 1048576); + + local_transport = mdaTransport; + virtual_transport = mdaTransport; + + smtpd_tls_auth_only = true; + # Nota: smtpd_tls_dh1024_param_file fue deprecado en 3.9 + + tls_append_default_CA = false; # Crítico + } // optionalAttrs isPrimary { + virtual_alias_maps = mkAfter [ "pcre:/etc/postfix/virtual_rules" ]; + virtual_mailbox_domains = attrNames virtualDomains; + virtual_mailbox_maps = [ "hash:/etc/postfix/virtual_recipients" ]; + + smtpd_sasl_type = "dovecot"; + smtpd_sasl_path = "inet:${cfg.mdaAddr}:${toString cfg.saslPort}"; + smtpd_sasl_local_domain = "$mydomain"; + smtpd_sasl_security_options = [ "noanonymous" ]; + + smtpd_tls_CAfile = "${config.local.pki.ca.mail.fullchain}"; + smtpd_tls_ccert_verifydepth = "1"; + + # Inventado, no es parámetro de postfix + local_submission_client_restrictions = [ + "permit_tls_all_clientcerts" + "permit_sasl_authenticated" + "reject" + ]; + + smtpd_sender_login_maps = [ "hash:/etc/postfix/sender_login" ]; + + smtpd_relay_restrictions = [ + "permit_mynetworks" + "permit_tls_all_clientcerts" + "permit_sasl_authenticated" + "reject_unauth_destination" + ]; + + smtpd_sender_restrictions = [ + "check_sender_access hash:/etc/postfix/sender_ccerts" + "reject_sender_login_mismatch" + ]; + + smtpd_milters = "unix:/run/opendkim/opendkim.sock"; + non_smtpd_milters = "$smtpd_milters"; + milter_default_action = "accept"; + } // optionalAttrs isBackup { + inet_interfaces = [ cfg.relayListen ]; + + smtpd_relay_restrictions = [ + "reject_unauth_destination" + ]; + }; + + # Importante: existe submissionOptions por aparte, no son iguales + submissionsOptions = optionalAttrs isPrimary { + smtpd_client_restrictions = "$local_submission_client_restrictions"; + smtpd_sasl_auth_enable = "yes"; + smtpd_tls_ask_ccert = "yes"; + smtpd_tls_security_level = "encrypt"; }; + }; }; #TODO: solo para las destination addresses necesarias @@ -231,5 +229,7 @@ in certs.smtp.enable = isPrimary; certs.smtp-backup.enable = isBackup; }; + + security.acme.certs.${mtaDomain.main}.reloadServices = [ "postfix.service" ]; }; } |
