2
0
mirror of https://gitlab.isc.org/isc-projects/bind9 synced 2025-08-22 10:10:06 +00:00

1964. [func] Seperate out MX and SRV to CNAME checks. [RT #15723]

This commit is contained in:
Mark Andrews 2006-01-05 23:45:34 +00:00
parent 1eb1e1e838
commit dc6da18ccb
13 changed files with 330 additions and 103 deletions

View File

@ -1,3 +1,5 @@
1964. [func] Seperate out MX and SRV to CNAME checks. [RT #15723]
1963. [port] Tru64 4.0E doesn't support send() and recv(). 1963. [port] Tru64 4.0E doesn't support send() and recv().
[RT #15586] [RT #15586]

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: check-tool.c,v 1.21 2005/09/30 08:25:38 marka Exp $ */ /* $Id: check-tool.c,v 1.22 2006/01/05 23:45:33 marka Exp $ */
/*! \file */ /*! \file */
@ -71,7 +71,9 @@ unsigned int zone_options = DNS_ZONEOPT_CHECKNS |
DNS_ZONEOPT_MANYERRORS | DNS_ZONEOPT_MANYERRORS |
DNS_ZONEOPT_CHECKNAMES | DNS_ZONEOPT_CHECKNAMES |
DNS_ZONEOPT_CHECKINTEGRITY | DNS_ZONEOPT_CHECKINTEGRITY |
DNS_ZONEOPT_CHECKWILDCARD; DNS_ZONEOPT_CHECKWILDCARD |
DNS_ZONEOPT_WARNMXCNAME |
DNS_ZONEOPT_WARNSRVCNAME;
/* /*
* This needs to match the list in bin/named/log.c. * This needs to match the list in bin/named/log.c.
@ -128,10 +130,11 @@ checkns(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner,
case 0: case 0:
if (strcasecmp(ai->ai_canonname, namebuf) != 0) { if (strcasecmp(ai->ai_canonname, namebuf) != 0) {
dns_zone_log(zone, ISC_LOG_ERROR, dns_zone_log(zone, ISC_LOG_ERROR,
"%s/NS '%s' (out of zone) " "%s/NS '%s' (out of zone) "
"is a CNAME (illegal)", "is a CNAME (illegal)",
ownerbuf, namebuf); ownerbuf, namebuf);
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0 */
/* answer = ISC_FALSE; */
} }
break; break;
case EAI_NONAME: case EAI_NONAME:
@ -141,7 +144,8 @@ checkns(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner,
dns_zone_log(zone, ISC_LOG_ERROR, "%s/NS '%s' (out of zone) " dns_zone_log(zone, ISC_LOG_ERROR, "%s/NS '%s' (out of zone) "
"has no addresses records (A or AAAA)", "has no addresses records (A or AAAA)",
ownerbuf, namebuf); ownerbuf, namebuf);
return (ISC_FALSE); /* XXX950 make fatal for 9.5.0 */
return (ISC_TRUE);
default: default:
dns_zone_log(zone, ISC_LOG_WARNING, dns_zone_log(zone, ISC_LOG_WARNING,
@ -175,7 +179,8 @@ checkns(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner,
ownerbuf, namebuf, ownerbuf, namebuf,
inet_ntop(AF_INET, rdata.data, inet_ntop(AF_INET, rdata.data,
addrbuf, sizeof(addrbuf))); addrbuf, sizeof(addrbuf)));
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0 */
/* answer = ISC_FALSE; */
} }
dns_rdata_reset(&rdata); dns_rdata_reset(&rdata);
result = dns_rdataset_next(a); result = dns_rdataset_next(a);
@ -203,7 +208,8 @@ checkns(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner,
ownerbuf, namebuf, ownerbuf, namebuf,
inet_ntop(AF_INET6, rdata.data, inet_ntop(AF_INET6, rdata.data,
addrbuf, sizeof(addrbuf))); addrbuf, sizeof(addrbuf)));
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0. */
/* answer = ISC_FALSE; */
} }
dns_rdata_reset(&rdata); dns_rdata_reset(&rdata);
result = dns_rdataset_next(aaaa); result = dns_rdataset_next(aaaa);
@ -246,7 +252,8 @@ checkns(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner,
ownerbuf, namebuf, type, ownerbuf, namebuf, type,
inet_ntop(cur->ai_family, ptr, inet_ntop(cur->ai_family, ptr,
addrbuf, sizeof(addrbuf))); addrbuf, sizeof(addrbuf)));
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0. */
/* answer = ISC_FALSE; */
} }
} }
freeaddrinfo(ai); freeaddrinfo(ai);
@ -263,6 +270,8 @@ checkmx(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner) {
char namebuf[DNS_NAME_FORMATSIZE + 1]; char namebuf[DNS_NAME_FORMATSIZE + 1];
char ownerbuf[DNS_NAME_FORMATSIZE]; char ownerbuf[DNS_NAME_FORMATSIZE];
int result; int result;
int level = ISC_LOG_ERROR;
isc_boolean_t answer = ISC_TRUE;
memset(&hints, 0, sizeof(hints)); memset(&hints, 0, sizeof(hints));
hints.ai_flags = AI_CANONNAME; hints.ai_flags = AI_CANONNAME;
@ -282,13 +291,21 @@ checkmx(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner) {
dns_name_format(name, namebuf, sizeof(namebuf) - 1); dns_name_format(name, namebuf, sizeof(namebuf) - 1);
switch (result) { switch (result) {
case 0: case 0:
if (strcasecmp(ai->ai_canonname, namebuf) != 0) if (strcasecmp(ai->ai_canonname, namebuf) != 0) {
dns_zone_log(zone, ISC_LOG_WARNING, if ((zone_options & DNS_ZONEOPT_WARNMXCNAME) != 0)
"%s/MX '%s' (out of zone) " level = ISC_LOG_WARNING;
"is a CNAME (illegal)", if ((zone_options & DNS_ZONEOPT_IGNOREMXCNAME) == 0) {
ownerbuf, namebuf); dns_zone_log(zone, ISC_LOG_WARNING,
"%s/MX '%s' (out of zone) "
"is a CNAME (illegal)",
ownerbuf, namebuf);
if (level == ISC_LOG_ERROR)
answer = ISC_FALSE;
}
}
freeaddrinfo(ai); freeaddrinfo(ai);
break; return (answer);
case EAI_NONAME: case EAI_NONAME:
#if defined(EAI_NODATA) && (EAI_NODATA != EAI_NONAME) #if defined(EAI_NODATA) && (EAI_NODATA != EAI_NONAME)
case EAI_NODATA: case EAI_NODATA:
@ -296,7 +313,8 @@ checkmx(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner) {
dns_zone_log(zone, ISC_LOG_ERROR, "%s/MX '%s' (out of zone) " dns_zone_log(zone, ISC_LOG_ERROR, "%s/MX '%s' (out of zone) "
"has no addresses records (A or AAAA)", "has no addresses records (A or AAAA)",
ownerbuf, namebuf); ownerbuf, namebuf);
return (ISC_FALSE); /* XXX950 make fatal for 9.5.0. */
return (ISC_TRUE);
default: default:
dns_zone_log(zone, ISC_LOG_WARNING, dns_zone_log(zone, ISC_LOG_WARNING,
@ -315,6 +333,8 @@ checksrv(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner) {
char namebuf[DNS_NAME_FORMATSIZE + 1]; char namebuf[DNS_NAME_FORMATSIZE + 1];
char ownerbuf[DNS_NAME_FORMATSIZE]; char ownerbuf[DNS_NAME_FORMATSIZE];
int result; int result;
int level = ISC_LOG_ERROR;
isc_boolean_t answer = ISC_TRUE;
memset(&hints, 0, sizeof(hints)); memset(&hints, 0, sizeof(hints));
hints.ai_flags = AI_CANONNAME; hints.ai_flags = AI_CANONNAME;
@ -334,13 +354,21 @@ checksrv(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner) {
dns_name_format(name, namebuf, sizeof(namebuf) - 1); dns_name_format(name, namebuf, sizeof(namebuf) - 1);
switch (result) { switch (result) {
case 0: case 0:
if (strcasecmp(ai->ai_canonname, namebuf) != 0) if (strcasecmp(ai->ai_canonname, namebuf) != 0) {
dns_zone_log(zone, ISC_LOG_WARNING, if ((zone_options & DNS_ZONEOPT_WARNSRVCNAME) != 0)
"%s/SRV '%s' (out of zone) " level = ISC_LOG_WARNING;
"is a CNAME (illegal)", if ((zone_options & DNS_ZONEOPT_IGNORESRVCNAME) == 0) {
ownerbuf, namebuf); dns_zone_log(zone, level,
"%s/SRV '%s' (out of zone) "
"is a CNAME (illegal)",
ownerbuf, namebuf);
if (level == ISC_LOG_ERROR)
answer = ISC_FALSE;
}
}
freeaddrinfo(ai); freeaddrinfo(ai);
break; return (answer);
case EAI_NONAME: case EAI_NONAME:
#if defined(EAI_NODATA) && (EAI_NODATA != EAI_NONAME) #if defined(EAI_NODATA) && (EAI_NODATA != EAI_NONAME)
case EAI_NODATA: case EAI_NODATA:
@ -348,7 +376,8 @@ checksrv(dns_zone_t *zone, dns_name_t *name, dns_name_t *owner) {
dns_zone_log(zone, ISC_LOG_ERROR, "%s/SRV '%s' (out of zone) " dns_zone_log(zone, ISC_LOG_ERROR, "%s/SRV '%s' (out of zone) "
"has no addresses records (A or AAAA)", "has no addresses records (A or AAAA)",
ownerbuf, namebuf); ownerbuf, namebuf);
return (ISC_FALSE); /* XXX950 make fatal for 9.5.0. */
return (ISC_TRUE);
default: default:
dns_zone_log(zone, ISC_LOG_WARNING, dns_zone_log(zone, ISC_LOG_WARNING,

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: named-checkconf.c,v 1.39 2005/09/18 07:16:17 marka Exp $ */ /* $Id: named-checkconf.c,v 1.40 2006/01/05 23:45:33 marka Exp $ */
/*! \file */ /*! \file */
@ -225,6 +225,42 @@ configure_zone(const char *vclass, const char *view, cfg_obj_t *zconfig,
zone_options &= ~DNS_ZONEOPT_CHECKINTEGRITY; zone_options &= ~DNS_ZONEOPT_CHECKINTEGRITY;
} }
obj = NULL;
if (get_maps(maps, "check-mx-cname", &obj)) {
if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
zone_options |= DNS_ZONEOPT_WARNMXCNAME;
zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
} else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
zone_options &= ~DNS_ZONEOPT_WARNMXCNAME;
zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
} else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
zone_options |= DNS_ZONEOPT_WARNMXCNAME;
zone_options |= DNS_ZONEOPT_IGNOREMXCNAME;
} else
INSIST(0);
} else {
zone_options |= DNS_ZONEOPT_WARNMXCNAME;
zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
}
obj = NULL;
if (get_maps(maps, "check-srv-cname", &obj)) {
if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
} else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
zone_options &= ~DNS_ZONEOPT_WARNSRVCNAME;
zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
} else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
zone_options |= DNS_ZONEOPT_IGNORESRVCNAME;
} else
INSIST(0);
} else {
zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
}
obj = NULL; obj = NULL;
if (get_maps(maps, "check-sibling", &obj)) { if (get_maps(maps, "check-sibling", &obj)) {
if (cfg_obj_asboolean(obj)) if (cfg_obj_asboolean(obj))

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: named-checkzone.c,v 1.41 2005/09/18 07:16:17 marka Exp $ */ /* $Id: named-checkzone.c,v 1.42 2006/01/05 23:45:33 marka Exp $ */
/*! \file */ /*! \file */
@ -77,7 +77,8 @@ usage(void) {
"[-f inputformat] [-F outputformat] " "[-f inputformat] [-F outputformat] "
"[-t directory] [-w directory] [-k (ignore|warn|fail)] " "[-t directory] [-w directory] [-k (ignore|warn|fail)] "
"[-n (ignore|warn|fail)] [-m (ignore|warn|fail)] " "[-n (ignore|warn|fail)] [-m (ignore|warn|fail)] "
"[-i (full|local|none)] [-W (ignore|warn)] " "[-i (full|local|none)] [-M (ignore|warn|fail)] "
"[-S (ignore|warn|fail)] [-W (ignore|warn)] "
"zonename filename\n", prog_name); "zonename filename\n", prog_name);
exit(1); exit(1);
} }
@ -134,8 +135,10 @@ main(int argc, char **argv) {
DNS_ZONEOPT_CHECKWILDCARD); DNS_ZONEOPT_CHECKWILDCARD);
} }
#define ARGCMP(X) (strcmp(isc_commandline_argument, X) == 0)
while ((c = isc_commandline_parse(argc, argv, while ((c = isc_commandline_parse(argc, argv,
"c:df:i:jk:m:n:qst:o:vw:DF:W:")) "c:df:i:jk:m:n:qst:o:vw:DF:M:S:W:"))
!= EOF) { != EOF) {
switch (c) { switch (c) {
case 'c': case 'c':
@ -147,35 +150,31 @@ main(int argc, char **argv) {
break; break;
case 'i': case 'i':
if (!strcmp(isc_commandline_argument, "full")) { if (ARGCMP("full")) {
zone_options |= DNS_ZONEOPT_CHECKINTEGRITY | zone_options |= DNS_ZONEOPT_CHECKINTEGRITY |
DNS_ZONEOPT_CHECKSIBLING; DNS_ZONEOPT_CHECKSIBLING;
docheckmx = ISC_TRUE; docheckmx = ISC_TRUE;
docheckns = ISC_TRUE; docheckns = ISC_TRUE;
dochecksrv = ISC_TRUE; dochecksrv = ISC_TRUE;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("full-sibling")) {
"full-sibling")) {
zone_options |= DNS_ZONEOPT_CHECKINTEGRITY; zone_options |= DNS_ZONEOPT_CHECKINTEGRITY;
zone_options &= ~DNS_ZONEOPT_CHECKSIBLING; zone_options &= ~DNS_ZONEOPT_CHECKSIBLING;
docheckmx = ISC_TRUE; docheckmx = ISC_TRUE;
docheckns = ISC_TRUE; docheckns = ISC_TRUE;
dochecksrv = ISC_TRUE; dochecksrv = ISC_TRUE;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("local")) {
"local")) {
zone_options |= DNS_ZONEOPT_CHECKINTEGRITY; zone_options |= DNS_ZONEOPT_CHECKINTEGRITY;
zone_options |= DNS_ZONEOPT_CHECKSIBLING; zone_options |= DNS_ZONEOPT_CHECKSIBLING;
docheckmx = ISC_FALSE; docheckmx = ISC_FALSE;
docheckns = ISC_FALSE; docheckns = ISC_FALSE;
dochecksrv = ISC_FALSE; dochecksrv = ISC_FALSE;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("local-sibling")) {
"local-sibling")) {
zone_options |= DNS_ZONEOPT_CHECKINTEGRITY; zone_options |= DNS_ZONEOPT_CHECKINTEGRITY;
zone_options &= ~DNS_ZONEOPT_CHECKSIBLING; zone_options &= ~DNS_ZONEOPT_CHECKSIBLING;
docheckmx = ISC_FALSE; docheckmx = ISC_FALSE;
docheckns = ISC_FALSE; docheckns = ISC_FALSE;
dochecksrv = ISC_FALSE; dochecksrv = ISC_FALSE;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("none")) {
"none")) {
zone_options &= ~DNS_ZONEOPT_CHECKINTEGRITY; zone_options &= ~DNS_ZONEOPT_CHECKINTEGRITY;
zone_options &= ~DNS_ZONEOPT_CHECKSIBLING; zone_options &= ~DNS_ZONEOPT_CHECKSIBLING;
docheckmx = ISC_FALSE; docheckmx = ISC_FALSE;
@ -201,15 +200,13 @@ main(int argc, char **argv) {
break; break;
case 'k': case 'k':
if (!strcmp(isc_commandline_argument, "warn")) { if (ARGCMP("warn")) {
zone_options |= DNS_ZONEOPT_CHECKNAMES; zone_options |= DNS_ZONEOPT_CHECKNAMES;
zone_options &= ~DNS_ZONEOPT_CHECKNAMESFAIL; zone_options &= ~DNS_ZONEOPT_CHECKNAMESFAIL;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("fail")) {
"fail")) {
zone_options |= DNS_ZONEOPT_CHECKNAMES | zone_options |= DNS_ZONEOPT_CHECKNAMES |
DNS_ZONEOPT_CHECKNAMESFAIL; DNS_ZONEOPT_CHECKNAMESFAIL;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("ignore")) {
"ignore")) {
zone_options &= ~(DNS_ZONEOPT_CHECKNAMES | zone_options &= ~(DNS_ZONEOPT_CHECKNAMES |
DNS_ZONEOPT_CHECKNAMESFAIL); DNS_ZONEOPT_CHECKNAMESFAIL);
} else { } else {
@ -220,13 +217,13 @@ main(int argc, char **argv) {
break; break;
case 'n': case 'n':
if (!strcmp(isc_commandline_argument, "ignore")) { if (ARGCMP("ignore")) {
zone_options &= ~(DNS_ZONEOPT_CHECKNS| zone_options &= ~(DNS_ZONEOPT_CHECKNS|
DNS_ZONEOPT_FATALNS); DNS_ZONEOPT_FATALNS);
} else if (!strcmp(isc_commandline_argument, "warn")) { } else if (ARGCMP("warn")) {
zone_options |= DNS_ZONEOPT_CHECKNS; zone_options |= DNS_ZONEOPT_CHECKNS;
zone_options &= ~DNS_ZONEOPT_FATALNS; zone_options &= ~DNS_ZONEOPT_FATALNS;
} else if (!strcmp(isc_commandline_argument, "fail")) { } else if (ARGCMP("fail")) {
zone_options |= DNS_ZONEOPT_CHECKNS| zone_options |= DNS_ZONEOPT_CHECKNS|
DNS_ZONEOPT_FATALNS; DNS_ZONEOPT_FATALNS;
} else { } else {
@ -237,15 +234,13 @@ main(int argc, char **argv) {
break; break;
case 'm': case 'm':
if (!strcmp(isc_commandline_argument, "warn")) { if (ARGCMP("warn")) {
zone_options |= DNS_ZONEOPT_CHECKMX; zone_options |= DNS_ZONEOPT_CHECKMX;
zone_options &= ~DNS_ZONEOPT_CHECKMXFAIL; zone_options &= ~DNS_ZONEOPT_CHECKMXFAIL;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("fail")) {
"fail")) {
zone_options |= DNS_ZONEOPT_CHECKMX | zone_options |= DNS_ZONEOPT_CHECKMX |
DNS_ZONEOPT_CHECKMXFAIL; DNS_ZONEOPT_CHECKMXFAIL;
} else if (!strcmp(isc_commandline_argument, } else if (ARGCMP("ignore")) {
"ignore")) {
zone_options &= ~(DNS_ZONEOPT_CHECKMX | zone_options &= ~(DNS_ZONEOPT_CHECKMX |
DNS_ZONEOPT_CHECKMXFAIL); DNS_ZONEOPT_CHECKMXFAIL);
} else { } else {
@ -276,10 +271,9 @@ main(int argc, char **argv) {
break; break;
case 's': case 's':
if (strcmp(isc_commandline_argument, "full") == 0) if (ARGCMP("full"))
outputstyle = &dns_master_style_full; outputstyle = &dns_master_style_full;
else if (strcmp(isc_commandline_argument, else if (ARGCMP("default")) {
"default") == 0) {
outputstyle = &dns_master_style_default; outputstyle = &dns_master_style_default;
} else { } else {
fprintf(stderr, fprintf(stderr,
@ -305,10 +299,44 @@ main(int argc, char **argv) {
dumpzone++; dumpzone++;
break; break;
case 'M':
if (ARGCMP("fail")) {
zone_options &= ~DNS_ZONEOPT_WARNMXCNAME;
zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
} else if (ARGCMP("warn")) {
zone_options |= DNS_ZONEOPT_WARNMXCNAME;
zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
} else if (ARGCMP("ignore")) {
zone_options |= DNS_ZONEOPT_WARNMXCNAME;
zone_options |= DNS_ZONEOPT_IGNOREMXCNAME;
} else {
fprintf(stderr, "invalid argument to -M: %s\n",
isc_commandline_argument);
exit(1);
}
break;
case 'S':
if (ARGCMP("fail")) {
zone_options &= ~DNS_ZONEOPT_WARNSRVCNAME;
zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
} else if (ARGCMP("warn")) {
zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
} else if (ARGCMP("ignore")) {
zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
zone_options |= DNS_ZONEOPT_IGNORESRVCNAME;
} else {
fprintf(stderr, "invalid argument to -S: %s\n",
isc_commandline_argument);
exit(1);
}
break;
case 'W': case 'W':
if (!strcmp(isc_commandline_argument, "warn")) if (ARGCMP("warn"))
zone_options |= DNS_ZONEOPT_CHECKWILDCARD; zone_options |= DNS_ZONEOPT_CHECKWILDCARD;
else if (!strcmp(isc_commandline_argument, "ignore")) else if (ARGCMP("ignore"))
zone_options &= ~DNS_ZONEOPT_CHECKWILDCARD; zone_options &= ~DNS_ZONEOPT_CHECKWILDCARD;
break; break;

View File

@ -18,7 +18,7 @@
- PERFORMANCE OF THIS SOFTWARE. - PERFORMANCE OF THIS SOFTWARE.
--> -->
<!-- $Id: named-checkzone.docbook,v 1.23 2005/08/24 23:53:55 marka Exp $ --> <!-- $Id: named-checkzone.docbook,v 1.24 2006/01/05 23:45:33 marka Exp $ -->
<refentry id="man.named-checkzone"> <refentry id="man.named-checkzone">
<refentryinfo> <refentryinfo>
<date>June 13, 2000</date> <date>June 13, 2000</date>
@ -63,9 +63,11 @@
<arg><option>-i <replaceable class="parameter">mode</replaceable></option></arg> <arg><option>-i <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-k <replaceable class="parameter">mode</replaceable></option></arg> <arg><option>-k <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-m <replaceable class="parameter">mode</replaceable></option></arg> <arg><option>-m <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-M <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-n <replaceable class="parameter">mode</replaceable></option></arg> <arg><option>-n <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-o <replaceable class="parameter">filename</replaceable></option></arg> <arg><option>-o <replaceable class="parameter">filename</replaceable></option></arg>
<arg><option>-s <replaceable class="parameter">style</replaceable></option></arg> <arg><option>-s <replaceable class="parameter">style</replaceable></option></arg>
<arg><option>-S <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-t <replaceable class="parameter">directory</replaceable></option></arg> <arg><option>-t <replaceable class="parameter">directory</replaceable></option></arg>
<arg><option>-w <replaceable class="parameter">directory</replaceable></option></arg> <arg><option>-w <replaceable class="parameter">directory</replaceable></option></arg>
<arg><option>-D</option></arg> <arg><option>-D</option></arg>
@ -80,6 +82,7 @@
<arg><option>-q</option></arg> <arg><option>-q</option></arg>
<arg><option>-v</option></arg> <arg><option>-v</option></arg>
<arg><option>-c <replaceable class="parameter">class</replaceable></option></arg> <arg><option>-c <replaceable class="parameter">class</replaceable></option></arg>
<arg><option>-C <replaceable class="parameter">mode</replaceable></option></arg>
<arg><option>-f <replaceable class="parameter">format</replaceable></option></arg> <arg><option>-f <replaceable class="parameter">format</replaceable></option></arg>
<arg><option>-F <replaceable class="parameter">format</replaceable></option></arg> <arg><option>-F <replaceable class="parameter">format</replaceable></option></arg>
<arg><option>-i <replaceable class="parameter">mode</replaceable></option></arg> <arg><option>-i <replaceable class="parameter">mode</replaceable></option></arg>
@ -264,6 +267,18 @@
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry>
<term>-M <replaceable class="parameter">mode</replaceable></term>
<listitem>
<para>
Check if a MX record refers to a CNAME.
Possible modes are <command>"fail"</command>,
<command>"warn"</command> (default) and
<command>"ignore"</command>.
</para>
</listitem>
</varlistentry>
<varlistentry> <varlistentry>
<term>-n <replaceable class="parameter">mode</replaceable></term> <term>-n <replaceable class="parameter">mode</replaceable></term>
<listitem> <listitem>
@ -309,6 +324,18 @@
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry>
<term>-S <replaceable class="parameter">mode</replaceable></term>
<listitem>
<para>
Check if a SRV record refers to a CNAME.
Possible modes are <command>"fail"</command>,
<command>"warn"</command> (default) and
<command>"ignore"</command>.
</para>
</listitem>
</varlistentry>
<varlistentry> <varlistentry>
<term>-t <replaceable class="parameter">directory</replaceable></term> <term>-t <replaceable class="parameter">directory</replaceable></term>
<listitem> <listitem>

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: config.c,v 1.66 2006/01/05 02:19:01 marka Exp $ */ /* $Id: config.c,v 1.67 2006/01/05 23:45:33 marka Exp $ */
/*! \file */ /*! \file */
@ -171,6 +171,8 @@ options {\n\
check-wildcard yes;\n\ check-wildcard yes;\n\
check-sibling yes;\n\ check-sibling yes;\n\
check-integrity yes;\n\ check-integrity yes;\n\
check-mx-cname warn;\n\
check-srv-cname warn;\n\
zero-no-soa-ttl yes;\n\ zero-no-soa-ttl yes;\n\
};\n\ };\n\
" "

View File

@ -17,7 +17,7 @@
- PERFORMANCE OF THIS SOFTWARE. - PERFORMANCE OF THIS SOFTWARE.
--> -->
<!-- $Id: named.conf.docbook,v 1.18 2006/01/05 02:19:01 marka Exp $ --> <!-- $Id: named.conf.docbook,v 1.19 2006/01/05 23:45:33 marka Exp $ -->
<refentry> <refentry>
<refentryinfo> <refentryinfo>
<date>Aug 13, 2004</date> <date>Aug 13, 2004</date>
@ -247,7 +247,9 @@ options {
check-names ( master | slave | response ) check-names ( master | slave | response )
( fail | warn | ignore ); ( fail | warn | ignore );
check-mx ( fail | warn | ignore ); check-mx ( fail | warn | ignore );
integrity-check <replaceable>boolean</replaceable>; check-integrity <replaceable>boolean</replaceable>;
check-mx-cname ( fail | warn | ignore );
check-srv-cname ( fail | warn | ignore );
cache-file <replaceable>quoted_string</replaceable>; cache-file <replaceable>quoted_string</replaceable>;
suppress-initial-notify <replaceable>boolean</replaceable>; // not yet implemented suppress-initial-notify <replaceable>boolean</replaceable>; // not yet implemented
preferred-glue <replaceable>string</replaceable>; preferred-glue <replaceable>string</replaceable>;
@ -391,7 +393,9 @@ view <replaceable>string</replaceable> <replaceable>optional_class</replaceable>
check-names ( master | slave | response ) check-names ( master | slave | response )
( fail | warn | ignore ); ( fail | warn | ignore );
check-mx ( fail | warn | ignore ); check-mx ( fail | warn | ignore );
integrity-check <replaceable>boolean</replaceable>; check-integrity <replaceable>boolean</replaceable>;
check-mx-cname ( fail | warn | ignore );
check-srv-cname ( fail | warn | ignore );
cache-file <replaceable>quoted_string</replaceable>; cache-file <replaceable>quoted_string</replaceable>;
suppress-initial-notify <replaceable>boolean</replaceable>; // not yet implemented suppress-initial-notify <replaceable>boolean</replaceable>; // not yet implemented
preferred-glue <replaceable>string</replaceable>; preferred-glue <replaceable>string</replaceable>;
@ -490,7 +494,9 @@ zone <replaceable>string</replaceable> <replaceable>optional_class</replaceable>
delegation-only <replaceable>boolean</replaceable>; delegation-only <replaceable>boolean</replaceable>;
check-names ( fail | warn | ignore ); check-names ( fail | warn | ignore );
check-mx ( fail | warn | ignore ); check-mx ( fail | warn | ignore );
integrity-check <replaceable>boolean</replaceable>; check-integrity <replaceable>boolean</replaceable>;
check-mx-cname ( fail | warn | ignore );
check-srv-cname ( fail | warn | ignore );
dialup <replaceable>dialuptype</replaceable>; dialup <replaceable>dialuptype</replaceable>;
ixfr-from-differences <replaceable>boolean</replaceable>; ixfr-from-differences <replaceable>boolean</replaceable>;
journal <replaceable>quoted_string</replaceable>; journal <replaceable>quoted_string</replaceable>;

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: zoneconf.c,v 1.127 2006/01/05 03:32:50 marka Exp $ */ /* $Id: zoneconf.c,v 1.128 2006/01/05 23:45:33 marka Exp $ */
/*% */ /*% */
@ -342,6 +342,7 @@ ns_zone_configure(cfg_obj_t *config, cfg_obj_t *vconfig, cfg_obj_t *zconfig,
isc_boolean_t alt; isc_boolean_t alt;
dns_view_t *view; dns_view_t *view;
isc_boolean_t check = ISC_FALSE, fail = ISC_FALSE; isc_boolean_t check = ISC_FALSE, fail = ISC_FALSE;
isc_boolean_t warn = ISC_FALSE, ignore = ISC_FALSE;
isc_boolean_t ixfrdiff; isc_boolean_t ixfrdiff;
dns_masterformat_t masterformat; dns_masterformat_t masterformat;
@ -682,6 +683,36 @@ ns_zone_configure(cfg_obj_t *config, cfg_obj_t *vconfig, cfg_obj_t *zconfig,
INSIST(obj != NULL); INSIST(obj != NULL);
dns_zone_setoption(zone, DNS_ZONEOPT_CHECKINTEGRITY, dns_zone_setoption(zone, DNS_ZONEOPT_CHECKINTEGRITY,
cfg_obj_asboolean(obj)); cfg_obj_asboolean(obj));
obj = NULL;
result = ns_config_get(maps, "check-mx-cname", &obj);
INSIST(obj != NULL);
if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
warn = ISC_TRUE;
ignore = ISC_FALSE;
} else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
warn = ignore = ISC_FALSE;
} else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
warn = ignore = ISC_TRUE;
} else
INSIST(0);
dns_zone_setoption(zone, DNS_ZONEOPT_WARNMXCNAME, warn);
dns_zone_setoption(zone, DNS_ZONEOPT_IGNOREMXCNAME, ignore);
obj = NULL;
result = ns_config_get(maps, "check-srv-cname", &obj);
INSIST(obj != NULL);
if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
warn = ISC_TRUE;
ignore = ISC_FALSE;
} else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
warn = ignore = ISC_FALSE;
} else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
warn = ignore = ISC_TRUE;
} else
INSIST(0);
dns_zone_setoption(zone, DNS_ZONEOPT_WARNSRVCNAME, warn);
dns_zone_setoption(zone, DNS_ZONEOPT_IGNORESRVCNAME, ignore);
} }
/* /*

View File

@ -18,7 +18,7 @@
- PERFORMANCE OF THIS SOFTWARE. - PERFORMANCE OF THIS SOFTWARE.
--> -->
<!-- File: $Id: Bv9ARM-book.xml,v 1.289 2006/01/05 11:52:32 marka Exp $ --> <!-- File: $Id: Bv9ARM-book.xml,v 1.290 2006/01/05 23:45:33 marka Exp $ -->
<book xmlns:xi="http://www.w3.org/2001/XInclude"> <book xmlns:xi="http://www.w3.org/2001/XInclude">
<title>BIND 9 Administrator Reference Manual</title> <title>BIND 9 Administrator Reference Manual</title>
@ -4402,6 +4402,8 @@ category notify { null; };
<optional> check-mx ( <replaceable>warn</replaceable> | <replaceable>fail</replaceable> | <replaceable>ignore</replaceable> ); </optional> <optional> check-mx ( <replaceable>warn</replaceable> | <replaceable>fail</replaceable> | <replaceable>ignore</replaceable> ); </optional>
<optional> check-wildcard <replaceable>yes_or_no</replaceable>; </optional> <optional> check-wildcard <replaceable>yes_or_no</replaceable>; </optional>
<optional> check-integrity <replaceable>yes_or_no</replaceable>; </optional> <optional> check-integrity <replaceable>yes_or_no</replaceable>; </optional>
<optional> check-mx-cname ( <replaceable>warn</replaceable> | <replaceable>fail</replaceable> | <replaceable>ignore</replaceable> ); </optional>
<optional> check-srv-cname ( <replaceable>warn</replaceable> | <replaceable>fail</replaceable> | <replaceable>ignore</replaceable> ); </optional>
<optional> check-sibling <replaceable>yes_or_no</replaceable>; </optional> <optional> check-sibling <replaceable>yes_or_no</replaceable>; </optional>
<optional> allow-notify { <replaceable>address_match_list</replaceable> }; </optional> <optional> allow-notify { <replaceable>address_match_list</replaceable> }; </optional>
<optional> allow-query { <replaceable>address_match_list</replaceable> }; </optional> <optional> allow-query { <replaceable>address_match_list</replaceable> }; </optional>
@ -5580,6 +5582,28 @@ options {
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry>
<term><command>check-mx-cname</command></term>
<listitem>
<para>
If <command>check-integrity</command> is set then
fail, warn or ignore MX records that refer
to CNAMES. The default is to <command>warn</command>.
</para>
</listitem>
</varlistentry>
<varlistentry>
<term><command>check-srv-cname</command></term>
<listitem>
<para>
If <command>check-integrity</command> is set then
fail, warn or ignore SRV records that refer
to CNAMES. The default is to <command>warn</command>.
</para>
</listitem>
</varlistentry>
<varlistentry> <varlistentry>
<term><command>check-sibling</command></term> <term><command>check-sibling</command></term>
<listitem> <listitem>

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: check.c,v 1.65 2005/11/03 22:59:52 marka Exp $ */ /* $Id: check.c,v 1.66 2006/01/05 23:45:33 marka Exp $ */
/*! \file */ /*! \file */
@ -931,6 +931,8 @@ check_zoneconf(cfg_obj_t *zconfig, cfg_obj_t *voptions, cfg_obj_t *config,
{ "check-wildcard", MASTERZONE }, { "check-wildcard", MASTERZONE },
{ "check-mx", MASTERZONE }, { "check-mx", MASTERZONE },
{ "integrity-check", MASTERZONE }, { "integrity-check", MASTERZONE },
{ "check-mx-cname", MASTERZONE },
{ "check-srv-cname", MASTERZONE },
{ "masterfile-format", MASTERZONE | SLAVEZONE | STUBZONE | HINTZONE }, { "masterfile-format", MASTERZONE | SLAVEZONE | STUBZONE | HINTZONE },
}; };

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: zone.h,v 1.139 2006/01/05 02:19:02 marka Exp $ */ /* $Id: zone.h,v 1.140 2006/01/05 23:45:34 marka Exp $ */
#ifndef DNS_ZONE_H #ifndef DNS_ZONE_H
#define DNS_ZONE_H 1 #define DNS_ZONE_H 1
@ -59,8 +59,12 @@ typedef enum {
#define DNS_ZONEOPT_CHECKMX 0x00004000U /*%< check-mx */ #define DNS_ZONEOPT_CHECKMX 0x00004000U /*%< check-mx */
#define DNS_ZONEOPT_CHECKMXFAIL 0x00008000U /*%< fatal check-mx failures */ #define DNS_ZONEOPT_CHECKMXFAIL 0x00008000U /*%< fatal check-mx failures */
#define DNS_ZONEOPT_CHECKINTEGRITY 0x00010000U /*%< perform integrity checks */ #define DNS_ZONEOPT_CHECKINTEGRITY 0x00010000U /*%< perform integrity checks */
#define DNS_ZONEOPT_CHECKSIBLING 0x00020000U /*%< perform sibling glue checks */ #define DNS_ZONEOPT_CHECKSIBLING 0x00020000U /*%< perform sibling glue checks */
#define DNS_ZONEOPT_NOCHECKNS 0x00040000U /*%< disable IN NS address checks */ #define DNS_ZONEOPT_NOCHECKNS 0x00040000U /*%< disable IN NS address checks */
#define DNS_ZONEOPT_WARNMXCNAME 0x00080000U /*%< warn on MX CNAME check */
#define DNS_ZONEOPT_IGNOREMXCNAME 0x00100000U /*%< ignore MX CNAME check */
#define DNS_ZONEOPT_WARNSRVCNAME 0x00200000U /*%< warn on SRV CNAME check */
#define DNS_ZONEOPT_IGNORESRVCNAME 0x00400000U /*%< ignore SRV CNAME check */
#ifndef NOMINUM_PUBLIC #ifndef NOMINUM_PUBLIC
/* /*

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: zone.c,v 1.449 2006/01/05 02:19:02 marka Exp $ */ /* $Id: zone.c,v 1.450 2006/01/05 23:45:33 marka Exp $ */
/*! \file */ /*! \file */
@ -468,7 +468,7 @@ zone_get_from_db(dns_zone_t *zone, dns_db_t *db, unsigned int *nscount,
unsigned int *soacount, isc_uint32_t *serial, unsigned int *soacount, isc_uint32_t *serial,
isc_uint32_t *refresh, isc_uint32_t *retry, isc_uint32_t *refresh, isc_uint32_t *retry,
isc_uint32_t *expire, isc_uint32_t *minimum, isc_uint32_t *expire, isc_uint32_t *minimum,
unsigned int *cnames); unsigned int *errors);
static void zone_freedbargs(dns_zone_t *zone); static void zone_freedbargs(dns_zone_t *zone);
static void forward_callback(isc_task_t *task, isc_event_t *event); static void forward_callback(isc_task_t *task, isc_event_t *event);
@ -1411,21 +1411,32 @@ zone_check_mx(dns_zone_t *zone, dns_db_t *db, dns_name_t *name,
dns_zone_log(zone, level, dns_zone_log(zone, level,
"%s/MX '%s' has no address records (A or AAAA)", "%s/MX '%s' has no address records (A or AAAA)",
ownerbuf, namebuf); ownerbuf, namebuf);
return (ISC_FALSE); /* XXX950 make fatal for 9.5.0. */
return (ISC_TRUE);
} }
if (result == DNS_R_CNAME) { if (result == DNS_R_CNAME) {
dns_zone_log(zone, level, "%s/MX '%s' is a CNAME (illegal)", if (DNS_ZONE_OPTION(zone, DNS_ZONEOPT_WARNMXCNAME) ||
ownerbuf, namebuf); DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNOREMXCNAME))
return (ISC_FALSE); level = ISC_LOG_WARNING;
if (!DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNOREMXCNAME))
dns_zone_log(zone, level,
"%s/MX '%s' is a CNAME (illegal)",
ownerbuf, namebuf);
return ((level == ISC_LOG_WARNING) ? ISC_TRUE : ISC_FALSE);
} }
if (result == DNS_R_DNAME) { if (result == DNS_R_DNAME) {
dns_name_format(foundname, altbuf, sizeof altbuf); if (DNS_ZONE_OPTION(zone, DNS_ZONEOPT_WARNMXCNAME) ||
dns_zone_log(zone, level, DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNOREMXCNAME))
"%s/MX '%s' is below a DNAME '%s' (illegal)", level = ISC_LOG_WARNING;
ownerbuf, namebuf, altbuf); if (!DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNOREMXCNAME)) {
return (ISC_FALSE); dns_name_format(foundname, altbuf, sizeof altbuf);
dns_zone_log(zone, level, "%s/MX '%s' is below a DNAME"
" '%s' (illegal)", ownerbuf, namebuf,
altbuf);
}
return ((level == ISC_LOG_WARNING) ? ISC_TRUE : ISC_FALSE);
} }
if (zone->checkmx != NULL && result == DNS_R_DELEGATION) if (zone->checkmx != NULL && result == DNS_R_DELEGATION)
@ -1446,6 +1457,12 @@ zone_check_srv(dns_zone_t *zone, dns_db_t *db, dns_name_t *name,
dns_name_t *foundname; dns_name_t *foundname;
int level; int level;
/*
* "." means the services does not exist.
*/
if (dns_name_equal(name, dns_rootname))
return (ISC_TRUE);
/* /*
* Outside of zone. * Outside of zone.
*/ */
@ -1482,21 +1499,32 @@ zone_check_srv(dns_zone_t *zone, dns_db_t *db, dns_name_t *name,
dns_zone_log(zone, level, dns_zone_log(zone, level,
"%s/SRV '%s' has no address records (A or AAAA)", "%s/SRV '%s' has no address records (A or AAAA)",
ownerbuf, namebuf); ownerbuf, namebuf);
return (ISC_FALSE); /* XXX950 make fatal for 9.5.0. */
return (ISC_TRUE);
} }
if (result == DNS_R_CNAME) { if (result == DNS_R_CNAME) {
dns_zone_log(zone, level, "%s/SRV '%s' is a CNAME (illegal)", if (DNS_ZONE_OPTION(zone, DNS_ZONEOPT_WARNSRVCNAME) ||
ownerbuf, namebuf); DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNORESRVCNAME))
return (ISC_FALSE); level = ISC_LOG_WARNING;
if (!DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNORESRVCNAME))
dns_zone_log(zone, level,
"%s/SRV '%s' is a CNAME (illegal)",
ownerbuf, namebuf);
return ((level == ISC_LOG_WARNING) ? ISC_TRUE : ISC_FALSE);
} }
if (result == DNS_R_DNAME) { if (result == DNS_R_DNAME) {
dns_name_format(foundname, altbuf, sizeof altbuf); if (DNS_ZONE_OPTION(zone, DNS_ZONEOPT_WARNSRVCNAME) ||
dns_zone_log(zone, level, DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNORESRVCNAME))
"%s/SRV '%s' is below a DNAME '%s' (illegal)", level = ISC_LOG_WARNING;
ownerbuf, namebuf, altbuf); if (!DNS_ZONE_OPTION(zone, DNS_ZONEOPT_IGNORESRVCNAME)) {
return (ISC_FALSE); dns_name_format(foundname, altbuf, sizeof altbuf);
dns_zone_log(zone, level, "%s/SRV '%s' is below a "
"DNAME '%s' (illegal)", ownerbuf, namebuf,
altbuf);
}
return ((level == ISC_LOG_WARNING) ? ISC_TRUE : ISC_FALSE);
} }
if (zone->checksrv != NULL && result == DNS_R_DELEGATION) if (zone->checksrv != NULL && result == DNS_R_DELEGATION)
@ -1599,18 +1627,21 @@ zone_check_glue(dns_zone_t *zone, dns_db_t *db, dns_name_t *name,
if (result == DNS_R_DELEGATION && zone->checkns != NULL) if (result == DNS_R_DELEGATION && zone->checkns != NULL)
(void)(zone->checkns)(zone, name, owner, (void)(zone->checkns)(zone, name, owner,
&a, &aaaa); &a, &aaaa);
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0. */
/* answer = ISC_FALSE; */
} }
} else if (result == DNS_R_CNAME) { } else if (result == DNS_R_CNAME) {
dns_zone_log(zone, level, "%s/NS '%s' is a CNAME (illegal)", dns_zone_log(zone, level, "%s/NS '%s' is a CNAME (illegal)",
ownerbuf, namebuf); ownerbuf, namebuf);
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0. */
/* answer = ISC_FALSE; */
} else if (result == DNS_R_DNAME) { } else if (result == DNS_R_DNAME) {
dns_name_format(foundname, altbuf, sizeof altbuf); dns_name_format(foundname, altbuf, sizeof altbuf);
dns_zone_log(zone, level, dns_zone_log(zone, level,
"%s/NS '%s' is below a DNAME '%s' (illegal)", "%s/NS '%s' is below a DNAME '%s' (illegal)",
ownerbuf, namebuf, altbuf); ownerbuf, namebuf, altbuf);
answer = ISC_FALSE; /* XXX950 make fatal for 9.5.0. */
/* answer = ISC_FALSE; */
} }
if (dns_rdataset_isassociated(&a)) if (dns_rdataset_isassociated(&a))
@ -1743,7 +1774,7 @@ zone_postload(dns_zone_t *zone, dns_db_t *db, isc_time_t loadtime,
{ {
unsigned int soacount = 0; unsigned int soacount = 0;
unsigned int nscount = 0; unsigned int nscount = 0;
unsigned int cnames = 0; unsigned int errors = 0;
isc_uint32_t serial, refresh, retry, expire, minimum; isc_uint32_t serial, refresh, retry, expire, minimum;
isc_time_t now; isc_time_t now;
isc_boolean_t needdump = ISC_FALSE; isc_boolean_t needdump = ISC_FALSE;
@ -1826,7 +1857,7 @@ zone_postload(dns_zone_t *zone, dns_db_t *db, isc_time_t loadtime,
INSIST(db != NULL); INSIST(db != NULL);
result = zone_get_from_db(zone, db, &nscount, &soacount, &serial, result = zone_get_from_db(zone, db, &nscount, &soacount, &serial,
&refresh, &retry, &expire, &minimum, &refresh, &retry, &expire, &minimum,
&cnames); &errors);
if (result != ISC_R_SUCCESS) { if (result != ISC_R_SUCCESS) {
dns_zone_log(zone, ISC_LOG_ERROR, dns_zone_log(zone, ISC_LOG_ERROR,
"could not find NS and/or SOA records"); "could not find NS and/or SOA records");
@ -1853,7 +1884,7 @@ zone_postload(dns_zone_t *zone, dns_db_t *db, isc_time_t loadtime,
} }
if (result != ISC_R_SUCCESS) if (result != ISC_R_SUCCESS)
goto cleanup; goto cleanup;
if (zone->type == dns_zone_master && cnames != 0) { if (zone->type == dns_zone_master && errors != 0) {
result = DNS_R_BADZONE; result = DNS_R_BADZONE;
goto cleanup; goto cleanup;
} }
@ -2042,13 +2073,15 @@ zone_check_ns(dns_zone_t *zone, dns_db_t *db, dns_name_t *name) {
dns_zone_log(zone, level, dns_zone_log(zone, level,
"NS '%s' has no address records (A or AAAA)", "NS '%s' has no address records (A or AAAA)",
namebuf); namebuf);
return (ISC_FALSE); /* XXX950 Make fatal ISC_FALSE for 9.5.0. */
return (ISC_TRUE);
} }
if (result == DNS_R_CNAME) { if (result == DNS_R_CNAME) {
dns_zone_log(zone, level, "NS '%s' is a CNAME (illegal)", dns_zone_log(zone, level, "NS '%s' is a CNAME (illegal)",
namebuf); namebuf);
return (ISC_FALSE); /* XXX950 Make fatal ISC_FALSE for 9.5.0. */
return (ISC_TRUE);
} }
if (result == DNS_R_DNAME) { if (result == DNS_R_DNAME) {
@ -2056,7 +2089,8 @@ zone_check_ns(dns_zone_t *zone, dns_db_t *db, dns_name_t *name) {
dns_zone_log(zone, level, dns_zone_log(zone, level,
"NS '%s' is below a DNAME '%s' (illegal)", "NS '%s' is below a DNAME '%s' (illegal)",
namebuf, altbuf); namebuf, altbuf);
return (ISC_FALSE); /* XXX950 Make fatal ISC_FALSE for 9.5.0. */
return (ISC_TRUE);
} }
return (ISC_TRUE); return (ISC_TRUE);
@ -2065,11 +2099,11 @@ zone_check_ns(dns_zone_t *zone, dns_db_t *db, dns_name_t *name) {
static isc_result_t static isc_result_t
zone_count_ns_rr(dns_zone_t *zone, dns_db_t *db, dns_dbnode_t *node, zone_count_ns_rr(dns_zone_t *zone, dns_db_t *db, dns_dbnode_t *node,
dns_dbversion_t *version, unsigned int *nscount, dns_dbversion_t *version, unsigned int *nscount,
unsigned int *cnames) unsigned int *errors)
{ {
isc_result_t result; isc_result_t result;
unsigned int count = 0; unsigned int count = 0;
unsigned int ccount = 0; unsigned int ecount = 0;
dns_rdataset_t rdataset; dns_rdataset_t rdataset;
dns_rdata_t rdata; dns_rdata_t rdata;
dns_rdata_ns_t ns; dns_rdata_ns_t ns;
@ -2084,7 +2118,7 @@ zone_count_ns_rr(dns_zone_t *zone, dns_db_t *db, dns_dbnode_t *node,
result = dns_rdataset_first(&rdataset); result = dns_rdataset_first(&rdataset);
while (result == ISC_R_SUCCESS) { while (result == ISC_R_SUCCESS) {
if (cnames != NULL && zone->rdclass == dns_rdataclass_in && if (errors != NULL && zone->rdclass == dns_rdataclass_in &&
(zone->type == dns_zone_master || (zone->type == dns_zone_master ||
zone->type == dns_zone_slave)) { zone->type == dns_zone_slave)) {
dns_rdata_init(&rdata); dns_rdata_init(&rdata);
@ -2093,7 +2127,7 @@ zone_count_ns_rr(dns_zone_t *zone, dns_db_t *db, dns_dbnode_t *node,
RUNTIME_CHECK(result == ISC_R_SUCCESS); RUNTIME_CHECK(result == ISC_R_SUCCESS);
if (dns_name_issubdomain(&ns.name, &zone->origin) && if (dns_name_issubdomain(&ns.name, &zone->origin) &&
!zone_check_ns(zone, db, &ns.name)) !zone_check_ns(zone, db, &ns.name))
ccount++; ecount++;
} }
count++; count++;
result = dns_rdataset_next(&rdataset); result = dns_rdataset_next(&rdataset);
@ -2103,8 +2137,8 @@ zone_count_ns_rr(dns_zone_t *zone, dns_db_t *db, dns_dbnode_t *node,
success: success:
if (nscount != NULL) if (nscount != NULL)
*nscount = count; *nscount = count;
if (cnames != NULL) if (errors != NULL)
*cnames = ccount; *errors = ecount;
result = ISC_R_SUCCESS; result = ISC_R_SUCCESS;
@ -2197,7 +2231,7 @@ zone_get_from_db(dns_zone_t *zone, dns_db_t *db, unsigned int *nscount,
unsigned int *soacount, isc_uint32_t *serial, unsigned int *soacount, isc_uint32_t *serial,
isc_uint32_t *refresh, isc_uint32_t *retry, isc_uint32_t *refresh, isc_uint32_t *retry,
isc_uint32_t *expire, isc_uint32_t *minimum, isc_uint32_t *expire, isc_uint32_t *minimum,
unsigned int *cnames) unsigned int *errors)
{ {
dns_dbversion_t *version; dns_dbversion_t *version;
isc_result_t result; isc_result_t result;
@ -2217,9 +2251,9 @@ zone_get_from_db(dns_zone_t *zone, dns_db_t *db, unsigned int *nscount,
goto closeversion; goto closeversion;
} }
if (nscount != NULL || cnames != NULL) { if (nscount != NULL || errors != NULL) {
result = zone_count_ns_rr(zone, db, node, version, result = zone_count_ns_rr(zone, db, node, version,
nscount, cnames); nscount, errors);
if (result != ISC_R_SUCCESS) if (result != ISC_R_SUCCESS)
answer = result; answer = result;
} }

View File

@ -15,7 +15,7 @@
* PERFORMANCE OF THIS SOFTWARE. * PERFORMANCE OF THIS SOFTWARE.
*/ */
/* $Id: namedconf.c,v 1.62 2006/01/05 02:19:02 marka Exp $ */ /* $Id: namedconf.c,v 1.63 2006/01/05 23:45:34 marka Exp $ */
/*! \file */ /*! \file */
@ -840,6 +840,8 @@ zone_clauses[] = {
{ "check-wildcard", &cfg_type_boolean, 0 }, { "check-wildcard", &cfg_type_boolean, 0 },
{ "check-integrity", &cfg_type_boolean, 0 }, { "check-integrity", &cfg_type_boolean, 0 },
{ "check-mx", &cfg_type_checkmode, 0 }, { "check-mx", &cfg_type_checkmode, 0 },
{ "check-mx-cname", &cfg_type_checkmode, 0 },
{ "check-srv-cname", &cfg_type_checkmode, 0 },
{ "check-sibling", &cfg_type_boolean, 0 }, { "check-sibling", &cfg_type_boolean, 0 },
{ "zero-no-soa-ttl", &cfg_type_boolean, 0 }, { "zero-no-soa-ttl", &cfg_type_boolean, 0 },
{ NULL, NULL, 0 } { NULL, NULL, 0 }