1999-01-28 23:53:36 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 1999 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.
|
|
|
|
*/
|
|
|
|
|
1999-04-01 04:14:25 +00:00
|
|
|
/*
|
|
|
|
* Principal Author: Bob Halley
|
|
|
|
*/
|
|
|
|
|
1999-01-28 23:53:36 +00:00
|
|
|
#include <config.h>
|
|
|
|
|
|
|
|
#include <stddef.h>
|
1999-01-29 07:05:09 +00:00
|
|
|
#include <stdlib.h>
|
|
|
|
#include <string.h>
|
1999-04-09 01:15:12 +00:00
|
|
|
#include <time.h>
|
|
|
|
#include <sys/time.h> /* XXX Naughty. */
|
1999-01-29 23:36:41 +00:00
|
|
|
#include <unistd.h> /* XXX Naughty. */
|
1999-01-28 23:53:36 +00:00
|
|
|
|
|
|
|
#include <isc/assertions.h>
|
|
|
|
#include <isc/error.h>
|
|
|
|
#include <isc/boolean.h>
|
|
|
|
#include <isc/region.h>
|
1999-04-17 01:38:04 +00:00
|
|
|
#include <isc/list.h>
|
1999-01-28 23:53:36 +00:00
|
|
|
|
|
|
|
#include <dns/types.h>
|
|
|
|
#include <dns/result.h>
|
|
|
|
#include <dns/name.h>
|
1999-04-01 04:14:25 +00:00
|
|
|
#include <dns/fixedname.h>
|
1999-01-28 23:53:36 +00:00
|
|
|
#include <dns/rdata.h>
|
|
|
|
#include <dns/rdataclass.h>
|
|
|
|
#include <dns/rdatatype.h>
|
|
|
|
#include <dns/rdatalist.h>
|
|
|
|
#include <dns/rdataset.h>
|
1999-03-11 06:02:50 +00:00
|
|
|
#include <dns/rdatasetiter.h>
|
1999-01-28 23:53:36 +00:00
|
|
|
#include <dns/compress.h>
|
|
|
|
#include <dns/db.h>
|
1999-04-17 01:38:04 +00:00
|
|
|
#include <dns/dbiterator.h>
|
1999-04-14 02:37:44 +00:00
|
|
|
#include <dns/dbtable.h>
|
1999-01-28 23:53:36 +00:00
|
|
|
|
1999-04-14 02:37:44 +00:00
|
|
|
#define MAXHOLD 100
|
|
|
|
#define MAXVERSIONS 100
|
1999-01-29 07:05:09 +00:00
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
typedef struct dbinfo {
|
|
|
|
dns_db_t * db;
|
|
|
|
dns_dbversion_t * version;
|
|
|
|
dns_dbversion_t * wversion;
|
|
|
|
dns_dbversion_t * rversions[MAXVERSIONS];
|
|
|
|
int rcount;
|
|
|
|
dns_dbnode_t * hold_nodes[MAXHOLD];
|
|
|
|
int hold_count;
|
1999-04-19 22:53:33 +00:00
|
|
|
dns_dbiterator_t * dbiterator;
|
|
|
|
dns_dbversion_t * iversion;
|
|
|
|
int pause_every;
|
1999-04-17 01:38:04 +00:00
|
|
|
ISC_LINK(struct dbinfo) link;
|
|
|
|
} dbinfo;
|
|
|
|
|
1999-04-14 02:37:44 +00:00
|
|
|
static isc_mem_t * mctx = NULL;
|
|
|
|
static char dbtype[128];
|
|
|
|
static dns_dbtable_t * dbtable;
|
1999-04-17 01:38:04 +00:00
|
|
|
static ISC_LIST(dbinfo) dbs;
|
|
|
|
static dbinfo * cache_dbi = NULL;
|
|
|
|
static int pause_every = 0;
|
1999-01-29 07:05:09 +00:00
|
|
|
|
1999-03-11 06:02:50 +00:00
|
|
|
static void
|
|
|
|
print_rdataset(dns_name_t *name, dns_rdataset_t *rdataset) {
|
|
|
|
isc_buffer_t text;
|
|
|
|
char t[1000];
|
|
|
|
dns_result_t result;
|
|
|
|
isc_region_t r;
|
|
|
|
|
|
|
|
isc_buffer_init(&text, t, sizeof t, ISC_BUFFERTYPE_TEXT);
|
1999-04-30 21:15:02 +00:00
|
|
|
result = dns_rdataset_totext(rdataset, name, ISC_FALSE, ISC_FALSE,
|
|
|
|
&text);
|
1999-03-11 06:02:50 +00:00
|
|
|
isc_buffer_used(&text, &r);
|
|
|
|
if (result == DNS_R_SUCCESS)
|
|
|
|
printf("%.*s", (int)r.length, (char *)r.base);
|
|
|
|
else
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
print_rdatasets(dns_name_t *name, dns_rdatasetiter_t *rdsiter) {
|
|
|
|
dns_result_t result;
|
|
|
|
dns_rdataset_t rdataset;
|
|
|
|
|
|
|
|
dns_rdataset_init(&rdataset);
|
|
|
|
result = dns_rdatasetiter_first(rdsiter);
|
|
|
|
while (result == DNS_R_SUCCESS) {
|
|
|
|
dns_rdatasetiter_current(rdsiter, &rdataset);
|
|
|
|
print_rdataset(name, &rdataset);
|
|
|
|
dns_rdataset_disassociate(&rdataset);
|
|
|
|
result = dns_rdatasetiter_next(rdsiter);
|
|
|
|
}
|
|
|
|
if (result != DNS_R_NOMORE)
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
|
|
|
}
|
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
static dbinfo *
|
|
|
|
select_db(char *origintext) {
|
|
|
|
dns_fixedname_t forigin;
|
|
|
|
dns_name_t *origin;
|
|
|
|
isc_buffer_t source;
|
|
|
|
size_t len;
|
|
|
|
dbinfo *dbi;
|
|
|
|
dns_result_t result;
|
|
|
|
|
|
|
|
if (strcasecmp(origintext, "cache") == 0) {
|
|
|
|
if (cache_dbi == NULL)
|
|
|
|
printf("the cache does not exist\n");
|
|
|
|
return (cache_dbi);
|
|
|
|
}
|
|
|
|
len = strlen(origintext);
|
|
|
|
isc_buffer_init(&source, origintext, len, ISC_BUFFERTYPE_TEXT);
|
|
|
|
isc_buffer_add(&source, len);
|
|
|
|
dns_fixedname_init(&forigin);
|
|
|
|
origin = dns_fixedname_name(&forigin);
|
|
|
|
result = dns_name_fromtext(origin, &source, dns_rootname, ISC_FALSE,
|
|
|
|
NULL);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
printf("bad name: %s\n", dns_result_totext(result));
|
|
|
|
return (NULL);
|
|
|
|
}
|
|
|
|
|
|
|
|
for (dbi = ISC_LIST_HEAD(dbs);
|
|
|
|
dbi != NULL;
|
|
|
|
dbi = ISC_LIST_NEXT(dbi, link)) {
|
|
|
|
if (dns_name_compare(dns_db_origin(dbi->db), origin) == 0)
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (dbi);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
dump(dbinfo *dbi) {
|
|
|
|
dns_fixedname_t fname;
|
|
|
|
dns_name_t *name;
|
|
|
|
dns_dbnode_t *node;
|
|
|
|
dns_rdatasetiter_t *rdsiter;
|
|
|
|
dns_result_t result;
|
|
|
|
int i;
|
|
|
|
|
1999-04-19 22:53:33 +00:00
|
|
|
dns_fixedname_init(&fname);
|
|
|
|
name = dns_fixedname_name(&fname);
|
|
|
|
|
|
|
|
if (dbi->dbiterator == NULL) {
|
|
|
|
INSIST(dbi->iversion == NULL);
|
|
|
|
if (dns_db_iszone(dbi->db)) {
|
|
|
|
if (dbi->version != NULL)
|
|
|
|
dns_db_attachversion(dbi->db, dbi->version,
|
|
|
|
&dbi->iversion);
|
|
|
|
else
|
|
|
|
dns_db_currentversion(dbi->db, &dbi->iversion);
|
1999-04-17 01:38:04 +00:00
|
|
|
}
|
|
|
|
|
1999-04-19 22:53:33 +00:00
|
|
|
result = dns_db_createiterator(dbi->db, ISC_FALSE,
|
|
|
|
&dbi->dbiterator);
|
|
|
|
if (result == DNS_R_SUCCESS)
|
|
|
|
result = dns_dbiterator_first(dbi->dbiterator);
|
|
|
|
} else
|
|
|
|
result = DNS_R_SUCCESS;
|
1999-04-17 01:38:04 +00:00
|
|
|
|
|
|
|
node = NULL;
|
|
|
|
rdsiter = NULL;
|
|
|
|
i = 0;
|
|
|
|
while (result == DNS_R_SUCCESS) {
|
1999-04-19 22:53:33 +00:00
|
|
|
result = dns_dbiterator_current(dbi->dbiterator, &node, name);
|
1999-04-17 01:38:04 +00:00
|
|
|
if (result != DNS_R_SUCCESS && result != DNS_R_NEWORIGIN)
|
|
|
|
break;
|
1999-04-19 22:53:33 +00:00
|
|
|
result = dns_db_allrdatasets(dbi->db, node, dbi->iversion, 0,
|
1999-04-17 01:38:04 +00:00
|
|
|
&rdsiter);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
dns_db_detachnode(dbi->db, &node);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
print_rdatasets(name, rdsiter);
|
|
|
|
dns_rdatasetiter_destroy(&rdsiter);
|
|
|
|
dns_db_detachnode(dbi->db, &node);
|
1999-04-19 22:53:33 +00:00
|
|
|
result = dns_dbiterator_next(dbi->dbiterator);
|
1999-04-17 01:38:04 +00:00
|
|
|
i++;
|
1999-04-19 22:53:33 +00:00
|
|
|
if (result == DNS_R_SUCCESS && i == dbi->pause_every) {
|
|
|
|
printf("[more...]\n");
|
|
|
|
result = dns_dbiterator_pause(dbi->dbiterator);
|
|
|
|
if (result == DNS_R_SUCCESS)
|
|
|
|
return;
|
1999-04-17 01:38:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
if (result != DNS_R_NOMORE)
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
|
|
|
|
1999-04-19 22:53:33 +00:00
|
|
|
dns_dbiterator_destroy(&dbi->dbiterator);
|
|
|
|
if (dbi->iversion != NULL)
|
|
|
|
dns_db_closeversion(dbi->db, &dbi->iversion, ISC_FALSE);
|
1999-04-17 01:38:04 +00:00
|
|
|
}
|
|
|
|
|
1999-04-14 02:37:44 +00:00
|
|
|
static dns_result_t
|
|
|
|
load(char *filename, char *origintext, isc_boolean_t cache) {
|
|
|
|
dns_fixedname_t forigin;
|
|
|
|
dns_name_t *origin;
|
|
|
|
dns_result_t result;
|
|
|
|
isc_buffer_t source;
|
|
|
|
size_t len;
|
1999-04-17 01:38:04 +00:00
|
|
|
dbinfo *dbi;
|
|
|
|
unsigned int i;
|
|
|
|
|
|
|
|
dbi = isc_mem_get(mctx, sizeof *dbi);
|
|
|
|
if (dbi == NULL)
|
|
|
|
return (DNS_R_NOMEMORY);
|
1999-04-14 02:37:44 +00:00
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->db = NULL;
|
|
|
|
dbi->version = NULL;
|
|
|
|
dbi->wversion = NULL;
|
|
|
|
for (i = 0; i < MAXVERSIONS; i++)
|
|
|
|
dbi->rversions[i] = NULL;
|
|
|
|
dbi->hold_count = 0;
|
|
|
|
for (i = 0; i < MAXHOLD; i++)
|
|
|
|
dbi->hold_nodes[i] = NULL;
|
1999-04-19 22:53:33 +00:00
|
|
|
dbi->dbiterator = NULL;
|
|
|
|
dbi->iversion = NULL;
|
|
|
|
dbi->pause_every = pause_every;
|
1999-04-14 02:37:44 +00:00
|
|
|
|
|
|
|
len = strlen(origintext);
|
|
|
|
isc_buffer_init(&source, origintext, len, ISC_BUFFERTYPE_TEXT);
|
|
|
|
isc_buffer_add(&source, len);
|
|
|
|
dns_fixedname_init(&forigin);
|
|
|
|
origin = dns_fixedname_name(&forigin);
|
|
|
|
result = dns_name_fromtext(origin, &source, dns_rootname, ISC_FALSE,
|
|
|
|
NULL);
|
|
|
|
if (result != DNS_R_SUCCESS)
|
|
|
|
return (result);
|
|
|
|
|
|
|
|
result = dns_db_create(mctx, dbtype, origin, cache, dns_rdataclass_in,
|
1999-04-17 01:38:04 +00:00
|
|
|
0, NULL, &dbi->db);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
isc_mem_put(mctx, dbi, sizeof *dbi);
|
1999-04-14 02:37:44 +00:00
|
|
|
return (result);
|
1999-04-17 01:38:04 +00:00
|
|
|
}
|
1999-04-14 02:37:44 +00:00
|
|
|
|
|
|
|
printf("loading %s (%s)\n", filename, origintext);
|
1999-04-17 01:38:04 +00:00
|
|
|
result = dns_db_load(dbi->db, filename);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
dns_db_detach(&dbi->db);
|
|
|
|
isc_mem_put(mctx, dbi, sizeof *dbi);
|
1999-04-14 02:37:44 +00:00
|
|
|
return (result);
|
1999-04-17 01:38:04 +00:00
|
|
|
}
|
1999-04-14 02:37:44 +00:00
|
|
|
printf("loaded\n");
|
|
|
|
|
|
|
|
if (cache) {
|
1999-04-17 01:38:04 +00:00
|
|
|
INSIST(cache_dbi == NULL);
|
|
|
|
dns_dbtable_adddefault(dbtable, dbi->db);
|
|
|
|
cache_dbi = dbi;
|
1999-04-14 02:37:44 +00:00
|
|
|
} else {
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dns_dbtable_add(dbtable, dbi->db) != DNS_R_SUCCESS) {
|
|
|
|
dns_db_detach(&dbi->db);
|
|
|
|
isc_mem_put(mctx, dbi, sizeof *dbi);
|
1999-04-14 02:37:44 +00:00
|
|
|
return (result);
|
1999-04-17 01:38:04 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
ISC_LIST_APPEND(dbs, dbi, link);
|
1999-04-14 02:37:44 +00:00
|
|
|
|
|
|
|
return (DNS_R_SUCCESS);
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
unload_all(void) {
|
1999-04-17 01:38:04 +00:00
|
|
|
dbinfo *dbi, *dbi_next;
|
1999-04-14 02:37:44 +00:00
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
for (dbi = ISC_LIST_HEAD(dbs); dbi != NULL; dbi = dbi_next) {
|
|
|
|
dbi_next = ISC_LIST_NEXT(dbi, link);
|
|
|
|
if (dns_db_iszone(dbi->db))
|
|
|
|
dns_dbtable_remove(dbtable, dbi->db);
|
|
|
|
else {
|
|
|
|
INSIST(dbi == cache_dbi);
|
|
|
|
dns_dbtable_removedefault(dbtable);
|
|
|
|
cache_dbi = NULL;
|
|
|
|
}
|
|
|
|
dns_db_detach(&dbi->db);
|
|
|
|
ISC_LIST_UNLINK(dbs, dbi, link);
|
|
|
|
isc_mem_put(mctx, dbi, sizeof *dbi);
|
1999-04-14 02:37:44 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
#define DBI_CHECK(dbi) \
|
|
|
|
if ((dbi) == NULL) { \
|
|
|
|
printf("You must first select a database with !DB\n"); \
|
|
|
|
continue; \
|
|
|
|
}
|
|
|
|
|
1999-01-28 23:53:36 +00:00
|
|
|
int
|
|
|
|
main(int argc, char *argv[]) {
|
|
|
|
dns_db_t *db;
|
|
|
|
dns_dbnode_t *node;
|
|
|
|
dns_result_t result;
|
1999-04-14 02:37:44 +00:00
|
|
|
dns_name_t name;
|
1999-01-28 23:53:36 +00:00
|
|
|
dns_offsets_t offsets;
|
|
|
|
size_t len;
|
1999-03-11 06:02:50 +00:00
|
|
|
isc_buffer_t source, target;
|
1999-01-28 23:53:36 +00:00
|
|
|
char s[1000];
|
1999-01-29 07:05:09 +00:00
|
|
|
char b[255];
|
1999-01-29 22:21:35 +00:00
|
|
|
dns_rdataset_t rdataset;
|
1999-01-29 23:36:41 +00:00
|
|
|
int ch;
|
1999-04-01 04:14:25 +00:00
|
|
|
dns_rdatatype_t type = 1;
|
1999-03-05 23:26:47 +00:00
|
|
|
isc_boolean_t printnode = ISC_FALSE;
|
|
|
|
isc_boolean_t addmode = ISC_FALSE;
|
1999-03-06 00:51:12 +00:00
|
|
|
isc_boolean_t delmode = ISC_FALSE;
|
1999-04-09 19:18:52 +00:00
|
|
|
isc_boolean_t holdmode = ISC_FALSE;
|
1999-03-05 23:26:47 +00:00
|
|
|
isc_boolean_t verbose = ISC_FALSE;
|
1999-04-01 04:14:25 +00:00
|
|
|
isc_boolean_t done = ISC_FALSE;
|
1999-04-09 01:15:12 +00:00
|
|
|
isc_boolean_t quiet = ISC_FALSE;
|
|
|
|
isc_boolean_t time_lookups = ISC_FALSE;
|
1999-04-01 04:14:25 +00:00
|
|
|
isc_boolean_t found_as;
|
1999-04-17 01:38:04 +00:00
|
|
|
int i, v;
|
1999-03-11 06:02:50 +00:00
|
|
|
dns_rdatasetiter_t *rdsiter;
|
1999-04-01 04:14:25 +00:00
|
|
|
char t1[256];
|
|
|
|
char t2[256];
|
|
|
|
isc_buffer_t tb1, tb2;
|
|
|
|
isc_region_t r1, r2;
|
|
|
|
dns_fixedname_t foundname;
|
|
|
|
dns_name_t *fname;
|
|
|
|
unsigned int options = 0;
|
1999-04-09 01:15:12 +00:00
|
|
|
struct timeval start, finish;
|
1999-04-14 02:37:44 +00:00
|
|
|
char *origintext;
|
1999-04-17 01:38:04 +00:00
|
|
|
dbinfo *dbi;
|
|
|
|
dns_dbversion_t *version;
|
|
|
|
dns_name_t *origin;
|
1999-04-27 23:20:27 +00:00
|
|
|
size_t memory_quota = 0;
|
1999-04-14 02:37:44 +00:00
|
|
|
|
|
|
|
RUNTIME_CHECK(isc_mem_create(0, 0, &mctx) == ISC_R_SUCCESS);
|
1999-04-20 22:27:27 +00:00
|
|
|
RUNTIME_CHECK(dns_dbtable_create(mctx, dns_rdataclass_in, &dbtable) ==
|
|
|
|
DNS_R_SUCCESS);
|
1999-01-29 23:36:41 +00:00
|
|
|
|
1999-02-11 04:56:56 +00:00
|
|
|
strcpy(dbtype, "rbt");
|
1999-04-27 23:20:27 +00:00
|
|
|
while ((ch = getopt(argc, argv, "c:d:t:z:P:Q:gpqvT")) != -1) {
|
1999-01-29 23:36:41 +00:00
|
|
|
switch (ch) {
|
1999-04-01 04:14:25 +00:00
|
|
|
case 'c':
|
1999-04-14 02:37:44 +00:00
|
|
|
result = load(optarg, ".", ISC_TRUE);
|
|
|
|
if (result != DNS_R_SUCCESS)
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
1999-01-29 23:36:41 +00:00
|
|
|
break;
|
1999-02-11 04:56:56 +00:00
|
|
|
case 'd':
|
|
|
|
strcpy(dbtype, optarg);
|
|
|
|
break;
|
1999-04-01 04:14:25 +00:00
|
|
|
case 'g':
|
1999-04-09 01:15:12 +00:00
|
|
|
options |= (DNS_DBFIND_GLUEOK|DNS_DBFIND_VALIDATEGLUE);
|
|
|
|
break;
|
|
|
|
case 'q':
|
|
|
|
quiet = ISC_TRUE;
|
|
|
|
verbose = ISC_FALSE;
|
1999-01-29 23:36:41 +00:00
|
|
|
break;
|
1999-03-05 23:26:47 +00:00
|
|
|
case 'p':
|
|
|
|
printnode = ISC_TRUE;
|
|
|
|
break;
|
1999-04-17 01:38:04 +00:00
|
|
|
case 'P':
|
|
|
|
pause_every = atoi(optarg);
|
|
|
|
break;
|
1999-04-27 23:20:27 +00:00
|
|
|
case 'Q':
|
|
|
|
memory_quota = atoi(optarg);
|
|
|
|
isc_mem_setquota(mctx, memory_quota);
|
|
|
|
break;
|
1999-04-01 04:14:25 +00:00
|
|
|
case 't':
|
|
|
|
type = atoi(optarg);
|
|
|
|
break;
|
1999-04-09 01:15:12 +00:00
|
|
|
case 'T':
|
|
|
|
time_lookups = ISC_TRUE;
|
|
|
|
break;
|
1999-03-05 23:26:47 +00:00
|
|
|
case 'v':
|
|
|
|
verbose = ISC_TRUE;
|
|
|
|
break;
|
1999-04-01 04:14:25 +00:00
|
|
|
case 'z':
|
1999-04-14 02:37:44 +00:00
|
|
|
origintext = strrchr(optarg, '/');
|
|
|
|
if (origintext == NULL)
|
|
|
|
origintext = optarg;
|
|
|
|
else
|
|
|
|
origintext++; /* Skip '/'. */
|
|
|
|
result = load(optarg, origintext, ISC_FALSE);
|
|
|
|
if (result != DNS_R_SUCCESS)
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
1999-04-01 04:14:25 +00:00
|
|
|
break;
|
1999-01-29 23:36:41 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
argc -= optind;
|
|
|
|
argv += optind;
|
1999-01-29 07:05:09 +00:00
|
|
|
|
1999-04-14 02:37:44 +00:00
|
|
|
if (argc != 0)
|
|
|
|
printf("ignoring trailing arguments\n");
|
1999-04-01 04:14:25 +00:00
|
|
|
|
1999-04-14 02:37:44 +00:00
|
|
|
/*
|
|
|
|
* Some final initialization...
|
|
|
|
*/
|
1999-04-01 04:14:25 +00:00
|
|
|
dns_fixedname_init(&foundname);
|
|
|
|
fname = dns_fixedname_name(&foundname);
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi = NULL;
|
|
|
|
origin = dns_rootname;
|
|
|
|
version = NULL;
|
1999-01-29 07:05:09 +00:00
|
|
|
|
1999-04-09 01:15:12 +00:00
|
|
|
if (time_lookups) {
|
|
|
|
/* Naughty */
|
|
|
|
(void)gettimeofday(&start, NULL);
|
|
|
|
}
|
|
|
|
|
1999-04-01 04:14:25 +00:00
|
|
|
while (!done) {
|
1999-04-09 01:15:12 +00:00
|
|
|
if (!quiet)
|
|
|
|
printf("\n");
|
1999-04-17 01:38:04 +00:00
|
|
|
if (fgets(s, sizeof s, stdin) == NULL) {
|
1999-04-01 04:14:25 +00:00
|
|
|
done = ISC_TRUE;
|
|
|
|
continue;
|
|
|
|
}
|
1999-04-17 01:38:04 +00:00
|
|
|
len = strlen(s);
|
|
|
|
if (len > 0 && s[len - 1] == '\n') {
|
|
|
|
s[len - 1] = '\0';
|
|
|
|
len--;
|
|
|
|
}
|
|
|
|
if (verbose && dbi != NULL) {
|
|
|
|
if (dbi->wversion != NULL)
|
|
|
|
printf("future version (%p)\n", dbi->wversion);
|
|
|
|
for (i = 0; i < dbi->rcount; i++)
|
|
|
|
if (dbi->rversions[i] != NULL)
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("open version %d (%p)\n", i,
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->rversions[i]);
|
1999-03-05 23:26:47 +00:00
|
|
|
}
|
1999-01-29 07:05:09 +00:00
|
|
|
dns_name_init(&name, offsets);
|
1999-03-05 23:26:47 +00:00
|
|
|
if (strcmp(s, "!R") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
|
|
|
if (dbi->rcount == MAXVERSIONS) {
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("too many open versions\n");
|
|
|
|
continue;
|
|
|
|
}
|
1999-04-17 01:38:04 +00:00
|
|
|
dns_db_currentversion(dbi->db,
|
|
|
|
&dbi->rversions[dbi->rcount]);
|
|
|
|
printf("opened version %d\n", dbi->rcount);
|
|
|
|
dbi->version = dbi->rversions[dbi->rcount];
|
|
|
|
version = dbi->version;
|
|
|
|
dbi->rcount++;
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!W") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
|
|
|
if (dbi->wversion != NULL) {
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("using existing future version\n");
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->version = dbi->wversion;
|
|
|
|
version = dbi->version;
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
|
|
|
}
|
1999-04-17 01:38:04 +00:00
|
|
|
result = dns_db_newversion(dbi->db, &dbi->wversion);
|
1999-03-05 23:26:47 +00:00
|
|
|
if (result != DNS_R_SUCCESS)
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
|
|
|
else
|
|
|
|
printf("newversion\n");
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->version = dbi->wversion;
|
|
|
|
version = dbi->version;
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!C") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-03-05 23:26:47 +00:00
|
|
|
addmode = ISC_FALSE;
|
1999-03-06 00:51:12 +00:00
|
|
|
delmode = ISC_FALSE;
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi->version == NULL)
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi->version == dbi->wversion) {
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("closing future version\n");
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->wversion = NULL;
|
1999-03-05 23:26:47 +00:00
|
|
|
} else {
|
1999-04-17 01:38:04 +00:00
|
|
|
for (i = 0; i < dbi->rcount; i++) {
|
|
|
|
if (dbi->version ==
|
|
|
|
dbi->rversions[i]) {
|
|
|
|
dbi->rversions[i] = NULL;
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("closing open version %d\n",
|
|
|
|
i);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
1999-04-17 01:38:04 +00:00
|
|
|
dns_db_closeversion(dbi->db, &dbi->version, ISC_TRUE);
|
|
|
|
version = NULL;
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!X") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-03-05 23:26:47 +00:00
|
|
|
addmode = ISC_FALSE;
|
1999-03-06 00:51:12 +00:00
|
|
|
delmode = ISC_FALSE;
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi->version == NULL)
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi->version == dbi->wversion) {
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("aborting future version\n");
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->wversion = NULL;
|
1999-03-05 23:26:47 +00:00
|
|
|
} else {
|
1999-04-17 01:38:04 +00:00
|
|
|
for (i = 0; i < dbi->rcount; i++) {
|
|
|
|
if (dbi->version ==
|
|
|
|
dbi->rversions[i]) {
|
|
|
|
dbi->rversions[i] = NULL;
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("closing open version %d\n",
|
|
|
|
i);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
1999-04-17 01:38:04 +00:00
|
|
|
dns_db_closeversion(dbi->db, &dbi->version, ISC_FALSE);
|
|
|
|
version = NULL;
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!A") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-03-06 00:51:12 +00:00
|
|
|
delmode = ISC_FALSE;
|
1999-03-05 23:26:47 +00:00
|
|
|
if (addmode)
|
|
|
|
addmode = ISC_FALSE;
|
|
|
|
else
|
|
|
|
addmode = ISC_TRUE;
|
|
|
|
printf("addmode = %s\n", addmode ? "TRUE" : "FALSE");
|
|
|
|
continue;
|
1999-03-06 00:51:12 +00:00
|
|
|
} else if (strcmp(s, "!D") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-03-06 00:51:12 +00:00
|
|
|
addmode = ISC_FALSE;
|
|
|
|
if (delmode)
|
|
|
|
delmode = ISC_FALSE;
|
|
|
|
else
|
|
|
|
delmode = ISC_TRUE;
|
|
|
|
printf("delmode = %s\n", delmode ? "TRUE" : "FALSE");
|
|
|
|
continue;
|
1999-04-09 19:18:52 +00:00
|
|
|
} else if (strcmp(s, "!H") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-04-09 19:18:52 +00:00
|
|
|
if (holdmode)
|
|
|
|
holdmode = ISC_FALSE;
|
|
|
|
else
|
|
|
|
holdmode = ISC_TRUE;
|
|
|
|
printf("holdmode = %s\n", holdmode ? "TRUE" : "FALSE");
|
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!HR") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
|
|
|
for (i = 0; i < dbi->hold_count; i++)
|
|
|
|
dns_db_detachnode(dbi->db,
|
|
|
|
&dbi->hold_nodes[i]);
|
|
|
|
dbi->hold_count = 0;
|
1999-04-09 19:18:52 +00:00
|
|
|
holdmode = ISC_FALSE;
|
|
|
|
printf("held nodes have been detached\n");
|
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!VC") == 0) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-04-09 19:18:52 +00:00
|
|
|
printf("switching to current version\n");
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->version = NULL;
|
1999-04-09 19:18:52 +00:00
|
|
|
version = NULL;
|
|
|
|
continue;
|
1999-03-05 23:26:47 +00:00
|
|
|
} else if (strstr(s, "!V") == s) {
|
1999-04-17 01:38:04 +00:00
|
|
|
DBI_CHECK(dbi);
|
1999-03-05 23:26:47 +00:00
|
|
|
v = atoi(&s[2]);
|
1999-04-17 01:38:04 +00:00
|
|
|
if (v >= dbi->rcount) {
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("unknown open version %d\n", v);
|
|
|
|
continue;
|
1999-04-17 01:38:04 +00:00
|
|
|
} else if (dbi->rversions[v] == NULL) {
|
1999-03-05 23:26:47 +00:00
|
|
|
printf("version %d is not open\n", v);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
printf("switching to open version %d\n", v);
|
1999-04-17 01:38:04 +00:00
|
|
|
dbi->version = dbi->rversions[v];
|
|
|
|
version = dbi->version;
|
1999-03-05 23:26:47 +00:00
|
|
|
continue;
|
1999-04-01 04:14:25 +00:00
|
|
|
} else if (strstr(s, "!T") == s) {
|
|
|
|
type = (unsigned int)atoi(&s[2]);
|
|
|
|
printf("now searching for type %u\n", type);
|
|
|
|
continue;
|
|
|
|
} else if (strcmp(s, "!G") == 0) {
|
|
|
|
if ((options & DNS_DBFIND_GLUEOK) != 0)
|
|
|
|
options &= ~DNS_DBFIND_GLUEOK;
|
|
|
|
else
|
|
|
|
options |= DNS_DBFIND_GLUEOK;
|
|
|
|
printf("glue ok = %s\n",
|
|
|
|
((options & DNS_DBFIND_GLUEOK) != 0) ?
|
|
|
|
"TRUE" : "FALSE");
|
|
|
|
continue;
|
1999-04-09 01:15:12 +00:00
|
|
|
} else if (strcmp(s, "!GV") == 0) {
|
|
|
|
if ((options & DNS_DBFIND_VALIDATEGLUE) != 0)
|
|
|
|
options &= ~DNS_DBFIND_VALIDATEGLUE;
|
|
|
|
else
|
|
|
|
options |= DNS_DBFIND_VALIDATEGLUE;
|
|
|
|
printf("validate glue = %s\n",
|
|
|
|
((options & DNS_DBFIND_VALIDATEGLUE) != 0) ?
|
|
|
|
"TRUE" : "FALSE");
|
|
|
|
continue;
|
1999-04-17 01:38:04 +00:00
|
|
|
} else if (strcmp(s, "!LS") == 0) {
|
|
|
|
DBI_CHECK(dbi);
|
|
|
|
dump(dbi);
|
|
|
|
continue;
|
1999-04-19 22:53:33 +00:00
|
|
|
} else if (strstr(s, "!P") == s) {
|
|
|
|
DBI_CHECK(dbi);
|
|
|
|
v = atoi(&s[2]);
|
|
|
|
dbi->pause_every = v;
|
|
|
|
continue;
|
1999-04-17 01:38:04 +00:00
|
|
|
} else if (strcmp(s, "!DB") == 0) {
|
|
|
|
dbi = NULL;
|
|
|
|
origin = dns_rootname;
|
|
|
|
version = NULL;
|
|
|
|
printf("now searching all databases\n");
|
|
|
|
continue;
|
|
|
|
} else if (strncmp(s, "!DB ", 4) == 0) {
|
|
|
|
dbi = select_db(s+4);
|
|
|
|
if (dbi != NULL) {
|
|
|
|
db = dbi->db;
|
|
|
|
origin = dns_db_origin(dbi->db);
|
|
|
|
version = dbi->version;
|
|
|
|
addmode = ISC_FALSE;
|
|
|
|
delmode = ISC_FALSE;
|
|
|
|
holdmode = ISC_FALSE;
|
|
|
|
} else {
|
|
|
|
db = NULL;
|
|
|
|
version = NULL;
|
|
|
|
origin = dns_rootname;
|
|
|
|
printf("database not found; "
|
|
|
|
"now searching all databases\n");
|
|
|
|
}
|
|
|
|
continue;
|
1999-03-05 23:26:47 +00:00
|
|
|
}
|
1999-04-17 01:38:04 +00:00
|
|
|
|
1999-01-29 07:05:09 +00:00
|
|
|
isc_buffer_init(&source, s, len, ISC_BUFFERTYPE_TEXT);
|
|
|
|
isc_buffer_add(&source, len);
|
|
|
|
isc_buffer_init(&target, b, sizeof b, ISC_BUFFERTYPE_BINARY);
|
1999-04-17 01:38:04 +00:00
|
|
|
result = dns_name_fromtext(&name, &source, origin,
|
1999-04-14 02:37:44 +00:00
|
|
|
ISC_FALSE, &target);
|
1999-01-29 07:05:09 +00:00
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
printf("bad name: %s\n", dns_result_totext(result));
|
|
|
|
continue;
|
|
|
|
}
|
1999-04-01 04:14:25 +00:00
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi == NULL) {
|
|
|
|
db = NULL;
|
|
|
|
result = dns_dbtable_find(dbtable, &name, &db);
|
|
|
|
if (result != DNS_R_SUCCESS &&
|
|
|
|
result != DNS_R_PARTIALMATCH) {
|
|
|
|
if (!quiet)
|
|
|
|
printf("\n%s\n",
|
|
|
|
dns_result_totext(result));
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
isc_buffer_init(&tb1, t1, sizeof t1,
|
|
|
|
ISC_BUFFERTYPE_TEXT);
|
|
|
|
result = dns_name_totext(dns_db_origin(db), ISC_FALSE,
|
|
|
|
&tb1);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
1999-04-14 02:37:44 +00:00
|
|
|
printf("\n%s\n", dns_result_totext(result));
|
1999-04-17 01:38:04 +00:00
|
|
|
dns_db_detach(&db);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
isc_buffer_used(&tb1, &r1);
|
|
|
|
printf("\ndatabase = %.*s (%s)\n",
|
|
|
|
(int)r1.length, r1.base,
|
|
|
|
(dns_db_iszone(db)) ? "zone" : "cache");
|
1999-04-14 02:37:44 +00:00
|
|
|
}
|
1999-04-05 20:56:03 +00:00
|
|
|
node = NULL;
|
1999-04-01 04:14:25 +00:00
|
|
|
dns_rdataset_init(&rdataset);
|
1999-04-09 01:15:12 +00:00
|
|
|
result = dns_db_find(db, &name, version, type, options, 0,
|
1999-04-01 04:14:25 +00:00
|
|
|
&node, fname, &rdataset);
|
1999-04-17 01:38:04 +00:00
|
|
|
if (!quiet) {
|
|
|
|
if (dbi != NULL)
|
|
|
|
printf("\n");
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
|
|
|
}
|
1999-04-01 04:14:25 +00:00
|
|
|
|
|
|
|
found_as = ISC_FALSE;
|
|
|
|
switch (result) {
|
|
|
|
case DNS_R_SUCCESS:
|
|
|
|
case DNS_R_GLUE:
|
|
|
|
case DNS_R_CNAME:
|
1999-04-05 20:56:03 +00:00
|
|
|
case DNS_R_ZONECUT:
|
1999-04-01 04:14:25 +00:00
|
|
|
break;
|
|
|
|
case DNS_R_DNAME:
|
|
|
|
case DNS_R_DELEGATION:
|
|
|
|
found_as = ISC_TRUE;
|
|
|
|
break;
|
|
|
|
case DNS_R_NXRDATASET:
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi != NULL) {
|
|
|
|
if (holdmode) {
|
|
|
|
RUNTIME_CHECK(dbi->hold_count <
|
|
|
|
MAXHOLD);
|
|
|
|
dbi->hold_nodes[dbi->hold_count++] =
|
|
|
|
node;
|
|
|
|
node = NULL;
|
|
|
|
} else
|
|
|
|
dns_db_detachnode(db, &node);
|
1999-04-14 02:37:44 +00:00
|
|
|
} else {
|
1999-04-09 19:18:52 +00:00
|
|
|
dns_db_detachnode(db, &node);
|
1999-04-14 02:37:44 +00:00
|
|
|
dns_db_detach(&db);
|
|
|
|
}
|
1999-04-01 04:14:25 +00:00
|
|
|
continue;
|
|
|
|
default:
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi == NULL)
|
|
|
|
dns_db_detach(&db);
|
1999-04-09 01:15:12 +00:00
|
|
|
if (quiet)
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
1999-04-01 04:14:25 +00:00
|
|
|
continue;
|
|
|
|
}
|
1999-04-09 01:15:12 +00:00
|
|
|
if (found_as && !quiet) {
|
1999-04-01 04:14:25 +00:00
|
|
|
isc_buffer_init(&tb1, t1, sizeof t1,
|
|
|
|
ISC_BUFFERTYPE_TEXT);
|
|
|
|
isc_buffer_init(&tb2, t2, sizeof t2,
|
|
|
|
ISC_BUFFERTYPE_TEXT);
|
|
|
|
result = dns_name_totext(&name, ISC_FALSE, &tb1);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
1999-04-14 02:37:44 +00:00
|
|
|
dns_db_detachnode(db, &node);
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi == NULL)
|
|
|
|
dns_db_detach(&db);
|
1999-04-01 04:14:25 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
result = dns_name_totext(fname, ISC_FALSE, &tb2);
|
|
|
|
if (result != DNS_R_SUCCESS) {
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
1999-04-14 02:37:44 +00:00
|
|
|
dns_db_detachnode(db, &node);
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi == NULL)
|
|
|
|
dns_db_detach(&db);
|
1999-04-01 04:14:25 +00:00
|
|
|
continue;
|
|
|
|
}
|
|
|
|
isc_buffer_used(&tb1, &r1);
|
|
|
|
isc_buffer_used(&tb2, &r2);
|
|
|
|
printf("found %.*s as %.*s\n",
|
|
|
|
(int)r1.length, r1.base,
|
|
|
|
(int)r2.length, r2.base);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (printnode)
|
|
|
|
dns_db_printnode(db, node, stdout);
|
|
|
|
|
|
|
|
if (!found_as && type == dns_rdatatype_any) {
|
|
|
|
rdsiter = NULL;
|
1999-04-09 01:15:12 +00:00
|
|
|
result = dns_db_allrdatasets(db, node, version, 0,
|
1999-04-01 04:14:25 +00:00
|
|
|
&rdsiter);
|
|
|
|
if (result == DNS_R_SUCCESS) {
|
1999-04-09 01:15:12 +00:00
|
|
|
if (!quiet)
|
|
|
|
print_rdatasets(fname, rdsiter);
|
1999-04-01 04:14:25 +00:00
|
|
|
dns_rdatasetiter_destroy(&rdsiter);
|
|
|
|
} else
|
|
|
|
printf("%s\n", dns_result_totext(result));
|
|
|
|
} else {
|
1999-04-09 01:15:12 +00:00
|
|
|
if (!quiet)
|
|
|
|
print_rdataset(fname, &rdataset);
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi != NULL && addmode && !found_as) {
|
1999-04-01 04:14:25 +00:00
|
|
|
rdataset.ttl++;
|
|
|
|
result = dns_db_addrdataset(db, node, version,
|
1999-05-05 22:57:20 +00:00
|
|
|
0, &rdataset,
|
|
|
|
NULL);
|
1999-04-01 04:14:25 +00:00
|
|
|
if (result != DNS_R_SUCCESS)
|
1999-01-29 22:21:35 +00:00
|
|
|
printf("%s\n",
|
|
|
|
dns_result_totext(result));
|
1999-04-09 01:15:12 +00:00
|
|
|
if (printnode)
|
|
|
|
dns_db_printnode(db, node, stdout);
|
1999-04-17 01:38:04 +00:00
|
|
|
} else if (dbi != NULL && delmode && !found_as) {
|
1999-04-01 04:14:25 +00:00
|
|
|
result = dns_db_deleterdataset(db, node,
|
|
|
|
version, type);
|
|
|
|
if (result != DNS_R_SUCCESS)
|
1999-03-11 06:02:50 +00:00
|
|
|
printf("%s\n",
|
|
|
|
dns_result_totext(result));
|
1999-04-09 01:15:12 +00:00
|
|
|
if (printnode)
|
|
|
|
dns_db_printnode(db, node, stdout);
|
1999-01-29 22:21:35 +00:00
|
|
|
}
|
1999-04-01 04:14:25 +00:00
|
|
|
dns_rdataset_disassociate(&rdataset);
|
1999-01-29 07:05:09 +00:00
|
|
|
}
|
1999-04-01 04:14:25 +00:00
|
|
|
|
1999-04-17 01:38:04 +00:00
|
|
|
if (dbi != NULL) {
|
|
|
|
if (holdmode) {
|
|
|
|
RUNTIME_CHECK(dbi->hold_count < MAXHOLD);
|
|
|
|
dbi->hold_nodes[dbi->hold_count++] = node;
|
|
|
|
node = NULL;
|
|
|
|
} else
|
|
|
|
dns_db_detachnode(db, &node);
|
1999-04-14 02:37:44 +00:00
|
|
|
} else {
|
1999-04-09 19:18:52 +00:00
|
|
|
dns_db_detachnode(db, &node);
|
1999-04-14 02:37:44 +00:00
|
|
|
dns_db_detach(&db);
|
|
|
|
}
|
1999-01-28 23:53:36 +00:00
|
|
|
}
|
|
|
|
|
1999-04-09 01:15:12 +00:00
|
|
|
if (time_lookups) {
|
|
|
|
struct timeval interval;
|
|
|
|
|
|
|
|
/* Naughty */
|
|
|
|
(void)gettimeofday(&finish, NULL);
|
|
|
|
if (start.tv_usec > finish.tv_usec) {
|
|
|
|
finish.tv_sec--;
|
|
|
|
interval.tv_usec = 1000000 -
|
|
|
|
start.tv_usec + finish.tv_usec;
|
|
|
|
} else
|
|
|
|
interval.tv_usec = finish.tv_usec - start.tv_usec;
|
|
|
|
interval.tv_sec = finish.tv_sec - start.tv_sec;
|
|
|
|
printf("elapsed time: %lu.%06lu seconds\n",
|
|
|
|
(unsigned long)interval.tv_sec,
|
|
|
|
(unsigned long)interval.tv_usec);
|
|
|
|
}
|
|
|
|
|
1999-04-14 02:37:44 +00:00
|
|
|
unload_all();
|
|
|
|
|
|
|
|
dns_dbtable_destroy(&dbtable);
|
1999-01-28 23:53:36 +00:00
|
|
|
|
1999-04-09 01:15:12 +00:00
|
|
|
if (!quiet)
|
|
|
|
isc_mem_stats(mctx, stdout);
|
1999-01-28 23:53:36 +00:00
|
|
|
|
|
|
|
return (0);
|
|
|
|
}
|