1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56
|
# Copyright (C) 2014 Red Hat, Inc. Jamie Bainbridge <jbainbri@redhat.com>
# Copyright (C) 2014 Red Hat, Inc. Bryn M. Reeves <bmr@redhat.com>
# This file is part of the sos project: https://github.com/sosreport/sos
#
# This copyrighted material is made available to anyone wishing to use,
# modify, copy, or redistribute it subject to the terms and conditions of
# version 2 of the GNU General Public License.
#
# See the LICENSE file in the source distribution for further information.
from sos.report.plugins import Plugin, RedHatPlugin, SoSPredicate
class FirewallD(Plugin, RedHatPlugin):
short_desc = 'Firewall daemon'
plugin_name = 'firewalld'
profiles = ('network',)
packages = ('firewalld',)
def setup(self):
self.add_copy_spec([
"/etc/firewalld/firewalld.conf",
"/etc/firewalld/*.xml",
"/etc/firewalld/icmptypes/*.xml",
"/etc/firewalld/services/*.xml",
"/etc/firewalld/zones/*.xml",
"/etc/sysconfig/firewalld",
"/var/log/firewalld",
])
# collect nftables ruleset
nft_pred = SoSPredicate(self,
kmods=['nf_tables', 'nfnetlink'],
required={'kmods': 'all'})
self.add_cmd_output("nft list ruleset", pred=nft_pred, changes=True)
# use a 10s timeout to workaround dbus problems in
# docker containers.
self.add_cmd_output([
"firewall-cmd --list-all-zones",
"firewall-cmd --direct --get-all-chains",
"firewall-cmd --direct --get-all-rules",
"firewall-cmd --direct --get-all-passthroughs",
"firewall-cmd --permanent --list-all-zones",
"firewall-cmd --permanent --direct --get-all-chains",
"firewall-cmd --permanent --direct --get-all-rules",
"firewall-cmd --permanent --direct --get-all-passthroughs",
"firewall-cmd --state",
"firewall-cmd --get-log-denied"
], timeout=10)
# vim: set et ts=4 sw=4 :
|