2023-08-02 12:03:56 -07:00
{{- if or (and (stat (joinPath .host.home ".config" "age" "chezmoi.txt")) (stat (joinPath .chezmoi.sourceDir ".chezmoitemplates" "secrets" "SENDGRID_API_KEY"))) (env "SENDGRID_API_KEY") -}}
2023-04-19 05:13:42 -07:00
#!/usr/bin/env bash
# @file SendGrid Postfix Configuration
# @brief Configures Postfix to use SendGrid as a relay host so you can use the `mail` program to send e-mail from the command-line
# @description
# This script follows the instructions from [SendGrid's documentation on integrating Postfix](https://docs.sendgrid.com/for-developers/sending-email/postfix).
# After this script runs, you should be able to send outgoing e-mails using SendGrid as an SMTP handler. In other words, you will
# be able to use the `mail` CLI command to send e-mails. The following is an example mailing the contents of `~/.bashrc` to `name@email.com`:
#
# ```shell
# cat ~/.bashrc | mail -s "My subject" name@email.com
# ```
{{ includeTemplate "universal/profile" }}
{{ includeTemplate "universal/logg" }}
if command -v postfix > /dev/null; then
### Ensure dependencies are installed
if command -v apt > /dev/null; then
logg info 'Installing libsasl2-modules'
sudo apt-get update
sudo apt-get install -y libsasl2-modules || EXIT_CODE=$?
elif command -v dnf > /dev/null; then
sudo dnf install -y cyrus-sasl-plain || EXIT_CODE=$?
elif command -v yum > /dev/null; then
sudo yum install -y cyrus-sasl-plain || EXIT_CODE=$?
fi
if [ -n " $ EXIT_CODE " ]; then
logg warn 'There was an error ensuring the Postfix-SendGrid dependencies were installed'
fi
if [ -d /etc/postfix ]; then
### Add the SendGrid Postfix settings to the Postfix configuration
if [ -f " ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/main.cf" ]; then
CONFIG_FILE=/etc/postfix/main.cf
if cat " $ CONFIG_FILE " | grep ' ### INSTALL DOCTOR MANAGED'; then
logg info 'Removing Install Doctor-managed block of code in /etc/postfix/main.cf block'
START_LINE="$(echo `grep -n -m 1 " ### INSTALL DOCTOR MANAGED ### START" "$CONFIG_FILE" | cut -f1 -d ":"`)"
END_LINE="$(echo `grep -n -m 1 " ### INSTALL DOCTOR MANAGED ### END" "$CONFIG_FILE" | cut -f1 -d ":"`)"
if command -v gsed > /dev/null; then
gsed -i " $ START_LINE , $ END_LINEd " " $ CONFIG_FILE "
else
sed -i " $ START_LINE , $ END_LINEd " " $ CONFIG_FILE "
fi
fi
### Add Postfix main configuration
logg "Adding configuration from ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/main.cf to /etc/postfix/main.cf"
echo "" | sudo tee -a " $ CONFIG_FILE "
cat " ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/main.cf" | sudo tee -a " $ CONFIG_FILE "
fi
### Ensure proper permissions on `sasl_passwd` and update Postfix hashmaps
if [ -f " ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/sasl_passwd" ]; then
logg info "Copying file from ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/sasl_passwd to /etc/postfix/sasl_passwd"
sudo cp -f " ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/sasl_passwd" /etc/postfix/sasl_passwd
logg info 'Assigning proper permissions to /etc/postfix/sasl_passwd'
sudo chmod 600 /etc/postfix/sasl_passwd
logg info 'Updating Postfix hashmaps for /etc/postfix/sasl_passwd'
sudo postmap /etc/postfix/sasl_passwd
2023-07-31 23:28:03 -07:00
else
logg warn '~/.config/postfix/sasl_passwd file is missing'
fi
### Forward root e-mails
if [ -d /root ]; then
logg info 'Forwarding root e-mails to {{ .user.email }}'
echo '{{ .user.email }}' | sudo tee /root/.forward > /dev/null || logg error 'Failed to set root user .forward file'
elif [ -d /var/root ]; then
logg info 'Forwarding root e-mails to {{ .user.email }}'
echo '{{ .user.email }}' | sudo tee /var/root/.forward > /dev/null || logg error 'Failed to set root user .forward file'
else
logg warn 'Unable to identify root user home directory'
fi
### Ensure /etc/postfix/header_checks exists
if [ ! -d /etc/postfix/header_checks ]; then
logg info 'Creating /etc/postfix/header_checks since it does not exist'
sudo touch /etc/postfix/header_checks
fi
### Re-write header From for SendGrid
if ! cat /etc/postfix/header_checks | grep 'no-reply@{{ .host.domain }}' > /dev/null; then
logg info 'Added From REPLACE to /etc/postfix/header_checks'
echo '/^From:.*@{{ .host.domain }}/ REPLACE From: no-reply@{{ .host.domain }}' | sudo tee -a /etc/postfix/header_checks > /dev/null
fi
### Update aliases
if [ -f /etc/aliases ]; then
logg info 'Forward root e-mails to {{ .user.email }}'
2023-07-31 23:34:52 -07:00
sudo sed s/ #root . * / root : \ { { . user . email } } / - i / etc / aliases
2023-07-31 23:28:03 -07:00
if ! cat /etc/aliases | grep '{{ .user.username }}: root' > /dev/null; then
logg info 'Forward user e-mail to root@localhost'
echo '{{ .user.username }}: root' | sudo tee -a /etc/aliases > /dev/null
fi
2023-07-31 23:34:52 -07:00
logg info 'Running `newaliases` to regenerate the alias database'
sudo newaliases
else
logg warn '/etc/aliases does not appear to exist'
2023-04-19 05:13:42 -07:00
fi
2023-04-19 06:31:45 -07:00
if [ -d /Applications ] && [ -d /System ]; then
### macOS
# Source: https://budiirawan.com/install-mail-server-mac-osx/
2023-07-31 23:34:52 -07:00
if [ -f " ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/com.apple.postfix.master.plist" ] && ! sudo launchctl list | grep 'postfix.master' > /dev/null; then
2023-04-19 06:34:06 -07:00
logg info 'Copying com.apple.postfix.master.plist'
sudo cp -f " ${ XDG_CONFIG_HOME : - $ HOME / . config } /postfix/com.apple.postfix.master.plist" /System/Library/LaunchDaemons/com.apple.postfix.master.plist
2023-07-31 23:28:03 -07:00
sudo launchctl load /System/Library/LaunchDaemons/com.apple.postfix.master.plist && logg success 'launchctl load of com.apple.postfix.master successful'
2023-04-19 06:34:06 -07:00
fi
2023-07-31 23:34:52 -07:00
if ! sudo postfix status > /dev/null; then
logg info 'Starting postfix'
sudo postfix start
else
logg info 'Reloading postfix'
sudo postfix reload
fi
2023-04-19 06:31:45 -07:00
else
### Enable / restart postfix on Linux
logg info 'Enabling / restarting postfix'
sudo systemctl enable postfix
sudo systemctl restart postfix
fi
2023-04-19 05:13:42 -07:00
else
logg warn '/etc/postfix is not a directory! Skipping SendGrid Postfix setup.'
fi
else
logg info 'Skipping Postfix configuration because Postfix is not installed'
fi
{{ end -}}