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.
    • BismarckB Offline
      Bismarck
      last edited by

      @jazzl0ver:

      Hi.

      In case someone needs to specify a port in domain forwarding, here is a patch for /usr/local/pkg/postfix.inc:

      --- postfix.inc.org     2015-10-29 13:59:12.000000000 +0300
      +++ postfix.inc 2015-10-29 14:19:36.000000000 +0300
      @@ -263,10 +263,17 @@
              if (is_array($postfix_domains['row'])) {
                      foreach ($postfix_domains['row'] as $postfix_row) {
                              $relay_domains .= ' ' . $postfix_row['domain'];
      -                       if (!empty($postfix_row['mailserverip']))
      -                               $transport .= $postfix_row['domain'] . " smtp:[" . $postfix_row['mailserverip'] . "]\n";
      +                       if (!empty($postfix_row['mailserverip'])) {
      +                               if (strrpos($postfix_row['mailserverip'], ":") === false) {
      +                                       $transport .= $postfix_row['domain'] . " smtp:[" . $postfix_row['mailserverip'] . "]\n";
      +                               }
      +                               else {
      +                                       list($t_ip, $t_port) = explode(":", $postfix_row['mailserverip']);
      +                                       $transport .= $postfix_row['domain'] . " smtp:[" . $t_ip . "]:" . "$t_port\n";
                                      }
                              }
      +               }
      +       }
              #check cron
              check_cron();
              #check logging
      @@ -787,8 +794,15 @@
                      } else if (substr($key, 0, 12) == "mailserverip" && is_numeric(substr($key, 12))) {
                              if (empty($post['domain' . substr($key, 12)]))
                                      $input_errors[] = "Domain for {$value} cannot be blank.";
      -                       if (!is_ipaddr($value) && !is_hostname($value))
      -                               $input_errors[] = "{$value} is not a valid IP address or host name.";
      +                       if (strrpos($value, ":") === false) {
      +                               if (!is_ipaddr($value) && !is_hostname($value))
      +                                       $input_errors[] = "{$value} is not a valid IP address or host name.";
      +                       }
      +                       else {
      +                               list($t_ip, $t_port) = explode(":", $value);
      +                               if (!is_ipaddr($t_ip) && !is_hostname($t_ip))
      +                                       $input_errors[] = "{$value} is not a valid IP address or host name.";
      +                       }
                      }
              }
       }
      
      

      Thanks jazzl0ver, patch works perfect! :)

      1 Reply Last reply Reply Quote 0
      • L Offline
        LinuxCuba
        last edited by

        En el día de  hoy salio pfsense 2.3.1 y aún nada de postfix forwarder, según la propia web de documentación de pfsense, https://doc.pfsense.org/index.php/2.3_Removed_Packages dice lo siguiente Postfix Forwarder - no package maintainer, not converted, en la lista de paquetes removidos. Por fin para cuando volvemos a tener estos paquetes que tanto nos ayudan y resuelven problemas. Muchas gracias.

        Today came out pfsense 2.3.1 and still nothing forwarder postfix, according to the website of documentation pfsense, https://doc.pfsense.org/index.php/2.3_Removed_Packages reads Postfix Forwarder - no package maintainer, not converted, removed from the list of packages. Finally when we again have these packages that both help us and solve problems. Thank you very much.

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

          @LinuxCuba:

          Postfix Forwarder - no package maintainer, not converted, removed from the list of packages.

          Not true. I've sent the pull request but it's still not verified or something on this direction.

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

          Help a community developer! ;D

          1 Reply Last reply Reply Quote 0
          • H Offline
            hcoin
            last edited by

            So, what's the reason a 'ready to go' pull request for postfix isn't moving ahead?  Did someone in high places just forget?  Perhaps a friendly ping email to correct the impression of no maintainer??

            1 Reply Last reply Reply Quote 0
            • jahonixJ Offline
              jahonix
              last edited by

              Well, maybe the team was just trying to get 2.3.1 out the door and didn't have the time to look at packages?

              1 Reply Last reply Reply Quote 0
              • E Offline
                edirob
                last edited by

                Hey Marcello - I'm still steamed that pfSense didn't make it more obvious that the upgrade to 2.3 was going to destroy my Postfix installation. >:(  I would NEVER have upgraded to 2.3 if I had known that all the work I did to get mail under control was about to be wiped out!  I was so grateful to you for providing the port for pfSense; it worked flawlessly once I figured out how to configure it (that took a long time).  Now my mail system is flooded with crap again every day.  I cannot wait for Postfix to make it back into the 2.3.1 package installer.

                Is there any way to download it directly from you/Github and install it manually into pfSense 2.3.1?  I'm desperate to get my mail back under control.

                Thanks for all your hard work!!

                Rob…

                1 Reply Last reply Reply Quote 0
                • jahonixJ Offline
                  jahonix
                  last edited by

                  @edirob:

                  …pfSense didn't make it more obvious that the upgrade to 2.3 was going to destroy my Postfix installation

                  You mean more than this?

                  Packages

                  The list of available packages in pfSense 2.3.x has been significantly trimmed.  We have removed packages that have been deprecated upstream, no longer have an active maintainer, or were never stable. A few have yet to be converted for Bootstrap and may return if converted. See the 2.3 Removed Packages list for details.

                  But I understand your frustration.

                  1 Reply Last reply Reply Quote 0
                  • L Offline
                    LinuxCuba
                    last edited by

                    @marcelloc:

                    @LinuxCuba:

                    Postfix Forwarder - no package maintainer, not converted, removed from the list of packages.

                    Not true. I've sent the pull request but it's still not verified or something on this direction.

                    No será cierto, pero es lo que informa la web de pfsense https://doc.pfsense.org/index.php/2.3_Removed_Packages
                    en estos momentos en que escribo este post dice así Postfix Forwarder - not converted (pending pull request) .
                    Muchas gracias a la espera de que salga pronto, hay alguna opción para poder instarlo manualmente.

                    It will not be true, but what informs the web of pfsense https://doc.pfsense.org/index.php/2.3_Removed_Packages
                    right now as I write this post so says Postfix Forwarder - not converted (pending pull request).
                    Thank you very much waiting to come out soon, there is an option to manually urge.

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

                      45 pages, sorry but i'm not going to wade through that.

                      Does this do smtp "passthrough" to the internal mail server for when you want to send mail?
                      I installed postfix on our debian server, and i can get incoming mail from outside mail servers go through postfix/spamassassin, and then to our internal server.
                      But the problem comes when you want to send mail from a client, when it connects it cannot do authentication (and ldap is insecure, i don't like it), and it says "relay access denied" - which makes sense due to it not being an open relay.
                      Can this do some kind of passthrough for when doing authentication to go directly to our internal one?

                      1 Reply Last reply Reply Quote 0
                      • kalessinK Offline
                        kalessin
                        last edited by

                        passthrough is a nat/port forward. postfix is a postfix server. mainly to filter spam and that. =)

                        "relay access denied" is a wrongly configured postfix. check http://www.postfix.org/documentation.html .

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

                          @kalessin:

                          passthrough is a nat/port forward. postfix is a postfix server. mainly to filter spam and that. =)

                          "relay access denied" is a wrongly configured postfix. check http://www.postfix.org/documentation.html .

                          yes i know, but doing port forward would make both incoming from client and server go to the internal server, that's not what i want
                          i only want postfix to handle incoming mail from servers outside the network

                          documentation doesn't help either because i don't know what to look for

                          1 Reply Last reply Reply Quote 0
                          • kalessinK Offline
                            kalessin
                            last edited by

                            you should have something like:
                            (internet)<–----->pfsense<------>intranet
                                                              ---(postfix)

                            so basically you came into the thread without reading the whole 45 pages with a problem. and you dont want to read the documentation because you dont know what to look for.
                            why dont you start by expaining nicely:
                            -what you want to do,
                            -which environment you have,
                            -which pf config/version, etc.
                            and what tests you have made. like telneting x port from the 'inside' and telneting the port from the 'outside'  with a nice pastebin link so we all can read about it. also quoting logs is a plus to know what to look for.

                            right now, we are having a conversation on when postfix package will be available upstream.
                            bye,

                            1 Reply Last reply Reply Quote 0
                            • H Offline
                              hcoin
                              last edited by

                              mrbrax: To use postfix for incoming filtering+ store and forward, without using it for lan->wan email, simply configure all users to point their email systems send configuration to some random free port number on the WAN interface-l which you nat to your internal systems.  Allow postfix on pfsense to operate normally, d-natting (port forwarding) 25  and maybe 465 to postfix on pfsense.

                              Also, kindly consider those offering their time to help you here are volunteers, many of whom have taken the time to understand the tools in order to be of service.  PFsense has this package as a frontend on postfix as you know.  You will pay yourself 10 minutes for every one you spend reading the postfix documentation, even though it doesn't seem like it when you're doing the reading.  I hope once you also find success you'll return the favor to help others here.

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

                                @kalessin:

                                you should have something like:
                                (internet)<–----->pfsense<------>intranet
                                                                  ---(postfix)

                                so basically you came into the thread without reading the whole 45 pages with a problem. and you dont want to read the documentation because you dont know what to look for.
                                why dont you start by expaining nicely:
                                -what you want to do,
                                -which environment you have,
                                -which pf config/version, etc.
                                and what tests you have made. like telneting x port from the 'inside' and telneting the port from the 'outside'  with a nice pastebin link so we all can read about it. also quoting logs is a plus to know what to look for.

                                right now, we are having a conversation on when postfix package will be available upstream.
                                bye,

                                forget it, this sounds too complicated anyway. we'll just continue dealing with putting spam manually in the bin

                                @hcoin:

                                mrbrax: To use postfix for incoming filtering+ store and forward, without using it for lan->wan email, simply configure all users to point their email systems send configuration to some random free port number on the WAN interface-l which you nat to your internal systems.  Allow postfix on pfsense to operate normally, d-natting (port forwarding) 25  and maybe 465 to postfix on pfsense.

                                Also, kindly consider those offering their time to help you here are volunteers, many of whom have taken the time to understand the tools in order to be of service.  PFsense has this package as a frontend on postfix as you know.  You will pay yourself 10 minutes for every one you spend reading the postfix documentation, even though it doesn't seem like it when you're doing the reading.  I hope once you also find success you'll return the favor to help others here.

                                As said, i don't know what to look for - for the stuff i want to do, so reading the documentation is useless when i barely know what i want to do in the first place.
                                and changing the configuration for everyone? not happening. if it doesn't work on port 25/587 on one domain it's not worth looking into.

                                What do you mean? consider volunteers?

                                1 Reply Last reply Reply Quote 0
                                • H Offline
                                  hcoin
                                  last edited by

                                  mbrax: You mentioned you only want postfix to handle incoming mail from servers outside the network, yes? That means for all approved clients whether inside the network or not, and servers inside the network you have another answer (maybe inside the network, or outside).  You also mentioned you can't control the server configurations on your clients, so setting up a custom smtp port for approved clients is out.

                                  There is only then one good answer I can see. 
                                  1: Set up postfix on pfsense so that all traffic on all smtp ports is handled by it.  Port forward all smtp ports on lan/wan to localhost, then set up postfix to bind to that interface.

                                  2: Configure postfix's capability to know which systems/clients are authorized to be exempt from security and to forward all email from them to the approved servers without change.

                                  3: Use the fuil screening ability of postfix on everything else, sending approved messages to the internal servers.

                                  For details on how to do that, read here:  http://www.postfix.org/documentation.html,  or, in the alternative, pay someone who has done this before to set it up for you.

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

                                    @hcoin:

                                    mbrax: You mentioned you only want postfix to handle incoming mail from servers outside the network, yes? That means for all approved clients whether inside the network or not, and servers inside the network you have another answer (maybe inside the network, or outside).  You also mentioned you can't control the server configurations on your clients, so setting up a custom smtp port for approved clients is out.

                                    There is only then one good answer I can see. 
                                    1: Set up postfix on pfsense so that all traffic on all smtp ports is handled by it.  Port forward all smtp ports on lan/wan to localhost, then set up postfix to bind to that interface.

                                    2: Configure postfix's capability to know which systems/clients are authorized to be exempt from security and to forward all email from them to the approved servers without change.

                                    3: Use the fuil screening ability of postfix on everything else, sending approved messages to the internal servers.

                                    For details on how to do that, read here:  http://www.postfix.org/documentation.html,  or, in the alternative, pay someone who has done this before to set it up for you.

                                    Yes, the problem lies in that postfix can't authenticate users due to it not having access to the database. That's why i was wondering if it can just forward it to the internal one and have it handle everything instead.

                                    And again, documentation won't help at all here still.

                                    1 Reply Last reply Reply Quote 0
                                    • H Offline
                                      hcoin
                                      last edited by

                                      "Yes, the problem lies in that postfix can't authenticate users due to it not having access to the database. That's why i was wondering if it can just forward it to the internal one and have it handle everything instead.

                                      And again, documentation won't help at all here still."

                                      Kindly notice that indeed it does.  Read here:
                                      http://www.postfix.org/LOCAL_RECIPIENT_README.html

                                      There you will see long experience strongly advises against turning off recipient validation, though it shows how to do that.
                                      When postfix offers validation by ldap, sql, web lookup, text file, SASL, etc. there is a way to do this properly.
                                      Surely you could write a little script on either pfsense cron on on the system that actually does know the recipient list to peel off  a copy then rsync it to pfsense if nothing else.

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

                                        @hcoin:

                                        Kindly notice that indeed it does.  Read here:
                                        http://www.postfix.org/LOCAL_RECIPIENT_README.html

                                        There you will see long experience strongly advises against turning off recipient validation, though it shows how to do that.
                                        When postfix offers validation by ldap, sql, web lookup, text file, SASL, etc. there is a way to do this properly.
                                        Surely you could write a little script on either pfsense cron on on the system that actually does know the recipient list to peel off  a copy then rsync it to pfsense if nothing else.

                                        I still don't think we're on the same page here. Let's say that the postfix server is not able to get authentication information.
                                        I'm only interested in parsing incoming mail from outside servers to check them for spam, nothing else (sending mail etc)

                                        i mean, thanks for helping but it's not really regarding my issue

                                        1 Reply Last reply Reply Quote 0
                                        • kalessinK Offline
                                          kalessin
                                          last edited by

                                          mbrax, thats what for postfix is there for, scan for spam….

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

                                            @kalessin:

                                            mbrax, thats what for postfix is there for, scan for spam….

                                            yes, yes i know

                                            but there's the part of a client using the server to send messages (which i don't want to use at all), and the part of a mail server sending mail to the users inside our mail server

                                            if it's not possible to just literally forward the data to the internal one when it's about clients sending messages and logging in, it won't work with my plan

                                            i don't think my idea comes across with words, so here's a work of art made in mspaint

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