mirror of
https://gitlab.com/libvirt/libvirt.git
synced 2025-01-28 07:25:17 +00:00
virNetworkDNSHostDefParseXML: Refactor parsing
Use 'virXMLNodeGetSubelementList' instead of looping through XML nodes and modernize the code. Signed-off-by: Peter Krempa <pkrempa@redhat.com> Reviewed-by: Michal Privoznik <mprivozn@redhat.com>
This commit is contained in:
parent
24b769a25b
commit
d0ee4e39bf
@ -655,63 +655,61 @@ virNetworkDNSHostDefParseXML(const char *networkName,
|
|||||||
virNetworkDNSHostDef *def,
|
virNetworkDNSHostDef *def,
|
||||||
bool partialOkay)
|
bool partialOkay)
|
||||||
{
|
{
|
||||||
xmlNodePtr cur;
|
g_autofree xmlNodePtr *hostnameNodes = NULL;
|
||||||
g_autofree char *ip = NULL;
|
size_t nhostnameNodes = virXMLNodeGetSubelementList(node, "hostname", &hostnameNodes);
|
||||||
|
size_t i;
|
||||||
|
g_auto(GStrv) hostnames = NULL;
|
||||||
|
g_autofree char *ip = virXMLPropString(node, "ip");
|
||||||
|
|
||||||
if (!(ip = virXMLPropString(node, "ip")) && !partialOkay) {
|
if (nhostnameNodes > 0) {
|
||||||
|
hostnames = g_new0(char *, nhostnameNodes + 1);
|
||||||
|
|
||||||
|
for (i = 0; i < nhostnameNodes; i++) {
|
||||||
|
if (!(hostnames[i] = virXMLNodeContentString(hostnameNodes[i])))
|
||||||
|
return -1;
|
||||||
|
|
||||||
|
if (*hostnames[i] == '\0') {
|
||||||
virReportError(VIR_ERR_XML_DETAIL,
|
virReportError(VIR_ERR_XML_DETAIL,
|
||||||
_("Missing IP address in network '%1$s' DNS HOST record"),
|
_("Missing hostname in network '%1$s' DNS HOST record"),
|
||||||
networkName);
|
networkName);
|
||||||
goto error;
|
return -1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (!partialOkay) {
|
||||||
|
virReportError(VIR_ERR_XML_DETAIL,
|
||||||
|
_("Missing hostname in network '%1$s' DNS HOST record"),
|
||||||
|
networkName);
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ip && (virSocketAddrParse(&def->ip, ip, AF_UNSPEC) < 0)) {
|
if (ip) {
|
||||||
|
if (virSocketAddrParse(&def->ip, ip, AF_UNSPEC) < 0) {
|
||||||
virReportError(VIR_ERR_XML_DETAIL,
|
virReportError(VIR_ERR_XML_DETAIL,
|
||||||
_("Invalid IP address in network '%1$s' DNS HOST record"),
|
_("Invalid IP address in network '%1$s' DNS HOST record"),
|
||||||
networkName);
|
networkName);
|
||||||
goto error;
|
return -1;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
cur = node->children;
|
if (!partialOkay) {
|
||||||
while (cur != NULL) {
|
|
||||||
if (cur->type == XML_ELEMENT_NODE &&
|
|
||||||
virXMLNodeNameEqual(cur, "hostname")) {
|
|
||||||
if (cur->children != NULL) {
|
|
||||||
g_autofree char *name = virXMLNodeContentString(cur);
|
|
||||||
|
|
||||||
if (!name)
|
|
||||||
goto error;
|
|
||||||
|
|
||||||
if (!name[0]) {
|
|
||||||
virReportError(VIR_ERR_XML_DETAIL,
|
virReportError(VIR_ERR_XML_DETAIL,
|
||||||
_("Missing hostname in network '%1$s' DNS HOST record"),
|
_("Missing IP address in network '%1$s' DNS HOST record"),
|
||||||
networkName);
|
networkName);
|
||||||
goto error;
|
return -1;
|
||||||
}
|
|
||||||
VIR_APPEND_ELEMENT(def->names, def->nnames, name);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
cur = cur->next;
|
|
||||||
}
|
|
||||||
if (def->nnames == 0 && !partialOkay) {
|
|
||||||
virReportError(VIR_ERR_XML_DETAIL,
|
|
||||||
_("Missing hostname in network '%1$s' DNS HOST record"),
|
|
||||||
networkName);
|
|
||||||
goto error;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!VIR_SOCKET_ADDR_VALID(&def->ip) && def->nnames == 0) {
|
if (nhostnameNodes == 0) {
|
||||||
virReportError(VIR_ERR_XML_DETAIL,
|
virReportError(VIR_ERR_XML_DETAIL,
|
||||||
_("Missing ip and hostname in network '%1$s' DNS HOST record"),
|
_("Missing ip and hostname in network '%1$s' DNS HOST record"),
|
||||||
networkName);
|
networkName);
|
||||||
goto error;
|
return -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
def->names = g_steal_pointer(&hostnames);
|
||||||
|
def->nnames = nhostnameNodes;
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
error:
|
|
||||||
virNetworkDNSHostDefClear(def);
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user