X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=mail-setup;h=b02da1ea52efaec1099e71c47d903269f47b815e;hb=15f043c2c297176bd623d8a8602e2dc5d67eacd6;hp=83ae53c1b2fb8c9e402208d77d9610ff875b4242;hpb=07d3aa7d2c415178ca720f3a53dfba1129babc4a;p=distro-setup diff --git a/mail-setup b/mail-setup index 83ae53c..b02da1e 100755 --- a/mail-setup +++ b/mail-setup @@ -27,6 +27,15 @@ Setup exim4 / postfix / dovecot The minimal assumption we have is that /etc/mailpass exists + +I've had problems with postfix on debian: +on stretch, a startup ordering issue caused all mail to fail. +postfix changed defaults to only use ipv6 dns, causing all my mail to fail. +I haven't gotten around to getting a non-debian exim +setup. + + + -h|--help Print help and exit. EOF exit $1 @@ -117,6 +126,7 @@ u=$SUDO_USER # echo "dmarc dns, name: _dmarc value: v=DMARC1; p=none; rua=mailto:mailauth-reports@$domain" # # 2017-02 spf policies: +# # host -t txt lists.fedoraproject.org # # google ~all, hotmail -all, yahoo: ?all, fastmail ?all # # i include fastmail\'s settings, per their instructions, # # and follow their policy. In mail in a box, or similar instructions, @@ -281,8 +291,9 @@ else # begin exim. has debian specific stuff for now if [[ -e /p/c/filesystem ]]; then # to put the hostname in the known hosts - ssh -o StrictHostKeyChecking=no root@li.iankelling.org : - /a/exe/vpn-mk-client-cert -b mail -n mail li.iankelling.org + : + #ssh -o StrictHostKeyChecking=no root@li.iankelling.org : + #/a/exe/vpn-mk-client-cert -b mail -n mail li.iankelling.org fi cat >/etc/systemd/system/mailroute.service </etc/exim4/conf.d/router/190_exim4-config_fsfsmarthost <<'EOF' +# smarthost for fsf mail +# ian: copied from /etc/exim4/conf.d/router/200_exim4-config_primary, and added senders = and +# replaced DCsmarthost with mail.fsf.org +fsfsmarthost: + debug_print = "R: smarthost for $local_part@$domain" + driver = manualroute + domains = ! +local_domains + senders = *@fsf.org + transport = remote_smtp_smarthost + route_list = * mail.fsf.org byname + host_find_failed = ignore + same_domain_copy_routing = yes + no_more +EOF + + # https://blog.dhampir.no/content/make-exim4-on-debian-respect-forward-and-etcaliases-when-using-a-smarthost + # i only need .forwards, so just doing that one. + cd /etc/exim4/conf.d/router + b=userforward_higher_priority + # replace the router name so it is unique + sed -r s/^\\S+:/$b:/ 600_exim4-config_userforward >175_$b # begin setup passwd.client f=/etc/exim4/passwd.client @@ -855,12 +894,9 @@ EOF done # end setup passwd.client - # https://blog.dhampir.no/content/make-exim4-on-debian-respect-forward-and-etcaliases-when-using-a-smarthost - # i only need .forwards, so just doing that one. - cd /etc/exim4/conf.d/router - b=userforward_higher_priority - # replace the router name so it is unique - sed -r s/^\\S+:/$b:/ 600_exim4-config_userforward >175_$b + # by default, only 10 days of logs are kept. increase that. + sed -ri 's/^(\s*rotate\s).*/\11000/' /etc/logrotate.d/exim4-base + systemctl restart exim4 fi #### end if exim4 @@ -905,11 +941,19 @@ if dpkg -s radicale &>/dev/null; then if [[ $HOSTNAME == $MAIL_HOST ]]; then systemctl restart radicale systemctl enable radicale + if [[ -e /etc/logrotate.d/radicale.disabled ]]; then + mv /etc/logrotate.d/radicale{.disabled,} + fi else systemctl stop radicale systemctl disable radicale + # weekly logrotate tries to restart radicale even if it's a disabled service in flidas. + if [[ -e /etc/logrotate.d/radicale ]]; then + mv /etc/logrotate.d/radicale{,.disabled} + fi fi fi +exit 0 # if I wanted the from address to be renamed and sent to a different address, # echo "sdx@localhost development@localhost" | sudo dd of=/etc/postfix/recipient_canonical