Hello. Let’s say I want to selfhost an email server (smtp + imap) that only will be used to receive email.

I only will send email internally (from my domain to my domain) and receive from 3rd parties.

Should I setup DKIM, DMARC, SPF and reverse IP lookup?

To be honest, I’m having a bit of hard time understanding the madness of email authentication. So I can’t figure it out by myself if those mechanisms are needed in my case.

I haven’t deployed anything, but probably will use Stalwart. It looks like it’s easy to deploy. Is there any other beginner-friendly email service I should read about?

Thanks!

  • @[email protected]
    link
    fedilink
    English
    2310 months ago

    You should definitely set up a DMARC record to prevent other people from using your email domain to send spam. If you don’t have DMARC configured, other email servers will give any senders the benefit of the doubt and accept mail that claims to be from your domain.

    You can just set the DMARC record to reject 100% of unverified mail and call it a day. Since you aren’t sending anything it won’t affect you.

    • @[email protected]
      link
      fedilink
      English
      1110 months ago

      I would also set up SPF to disallow all IPs to send mail for that domain in case some system supports SPF but not DMARC.

      • @[email protected]OP
        link
        fedilink
        English
        810 months ago

        Thanks to both of you.

        I had the hope that DMARC, SPF and DKIM was stuff I could just ignore if not sending email. It seems I was wrong about that.

        • @[email protected]
          link
          fedilink
          English
          610 months ago

          Those three are really not all that complicated, basically (apart from DKIM which you can ignore when not sending) they are just a couple of TXT DNS records you need to set once for your domain. Even if you were using DKIM it is just a keypair you generate and then put the public key into a DNS TXT record and configure your mail server to use the private key.

    • funkajunk
      link
      fedilink
      English
      810 months ago

      Just to flesh that out a bit… All you need is to add a TXT record to your DNS records:

      Name: _dmarc.yourdomain.com

      Value: v=DMARC1; p=reject; pct=100

    • lemmyvore
      link
      fedilink
      English
      610 months ago

      will give any senders the benefit of the doubt and accept mail that claims to be from your domain.

      You misspelled “black-hole your domain forever”.

    • 𝘋𝘪𝘳𝘬
      link
      fedilink
      English
      5
      edit-2
      10 months ago

      Some strict mail servers even blacklist you if the DMARC record is missing.

      • @69420
        link
        English
        210 months ago

        Some servers blacklist you even if you have DMARC, SPF, DKIM, DNS setup perfectly, but your IP is in a block of addresses that may or may not have been hosted by the same ISP of some unrelated server that was possibly compromised 10 years before you even set up the mail server. Ask me how I know.

        • @[email protected]
          link
          fedilink
          English
          210 months ago

          Some servers blacklist you no matter what you do because you’re not a big player in the e-mail space… Outlook. Fuck Outlook. M365 doesn’t do that though.

          Also the idea that reverse IPs are needed (in practice) when SPF, DKIM and DMARC are in use is insane. I have literally told you my public key and signed the e-mail. It’s me. You don’t need to check the damn PTR!

  • @[email protected]
    link
    fedilink
    English
    410 months ago

    Should I setup DKIM, DMARC, SPF and reverse IP lookup?

    This is no brainer to setup using mailcow. Just need to copy paste the provided TXT values from mailcow ui into your dns entries.

    Mailcow is fantastic and very easy to deploy. I highly recommend it.

  • @[email protected]
    link
    fedilink
    English
    310 months ago

    If your domain will NEVER send e-mail out, you only really need and SPF record to tell other servers to drop e-mail FROM your domain. Even that’s somewhat optional. If you ever plan on sending ANY outbound (you should at very least for the occasional ticket) then do DKIM, DMARC and SPF. The more of these you do, the less likely e-mails FROM your domain are to be flagged as spam.