mirror of
https://salsa.debian.org/freeipa-team/freeipa.git
synced 2025-01-16 03:11:57 -06:00
fc70c78e45
The new Firewall class provides methods to enable and disable a service, service lists and also methods to apply a passthrough rule, also to add, prepend and also remove a list of passthrough rules: class Firewall __init__(host) Initialize with host where firewall changes should be applied Unmasks, enables and starts firewalld enable_service(service) Enable firewall service in firewalld runtime and permanent environment disable_service(service) Disable firewall service in firewalld runtime and permanent environment enable_services(services) Enable list of firewall services in firewalld runtime and permanent environment disable_services(services) Disable list of firewall services in firewalld runtime and permanent environment passthrough_rule(rule, ipv=None) Generic method to get direct passthrough rules to firewalld rule is an ip[6]tables rule without using the ip[6]tables command. The rule will per default be added to the IPv4 and IPv6 firewall. If there are IP version specific parts in the rule, please make sure that ipv is set properly. The rule is added to the direct sub chain of the chain that is used in the rule add_passthrough_rules(rules, ipv=None) Add passthough rules to the end of the chain rules is a list of ip[6]tables rules, where the first entry of each rule is the chain. No --append/-A, --delete/-D should be added before the chain name, beacuse these are added by the method. If there are IP version specific parts in the rule, please make sure that ipv is set to either ipv4 or ipv6. prepend_passthrough_rules(rules, ipv=None) Insert passthough rules starting at position 1 as a block rules is a list of ip[6]tables rules, where the first entry of each rule is the chain. No --append/-A, --delete/-D should be added before the chain name, beacuse these are added by the method. If there are IP version specific parts in the rule, please make sure that ipv is set to either ipv4 or ipv6. remove_passthrough_rules(rules, ipv=None) Remove passthrough rules rules is a list of ip[6]tables rules, where the first entry of each rule is the chain. No --append/-A, --delete/-D should be added before the chain name, beacuse these are added by the method. If there are IP version specific parts in the rule, please make sure that ipv is set to either ipv4 or ipv6. See: https://pagure.io/freeipa/issue/7755 Signed-off-by: Thomas Woerner <twoerner@redhat.com> Reviewed-By: Christian Heimes <cheimes@redhat.com> Reviewed-By: Armando Neto <abiagion@redhat.com>
123 lines
5.0 KiB
Python
123 lines
5.0 KiB
Python
#
|
|
# Copyright (C) 2018 FreeIPA Contributors. See COPYING for license
|
|
#
|
|
|
|
"""Firewall class for integration testing using firewalld"""
|
|
|
|
from ipapython import ipautil
|
|
|
|
|
|
class Firewall:
|
|
def __init__(self, host):
|
|
"""Initialize with host where firewall changes should be applied
|
|
Unmasks, enables and starts firewalld."""
|
|
self.host = host
|
|
# Unmask firewalld service
|
|
self.host.run_command(["systemctl", "unmask", "firewalld"])
|
|
# Enable firewalld service
|
|
self.host.run_command(["systemctl", "enable", "firewalld"])
|
|
# Start firewalld service
|
|
self.host.run_command(["systemctl", "start", "firewalld"])
|
|
|
|
def _rp_action(self, args):
|
|
"""Run-time and permanant firewall action"""
|
|
cmd = ["firewall-cmd"]
|
|
cmd.extend(args)
|
|
|
|
# Run-time part
|
|
result = self.host.run_command(cmd, raiseonerr=False)
|
|
if result.returncode not in [0, 11, 12]:
|
|
# Ignore firewalld error codes:
|
|
# 11 is ALREADY_ENABLED
|
|
# 12 is NOT_ENABLED
|
|
raise ipautil.CalledProcessError(result.returncode, cmd,
|
|
result.stdout_text,
|
|
result.stderr_text)
|
|
|
|
# Permanent part
|
|
result = self.host.run_command(cmd + ["--permanent"],
|
|
raiseonerr=False)
|
|
if result.returncode not in [0, 11, 12]:
|
|
# Ignore firewalld error codes:
|
|
# 11 is ALREADY_ENABLED
|
|
# 12 is NOT_ENABLED
|
|
raise ipautil.CalledProcessError(result.returncode, cmd,
|
|
result.stdout_text,
|
|
result.stderr_text)
|
|
|
|
def enable_service(self, service):
|
|
"""Enable firewall service in firewalld runtime and permanent
|
|
environment"""
|
|
self._rp_action(["--add-service", service])
|
|
|
|
def disable_service(self, service):
|
|
"""Disable firewall service in firewalld runtime and permanent
|
|
environment"""
|
|
self._rp_action(["--remove-service", service])
|
|
|
|
def enable_services(self, services):
|
|
"""Enable list of firewall services in firewalld runtime and
|
|
permanent environment"""
|
|
args = []
|
|
for service in services:
|
|
args.extend(["--add-service", service])
|
|
self._rp_action(args)
|
|
|
|
def disable_services(self, services):
|
|
"""Disable list of firewall services in firewalld runtime and
|
|
permanent environment"""
|
|
args = []
|
|
for service in services:
|
|
args.extend(["--remove-service", service])
|
|
self._rp_action(args)
|
|
|
|
def passthrough_rule(self, rule, ipv=None):
|
|
"""Generic method to get direct passthrough rules to firewalld
|
|
rule is an ip[6]tables rule without using the ip[6]tables command.
|
|
The rule will per default be added to the IPv4 and IPv6 firewall.
|
|
If there are IP version specific parts in the rule, please make sure
|
|
that ipv is adapted properly.
|
|
The rule is added to the direct sub chain of the chain that is used
|
|
in the rule"""
|
|
if ipv is None:
|
|
ipvs = ["ipv4", "ipv6"]
|
|
else:
|
|
ipvs = [ipv]
|
|
for _ipv in ipvs:
|
|
args = ["firewall-cmd", "--direct", "--passthrough", _ipv] + rule
|
|
self.host.run_command(args)
|
|
|
|
def add_passthrough_rules(self, rules, ipv=None):
|
|
"""Add passthough rules to the end of the chain
|
|
rules is a list of ip[6]tables rules, where the first entry of each
|
|
rule is the chain. No --append/-A, --delete/-D should be added before
|
|
the chain name, beacuse these are added by the method.
|
|
If there are IP version specific parts in the rule, please make sure
|
|
that ipv is adapted properly.
|
|
"""
|
|
for rule in rules:
|
|
self.passthrough_rule(["-A"] + rule, ipv)
|
|
|
|
def prepend_passthrough_rules(self, rules, ipv=None):
|
|
"""Insert passthough rules starting at position 1 as a block
|
|
rules is a list of ip[6]tables rules, where the first entry of each
|
|
rule is the chain. No --append/-A, --delete/-D should be added before
|
|
the chain name, beacuse these are added by the method.
|
|
If there are IP version specific parts in the rule, please make sure
|
|
that ipv is adapted properly.
|
|
"""
|
|
# first rule number in iptables is 1
|
|
for i, rule in enumerate(rules, start=1):
|
|
self.passthrough_rule(["-I", rule[0], str(i)] + rule[1:], ipv)
|
|
|
|
def remove_passthrough_rules(self, rules, ipv=None):
|
|
"""Remove passthrough rules
|
|
rules is a list of ip[6]tables rules, where the first entry of each
|
|
rule is the chain. No --append/-A, --delete/-D should be added before
|
|
the chain name, beacuse these are added by the method.
|
|
If there are IP version specific parts in the rule, please make sure
|
|
that ipv is adapted properly.
|
|
"""
|
|
for rule in rules:
|
|
self.passthrough_rule(["-D"] + rule, ipv)
|