#!/bin/sh domain="$1" # Input validation to allow only valid domain characters if ! [[ "$domain" =~ ^[a-zA-Z0-9.-]+$ ]]; then echo "Give a valid domain as an argument to add mail server for it. Only alphanumeric characters, dashes, and dots are allowed." exit 1 fi subdom="mail" maildomain="mail.$(cat /etc/mailname)" # Add the domain to the valid postfix addresses grep -q "^mydestination.*$domain" /etc/postfix/main.cf || sed -i "s/^mydestination.*/&, $domain/" /etc/postfix/main.cf # Create DKIM for the new domain mkdir -p "/etc/postfix/dkim/$domain" opendkim-genkey -D "/etc/postfix/dkim/$domain" -d "$domain" -s "$subdom" chgrp -R opendkim /etc/postfix/dkim/* chmod -R g+r /etc/postfix/dkim/* # Add entries to keytable and signing table echo "$subdom._domainkey.$domain $domain:$subdom:/etc/postfix/dkim/$domain/$subdom.private" >> /etc/postfix/dkim/keytable echo "*@$domain $subdom._domainkey.$domain" >> /etc/postfix/dkim/signingtable systemctl reload opendkim postfix # Print out DKIM TXT entry pval="$(tr -d '\n' <"/etc/postfix/dkim/$domain/$subdom.txt" | sed "s/k=rsa.* \"p=/k=rsa; p=/;s/\"\s*\"//;s/\"\s*).*//" | grep -o 'p=.*')" dkimentry="$subdom._domainkey.$domain TXT v=DKIM1; k=rsa; $pval" dmarcentry="_dmarc.$domain TXT v=DMARC1; p=reject; rua=mailto:dmarc@$domain; fo=1" spfentry="$domain TXT v=spf1 mx a:$maildomain -all" mxentry="$domain MX 10 $maildomain 300" echo "$dkimentry $dmarcentry $spfentry $mxentry" >> "$HOME/dns_emailwizard_added" echo "=== ADD THE FOLLOWING TO YOUR DNS TXT RECORDS ===" echo "$dkimentry $dmarcentry $spfentry $mxentry" echo "They have also been stored in ~/dns_emailwizard_added"