Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    Postfix - antispam and relay package

    Scheduled Pinned Locked Moved pfSense Packages
    855 Posts 136 Posters 1.4m Views 2 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • C Offline
      cmariotti
      last edited by

      I posted a question to the pfSense mailing list and was directed to look at the Postfix relay package. I saw a posting asking if SMTP out was an option, but I didn't see a clear answer to this.

      Let me explain my issue…

      After converting a network of computers to use a fairly popular 3rd party email service (not my decision unfortunately), users are experiencing very odd issues with email (POP and SMTP based). The 3rd party says we should try different ports, increase timeouts, etc…  and they sometimes take days to admit they themselves have an issue (after we have jumped through their hoops).

      One of the issues is email taking a while to be sent out of the network to the 3rd party SMTP servers… in many cases, items sit in Outlook… with recipients complaining that they received multiple copies of the same email.

      My thought was to see if there was an SMTP server that can run on pfSense 2.0? I would like to be able to monitor the queue, etc…  My hope is that the client computers would stop failing/timing out/multiple deliveries and that pfSense would just act as the active sender SMTP server... basically to send out emails from the network directly to the recipient's mailserver... But I need to be able to manage and monitor it easily in real-time and after the fact on specific dates/times to see what is happening with a specific email problem.

      Any advice or suggestions? Does the replay package allow this? Or is it simply for inbound emails only?

      Regards,

      Chuck

      1 Reply Last reply Reply Quote 0
      • marcellocM Offline
        marcelloc
        last edited by

        If you have static ip on your internet connection and if you could include this ip as a Spf record on your internet dns domain, then you could configure your smtp client option to this package.

        I suggest you to change pop3 to imap. It's much better.

        Smtp auth with SASL is not working on current version because a missing dependencie in cyrrus-SASL package.

        Treinamentos de Elite: http://sys-squad.com

        Help a community developer! ;D

        1 Reply Last reply Reply Quote 0
        • C Offline
          cmariotti
          last edited by

          So basically just install the package, create spf record for the public IP and point the clients to use the internal firewall IP as their SMTP server. That sound right?

          1 Reply Last reply Reply Quote 0
          • marcellocM Offline
            marcelloc
            last edited by

            Yes. That's it.

            On package, try this configurarion:

            • listen only in localhost and lan

            • disable postscreen

            • choose basic header verification

            • do not check Helo valid hostname

            • at acls, include your internal network on client access list

            Treinamentos de Elite: http://sys-squad.com

            Help a community developer! ;D

            1 Reply Last reply Reply Quote 0
            • T Offline
              timreichhart
              last edited by

              does this package have a option for users to manage there whitelist/blacklist or any other options they need to configure under there own login page?

              1 Reply Last reply Reply Quote 0
              • marcellocM Offline
                marcelloc
                last edited by

                This package act as a relay for internal smtp server. Postfix on pfsense has no client accounts or user page.

                Treinamentos de Elite: http://sys-squad.com

                Help a community developer! ;D

                1 Reply Last reply Reply Quote 0
                • D Offline
                  darklogic
                  last edited by

                  marcelloc,

                  Any word on the postfix AV and anti-spam add-on? Your latest release fixed all the issues I was having. Great package. I am excited to see what will come next.

                  Thanks Again,

                  1 Reply Last reply Reply Quote 0
                  • marcellocM Offline
                    marcelloc
                    last edited by

                    The upcoming version 2.3 improves maillog Database and fixes some minor bugs.

                    Mailscanner maybe released in december.

                    Treinamentos de Elite: http://sys-squad.com

                    Help a community developer! ;D

                    1 Reply Last reply Reply Quote 0
                    • D Offline
                      darklogic
                      last edited by

                      That is excellent news. Keep up the great work.

                      Thanks Again,

                      MDP

                      1 Reply Last reply Reply Quote 0
                      • M Offline
                        mince69meat
                        last edited by

                        @marcelloc:

                        Hi all,

                        Postfix compilation on x64 now includes cyrus-SASL2 and TLS.

                        who need or want to test it, reinstall or remove/install postfix package.

                        No changes in gui for this option. Include all your SASL and/or TLS config in custom main.cf options

                        att,
                        Marcello Coutinho

                        Hi Marcello and everyone else

                        can anyone help me out I would like to send mail from internal to exturnal though this fantastic packege but can't get passed "smtpd_recipient_restrictions = reject_unauth_destination" have tried "smtpd_recipient_restrictions = permit_mynetworks reject_unauth_destination" in custom but it will not override the defaults, tried SASL but don't know how to install it on pfsense, have spent a week doing this before postting so sorry if its in a post elswere, any help or point to any posts that could help or how to override the default would be grateful

                        Mick

                        1 Reply Last reply Reply Quote 0
                        • marcellocM Offline
                          marcelloc
                          last edited by

                          mince69meat,

                          I'ts included in upcoming version 2.3. I'm finished coding and now I'm testing before publishing.

                          The not so good news is that 2.2 sqlite database is not compatible with 2.3.

                          Treinamentos de Elite: http://sys-squad.com

                          Help a community developer! ;D

                          1 Reply Last reply Reply Quote 0
                          • M Offline
                            mince69meat
                            last edited by

                            @marcelloc:

                            mince69meat,

                            I'ts included in upcoming version 2.3. I'm finished coding and now I'm testing before publishing.

                            The not so good news is that 2.2 sqlite database is not compatible with 2.3.

                            Love you man, im up all though the night as I was just about to build a bsd VM to get around the problem till your fantastic package was more.. if you want I have a fresh PF without postfix just finnished installing if you need a tester :-) before release. dont know what to do now wait or carry on with the bsd VM, dont know if I can help any more than being a user tester but know a little about coding and postfix, great work - respect

                            1 Reply Last reply Reply Quote 0
                            • marcellocM Offline
                              marcelloc
                              last edited by

                              to patch 2.2 to accept mynetworks,BACKUP /usr/local/pkg/postfix.inc to /root dir and then edit /usr/local/pkg/postfix.inc to modify postfix declaration.

                              Do not backup postfix.inc file on same dir, it will break your boot.

                              look for 'postscreen_access_list=' and include permit_mynetworks:
                              postscreen_access_list = permit_mynetworks,\n\t\t\tcidr:/usr/local/etc/postfix/cal_cidr\n"

                              look for 'smtpd_recipient_restrictions=' (02 times in file) and include permit_mynetworks
                              smtpd_recipient_restrictions = permit_mynetworks,reject_unauth_destination,

                              save file, Go to custom options in gui, declare 'mynetworks' list save config and check main.cf file in view configuration tab

                              
                              Examples:
                              mynetworks = 127.0.0.0/8 168.100.189.0/28
                              mynetworks = !192.168.0.1, 192.168.0.0/28
                              mynetworks = 127.0.0.0/8 168.100.189.0/28 [::1]/128 [2001:240:587::]/64
                              "mynetworks_style = host"
                              "mynetworks_style = subnet" 
                              "mynetworks_style = class"
                              
                              

                              reference: http://www.postfix.org/postconf.5.html

                              Treinamentos de Elite: http://sys-squad.com

                              Help a community developer! ;D

                              1 Reply Last reply Reply Quote 0
                              • M Offline
                                mince69meat
                                last edited by

                                @marcelloc:

                                to patch 2.2 to accept mynetworks,BACKUP /usr/local/pkg/postfix.inc to /root dir and then edit /usr/local/pkg/postfix.inc to modify postfix declaration.

                                Do not backup postfix.inc file on same dir, it will break your boot.

                                look for 'postscreen_access_list=' and include permit_mynetworks:
                                postscreen_access_list = permit_mynetworks,\n\t\t\tcidr:/usr/local/etc/postfix/cal_cidr\n"

                                look for 'smtpd_recipient_restrictions=' (02 times in file) and include permit_mynetworks
                                smtpd_recipient_restrictions = permit_mynetworks,reject_unauth_destination,

                                save file, Go to custom options in gui, declare 'mynetworks' list save config and check main.cf file in view configuration tab

                                
                                Examples:
                                mynetworks = 127.0.0.0/8 168.100.189.0/28
                                mynetworks = !192.168.0.1, 192.168.0.0/28
                                mynetworks = 127.0.0.0/8 168.100.189.0/28 [::1]/128 [2001:240:587::]/64
                                "mynetworks_style = host"
                                "mynetworks_style = subnet" 
                                "mynetworks_style = class"
                                
                                

                                reference: http://www.postfix.org/postconf.5.html

                                Hi marcelloc, knew to edit postfix.inc (would have missed postscreen_access_list, thanks), did not want to edit this file as I'm worried about braking the package on updates, can you comfirm this will not brake anything on update? was looking for a way to override just by the "custom main.cf options" to keep the package as you made it :-) and not cause problems on upgrades as I have boken things in the past by doing things my way and not the matainers way lol

                                some info for you, installing postfix on x64 I see that cyrus-sasl-2.1.25_1.tbz is installed as dependencie but on a x86 system it is not installed, don't know if you know that, also for the rest of the community pkg_add will not install it properly on x86 :-(

                                nice work and brill post about adding mynetworks, should help more on here out than just me

                                respect

                                1 Reply Last reply Reply Quote 0
                                • marcellocM Offline
                                  marcelloc
                                  last edited by

                                  The postfix in 32 bit version is not compilled every day just like 64bits. This may be something related to 2.1 working. The cyrrus-SASL has a missing dependencie that was not fixed yet, So you can only use unauth outgoing smtp for now.

                                  About the postfix.inc, if you do the way I described, it will not broke any package update. Just insert the update on file and do not remove anything.
                                  Package update will update postfix.inc
                                  Do it with caution.
                                  I'll send a line to core team asking 32bits updates.
                                  Postix is on 2.8.7 on 64 bits and 2.8.5 on 32.

                                  Treinamentos de Elite: http://sys-squad.com

                                  Help a community developer! ;D

                                  1 Reply Last reply Reply Quote 0
                                  • M Offline
                                    mince69meat
                                    last edited by

                                    How would you use unauth outgoing smtp and get passed the "reject_unauth_destination" or is the only wayto  edit /usr/local/pkg/postfix.inc as you said a few posts back?

                                    1 Reply Last reply Reply Quote 0
                                    • M Offline
                                      mince69meat
                                      last edited by

                                      @marcelloc:

                                      to patch 2.2 to accept mynetworks,BACKUP /usr/local/pkg/postfix.inc to /root dir and then edit /usr/local/pkg/postfix.inc to modify postfix declaration.

                                      Do not backup postfix.inc file on same dir, it will break your boot.

                                      look for 'postscreen_access_list=' and include permit_mynetworks:
                                      postscreen_access_list = permit_mynetworks,\n\t\t\tcidr:/usr/local/etc/postfix/cal_cidr\n"

                                      look for 'smtpd_recipient_restrictions=' (02 times in file) and include permit_mynetworks
                                      smtpd_recipient_restrictions = permit_mynetworks,reject_unauth_destination,

                                      save file, Go to custom options in gui, declare 'mynetworks' list save config and check main.cf file in view configuration tab

                                      
                                      Examples:
                                      mynetworks = 127.0.0.0/8 168.100.189.0/28
                                      mynetworks = !192.168.0.1, 192.168.0.0/28
                                      mynetworks = 127.0.0.0/8 168.100.189.0/28 [::1]/128 [2001:240:587::]/64
                                      "mynetworks_style = host"
                                      "mynetworks_style = subnet" 
                                      "mynetworks_style = class"
                                      
                                      

                                      reference: http://www.postfix.org/postconf.5.html

                                      is this line right the middle part (tcidr) just don't seem right?
                                      postscreen_access_list = permit_mynetworks,\n\t\t\tcidr:/usr/local/etc/postfix/cal_cidr\n"

                                      1 Reply Last reply Reply Quote 0
                                      • M Offline
                                        mince69meat
                                        last edited by

                                        hope someone can help with this one, have multi wan and want postfix to send mail out of non default wan gateway, tried smtp_bind_address = xxx.xxx.xxx.xxx and it works sendding out but then incoming mail will not forward to internal mail server, any hint want to try either on pf firewall or postfix would be great

                                        Mince

                                        1 Reply Last reply Reply Quote 0
                                        • marcellocM Offline
                                          marcelloc
                                          last edited by

                                          Did you created a wan rule to accept incoming traffic on this ip?

                                          Another way to do it is listening postfix on loopback and then create inbound and outbound nat to your ip aliases or carp.

                                          is this line right the middle part (tcidr) just don't seem right?
                                          postscreen_access_list = permit_mynetworks,\n\t\t\tcidr:/usr/local/etc/postfix/cal_cidr\n"

                                          Just include the 'permit_mynetworks,' at The beginning of postscreen_access_list.

                                          Treinamentos de Elite: http://sys-squad.com

                                          Help a community developer! ;D

                                          1 Reply Last reply Reply Quote 0
                                          • marcellocM Offline
                                            marcelloc
                                            last edited by

                                            Hi everybody,

                                            I've just published package version 2.3 with many improvements. check first post for screen shots

                                            main improvements:

                                            • sqlite export option to allow multiple box admins to search mail in only one box

                                            • new database structure

                                            • queue gui tab

                                            • more search options

                                            • wildcard support in search

                                            • postfix version 2.8.7 for x64bits

                                            • widget options to prevent memory limit reach in dashboard

                                            • apply permissions to non adminis users, so they can only search mail or view queue

                                            • include mynetworks to allow internal clients/hosts to send mail through postfix forwarder

                                            Treinamentos de Elite: http://sys-squad.com

                                            Help a community developer! ;D

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.