From 167315b0fc4486d95a244512c53ebc320dd9c0f3 Mon Sep 17 00:00:00 2001 From: Tomas Barton Date: Sat, 14 Sep 2024 17:41:00 +0200 Subject: [PATCH] Support logging to NFLOG group --- REFERENCE.md | 10 ++++++++++ manifests/inet_filter.pp | 3 ++- manifests/init.pp | 5 +++++ spec/classes/inet_filter_spec.rb | 33 ++++++++++++++++++++++++++++++++ templates/reject_rule.epp | 8 ++++---- 5 files changed, 54 insertions(+), 5 deletions(-) diff --git a/REFERENCE.md b/REFERENCE.md index 1a8f89f6..317094f1 100644 --- a/REFERENCE.md +++ b/REFERENCE.md @@ -168,6 +168,7 @@ The following parameters are available in the `nftables` class: * [`log_prefix`](#-nftables--log_prefix) * [`log_discarded`](#-nftables--log_discarded) * [`log_limit`](#-nftables--log_limit) +* [`log_group`](#-nftables--log_group) * [`reject_with`](#-nftables--reject_with) * [`in_out_conntrack`](#-nftables--in_out_conntrack) * [`in_out_drop_invalid`](#-nftables--in_out_drop_invalid) @@ -328,6 +329,15 @@ disable rate limiting. Default value: `'3/minute burst 5 packets'` +##### `log_group` + +Data type: `Optional[Integer]` + +When specified, the Linux kernel will pass the packet to nfnetlink_log +which will send the log through a netlink socket to the specified group. + +Default value: `undef` + ##### `reject_with` Data type: `Variant[Boolean[false], Pattern[/icmp(v6|x)? type .+|tcp reset/]]` diff --git a/manifests/inet_filter.pp b/manifests/inet_filter.pp index 14d22b05..fdcd81b5 100644 --- a/manifests/inet_filter.pp +++ b/manifests/inet_filter.pp @@ -3,7 +3,8 @@ $_reject_rule = epp('nftables/reject_rule.epp', { 'log_prefix' => sprintf($nftables::log_prefix, { 'chain' => '%s', 'comment' => 'Rejected: ' }), - 'log_limit' => $nftables::log_limit + 'log_limit' => $nftables::log_limit, + 'log_group' => $nftables::log_group, } ) diff --git a/manifests/init.pp b/manifests/init.pp index f1255127..df045ebe 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -72,6 +72,10 @@ # to the rules that log discarded traffic. Set to false to # disable rate limiting. # +# @param log_group +# When specified, the Linux kernel will pass the packet to nfnetlink_log +# which will send the log through a netlink socket to the specified group. +# # @param reject_with # How to discard packets not matching any rule. If `false`, the # fate of the packet will be defined by the chain policy (normally @@ -147,6 +151,7 @@ Hash $rules = {}, Hash $sets = {}, String $log_prefix = '[nftables] %s %s', + Optional[Integer] $log_group = undef, String[1] $nat_table_name = 'nat', Stdlib::Unixpath $inmem_rules_hash_file = '/var/tmp/puppet-nft-memhash', Boolean $log_discarded = true, diff --git a/spec/classes/inet_filter_spec.rb b/spec/classes/inet_filter_spec.rb index ebc999be..1645658d 100644 --- a/spec/classes/inet_filter_spec.rb +++ b/spec/classes/inet_filter_spec.rb @@ -571,6 +571,39 @@ } end + context 'custom log group' do + let(:params) do + { + log_group: 1, + log_limit: '5/minute', + } + end + + it { + expect(subject).to contain_concat__fragment('nftables-inet-filter-chain-INPUT-rule-log_discarded').with( + target: 'nftables-inet-filter-chain-INPUT', + content: %r{^ limit rate 5/minute log prefix "\[nftables\] INPUT Rejected: " group 1$}, + order: '97-nftables-inet-filter-chain-INPUT-rule-log_discarded-b' + ) + } + + it { + expect(subject).to contain_concat__fragment('nftables-inet-filter-chain-OUTPUT-rule-log_discarded').with( + target: 'nftables-inet-filter-chain-OUTPUT', + content: %r{^ limit rate 5/minute log prefix "\[nftables\] OUTPUT Rejected: " group 1$}, + order: '97-nftables-inet-filter-chain-OUTPUT-rule-log_discarded-b' + ) + } + + it { + expect(subject).to contain_concat__fragment('nftables-inet-filter-chain-FORWARD-rule-log_discarded').with( + target: 'nftables-inet-filter-chain-FORWARD', + content: %r{^ limit rate 5/minute log prefix "\[nftables\] FORWARD Rejected: " group 1$}, + order: '97-nftables-inet-filter-chain-FORWARD-rule-log_discarded-b' + ) + } + end + context 'no reject rule, use chain policy without explicit reject' do let(:params) do { diff --git a/templates/reject_rule.epp b/templates/reject_rule.epp index 4a1c9f97..26a7e26c 100644 --- a/templates/reject_rule.epp +++ b/templates/reject_rule.epp @@ -1,5 +1,5 @@ <% if $log_limit { -%> -limit rate <%= $log_limit %> log prefix "<%= $log_prefix %>" flags all counter -<% } else { -%> -log prefix "<%= $log_prefix %>" flags all counter -<% } -%> +limit rate <%= $log_limit %><%= ' ' -%> +<% } -%> log prefix "<%= $log_prefix %>"<% if $log_group { -%> + group <%= $log_group -%> +<% } else { %> flags all counter<% } -%>