mirror of
https://gitlab.com/shorewall/code.git
synced 2025-02-08 14:01:47 +01:00
Implement BASIC_FILTERS
Signed-off-by: Tom Eastep <teastep@shorewall.net>
This commit is contained in:
parent
0383ca7de6
commit
2dbcd36a9c
@ -843,6 +843,7 @@ sub initialize( $;$$) {
|
|||||||
TRACK_RULES => undef,
|
TRACK_RULES => undef,
|
||||||
REJECT_ACTION => undef,
|
REJECT_ACTION => undef,
|
||||||
INLINE_MATCHES => undef,
|
INLINE_MATCHES => undef,
|
||||||
|
BASIC_FILTERS => undef,
|
||||||
#
|
#
|
||||||
# Packet Disposition
|
# Packet Disposition
|
||||||
#
|
#
|
||||||
@ -5585,6 +5586,9 @@ sub get_configuration( $$$$$ ) {
|
|||||||
default_yes_no 'CHAIN_SCRIPTS' , 'Yes';
|
default_yes_no 'CHAIN_SCRIPTS' , 'Yes';
|
||||||
default_yes_no 'TRACK_RULES' , '';
|
default_yes_no 'TRACK_RULES' , '';
|
||||||
default_yes_no 'INLINE_MATCHES' , '';
|
default_yes_no 'INLINE_MATCHES' , '';
|
||||||
|
default_yes_no 'BASIC_FILTERS' , '';
|
||||||
|
|
||||||
|
require_capability( 'BASIC_EMATCH', 'BASIC_FILTERS=Yes', 's' ) if $config{BASIC_FILTERS};
|
||||||
|
|
||||||
if ( $val = $config{REJECT_ACTION} ) {
|
if ( $val = $config{REJECT_ACTION} ) {
|
||||||
fatal_error "Invalid Reject Action Name ($val)" unless $val =~ /^[a-zA-Z][\w-]*$/;
|
fatal_error "Invalid Reject Action Name ($val)" unless $val =~ /^[a-zA-Z][\w-]*$/;
|
||||||
|
@ -2512,7 +2512,7 @@ sub process_tc_filter() {
|
|||||||
|
|
||||||
fatal_error 'CLASS must be specified' if $devclass eq '-';
|
fatal_error 'CLASS must be specified' if $devclass eq '-';
|
||||||
|
|
||||||
if ( have_capability 'BASIC_EMATCH' ) {
|
if ( $config{BASIC_FILTERS} ) {
|
||||||
for my $proto ( split_list $protos, 'Protocol' ) {
|
for my $proto ( split_list $protos, 'Protocol' ) {
|
||||||
process_tc_filter2( $devclass, $source, $dest , $proto, $portlist , $sportlist, $tos, $length, $priority );
|
process_tc_filter2( $devclass, $source, $dest , $proto, $portlist , $sportlist, $tos, $length, $priority );
|
||||||
}
|
}
|
||||||
|
@ -120,6 +120,8 @@ ADD_SNAT_ALIASES=No
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -131,6 +131,8 @@ ADD_SNAT_ALIASES=No
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -129,6 +129,8 @@ ADD_SNAT_ALIASES=No
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -132,6 +132,8 @@ ADD_SNAT_ALIASES=No
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -120,6 +120,8 @@ ADD_SNAT_ALIASES=No
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -389,6 +389,30 @@
|
|||||||
</listitem>
|
</listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><emphasis role="bold">BASIC_FILTERS=</emphasis>[<emphasis
|
||||||
|
role="bold">Yes</emphasis>|<emphasis role="bold">No</emphasis>]</term>
|
||||||
|
|
||||||
|
<listitem>
|
||||||
|
<para>Added in Shorewall-4.6.0. When set to <emphasis
|
||||||
|
role="bold">Yes</emphasis>, causes entries in <ulink
|
||||||
|
url="shorewall-tcfilters.html">shorewall-tcfilters(5)</ulink> to
|
||||||
|
generate a basic filter rather than a u32 filter. This setting
|
||||||
|
requires the <firstterm>Basic Ematch</firstterm> capability in your
|
||||||
|
kernel and iptables.</para>
|
||||||
|
|
||||||
|
<note>
|
||||||
|
<para>One of the advantages of basic filters is that ipset matches
|
||||||
|
are supported in newer iproute2 and kernel versions. Because
|
||||||
|
Shorewall cannot reliably detect this capability, use of basic
|
||||||
|
filters is controlled by this option.</para>
|
||||||
|
</note>
|
||||||
|
|
||||||
|
<para>The default value is <emphasis role="bold">No</emphasis> which
|
||||||
|
causes u32 filters to be generated.</para>
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term><emphasis role="bold">BLACKLIST=</emphasis>[{<emphasis
|
<term><emphasis role="bold">BLACKLIST=</emphasis>[{<emphasis
|
||||||
role="bold">ALL</emphasis>|<emphasis
|
role="bold">ALL</emphasis>|<emphasis
|
||||||
|
@ -113,6 +113,8 @@ ACCOUNTING_TABLE=filter
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -113,6 +113,8 @@ ACCOUNTING_TABLE=filter
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -113,6 +113,8 @@ ACCOUNTING_TABLE=filter
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -113,6 +113,8 @@ ACCOUNTING_TABLE=filter
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -113,6 +113,8 @@ ACCOUNTING_TABLE=filter
|
|||||||
|
|
||||||
ADMINISABSENTMINDED=Yes
|
ADMINISABSENTMINDED=Yes
|
||||||
|
|
||||||
|
BASIC_FILTERS=No
|
||||||
|
|
||||||
IGNOREUNKNOWNVARIABLES=No
|
IGNOREUNKNOWNVARIABLES=No
|
||||||
|
|
||||||
AUTOCOMMENT=Yes
|
AUTOCOMMENT=Yes
|
||||||
|
@ -326,6 +326,30 @@
|
|||||||
</listitem>
|
</listitem>
|
||||||
</varlistentry>
|
</varlistentry>
|
||||||
|
|
||||||
|
<varlistentry>
|
||||||
|
<term><emphasis role="bold">BASIC_FILTERS=</emphasis>[<emphasis
|
||||||
|
role="bold">Yes</emphasis>|<emphasis role="bold">No</emphasis>]</term>
|
||||||
|
|
||||||
|
<listitem>
|
||||||
|
<para>Added in Shorewall-4.6.0. When set to <emphasis
|
||||||
|
role="bold">Yes</emphasis>, causes entries in <ulink
|
||||||
|
url="shorewall6-tcfilters.html">shorewall6-tcfilters(5)</ulink> to
|
||||||
|
generate a basic filter rather than a u32 filter. This setting
|
||||||
|
requires the <firstterm>Basic Ematch</firstterm> capability in your
|
||||||
|
kernel and iptables.</para>
|
||||||
|
|
||||||
|
<note>
|
||||||
|
<para>One of the advantages of basic filters is that ipset matches
|
||||||
|
are supported in newer iproute2 and kernel versions. Because
|
||||||
|
Shorewall6 cannot reliably detect this capability, use of basic
|
||||||
|
filters is controlled by this option.</para>
|
||||||
|
</note>
|
||||||
|
|
||||||
|
<para>The default value is No which causes u32 filters to be
|
||||||
|
generated.</para>
|
||||||
|
</listitem>
|
||||||
|
</varlistentry>
|
||||||
|
|
||||||
<varlistentry>
|
<varlistentry>
|
||||||
<term><emphasis role="bold">BLACKLIST=</emphasis>[{<emphasis
|
<term><emphasis role="bold">BLACKLIST=</emphasis>[{<emphasis
|
||||||
role="bold">ALL</emphasis>|<emphasis
|
role="bold">ALL</emphasis>|<emphasis
|
||||||
|
Loading…
Reference in New Issue
Block a user