2012-07-23 14:15:55 +08:00
|
|
|
/*
|
2012-08-20 16:56:03 -06:00
|
|
|
* virsh-nwfilter.c: Commands to manage network filters
|
2012-07-23 14:15:55 +08:00
|
|
|
*
|
2016-01-09 08:36:29 -05:00
|
|
|
* Copyright (C) 2005, 2007-2016 Red Hat, Inc.
|
2012-07-23 14:15:55 +08:00
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Lesser General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2.1 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Lesser General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public
|
2012-09-20 16:30:55 -06:00
|
|
|
* License along with this library. If not, see
|
2012-07-23 14:15:55 +08:00
|
|
|
* <http://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
2012-08-20 16:56:03 -06:00
|
|
|
#include <config.h>
|
|
|
|
#include "virsh-nwfilter.h"
|
2021-09-26 13:18:17 +02:00
|
|
|
#include "virsh-util.h"
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2012-08-20 16:56:03 -06:00
|
|
|
#include "internal.h"
|
2012-12-12 18:06:53 +00:00
|
|
|
#include "viralloc.h"
|
2013-05-09 14:59:04 -04:00
|
|
|
#include "virfile.h"
|
2018-09-21 16:17:15 +02:00
|
|
|
#include "vsh-table.h"
|
2012-08-20 16:56:03 -06:00
|
|
|
|
|
|
|
virNWFilterPtr
|
2015-06-15 18:53:58 +02:00
|
|
|
virshCommandOptNWFilterBy(vshControl *ctl, const vshCmd *cmd,
|
|
|
|
const char **name, unsigned int flags)
|
2012-07-23 14:15:55 +08:00
|
|
|
{
|
|
|
|
virNWFilterPtr nwfilter = NULL;
|
|
|
|
const char *n = NULL;
|
|
|
|
const char *optname = "nwfilter";
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2015-06-15 18:53:58 +02:00
|
|
|
|
|
|
|
virCheckFlags(VIRSH_BYUUID | VIRSH_BYNAME, NULL);
|
2012-08-20 16:56:03 -06:00
|
|
|
|
2013-01-21 18:18:41 +01:00
|
|
|
if (vshCommandOptStringReq(ctl, cmd, optname, &n) < 0)
|
2012-07-23 14:15:55 +08:00
|
|
|
return NULL;
|
|
|
|
|
|
|
|
vshDebug(ctl, VSH_ERR_INFO, "%s: found option <%s>: %s\n",
|
|
|
|
cmd->def->name, optname, n);
|
|
|
|
|
|
|
|
if (name)
|
|
|
|
*name = n;
|
|
|
|
|
|
|
|
/* try it by UUID */
|
2015-06-15 18:53:58 +02:00
|
|
|
if ((flags & VIRSH_BYUUID) && strlen(n) == VIR_UUID_STRING_BUFLEN-1) {
|
2012-07-23 14:15:55 +08:00
|
|
|
vshDebug(ctl, VSH_ERR_DEBUG, "%s: <%s> trying as nwfilter UUID\n",
|
|
|
|
cmd->def->name, optname);
|
2015-06-15 18:53:58 +02:00
|
|
|
nwfilter = virNWFilterLookupByUUIDString(priv->conn, n);
|
2012-07-23 14:15:55 +08:00
|
|
|
}
|
|
|
|
/* try it by NAME */
|
2015-06-15 18:53:58 +02:00
|
|
|
if (!nwfilter && (flags & VIRSH_BYNAME)) {
|
2012-07-23 14:15:55 +08:00
|
|
|
vshDebug(ctl, VSH_ERR_DEBUG, "%s: <%s> trying as nwfilter NAME\n",
|
|
|
|
cmd->def->name, optname);
|
2015-06-15 18:53:58 +02:00
|
|
|
nwfilter = virNWFilterLookupByName(priv->conn, n);
|
2012-07-23 14:15:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!nwfilter)
|
2023-03-09 15:54:58 +01:00
|
|
|
vshError(ctl, _("failed to get nwfilter '%1$s'"), n);
|
2012-07-23 14:15:55 +08:00
|
|
|
|
|
|
|
return nwfilter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-define" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_define[] = {
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = "help",
|
|
|
|
.data = N_("define or update a network filter from an XML file")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Define a new network filter or update an existing one.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_define[] = {
|
2016-01-09 08:36:29 -05:00
|
|
|
VIRSH_COMMON_OPT_FILE(N_("file containing an XML network "
|
|
|
|
"filter description")),
|
2021-08-20 13:57:10 +02:00
|
|
|
{.name = "validate",
|
|
|
|
.type = VSH_OT_BOOL,
|
|
|
|
.help = N_("validate the XML against the schema")
|
|
|
|
},
|
2013-01-14 15:32:22 +01:00
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterDefine(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
2021-09-26 13:18:17 +02:00
|
|
|
g_autoptr(virshNWFilter) nwfilter = NULL;
|
2012-07-23 14:15:55 +08:00
|
|
|
const char *from = NULL;
|
|
|
|
bool ret = true;
|
2021-08-11 15:25:15 +02:00
|
|
|
g_autofree char *buffer = NULL;
|
2021-08-20 13:57:10 +02:00
|
|
|
unsigned int flags = 0;
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2013-01-21 18:18:41 +01:00
|
|
|
if (vshCommandOptStringReq(ctl, cmd, "file", &from) < 0)
|
2012-07-23 14:15:55 +08:00
|
|
|
return false;
|
|
|
|
|
2021-08-20 13:57:10 +02:00
|
|
|
if (vshCommandOptBool(cmd, "validate"))
|
|
|
|
flags |= VIR_NWFILTER_DEFINE_VALIDATE;
|
|
|
|
|
virsh: use common namespacing
Convert the exported items in virsh.h to use a common 'vsh' prefix.
* tools/virsh.h (VIRSH_MAX_XML_FILE): Rename...
(VSH_MAX_XML_FILE): ...and parenthesize.
(DIFF_MSEC, CTRL_CLOSE_BRACKET): Delete.
(vshUsage, vshInit, vshDeinit, vshParseArgv): Remove prototype.
(editWriteToTempFile, editFile, editReadBackFile, prettyCapacity)
(virshReportError): Rename...
(vshEditWriteToTempFile, vshEditFile, vshEditReadBackFile)
(vshPrettyCapacity, vshReportError): ...into vsh namespace.
(jobWatchTimeoutFunc): Move to virsh-domain.c.
* tools/virsh.c (vshCommandRun): Inline former DIFF_MSEC.
(main): Inline former CTRL_CLOSE_BRACKET.
(vshUsage, vshInit, vshDeinit, vshParseArgv): Make static.
(prettyCapacity, virshReportError, editWriteToTempFile, editFile):
Fix naming, and adjust usage.
(vshAskReedit, vshCommandRun, vshEventLoop, vshInit): Adjust
usage.
* tools/virsh-domain.c (cmdAttachDevice, cmdCPUCompare)
(cmdCPUBaseline, cmdCreate, cmdDefine, cmdDetachDevice)
(cmdUpdateDevice, cmdDesc, cmdUndefine, cmdStart, cmdVcpucount)
(cmdAttachDevice, cmdDomjobinfo): Likewise.
* tools/virsh-edit.c (do): Likewise.
* tools/virsh-interface.c (cmdInterfaceDefine): Likewise.
* tools/virsh-network.c (cmdNetworkCreate, cmdNetworkDefine):
Likewise.
* tools/virsh-nodedev.c (cmdNodeDeviceCreate): Likewise.
* tools/virsh-nwfilter.c (cmdNWFilterDefine): Likewise.
* tools/virsh-pool.c (cmdPoolCreate, cmdPoolDefine)
(cmdPoolDiscoverSources, cmdPoolList): Likewise.
* tools/virsh-secret.c (cmdSecretDefine): Likewise.
* tools/virsh-snapshot.c (cmdSnapshotCreate, vshSnapshotCreate)
(vshLookupSnapshot, cmdSnapshotEdit, cmdSnapshotCurrent)
(vshGetSnapshotParent): Likewise.
* tools/virsh-volume.c (cmdVolCreate, cmdVolCreateFrom)
(cmdVolInfo, cmdVolList): Likewise.
2012-08-18 22:10:17 -06:00
|
|
|
if (virFileReadAll(from, VSH_MAX_XML_FILE, &buffer) < 0)
|
2012-07-23 14:15:55 +08:00
|
|
|
return false;
|
|
|
|
|
2021-08-20 13:57:10 +02:00
|
|
|
if (flags)
|
|
|
|
nwfilter = virNWFilterDefineXMLFlags(priv->conn, buffer, flags);
|
|
|
|
else
|
|
|
|
nwfilter = virNWFilterDefineXML(priv->conn, buffer);
|
2012-07-23 14:15:55 +08:00
|
|
|
|
|
|
|
if (nwfilter != NULL) {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshPrintExtra(ctl, _("Network filter %1$s defined from %2$s\n"),
|
2016-08-24 16:14:23 +02:00
|
|
|
virNWFilterGetName(nwfilter), from);
|
2012-07-23 14:15:55 +08:00
|
|
|
} else {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshError(ctl, _("Failed to define network filter from %1$s"), from);
|
2012-07-23 14:15:55 +08:00
|
|
|
ret = false;
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-undefine" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_undefine[] = {
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = "help",
|
|
|
|
.data = N_("undefine a network filter")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Undefine a given network filter.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_undefine[] = {
|
2013-01-14 15:32:22 +01:00
|
|
|
{.name = "nwfilter",
|
|
|
|
.type = VSH_OT_DATA,
|
|
|
|
.flags = VSH_OFLAG_REQ,
|
2018-01-12 14:51:34 +01:00
|
|
|
.help = N_("network filter name or uuid"),
|
|
|
|
.completer = virshNWFilterNameCompleter,
|
2013-01-14 15:32:22 +01:00
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterUndefine(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
2021-09-26 13:18:17 +02:00
|
|
|
g_autoptr(virshNWFilter) nwfilter = NULL;
|
2012-07-23 14:15:55 +08:00
|
|
|
bool ret = true;
|
|
|
|
const char *name;
|
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
if (!(nwfilter = virshCommandOptNWFilter(ctl, cmd, &name)))
|
2012-07-23 14:15:55 +08:00
|
|
|
return false;
|
|
|
|
|
|
|
|
if (virNWFilterUndefine(nwfilter) == 0) {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshPrintExtra(ctl, _("Network filter %1$s undefined\n"), name);
|
2012-07-23 14:15:55 +08:00
|
|
|
} else {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshError(ctl, _("Failed to undefine network filter %1$s"), name);
|
2012-07-23 14:15:55 +08:00
|
|
|
ret = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-dumpxml" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_dumpxml[] = {
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = "help",
|
|
|
|
.data = N_("network filter information in XML")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Output the network filter information as an XML dump to stdout.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_dumpxml[] = {
|
2013-01-14 15:32:22 +01:00
|
|
|
{.name = "nwfilter",
|
|
|
|
.type = VSH_OT_DATA,
|
|
|
|
.flags = VSH_OFLAG_REQ,
|
2018-01-12 14:51:34 +01:00
|
|
|
.help = N_("network filter name or uuid"),
|
|
|
|
.completer = virshNWFilterNameCompleter,
|
2013-01-14 15:32:22 +01:00
|
|
|
},
|
2022-06-16 16:29:54 +01:00
|
|
|
{.name = "xpath",
|
|
|
|
.type = VSH_OT_STRING,
|
virsh: Require --xpath for *dumpxml
Historically, the dumpxml command reject any unknown arguments,
for instance:
virsh dumpxml fedora xxx
However, after v8.5.0-rc1~31 the second argument ('xxx') is
treated as an XPath, but it's not that clearly visible.
Therefore, require the --xpath switch, like this:
virsh dumpxml fedora --xpath xxx
Yes, this breaks already released virsh, but I think we can argue
that the pool of users of this particular function is very small.
We also document the argument being mandatory:
dumpxml [--inactive] [--security-info] [--update-cpu] [--migratable]
[--xpath EXPRESSION] [--wrap] domain
The sooner we do this change, the better.
The same applies for other *dumpxml functions (net-dumpxml,
pool-dumpxml, vol-dumpxl to name a few).
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2103524
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2022-07-08 12:45:42 +02:00
|
|
|
.flags = VSH_OFLAG_REQ_OPT,
|
2022-06-16 16:29:54 +01:00
|
|
|
.completer = virshCompleteEmpty,
|
|
|
|
.help = N_("xpath expression to filter the XML document")
|
|
|
|
},
|
|
|
|
{.name = "wrap",
|
|
|
|
.type = VSH_OT_BOOL,
|
|
|
|
.help = N_("wrap xpath results in an common root element"),
|
|
|
|
},
|
2013-01-14 15:32:22 +01:00
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterDumpXML(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
2021-09-26 13:18:17 +02:00
|
|
|
g_autoptr(virshNWFilter) nwfilter = NULL;
|
2022-06-16 16:29:54 +01:00
|
|
|
g_autofree char *xml = NULL;
|
|
|
|
bool wrap = vshCommandOptBool(cmd, "wrap");
|
|
|
|
const char *xpath = NULL;
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
if (!(nwfilter = virshCommandOptNWFilter(ctl, cmd, NULL)))
|
2012-07-23 14:15:55 +08:00
|
|
|
return false;
|
|
|
|
|
2022-06-16 16:29:54 +01:00
|
|
|
if (vshCommandOptStringQuiet(ctl, cmd, "xpath", &xpath) < 0)
|
|
|
|
return false;
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2022-06-16 16:29:54 +01:00
|
|
|
if (!(xml = virNWFilterGetXMLDesc(nwfilter, 0)))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
return virshDumpXML(ctl, xml, "nwfilter", xpath, wrap);
|
2012-07-23 14:15:55 +08:00
|
|
|
}
|
|
|
|
|
2012-09-05 14:02:07 +08:00
|
|
|
static int
|
2015-06-15 18:53:58 +02:00
|
|
|
virshNWFilterSorter(const void *a, const void *b)
|
2012-09-05 14:02:07 +08:00
|
|
|
{
|
|
|
|
virNWFilterPtr *fa = (virNWFilterPtr *) a;
|
|
|
|
virNWFilterPtr *fb = (virNWFilterPtr *) b;
|
|
|
|
|
|
|
|
if (*fa && !*fb)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (!*fa)
|
|
|
|
return *fb != NULL;
|
|
|
|
|
|
|
|
return vshStrcasecmp(virNWFilterGetName(*fa),
|
|
|
|
virNWFilterGetName(*fb));
|
|
|
|
}
|
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
struct virshNWFilterList {
|
2012-09-05 14:02:07 +08:00
|
|
|
virNWFilterPtr *filters;
|
|
|
|
size_t nfilters;
|
|
|
|
};
|
|
|
|
|
|
|
|
static void
|
2021-03-11 08:16:13 +01:00
|
|
|
virshNWFilterListFree(struct virshNWFilterList *list)
|
2012-09-05 14:02:07 +08:00
|
|
|
{
|
Convert 'int i' to 'size_t i' in tools/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
2012-09-05 14:02:07 +08:00
|
|
|
|
2013-08-27 13:27:50 +02:00
|
|
|
if (list && list->filters) {
|
2012-09-05 14:02:07 +08:00
|
|
|
for (i = 0; i < list->nfilters; i++) {
|
2021-09-26 13:18:17 +02:00
|
|
|
virshNWFilterFree(list->filters[i]);
|
2012-09-05 14:02:07 +08:00
|
|
|
}
|
2021-02-03 14:32:55 -05:00
|
|
|
g_free(list->filters);
|
2012-09-05 14:02:07 +08:00
|
|
|
}
|
2021-02-03 14:32:55 -05:00
|
|
|
g_free(list);
|
2012-09-05 14:02:07 +08:00
|
|
|
}
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
static struct virshNWFilterList *
|
2015-06-15 18:53:58 +02:00
|
|
|
virshNWFilterListCollect(vshControl *ctl,
|
|
|
|
unsigned int flags)
|
2012-09-05 14:02:07 +08:00
|
|
|
{
|
2021-03-11 08:16:13 +01:00
|
|
|
struct virshNWFilterList *list = g_new0(struct virshNWFilterList, 1);
|
Convert 'int i' to 'size_t i' in tools/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
2012-09-05 14:02:07 +08:00
|
|
|
int ret;
|
|
|
|
virNWFilterPtr filter;
|
|
|
|
bool success = false;
|
|
|
|
size_t deleted = 0;
|
|
|
|
int nfilters = 0;
|
|
|
|
char **names = NULL;
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2012-09-05 14:02:07 +08:00
|
|
|
|
|
|
|
/* try the list with flags support (0.10.2 and later) */
|
2015-06-15 18:53:58 +02:00
|
|
|
if ((ret = virConnectListAllNWFilters(priv->conn,
|
2012-09-05 14:02:07 +08:00
|
|
|
&list->filters,
|
|
|
|
flags)) >= 0) {
|
|
|
|
list->nfilters = ret;
|
|
|
|
goto finished;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* check if the command is actually supported */
|
|
|
|
if (last_error && last_error->code == VIR_ERR_NO_SUPPORT) {
|
|
|
|
vshResetLibvirtError();
|
|
|
|
goto fallback;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* there was an error during the call */
|
2017-12-12 17:41:46 +00:00
|
|
|
vshError(ctl, "%s", _("Failed to list network filters"));
|
2012-09-05 14:02:07 +08:00
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
|
2014-03-25 07:53:59 +01:00
|
|
|
fallback:
|
2012-09-05 14:02:07 +08:00
|
|
|
/* fall back to old method (0.9.13 and older) */
|
|
|
|
vshResetLibvirtError();
|
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
nfilters = virConnectNumOfNWFilters(priv->conn);
|
2012-09-05 14:02:07 +08:00
|
|
|
if (nfilters < 0) {
|
|
|
|
vshError(ctl, "%s", _("Failed to count network filters"));
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (nfilters == 0)
|
|
|
|
return list;
|
|
|
|
|
2020-10-05 18:50:09 +02:00
|
|
|
names = g_new0(char *, nfilters);
|
2012-09-05 14:02:07 +08:00
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
nfilters = virConnectListNWFilters(priv->conn, names, nfilters);
|
2012-09-05 14:02:07 +08:00
|
|
|
if (nfilters < 0) {
|
|
|
|
vshError(ctl, "%s", _("Failed to list network filters"));
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
2020-10-05 18:50:09 +02:00
|
|
|
list->filters = g_new0(virNWFilterPtr, nfilters);
|
2012-09-05 14:02:07 +08:00
|
|
|
list->nfilters = 0;
|
|
|
|
|
|
|
|
/* get the network filters */
|
2013-05-21 15:44:53 +08:00
|
|
|
for (i = 0; i < nfilters; i++) {
|
2015-06-15 18:53:58 +02:00
|
|
|
if (!(filter = virNWFilterLookupByName(priv->conn, names[i])))
|
2012-09-05 14:02:07 +08:00
|
|
|
continue;
|
|
|
|
list->filters[list->nfilters++] = filter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* truncate network filters that weren't found */
|
|
|
|
deleted = nfilters - list->nfilters;
|
|
|
|
|
2014-03-25 07:53:59 +01:00
|
|
|
finished:
|
2012-09-05 14:02:07 +08:00
|
|
|
/* sort the list */
|
|
|
|
if (list->filters && list->nfilters)
|
|
|
|
qsort(list->filters, list->nfilters,
|
2015-06-15 18:53:58 +02:00
|
|
|
sizeof(*list->filters), virshNWFilterSorter);
|
2012-09-05 14:02:07 +08:00
|
|
|
|
|
|
|
/* truncate the list for not found filter objects */
|
|
|
|
if (deleted)
|
|
|
|
VIR_SHRINK_N(list->filters, list->nfilters, deleted);
|
|
|
|
|
|
|
|
success = true;
|
|
|
|
|
2014-03-25 07:53:59 +01:00
|
|
|
cleanup:
|
Convert 'int i' to 'size_t i' in tools/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
for (i = 0; nfilters != -1 && i < nfilters; i++)
|
2012-09-05 14:02:07 +08:00
|
|
|
VIR_FREE(names[i]);
|
|
|
|
VIR_FREE(names);
|
|
|
|
|
|
|
|
if (!success) {
|
2022-01-28 18:42:45 +01:00
|
|
|
g_clear_pointer(&list, virshNWFilterListFree);
|
2012-09-05 14:02:07 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
2012-07-23 14:15:55 +08:00
|
|
|
/*
|
|
|
|
* "nwfilter-list" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_list[] = {
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = "help",
|
|
|
|
.data = N_("list network filters")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Returns list of network filters.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_list[] = {
|
2013-01-14 15:32:22 +01:00
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
2019-10-14 14:44:29 +02:00
|
|
|
cmdNWFilterList(vshControl *ctl, const vshCmd *cmd G_GNUC_UNUSED)
|
2012-07-23 14:15:55 +08:00
|
|
|
{
|
Convert 'int i' to 'size_t i' in tools/ files
Convert the type of loop iterators named 'i', 'j', k',
'ii', 'jj', 'kk', to be 'size_t' instead of 'int' or
'unsigned int', also santizing 'ii', 'jj', 'kk' to use
the normal 'i', 'j', 'k' naming
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
2013-07-08 15:09:33 +01:00
|
|
|
size_t i;
|
2012-07-23 14:15:55 +08:00
|
|
|
char uuid[VIR_UUID_STRING_BUFLEN];
|
2018-09-21 16:17:15 +02:00
|
|
|
bool ret = false;
|
2021-03-11 08:16:13 +01:00
|
|
|
struct virshNWFilterList *list = NULL;
|
2021-08-11 15:12:02 +02:00
|
|
|
g_autoptr(vshTable) table = NULL;
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
if (!(list = virshNWFilterListCollect(ctl, 0)))
|
2012-07-23 14:15:55 +08:00
|
|
|
return false;
|
|
|
|
|
2018-09-21 16:17:15 +02:00
|
|
|
table = vshTableNew(_("UUID"), _("Name"), NULL);
|
|
|
|
if (!table)
|
|
|
|
goto cleanup;
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2012-09-05 14:02:07 +08:00
|
|
|
for (i = 0; i < list->nfilters; i++) {
|
|
|
|
virNWFilterPtr nwfilter = list->filters[i];
|
2012-07-23 14:15:55 +08:00
|
|
|
|
|
|
|
virNWFilterGetUUIDString(nwfilter, uuid);
|
2018-09-21 16:17:15 +02:00
|
|
|
if (vshTableRowAppend(table,
|
|
|
|
uuid,
|
|
|
|
virNWFilterGetName(nwfilter),
|
|
|
|
NULL) < 0)
|
|
|
|
goto cleanup;
|
2012-07-23 14:15:55 +08:00
|
|
|
}
|
|
|
|
|
2018-09-21 16:17:15 +02:00
|
|
|
vshTablePrintToStdout(table, ctl);
|
|
|
|
|
|
|
|
ret = true;
|
|
|
|
cleanup:
|
2015-06-15 18:53:58 +02:00
|
|
|
virshNWFilterListFree(list);
|
2018-09-21 16:17:15 +02:00
|
|
|
return ret;
|
2012-07-23 14:15:55 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-edit" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_edit[] = {
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = "help",
|
|
|
|
.data = N_("edit XML configuration for a network filter")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Edit the XML configuration for a network filter.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_edit[] = {
|
2013-01-14 15:32:22 +01:00
|
|
|
{.name = "nwfilter",
|
|
|
|
.type = VSH_OT_DATA,
|
|
|
|
.flags = VSH_OFLAG_REQ,
|
2018-01-12 14:51:34 +01:00
|
|
|
.help = N_("network filter name or uuid"),
|
|
|
|
.completer = virshNWFilterNameCompleter,
|
2013-01-14 15:32:22 +01:00
|
|
|
},
|
|
|
|
{.name = NULL}
|
2012-07-23 14:15:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterEdit(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
|
|
|
bool ret = false;
|
2021-09-26 13:18:17 +02:00
|
|
|
g_autoptr(virshNWFilter) nwfilter = NULL;
|
|
|
|
g_autoptr(virshNWFilter) nwfilter_edited = NULL;
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2012-07-23 14:15:55 +08:00
|
|
|
|
2015-06-15 18:53:58 +02:00
|
|
|
nwfilter = virshCommandOptNWFilter(ctl, cmd, NULL);
|
2012-07-23 14:15:55 +08:00
|
|
|
if (nwfilter == NULL)
|
|
|
|
goto cleanup;
|
|
|
|
|
|
|
|
#define EDIT_GET_XML virNWFilterGetXMLDesc(nwfilter, 0)
|
2017-11-03 13:09:47 +01:00
|
|
|
#define EDIT_NOT_CHANGED \
|
|
|
|
do { \
|
2023-03-09 15:54:58 +01:00
|
|
|
vshPrintExtra(ctl, _("Network filter %1$s XML configuration not changed.\n"), \
|
|
|
|
virNWFilterGetName(nwfilter)); \
|
2017-11-03 13:09:47 +01:00
|
|
|
ret = true; \
|
|
|
|
goto edit_cleanup; \
|
2014-11-14 15:57:17 +01:00
|
|
|
} while (0)
|
2012-07-23 14:15:55 +08:00
|
|
|
#define EDIT_DEFINE \
|
2015-06-15 18:53:58 +02:00
|
|
|
(nwfilter_edited = virNWFilterDefineXML(priv->conn, doc_edited))
|
2012-07-23 14:15:55 +08:00
|
|
|
#include "virsh-edit.c"
|
|
|
|
|
2023-03-09 15:54:58 +01:00
|
|
|
vshPrintExtra(ctl, _("Network filter %1$s XML configuration edited.\n"),
|
2016-11-04 15:22:26 +01:00
|
|
|
virNWFilterGetName(nwfilter_edited));
|
2012-07-23 14:15:55 +08:00
|
|
|
|
|
|
|
ret = true;
|
|
|
|
|
2014-03-25 07:53:59 +01:00
|
|
|
cleanup:
|
2012-07-23 14:15:55 +08:00
|
|
|
return ret;
|
|
|
|
}
|
2012-07-23 15:19:04 +08:00
|
|
|
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
virNWFilterBindingPtr
|
|
|
|
virshCommandOptNWFilterBindingBy(vshControl *ctl,
|
|
|
|
const vshCmd *cmd,
|
|
|
|
const char **name,
|
|
|
|
unsigned int flags)
|
|
|
|
{
|
|
|
|
virNWFilterBindingPtr binding = NULL;
|
|
|
|
const char *n = NULL;
|
|
|
|
const char *optname = "binding";
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
virCheckFlags(0, NULL);
|
|
|
|
|
|
|
|
if (vshCommandOptStringReq(ctl, cmd, optname, &n) < 0)
|
|
|
|
return NULL;
|
|
|
|
|
|
|
|
vshDebug(ctl, VSH_ERR_INFO, "%s: found option <%s>: %s\n",
|
|
|
|
cmd->def->name, optname, n);
|
|
|
|
|
|
|
|
if (name)
|
|
|
|
*name = n;
|
|
|
|
|
|
|
|
vshDebug(ctl, VSH_ERR_DEBUG, "%s: <%s> trying as nwfilter binding port dev\n",
|
|
|
|
cmd->def->name, optname);
|
|
|
|
binding = virNWFilterBindingLookupByPortDev(priv->conn, n);
|
|
|
|
|
|
|
|
if (!binding)
|
2023-03-09 15:54:58 +01:00
|
|
|
vshError(ctl, _("failed to get nwfilter binding '%1$s'"), n);
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
return binding;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-binding-create" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_binding_create[] = {
|
|
|
|
{.name = "help",
|
|
|
|
.data = N_("create a network filter binding from an XML file")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Create a new network filter binding.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_binding_create[] = {
|
|
|
|
VIRSH_COMMON_OPT_FILE(N_("file containing an XML network "
|
|
|
|
"filter binding description")),
|
2021-08-26 14:32:35 +02:00
|
|
|
{.name = "validate",
|
|
|
|
.type = VSH_OT_BOOL,
|
|
|
|
.help = N_("validate the XML against the schema")
|
|
|
|
},
|
2018-05-09 17:44:35 +01:00
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterBindingCreate(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
|
|
|
virNWFilterBindingPtr binding;
|
|
|
|
const char *from = NULL;
|
2023-02-01 16:08:22 +01:00
|
|
|
g_autofree char *buffer = NULL;
|
2021-08-26 14:32:35 +02:00
|
|
|
unsigned int flags = 0;
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
if (vshCommandOptStringReq(ctl, cmd, "file", &from) < 0)
|
|
|
|
return false;
|
|
|
|
|
2021-08-26 14:32:35 +02:00
|
|
|
if (vshCommandOptBool(cmd, "validate"))
|
|
|
|
flags |= VIR_NWFILTER_BINDING_CREATE_VALIDATE;
|
|
|
|
|
2018-05-09 17:44:35 +01:00
|
|
|
if (virFileReadAll(from, VSH_MAX_XML_FILE, &buffer) < 0)
|
|
|
|
return false;
|
|
|
|
|
2021-08-26 14:32:35 +02:00
|
|
|
binding = virNWFilterBindingCreateXML(priv->conn, buffer, flags);
|
2018-05-09 17:44:35 +01:00
|
|
|
|
2021-09-24 01:49:08 +02:00
|
|
|
if (!binding) {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshError(ctl, _("Failed to create network filter from %1$s"), from);
|
2021-09-24 01:49:08 +02:00
|
|
|
return false;
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
2021-09-24 01:49:08 +02:00
|
|
|
|
2023-03-09 15:54:58 +01:00
|
|
|
vshPrintExtra(ctl, _("Network filter binding on %1$s created from %2$s\n"),
|
2021-09-24 01:49:08 +02:00
|
|
|
virNWFilterBindingGetPortDev(binding), from);
|
|
|
|
virNWFilterBindingFree(binding);
|
|
|
|
return true;
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-binding-delete" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_binding_delete[] = {
|
|
|
|
{.name = "help",
|
|
|
|
.data = N_("delete a network filter binding")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Delete a given network filter binding.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_binding_delete[] = {
|
|
|
|
{.name = "binding",
|
|
|
|
.type = VSH_OT_DATA,
|
|
|
|
.flags = VSH_OFLAG_REQ,
|
|
|
|
.help = N_("network filter binding port dev"),
|
|
|
|
.completer = virshNWFilterBindingNameCompleter,
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterBindingDelete(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
|
|
|
virNWFilterBindingPtr binding;
|
|
|
|
bool ret = true;
|
|
|
|
const char *portdev;
|
|
|
|
|
|
|
|
if (!(binding = virshCommandOptNWFilterBinding(ctl, cmd, &portdev)))
|
|
|
|
return false;
|
|
|
|
|
|
|
|
if (virNWFilterBindingDelete(binding) == 0) {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshPrintExtra(ctl, _("Network filter binding on %1$s deleted\n"), portdev);
|
2018-05-09 17:44:35 +01:00
|
|
|
} else {
|
2023-03-09 15:54:58 +01:00
|
|
|
vshError(ctl, _("Failed to delete network filter binding on %1$s"), portdev);
|
2018-05-09 17:44:35 +01:00
|
|
|
ret = false;
|
|
|
|
}
|
|
|
|
|
|
|
|
virNWFilterBindingFree(binding);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-binding-dumpxml" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_binding_dumpxml[] = {
|
|
|
|
{.name = "help",
|
|
|
|
.data = N_("network filter information in XML")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Output the network filter information as an XML dump to stdout.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_binding_dumpxml[] = {
|
|
|
|
{.name = "binding",
|
|
|
|
.type = VSH_OT_DATA,
|
|
|
|
.flags = VSH_OFLAG_REQ,
|
|
|
|
.help = N_("network filter binding portdev"),
|
|
|
|
.completer = virshNWFilterBindingNameCompleter,
|
|
|
|
},
|
2022-06-16 16:29:54 +01:00
|
|
|
{.name = "xpath",
|
|
|
|
.type = VSH_OT_STRING,
|
virsh: Require --xpath for *dumpxml
Historically, the dumpxml command reject any unknown arguments,
for instance:
virsh dumpxml fedora xxx
However, after v8.5.0-rc1~31 the second argument ('xxx') is
treated as an XPath, but it's not that clearly visible.
Therefore, require the --xpath switch, like this:
virsh dumpxml fedora --xpath xxx
Yes, this breaks already released virsh, but I think we can argue
that the pool of users of this particular function is very small.
We also document the argument being mandatory:
dumpxml [--inactive] [--security-info] [--update-cpu] [--migratable]
[--xpath EXPRESSION] [--wrap] domain
The sooner we do this change, the better.
The same applies for other *dumpxml functions (net-dumpxml,
pool-dumpxml, vol-dumpxl to name a few).
Resolves: https://bugzilla.redhat.com/show_bug.cgi?id=2103524
Signed-off-by: Michal Privoznik <mprivozn@redhat.com>
Reviewed-by: Peter Krempa <pkrempa@redhat.com>
2022-07-08 12:45:42 +02:00
|
|
|
.flags = VSH_OFLAG_REQ_OPT,
|
2022-06-16 16:29:54 +01:00
|
|
|
.completer = virshCompleteEmpty,
|
|
|
|
.help = N_("xpath expression to filter the XML document")
|
|
|
|
},
|
|
|
|
{.name = "wrap",
|
|
|
|
.type = VSH_OT_BOOL,
|
|
|
|
.help = N_("wrap xpath results in an common root element"),
|
|
|
|
},
|
2018-05-09 17:44:35 +01:00
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
|
|
|
cmdNWFilterBindingDumpXML(vshControl *ctl, const vshCmd *cmd)
|
|
|
|
{
|
|
|
|
virNWFilterBindingPtr binding;
|
|
|
|
bool ret = true;
|
2022-06-16 16:29:54 +01:00
|
|
|
g_autofree char *xml = NULL;
|
|
|
|
bool wrap = vshCommandOptBool(cmd, "wrap");
|
|
|
|
const char *xpath = NULL;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
if (!(binding = virshCommandOptNWFilterBinding(ctl, cmd, NULL)))
|
|
|
|
return false;
|
|
|
|
|
2022-06-16 16:29:54 +01:00
|
|
|
if (!(xml = virNWFilterBindingGetXMLDesc(binding, 0)))
|
|
|
|
goto cleanup;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
2022-06-16 16:29:54 +01:00
|
|
|
ret = virshDumpXML(ctl, xml, "nwfilter-binding", xpath, wrap);
|
|
|
|
|
|
|
|
cleanup:
|
2018-05-09 17:44:35 +01:00
|
|
|
virNWFilterBindingFree(binding);
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
virshNWFilterBindingSorter(const void *a, const void *b)
|
|
|
|
{
|
|
|
|
virNWFilterBindingPtr *fa = (virNWFilterBindingPtr *) a;
|
|
|
|
virNWFilterBindingPtr *fb = (virNWFilterBindingPtr *) b;
|
|
|
|
|
|
|
|
if (*fa && !*fb)
|
|
|
|
return -1;
|
|
|
|
|
|
|
|
if (!*fa)
|
|
|
|
return *fb != NULL;
|
|
|
|
|
|
|
|
return vshStrcasecmp(virNWFilterBindingGetPortDev(*fa),
|
|
|
|
virNWFilterBindingGetPortDev(*fb));
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
struct virshNWFilterBindingList {
|
|
|
|
virNWFilterBindingPtr *bindings;
|
|
|
|
size_t nbindings;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
static void
|
2021-03-11 08:16:13 +01:00
|
|
|
virshNWFilterBindingListFree(struct virshNWFilterBindingList *list)
|
2018-05-09 17:44:35 +01:00
|
|
|
{
|
|
|
|
size_t i;
|
|
|
|
|
|
|
|
if (list && list->bindings) {
|
|
|
|
for (i = 0; i < list->nbindings; i++) {
|
|
|
|
if (list->bindings[i])
|
|
|
|
virNWFilterBindingFree(list->bindings[i]);
|
|
|
|
}
|
2021-02-03 14:32:55 -05:00
|
|
|
g_free(list->bindings);
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
2021-02-03 14:32:55 -05:00
|
|
|
g_free(list);
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2021-03-11 08:16:13 +01:00
|
|
|
static struct virshNWFilterBindingList *
|
2018-05-09 17:44:35 +01:00
|
|
|
virshNWFilterBindingListCollect(vshControl *ctl,
|
|
|
|
unsigned int flags)
|
|
|
|
{
|
2021-03-11 08:16:13 +01:00
|
|
|
struct virshNWFilterBindingList *list = g_new0(struct virshNWFilterBindingList, 1);
|
2018-05-09 17:44:35 +01:00
|
|
|
int ret;
|
|
|
|
bool success = false;
|
2021-03-11 08:16:13 +01:00
|
|
|
virshControl *priv = ctl->privData;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
if ((ret = virConnectListAllNWFilterBindings(priv->conn,
|
|
|
|
&list->bindings,
|
|
|
|
flags)) < 0) {
|
|
|
|
/* there was an error during the call */
|
|
|
|
vshError(ctl, "%s", _("Failed to list network filter bindings"));
|
|
|
|
goto cleanup;
|
|
|
|
}
|
|
|
|
|
|
|
|
list->nbindings = ret;
|
|
|
|
|
|
|
|
/* sort the list */
|
|
|
|
if (list->bindings && list->nbindings > 1)
|
|
|
|
qsort(list->bindings, list->nbindings,
|
|
|
|
sizeof(*list->bindings), virshNWFilterBindingSorter);
|
|
|
|
|
|
|
|
success = true;
|
|
|
|
|
|
|
|
cleanup:
|
|
|
|
if (!success) {
|
2022-01-28 18:42:45 +01:00
|
|
|
g_clear_pointer(&list, virshNWFilterBindingListFree);
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
return list;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
* "nwfilter-binding-list" command
|
|
|
|
*/
|
|
|
|
static const vshCmdInfo info_nwfilter_binding_list[] = {
|
|
|
|
{.name = "help",
|
|
|
|
.data = N_("list network filter bindings")
|
|
|
|
},
|
|
|
|
{.name = "desc",
|
|
|
|
.data = N_("Returns list of network filter bindings.")
|
|
|
|
},
|
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static const vshCmdOptDef opts_nwfilter_binding_list[] = {
|
|
|
|
{.name = NULL}
|
|
|
|
};
|
|
|
|
|
|
|
|
static bool
|
2019-10-14 14:44:29 +02:00
|
|
|
cmdNWFilterBindingList(vshControl *ctl, const vshCmd *cmd G_GNUC_UNUSED)
|
2018-05-09 17:44:35 +01:00
|
|
|
{
|
|
|
|
size_t i;
|
2018-09-21 16:17:15 +02:00
|
|
|
bool ret = false;
|
2021-03-11 08:16:13 +01:00
|
|
|
struct virshNWFilterBindingList *list = NULL;
|
2021-08-11 15:12:02 +02:00
|
|
|
g_autoptr(vshTable) table = NULL;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
if (!(list = virshNWFilterBindingListCollect(ctl, 0)))
|
|
|
|
return false;
|
|
|
|
|
2018-09-21 16:17:15 +02:00
|
|
|
table = vshTableNew(_("Port Dev"), _("Filter"), NULL);
|
|
|
|
if (!table)
|
|
|
|
goto cleanup;
|
2018-05-09 17:44:35 +01:00
|
|
|
|
|
|
|
for (i = 0; i < list->nbindings; i++) {
|
|
|
|
virNWFilterBindingPtr binding = list->bindings[i];
|
|
|
|
|
2018-09-21 16:17:15 +02:00
|
|
|
if (vshTableRowAppend(table,
|
|
|
|
virNWFilterBindingGetPortDev(binding),
|
|
|
|
virNWFilterBindingGetFilterName(binding),
|
|
|
|
NULL) < 0)
|
|
|
|
goto cleanup;
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
|
|
|
|
2018-09-21 16:17:15 +02:00
|
|
|
vshTablePrintToStdout(table, ctl);
|
|
|
|
|
|
|
|
ret = true;
|
|
|
|
cleanup:
|
2018-05-09 17:44:35 +01:00
|
|
|
virshNWFilterBindingListFree(list);
|
2018-09-21 16:17:15 +02:00
|
|
|
return ret;
|
2018-05-09 17:44:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2012-08-20 16:56:03 -06:00
|
|
|
const vshCmdDef nwfilterCmds[] = {
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = "nwfilter-define",
|
|
|
|
.handler = cmdNWFilterDefine,
|
|
|
|
.opts = opts_nwfilter_define,
|
|
|
|
.info = info_nwfilter_define,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-dumpxml",
|
|
|
|
.handler = cmdNWFilterDumpXML,
|
|
|
|
.opts = opts_nwfilter_dumpxml,
|
|
|
|
.info = info_nwfilter_dumpxml,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-edit",
|
|
|
|
.handler = cmdNWFilterEdit,
|
|
|
|
.opts = opts_nwfilter_edit,
|
|
|
|
.info = info_nwfilter_edit,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-list",
|
|
|
|
.handler = cmdNWFilterList,
|
|
|
|
.opts = opts_nwfilter_list,
|
|
|
|
.info = info_nwfilter_list,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-undefine",
|
|
|
|
.handler = cmdNWFilterUndefine,
|
|
|
|
.opts = opts_nwfilter_undefine,
|
|
|
|
.info = info_nwfilter_undefine,
|
|
|
|
.flags = 0
|
|
|
|
},
|
2018-05-09 17:44:35 +01:00
|
|
|
{.name = "nwfilter-binding-create",
|
|
|
|
.handler = cmdNWFilterBindingCreate,
|
|
|
|
.opts = opts_nwfilter_binding_create,
|
|
|
|
.info = info_nwfilter_binding_create,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-binding-delete",
|
|
|
|
.handler = cmdNWFilterBindingDelete,
|
|
|
|
.opts = opts_nwfilter_binding_delete,
|
|
|
|
.info = info_nwfilter_binding_delete,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-binding-dumpxml",
|
|
|
|
.handler = cmdNWFilterBindingDumpXML,
|
|
|
|
.opts = opts_nwfilter_binding_dumpxml,
|
|
|
|
.info = info_nwfilter_binding_dumpxml,
|
|
|
|
.flags = 0
|
|
|
|
},
|
|
|
|
{.name = "nwfilter-binding-list",
|
|
|
|
.handler = cmdNWFilterBindingList,
|
|
|
|
.opts = opts_nwfilter_binding_list,
|
|
|
|
.info = info_nwfilter_binding_list,
|
|
|
|
.flags = 0
|
|
|
|
},
|
2013-02-07 16:25:10 +01:00
|
|
|
{.name = NULL}
|
2012-07-23 15:19:04 +08:00
|
|
|
};
|