1*00b67f09SDavid van Moolenbroek /* $NetBSD: named-checkconf.c,v 1.11 2015/07/08 17:28:54 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004-2007, 2009-2014 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek * Copyright (C) 1999-2002 Internet Software Consortium.
6*00b67f09SDavid van Moolenbroek *
7*00b67f09SDavid van Moolenbroek * Permission to use, copy, modify, and/or distribute this software for any
8*00b67f09SDavid van Moolenbroek * purpose with or without fee is hereby granted, provided that the above
9*00b67f09SDavid van Moolenbroek * copyright notice and this permission notice appear in all copies.
10*00b67f09SDavid van Moolenbroek *
11*00b67f09SDavid van Moolenbroek * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES WITH
12*00b67f09SDavid van Moolenbroek * REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
13*00b67f09SDavid van Moolenbroek * AND FITNESS. IN NO EVENT SHALL ISC BE LIABLE FOR ANY SPECIAL, DIRECT,
14*00b67f09SDavid van Moolenbroek * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
15*00b67f09SDavid van Moolenbroek * LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE
16*00b67f09SDavid van Moolenbroek * OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
17*00b67f09SDavid van Moolenbroek * PERFORMANCE OF THIS SOFTWARE.
18*00b67f09SDavid van Moolenbroek */
19*00b67f09SDavid van Moolenbroek
20*00b67f09SDavid van Moolenbroek /* Id: named-checkconf.c,v 1.56 2011/03/12 04:59:46 tbox Exp */
21*00b67f09SDavid van Moolenbroek
22*00b67f09SDavid van Moolenbroek /*! \file */
23*00b67f09SDavid van Moolenbroek
24*00b67f09SDavid van Moolenbroek #include <config.h>
25*00b67f09SDavid van Moolenbroek
26*00b67f09SDavid van Moolenbroek #include <errno.h>
27*00b67f09SDavid van Moolenbroek #include <stdlib.h>
28*00b67f09SDavid van Moolenbroek #include <stdio.h>
29*00b67f09SDavid van Moolenbroek
30*00b67f09SDavid van Moolenbroek #include <isc/commandline.h>
31*00b67f09SDavid van Moolenbroek #include <isc/dir.h>
32*00b67f09SDavid van Moolenbroek #include <isc/entropy.h>
33*00b67f09SDavid van Moolenbroek #include <isc/hash.h>
34*00b67f09SDavid van Moolenbroek #include <isc/log.h>
35*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
36*00b67f09SDavid van Moolenbroek #include <isc/result.h>
37*00b67f09SDavid van Moolenbroek #include <isc/string.h>
38*00b67f09SDavid van Moolenbroek #include <isc/util.h>
39*00b67f09SDavid van Moolenbroek
40*00b67f09SDavid van Moolenbroek #include <isccfg/namedconf.h>
41*00b67f09SDavid van Moolenbroek
42*00b67f09SDavid van Moolenbroek #include <bind9/check.h>
43*00b67f09SDavid van Moolenbroek
44*00b67f09SDavid van Moolenbroek #include <dns/db.h>
45*00b67f09SDavid van Moolenbroek #include <dns/fixedname.h>
46*00b67f09SDavid van Moolenbroek #include <dns/log.h>
47*00b67f09SDavid van Moolenbroek #include <dns/name.h>
48*00b67f09SDavid van Moolenbroek #include <dns/rdataclass.h>
49*00b67f09SDavid van Moolenbroek #include <dns/result.h>
50*00b67f09SDavid van Moolenbroek #include <dns/rootns.h>
51*00b67f09SDavid van Moolenbroek #include <dns/zone.h>
52*00b67f09SDavid van Moolenbroek
53*00b67f09SDavid van Moolenbroek #include "check-tool.h"
54*00b67f09SDavid van Moolenbroek
55*00b67f09SDavid van Moolenbroek static const char *program = "named-checkconf";
56*00b67f09SDavid van Moolenbroek
57*00b67f09SDavid van Moolenbroek isc_log_t *logc = NULL;
58*00b67f09SDavid van Moolenbroek
59*00b67f09SDavid van Moolenbroek #define CHECK(r)\
60*00b67f09SDavid van Moolenbroek do { \
61*00b67f09SDavid van Moolenbroek result = (r); \
62*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS) \
63*00b67f09SDavid van Moolenbroek goto cleanup; \
64*00b67f09SDavid van Moolenbroek } while (/*CONSTCOND*/0)
65*00b67f09SDavid van Moolenbroek
66*00b67f09SDavid van Moolenbroek /*% usage */
67*00b67f09SDavid van Moolenbroek ISC_PLATFORM_NORETURN_PRE static void
68*00b67f09SDavid van Moolenbroek usage(void) ISC_PLATFORM_NORETURN_POST;
69*00b67f09SDavid van Moolenbroek
70*00b67f09SDavid van Moolenbroek static void
usage(void)71*00b67f09SDavid van Moolenbroek usage(void) {
72*00b67f09SDavid van Moolenbroek fprintf(stderr, "usage: %s [-h] [-j] [-p] [-v] [-z] [-t directory] "
73*00b67f09SDavid van Moolenbroek "[named.conf]\n", program);
74*00b67f09SDavid van Moolenbroek exit(1);
75*00b67f09SDavid van Moolenbroek }
76*00b67f09SDavid van Moolenbroek
77*00b67f09SDavid van Moolenbroek /*% directory callback */
78*00b67f09SDavid van Moolenbroek static isc_result_t
directory_callback(const char * clausename,const cfg_obj_t * obj,void * arg)79*00b67f09SDavid van Moolenbroek directory_callback(const char *clausename, const cfg_obj_t *obj, void *arg) {
80*00b67f09SDavid van Moolenbroek isc_result_t result;
81*00b67f09SDavid van Moolenbroek const char *directory;
82*00b67f09SDavid van Moolenbroek
83*00b67f09SDavid van Moolenbroek REQUIRE(strcasecmp("directory", clausename) == 0);
84*00b67f09SDavid van Moolenbroek
85*00b67f09SDavid van Moolenbroek UNUSED(arg);
86*00b67f09SDavid van Moolenbroek UNUSED(clausename);
87*00b67f09SDavid van Moolenbroek
88*00b67f09SDavid van Moolenbroek /*
89*00b67f09SDavid van Moolenbroek * Change directory.
90*00b67f09SDavid van Moolenbroek */
91*00b67f09SDavid van Moolenbroek directory = cfg_obj_asstring(obj);
92*00b67f09SDavid van Moolenbroek result = isc_dir_chdir(directory);
93*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS) {
94*00b67f09SDavid van Moolenbroek cfg_obj_log(obj, logc, ISC_LOG_ERROR,
95*00b67f09SDavid van Moolenbroek "change directory to '%s' failed: %s\n",
96*00b67f09SDavid van Moolenbroek directory, isc_result_totext(result));
97*00b67f09SDavid van Moolenbroek return (result);
98*00b67f09SDavid van Moolenbroek }
99*00b67f09SDavid van Moolenbroek
100*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
101*00b67f09SDavid van Moolenbroek }
102*00b67f09SDavid van Moolenbroek
103*00b67f09SDavid van Moolenbroek static isc_boolean_t
get_maps(const cfg_obj_t ** maps,const char * name,const cfg_obj_t ** obj)104*00b67f09SDavid van Moolenbroek get_maps(const cfg_obj_t **maps, const char *name, const cfg_obj_t **obj) {
105*00b67f09SDavid van Moolenbroek int i;
106*00b67f09SDavid van Moolenbroek for (i = 0;; i++) {
107*00b67f09SDavid van Moolenbroek if (maps[i] == NULL)
108*00b67f09SDavid van Moolenbroek return (ISC_FALSE);
109*00b67f09SDavid van Moolenbroek if (cfg_map_get(maps[i], name, obj) == ISC_R_SUCCESS)
110*00b67f09SDavid van Moolenbroek return (ISC_TRUE);
111*00b67f09SDavid van Moolenbroek }
112*00b67f09SDavid van Moolenbroek }
113*00b67f09SDavid van Moolenbroek
114*00b67f09SDavid van Moolenbroek static isc_boolean_t
get_checknames(const cfg_obj_t ** maps,const cfg_obj_t ** obj)115*00b67f09SDavid van Moolenbroek get_checknames(const cfg_obj_t **maps, const cfg_obj_t **obj) {
116*00b67f09SDavid van Moolenbroek const cfg_listelt_t *element;
117*00b67f09SDavid van Moolenbroek const cfg_obj_t *checknames;
118*00b67f09SDavid van Moolenbroek const cfg_obj_t *type;
119*00b67f09SDavid van Moolenbroek const cfg_obj_t *value;
120*00b67f09SDavid van Moolenbroek isc_result_t result;
121*00b67f09SDavid van Moolenbroek int i;
122*00b67f09SDavid van Moolenbroek
123*00b67f09SDavid van Moolenbroek for (i = 0;; i++) {
124*00b67f09SDavid van Moolenbroek if (maps[i] == NULL)
125*00b67f09SDavid van Moolenbroek return (ISC_FALSE);
126*00b67f09SDavid van Moolenbroek checknames = NULL;
127*00b67f09SDavid van Moolenbroek result = cfg_map_get(maps[i], "check-names", &checknames);
128*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
129*00b67f09SDavid van Moolenbroek continue;
130*00b67f09SDavid van Moolenbroek if (checknames != NULL && !cfg_obj_islist(checknames)) {
131*00b67f09SDavid van Moolenbroek *obj = checknames;
132*00b67f09SDavid van Moolenbroek return (ISC_TRUE);
133*00b67f09SDavid van Moolenbroek }
134*00b67f09SDavid van Moolenbroek for (element = cfg_list_first(checknames);
135*00b67f09SDavid van Moolenbroek element != NULL;
136*00b67f09SDavid van Moolenbroek element = cfg_list_next(element)) {
137*00b67f09SDavid van Moolenbroek value = cfg_listelt_value(element);
138*00b67f09SDavid van Moolenbroek type = cfg_tuple_get(value, "type");
139*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(type), "master") != 0)
140*00b67f09SDavid van Moolenbroek continue;
141*00b67f09SDavid van Moolenbroek *obj = cfg_tuple_get(value, "mode");
142*00b67f09SDavid van Moolenbroek return (ISC_TRUE);
143*00b67f09SDavid van Moolenbroek }
144*00b67f09SDavid van Moolenbroek }
145*00b67f09SDavid van Moolenbroek }
146*00b67f09SDavid van Moolenbroek
147*00b67f09SDavid van Moolenbroek static isc_result_t
configure_hint(const char * zfile,const char * zclass,isc_mem_t * mctx)148*00b67f09SDavid van Moolenbroek configure_hint(const char *zfile, const char *zclass, isc_mem_t *mctx) {
149*00b67f09SDavid van Moolenbroek isc_result_t result;
150*00b67f09SDavid van Moolenbroek dns_db_t *db = NULL;
151*00b67f09SDavid van Moolenbroek dns_rdataclass_t rdclass;
152*00b67f09SDavid van Moolenbroek isc_textregion_t r;
153*00b67f09SDavid van Moolenbroek
154*00b67f09SDavid van Moolenbroek if (zfile == NULL)
155*00b67f09SDavid van Moolenbroek return (ISC_R_FAILURE);
156*00b67f09SDavid van Moolenbroek
157*00b67f09SDavid van Moolenbroek DE_CONST(zclass, r.base);
158*00b67f09SDavid van Moolenbroek r.length = strlen(zclass);
159*00b67f09SDavid van Moolenbroek result = dns_rdataclass_fromtext(&rdclass, &r);
160*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
161*00b67f09SDavid van Moolenbroek return (result);
162*00b67f09SDavid van Moolenbroek
163*00b67f09SDavid van Moolenbroek result = dns_rootns_create(mctx, rdclass, zfile, &db);
164*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
165*00b67f09SDavid van Moolenbroek return (result);
166*00b67f09SDavid van Moolenbroek
167*00b67f09SDavid van Moolenbroek dns_db_detach(&db);
168*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
169*00b67f09SDavid van Moolenbroek }
170*00b67f09SDavid van Moolenbroek
171*00b67f09SDavid van Moolenbroek /*% configure the zone */
172*00b67f09SDavid van Moolenbroek static isc_result_t
configure_zone(const char * vclass,const char * view,const cfg_obj_t * zconfig,const cfg_obj_t * vconfig,const cfg_obj_t * config,isc_mem_t * mctx)173*00b67f09SDavid van Moolenbroek configure_zone(const char *vclass, const char *view,
174*00b67f09SDavid van Moolenbroek const cfg_obj_t *zconfig, const cfg_obj_t *vconfig,
175*00b67f09SDavid van Moolenbroek const cfg_obj_t *config, isc_mem_t *mctx)
176*00b67f09SDavid van Moolenbroek {
177*00b67f09SDavid van Moolenbroek int i = 0;
178*00b67f09SDavid van Moolenbroek isc_result_t result;
179*00b67f09SDavid van Moolenbroek const char *zclass;
180*00b67f09SDavid van Moolenbroek const char *zname;
181*00b67f09SDavid van Moolenbroek const char *zfile = NULL;
182*00b67f09SDavid van Moolenbroek const cfg_obj_t *maps[4];
183*00b67f09SDavid van Moolenbroek const cfg_obj_t *mastersobj = NULL;
184*00b67f09SDavid van Moolenbroek const cfg_obj_t *zoptions = NULL;
185*00b67f09SDavid van Moolenbroek const cfg_obj_t *classobj = NULL;
186*00b67f09SDavid van Moolenbroek const cfg_obj_t *typeobj = NULL;
187*00b67f09SDavid van Moolenbroek const cfg_obj_t *fileobj = NULL;
188*00b67f09SDavid van Moolenbroek const cfg_obj_t *dlzobj = NULL;
189*00b67f09SDavid van Moolenbroek const cfg_obj_t *dbobj = NULL;
190*00b67f09SDavid van Moolenbroek const cfg_obj_t *obj = NULL;
191*00b67f09SDavid van Moolenbroek const cfg_obj_t *fmtobj = NULL;
192*00b67f09SDavid van Moolenbroek dns_masterformat_t masterformat;
193*00b67f09SDavid van Moolenbroek dns_ttl_t maxttl = 0;
194*00b67f09SDavid van Moolenbroek
195*00b67f09SDavid van Moolenbroek zone_options = DNS_ZONEOPT_CHECKNS | DNS_ZONEOPT_MANYERRORS;
196*00b67f09SDavid van Moolenbroek
197*00b67f09SDavid van Moolenbroek zname = cfg_obj_asstring(cfg_tuple_get(zconfig, "name"));
198*00b67f09SDavid van Moolenbroek classobj = cfg_tuple_get(zconfig, "class");
199*00b67f09SDavid van Moolenbroek if (!cfg_obj_isstring(classobj))
200*00b67f09SDavid van Moolenbroek zclass = vclass;
201*00b67f09SDavid van Moolenbroek else
202*00b67f09SDavid van Moolenbroek zclass = cfg_obj_asstring(classobj);
203*00b67f09SDavid van Moolenbroek
204*00b67f09SDavid van Moolenbroek zoptions = cfg_tuple_get(zconfig, "options");
205*00b67f09SDavid van Moolenbroek maps[i++] = zoptions;
206*00b67f09SDavid van Moolenbroek if (vconfig != NULL)
207*00b67f09SDavid van Moolenbroek maps[i++] = cfg_tuple_get(vconfig, "options");
208*00b67f09SDavid van Moolenbroek if (config != NULL) {
209*00b67f09SDavid van Moolenbroek cfg_map_get(config, "options", &obj);
210*00b67f09SDavid van Moolenbroek if (obj != NULL)
211*00b67f09SDavid van Moolenbroek maps[i++] = obj;
212*00b67f09SDavid van Moolenbroek }
213*00b67f09SDavid van Moolenbroek maps[i] = NULL;
214*00b67f09SDavid van Moolenbroek
215*00b67f09SDavid van Moolenbroek cfg_map_get(zoptions, "type", &typeobj);
216*00b67f09SDavid van Moolenbroek if (typeobj == NULL)
217*00b67f09SDavid van Moolenbroek return (ISC_R_FAILURE);
218*00b67f09SDavid van Moolenbroek
219*00b67f09SDavid van Moolenbroek /*
220*00b67f09SDavid van Moolenbroek * Skip checks when using an alternate data source.
221*00b67f09SDavid van Moolenbroek */
222*00b67f09SDavid van Moolenbroek cfg_map_get(zoptions, "database", &dbobj);
223*00b67f09SDavid van Moolenbroek if (dbobj != NULL &&
224*00b67f09SDavid van Moolenbroek strcmp("rbt", cfg_obj_asstring(dbobj)) != 0 &&
225*00b67f09SDavid van Moolenbroek strcmp("rbt64", cfg_obj_asstring(dbobj)) != 0)
226*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
227*00b67f09SDavid van Moolenbroek
228*00b67f09SDavid van Moolenbroek cfg_map_get(zoptions, "dlz", &dlzobj);
229*00b67f09SDavid van Moolenbroek if (dlzobj != NULL)
230*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
231*00b67f09SDavid van Moolenbroek
232*00b67f09SDavid van Moolenbroek cfg_map_get(zoptions, "file", &fileobj);
233*00b67f09SDavid van Moolenbroek if (fileobj != NULL)
234*00b67f09SDavid van Moolenbroek zfile = cfg_obj_asstring(fileobj);
235*00b67f09SDavid van Moolenbroek
236*00b67f09SDavid van Moolenbroek /*
237*00b67f09SDavid van Moolenbroek * Check hints files for hint zones.
238*00b67f09SDavid van Moolenbroek * Skip loading checks for any type other than
239*00b67f09SDavid van Moolenbroek * master and redirect
240*00b67f09SDavid van Moolenbroek */
241*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(typeobj), "hint") == 0)
242*00b67f09SDavid van Moolenbroek return (configure_hint(zfile, zclass, mctx));
243*00b67f09SDavid van Moolenbroek else if ((strcasecmp(cfg_obj_asstring(typeobj), "master") != 0) &&
244*00b67f09SDavid van Moolenbroek (strcasecmp(cfg_obj_asstring(typeobj), "redirect") != 0))
245*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
246*00b67f09SDavid van Moolenbroek
247*00b67f09SDavid van Moolenbroek /*
248*00b67f09SDavid van Moolenbroek * Is the redirect zone configured as a slave?
249*00b67f09SDavid van Moolenbroek */
250*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(typeobj), "redirect") == 0) {
251*00b67f09SDavid van Moolenbroek cfg_map_get(zoptions, "masters", &mastersobj);
252*00b67f09SDavid van Moolenbroek if (mastersobj != NULL)
253*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
254*00b67f09SDavid van Moolenbroek }
255*00b67f09SDavid van Moolenbroek
256*00b67f09SDavid van Moolenbroek if (zfile == NULL)
257*00b67f09SDavid van Moolenbroek return (ISC_R_FAILURE);
258*00b67f09SDavid van Moolenbroek
259*00b67f09SDavid van Moolenbroek obj = NULL;
260*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-dup-records", &obj)) {
261*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
262*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKDUPRR;
263*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKDUPRRFAIL;
264*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
265*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKDUPRR;
266*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKDUPRRFAIL;
267*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
268*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKDUPRR;
269*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKDUPRRFAIL;
270*00b67f09SDavid van Moolenbroek } else
271*00b67f09SDavid van Moolenbroek INSIST(0);
272*00b67f09SDavid van Moolenbroek } else {
273*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKDUPRR;
274*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKDUPRRFAIL;
275*00b67f09SDavid van Moolenbroek }
276*00b67f09SDavid van Moolenbroek
277*00b67f09SDavid van Moolenbroek obj = NULL;
278*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-mx", &obj)) {
279*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
280*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKMX;
281*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKMXFAIL;
282*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
283*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKMX;
284*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKMXFAIL;
285*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
286*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKMX;
287*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKMXFAIL;
288*00b67f09SDavid van Moolenbroek } else
289*00b67f09SDavid van Moolenbroek INSIST(0);
290*00b67f09SDavid van Moolenbroek } else {
291*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKMX;
292*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKMXFAIL;
293*00b67f09SDavid van Moolenbroek }
294*00b67f09SDavid van Moolenbroek
295*00b67f09SDavid van Moolenbroek obj = NULL;
296*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-integrity", &obj)) {
297*00b67f09SDavid van Moolenbroek if (cfg_obj_asboolean(obj))
298*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKINTEGRITY;
299*00b67f09SDavid van Moolenbroek else
300*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKINTEGRITY;
301*00b67f09SDavid van Moolenbroek } else
302*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKINTEGRITY;
303*00b67f09SDavid van Moolenbroek
304*00b67f09SDavid van Moolenbroek obj = NULL;
305*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-mx-cname", &obj)) {
306*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
307*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_WARNMXCNAME;
308*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
309*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
310*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_WARNMXCNAME;
311*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
312*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
313*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_WARNMXCNAME;
314*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_IGNOREMXCNAME;
315*00b67f09SDavid van Moolenbroek } else
316*00b67f09SDavid van Moolenbroek INSIST(0);
317*00b67f09SDavid van Moolenbroek } else {
318*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_WARNMXCNAME;
319*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_IGNOREMXCNAME;
320*00b67f09SDavid van Moolenbroek }
321*00b67f09SDavid van Moolenbroek
322*00b67f09SDavid van Moolenbroek obj = NULL;
323*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-srv-cname", &obj)) {
324*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
325*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
326*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
327*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
328*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_WARNSRVCNAME;
329*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
330*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
331*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
332*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_IGNORESRVCNAME;
333*00b67f09SDavid van Moolenbroek } else
334*00b67f09SDavid van Moolenbroek INSIST(0);
335*00b67f09SDavid van Moolenbroek } else {
336*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_WARNSRVCNAME;
337*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_IGNORESRVCNAME;
338*00b67f09SDavid van Moolenbroek }
339*00b67f09SDavid van Moolenbroek
340*00b67f09SDavid van Moolenbroek obj = NULL;
341*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-sibling", &obj)) {
342*00b67f09SDavid van Moolenbroek if (cfg_obj_asboolean(obj))
343*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKSIBLING;
344*00b67f09SDavid van Moolenbroek else
345*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKSIBLING;
346*00b67f09SDavid van Moolenbroek }
347*00b67f09SDavid van Moolenbroek
348*00b67f09SDavid van Moolenbroek obj = NULL;
349*00b67f09SDavid van Moolenbroek if (get_maps(maps, "check-spf", &obj)) {
350*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
351*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKSPF;
352*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
353*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKSPF;
354*00b67f09SDavid van Moolenbroek } else
355*00b67f09SDavid van Moolenbroek INSIST(0);
356*00b67f09SDavid van Moolenbroek } else {
357*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKSPF;
358*00b67f09SDavid van Moolenbroek }
359*00b67f09SDavid van Moolenbroek
360*00b67f09SDavid van Moolenbroek obj = NULL;
361*00b67f09SDavid van Moolenbroek if (get_checknames(maps, &obj)) {
362*00b67f09SDavid van Moolenbroek if (strcasecmp(cfg_obj_asstring(obj), "warn") == 0) {
363*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKNAMES;
364*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKNAMESFAIL;
365*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "fail") == 0) {
366*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKNAMES;
367*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKNAMESFAIL;
368*00b67f09SDavid van Moolenbroek } else if (strcasecmp(cfg_obj_asstring(obj), "ignore") == 0) {
369*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKNAMES;
370*00b67f09SDavid van Moolenbroek zone_options &= ~DNS_ZONEOPT_CHECKNAMESFAIL;
371*00b67f09SDavid van Moolenbroek } else
372*00b67f09SDavid van Moolenbroek INSIST(0);
373*00b67f09SDavid van Moolenbroek } else {
374*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKNAMES;
375*00b67f09SDavid van Moolenbroek zone_options |= DNS_ZONEOPT_CHECKNAMESFAIL;
376*00b67f09SDavid van Moolenbroek }
377*00b67f09SDavid van Moolenbroek
378*00b67f09SDavid van Moolenbroek masterformat = dns_masterformat_text;
379*00b67f09SDavid van Moolenbroek fmtobj = NULL;
380*00b67f09SDavid van Moolenbroek if (get_maps(maps, "masterfile-format", &fmtobj)) {
381*00b67f09SDavid van Moolenbroek const char *masterformatstr = cfg_obj_asstring(fmtobj);
382*00b67f09SDavid van Moolenbroek if (strcasecmp(masterformatstr, "text") == 0)
383*00b67f09SDavid van Moolenbroek masterformat = dns_masterformat_text;
384*00b67f09SDavid van Moolenbroek else if (strcasecmp(masterformatstr, "raw") == 0)
385*00b67f09SDavid van Moolenbroek masterformat = dns_masterformat_raw;
386*00b67f09SDavid van Moolenbroek else if (strcasecmp(masterformatstr, "map") == 0)
387*00b67f09SDavid van Moolenbroek masterformat = dns_masterformat_map;
388*00b67f09SDavid van Moolenbroek else
389*00b67f09SDavid van Moolenbroek INSIST(0);
390*00b67f09SDavid van Moolenbroek }
391*00b67f09SDavid van Moolenbroek
392*00b67f09SDavid van Moolenbroek obj = NULL;
393*00b67f09SDavid van Moolenbroek if (get_maps(maps, "max-zone-ttl", &obj)) {
394*00b67f09SDavid van Moolenbroek maxttl = cfg_obj_asuint32(obj);
395*00b67f09SDavid van Moolenbroek zone_options2 |= DNS_ZONEOPT2_CHECKTTL;
396*00b67f09SDavid van Moolenbroek }
397*00b67f09SDavid van Moolenbroek
398*00b67f09SDavid van Moolenbroek result = load_zone(mctx, zname, zfile, masterformat,
399*00b67f09SDavid van Moolenbroek zclass, maxttl, NULL);
400*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
401*00b67f09SDavid van Moolenbroek fprintf(stderr, "%s/%s/%s: %s\n", view, zname, zclass,
402*00b67f09SDavid van Moolenbroek dns_result_totext(result));
403*00b67f09SDavid van Moolenbroek return (result);
404*00b67f09SDavid van Moolenbroek }
405*00b67f09SDavid van Moolenbroek
406*00b67f09SDavid van Moolenbroek /*% configure a view */
407*00b67f09SDavid van Moolenbroek static isc_result_t
configure_view(const char * vclass,const char * view,const cfg_obj_t * config,const cfg_obj_t * vconfig,isc_mem_t * mctx)408*00b67f09SDavid van Moolenbroek configure_view(const char *vclass, const char *view, const cfg_obj_t *config,
409*00b67f09SDavid van Moolenbroek const cfg_obj_t *vconfig, isc_mem_t *mctx)
410*00b67f09SDavid van Moolenbroek {
411*00b67f09SDavid van Moolenbroek const cfg_listelt_t *element;
412*00b67f09SDavid van Moolenbroek const cfg_obj_t *voptions;
413*00b67f09SDavid van Moolenbroek const cfg_obj_t *zonelist;
414*00b67f09SDavid van Moolenbroek isc_result_t result = ISC_R_SUCCESS;
415*00b67f09SDavid van Moolenbroek isc_result_t tresult;
416*00b67f09SDavid van Moolenbroek
417*00b67f09SDavid van Moolenbroek voptions = NULL;
418*00b67f09SDavid van Moolenbroek if (vconfig != NULL)
419*00b67f09SDavid van Moolenbroek voptions = cfg_tuple_get(vconfig, "options");
420*00b67f09SDavid van Moolenbroek
421*00b67f09SDavid van Moolenbroek zonelist = NULL;
422*00b67f09SDavid van Moolenbroek if (voptions != NULL)
423*00b67f09SDavid van Moolenbroek (void)cfg_map_get(voptions, "zone", &zonelist);
424*00b67f09SDavid van Moolenbroek else
425*00b67f09SDavid van Moolenbroek (void)cfg_map_get(config, "zone", &zonelist);
426*00b67f09SDavid van Moolenbroek
427*00b67f09SDavid van Moolenbroek for (element = cfg_list_first(zonelist);
428*00b67f09SDavid van Moolenbroek element != NULL;
429*00b67f09SDavid van Moolenbroek element = cfg_list_next(element))
430*00b67f09SDavid van Moolenbroek {
431*00b67f09SDavid van Moolenbroek const cfg_obj_t *zconfig = cfg_listelt_value(element);
432*00b67f09SDavid van Moolenbroek tresult = configure_zone(vclass, view, zconfig, vconfig,
433*00b67f09SDavid van Moolenbroek config, mctx);
434*00b67f09SDavid van Moolenbroek if (tresult != ISC_R_SUCCESS)
435*00b67f09SDavid van Moolenbroek result = tresult;
436*00b67f09SDavid van Moolenbroek }
437*00b67f09SDavid van Moolenbroek return (result);
438*00b67f09SDavid van Moolenbroek }
439*00b67f09SDavid van Moolenbroek
440*00b67f09SDavid van Moolenbroek
441*00b67f09SDavid van Moolenbroek /*% load zones from the configuration */
442*00b67f09SDavid van Moolenbroek static isc_result_t
load_zones_fromconfig(const cfg_obj_t * config,isc_mem_t * mctx)443*00b67f09SDavid van Moolenbroek load_zones_fromconfig(const cfg_obj_t *config, isc_mem_t *mctx) {
444*00b67f09SDavid van Moolenbroek const cfg_listelt_t *element;
445*00b67f09SDavid van Moolenbroek const cfg_obj_t *classobj;
446*00b67f09SDavid van Moolenbroek const cfg_obj_t *views;
447*00b67f09SDavid van Moolenbroek const cfg_obj_t *vconfig;
448*00b67f09SDavid van Moolenbroek const char *vclass;
449*00b67f09SDavid van Moolenbroek isc_result_t result = ISC_R_SUCCESS;
450*00b67f09SDavid van Moolenbroek isc_result_t tresult;
451*00b67f09SDavid van Moolenbroek
452*00b67f09SDavid van Moolenbroek views = NULL;
453*00b67f09SDavid van Moolenbroek
454*00b67f09SDavid van Moolenbroek (void)cfg_map_get(config, "view", &views);
455*00b67f09SDavid van Moolenbroek for (element = cfg_list_first(views);
456*00b67f09SDavid van Moolenbroek element != NULL;
457*00b67f09SDavid van Moolenbroek element = cfg_list_next(element))
458*00b67f09SDavid van Moolenbroek {
459*00b67f09SDavid van Moolenbroek const char *vname;
460*00b67f09SDavid van Moolenbroek
461*00b67f09SDavid van Moolenbroek vclass = "IN";
462*00b67f09SDavid van Moolenbroek vconfig = cfg_listelt_value(element);
463*00b67f09SDavid van Moolenbroek if (vconfig != NULL) {
464*00b67f09SDavid van Moolenbroek classobj = cfg_tuple_get(vconfig, "class");
465*00b67f09SDavid van Moolenbroek if (cfg_obj_isstring(classobj))
466*00b67f09SDavid van Moolenbroek vclass = cfg_obj_asstring(classobj);
467*00b67f09SDavid van Moolenbroek }
468*00b67f09SDavid van Moolenbroek vname = cfg_obj_asstring(cfg_tuple_get(vconfig, "name"));
469*00b67f09SDavid van Moolenbroek tresult = configure_view(vclass, vname, config, vconfig, mctx);
470*00b67f09SDavid van Moolenbroek if (tresult != ISC_R_SUCCESS)
471*00b67f09SDavid van Moolenbroek result = tresult;
472*00b67f09SDavid van Moolenbroek }
473*00b67f09SDavid van Moolenbroek
474*00b67f09SDavid van Moolenbroek if (views == NULL) {
475*00b67f09SDavid van Moolenbroek tresult = configure_view("IN", "_default", config, NULL, mctx);
476*00b67f09SDavid van Moolenbroek if (tresult != ISC_R_SUCCESS)
477*00b67f09SDavid van Moolenbroek result = tresult;
478*00b67f09SDavid van Moolenbroek }
479*00b67f09SDavid van Moolenbroek return (result);
480*00b67f09SDavid van Moolenbroek }
481*00b67f09SDavid van Moolenbroek
482*00b67f09SDavid van Moolenbroek static void
output(void * closure,const char * text,int textlen)483*00b67f09SDavid van Moolenbroek output(void *closure, const char *text, int textlen) {
484*00b67f09SDavid van Moolenbroek UNUSED(closure);
485*00b67f09SDavid van Moolenbroek if (fwrite(text, 1, textlen, stdout) != (size_t)textlen) {
486*00b67f09SDavid van Moolenbroek perror("fwrite");
487*00b67f09SDavid van Moolenbroek exit(1);
488*00b67f09SDavid van Moolenbroek }
489*00b67f09SDavid van Moolenbroek }
490*00b67f09SDavid van Moolenbroek
491*00b67f09SDavid van Moolenbroek /*% The main processing routine */
492*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)493*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
494*00b67f09SDavid van Moolenbroek int c;
495*00b67f09SDavid van Moolenbroek cfg_parser_t *parser = NULL;
496*00b67f09SDavid van Moolenbroek cfg_obj_t *config = NULL;
497*00b67f09SDavid van Moolenbroek const char *conffile = NULL;
498*00b67f09SDavid van Moolenbroek isc_mem_t *mctx = NULL;
499*00b67f09SDavid van Moolenbroek isc_result_t result;
500*00b67f09SDavid van Moolenbroek int exit_status = 0;
501*00b67f09SDavid van Moolenbroek isc_entropy_t *ectx = NULL;
502*00b67f09SDavid van Moolenbroek isc_boolean_t load_zones = ISC_FALSE;
503*00b67f09SDavid van Moolenbroek isc_boolean_t print = ISC_FALSE;
504*00b67f09SDavid van Moolenbroek unsigned int flags = 0;
505*00b67f09SDavid van Moolenbroek
506*00b67f09SDavid van Moolenbroek isc__mem_register();
507*00b67f09SDavid van Moolenbroek isc_commandline_errprint = ISC_FALSE;
508*00b67f09SDavid van Moolenbroek
509*00b67f09SDavid van Moolenbroek /*
510*00b67f09SDavid van Moolenbroek * Process memory debugging argument first.
511*00b67f09SDavid van Moolenbroek */
512*00b67f09SDavid van Moolenbroek #define CMDLINE_FLAGS "dhjm:t:pvxz"
513*00b67f09SDavid van Moolenbroek while ((c = isc_commandline_parse(argc, argv, CMDLINE_FLAGS)) != -1) {
514*00b67f09SDavid van Moolenbroek switch (c) {
515*00b67f09SDavid van Moolenbroek case 'm':
516*00b67f09SDavid van Moolenbroek if (strcasecmp(isc_commandline_argument, "record") == 0)
517*00b67f09SDavid van Moolenbroek isc_mem_debugging |= ISC_MEM_DEBUGRECORD;
518*00b67f09SDavid van Moolenbroek if (strcasecmp(isc_commandline_argument, "trace") == 0)
519*00b67f09SDavid van Moolenbroek isc_mem_debugging |= ISC_MEM_DEBUGTRACE;
520*00b67f09SDavid van Moolenbroek if (strcasecmp(isc_commandline_argument, "usage") == 0)
521*00b67f09SDavid van Moolenbroek isc_mem_debugging |= ISC_MEM_DEBUGUSAGE;
522*00b67f09SDavid van Moolenbroek if (strcasecmp(isc_commandline_argument, "size") == 0)
523*00b67f09SDavid van Moolenbroek isc_mem_debugging |= ISC_MEM_DEBUGSIZE;
524*00b67f09SDavid van Moolenbroek if (strcasecmp(isc_commandline_argument, "mctx") == 0)
525*00b67f09SDavid van Moolenbroek isc_mem_debugging |= ISC_MEM_DEBUGCTX;
526*00b67f09SDavid van Moolenbroek break;
527*00b67f09SDavid van Moolenbroek default:
528*00b67f09SDavid van Moolenbroek break;
529*00b67f09SDavid van Moolenbroek }
530*00b67f09SDavid van Moolenbroek }
531*00b67f09SDavid van Moolenbroek isc_commandline_reset = ISC_TRUE;
532*00b67f09SDavid van Moolenbroek
533*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS);
534*00b67f09SDavid van Moolenbroek
535*00b67f09SDavid van Moolenbroek while ((c = isc_commandline_parse(argc, argv, CMDLINE_FLAGS)) != EOF) {
536*00b67f09SDavid van Moolenbroek switch (c) {
537*00b67f09SDavid van Moolenbroek case 'd':
538*00b67f09SDavid van Moolenbroek debug++;
539*00b67f09SDavid van Moolenbroek break;
540*00b67f09SDavid van Moolenbroek
541*00b67f09SDavid van Moolenbroek case 'j':
542*00b67f09SDavid van Moolenbroek nomerge = ISC_FALSE;
543*00b67f09SDavid van Moolenbroek break;
544*00b67f09SDavid van Moolenbroek
545*00b67f09SDavid van Moolenbroek case 'm':
546*00b67f09SDavid van Moolenbroek break;
547*00b67f09SDavid van Moolenbroek
548*00b67f09SDavid van Moolenbroek case 't':
549*00b67f09SDavid van Moolenbroek result = isc_dir_chroot(isc_commandline_argument);
550*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS) {
551*00b67f09SDavid van Moolenbroek fprintf(stderr, "isc_dir_chroot: %s\n",
552*00b67f09SDavid van Moolenbroek isc_result_totext(result));
553*00b67f09SDavid van Moolenbroek exit(1);
554*00b67f09SDavid van Moolenbroek }
555*00b67f09SDavid van Moolenbroek break;
556*00b67f09SDavid van Moolenbroek
557*00b67f09SDavid van Moolenbroek case 'p':
558*00b67f09SDavid van Moolenbroek print = ISC_TRUE;
559*00b67f09SDavid van Moolenbroek break;
560*00b67f09SDavid van Moolenbroek
561*00b67f09SDavid van Moolenbroek case 'v':
562*00b67f09SDavid van Moolenbroek printf(VERSION "\n");
563*00b67f09SDavid van Moolenbroek exit(0);
564*00b67f09SDavid van Moolenbroek
565*00b67f09SDavid van Moolenbroek case 'x':
566*00b67f09SDavid van Moolenbroek flags |= CFG_PRINTER_XKEY;
567*00b67f09SDavid van Moolenbroek break;
568*00b67f09SDavid van Moolenbroek
569*00b67f09SDavid van Moolenbroek case 'z':
570*00b67f09SDavid van Moolenbroek load_zones = ISC_TRUE;
571*00b67f09SDavid van Moolenbroek docheckmx = ISC_FALSE;
572*00b67f09SDavid van Moolenbroek docheckns = ISC_FALSE;
573*00b67f09SDavid van Moolenbroek dochecksrv = ISC_FALSE;
574*00b67f09SDavid van Moolenbroek break;
575*00b67f09SDavid van Moolenbroek
576*00b67f09SDavid van Moolenbroek case '?':
577*00b67f09SDavid van Moolenbroek if (isc_commandline_option != '?')
578*00b67f09SDavid van Moolenbroek fprintf(stderr, "%s: invalid argument -%c\n",
579*00b67f09SDavid van Moolenbroek program, isc_commandline_option);
580*00b67f09SDavid van Moolenbroek /* FALLTHROUGH */
581*00b67f09SDavid van Moolenbroek case 'h':
582*00b67f09SDavid van Moolenbroek usage();
583*00b67f09SDavid van Moolenbroek
584*00b67f09SDavid van Moolenbroek default:
585*00b67f09SDavid van Moolenbroek fprintf(stderr, "%s: unhandled option -%c\n",
586*00b67f09SDavid van Moolenbroek program, isc_commandline_option);
587*00b67f09SDavid van Moolenbroek exit(1);
588*00b67f09SDavid van Moolenbroek }
589*00b67f09SDavid van Moolenbroek }
590*00b67f09SDavid van Moolenbroek
591*00b67f09SDavid van Moolenbroek if (((flags & CFG_PRINTER_XKEY) != 0) && !print) {
592*00b67f09SDavid van Moolenbroek fprintf(stderr, "%s: -x cannot be used without -p\n", program);
593*00b67f09SDavid van Moolenbroek exit(1);
594*00b67f09SDavid van Moolenbroek }
595*00b67f09SDavid van Moolenbroek
596*00b67f09SDavid van Moolenbroek if (isc_commandline_index + 1 < argc)
597*00b67f09SDavid van Moolenbroek usage();
598*00b67f09SDavid van Moolenbroek if (argv[isc_commandline_index] != NULL)
599*00b67f09SDavid van Moolenbroek conffile = argv[isc_commandline_index];
600*00b67f09SDavid van Moolenbroek if (conffile == NULL || conffile[0] == '\0')
601*00b67f09SDavid van Moolenbroek conffile = NAMED_CONFFILE;
602*00b67f09SDavid van Moolenbroek
603*00b67f09SDavid van Moolenbroek #ifdef _WIN32
604*00b67f09SDavid van Moolenbroek InitSockets();
605*00b67f09SDavid van Moolenbroek #endif
606*00b67f09SDavid van Moolenbroek
607*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(setup_logging(mctx, stdout, &logc) == ISC_R_SUCCESS);
608*00b67f09SDavid van Moolenbroek
609*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_entropy_create(mctx, &ectx) == ISC_R_SUCCESS);
610*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_hash_create(mctx, ectx, DNS_NAME_MAXWIRE)
611*00b67f09SDavid van Moolenbroek == ISC_R_SUCCESS);
612*00b67f09SDavid van Moolenbroek
613*00b67f09SDavid van Moolenbroek dns_result_register();
614*00b67f09SDavid van Moolenbroek
615*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(cfg_parser_create(mctx, logc, &parser) == ISC_R_SUCCESS);
616*00b67f09SDavid van Moolenbroek
617*00b67f09SDavid van Moolenbroek cfg_parser_setcallback(parser, directory_callback, NULL);
618*00b67f09SDavid van Moolenbroek
619*00b67f09SDavid van Moolenbroek if (cfg_parse_file(parser, conffile, &cfg_type_namedconf, &config) !=
620*00b67f09SDavid van Moolenbroek ISC_R_SUCCESS)
621*00b67f09SDavid van Moolenbroek exit(1);
622*00b67f09SDavid van Moolenbroek
623*00b67f09SDavid van Moolenbroek result = bind9_check_namedconf(config, logc, mctx);
624*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
625*00b67f09SDavid van Moolenbroek exit_status = 1;
626*00b67f09SDavid van Moolenbroek
627*00b67f09SDavid van Moolenbroek if (result == ISC_R_SUCCESS && load_zones) {
628*00b67f09SDavid van Moolenbroek result = load_zones_fromconfig(config, mctx);
629*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
630*00b67f09SDavid van Moolenbroek exit_status = 1;
631*00b67f09SDavid van Moolenbroek }
632*00b67f09SDavid van Moolenbroek
633*00b67f09SDavid van Moolenbroek if (print && exit_status == 0)
634*00b67f09SDavid van Moolenbroek cfg_printx(config, flags, output, NULL);
635*00b67f09SDavid van Moolenbroek cfg_obj_destroy(parser, &config);
636*00b67f09SDavid van Moolenbroek
637*00b67f09SDavid van Moolenbroek cfg_parser_destroy(&parser);
638*00b67f09SDavid van Moolenbroek
639*00b67f09SDavid van Moolenbroek dns_name_destroy();
640*00b67f09SDavid van Moolenbroek
641*00b67f09SDavid van Moolenbroek isc_log_destroy(&logc);
642*00b67f09SDavid van Moolenbroek
643*00b67f09SDavid van Moolenbroek isc_hash_destroy();
644*00b67f09SDavid van Moolenbroek isc_entropy_detach(&ectx);
645*00b67f09SDavid van Moolenbroek
646*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
647*00b67f09SDavid van Moolenbroek
648*00b67f09SDavid van Moolenbroek #ifdef _WIN32
649*00b67f09SDavid van Moolenbroek DestroySockets();
650*00b67f09SDavid van Moolenbroek #endif
651*00b67f09SDavid van Moolenbroek
652*00b67f09SDavid van Moolenbroek return (exit_status);
653*00b67f09SDavid van Moolenbroek }
654