Difference between revisions of "Simple ruleset for a workstation"

From nftables wiki
Jump to navigation Jump to search
(remove echo request in IPv6 examples)
(Pages using deprecated source tags)
 
Line 7: Line 7:
For IPv4 only workstation.
For IPv4 only workstation.


<source lang="bash">
<syntaxhighlight lang="bash">
flush ruleset
flush ruleset


Line 21: Line 21:
     }
     }
}
}
</source>
</syntaxhighlight>


= fw6.basic =
= fw6.basic =
Line 27: Line 27:
For IPv6 only workstation.
For IPv6 only workstation.


<source lang="bash">
<syntaxhighlight lang="bash">
flush ruleset
flush ruleset


Line 44: Line 44:
         }
         }
}
}
</source>
</syntaxhighlight>


= fw.inet.basic =
= fw.inet.basic =
Line 50: Line 50:
For dual-stack IPv4/IPv6 workstation.
For dual-stack IPv4/IPv6 workstation.


<source lang="bash">
<syntaxhighlight lang="bash">
flush ruleset
flush ruleset


Line 68: Line 68:
         }
         }
}
}
</source>
</syntaxhighlight>

Latest revision as of 00:51, 9 December 2021

A very simple set of rules that allows you to initiate communications from your workstation to the Internet but restricts any communication initiation to your workstation (that was not initiated by you).

You can load this file with nft -f.

fw.basic

For IPv4 only workstation.

flush ruleset

table ip filter {
     chain input {
          type filter hook input priority 0; policy drop;

          # accept traffic originated from us
          ct state established,related accept

          # accept any localhost traffic
          iif lo accept
     }
}

fw6.basic

For IPv6 only workstation.

flush ruleset

table ip6 filter {
        chain input {
                 type filter hook input priority 0; policy drop;

                 # accept any localhost traffic
                 iif lo accept

                 # accept traffic originated from us
                 ct state established,related accept

                 # accept neighbour discovery otherwise connectivity breaks
                 icmpv6 type { nd-neighbor-solicit, nd-router-advert, nd-neighbor-advert } accept
        }
}

fw.inet.basic

For dual-stack IPv4/IPv6 workstation.

flush ruleset

table inet filter {
        chain input {
                 type filter hook input priority 0; policy drop;

                 # accept any localhost traffic
                 iif lo accept

                 # accept traffic originated from us
                 ct state established,related accept

                 # accept neighbour discovery otherwise IPv6 connectivity breaks
                 icmpv6 type { nd-neighbor-solicit, nd-router-advert, nd-neighbor-advert } accept

        }
}