1*00b67f09SDavid van Moolenbroek /* $NetBSD: cfg_test.c,v 1.6 2014/12/10 04:37:53 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004, 2005, 2007, 2009-2011 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek * Copyright (C) 2001, 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: cfg_test.c,v 1.25 2011/09/05 23:46:54 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
29*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
30*00b67f09SDavid van Moolenbroek #include <isc/string.h>
31*00b67f09SDavid van Moolenbroek #include <isc/util.h>
32*00b67f09SDavid van Moolenbroek
33*00b67f09SDavid van Moolenbroek #include <isccfg/namedconf.h>
34*00b67f09SDavid van Moolenbroek
35*00b67f09SDavid van Moolenbroek #include <dns/log.h>
36*00b67f09SDavid van Moolenbroek
37*00b67f09SDavid van Moolenbroek static void
check_result(isc_result_t result,const char * format,...)38*00b67f09SDavid van Moolenbroek check_result(isc_result_t result, const char *format, ...) {
39*00b67f09SDavid van Moolenbroek va_list args;
40*00b67f09SDavid van Moolenbroek
41*00b67f09SDavid van Moolenbroek if (result == ISC_R_SUCCESS)
42*00b67f09SDavid van Moolenbroek return;
43*00b67f09SDavid van Moolenbroek
44*00b67f09SDavid van Moolenbroek va_start(args, format);
45*00b67f09SDavid van Moolenbroek vfprintf(stderr, format, args);
46*00b67f09SDavid van Moolenbroek va_end(args);
47*00b67f09SDavid van Moolenbroek fprintf(stderr, ": %s\n", isc_result_totext(result));
48*00b67f09SDavid van Moolenbroek exit(1);
49*00b67f09SDavid van Moolenbroek }
50*00b67f09SDavid van Moolenbroek
51*00b67f09SDavid van Moolenbroek static void
output(void * closure,const char * text,int textlen)52*00b67f09SDavid van Moolenbroek output(void *closure, const char *text, int textlen) {
53*00b67f09SDavid van Moolenbroek UNUSED(closure);
54*00b67f09SDavid van Moolenbroek (void) fwrite(text, 1, textlen, stdout);
55*00b67f09SDavid van Moolenbroek }
56*00b67f09SDavid van Moolenbroek
57*00b67f09SDavid van Moolenbroek static void
usage(void)58*00b67f09SDavid van Moolenbroek usage(void) {
59*00b67f09SDavid van Moolenbroek fprintf(stderr, "usage: cfg_test --rndc|--named "
60*00b67f09SDavid van Moolenbroek "[--grammar] [--memstats] conffile\n");
61*00b67f09SDavid van Moolenbroek exit(1);
62*00b67f09SDavid van Moolenbroek }
63*00b67f09SDavid van Moolenbroek
64*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)65*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
66*00b67f09SDavid van Moolenbroek isc_result_t result;
67*00b67f09SDavid van Moolenbroek isc_mem_t *mctx = NULL;
68*00b67f09SDavid van Moolenbroek isc_log_t *lctx = NULL;
69*00b67f09SDavid van Moolenbroek isc_logconfig_t *lcfg = NULL;
70*00b67f09SDavid van Moolenbroek isc_logdestination_t destination;
71*00b67f09SDavid van Moolenbroek cfg_parser_t *pctx = NULL;
72*00b67f09SDavid van Moolenbroek cfg_obj_t *cfg = NULL;
73*00b67f09SDavid van Moolenbroek cfg_type_t *type = NULL;
74*00b67f09SDavid van Moolenbroek isc_boolean_t grammar = ISC_FALSE;
75*00b67f09SDavid van Moolenbroek isc_boolean_t memstats = ISC_FALSE;
76*00b67f09SDavid van Moolenbroek char *filename = NULL;
77*00b67f09SDavid van Moolenbroek
78*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS);
79*00b67f09SDavid van Moolenbroek
80*00b67f09SDavid van Moolenbroek result = isc_log_create(mctx, &lctx, &lcfg);
81*00b67f09SDavid van Moolenbroek check_result(result, "isc_log_create()");
82*00b67f09SDavid van Moolenbroek isc_log_setcontext(lctx);
83*00b67f09SDavid van Moolenbroek
84*00b67f09SDavid van Moolenbroek /*
85*00b67f09SDavid van Moolenbroek * Create and install the default channel.
86*00b67f09SDavid van Moolenbroek */
87*00b67f09SDavid van Moolenbroek destination.file.stream = stderr;
88*00b67f09SDavid van Moolenbroek destination.file.name = NULL;
89*00b67f09SDavid van Moolenbroek destination.file.versions = ISC_LOG_ROLLNEVER;
90*00b67f09SDavid van Moolenbroek destination.file.maximum_size = 0;
91*00b67f09SDavid van Moolenbroek result = isc_log_createchannel(lcfg, "_default",
92*00b67f09SDavid van Moolenbroek ISC_LOG_TOFILEDESC,
93*00b67f09SDavid van Moolenbroek ISC_LOG_DYNAMIC,
94*00b67f09SDavid van Moolenbroek &destination, ISC_LOG_PRINTTIME);
95*00b67f09SDavid van Moolenbroek check_result(result, "isc_log_createchannel()");
96*00b67f09SDavid van Moolenbroek result = isc_log_usechannel(lcfg, "_default", NULL, NULL);
97*00b67f09SDavid van Moolenbroek check_result(result, "isc_log_usechannel()");
98*00b67f09SDavid van Moolenbroek
99*00b67f09SDavid van Moolenbroek /*
100*00b67f09SDavid van Moolenbroek * Set the initial debug level.
101*00b67f09SDavid van Moolenbroek */
102*00b67f09SDavid van Moolenbroek isc_log_setdebuglevel(lctx, 2);
103*00b67f09SDavid van Moolenbroek
104*00b67f09SDavid van Moolenbroek if (argc < 3)
105*00b67f09SDavid van Moolenbroek usage();
106*00b67f09SDavid van Moolenbroek
107*00b67f09SDavid van Moolenbroek while (argc > 1) {
108*00b67f09SDavid van Moolenbroek if (strcmp(argv[1], "--grammar") == 0) {
109*00b67f09SDavid van Moolenbroek grammar = ISC_TRUE;
110*00b67f09SDavid van Moolenbroek } else if (strcmp(argv[1], "--memstats") == 0) {
111*00b67f09SDavid van Moolenbroek memstats = ISC_TRUE;
112*00b67f09SDavid van Moolenbroek } else if (strcmp(argv[1], "--named") == 0) {
113*00b67f09SDavid van Moolenbroek type = &cfg_type_namedconf;
114*00b67f09SDavid van Moolenbroek } else if (strcmp(argv[1], "--rndc") == 0) {
115*00b67f09SDavid van Moolenbroek type = &cfg_type_rndcconf;
116*00b67f09SDavid van Moolenbroek } else if (argv[1][0] == '-') {
117*00b67f09SDavid van Moolenbroek usage();
118*00b67f09SDavid van Moolenbroek } else {
119*00b67f09SDavid van Moolenbroek filename = argv[1];
120*00b67f09SDavid van Moolenbroek }
121*00b67f09SDavid van Moolenbroek argv++, argc--;
122*00b67f09SDavid van Moolenbroek }
123*00b67f09SDavid van Moolenbroek
124*00b67f09SDavid van Moolenbroek if (grammar) {
125*00b67f09SDavid van Moolenbroek if (type == NULL)
126*00b67f09SDavid van Moolenbroek usage();
127*00b67f09SDavid van Moolenbroek cfg_print_grammar(type, output, NULL);
128*00b67f09SDavid van Moolenbroek } else {
129*00b67f09SDavid van Moolenbroek if (type == NULL || filename == NULL)
130*00b67f09SDavid van Moolenbroek usage();
131*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(cfg_parser_create(mctx, lctx, &pctx) == ISC_R_SUCCESS);
132*00b67f09SDavid van Moolenbroek
133*00b67f09SDavid van Moolenbroek result = cfg_parse_file(pctx, filename, type, &cfg);
134*00b67f09SDavid van Moolenbroek
135*00b67f09SDavid van Moolenbroek fprintf(stderr, "read config: %s\n", isc_result_totext(result));
136*00b67f09SDavid van Moolenbroek
137*00b67f09SDavid van Moolenbroek if (result != ISC_R_SUCCESS)
138*00b67f09SDavid van Moolenbroek exit(1);
139*00b67f09SDavid van Moolenbroek
140*00b67f09SDavid van Moolenbroek cfg_print(cfg, output, NULL);
141*00b67f09SDavid van Moolenbroek
142*00b67f09SDavid van Moolenbroek cfg_obj_destroy(pctx, &cfg);
143*00b67f09SDavid van Moolenbroek
144*00b67f09SDavid van Moolenbroek cfg_parser_destroy(&pctx);
145*00b67f09SDavid van Moolenbroek }
146*00b67f09SDavid van Moolenbroek
147*00b67f09SDavid van Moolenbroek isc_log_destroy(&lctx);
148*00b67f09SDavid van Moolenbroek if (memstats)
149*00b67f09SDavid van Moolenbroek isc_mem_stats(mctx, stderr);
150*00b67f09SDavid van Moolenbroek isc_mem_destroy(&mctx);
151*00b67f09SDavid van Moolenbroek
152*00b67f09SDavid van Moolenbroek fflush(stdout);
153*00b67f09SDavid van Moolenbroek if (ferror(stdout)) {
154*00b67f09SDavid van Moolenbroek fprintf(stderr, "write error\n");
155*00b67f09SDavid van Moolenbroek return (1);
156*00b67f09SDavid van Moolenbroek } else
157*00b67f09SDavid van Moolenbroek return (0);
158*00b67f09SDavid van Moolenbroek }
159