firewalld - fail offline operations on old lib version

This fixes an issue where the check for an import error would occur
before checking to see if firewalld is in "offline mode" and if it
is, then checking to ensure the version of the firewall python
library was new enough to support offline operations. This patch
will now fail with a correct error message in the scenario that
someone attempts to perform an offline operation but has a version
of the firewall python library that is too old.

Signed-off-by: Adam Miller <maxamillion@fedoraproject.org>
This commit is contained in:
Adam Miller 2017-11-22 08:56:32 -06:00 committed by Brian Coca
parent eec2ab5e75
commit 9225052496

View file

@ -158,6 +158,7 @@ try:
fw.getDefaultZone() fw.getDefaultZone()
except AttributeError: except AttributeError:
# Firewalld is not currently running, permanent-only operations # Firewalld is not currently running, permanent-only operations
fw_offline = True
# Import other required parts of the firewalld API # Import other required parts of the firewalld API
# #
@ -167,7 +168,6 @@ try:
from firewall.client import FirewallClientZoneSettings from firewall.client import FirewallClientZoneSettings
fw = Firewall_test() fw = Firewall_test()
fw.start() fw.start()
fw_offline = True
except ImportError: except ImportError:
import_failure = True import_failure = True
@ -749,11 +749,6 @@ def main():
supports_check_mode=True supports_check_mode=True
) )
if import_failure:
module.fail_json(
msg='firewalld and its python module are required for this module, version 0.2.11 or newer required (0.3.9 or newer for offline operations)'
)
if fw_offline: if fw_offline:
# Pre-run version checking # Pre-run version checking
if FW_VERSION < "0.3.9": if FW_VERSION < "0.3.9":
@ -771,6 +766,11 @@ def main():
module.fail_json(msg="firewalld connection can't be established,\ module.fail_json(msg="firewalld connection can't be established,\
installed version (%s) likely too old. Requires firewalld >= 0.2.11" % FW_VERSION) installed version (%s) likely too old. Requires firewalld >= 0.2.11" % FW_VERSION)
if import_failure:
module.fail_json(
msg='firewalld and its python module are required for this module, version 0.2.11 or newer required (0.3.9 or newer for offline operations)'
)
permanent = module.params['permanent'] permanent = module.params['permanent']
desired_state = module.params['state'] desired_state = module.params['state']
immediate = module.params['immediate'] immediate = module.params['immediate']