mirror of
https://github.com/isc-projects/bind9.git
synced 2026-06-12 18:50:01 -04:00
4539. [bug] Referencing a nonexistant zone with rpz could lead
to a assertion failure when configuring. [RT #43787]
(cherry picked from commit 762c4fc5a8)
This commit is contained in:
parent
74685182f7
commit
a1f98389a3
6 changed files with 97 additions and 54 deletions
3
CHANGES
3
CHANGES
|
|
@ -1,3 +1,6 @@
|
|||
4539. [bug] Referencing a nonexistant zone with rpz could lead
|
||||
to a assertion failure when configuring. [RT #43787]
|
||||
|
||||
4538. [bug] Call dns_client_startresolve from client->task.
|
||||
[RT #43896]
|
||||
|
||||
|
|
|
|||
|
|
@ -2540,29 +2540,6 @@ configure_view(dns_view_t *view, dns_viewlist_t *viewlist,
|
|||
viewlist, actx, ISC_FALSE, old_rpz_ok));
|
||||
}
|
||||
|
||||
/*
|
||||
* Check that a master or slave zone was found for each
|
||||
* zone named in the response policy statement.
|
||||
*/
|
||||
if (view->rpzs != NULL) {
|
||||
dns_rpz_num_t n;
|
||||
|
||||
for (n = 0; n < view->rpzs->p.num_zones; ++n)
|
||||
{
|
||||
if ((view->rpzs->defined & DNS_RPZ_ZBIT(n)) == 0) {
|
||||
char namebuf[DNS_NAME_FORMATSIZE];
|
||||
|
||||
dns_name_format(&view->rpzs->zones[n]->origin,
|
||||
namebuf, sizeof(namebuf));
|
||||
cfg_obj_log(obj, ns_g_lctx, DNS_RPZ_ERROR_LEVEL,
|
||||
"'%s' is not a master or slave zone",
|
||||
namebuf);
|
||||
result = ISC_R_NOTFOUND;
|
||||
goto cleanup;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/*
|
||||
* If we're allowing added zones, then load zone configuration
|
||||
* from the newzone file for zones that were added during previous
|
||||
|
|
|
|||
5
bin/tests/system/checkconf/bad-rpz-zone.conf
Normal file
5
bin/tests/system/checkconf/bad-rpz-zone.conf
Normal file
|
|
@ -0,0 +1,5 @@
|
|||
options {
|
||||
response-policy {
|
||||
zone "nonexistent";
|
||||
};
|
||||
};
|
||||
|
|
@ -48,8 +48,10 @@ for bad in bad*.conf
|
|||
do
|
||||
ret=0
|
||||
echo "I: checking that named-checkconf detects error in $bad"
|
||||
$CHECKCONF $bad > /dev/null 2>&1
|
||||
if [ $? != 1 ]; then echo "I:failed"; ret=1; fi
|
||||
$CHECKCONF $bad > checkconf.out 2>&1
|
||||
if [ $? != 1 ]; then ret=1; fi
|
||||
grep "^$bad:[0-9]*: " checkconf.out > /dev/null || ret=1
|
||||
if [ $ret != 0 ]; then echo "I:failed"; fi
|
||||
status=`expr $status + $ret`
|
||||
done
|
||||
|
||||
|
|
|
|||
|
|
@ -2748,6 +2748,53 @@ check_trusted_key(const cfg_obj_t *key, isc_boolean_t managed,
|
|||
return (result);
|
||||
}
|
||||
|
||||
static isc_result_t
|
||||
check_rpz_catz(const char *rpz_catz, const cfg_obj_t *rpz_obj,
|
||||
const char *viewname, isc_symtab_t *symtab, isc_log_t *logctx)
|
||||
{
|
||||
const cfg_listelt_t *element;
|
||||
const cfg_obj_t *obj, *nameobj, *zoneobj;
|
||||
const char *zonename, *zonetype;
|
||||
const char *forview = " for view ";
|
||||
isc_symvalue_t value;
|
||||
isc_result_t result, tresult;
|
||||
|
||||
if (viewname == NULL) {
|
||||
viewname = "";
|
||||
forview = "";
|
||||
}
|
||||
result = ISC_R_SUCCESS;
|
||||
|
||||
obj = cfg_tuple_get(rpz_obj, "zone list");
|
||||
for (element = cfg_list_first(obj);
|
||||
element != NULL;
|
||||
element = cfg_list_next(element)) {
|
||||
obj = cfg_listelt_value(element);
|
||||
nameobj = cfg_tuple_get(obj, "zone name");
|
||||
zonename = cfg_obj_asstring(nameobj);
|
||||
zonetype = "";
|
||||
tresult = isc_symtab_lookup(symtab, zonename, 3, &value);
|
||||
if (tresult == ISC_R_SUCCESS) {
|
||||
obj = NULL;
|
||||
zoneobj = value.as_cpointer;
|
||||
if (zoneobj != NULL && cfg_obj_istuple(zoneobj))
|
||||
zoneobj = cfg_tuple_get(zoneobj, "options");
|
||||
if (zoneobj != NULL && cfg_obj_ismap(zoneobj))
|
||||
(void)cfg_map_get(zoneobj, "type", &obj);
|
||||
if (obj != NULL)
|
||||
zonetype = cfg_obj_asstring(obj);
|
||||
}
|
||||
if (strcasecmp(zonetype, "master") != 0 &&
|
||||
strcasecmp(zonetype, "slave") != 0) {
|
||||
cfg_obj_log(nameobj, logctx, ISC_LOG_ERROR,
|
||||
"%s '%s'%s%s is not a master or slave zone",
|
||||
rpz_catz, zonename, forview, viewname);
|
||||
result = ISC_R_FAILURE;
|
||||
}
|
||||
}
|
||||
return (result);
|
||||
}
|
||||
|
||||
static isc_result_t
|
||||
check_viewconf(const cfg_obj_t *config, const cfg_obj_t *voptions,
|
||||
const char *viewname, dns_rdataclass_t vclass,
|
||||
|
|
@ -2762,6 +2809,7 @@ check_viewconf(const cfg_obj_t *config, const cfg_obj_t *voptions,
|
|||
cfg_aclconfctx_t *actx = NULL;
|
||||
const cfg_obj_t *obj;
|
||||
const cfg_obj_t *options = NULL;
|
||||
const cfg_obj_t *opts = NULL;
|
||||
isc_boolean_t enablednssec, enablevalidation;
|
||||
const char *valstr = "no";
|
||||
|
||||
|
|
@ -2770,6 +2818,14 @@ check_viewconf(const cfg_obj_t *config, const cfg_obj_t *voptions,
|
|||
*/
|
||||
(void)cfg_map_get(config, "options", &options);
|
||||
|
||||
/*
|
||||
* The most relevant options for this view
|
||||
*/
|
||||
if (voptions != NULL)
|
||||
opts = voptions;
|
||||
else
|
||||
opts = options;
|
||||
|
||||
/*
|
||||
* Check that all zone statements are syntactically correct and
|
||||
* there are no duplicate zones.
|
||||
|
|
@ -2799,20 +2855,30 @@ check_viewconf(const cfg_obj_t *config, const cfg_obj_t *voptions,
|
|||
result = ISC_R_FAILURE;
|
||||
}
|
||||
|
||||
/*
|
||||
* Check that the response-policy and catalog-zones options
|
||||
* refer to zones that exist.
|
||||
*/
|
||||
if (opts != NULL) {
|
||||
obj = NULL;
|
||||
if (cfg_map_get(opts, "response-policy", &obj) == ISC_R_SUCCESS
|
||||
&& check_rpz_catz("response-policy zone", obj,
|
||||
viewname, symtab, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
obj = NULL;
|
||||
if (cfg_map_get(opts, "catalog-zones", &obj) == ISC_R_SUCCESS
|
||||
&& check_rpz_catz("catalog zone", obj,
|
||||
viewname, symtab, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
}
|
||||
|
||||
isc_symtab_destroy(&symtab);
|
||||
|
||||
/*
|
||||
* Check that forwarding is reasonable.
|
||||
*/
|
||||
if (voptions == NULL) {
|
||||
if (options != NULL)
|
||||
if (check_forward(options, NULL,
|
||||
logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
} else {
|
||||
if (check_forward(voptions, NULL, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
}
|
||||
if (opts != NULL && check_forward(opts, NULL, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
|
||||
/*
|
||||
* Check non-zero options at the global and view levels.
|
||||
|
|
@ -2825,22 +2891,14 @@ check_viewconf(const cfg_obj_t *config, const cfg_obj_t *voptions,
|
|||
/*
|
||||
* Check that dual-stack-servers is reasonable.
|
||||
*/
|
||||
if (voptions == NULL) {
|
||||
if (options != NULL)
|
||||
if (check_dual_stack(options, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
} else {
|
||||
if (check_dual_stack(voptions, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
}
|
||||
if (opts != NULL && check_dual_stack(opts, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
|
||||
/*
|
||||
* Check that rrset-order is reasonable.
|
||||
*/
|
||||
if (voptions != NULL) {
|
||||
if (check_order(voptions, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
}
|
||||
if (opts != NULL && check_order(opts, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
|
||||
/*
|
||||
* Check that all key statements are syntactically correct and
|
||||
|
|
@ -3277,10 +3335,6 @@ bind9_check_namedconf(const cfg_obj_t *config, isc_log_t *logctx,
|
|||
if (bind9_check_controls(config, logctx, mctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
|
||||
if (options != NULL &&
|
||||
check_order(options, logctx) != ISC_R_SUCCESS)
|
||||
result = ISC_R_FAILURE;
|
||||
|
||||
(void)cfg_map_get(config, "view", &views);
|
||||
|
||||
if (views != NULL && options != NULL)
|
||||
|
|
|
|||
|
|
@ -2758,11 +2758,13 @@ cfg_obj_log(const cfg_obj_t *obj, isc_log_t *lctx, int level,
|
|||
va_start(ap, fmt);
|
||||
|
||||
vsnprintf(msgbuf, sizeof(msgbuf), fmt, ap);
|
||||
isc_log_write(lctx, CAT, MOD, level,
|
||||
"%s:%u: %s",
|
||||
obj->file == NULL ? "<unknown file>" : obj->file,
|
||||
obj->line, msgbuf);
|
||||
va_end(ap);
|
||||
if (obj->file != NULL) {
|
||||
isc_log_write(lctx, CAT, MOD, level,
|
||||
"%s:%u: %s", obj->file, obj->line, msgbuf);
|
||||
} else {
|
||||
isc_log_write(lctx, CAT, MOD, level, "%s", msgbuf);
|
||||
}
|
||||
}
|
||||
|
||||
const char *
|
||||
|
|
|
|||
Loading…
Reference in a new issue