mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-09 22:45:21 +00:00
Don't ignore errors parsing nwfilter rules
For inexplicable reasons, the nwfilter XML parser is intentionally
ignoring errors that arise during parsing. As well as meaning that
users don't get any feedback on their XML mistakes, this will lead
it to silently drop data in OOM conditions.
Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
(cherry picked from commit 4f2094346d
)
This commit is contained in:
parent
f036740814
commit
caefceb668
@ -2369,9 +2369,7 @@ virNWFilterRuleParse(xmlNodePtr node)
|
|||||||
if (virNWFilterRuleDetailsParse(cur,
|
if (virNWFilterRuleDetailsParse(cur,
|
||||||
ret,
|
ret,
|
||||||
virAttr[i].att) < 0) {
|
virAttr[i].att) < 0) {
|
||||||
/* we ignore malformed rules
|
|
||||||
goto err_exit;
|
goto err_exit;
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
@ -2572,11 +2570,13 @@ virNWFilterDefParseXML(xmlXPathContextPtr ctxt) {
|
|||||||
if (VIR_ALLOC(entry) < 0)
|
if (VIR_ALLOC(entry) < 0)
|
||||||
goto cleanup;
|
goto cleanup;
|
||||||
|
|
||||||
/* ignore malformed rule and include elements */
|
if (xmlStrEqual(curr->name, BAD_CAST "rule")) {
|
||||||
if (xmlStrEqual(curr->name, BAD_CAST "rule"))
|
if (!(entry->rule = virNWFilterRuleParse(curr)))
|
||||||
entry->rule = virNWFilterRuleParse(curr);
|
goto cleanup;
|
||||||
else if (xmlStrEqual(curr->name, BAD_CAST "filterref"))
|
} else if (xmlStrEqual(curr->name, BAD_CAST "filterref")) {
|
||||||
entry->include = virNWFilterIncludeParse(curr);
|
if (!(entry->include = virNWFilterIncludeParse(curr)))
|
||||||
|
goto cleanup;
|
||||||
|
}
|
||||||
|
|
||||||
if (entry->rule || entry->include) {
|
if (entry->rule || entry->include) {
|
||||||
if (VIR_REALLOC_N(ret->filterEntries, ret->nentries+1) < 0) {
|
if (VIR_REALLOC_N(ret->filterEntries, ret->nentries+1) < 0) {
|
||||||
|
@ -36,15 +36,12 @@ testCompareXMLToXMLFiles(const char *inxml, const char *outxml,
|
|||||||
|
|
||||||
virResetLastError();
|
virResetLastError();
|
||||||
|
|
||||||
if (!(dev = virNWFilterDefParseString(NULL, inXmlData)))
|
if (!(dev = virNWFilterDefParseString(NULL, inXmlData))) {
|
||||||
goto fail;
|
|
||||||
|
|
||||||
if (!!virGetLastError() != expect_error)
|
|
||||||
goto fail;
|
|
||||||
|
|
||||||
if (expect_error) {
|
if (expect_error) {
|
||||||
/* need to suppress the errors */
|
|
||||||
virResetLastError();
|
virResetLastError();
|
||||||
|
goto done;
|
||||||
|
}
|
||||||
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(actual = virNWFilterDefFormat(dev)))
|
if (!(actual = virNWFilterDefFormat(dev)))
|
||||||
@ -55,6 +52,7 @@ testCompareXMLToXMLFiles(const char *inxml, const char *outxml,
|
|||||||
goto fail;
|
goto fail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
done:
|
||||||
ret = 0;
|
ret = 0;
|
||||||
|
|
||||||
fail:
|
fail:
|
||||||
|
Loading…
Reference in New Issue
Block a user