|
|
79b470 |
From 36a12736f39da72dba98b843def645e5e4ed0afb Mon Sep 17 00:00:00 2001
|
|
|
79b470 |
Message-Id: <36a12736f39da72dba98b843def645e5e4ed0afb@dist-git>
|
|
|
79b470 |
From: Laine Stump <laine@redhat.com>
|
|
|
79b470 |
Date: Fri, 15 Jan 2021 22:51:49 -0500
|
|
|
79b470 |
Subject: [PATCH] util: always check for ebtables/iptables binaries, even when
|
|
|
79b470 |
using firewalld
|
|
|
79b470 |
|
|
|
79b470 |
Even though *we* don't call ebtables/iptables/ip6tables (yet) when the
|
|
|
79b470 |
firewalld backend is selected, firewalld does, so these binaries need
|
|
|
79b470 |
to be there; let's check for them. (Also, the patch after this one is
|
|
|
79b470 |
going to start execing those binaries directly rather than via
|
|
|
79b470 |
firewalld).
|
|
|
79b470 |
|
|
|
79b470 |
https://bugzilla.redhat.com/1607929
|
|
|
79b470 |
|
|
|
79b470 |
Signed-off-by: Laine Stump <laine@redhat.com>
|
|
|
79b470 |
Reviewed-by: Daniel Henrique Barboza <danielhb413@gmail.com>
|
|
|
79b470 |
(cherry picked from commit 56dd128bd06c38fab4256a098124d47d803e919a)
|
|
|
79b470 |
Message-Id: <20210116035151.1066734-7-laine@redhat.com>
|
|
|
79b470 |
Reviewed-by: Jiri Denemark <jdenemar@redhat.com>
|
|
|
79b470 |
---
|
|
|
79b470 |
src/util/virfirewall.c | 56 ++++++++++++++++++++----------------------
|
|
|
79b470 |
1 file changed, 26 insertions(+), 30 deletions(-)
|
|
|
79b470 |
|
|
|
79b470 |
diff --git a/src/util/virfirewall.c b/src/util/virfirewall.c
|
|
|
79b470 |
index 2e3b02402e..520d515c11 100644
|
|
|
79b470 |
--- a/src/util/virfirewall.c
|
|
|
79b470 |
+++ b/src/util/virfirewall.c
|
|
|
79b470 |
@@ -100,24 +100,38 @@ VIR_ONCE_GLOBAL_INIT(virFirewall);
|
|
|
79b470 |
static int
|
|
|
79b470 |
virFirewallValidateBackend(virFirewallBackend backend)
|
|
|
79b470 |
{
|
|
|
79b470 |
- VIR_DEBUG("Validating backend %d", backend);
|
|
|
79b470 |
+ const char *commands[] = {
|
|
|
79b470 |
+ IPTABLES_PATH, IP6TABLES_PATH, EBTABLES_PATH
|
|
|
79b470 |
+ };
|
|
|
79b470 |
+ size_t i;
|
|
|
79b470 |
+
|
|
|
79b470 |
+ for (i = 0; i < G_N_ELEMENTS(commands); i++) {
|
|
|
79b470 |
+ if (!virFileIsExecutable(commands[i])) {
|
|
|
79b470 |
+ virReportSystemError(errno,
|
|
|
79b470 |
+ _("%s not available, firewall backend will not function"),
|
|
|
79b470 |
+ commands[i]);
|
|
|
79b470 |
+ return -1;
|
|
|
79b470 |
+ }
|
|
|
79b470 |
+ }
|
|
|
79b470 |
+ VIR_DEBUG("found iptables/ip6tables/ebtables");
|
|
|
79b470 |
+
|
|
|
79b470 |
if (backend == VIR_FIREWALL_BACKEND_AUTOMATIC ||
|
|
|
79b470 |
backend == VIR_FIREWALL_BACKEND_FIREWALLD) {
|
|
|
79b470 |
int rv = virFirewallDIsRegistered();
|
|
|
79b470 |
|
|
|
79b470 |
VIR_DEBUG("Firewalld is registered ? %d", rv);
|
|
|
79b470 |
- if (rv < 0) {
|
|
|
79b470 |
- if (rv == -2) {
|
|
|
79b470 |
- if (backend == VIR_FIREWALL_BACKEND_FIREWALLD) {
|
|
|
79b470 |
- virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
|
|
79b470 |
- _("firewalld firewall backend requested, but service is not running"));
|
|
|
79b470 |
- return -1;
|
|
|
79b470 |
- } else {
|
|
|
79b470 |
- VIR_DEBUG("firewalld service not running, trying direct backend");
|
|
|
79b470 |
- backend = VIR_FIREWALL_BACKEND_DIRECT;
|
|
|
79b470 |
- }
|
|
|
79b470 |
- } else {
|
|
|
79b470 |
+
|
|
|
79b470 |
+ if (rv == -1)
|
|
|
79b470 |
+ return -1;
|
|
|
79b470 |
+
|
|
|
79b470 |
+ if (rv == -2) {
|
|
|
79b470 |
+ if (backend == VIR_FIREWALL_BACKEND_FIREWALLD) {
|
|
|
79b470 |
+ virReportError(VIR_ERR_INTERNAL_ERROR, "%s",
|
|
|
79b470 |
+ _("firewalld backend requested, but service is not running"));
|
|
|
79b470 |
return -1;
|
|
|
79b470 |
+ } else {
|
|
|
79b470 |
+ VIR_DEBUG("firewalld service not running, using direct backend");
|
|
|
79b470 |
+ backend = VIR_FIREWALL_BACKEND_DIRECT;
|
|
|
79b470 |
}
|
|
|
79b470 |
} else {
|
|
|
79b470 |
VIR_DEBUG("firewalld service running, using firewalld backend");
|
|
|
79b470 |
@@ -125,25 +139,7 @@ virFirewallValidateBackend(virFirewallBackend backend)
|
|
|
79b470 |
}
|
|
|
79b470 |
}
|
|
|
79b470 |
|
|
|
79b470 |
- if (backend == VIR_FIREWALL_BACKEND_DIRECT) {
|
|
|
79b470 |
- const char *commands[] = {
|
|
|
79b470 |
- IPTABLES_PATH, IP6TABLES_PATH, EBTABLES_PATH
|
|
|
79b470 |
- };
|
|
|
79b470 |
- size_t i;
|
|
|
79b470 |
-
|
|
|
79b470 |
- for (i = 0; i < G_N_ELEMENTS(commands); i++) {
|
|
|
79b470 |
- if (!virFileIsExecutable(commands[i])) {
|
|
|
79b470 |
- virReportSystemError(errno,
|
|
|
79b470 |
- _("direct firewall backend requested, but %s is not available"),
|
|
|
79b470 |
- commands[i]);
|
|
|
79b470 |
- return -1;
|
|
|
79b470 |
- }
|
|
|
79b470 |
- }
|
|
|
79b470 |
- VIR_DEBUG("found iptables/ip6tables/ebtables, using direct backend");
|
|
|
79b470 |
- }
|
|
|
79b470 |
-
|
|
|
79b470 |
currentBackend = backend;
|
|
|
79b470 |
-
|
|
|
79b470 |
return 0;
|
|
|
79b470 |
}
|
|
|
79b470 |
|
|
|
79b470 |
--
|
|
|
79b470 |
2.30.0
|
|
|
79b470 |
|