1*00b67f09SDavid van Moolenbroek /* $NetBSD: named-journalprint.c,v 1.6 2014/12/10 04:37:54 christos Exp $ */
2*00b67f09SDavid van Moolenbroek
3*00b67f09SDavid van Moolenbroek /*
4*00b67f09SDavid van Moolenbroek * Copyright (C) 2004-2009 Internet Systems Consortium, Inc. ("ISC")
5*00b67f09SDavid van Moolenbroek * Copyright (C) 2000, 2001 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-journalprint.c,v 1.2 2009/12/04 21:59:23 marka Exp */
21*00b67f09SDavid van Moolenbroek
22*00b67f09SDavid van Moolenbroek /*! \file */
23*00b67f09SDavid van Moolenbroek #include <config.h>
24*00b67f09SDavid van Moolenbroek
25*00b67f09SDavid van Moolenbroek #include <isc/log.h>
26*00b67f09SDavid van Moolenbroek #include <isc/mem.h>
27*00b67f09SDavid van Moolenbroek #include <isc/util.h>
28*00b67f09SDavid van Moolenbroek
29*00b67f09SDavid van Moolenbroek #include <dns/journal.h>
30*00b67f09SDavid van Moolenbroek #include <dns/log.h>
31*00b67f09SDavid van Moolenbroek #include <dns/result.h>
32*00b67f09SDavid van Moolenbroek #include <dns/types.h>
33*00b67f09SDavid van Moolenbroek
34*00b67f09SDavid van Moolenbroek #include <stdlib.h>
35*00b67f09SDavid van Moolenbroek
36*00b67f09SDavid van Moolenbroek /*
37*00b67f09SDavid van Moolenbroek * Setup logging to use stderr.
38*00b67f09SDavid van Moolenbroek */
39*00b67f09SDavid van Moolenbroek static isc_result_t
setup_logging(isc_mem_t * mctx,FILE * errout,isc_log_t ** logp)40*00b67f09SDavid van Moolenbroek setup_logging(isc_mem_t *mctx, FILE *errout, isc_log_t **logp) {
41*00b67f09SDavid van Moolenbroek isc_logdestination_t destination;
42*00b67f09SDavid van Moolenbroek isc_logconfig_t *logconfig = NULL;
43*00b67f09SDavid van Moolenbroek isc_log_t *log = NULL;
44*00b67f09SDavid van Moolenbroek
45*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_log_create(mctx, &log, &logconfig) == ISC_R_SUCCESS);
46*00b67f09SDavid van Moolenbroek isc_log_setcontext(log);
47*00b67f09SDavid van Moolenbroek dns_log_init(log);
48*00b67f09SDavid van Moolenbroek dns_log_setcontext(log);
49*00b67f09SDavid van Moolenbroek
50*00b67f09SDavid van Moolenbroek destination.file.stream = errout;
51*00b67f09SDavid van Moolenbroek destination.file.name = NULL;
52*00b67f09SDavid van Moolenbroek destination.file.versions = ISC_LOG_ROLLNEVER;
53*00b67f09SDavid van Moolenbroek destination.file.maximum_size = 0;
54*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_log_createchannel(logconfig, "stderr",
55*00b67f09SDavid van Moolenbroek ISC_LOG_TOFILEDESC,
56*00b67f09SDavid van Moolenbroek ISC_LOG_DYNAMIC,
57*00b67f09SDavid van Moolenbroek &destination, 0) == ISC_R_SUCCESS);
58*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_log_usechannel(logconfig, "stderr",
59*00b67f09SDavid van Moolenbroek NULL, NULL) == ISC_R_SUCCESS);
60*00b67f09SDavid van Moolenbroek
61*00b67f09SDavid van Moolenbroek *logp = log;
62*00b67f09SDavid van Moolenbroek return (ISC_R_SUCCESS);
63*00b67f09SDavid van Moolenbroek }
64*00b67f09SDavid van Moolenbroek
65*00b67f09SDavid van Moolenbroek int
main(int argc,char ** argv)66*00b67f09SDavid van Moolenbroek main(int argc, char **argv) {
67*00b67f09SDavid van Moolenbroek char *file;
68*00b67f09SDavid van Moolenbroek isc_mem_t *mctx = NULL;
69*00b67f09SDavid van Moolenbroek isc_result_t result;
70*00b67f09SDavid van Moolenbroek isc_log_t *lctx = NULL;
71*00b67f09SDavid van Moolenbroek
72*00b67f09SDavid van Moolenbroek if (argc != 2) {
73*00b67f09SDavid van Moolenbroek printf("usage: %s journal\n", argv[0]);
74*00b67f09SDavid van Moolenbroek return(1);
75*00b67f09SDavid van Moolenbroek }
76*00b67f09SDavid van Moolenbroek
77*00b67f09SDavid van Moolenbroek file = argv[1];
78*00b67f09SDavid van Moolenbroek
79*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS);
80*00b67f09SDavid van Moolenbroek RUNTIME_CHECK(setup_logging(mctx, stderr, &lctx) == ISC_R_SUCCESS);
81*00b67f09SDavid van Moolenbroek
82*00b67f09SDavid van Moolenbroek result = dns_journal_print(mctx, file, stdout);
83*00b67f09SDavid van Moolenbroek if (result == DNS_R_NOJOURNAL)
84*00b67f09SDavid van Moolenbroek fprintf(stderr, "%s\n", dns_result_totext(result));
85*00b67f09SDavid van Moolenbroek isc_log_destroy(&lctx);
86*00b67f09SDavid van Moolenbroek isc_mem_detach(&mctx);
87*00b67f09SDavid van Moolenbroek return(result != ISC_R_SUCCESS ? 1 : 0);
88*00b67f09SDavid van Moolenbroek }
89