Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp1153020ybz; Wed, 22 Apr 2020 14:42:02 -0700 (PDT) X-Google-Smtp-Source: APiQypKvVNrIJ/ck1XZTMtWyNVhAh0QfScpFnWmIX4Pmv+ogjDhpdM05Gj6KWJ01f3gEOUVmwvt8 X-Received: by 2002:aa7:cd01:: with SMTP id b1mr519147edw.163.1587591722208; Wed, 22 Apr 2020 14:42:02 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587591722; cv=none; d=google.com; s=arc-20160816; b=zgZvmYf4MIFWDDnCv39spQjxaDeuzqAkzKJyrkwFVN3wnHLvgs8eNv7Gx/B4T7rwKh ODJa2kcGJCVnhcdczU5NaD5+NFHjfNr4xgTt7tNVjmh68t2hk4+kUxY+lRkZEcUKWSNY PZ18AyvnmVDyR7vuVvMnZJKM+vLix7n5/2la95H3AcJR7FrcaS0sGsXKem23WabLfXF3 YB2UqEgAQK1lxKxBvr+5+DMtZ1J3njIQ9y/7Ma9T3ewqdCJzdcKOVlvKg4C5IWPTLj66 SFVdMGnZoChrLl7tCmDwnegYXdm3BavhlB99iMo4XEnCAFUKbmP8p9FC2zBls9jtgZQH CvqA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:references :in-reply-to:message-id:date:subject:cc:to:from:dkim-signature; bh=DENkatVCQ+jpqkBbLef2D+gdKupZek3QYZiIVYQZ1G0=; b=vc6Ikb5NlNT0IskpDx2TE/2YGKZJWs+qUfUfC7U5TR0QHD1L+8ymhcvCJDjxEQISTf /eeIylc65CHHUVu2cwP7fRZi3BgtiTuStCCuESJV3PUFuN7rUGhg0y0a8uqguvu85FDZ 6PupfWcM2PISgiyg1w7ZG6gpZzrA3jMJv8+BNdFAmNE4nOW8j8reWowpbiKnTKmubp3O dwkm2EosA/hT2u9a8/3EpWPYkzDPUZOM0AN2HcDVFgP1av1+QhS66ipjaQsGlJ2mh5LQ irTvtQicq4Xl2irgsLqs9Ug28GClnfFnAJpztt8N+v7Si9C9+JJOr/sdLy17IdQC+jgD sxYQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=ib7AHgJo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id y89si190960edy.357.2020.04.22.14.41.39; Wed, 22 Apr 2020 14:42:02 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b=ib7AHgJo; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726505AbgDVVkg (ORCPT + 99 others); Wed, 22 Apr 2020 17:40:36 -0400 Received: from us-smtp-1.mimecast.com ([205.139.110.61]:34118 "EHLO us-smtp-delivery-1.mimecast.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726467AbgDVVkg (ORCPT ); Wed, 22 Apr 2020 17:40:36 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1587591634; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:in-reply-to:in-reply-to:in-reply-to: references:references:references; bh=DENkatVCQ+jpqkBbLef2D+gdKupZek3QYZiIVYQZ1G0=; b=ib7AHgJokVNjiwloZ55UXRyVewYs/AIDTHP8G6Shfazilb1Riiux0Wn/s/LmWT24YtAeB4 rC7S2L5MsM5wMoAzsviXlVqeXHB4q303FzUeoJBrm+Kd+xJs/LeKPti+UWRczqHG2uyqcU Hlhax6SWF5iTelOn4lRehr64P5toC6Y= Received: from mimecast-mx01.redhat.com (mimecast-mx01.redhat.com [209.132.183.4]) (Using TLS) by relay.mimecast.com with ESMTP id us-mta-56-QxQTvcTBOh6N_kqXIloajg-1; Wed, 22 Apr 2020 17:40:32 -0400 X-MC-Unique: QxQTvcTBOh6N_kqXIloajg-1 Received: from smtp.corp.redhat.com (int-mx05.intmail.prod.int.phx2.redhat.com [10.5.11.15]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 352261B18BC7; Wed, 22 Apr 2020 21:40:31 +0000 (UTC) Received: from madcap2.tricolour.ca (unknown [10.3.128.9]) by smtp.corp.redhat.com (Postfix) with ESMTP id 8F90B5D710; Wed, 22 Apr 2020 21:40:16 +0000 (UTC) From: Richard Guy Briggs To: Linux-Audit Mailing List , LKML , netfilter-devel@vger.kernel.org Cc: Paul Moore , sgrubb@redhat.com, omosnace@redhat.com, fw@strlen.de, twoerner@redhat.com, eparis@parisplace.org, ebiederm@xmission.com, tgraf@infradead.org, Richard Guy Briggs Subject: [PATCH ghak25 v4 2/3] netfilter: add audit table unregister actions Date: Wed, 22 Apr 2020 17:39:29 -0400 Message-Id: In-Reply-To: References: In-Reply-To: References: X-Scanned-By: MIMEDefang 2.79 on 10.5.11.15 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Audit the action of unregistering ebtables and x_tables. See: https://github.com/linux-audit/audit-kernel/issues/44 Signed-off-by: Richard Guy Briggs --- include/linux/audit.h | 1 + kernel/auditsc.c | 5 +++-- net/bridge/netfilter/ebtables.c | 2 ++ net/netfilter/x_tables.c | 2 ++ 4 files changed, 8 insertions(+), 2 deletions(-) diff --git a/include/linux/audit.h b/include/linux/audit.h index 5c7f07a9776d..1a2351508211 100644 --- a/include/linux/audit.h +++ b/include/linux/audit.h @@ -97,6 +97,7 @@ struct audit_ntp_data { enum audit_nfcfgop { AUDIT_XT_OP_REGISTER, AUDIT_XT_OP_REPLACE, + AUDIT_XT_OP_UNREGISTER, }; extern int is_audit_feature_set(int which); diff --git a/kernel/auditsc.c b/kernel/auditsc.c index 705beac0ce29..d281c18d1771 100644 --- a/kernel/auditsc.c +++ b/kernel/auditsc.c @@ -136,8 +136,9 @@ struct audit_nfcfgop_tab { }; const struct audit_nfcfgop_tab audit_nfcfgs[] = { - { AUDIT_XT_OP_REGISTER, "register" }, - { AUDIT_XT_OP_REPLACE, "replace" }, + { AUDIT_XT_OP_REGISTER, "register" }, + { AUDIT_XT_OP_REPLACE, "replace" }, + { AUDIT_XT_OP_UNREGISTER, "unregister" }, }; static int audit_match_perm(struct audit_context *ctx, int mask) diff --git a/net/bridge/netfilter/ebtables.c b/net/bridge/netfilter/ebtables.c index 0a148e68b6e1..4778db5601b0 100644 --- a/net/bridge/netfilter/ebtables.c +++ b/net/bridge/netfilter/ebtables.c @@ -1124,6 +1124,8 @@ static void __ebt_unregister_table(struct net *net, struct ebt_table *table) mutex_lock(&ebt_mutex); list_del(&table->list); mutex_unlock(&ebt_mutex); + audit_log_nfcfg(table->name, AF_BRIDGE, table->private->nentries, + AUDIT_XT_OP_UNREGISTER); EBT_ENTRY_ITERATE(table->private->entries, table->private->entries_size, ebt_cleanup_entry, net, NULL); if (table->private->nentries) diff --git a/net/netfilter/x_tables.c b/net/netfilter/x_tables.c index 8f8c5dbf603d..99a468be4a59 100644 --- a/net/netfilter/x_tables.c +++ b/net/netfilter/x_tables.c @@ -1472,6 +1472,8 @@ void *xt_unregister_table(struct xt_table *table) private = table->private; list_del(&table->list); mutex_unlock(&xt[table->af].mutex); + audit_log_nfcfg(table->name, table->af, private->number, + AUDIT_XT_OP_UNREGISTER); kfree(table); return private; -- 1.8.3.1