⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 dnssectool.c

📁 bind-3.2.
💻 C
字号:
/* * Copyright (C) 2000, 2001, 2003  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: dnssectool.c,v 1.31.2.4 2003/10/09 07:32:31 marka Exp $ */#include <config.h>#include <stdlib.h>#include <isc/buffer.h>#include <isc/entropy.h>#include <isc/string.h>#include <isc/time.h>#include <isc/util.h>#include <isc/print.h>#include <dns/log.h>#include <dns/name.h>#include <dns/rdatastruct.h>#include <dns/rdatatype.h>#include <dns/result.h>#include <dns/secalg.h>#include <dns/time.h>#include "dnssectool.h"extern int verbose;extern const char *program;static isc_entropysource_t *source = NULL;static fatalcallback_t *fatalcallback = NULL;voidfatal(const char *format, ...) {	va_list args;	fprintf(stderr, "%s: ", program);	va_start(args, format);	vfprintf(stderr, format, args);	va_end(args);	fprintf(stderr, "\n");	if (fatalcallback != NULL)		(*fatalcallback)();	exit(1);}voidsetfatalcallback(fatalcallback_t *callback) {	fatalcallback = callback;}voidcheck_result(isc_result_t result, const char *message) {	if (result != ISC_R_SUCCESS)		fatal("%s: %s", message, isc_result_totext(result));}voidvbprintf(int level, const char *fmt, ...) {	va_list ap;	if (level > verbose)		return;	va_start(ap, fmt);	fprintf(stderr, "%s: ", program);	vfprintf(stderr, fmt, ap);	va_end(ap);}voidtype_format(const dns_rdatatype_t type, char *cp, unsigned int size) {	isc_buffer_t b;	isc_region_t r;	isc_result_t result;	isc_buffer_init(&b, cp, size - 1);	result = dns_rdatatype_totext(type, &b);	check_result(result, "dns_rdatatype_totext()");	isc_buffer_usedregion(&b, &r);	r.base[r.length] = 0;}voidalg_format(const dns_secalg_t alg, char *cp, unsigned int size) {	isc_buffer_t b;	isc_region_t r;	isc_result_t result;	isc_buffer_init(&b, cp, size - 1);	result = dns_secalg_totext(alg, &b);	check_result(result, "dns_secalg_totext()");	isc_buffer_usedregion(&b, &r);	r.base[r.length] = 0;}voidsig_format(dns_rdata_sig_t *sig, char *cp, unsigned int size) {	char namestr[DNS_NAME_FORMATSIZE];	char algstr[DNS_NAME_FORMATSIZE];	dns_name_format(&sig->signer, namestr, sizeof namestr);	alg_format(sig->algorithm, algstr, sizeof algstr);	snprintf(cp, size, "%s/%s/%d", namestr, algstr, sig->keyid);}voidkey_format(const dst_key_t *key, char *cp, unsigned int size) {	char namestr[DNS_NAME_FORMATSIZE];	char algstr[DNS_NAME_FORMATSIZE];	dns_name_format(dst_key_name(key), namestr, sizeof namestr);	alg_format((dns_secalg_t) dst_key_alg(key), algstr, sizeof algstr);	snprintf(cp, size, "%s/%s/%d", namestr, algstr, dst_key_id(key));}voidsetup_logging(int verbose, isc_mem_t *mctx, isc_log_t **logp) {	isc_result_t result;	isc_logdestination_t destination;	isc_logconfig_t *logconfig = NULL;	isc_log_t *log = NULL;	int level;	switch (verbose) {	case 0:		/*		 * We want to see warnings about things like out-of-zone		 * data in the master file even when not verbose.		 */		level = ISC_LOG_WARNING;		break;	case 1:		level = ISC_LOG_INFO;		break;	default:		level = ISC_LOG_DEBUG(verbose - 2 + 1);		break;	}	RUNTIME_CHECK(isc_log_create(mctx, &log, &logconfig) == ISC_R_SUCCESS);	isc_log_setcontext(log);	dns_log_init(log);	dns_log_setcontext(log);	RUNTIME_CHECK(isc_log_settag(logconfig, program) == ISC_R_SUCCESS);	/*	 * Set up a channel similar to default_stderr except:	 *  - the logging level is passed in	 *  - the program name and logging level are printed	 *  - no time stamp is printed	 */	destination.file.stream = stderr;	destination.file.name = NULL;	destination.file.versions = ISC_LOG_ROLLNEVER;	destination.file.maximum_size = 0;	result = isc_log_createchannel(logconfig, "stderr",				       ISC_LOG_TOFILEDESC,				       level,				       &destination,				       ISC_LOG_PRINTTAG|ISC_LOG_PRINTLEVEL);	check_result(result, "isc_log_createchannel()");	RUNTIME_CHECK(isc_log_usechannel(logconfig, "stderr",					 NULL, NULL) == ISC_R_SUCCESS);	*logp = log;}voidcleanup_logging(isc_log_t **logp) {	isc_log_t *log;	REQUIRE(logp != NULL);	log = *logp;	if (log == NULL)		return;	isc_log_destroy(&log);	isc_log_setcontext(NULL);	dns_log_setcontext(NULL);	logp = NULL;}voidsetup_entropy(isc_mem_t *mctx, const char *randomfile, isc_entropy_t **ectx) {	isc_result_t result;	int usekeyboard = ISC_ENTROPY_KEYBOARDMAYBE;	REQUIRE(ectx != NULL);		if (*ectx == NULL) {		result = isc_entropy_create(mctx, ectx);		if (result != ISC_R_SUCCESS)			fatal("could not create entropy object");	}	if (randomfile != NULL && strcmp(randomfile, "keyboard") == 0) {		usekeyboard = ISC_ENTROPY_KEYBOARDYES;		randomfile = NULL;	}	result = isc_entropy_usebestsource(*ectx, &source, randomfile,					   usekeyboard);	if (result != ISC_R_SUCCESS)		fatal("could not initialize entropy source: %s",		      isc_result_totext(result));}voidcleanup_entropy(isc_entropy_t **ectx) {	if (source != NULL)		isc_entropy_destroysource(&source);	isc_entropy_detach(ectx);}isc_stdtime_tstrtotime(char *str, isc_int64_t now, isc_int64_t base) {	isc_int64_t val, offset;	isc_result_t result;	char *endp;	if (str[0] == '+') {		offset = strtol(str + 1, &endp, 0);		if (*endp != '\0')			fatal("time value %s is invalid", str);		val = base + offset;	} else if (strncmp(str, "now+", 4) == 0) {		offset = strtol(str + 4, &endp, 0);		if (*endp != '\0')			fatal("time value %s is invalid", str);		val = now + offset;	} else if (strlen(str) == 8U) {		char timestr[15];		sprintf(timestr, "%s000000", str);		result = dns_time64_fromtext(timestr, &val);		if (result != ISC_R_SUCCESS)			fatal("time value %s is invalid", str);	} else {		result = dns_time64_fromtext(str, &val);		if (result != ISC_R_SUCCESS)			fatal("time value %s is invalid", str);	}	return ((isc_stdtime_t) val);}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -