Received: by 2002:a25:e7d8:0:0:0:0:0 with SMTP id e207csp4214085ybh; Tue, 17 Mar 2020 14:34:08 -0700 (PDT) X-Google-Smtp-Source: ADFU+vudt+MLv1iMJWUWf4/dfDGinqT6KnfLjcoqK5ZzLrWRVeKsWBnOLnsG/h0/6XVh491XyOMT X-Received: by 2002:a9d:7a4e:: with SMTP id z14mr1237273otm.78.1584480848717; Tue, 17 Mar 2020 14:34:08 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1584480848; cv=none; d=google.com; s=arc-20160816; b=sQsbK2gyqc5WZF288DecZD6dlFFZ+2uRY9NIj6SLBor6f+5NFti/46SEAqazhcweJb 5kj4p+Fl+I3JB/Jpv3Qx/Uj9NtSJFsPOReGnyf1n9BTNlIJ0bOw9RUG5w6+dt4ZfMZKH /U+H0YtOdfgk9z+dXElLeK0bgLLlY7iUt4YPAPng8qSL71+8L5rXAFD17JScLhnK+HiQ xJu49fXlMO3yTSHwc849IEr1HsC+r5zWpYdqg9R4kLLM/BvhYlYnZtiAx66WKA0PxSW3 HNecr0ACvSW5nyptD5Vss6ui1I+0Hd4whAJuG/OpOJVpKVMK31Y1m7LtRQRVCoOoxYyq njRg== 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=ayEqZx2f8JmdXf64atk8+6eayXgF695pjKzYuKwjbTc=; b=aTr824MTLCHwIzAARr76CHOMsIUZ/bZN9k9g/hQxYjbB7TBHtsYUwUasJbiuzoVFvo vFgKwmpR027OQk7wrjoRjcqKLLcSMq3OxU2QTCNgS/re134t2PV56HuPiseJwA2UYrA5 HPWXWmurDV32UB+veza5xDYe9N/KnBiwa25BF2McsAkS4oJ1LH5zWud2lIVaSFWQKFfD j8we51Y+7JQVP7X130nCcJOplXPkp9QT6T0x7liBT/N9byLKUGW1Euy0nMZArTwx6gfy AqH1Av6uegQD5AarXzFIdp1VZfH96uczX89FyzdTEyG6hPALtOgeUtFOO088UE/3cha5 pN/g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="huXxdi/f"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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. [209.132.180.67]) by mx.google.com with ESMTP id s1si2293784oij.237.2020.03.17.14.33.55; Tue, 17 Mar 2020 14:34:08 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@redhat.com header.s=mimecast20190719 header.b="huXxdi/f"; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 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 S1726987AbgCQVbi (ORCPT + 99 others); Tue, 17 Mar 2020 17:31:38 -0400 Received: from us-smtp-delivery-74.mimecast.com ([63.128.21.74]:52403 "EHLO us-smtp-delivery-74.mimecast.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726494AbgCQVbh (ORCPT ); Tue, 17 Mar 2020 17:31:37 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=redhat.com; s=mimecast20190719; t=1584480696; 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=ayEqZx2f8JmdXf64atk8+6eayXgF695pjKzYuKwjbTc=; b=huXxdi/fZdS/tU+yH41IPzSszw3rDXGiiF89mIqP2SXeaqrjCTIi+LaEwUylTXNIoWEg6N UPM+3f+78q/moKu09/UJ6lsC3gmq5pLOehc14YVdz6mQqLt8YY3pQ1MdZW+FKkH+48RF1C qZylWtO7Os4FV7pdhrmWt67+liLjMVA= 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-160-HDe1Ws9-NCewDps3-KYRjw-1; Tue, 17 Mar 2020 17:31:34 -0400 X-MC-Unique: HDe1Ws9-NCewDps3-KYRjw-1 Received: from smtp.corp.redhat.com (int-mx08.intmail.prod.int.phx2.redhat.com [10.5.11.23]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mimecast-mx01.redhat.com (Postfix) with ESMTPS id 3BEFF18C35A2; Tue, 17 Mar 2020 21:31:33 +0000 (UTC) Received: from madcap2.tricolour.ca (unknown [10.36.110.5]) by smtp.corp.redhat.com (Postfix) with ESMTP id 5C0DA19C58; Tue, 17 Mar 2020 21:31:21 +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 v3 2/3] netfilter: add audit table unregister actions Date: Tue, 17 Mar 2020 17:30:23 -0400 Message-Id: <1715b217352ea7c920e97308cef59306ab63dd88.1584480281.git.rgb@redhat.com> In-Reply-To: References: In-Reply-To: References: X-Scanned-By: MIMEDefang 2.84 on 10.5.11.23 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 f4aed2b9be8d..17427c41cc29 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 f4e342125dd9..dbb056feccb9 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 55f9409c3ee0..b3a2e6ea516c 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 db5cbcf43748..e43720a7783b 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