Don't check validity of missing attributes in DNS SRV XML

This fixes a crash if one of them is missing.

https://bugzilla.redhat.com/show_bug.cgi?id=988718
(cherry picked from commit 461fd86a661f32a9aa8044190b2a63b05290332f)
This commit is contained in:
Ján Tomko 2013-07-26 12:11:21 +02:00
parent 90688b148c
commit 80fffee94b

View File

@ -920,7 +920,7 @@ virNetworkDNSSrvDefParseXML(const char *networkName,
" of network %s"), networkName); " of network %s"), networkName);
goto error; goto error;
} }
if (strlen(def->service) > DNS_RECORD_LENGTH_SRV) { if (def->service && strlen(def->service) > DNS_RECORD_LENGTH_SRV) {
virReportError(VIR_ERR_XML_DETAIL, virReportError(VIR_ERR_XML_DETAIL,
_("Service name '%s' in network %s is too long, limit is %d bytes"), _("Service name '%s' in network %s is too long, limit is %d bytes"),
def->service, networkName, DNS_RECORD_LENGTH_SRV); def->service, networkName, DNS_RECORD_LENGTH_SRV);
@ -936,7 +936,8 @@ virNetworkDNSSrvDefParseXML(const char *networkName,
} }
/* Check whether protocol value is the supported one */ /* Check whether protocol value is the supported one */
if (STRNEQ(def->protocol, "tcp") && (STRNEQ(def->protocol, "udp"))) { if (def->protocol && STRNEQ(def->protocol, "tcp") &&
(STRNEQ(def->protocol, "udp"))) {
virReportError(VIR_ERR_XML_DETAIL, virReportError(VIR_ERR_XML_DETAIL,
_("Invalid protocol attribute value '%s' " _("Invalid protocol attribute value '%s' "
" in DNS SRV record of network %s"), " in DNS SRV record of network %s"),