iptables Masquerade leave out some local packet?

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
1
down vote

favorite












In openwrt i have config lan forward to wan with masqenabled. And my lan network is 192.168.100.0/24. when some pc ping with other network ip e.g: 192.168.1.15, tcpdump will get some local packet in wan, which cause wan close. (my wan is a 3g modem).



openwrt firewall config:



config defaults
option syn_flood '1'
option input 'DROP'
option output 'DROP'
option forward 'DROP'

config zone
option name 'lan'
list network 'lan'
option input 'ACCEPT'
option forward 'DROP'
option output 'ACCEPT'

config zone
option name 'cellular'
list network 'cellular'
option input 'DROP'
option forward 'DROP'
option output 'ACCEPT'
option masq '1'
option mtu_fix '1'

config forwarding
option src 'lan'
option dest 'cellular'


When pc in lan exec:



 ping -I 192.168.1.15 114.114.114.114


I can catch some invaild packet in ppp



 tcpdump -i 3g-cellular -s 0 -w a.pcap


enter image description here



iptables -t nat -L -v:



Chain POSTROUTING (policy ACCEPT 119 packets, 7439 bytes)
pkts bytes target prot opt in out source destination
337 24011 zone_wan_postrouting all -- any 3g-cellular anywhere anywhere /* !fw3 */

Chain zone_wan_postrouting
pkts bytes target prot opt in out source destination
337 24011 MASQUERADE all -- any any anywhere anywhere /* !fw3 */









share|improve this question



























    up vote
    1
    down vote

    favorite












    In openwrt i have config lan forward to wan with masqenabled. And my lan network is 192.168.100.0/24. when some pc ping with other network ip e.g: 192.168.1.15, tcpdump will get some local packet in wan, which cause wan close. (my wan is a 3g modem).



    openwrt firewall config:



    config defaults
    option syn_flood '1'
    option input 'DROP'
    option output 'DROP'
    option forward 'DROP'

    config zone
    option name 'lan'
    list network 'lan'
    option input 'ACCEPT'
    option forward 'DROP'
    option output 'ACCEPT'

    config zone
    option name 'cellular'
    list network 'cellular'
    option input 'DROP'
    option forward 'DROP'
    option output 'ACCEPT'
    option masq '1'
    option mtu_fix '1'

    config forwarding
    option src 'lan'
    option dest 'cellular'


    When pc in lan exec:



     ping -I 192.168.1.15 114.114.114.114


    I can catch some invaild packet in ppp



     tcpdump -i 3g-cellular -s 0 -w a.pcap


    enter image description here



    iptables -t nat -L -v:



    Chain POSTROUTING (policy ACCEPT 119 packets, 7439 bytes)
    pkts bytes target prot opt in out source destination
    337 24011 zone_wan_postrouting all -- any 3g-cellular anywhere anywhere /* !fw3 */

    Chain zone_wan_postrouting
    pkts bytes target prot opt in out source destination
    337 24011 MASQUERADE all -- any any anywhere anywhere /* !fw3 */









    share|improve this question

























      up vote
      1
      down vote

      favorite









      up vote
      1
      down vote

      favorite











      In openwrt i have config lan forward to wan with masqenabled. And my lan network is 192.168.100.0/24. when some pc ping with other network ip e.g: 192.168.1.15, tcpdump will get some local packet in wan, which cause wan close. (my wan is a 3g modem).



      openwrt firewall config:



      config defaults
      option syn_flood '1'
      option input 'DROP'
      option output 'DROP'
      option forward 'DROP'

      config zone
      option name 'lan'
      list network 'lan'
      option input 'ACCEPT'
      option forward 'DROP'
      option output 'ACCEPT'

      config zone
      option name 'cellular'
      list network 'cellular'
      option input 'DROP'
      option forward 'DROP'
      option output 'ACCEPT'
      option masq '1'
      option mtu_fix '1'

      config forwarding
      option src 'lan'
      option dest 'cellular'


      When pc in lan exec:



       ping -I 192.168.1.15 114.114.114.114


      I can catch some invaild packet in ppp



       tcpdump -i 3g-cellular -s 0 -w a.pcap


      enter image description here



      iptables -t nat -L -v:



      Chain POSTROUTING (policy ACCEPT 119 packets, 7439 bytes)
      pkts bytes target prot opt in out source destination
      337 24011 zone_wan_postrouting all -- any 3g-cellular anywhere anywhere /* !fw3 */

      Chain zone_wan_postrouting
      pkts bytes target prot opt in out source destination
      337 24011 MASQUERADE all -- any any anywhere anywhere /* !fw3 */









      share|improve this question















      In openwrt i have config lan forward to wan with masqenabled. And my lan network is 192.168.100.0/24. when some pc ping with other network ip e.g: 192.168.1.15, tcpdump will get some local packet in wan, which cause wan close. (my wan is a 3g modem).



      openwrt firewall config:



      config defaults
      option syn_flood '1'
      option input 'DROP'
      option output 'DROP'
      option forward 'DROP'

      config zone
      option name 'lan'
      list network 'lan'
      option input 'ACCEPT'
      option forward 'DROP'
      option output 'ACCEPT'

      config zone
      option name 'cellular'
      list network 'cellular'
      option input 'DROP'
      option forward 'DROP'
      option output 'ACCEPT'
      option masq '1'
      option mtu_fix '1'

      config forwarding
      option src 'lan'
      option dest 'cellular'


      When pc in lan exec:



       ping -I 192.168.1.15 114.114.114.114


      I can catch some invaild packet in ppp



       tcpdump -i 3g-cellular -s 0 -w a.pcap


      enter image description here



      iptables -t nat -L -v:



      Chain POSTROUTING (policy ACCEPT 119 packets, 7439 bytes)
      pkts bytes target prot opt in out source destination
      337 24011 zone_wan_postrouting all -- any 3g-cellular anywhere anywhere /* !fw3 */

      Chain zone_wan_postrouting
      pkts bytes target prot opt in out source destination
      337 24011 MASQUERADE all -- any any anywhere anywhere /* !fw3 */






      linux iptables openwrt netfilter






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Nov 30 at 15:40

























      asked Nov 30 at 9:01









      jianxi sun

      235




      235




















          1 Answer
          1






          active

          oldest

          votes

















          up vote
          0
          down vote













          In other words, the openwrt firewall seems to only NAT packets coming from its own LAN. So probably the iptables rule has additional restriction on the source.



          You can verify this by inspecting all iptables rules your current firewall configuration generates (with iptables -S etc.)



          As a workaround, you can modify the iptables NAT rule directly into a variant without the source filter.



          I don't know how to change the openwrt firewall configuration so it produces the iptables rules you want. Possibly the OpenWRT community will know.



          Edit



          Example for a condition where not all packets will end up on zone_wan_postrouting, from an existing OpenWRT firewall configuration:



          # iptables -S -t nat
          ...
          -A POSTROUTING -j delegate_postrouting
          -A delegate_postrouting -m comment --comment "user chain for postrouting" -j postrouting_rule
          -A delegate_postrouting -o br-wan -j zone_wan_postrouting
          -A delegate_postrouting -o br-client -j zone_client_postrouting
          -A delegate_postrouting -o local-node -j zone_local_node_postrouting
          ...
          -A zone_wan_postrouting -m comment --comment "user chain for postrouting" -j postrouting_wan_rule
          -A zone_wan_postrouting -j MASQUERADE
          ...


          So as you can see, the chain POSTROUTING jumps (-j) to delegate_postrouting, there it checks if the packet has an outgoing interface of br-wan, and in that case it jumps to zone_wan_postrouting, where it unconditionally masquerades this packet. Other outgoing interfaces (br-client, local-node) are forwarded to different chains.



          So the condition is outgoing interface of br-wan. It's easy to add other conditions to that, like some source or destination range:



          -A delegate_postrouting -o br-wan -s 192.168.100.0/24 -j zone_wan_postrouting


          or even more complex ones with packet marks, protocols, ports, and lots of other stuff.



          So without actually looking at all your iptables rules, we won't know. Maybe indeed all packets go this way, and the problem is elsewhere. Maybe there's an extra condition that doesn't show up in iptables -L. Maybe not.






          share|improve this answer






















          • iptables -t nat -L -v, masq will nat all packet get in from any nic.
            – jianxi sun
            Nov 30 at 15:38










          • iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
            – dirkt
            Nov 30 at 15:45










          • I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
            – jianxi sun
            Dec 1 at 5:30










          Your Answer








          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "106"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f485098%2fiptables-masquerade-leave-out-some-local-packet%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes








          up vote
          0
          down vote













          In other words, the openwrt firewall seems to only NAT packets coming from its own LAN. So probably the iptables rule has additional restriction on the source.



          You can verify this by inspecting all iptables rules your current firewall configuration generates (with iptables -S etc.)



          As a workaround, you can modify the iptables NAT rule directly into a variant without the source filter.



          I don't know how to change the openwrt firewall configuration so it produces the iptables rules you want. Possibly the OpenWRT community will know.



          Edit



          Example for a condition where not all packets will end up on zone_wan_postrouting, from an existing OpenWRT firewall configuration:



          # iptables -S -t nat
          ...
          -A POSTROUTING -j delegate_postrouting
          -A delegate_postrouting -m comment --comment "user chain for postrouting" -j postrouting_rule
          -A delegate_postrouting -o br-wan -j zone_wan_postrouting
          -A delegate_postrouting -o br-client -j zone_client_postrouting
          -A delegate_postrouting -o local-node -j zone_local_node_postrouting
          ...
          -A zone_wan_postrouting -m comment --comment "user chain for postrouting" -j postrouting_wan_rule
          -A zone_wan_postrouting -j MASQUERADE
          ...


          So as you can see, the chain POSTROUTING jumps (-j) to delegate_postrouting, there it checks if the packet has an outgoing interface of br-wan, and in that case it jumps to zone_wan_postrouting, where it unconditionally masquerades this packet. Other outgoing interfaces (br-client, local-node) are forwarded to different chains.



          So the condition is outgoing interface of br-wan. It's easy to add other conditions to that, like some source or destination range:



          -A delegate_postrouting -o br-wan -s 192.168.100.0/24 -j zone_wan_postrouting


          or even more complex ones with packet marks, protocols, ports, and lots of other stuff.



          So without actually looking at all your iptables rules, we won't know. Maybe indeed all packets go this way, and the problem is elsewhere. Maybe there's an extra condition that doesn't show up in iptables -L. Maybe not.






          share|improve this answer






















          • iptables -t nat -L -v, masq will nat all packet get in from any nic.
            – jianxi sun
            Nov 30 at 15:38










          • iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
            – dirkt
            Nov 30 at 15:45










          • I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
            – jianxi sun
            Dec 1 at 5:30














          up vote
          0
          down vote













          In other words, the openwrt firewall seems to only NAT packets coming from its own LAN. So probably the iptables rule has additional restriction on the source.



          You can verify this by inspecting all iptables rules your current firewall configuration generates (with iptables -S etc.)



          As a workaround, you can modify the iptables NAT rule directly into a variant without the source filter.



          I don't know how to change the openwrt firewall configuration so it produces the iptables rules you want. Possibly the OpenWRT community will know.



          Edit



          Example for a condition where not all packets will end up on zone_wan_postrouting, from an existing OpenWRT firewall configuration:



          # iptables -S -t nat
          ...
          -A POSTROUTING -j delegate_postrouting
          -A delegate_postrouting -m comment --comment "user chain for postrouting" -j postrouting_rule
          -A delegate_postrouting -o br-wan -j zone_wan_postrouting
          -A delegate_postrouting -o br-client -j zone_client_postrouting
          -A delegate_postrouting -o local-node -j zone_local_node_postrouting
          ...
          -A zone_wan_postrouting -m comment --comment "user chain for postrouting" -j postrouting_wan_rule
          -A zone_wan_postrouting -j MASQUERADE
          ...


          So as you can see, the chain POSTROUTING jumps (-j) to delegate_postrouting, there it checks if the packet has an outgoing interface of br-wan, and in that case it jumps to zone_wan_postrouting, where it unconditionally masquerades this packet. Other outgoing interfaces (br-client, local-node) are forwarded to different chains.



          So the condition is outgoing interface of br-wan. It's easy to add other conditions to that, like some source or destination range:



          -A delegate_postrouting -o br-wan -s 192.168.100.0/24 -j zone_wan_postrouting


          or even more complex ones with packet marks, protocols, ports, and lots of other stuff.



          So without actually looking at all your iptables rules, we won't know. Maybe indeed all packets go this way, and the problem is elsewhere. Maybe there's an extra condition that doesn't show up in iptables -L. Maybe not.






          share|improve this answer






















          • iptables -t nat -L -v, masq will nat all packet get in from any nic.
            – jianxi sun
            Nov 30 at 15:38










          • iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
            – dirkt
            Nov 30 at 15:45










          • I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
            – jianxi sun
            Dec 1 at 5:30












          up vote
          0
          down vote










          up vote
          0
          down vote









          In other words, the openwrt firewall seems to only NAT packets coming from its own LAN. So probably the iptables rule has additional restriction on the source.



          You can verify this by inspecting all iptables rules your current firewall configuration generates (with iptables -S etc.)



          As a workaround, you can modify the iptables NAT rule directly into a variant without the source filter.



          I don't know how to change the openwrt firewall configuration so it produces the iptables rules you want. Possibly the OpenWRT community will know.



          Edit



          Example for a condition where not all packets will end up on zone_wan_postrouting, from an existing OpenWRT firewall configuration:



          # iptables -S -t nat
          ...
          -A POSTROUTING -j delegate_postrouting
          -A delegate_postrouting -m comment --comment "user chain for postrouting" -j postrouting_rule
          -A delegate_postrouting -o br-wan -j zone_wan_postrouting
          -A delegate_postrouting -o br-client -j zone_client_postrouting
          -A delegate_postrouting -o local-node -j zone_local_node_postrouting
          ...
          -A zone_wan_postrouting -m comment --comment "user chain for postrouting" -j postrouting_wan_rule
          -A zone_wan_postrouting -j MASQUERADE
          ...


          So as you can see, the chain POSTROUTING jumps (-j) to delegate_postrouting, there it checks if the packet has an outgoing interface of br-wan, and in that case it jumps to zone_wan_postrouting, where it unconditionally masquerades this packet. Other outgoing interfaces (br-client, local-node) are forwarded to different chains.



          So the condition is outgoing interface of br-wan. It's easy to add other conditions to that, like some source or destination range:



          -A delegate_postrouting -o br-wan -s 192.168.100.0/24 -j zone_wan_postrouting


          or even more complex ones with packet marks, protocols, ports, and lots of other stuff.



          So without actually looking at all your iptables rules, we won't know. Maybe indeed all packets go this way, and the problem is elsewhere. Maybe there's an extra condition that doesn't show up in iptables -L. Maybe not.






          share|improve this answer














          In other words, the openwrt firewall seems to only NAT packets coming from its own LAN. So probably the iptables rule has additional restriction on the source.



          You can verify this by inspecting all iptables rules your current firewall configuration generates (with iptables -S etc.)



          As a workaround, you can modify the iptables NAT rule directly into a variant without the source filter.



          I don't know how to change the openwrt firewall configuration so it produces the iptables rules you want. Possibly the OpenWRT community will know.



          Edit



          Example for a condition where not all packets will end up on zone_wan_postrouting, from an existing OpenWRT firewall configuration:



          # iptables -S -t nat
          ...
          -A POSTROUTING -j delegate_postrouting
          -A delegate_postrouting -m comment --comment "user chain for postrouting" -j postrouting_rule
          -A delegate_postrouting -o br-wan -j zone_wan_postrouting
          -A delegate_postrouting -o br-client -j zone_client_postrouting
          -A delegate_postrouting -o local-node -j zone_local_node_postrouting
          ...
          -A zone_wan_postrouting -m comment --comment "user chain for postrouting" -j postrouting_wan_rule
          -A zone_wan_postrouting -j MASQUERADE
          ...


          So as you can see, the chain POSTROUTING jumps (-j) to delegate_postrouting, there it checks if the packet has an outgoing interface of br-wan, and in that case it jumps to zone_wan_postrouting, where it unconditionally masquerades this packet. Other outgoing interfaces (br-client, local-node) are forwarded to different chains.



          So the condition is outgoing interface of br-wan. It's easy to add other conditions to that, like some source or destination range:



          -A delegate_postrouting -o br-wan -s 192.168.100.0/24 -j zone_wan_postrouting


          or even more complex ones with packet marks, protocols, ports, and lots of other stuff.



          So without actually looking at all your iptables rules, we won't know. Maybe indeed all packets go this way, and the problem is elsewhere. Maybe there's an extra condition that doesn't show up in iptables -L. Maybe not.







          share|improve this answer














          share|improve this answer



          share|improve this answer








          edited Dec 1 at 13:06

























          answered Nov 30 at 10:14









          dirkt

          16.4k21335




          16.4k21335











          • iptables -t nat -L -v, masq will nat all packet get in from any nic.
            – jianxi sun
            Nov 30 at 15:38










          • iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
            – dirkt
            Nov 30 at 15:45










          • I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
            – jianxi sun
            Dec 1 at 5:30
















          • iptables -t nat -L -v, masq will nat all packet get in from any nic.
            – jianxi sun
            Nov 30 at 15:38










          • iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
            – dirkt
            Nov 30 at 15:45










          • I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
            – jianxi sun
            Dec 1 at 5:30















          iptables -t nat -L -v, masq will nat all packet get in from any nic.
          – jianxi sun
          Nov 30 at 15:38




          iptables -t nat -L -v, masq will nat all packet get in from any nic.
          – jianxi sun
          Nov 30 at 15:38












          iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
          – dirkt
          Nov 30 at 15:45




          iptables -L doesn't always list all conditions, please use -S. Also, you'll have to check all rules, not all packets will end up in chain zone_wan_postrouting, and the filter may be in the rules leading up to this chain. Yes, there are probably many rules, I know. You still have to work through them.
          – dirkt
          Nov 30 at 15:45












          I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
          – jianxi sun
          Dec 1 at 5:30




          I think all packet will get in nat postrouting. What's the meaning of not all packets will end up in chain nat postrouting? Please give an example of packet that will not pass NAT POSTROUTING. tks.
          – jianxi sun
          Dec 1 at 5:30

















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.





          Some of your past answers have not been well-received, and you're in danger of being blocked from answering.


          Please pay close attention to the following guidance:


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f485098%2fiptables-masquerade-leave-out-some-local-packet%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown






          Popular posts from this blog

          How to check contact read email or not when send email to Individual?

          How many registers does an x86_64 CPU actually have?

          Nur Jahan