/* * Copyright (C) 1999, 2000 Internet Software Consortium. * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND INTERNET SOFTWARE CONSORTIUM * DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL * INTERNET SOFTWARE CONSORTIUM BE LIABLE FOR ANY SPECIAL, DIRECT, * INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING * FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, * NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION * WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. */ /* $Id: cfg_test.c,v 1.5 2001/02/22 04:17:57 gson Exp $ */ #include #include #include #include #include #include #include #include #include static void check_result(isc_result_t result, const char *format, ...) { va_list args; if (result == ISC_R_SUCCESS) return; va_start(args, format); vfprintf(stderr, format, args); va_end(args); fprintf(stderr, ": %s\n", isc_result_totext(result)); exit(1); } static void output(void *closure, const char *text, int textlen) { UNUSED(closure); (void) fwrite(text, 1, textlen, stdout); } static void usage() { fprintf(stderr, "usage: cfg_test --rndc|--named conffile\n"); exit(1); } int main(int argc, char **argv) { isc_result_t result; isc_mem_t *mctx = NULL; isc_log_t *lctx = NULL; isc_logconfig_t *lcfg = NULL; isc_logdestination_t destination; cfg_parser_t *pctx = NULL; cfg_obj_t *cfg = NULL; cfg_type_t *type; RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS); result = isc_log_create(mctx, &lctx, &lcfg); check_result(result, "isc_log_create()"); isc_log_setcontext(lctx); /* * Create and install the default channel. */ destination.file.stream = stderr; destination.file.name = NULL; destination.file.versions = ISC_LOG_ROLLNEVER; destination.file.maximum_size = 0; result = isc_log_createchannel(lcfg, "_default", ISC_LOG_TOFILEDESC, ISC_LOG_DYNAMIC, &destination, ISC_LOG_PRINTTIME); check_result(result, "isc_log_createchannel()"); result = isc_log_usechannel(lcfg, "_default", NULL, NULL); check_result(result, "isc_log_usechannel()"); /* * Set the initial debug level. */ isc_log_setdebuglevel(lctx, 2); if (argc < 3) usage(); if (strcmp(argv[1], "--named") == 0) type = &cfg_type_namedconf; else if (strcmp(argv[1], "--rndc") == 0) type = &cfg_type_rndcconf; else usage(); RUNTIME_CHECK(cfg_parser_create(mctx, lctx, &pctx) == ISC_R_SUCCESS); result = cfg_parse_file(pctx, argv[2], type, &cfg); fprintf(stderr, "read config: %s\n", isc_result_totext(result)); if (result != ISC_R_SUCCESS) exit(1); cfg_print(cfg, output, NULL); #if 1 /* Example of how to extract stuff from a configuration. */ if (type == &cfg_type_namedconf) { cfg_obj_t *options = NULL; cfg_obj_t *version = NULL; cfg_obj_t *zones = NULL; result = cfg_map_get(cfg, "options", &options); if (result == ISC_R_SUCCESS) { result = cfg_map_get(options, "version", &version); if (result == ISC_R_SUCCESS) { fprintf(stderr, "(server version is \"%s\")\n", cfg_obj_asstring(version)); } } result = cfg_map_get(cfg, "zone", &zones); if (result == ISC_R_SUCCESS) { cfg_listelt_t *elt; for (elt = cfg_list_first(zones); elt != NULL; elt = cfg_list_next(elt)) { cfg_obj_t *zone = cfg_listelt_value(elt); fprintf(stderr, "(zone name is \"%s\")\n", cfg_obj_asstring(cfg_tuple_get(zone, "name"))); } } } else if (type == &cfg_type_rndcconf) { cfg_obj_t *keys = NULL; result = cfg_map_get(cfg, "key", &keys); if (result == ISC_R_SUCCESS) { cfg_listelt_t *elt; for (elt = cfg_list_first(keys); elt != NULL; elt = cfg_list_next(elt)) { cfg_obj_t *key = cfg_listelt_value(elt); cfg_obj_t *secret = NULL; result = cfg_map_get(key, "secret", &secret); if (result == ISC_R_SUCCESS) { fprintf(stderr, "(key \"%s\" secret " "is \"%s\")\n", cfg_obj_asstring(cfg_map_getname(key)), cfg_obj_asstring(secret)); } } } } #endif cfg_obj_destroy(pctx, &cfg); cfg_parser_destroy(&pctx); isc_log_destroy(&lctx); isc_mem_stats(mctx, stderr); isc_mem_destroy(&mctx); return (0); }