Fix an issue where the _res symbol is undeclared due to another symbol with
the same name somewhere else( I think). At least it works now. Renamed to _resolve_configuration (probably will never clash with anything else ever) git-svn-id: file:///srv/svn/repos/haiku/trunk/current@3565 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
3ffe393cd6
commit
26e367740a
@ -527,10 +527,10 @@ explore_fqdn(pai, hostname, servname, res)
|
|||||||
if (get_portmatch(pai, servname) != 0)
|
if (get_portmatch(pai, servname) != 0)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
strncpy(lookups, "f", sizeof lookups);
|
strncpy(lookups, "f", sizeof lookups);
|
||||||
else {
|
else {
|
||||||
memcpy(lookups, _res.lookups, sizeof lookups);
|
memcpy(lookups, _resolver_configuration.lookups, sizeof lookups);
|
||||||
if (lookups[0] == '\0')
|
if (lookups[0] == '\0')
|
||||||
strncpy(lookups, "bf", sizeof lookups);
|
strncpy(lookups, "bf", sizeof lookups);
|
||||||
}
|
}
|
||||||
@ -1542,7 +1542,7 @@ res_queryN(name, target)
|
|||||||
rcode = NOERROR;
|
rcode = NOERROR;
|
||||||
ancount = 0;
|
ancount = 0;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
@ -1561,17 +1561,17 @@ res_queryN(name, target)
|
|||||||
answer = t->answer;
|
answer = t->answer;
|
||||||
anslen = t->anslen;
|
anslen = t->anslen;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_query(%s, %d, %d)\n", name, class, type);
|
printf(";; res_query(%s, %d, %d)\n", name, class, type);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
n = res_mkquery(QUERY, name, class, type, NULL, 0, NULL,
|
n = res_mkquery(QUERY, name, class, type, NULL, 0, NULL,
|
||||||
buf, sizeof(buf));
|
buf, sizeof(buf));
|
||||||
if (n > 0 && (_res.options & RES_USE_EDNS0) != 0)
|
if (n > 0 && (_resolver_configuration.options & RES_USE_EDNS0) != 0)
|
||||||
n = res_opt(n, buf, sizeof(buf), anslen);
|
n = res_opt(n, buf, sizeof(buf), anslen);
|
||||||
if (n <= 0) {
|
if (n <= 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_query: mkquery failed\n");
|
printf(";; res_query: mkquery failed\n");
|
||||||
#endif
|
#endif
|
||||||
h_errno = NO_RECOVERY;
|
h_errno = NO_RECOVERY;
|
||||||
@ -1581,7 +1581,7 @@ res_queryN(name, target)
|
|||||||
#if 0
|
#if 0
|
||||||
if (n < 0) {
|
if (n < 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_query: send error\n");
|
printf(";; res_query: send error\n");
|
||||||
#endif
|
#endif
|
||||||
h_errno = TRY_AGAIN;
|
h_errno = TRY_AGAIN;
|
||||||
@ -1592,7 +1592,7 @@ res_queryN(name, target)
|
|||||||
if (n < 0 || hp->rcode != NOERROR || ntohs(hp->ancount) == 0) {
|
if (n < 0 || hp->rcode != NOERROR || ntohs(hp->ancount) == 0) {
|
||||||
rcode = hp->rcode; /* record most recent error */
|
rcode = hp->rcode; /* record most recent error */
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; rcode = %d, ancount=%d\n", hp->rcode,
|
printf(";; rcode = %d, ancount=%d\n", hp->rcode,
|
||||||
ntohs(hp->ancount));
|
ntohs(hp->ancount));
|
||||||
#endif
|
#endif
|
||||||
@ -1644,7 +1644,7 @@ res_searchN(name, target)
|
|||||||
int trailing_dot, ret, saved_herrno;
|
int trailing_dot, ret, saved_herrno;
|
||||||
int got_nodata = 0, got_servfail = 0, tried_as_is = 0;
|
int got_nodata = 0, got_servfail = 0, tried_as_is = 0;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
@ -1669,7 +1669,7 @@ res_searchN(name, target)
|
|||||||
* 'as is'. The threshold can be set with the "ndots" option.
|
* 'as is'. The threshold can be set with the "ndots" option.
|
||||||
*/
|
*/
|
||||||
saved_herrno = -1;
|
saved_herrno = -1;
|
||||||
if (dots >= _res.ndots) {
|
if (dots >= _resolver_configuration.ndots) {
|
||||||
ret = res_querydomainN(name, NULL, target);
|
ret = res_querydomainN(name, NULL, target);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
return (ret);
|
return (ret);
|
||||||
@ -1683,11 +1683,11 @@ res_searchN(name, target)
|
|||||||
* - there is at least one dot, there is no trailing dot,
|
* - there is at least one dot, there is no trailing dot,
|
||||||
* and RES_DNSRCH is set.
|
* and RES_DNSRCH is set.
|
||||||
*/
|
*/
|
||||||
if ((!dots && (_res.options & RES_DEFNAMES)) ||
|
if ((!dots && (_resolver_configuration.options & RES_DEFNAMES)) ||
|
||||||
(dots && !trailing_dot && (_res.options & RES_DNSRCH))) {
|
(dots && !trailing_dot && (_resolver_configuration.options & RES_DNSRCH))) {
|
||||||
int done = 0;
|
int done = 0;
|
||||||
|
|
||||||
for (domain = (const char * const *)_res.dnsrch;
|
for (domain = (const char * const *)_resolver_configuration.dnsrch;
|
||||||
*domain && !done;
|
*domain && !done;
|
||||||
domain++) {
|
domain++) {
|
||||||
|
|
||||||
@ -1735,7 +1735,7 @@ res_searchN(name, target)
|
|||||||
* if we got here for some reason other than DNSRCH,
|
* if we got here for some reason other than DNSRCH,
|
||||||
* we only wanted one iteration of the loop, so stop.
|
* we only wanted one iteration of the loop, so stop.
|
||||||
*/
|
*/
|
||||||
if (!(_res.options & RES_DNSRCH))
|
if (!(_resolver_configuration.options & RES_DNSRCH))
|
||||||
done++;
|
done++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -1781,12 +1781,12 @@ res_querydomainN(name, domain, target)
|
|||||||
const char *longname = nbuf;
|
const char *longname = nbuf;
|
||||||
size_t n, d;
|
size_t n, d;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_querydomain(%s, %s)\n",
|
printf(";; res_querydomain(%s, %s)\n",
|
||||||
name, domain?domain:"<Nil>");
|
name, domain?domain:"<Nil>");
|
||||||
#endif
|
#endif
|
||||||
|
@ -350,7 +350,7 @@ static struct hostent *getanswer(const querybuf *answer,
|
|||||||
break;
|
break;
|
||||||
#else
|
#else
|
||||||
host.h_name = bp;
|
host.h_name = bp;
|
||||||
if (_res.options & RES_USE_INET6) {
|
if (_resolver_configuration.options & RES_USE_INET6) {
|
||||||
n = strlen(bp) + 1; /* for the \0 */
|
n = strlen(bp) + 1; /* for the \0 */
|
||||||
bp += n;
|
bp += n;
|
||||||
buflen -= n;
|
buflen -= n;
|
||||||
@ -386,7 +386,7 @@ static struct hostent *getanswer(const querybuf *answer,
|
|||||||
|
|
||||||
if (bp + n >= &hostbuf[sizeof hostbuf]) {
|
if (bp + n >= &hostbuf[sizeof hostbuf]) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf("size (%d) too big\n", n);
|
printf("size (%d) too big\n", n);
|
||||||
#endif
|
#endif
|
||||||
had_error++;
|
had_error++;
|
||||||
@ -395,7 +395,7 @@ static struct hostent *getanswer(const querybuf *answer,
|
|||||||
if (hap >= &h_addr_ptrs[MAXADDRS-1]) {
|
if (hap >= &h_addr_ptrs[MAXADDRS-1]) {
|
||||||
if (!toobig++)
|
if (!toobig++)
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf("Too many addresses (%d)\n", MAXADDRS);
|
printf("Too many addresses (%d)\n", MAXADDRS);
|
||||||
#endif
|
#endif
|
||||||
cp += n;
|
cp += n;
|
||||||
@ -419,7 +419,7 @@ static struct hostent *getanswer(const querybuf *answer,
|
|||||||
* in its return structures - should give it the "best"
|
* in its return structures - should give it the "best"
|
||||||
* address in that case, not some random one
|
* address in that case, not some random one
|
||||||
*/
|
*/
|
||||||
if (_res.nsort && haveanswer > 1 && qtype == T_A)
|
if (_resolver_configuration.nsort && haveanswer > 1 && qtype == T_A)
|
||||||
addrsort(h_addr_ptrs, haveanswer);
|
addrsort(h_addr_ptrs, haveanswer);
|
||||||
# endif /*RESOLVSORT*/
|
# endif /*RESOLVSORT*/
|
||||||
if (!host.h_name) {
|
if (!host.h_name) {
|
||||||
@ -432,7 +432,7 @@ static struct hostent *getanswer(const querybuf *answer,
|
|||||||
buflen -= n;
|
buflen -= n;
|
||||||
}
|
}
|
||||||
#if INET6
|
#if INET6
|
||||||
if (_res.options & RES_USE_INET6)
|
if (_resolver_configuration.options & RES_USE_INET6)
|
||||||
map_v4v6_hostent(&host, &bp, &buflen);
|
map_v4v6_hostent(&host, &bp, &buflen);
|
||||||
#endif
|
#endif
|
||||||
h_errno = NETDB_SUCCESS;
|
h_errno = NETDB_SUCCESS;
|
||||||
@ -507,10 +507,10 @@ struct hostent * gethostbyname(const char *name)
|
|||||||
gethostnamadr = create_sem(1, "gethostnamadr");
|
gethostnamadr = create_sem(1, "gethostnamadr");
|
||||||
|
|
||||||
acquire_sem_etc(gethostnamadr,1, B_CAN_INTERRUPT, 0);
|
acquire_sem_etc(gethostnamadr,1, B_CAN_INTERRUPT, 0);
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
hp = _gethtbyname2(name, AF_INET);
|
hp = _gethtbyname2(name, AF_INET);
|
||||||
#if INET6
|
#if INET6
|
||||||
else if (_res.options & RES_USE_INET6) {
|
else if (_resolver_configuration.options & RES_USE_INET6) {
|
||||||
hp = gethostbyname2(name, AF_INET6);
|
hp = gethostbyname2(name, AF_INET6);
|
||||||
if (hp == NULL)
|
if (hp == NULL)
|
||||||
hp = gethostbyname2(name, AF_INET);
|
hp = gethostbyname2(name, AF_INET);
|
||||||
@ -533,7 +533,7 @@ struct hostent *gethostbyname2(const char *name, int af)
|
|||||||
register struct hostent *hp;
|
register struct hostent *hp;
|
||||||
char lookups[MAXDNSLUS];
|
char lookups[MAXDNSLUS];
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
return (_gethtbyname2(name, af));
|
return (_gethtbyname2(name, af));
|
||||||
|
|
||||||
switch (af) {
|
switch (af) {
|
||||||
@ -592,7 +592,7 @@ struct hostent *gethostbyname2(const char *name, int af)
|
|||||||
h_addr_ptrs[1] = NULL;
|
h_addr_ptrs[1] = NULL;
|
||||||
host.h_addr_list = h_addr_ptrs;
|
host.h_addr_list = h_addr_ptrs;
|
||||||
#if INET6
|
#if INET6
|
||||||
if (_res.options & RES_USE_INET6)
|
if (_resolver_configuration.options & RES_USE_INET6)
|
||||||
map_v4v6_hostent(&host, &bp, &len);
|
map_v4v6_hostent(&host, &bp, &len);
|
||||||
#endif
|
#endif
|
||||||
h_errno = NETDB_SUCCESS;
|
h_errno = NETDB_SUCCESS;
|
||||||
@ -632,7 +632,7 @@ struct hostent *gethostbyname2(const char *name, int af)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(lookups, _res.lookups, sizeof lookups);
|
memcpy(lookups, _resolver_configuration.lookups, sizeof lookups);
|
||||||
if (lookups[0] == '\0')
|
if (lookups[0] == '\0')
|
||||||
strncpy(lookups, "bf", sizeof lookups);
|
strncpy(lookups, "bf", sizeof lookups);
|
||||||
|
|
||||||
@ -650,7 +650,7 @@ struct hostent *gethostbyname2(const char *name, int af)
|
|||||||
if ((n = res_search(name, C_IN, type, buf.buf,
|
if ((n = res_search(name, C_IN, type, buf.buf,
|
||||||
sizeof(buf))) < 0) {
|
sizeof(buf))) < 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf("res_search failed\n");
|
printf("res_search failed\n");
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
@ -679,7 +679,7 @@ struct hostent *gethostbyaddr(const char *addr, int len, int af)
|
|||||||
struct hostent *res;
|
struct hostent *res;
|
||||||
|
|
||||||
acquire_sem(gethostnamadr);
|
acquire_sem(gethostnamadr);
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
//printf("gethostbyaddr: calling _gethtbyaddr\n");
|
//printf("gethostbyaddr: calling _gethtbyaddr\n");
|
||||||
res = _gethtbyaddr(addr, len, af);
|
res = _gethtbyaddr(addr, len, af);
|
||||||
release_sem_etc(gethostnamadr,1, B_CAN_INTERRUPT);
|
release_sem_etc(gethostnamadr,1, B_CAN_INTERRUPT);
|
||||||
@ -736,7 +736,7 @@ struct hostent *gethostbyaddr(const char *addr, int len, int af)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
memcpy(lookups, _res.lookups, sizeof lookups);
|
memcpy(lookups, _resolver_configuration.lookups, sizeof lookups);
|
||||||
if (lookups[0] == '\0')
|
if (lookups[0] == '\0')
|
||||||
strncpy(lookups, "bf", sizeof lookups);
|
strncpy(lookups, "bf", sizeof lookups);
|
||||||
|
|
||||||
@ -756,7 +756,7 @@ struct hostent *gethostbyaddr(const char *addr, int len, int af)
|
|||||||
sizeof buf.buf);
|
sizeof buf.buf);
|
||||||
if (n < 0) {
|
if (n < 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf("res_query failed\n");
|
printf("res_query failed\n");
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
@ -768,7 +768,7 @@ struct hostent *gethostbyaddr(const char *addr, int len, int af)
|
|||||||
memcpy(host_addr, addr, len);
|
memcpy(host_addr, addr, len);
|
||||||
h_addr_ptrs[0] = (char *)host_addr;
|
h_addr_ptrs[0] = (char *)host_addr;
|
||||||
h_addr_ptrs[1] = NULL;
|
h_addr_ptrs[1] = NULL;
|
||||||
if (af == AF_INET && (_res.options & RES_USE_INET6)) {
|
if (af == AF_INET && (_resolver_configuration.options & RES_USE_INET6)) {
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
map_v4v6_address((char*)host_addr,
|
map_v4v6_address((char*)host_addr,
|
||||||
(char*)host_addr);
|
(char*)host_addr);
|
||||||
@ -844,7 +844,7 @@ struct hostent *_gethtent()
|
|||||||
af = AF_INET6;
|
af = AF_INET6;
|
||||||
len = IN6ADDRSZ;
|
len = IN6ADDRSZ;
|
||||||
} else if (inet_pton(AF_INET, p, host_addr) > 0) {
|
} else if (inet_pton(AF_INET, p, host_addr) > 0) {
|
||||||
if (_res.options & RES_USE_INET6) {
|
if (_resolver_configuration.options & RES_USE_INET6) {
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
map_v4v6_address((char*)host_addr, (char*)host_addr);
|
map_v4v6_address((char*)host_addr, (char*)host_addr);
|
||||||
af = AF_INET6;
|
af = AF_INET6;
|
||||||
@ -884,7 +884,7 @@ struct hostent *_gethtent()
|
|||||||
*cp++ = '\0';
|
*cp++ = '\0';
|
||||||
}
|
}
|
||||||
*q = NULL;
|
*q = NULL;
|
||||||
if (_res.options & RES_USE_INET6) {
|
if (_resolver_configuration.options & RES_USE_INET6) {
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
char *bp = hostbuf;
|
char *bp = hostbuf;
|
||||||
int buflen = sizeof hostbuf;
|
int buflen = sizeof hostbuf;
|
||||||
@ -901,7 +901,7 @@ struct hostent *_gethtbyname(const char *name)
|
|||||||
extern struct hostent *_gethtbyname2();
|
extern struct hostent *_gethtbyname2();
|
||||||
struct hostent *hp;
|
struct hostent *hp;
|
||||||
|
|
||||||
if (_res.options & RES_USE_INET6) {
|
if (_resolver_configuration.options & RES_USE_INET6) {
|
||||||
hp = _gethtbyname2(name, AF_INET6);
|
hp = _gethtbyname2(name, AF_INET6);
|
||||||
if (hp)
|
if (hp)
|
||||||
return (hp);
|
return (hp);
|
||||||
@ -1149,9 +1149,9 @@ addrsort(ap, num)
|
|||||||
|
|
||||||
p = ap;
|
p = ap;
|
||||||
for (i = 0; i < num; i++, p++) {
|
for (i = 0; i < num; i++, p++) {
|
||||||
for (j = 0 ; (unsigned)j < _res.nsort; j++)
|
for (j = 0 ; (unsigned)j < _resolver_configuration.nsort; j++)
|
||||||
if (_res.sort_list[j].addr.s_addr ==
|
if (_resolver_configuration.sort_list[j].addr.s_addr ==
|
||||||
(((struct in_addr *)(*p))->s_addr & _res.sort_list[j].mask))
|
(((struct in_addr *)(*p))->s_addr & _resolver_configuration.sort_list[j].mask))
|
||||||
break;
|
break;
|
||||||
aval[i] = j;
|
aval[i] = j;
|
||||||
if (needsort == 0 && i > 0 && j < aval[i-1])
|
if (needsort == 0 && i > 0 && j < aval[i-1])
|
||||||
|
@ -246,10 +246,10 @@ getnetbyaddr(net, net_type)
|
|||||||
char lookups[MAXDNSLUS];
|
char lookups[MAXDNSLUS];
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
return(_getnetbyaddr(net, net_type));
|
return(_getnetbyaddr(net, net_type));
|
||||||
|
|
||||||
memcpy(lookups, _res.lookups, sizeof lookups);
|
memcpy(lookups, _resolver_configuration.lookups, sizeof lookups);
|
||||||
if (lookups[0] == '\0')
|
if (lookups[0] == '\0')
|
||||||
strncpy(lookups, "bf", sizeof lookups);
|
strncpy(lookups, "bf", sizeof lookups);
|
||||||
|
|
||||||
@ -313,7 +313,7 @@ getnetbyaddr(net, net_type)
|
|||||||
sizeof(buf));
|
sizeof(buf));
|
||||||
if (anslen < 0) {
|
if (anslen < 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf("res_query failed\n");
|
printf("res_query failed\n");
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
@ -351,10 +351,10 @@ getnetbyname(net)
|
|||||||
char lookups[MAXDNSLUS];
|
char lookups[MAXDNSLUS];
|
||||||
int i;
|
int i;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
return (_getnetbyname(net));
|
return (_getnetbyname(net));
|
||||||
|
|
||||||
memcpy(lookups, _res.lookups, sizeof lookups);
|
memcpy(lookups, _resolver_configuration.lookups, sizeof lookups);
|
||||||
if (lookups[0] == '\0')
|
if (lookups[0] == '\0')
|
||||||
strncpy(lookups, "bf", sizeof lookups);
|
strncpy(lookups, "bf", sizeof lookups);
|
||||||
|
|
||||||
@ -371,7 +371,7 @@ getnetbyname(net)
|
|||||||
sizeof(buf));
|
sizeof(buf));
|
||||||
if (anslen < 0) {
|
if (anslen < 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf("res_query failed\n");
|
printf("res_query failed\n");
|
||||||
#endif
|
#endif
|
||||||
break;
|
break;
|
||||||
|
@ -187,13 +187,13 @@ do_rrset(msg, len, cp, cnt, pflag, file, hs)
|
|||||||
/*
|
/*
|
||||||
* Print answer records.
|
* Print answer records.
|
||||||
*/
|
*/
|
||||||
sflag = (_res.pfcode & pflag);
|
sflag = (_resolver_configuration.pfcode & pflag);
|
||||||
if ((n = ntohs(cnt))) {
|
if ((n = ntohs(cnt))) {
|
||||||
if ((!_res.pfcode) ||
|
if ((!_resolver_configuration.pfcode) ||
|
||||||
((sflag) && (_res.pfcode & RES_PRF_HEAD1)))
|
((sflag) && (_resolver_configuration.pfcode & RES_PRF_HEAD1)))
|
||||||
fprintf(file, "%s", hs);
|
fprintf(file, "%s", hs);
|
||||||
while (--n >= 0) {
|
while (--n >= 0) {
|
||||||
if ((!_res.pfcode) || sflag) {
|
if ((!_resolver_configuration.pfcode) || sflag) {
|
||||||
cp = p_rr(cp, msg, file);
|
cp = p_rr(cp, msg, file);
|
||||||
} else {
|
} else {
|
||||||
unsigned int dlen;
|
unsigned int dlen;
|
||||||
@ -208,8 +208,8 @@ do_rrset(msg, len, cp, cnt, pflag, file, hs)
|
|||||||
if ((cp - msg) > len)
|
if ((cp - msg) > len)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
if ((!_res.pfcode) ||
|
if ((!_resolver_configuration.pfcode) ||
|
||||||
((sflag) && (_res.pfcode & RES_PRF_HEAD1)))
|
((sflag) && (_resolver_configuration.pfcode & RES_PRF_HEAD1)))
|
||||||
putc('\n', file);
|
putc('\n', file);
|
||||||
}
|
}
|
||||||
return (cp);
|
return (cp);
|
||||||
@ -227,7 +227,7 @@ __p_query(msg)
|
|||||||
* This is intended to be primarily a debugging routine.
|
* This is intended to be primarily a debugging routine.
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
__fp_resstat(statp, file)
|
__fp_resolver_configurationstat(statp, file)
|
||||||
struct __res_state *statp;
|
struct __res_state *statp;
|
||||||
FILE *file;
|
FILE *file;
|
||||||
{
|
{
|
||||||
@ -235,7 +235,7 @@ __fp_resstat(statp, file)
|
|||||||
|
|
||||||
fprintf(file, ";; res options:");
|
fprintf(file, ";; res options:");
|
||||||
if (!statp)
|
if (!statp)
|
||||||
statp = &_res;
|
statp = &_resolver_configuration;
|
||||||
for (mask = 1; mask != 0; mask <<= 1)
|
for (mask = 1; mask != 0; mask <<= 1)
|
||||||
if (statp->options & mask)
|
if (statp->options & mask)
|
||||||
fprintf(file, " %s", p_option(mask));
|
fprintf(file, " %s", p_option(mask));
|
||||||
@ -256,7 +256,7 @@ __fp_nquery(msg, len, file)
|
|||||||
register const HEADER *hp;
|
register const HEADER *hp;
|
||||||
register int n;
|
register int n;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
#define TruncTest(x) if (x > endMark) goto trunc
|
#define TruncTest(x) if (x > endMark) goto trunc
|
||||||
@ -268,16 +268,16 @@ __fp_nquery(msg, len, file)
|
|||||||
hp = (HEADER *)msg;
|
hp = (HEADER *)msg;
|
||||||
cp = msg + HFIXEDSZ;
|
cp = msg + HFIXEDSZ;
|
||||||
endMark = msg + len;
|
endMark = msg + len;
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_HEADX) || hp->rcode) {
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_HEADX) || hp->rcode) {
|
||||||
fprintf(file, ";; ->>HEADER<<- opcode: %s, status: %s, id: %d",
|
fprintf(file, ";; ->>HEADER<<- opcode: %s, status: %s, id: %d",
|
||||||
_res_opcodes[hp->opcode],
|
_res_opcodes[hp->opcode],
|
||||||
_res_resultcodes[hp->rcode],
|
_res_resultcodes[hp->rcode],
|
||||||
ntohs(hp->id));
|
ntohs(hp->id));
|
||||||
putc('\n', file);
|
putc('\n', file);
|
||||||
}
|
}
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_HEADX))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_HEADX))
|
||||||
putc(';', file);
|
putc(';', file);
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_HEAD2)) {
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_HEAD2)) {
|
||||||
fprintf(file, "; flags:");
|
fprintf(file, "; flags:");
|
||||||
if (hp->qr)
|
if (hp->qr)
|
||||||
fprintf(file, " qr");
|
fprintf(file, " qr");
|
||||||
@ -296,13 +296,13 @@ __fp_nquery(msg, len, file)
|
|||||||
if (hp->cd)
|
if (hp->cd)
|
||||||
fprintf(file, " cd");
|
fprintf(file, " cd");
|
||||||
}
|
}
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_HEAD1)) {
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_HEAD1)) {
|
||||||
fprintf(file, "; Ques: %d", ntohs(hp->qdcount));
|
fprintf(file, "; Ques: %d", ntohs(hp->qdcount));
|
||||||
fprintf(file, ", Ans: %d", ntohs(hp->ancount));
|
fprintf(file, ", Ans: %d", ntohs(hp->ancount));
|
||||||
fprintf(file, ", Auth: %d", ntohs(hp->nscount));
|
fprintf(file, ", Auth: %d", ntohs(hp->nscount));
|
||||||
fprintf(file, ", Addit: %d", ntohs(hp->arcount));
|
fprintf(file, ", Addit: %d", ntohs(hp->arcount));
|
||||||
}
|
}
|
||||||
if ((!_res.pfcode) || (_res.pfcode &
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode &
|
||||||
(RES_PRF_HEADX | RES_PRF_HEAD2 | RES_PRF_HEAD1))) {
|
(RES_PRF_HEADX | RES_PRF_HEAD2 | RES_PRF_HEAD1))) {
|
||||||
putc('\n',file);
|
putc('\n',file);
|
||||||
}
|
}
|
||||||
@ -310,13 +310,13 @@ __fp_nquery(msg, len, file)
|
|||||||
* Print question records.
|
* Print question records.
|
||||||
*/
|
*/
|
||||||
if ((n = ntohs(hp->qdcount))) {
|
if ((n = ntohs(hp->qdcount))) {
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_QUES))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_QUES))
|
||||||
fprintf(file, ";; QUESTIONS:\n");
|
fprintf(file, ";; QUESTIONS:\n");
|
||||||
while (--n >= 0) {
|
while (--n >= 0) {
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_QUES))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_QUES))
|
||||||
fprintf(file, ";;\t");
|
fprintf(file, ";;\t");
|
||||||
TruncTest(cp);
|
TruncTest(cp);
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_QUES))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_QUES))
|
||||||
cp = p_cdnname(cp, msg, len, file);
|
cp = p_cdnname(cp, msg, len, file);
|
||||||
else {
|
else {
|
||||||
int n;
|
int n;
|
||||||
@ -330,16 +330,16 @@ __fp_nquery(msg, len, file)
|
|||||||
}
|
}
|
||||||
ErrorTest(cp);
|
ErrorTest(cp);
|
||||||
TruncTest(cp);
|
TruncTest(cp);
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_QUES))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_QUES))
|
||||||
fprintf(file, ", type = %s",
|
fprintf(file, ", type = %s",
|
||||||
__p_type(_getshort((u_char*)cp)));
|
__p_type(_getshort((u_char*)cp)));
|
||||||
cp += INT16SZ;
|
cp += INT16SZ;
|
||||||
TruncTest(cp);
|
TruncTest(cp);
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_QUES))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_QUES))
|
||||||
fprintf(file, ", class = %s\n",
|
fprintf(file, ", class = %s\n",
|
||||||
__p_class(_getshort((u_char*)cp)));
|
__p_class(_getshort((u_char*)cp)));
|
||||||
cp += INT16SZ;
|
cp += INT16SZ;
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_QUES))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_QUES))
|
||||||
putc('\n', file);
|
putc('\n', file);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -468,7 +468,7 @@ __p_rr(cp, msg, file)
|
|||||||
char rrname[MAXDNAME]; /* The fqdn of this RR */
|
char rrname[MAXDNAME]; /* The fqdn of this RR */
|
||||||
char base64_key[MAX_KEY_BASE64];
|
char base64_key[MAX_KEY_BASE64];
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (NULL);
|
return (NULL);
|
||||||
}
|
}
|
||||||
@ -486,9 +486,9 @@ __p_rr(cp, msg, file)
|
|||||||
dlen = _getshort((u_char*)cp);
|
dlen = _getshort((u_char*)cp);
|
||||||
cp += INT16SZ;
|
cp += INT16SZ;
|
||||||
cp1 = cp;
|
cp1 = cp;
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_TTLID))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_TTLID))
|
||||||
fprintf(file, "\t%lu", (u_long)tmpttl);
|
fprintf(file, "\t%lu", (u_long)tmpttl);
|
||||||
if ((!_res.pfcode) || (_res.pfcode & RES_PRF_CLASS))
|
if ((!_resolver_configuration.pfcode) || (_resolver_configuration.pfcode & RES_PRF_CLASS))
|
||||||
fprintf(file, "\t%s", __p_class(class));
|
fprintf(file, "\t%s", __p_class(class));
|
||||||
fprintf(file, "\t%s", __p_type(type));
|
fprintf(file, "\t%s", __p_type(type));
|
||||||
/*
|
/*
|
||||||
|
@ -105,7 +105,7 @@ static uint32 net_mask (struct in_addr);
|
|||||||
* Resolver state default settings.
|
* Resolver state default settings.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
struct __res_state _res
|
struct __res_state _resolver_configuration
|
||||||
# if defined(__BIND_RES_TEXT)
|
# if defined(__BIND_RES_TEXT)
|
||||||
= { RES_TIMEOUT, } /* Motorola, et al. */
|
= { RES_TIMEOUT, } /* Motorola, et al. */
|
||||||
# endif
|
# endif
|
||||||
@ -173,33 +173,33 @@ res_init()
|
|||||||
* set in RES_DEFAULT). Our solution is to declare such applications
|
* set in RES_DEFAULT). Our solution is to declare such applications
|
||||||
* "broken". They could fool us by setting RES_INIT but none do (yet).
|
* "broken". They could fool us by setting RES_INIT but none do (yet).
|
||||||
*/
|
*/
|
||||||
if (!_res.retrans)
|
if (!_resolver_configuration.retrans)
|
||||||
_res.retrans = RES_TIMEOUT;
|
_resolver_configuration.retrans = RES_TIMEOUT;
|
||||||
if (!_res.retry)
|
if (!_resolver_configuration.retry)
|
||||||
_res.retry = 4;
|
_resolver_configuration.retry = 4;
|
||||||
if (!(_res.options & RES_INIT))
|
if (!(_resolver_configuration.options & RES_INIT))
|
||||||
_res.options = RES_DEFAULT;
|
_resolver_configuration.options = RES_DEFAULT;
|
||||||
|
|
||||||
#ifdef USELOOPBACK
|
#ifdef USELOOPBACK
|
||||||
_res.nsaddr.sin_addr = inet_makeaddr(IN_LOOPBACKNET, 1);
|
_resolver_configuration.nsaddr.sin_addr = inet_makeaddr(IN_LOOPBACKNET, 1);
|
||||||
#else
|
#else
|
||||||
_res.nsaddr.sin_addr.s_addr = INADDR_ANY;
|
_resolver_configuration.nsaddr.sin_addr.s_addr = INADDR_ANY;
|
||||||
#endif
|
#endif
|
||||||
_res.nsaddr.sin_family = AF_INET;
|
_resolver_configuration.nsaddr.sin_family = AF_INET;
|
||||||
_res.nsaddr.sin_port = htons(NAMESERVER_PORT);
|
_resolver_configuration.nsaddr.sin_port = htons(NAMESERVER_PORT);
|
||||||
_res.nsaddr.sin_len = sizeof(struct sockaddr_in);
|
_resolver_configuration.nsaddr.sin_len = sizeof(struct sockaddr_in);
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
if (sizeof(_res_ext.nsaddr) >= _res.nsaddr.sin_len)
|
if (sizeof(_resolver_configuration_ext.nsaddr) >= _resolver_configuration.nsaddr.sin_len)
|
||||||
memcpy(&_res_ext.nsaddr, &_res.nsaddr, _res.nsaddr.sin_len);
|
memcpy(&_resolver_configuration_ext.nsaddr, &_resolver_configuration.nsaddr, _resolver_configuration.nsaddr.sin_len);
|
||||||
#endif
|
#endif
|
||||||
_res.nscount = 1;
|
_resolver_configuration.nscount = 1;
|
||||||
_res.ndots = 1;
|
_resolver_configuration.ndots = 1;
|
||||||
_res.pfcode = 0;
|
_resolver_configuration.pfcode = 0;
|
||||||
strncpy(_res.lookups, "f", sizeof _res.lookups);
|
strncpy(_resolver_configuration.lookups, "f", sizeof _resolver_configuration.lookups);
|
||||||
|
|
||||||
/* Allow user to override the local domain definition */
|
/* Allow user to override the local domain definition */
|
||||||
if ((cp = getenv("LOCALDOMAIN")) != NULL) {
|
if ((cp = getenv("LOCALDOMAIN")) != NULL) {
|
||||||
strncpy(_res.defdname, cp, sizeof(_res.defdname));
|
strncpy(_resolver_configuration.defdname, cp, sizeof(_resolver_configuration.defdname));
|
||||||
haveenv++;
|
haveenv++;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -209,10 +209,10 @@ res_init()
|
|||||||
* one that they want to use as an individual (even more
|
* one that they want to use as an individual (even more
|
||||||
* important now that the rfc1535 stuff restricts searches)
|
* important now that the rfc1535 stuff restricts searches)
|
||||||
*/
|
*/
|
||||||
cp = _res.defdname;
|
cp = _resolver_configuration.defdname;
|
||||||
pp = _res.dnsrch;
|
pp = _resolver_configuration.dnsrch;
|
||||||
*pp++ = cp;
|
*pp++ = cp;
|
||||||
for (n = 0; *cp && pp < _res.dnsrch + MAXDNSRCH; cp++) {
|
for (n = 0; *cp && pp < _resolver_configuration.dnsrch + MAXDNSRCH; cp++) {
|
||||||
if (*cp == '\n') /* silly backwards compat */
|
if (*cp == '\n') /* silly backwards compat */
|
||||||
break;
|
break;
|
||||||
else if (*cp == ' ' || *cp == '\t') {
|
else if (*cp == ' ' || *cp == '\t') {
|
||||||
@ -237,7 +237,7 @@ res_init()
|
|||||||
line[sizeof(name) - 1] == '\t'))
|
line[sizeof(name) - 1] == '\t'))
|
||||||
|
|
||||||
if ((fp = fopen(_PATH_RESCONF, "r")) != NULL) {
|
if ((fp = fopen(_PATH_RESCONF, "r")) != NULL) {
|
||||||
strncpy(_res.lookups, "bf", sizeof _res.lookups);
|
strncpy(_resolver_configuration.lookups, "bf", sizeof _resolver_configuration.lookups);
|
||||||
|
|
||||||
/* read the config file */
|
/* read the config file */
|
||||||
buf[0] = '\0';
|
buf[0] = '\0';
|
||||||
@ -263,8 +263,8 @@ res_init()
|
|||||||
cp++;
|
cp++;
|
||||||
if ((*cp == '\0') || (*cp == '\n'))
|
if ((*cp == '\0') || (*cp == '\n'))
|
||||||
continue;
|
continue;
|
||||||
strncpy(_res.defdname, cp, sizeof(_res.defdname));
|
strncpy(_resolver_configuration.defdname, cp, sizeof(_resolver_configuration.defdname));
|
||||||
if ((cp = strpbrk(_res.defdname, " \t\n")) != NULL)
|
if ((cp = strpbrk(_resolver_configuration.defdname, " \t\n")) != NULL)
|
||||||
*cp = '\0';
|
*cp = '\0';
|
||||||
havesearch = 0;
|
havesearch = 0;
|
||||||
continue;
|
continue;
|
||||||
@ -272,7 +272,7 @@ res_init()
|
|||||||
/* lookup types */
|
/* lookup types */
|
||||||
if (MATCH(buf, "lookup")) {
|
if (MATCH(buf, "lookup")) {
|
||||||
char *sp = NULL;
|
char *sp = NULL;
|
||||||
memset(_res.lookups, 0, sizeof _res.lookups);
|
memset(_resolver_configuration.lookups, 0, sizeof _resolver_configuration.lookups);
|
||||||
cp = buf + sizeof("lookup") - 1;
|
cp = buf + sizeof("lookup") - 1;
|
||||||
for (n = 0;; cp++) {
|
for (n = 0;; cp++) {
|
||||||
if (n == MAXDNSLUS)
|
if (n == MAXDNSLUS)
|
||||||
@ -280,14 +280,14 @@ res_init()
|
|||||||
if ((*cp == '\0') || (*cp == '\n')) {
|
if ((*cp == '\0') || (*cp == '\n')) {
|
||||||
if (sp) {
|
if (sp) {
|
||||||
if (*sp=='y' || *sp=='b' || *sp=='f')
|
if (*sp=='y' || *sp=='b' || *sp=='f')
|
||||||
_res.lookups[n++] = *sp;
|
_resolver_configuration.lookups[n++] = *sp;
|
||||||
sp = NULL;
|
sp = NULL;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
} else if ((*cp == ' ') || (*cp == '\t') || (*cp == ',')) {
|
} else if ((*cp == ' ') || (*cp == '\t') || (*cp == ',')) {
|
||||||
if (sp) {
|
if (sp) {
|
||||||
if (*sp=='y' || *sp=='b' || *sp=='f')
|
if (*sp=='y' || *sp=='b' || *sp=='f')
|
||||||
_res.lookups[n++] = *sp;
|
_resolver_configuration.lookups[n++] = *sp;
|
||||||
sp = NULL;
|
sp = NULL;
|
||||||
}
|
}
|
||||||
} else if (sp == NULL)
|
} else if (sp == NULL)
|
||||||
@ -304,17 +304,17 @@ res_init()
|
|||||||
cp++;
|
cp++;
|
||||||
if ((*cp == '\0') || (*cp == '\n'))
|
if ((*cp == '\0') || (*cp == '\n'))
|
||||||
continue;
|
continue;
|
||||||
strncpy(_res.defdname, cp, sizeof(_res.defdname));
|
strncpy(_resolver_configuration.defdname, cp, sizeof(_resolver_configuration.defdname));
|
||||||
if ((cp = strchr(_res.defdname, '\n')) != NULL)
|
if ((cp = strchr(_resolver_configuration.defdname, '\n')) != NULL)
|
||||||
*cp = '\0';
|
*cp = '\0';
|
||||||
/*
|
/*
|
||||||
* Set search list to be blank-separated strings
|
* Set search list to be blank-separated strings
|
||||||
* on rest of line.
|
* on rest of line.
|
||||||
*/
|
*/
|
||||||
cp = _res.defdname;
|
cp = _resolver_configuration.defdname;
|
||||||
pp = _res.dnsrch;
|
pp = _resolver_configuration.dnsrch;
|
||||||
*pp++ = cp;
|
*pp++ = cp;
|
||||||
for (n = 0; *cp && pp < _res.dnsrch + MAXDNSRCH; cp++) {
|
for (n = 0; *cp && pp < _resolver_configuration.dnsrch + MAXDNSRCH; cp++) {
|
||||||
if (*cp == ' ' || *cp == '\t') {
|
if (*cp == ' ' || *cp == '\t') {
|
||||||
*cp = 0;
|
*cp = 0;
|
||||||
n = 1;
|
n = 1;
|
||||||
@ -359,19 +359,19 @@ res_init()
|
|||||||
res = NULL;
|
res = NULL;
|
||||||
if (getaddrinfo(cp, pbuf, &hints, &res) == 0 &&
|
if (getaddrinfo(cp, pbuf, &hints, &res) == 0 &&
|
||||||
res->ai_next == NULL) {
|
res->ai_next == NULL) {
|
||||||
if (res->ai_addrlen <= sizeof(_res_ext.nsaddr_list[nserv])) {
|
if (res->ai_addrlen <= sizeof(_resolver_configuration_ext.nsaddr_list[nserv])) {
|
||||||
memcpy(&_res_ext.nsaddr_list[nserv], res->ai_addr,
|
memcpy(&_resolver_configuration_ext.nsaddr_list[nserv], res->ai_addr,
|
||||||
res->ai_addrlen);
|
res->ai_addrlen);
|
||||||
} else {
|
} else {
|
||||||
memset(&_res_ext.nsaddr_list[nserv], 0,
|
memset(&_resolver_configuration_ext.nsaddr_list[nserv], 0,
|
||||||
sizeof(_res_ext.nsaddr_list[nserv]));
|
sizeof(_resolver_configuration_ext.nsaddr_list[nserv]));
|
||||||
}
|
}
|
||||||
if (res->ai_addrlen <= sizeof(_res.nsaddr_list[nserv])) {
|
if (res->ai_addrlen <= sizeof(_resolver_configuration.nsaddr_list[nserv])) {
|
||||||
memcpy(&_res.nsaddr_list[nserv], res->ai_addr,
|
memcpy(&_resolver_configuration.nsaddr_list[nserv], res->ai_addr,
|
||||||
res->ai_addrlen);
|
res->ai_addrlen);
|
||||||
} else {
|
} else {
|
||||||
memset(&_res.nsaddr_list[nserv], 0,
|
memset(&_resolver_configuration.nsaddr_list[nserv], 0,
|
||||||
sizeof(_res.nsaddr_list[nserv]));
|
sizeof(_resolver_configuration.nsaddr_list[nserv]));
|
||||||
}
|
}
|
||||||
nserv++;
|
nserv++;
|
||||||
}
|
}
|
||||||
@ -379,10 +379,10 @@ res_init()
|
|||||||
freeaddrinfo(res);
|
freeaddrinfo(res);
|
||||||
#else /* INET6 */
|
#else /* INET6 */
|
||||||
if ((*cp != '\0') && (*cp != '\n') && inet_aton(cp, &a)) {
|
if ((*cp != '\0') && (*cp != '\n') && inet_aton(cp, &a)) {
|
||||||
_res.nsaddr_list[nserv].sin_addr = a;
|
_resolver_configuration.nsaddr_list[nserv].sin_addr = a;
|
||||||
_res.nsaddr_list[nserv].sin_family = AF_INET;
|
_resolver_configuration.nsaddr_list[nserv].sin_family = AF_INET;
|
||||||
_res.nsaddr_list[nserv].sin_port = htons(NAMESERVER_PORT);
|
_resolver_configuration.nsaddr_list[nserv].sin_port = htons(NAMESERVER_PORT);
|
||||||
_res.nsaddr_list[nserv].sin_len = sizeof(struct sockaddr_in);
|
_resolver_configuration.nsaddr_list[nserv].sin_len = sizeof(struct sockaddr_in);
|
||||||
nserv++;
|
nserv++;
|
||||||
}
|
}
|
||||||
#endif /* INET6 */
|
#endif /* INET6 */
|
||||||
@ -410,7 +410,7 @@ res_init()
|
|||||||
n = *cp;
|
n = *cp;
|
||||||
*cp = 0;
|
*cp = 0;
|
||||||
if (inet_aton(net, &a)) {
|
if (inet_aton(net, &a)) {
|
||||||
_res.sort_list[nsort].addr = a;
|
_resolver_configuration.sort_list[nsort].addr = a;
|
||||||
if (ISSORTMASK(n)) {
|
if (ISSORTMASK(n)) {
|
||||||
*cp++ = n;
|
*cp++ = n;
|
||||||
net = cp;
|
net = cp;
|
||||||
@ -420,29 +420,29 @@ res_init()
|
|||||||
n = *cp;
|
n = *cp;
|
||||||
*cp = 0;
|
*cp = 0;
|
||||||
if (inet_aton(net, &a)) {
|
if (inet_aton(net, &a)) {
|
||||||
_res.sort_list[nsort].mask = a.s_addr;
|
_resolver_configuration.sort_list[nsort].mask = a.s_addr;
|
||||||
} else {
|
} else {
|
||||||
_res.sort_list[nsort].mask =
|
_resolver_configuration.sort_list[nsort].mask =
|
||||||
net_mask(_res.sort_list[nsort].addr);
|
net_mask(_resolver_configuration.sort_list[nsort].addr);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
_res.sort_list[nsort].mask =
|
_resolver_configuration.sort_list[nsort].mask =
|
||||||
net_mask(_res.sort_list[nsort].addr);
|
net_mask(_resolver_configuration.sort_list[nsort].addr);
|
||||||
}
|
}
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
_res_ext.sort_list[nsort].af = AF_INET;
|
_resolver_configuration_ext.sort_list[nsort].af = AF_INET;
|
||||||
_res_ext.sort_list[nsort].addr.ina =
|
_resolver_configuration_ext.sort_list[nsort].addr.ina =
|
||||||
_res.sort_list[nsort].addr;
|
_resolver_configuration.sort_list[nsort].addr;
|
||||||
_res_ext.sort_list[nsort].mask.ina.s_addr =
|
_resolver_configuration_ext.sort_list[nsort].mask.ina.s_addr =
|
||||||
_res.sort_list[nsort].mask;
|
_resolver_configuration.sort_list[nsort].mask;
|
||||||
#endif /* INET6 */
|
#endif /* INET6 */
|
||||||
nsort++;
|
nsort++;
|
||||||
}
|
}
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
else if (inet_pton(AF_INET6, net, &a6) == 1) {
|
else if (inet_pton(AF_INET6, net, &a6) == 1) {
|
||||||
_res_ext.sort_list[nsort].af = AF_INET6;
|
_resolver_configuration_ext.sort_list[nsort].af = AF_INET6;
|
||||||
_res_ext.sort_list[nsort].addr.in6a = a6;
|
_resolver_configuration_ext.sort_list[nsort].addr.in6a = a6;
|
||||||
u = (u_char *)&_res_ext.sort_list[nsort].mask.in6a;
|
u = (u_char *)&_resolver_configuration_ext.sort_list[nsort].mask.in6a;
|
||||||
*cp++ = n;
|
*cp++ = n;
|
||||||
net = cp;
|
net = cp;
|
||||||
while (*cp && *cp != ';' &&
|
while (*cp && *cp != ';' &&
|
||||||
@ -492,33 +492,33 @@ res_init()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (nserv > 1)
|
if (nserv > 1)
|
||||||
_res.nscount = nserv;
|
_resolver_configuration.nscount = nserv;
|
||||||
#ifdef RESOLVSORT
|
#ifdef RESOLVSORT
|
||||||
_res.nsort = nsort;
|
_resolver_configuration.nsort = nsort;
|
||||||
#endif
|
#endif
|
||||||
(void) fclose(fp);
|
(void) fclose(fp);
|
||||||
}
|
}
|
||||||
if (_res.defdname[0] == 0 &&
|
if (_resolver_configuration.defdname[0] == 0 &&
|
||||||
gethostname(buf, sizeof(_res.defdname) - 1) == 0 &&
|
gethostname(buf, sizeof(_resolver_configuration.defdname) - 1) == 0 &&
|
||||||
(cp = strchr(buf, '.')) != NULL)
|
(cp = strchr(buf, '.')) != NULL)
|
||||||
{
|
{
|
||||||
strncpy(_res.defdname, cp + 1,
|
strncpy(_resolver_configuration.defdname, cp + 1,
|
||||||
sizeof(_res.defdname));
|
sizeof(_resolver_configuration.defdname));
|
||||||
}
|
}
|
||||||
|
|
||||||
/* find components of local domain that might be searched */
|
/* find components of local domain that might be searched */
|
||||||
if (havesearch == 0) {
|
if (havesearch == 0) {
|
||||||
pp = _res.dnsrch;
|
pp = _resolver_configuration.dnsrch;
|
||||||
*pp++ = _res.defdname;
|
*pp++ = _resolver_configuration.defdname;
|
||||||
*pp = NULL;
|
*pp = NULL;
|
||||||
|
|
||||||
#ifndef RFC1535
|
#ifndef RFC1535
|
||||||
dots = 0;
|
dots = 0;
|
||||||
for (cp = _res.defdname; *cp; cp++)
|
for (cp = _resolver_configuration.defdname; *cp; cp++)
|
||||||
dots += (*cp == '.');
|
dots += (*cp == '.');
|
||||||
|
|
||||||
cp = _res.defdname;
|
cp = _resolver_configuration.defdname;
|
||||||
while (pp < _res.dnsrch + MAXDFLSRCH) {
|
while (pp < _resolver_configuration.dnsrch + MAXDFLSRCH) {
|
||||||
if (dots < LOCALDOMAINPARTS)
|
if (dots < LOCALDOMAINPARTS)
|
||||||
break;
|
break;
|
||||||
cp = strchr(cp, '.') + 1; /* we know there is one */
|
cp = strchr(cp, '.') + 1; /* we know there is one */
|
||||||
@ -527,9 +527,9 @@ res_init()
|
|||||||
}
|
}
|
||||||
*pp = NULL;
|
*pp = NULL;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG) {
|
if (_resolver_configuration.options & RES_DEBUG) {
|
||||||
printf(";; res_init()... default dnsrch list:\n");
|
printf(";; res_init()... default dnsrch list:\n");
|
||||||
for (pp = _res.dnsrch; *pp; pp++)
|
for (pp = _resolver_configuration.dnsrch; *pp; pp++)
|
||||||
printf(";;\t%s\n", *pp);
|
printf(";;\t%s\n", *pp);
|
||||||
printf(";;\t..END..\n");
|
printf(";;\t..END..\n");
|
||||||
}
|
}
|
||||||
@ -538,11 +538,11 @@ res_init()
|
|||||||
}
|
}
|
||||||
|
|
||||||
// if (issetugid())
|
// if (issetugid())
|
||||||
// _res.options |= RES_NOALIASES;
|
// _resolver_configuration.options |= RES_NOALIASES;
|
||||||
// else
|
// else
|
||||||
if ((cp = getenv("RES_OPTIONS")) != NULL)
|
if ((cp = getenv("RES_OPTIONS")) != NULL)
|
||||||
res_setoptions(cp, "env");
|
res_setoptions(cp, "env");
|
||||||
_res.options |= RES_INIT;
|
_resolver_configuration.options |= RES_INIT;
|
||||||
return (0);
|
return (0);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -556,7 +556,7 @@ res_setoptions(options, source)
|
|||||||
long l;
|
long l;
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_setoptions(\"%s\", \"%s\")...\n",
|
printf(";; res_setoptions(\"%s\", \"%s\")...\n",
|
||||||
options, source);
|
options, source);
|
||||||
#endif
|
#endif
|
||||||
@ -571,31 +571,31 @@ res_setoptions(options, source)
|
|||||||
if (l >= 0 && endp != p &&
|
if (l >= 0 && endp != p &&
|
||||||
(*endp = '\0' || isspace(*endp))) {
|
(*endp = '\0' || isspace(*endp))) {
|
||||||
if (l <= RES_MAXNDOTS)
|
if (l <= RES_MAXNDOTS)
|
||||||
_res.ndots = l;
|
_resolver_configuration.ndots = l;
|
||||||
else
|
else
|
||||||
_res.ndots = RES_MAXNDOTS;
|
_resolver_configuration.ndots = RES_MAXNDOTS;
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";;\tndots=%d\n", _res.ndots);
|
printf(";;\tndots=%d\n", _resolver_configuration.ndots);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
} else if (!strncmp(cp, "debug", sizeof("debug") - 1)) {
|
} else if (!strncmp(cp, "debug", sizeof("debug") - 1)) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (!(_res.options & RES_DEBUG)) {
|
if (!(_resolver_configuration.options & RES_DEBUG)) {
|
||||||
printf(";; res_setoptions(\"%s\", \"%s\")..\n",
|
printf(";; res_setoptions(\"%s\", \"%s\")..\n",
|
||||||
options, source);
|
options, source);
|
||||||
_res.options |= RES_DEBUG;
|
_resolver_configuration.options |= RES_DEBUG;
|
||||||
}
|
}
|
||||||
printf(";;\tdebug\n");
|
printf(";;\tdebug\n");
|
||||||
#endif
|
#endif
|
||||||
} else if (!strncmp(cp, "inet6", sizeof("inet6") - 1)) {
|
} else if (!strncmp(cp, "inet6", sizeof("inet6") - 1)) {
|
||||||
_res.options |= RES_USE_INET6;
|
_resolver_configuration.options |= RES_USE_INET6;
|
||||||
} else if (!strncmp(cp, "insecure1", sizeof("insecure1") - 1)) {
|
} else if (!strncmp(cp, "insecure1", sizeof("insecure1") - 1)) {
|
||||||
_res.options |= RES_INSECURE1;
|
_resolver_configuration.options |= RES_INSECURE1;
|
||||||
} else if (!strncmp(cp, "insecure2", sizeof("insecure2") - 1)) {
|
} else if (!strncmp(cp, "insecure2", sizeof("insecure2") - 1)) {
|
||||||
_res.options |= RES_INSECURE2;
|
_resolver_configuration.options |= RES_INSECURE2;
|
||||||
} else if (!strncmp(cp, "edns0", sizeof("edns0") - 1)) {
|
} else if (!strncmp(cp, "edns0", sizeof("edns0") - 1)) {
|
||||||
_res.options |= RES_USE_EDNS0;
|
_resolver_configuration.options |= RES_USE_EDNS0;
|
||||||
} else {
|
} else {
|
||||||
/* XXX - print a warning here? */
|
/* XXX - print a warning here? */
|
||||||
}
|
}
|
||||||
|
@ -85,12 +85,12 @@ res_mkquery(op, dname, class, type, data, datalen, newrr_in, buf, buflen)
|
|||||||
register int n;
|
register int n;
|
||||||
u_char *dnptrs[20], **dpp, **lastdnptr;
|
u_char *dnptrs[20], **dpp, **lastdnptr;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_mkquery(%d, %s, %d, %d)\n",
|
printf(";; res_mkquery(%d, %s, %d, %d)\n",
|
||||||
op, dname, class, type);
|
op, dname, class, type);
|
||||||
#endif
|
#endif
|
||||||
@ -107,10 +107,10 @@ res_mkquery(op, dname, class, type, data, datalen, newrr_in, buf, buflen)
|
|||||||
|
|
||||||
memset(buf, 0, HFIXEDSZ);
|
memset(buf, 0, HFIXEDSZ);
|
||||||
hp = (HEADER *) buf;
|
hp = (HEADER *) buf;
|
||||||
_res.id = res_randomid();
|
_resolver_configuration.id = res_randomid();
|
||||||
hp->id = htons(_res.id);
|
hp->id = htons(_resolver_configuration.id);
|
||||||
hp->opcode = op;
|
hp->opcode = op;
|
||||||
hp->rd = (_res.options & RES_RECURSE) != 0;
|
hp->rd = (_resolver_configuration.options & RES_RECURSE) != 0;
|
||||||
hp->rcode = NOERROR;
|
hp->rcode = NOERROR;
|
||||||
cp = buf + HFIXEDSZ;
|
cp = buf + HFIXEDSZ;
|
||||||
buflen -= HFIXEDSZ;
|
buflen -= HFIXEDSZ;
|
||||||
@ -212,9 +212,9 @@ res_opt(n0, buf, buflen, anslen)
|
|||||||
cp += INT16SZ;
|
cp += INT16SZ;
|
||||||
*cp++ = NOERROR; /* extended RCODE */
|
*cp++ = NOERROR; /* extended RCODE */
|
||||||
*cp++ = 0; /* EDNS version */
|
*cp++ = 0; /* EDNS version */
|
||||||
if (_res.options & RES_USE_DNSSEC) {
|
if (_resolver_configuration.options & RES_USE_DNSSEC) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_opt()... ENDS0 DNSSEC OK\n");
|
printf(";; res_opt()... ENDS0 DNSSEC OK\n");
|
||||||
#endif /* DEBUG */
|
#endif /* DEBUG */
|
||||||
__putshort(DNS_MESSAGEEXTFLAG_DO, cp); /* EDNS Z field */
|
__putshort(DNS_MESSAGEEXTFLAG_DO, cp); /* EDNS Z field */
|
||||||
|
@ -101,25 +101,25 @@ res_query(name, class, type, answer, anslen)
|
|||||||
|
|
||||||
hp->rcode = NOERROR; /* default */
|
hp->rcode = NOERROR; /* default */
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_query(%s, %d, %d)\n", name, class, type);
|
printf(";; res_query(%s, %d, %d)\n", name, class, type);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
n = res_mkquery(QUERY, name, class, type, NULL, 0, NULL,
|
n = res_mkquery(QUERY, name, class, type, NULL, 0, NULL,
|
||||||
buf, sizeof(buf));
|
buf, sizeof(buf));
|
||||||
if (n > 0 && ((_res.options & RES_USE_EDNS0) ||
|
if (n > 0 && ((_resolver_configuration.options & RES_USE_EDNS0) ||
|
||||||
(_res.options & RES_USE_DNSSEC))) {
|
(_resolver_configuration.options & RES_USE_DNSSEC))) {
|
||||||
n = res_opt(n, buf, sizeof(buf), anslen);
|
n = res_opt(n, buf, sizeof(buf), anslen);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (n <= 0) {
|
if (n <= 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_query: mkquery failed\n");
|
printf(";; res_query: mkquery failed\n");
|
||||||
#endif
|
#endif
|
||||||
h_errno = NO_RECOVERY;
|
h_errno = NO_RECOVERY;
|
||||||
@ -128,7 +128,7 @@ res_query(name, class, type, answer, anslen)
|
|||||||
n = res_send(buf, n, answer, anslen);
|
n = res_send(buf, n, answer, anslen);
|
||||||
if (n < 0) {
|
if (n < 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_query: send error\n");
|
printf(";; res_query: send error\n");
|
||||||
#endif
|
#endif
|
||||||
h_errno = TRY_AGAIN;
|
h_errno = TRY_AGAIN;
|
||||||
@ -137,7 +137,7 @@ res_query(name, class, type, answer, anslen)
|
|||||||
|
|
||||||
if (hp->rcode != NOERROR || ntohs(hp->ancount) == 0) {
|
if (hp->rcode != NOERROR || ntohs(hp->ancount) == 0) {
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; rcode = %d, ancount=%d\n", hp->rcode,
|
printf(";; rcode = %d, ancount=%d\n", hp->rcode,
|
||||||
ntohs(hp->ancount));
|
ntohs(hp->ancount));
|
||||||
#endif
|
#endif
|
||||||
@ -182,7 +182,7 @@ res_search(name, class, type, answer, anslen)
|
|||||||
int trailing_dot, ret, saved_herrno;
|
int trailing_dot, ret, saved_herrno;
|
||||||
int got_nodata = 0, got_servfail = 0, tried_as_is = 0;
|
int got_nodata = 0, got_servfail = 0, tried_as_is = 0;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
@ -206,7 +206,7 @@ res_search(name, class, type, answer, anslen)
|
|||||||
* 'as is'. The threshold can be set with the "ndots" option.
|
* 'as is'. The threshold can be set with the "ndots" option.
|
||||||
*/
|
*/
|
||||||
saved_herrno = -1;
|
saved_herrno = -1;
|
||||||
if (dots >= _res.ndots) {
|
if (dots >= _resolver_configuration.ndots) {
|
||||||
ret = res_querydomain(name, NULL, class, type, answer, anslen);
|
ret = res_querydomain(name, NULL, class, type, answer, anslen);
|
||||||
if (ret > 0)
|
if (ret > 0)
|
||||||
return (ret);
|
return (ret);
|
||||||
@ -220,11 +220,11 @@ res_search(name, class, type, answer, anslen)
|
|||||||
* - there is at least one dot, there is no trailing dot,
|
* - there is at least one dot, there is no trailing dot,
|
||||||
* and RES_DNSRCH is set.
|
* and RES_DNSRCH is set.
|
||||||
*/
|
*/
|
||||||
if ((!dots && (_res.options & RES_DEFNAMES)) ||
|
if ((!dots && (_resolver_configuration.options & RES_DEFNAMES)) ||
|
||||||
(dots && !trailing_dot && (_res.options & RES_DNSRCH))) {
|
(dots && !trailing_dot && (_resolver_configuration.options & RES_DNSRCH))) {
|
||||||
int done = 0;
|
int done = 0;
|
||||||
|
|
||||||
for (domain = (const char * const *)_res.dnsrch;
|
for (domain = (const char * const *)_resolver_configuration.dnsrch;
|
||||||
*domain && !done;
|
*domain && !done;
|
||||||
domain++) {
|
domain++) {
|
||||||
|
|
||||||
@ -273,7 +273,7 @@ res_search(name, class, type, answer, anslen)
|
|||||||
/* if we got here for some reason other than DNSRCH,
|
/* if we got here for some reason other than DNSRCH,
|
||||||
* we only wanted one iteration of the loop, so stop.
|
* we only wanted one iteration of the loop, so stop.
|
||||||
*/
|
*/
|
||||||
if (!(_res.options & RES_DNSRCH))
|
if (!(_resolver_configuration.options & RES_DNSRCH))
|
||||||
done++;
|
done++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -319,12 +319,12 @@ res_querydomain(name, domain, class, type, answer, anslen)
|
|||||||
const char *longname = nbuf;
|
const char *longname = nbuf;
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
h_errno = NETDB_INTERNAL;
|
h_errno = NETDB_INTERNAL;
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
if (_res.options & RES_DEBUG)
|
if (_resolver_configuration.options & RES_DEBUG)
|
||||||
printf(";; res_querydomain(%s, %s, %d, %d)\n",
|
printf(";; res_querydomain(%s, %s, %d, %d)\n",
|
||||||
name, domain?domain:"<Nil>", class, type);
|
name, domain?domain:"<Nil>", class, type);
|
||||||
#endif
|
#endif
|
||||||
@ -356,7 +356,7 @@ hostalias(name)
|
|||||||
static char abuf[MAXDNAME];
|
static char abuf[MAXDNAME];
|
||||||
size_t len;
|
size_t len;
|
||||||
|
|
||||||
if (_res.options & RES_NOALIASES)
|
if (_resolver_configuration.options & RES_NOALIASES)
|
||||||
return (NULL);
|
return (NULL);
|
||||||
file = getenv("HOSTALIASES");
|
file = getenv("HOSTALIASES");
|
||||||
// if (issetugid() != 0 || file == NULL || (fp = fopen(file, "r")) == NULL)
|
// if (issetugid() != 0 || file == NULL || (fp = fopen(file, "r")) == NULL)
|
||||||
|
@ -114,7 +114,7 @@ static void Perror (FILE *, char *, int);
|
|||||||
{
|
{
|
||||||
int save = errno;
|
int save = errno;
|
||||||
|
|
||||||
if (_res.options & RES_DEBUG) {
|
if (_resolver_configuration.options & RES_DEBUG) {
|
||||||
if (getnameinfo(address, address->sa_len, abuf, sizeof(abuf),
|
if (getnameinfo(address, address->sa_len, abuf, sizeof(abuf),
|
||||||
pbuf, sizeof(pbuf),
|
pbuf, sizeof(pbuf),
|
||||||
NI_NUMERICHOST|NI_NUMERICSERV|NI_WITHSCOPEID) != 0) {
|
NI_NUMERICHOST|NI_NUMERICSERV|NI_WITHSCOPEID) != 0) {
|
||||||
@ -134,7 +134,7 @@ static void Perror (FILE *, char *, int);
|
|||||||
{
|
{
|
||||||
int save = errno;
|
int save = errno;
|
||||||
|
|
||||||
if (_res.options & RES_DEBUG) {
|
if (_resolver_configuration.options & RES_DEBUG) {
|
||||||
fprintf(file, "res_send: %s: %s\n",
|
fprintf(file, "res_send: %s: %s\n",
|
||||||
string, strerror(error));
|
string, strerror(error));
|
||||||
}
|
}
|
||||||
@ -172,29 +172,29 @@ get_nsaddr(n)
|
|||||||
size_t n;
|
size_t n;
|
||||||
{
|
{
|
||||||
|
|
||||||
if (!_res.nsaddr_list[n].sin_family) {
|
if (!_resolver_configuration.nsaddr_list[n].sin_family) {
|
||||||
/*
|
/*
|
||||||
* - _res_ext.nsaddr_list[n] holds an address that is larger
|
* - _resolver_configuration_ext.nsaddr_list[n] holds an address that is larger
|
||||||
* than struct sockaddr, and
|
* than struct sockaddr, and
|
||||||
* - user code did not update _res.nsaddr_list[n].
|
* - user code did not update _resolver_configuration.nsaddr_list[n].
|
||||||
*/
|
*/
|
||||||
return (struct sockaddr *)&_res_ext.nsaddr_list[n];
|
return (struct sockaddr *)&_resolver_configuration_ext.nsaddr_list[n];
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
* - user code updated _res.nsaddr_list[n], or
|
* - user code updated _resolver_configuration.nsaddr_list[n], or
|
||||||
* - _res.nsaddr_list[n] has the same content as
|
* - _resolver_configuration.nsaddr_list[n] has the same content as
|
||||||
* _res_ext.nsaddr_list[n].
|
* _resolver_configuration_ext.nsaddr_list[n].
|
||||||
*/
|
*/
|
||||||
return (struct sockaddr *)&_res.nsaddr_list[n];
|
return (struct sockaddr *)&_resolver_configuration.nsaddr_list[n];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
#define get_nsaddr(n) ((struct sockaddr *)&_res.nsaddr_list[(n)])
|
#define get_nsaddr(n) ((struct sockaddr *)&_resolver_configuration.nsaddr_list[(n)])
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* int
|
/* int
|
||||||
* res_isourserver(ina)
|
* res_isourserver(ina)
|
||||||
* looks up "ina" in _res.ns_addr_list[]
|
* looks up "ina" in _resolver_configuration.ns_addr_list[]
|
||||||
* returns:
|
* returns:
|
||||||
* 0 : not found
|
* 0 : not found
|
||||||
* >0 : found
|
* >0 : found
|
||||||
@ -221,7 +221,7 @@ res_isourserver(inp)
|
|||||||
switch (inp->sin_family) {
|
switch (inp->sin_family) {
|
||||||
#ifdef INET6
|
#ifdef INET6
|
||||||
case AF_INET6:
|
case AF_INET6:
|
||||||
for (ns = 0; ns < _res.nscount; ns++) {
|
for (ns = 0; ns < _resolver_configuration.nscount; ns++) {
|
||||||
srv6 = (struct sockaddr_in6 *)get_nsaddr(ns);
|
srv6 = (struct sockaddr_in6 *)get_nsaddr(ns);
|
||||||
if (srv6->sin6_family == in6p->sin6_family &&
|
if (srv6->sin6_family == in6p->sin6_family &&
|
||||||
srv6->sin6_port == in6p->sin6_port &&
|
srv6->sin6_port == in6p->sin6_port &&
|
||||||
@ -236,7 +236,7 @@ res_isourserver(inp)
|
|||||||
break;
|
break;
|
||||||
#endif
|
#endif
|
||||||
case AF_INET:
|
case AF_INET:
|
||||||
for (ns = 0; ns < _res.nscount; ns++) {
|
for (ns = 0; ns < _resolver_configuration.nscount; ns++) {
|
||||||
srv = (struct sockaddr_in *)get_nsaddr(ns);
|
srv = (struct sockaddr_in *)get_nsaddr(ns);
|
||||||
if (srv->sin_family == inp->sin_family &&
|
if (srv->sin_family == inp->sin_family &&
|
||||||
srv->sin_port == inp->sin_port &&
|
srv->sin_port == inp->sin_port &&
|
||||||
@ -338,13 +338,13 @@ res_send(buf, buflen, ans, anssiz)
|
|||||||
register int n;
|
register int n;
|
||||||
u_int badns; /* XXX NSMAX can't exceed #/bits in this var */
|
u_int badns; /* XXX NSMAX can't exceed #/bits in this var */
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1) {
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1) {
|
||||||
/* errno should have been set by res_init() in this case. */
|
/* errno should have been set by res_init() in this case. */
|
||||||
return (-1);
|
return (-1);
|
||||||
}
|
}
|
||||||
DprintQ((_res.options & RES_DEBUG) || (_res.pfcode & RES_PRF_QUERY),
|
DprintQ((_resolver_configuration.options & RES_DEBUG) || (_resolver_configuration.pfcode & RES_PRF_QUERY),
|
||||||
(stdout, ";; res_send()\n"), buf, buflen);
|
(stdout, ";; res_send()\n"), buf, buflen);
|
||||||
v_circuit = (_res.options & RES_USEVC) || buflen > PACKETSZ;
|
v_circuit = (_resolver_configuration.options & RES_USEVC) || buflen > PACKETSZ;
|
||||||
gotsomewhere = 0;
|
gotsomewhere = 0;
|
||||||
connreset = 0;
|
connreset = 0;
|
||||||
terrno = ETIMEDOUT;
|
terrno = ETIMEDOUT;
|
||||||
@ -353,8 +353,8 @@ res_send(buf, buflen, ans, anssiz)
|
|||||||
/*
|
/*
|
||||||
* Send request, RETRY times, or until successful
|
* Send request, RETRY times, or until successful
|
||||||
*/
|
*/
|
||||||
for (try = 0; try < _res.retry; try++) {
|
for (try = 0; try < _resolver_configuration.retry; try++) {
|
||||||
for (ns = 0; ns < _res.nscount; ns++) {
|
for (ns = 0; ns < _resolver_configuration.nscount; ns++) {
|
||||||
struct sockaddr *nsap = get_nsaddr(ns);
|
struct sockaddr *nsap = get_nsaddr(ns);
|
||||||
uint32 salen;
|
uint32 salen;
|
||||||
|
|
||||||
@ -406,7 +406,7 @@ res_send(buf, buflen, ans, anssiz)
|
|||||||
} while (!done);
|
} while (!done);
|
||||||
}
|
}
|
||||||
|
|
||||||
Dprint((_res.options & RES_DEBUG) &&
|
Dprint((_resolver_configuration.options & RES_DEBUG) &&
|
||||||
getnameinfo(nsap, salen, abuf, sizeof(abuf),
|
getnameinfo(nsap, salen, abuf, sizeof(abuf),
|
||||||
NULL, 0, NI_NUMERICHOST | NI_WITHSCOPEID) == 0,
|
NULL, 0, NI_NUMERICHOST | NI_WITHSCOPEID) == 0,
|
||||||
(stdout, ";; Querying server (# %d) address = %s\n",
|
(stdout, ";; Querying server (# %d) address = %s\n",
|
||||||
@ -422,7 +422,7 @@ res_send(buf, buflen, ans, anssiz)
|
|||||||
* Use virtual circuit;
|
* Use virtual circuit;
|
||||||
* at most one attempt per server.
|
* at most one attempt per server.
|
||||||
*/
|
*/
|
||||||
try = _res.retry;
|
try = _resolver_configuration.retry;
|
||||||
truncated = 0;
|
truncated = 0;
|
||||||
if ((s < 0) || (!vc) || (af != nsap->sa_family)) {
|
if ((s < 0) || (!vc) || (af != nsap->sa_family)) {
|
||||||
if (s >= 0)
|
if (s >= 0)
|
||||||
@ -501,7 +501,7 @@ read_len:
|
|||||||
}
|
}
|
||||||
resplen = _getshort(ans);
|
resplen = _getshort(ans);
|
||||||
if (resplen > anssiz) {
|
if (resplen > anssiz) {
|
||||||
Dprint(_res.options & RES_DEBUG,
|
Dprint(_resolver_configuration.options & RES_DEBUG,
|
||||||
(stdout, ";; response truncated\n")
|
(stdout, ";; response truncated\n")
|
||||||
);
|
);
|
||||||
truncated = 1;
|
truncated = 1;
|
||||||
@ -547,8 +547,8 @@ read_len:
|
|||||||
* wait for the correct one.
|
* wait for the correct one.
|
||||||
*/
|
*/
|
||||||
if (hp->id != anhp->id) {
|
if (hp->id != anhp->id) {
|
||||||
DprintQ((_res.options & RES_DEBUG) ||
|
DprintQ((_resolver_configuration.options & RES_DEBUG) ||
|
||||||
(_res.pfcode & RES_PRF_REPLY),
|
(_resolver_configuration.pfcode & RES_PRF_REPLY),
|
||||||
(stdout, ";; old answer (unexpected):\n"),
|
(stdout, ";; old answer (unexpected):\n"),
|
||||||
ans, (resplen>anssiz)?anssiz:resplen);
|
ans, (resplen>anssiz)?anssiz:resplen);
|
||||||
goto read_len;
|
goto read_len;
|
||||||
@ -606,8 +606,8 @@ read_len:
|
|||||||
* as we wish to receive answers from the first
|
* as we wish to receive answers from the first
|
||||||
* server to respond.
|
* server to respond.
|
||||||
*/
|
*/
|
||||||
if (!(_res.options & RES_INSECURE1) &&
|
if (!(_resolver_configuration.options & RES_INSECURE1) &&
|
||||||
(_res.nscount == 1 || (try == 0 && ns == 0))) {
|
(_resolver_configuration.nscount == 1 || (try == 0 && ns == 0))) {
|
||||||
/*
|
/*
|
||||||
* Connect only if we are sure we won't
|
* Connect only if we are sure we won't
|
||||||
* receive a response from another server.
|
* receive a response from another server.
|
||||||
@ -654,7 +654,7 @@ read_len:
|
|||||||
goto bad_dg_sock;
|
goto bad_dg_sock;
|
||||||
(void) dup2(s1, s);
|
(void) dup2(s1, s);
|
||||||
(void) close(s1);
|
(void) close(s1);
|
||||||
Dprint(_res.options & RES_DEBUG,
|
Dprint(_resolver_configuration.options & RES_DEBUG,
|
||||||
(stdout, ";; new DG socket\n"))
|
(stdout, ";; new DG socket\n"))
|
||||||
#endif
|
#endif
|
||||||
#ifdef IPV6_MINMTU
|
#ifdef IPV6_MINMTU
|
||||||
@ -680,9 +680,9 @@ read_len:
|
|||||||
/*
|
/*
|
||||||
* Wait for reply
|
* Wait for reply
|
||||||
*/
|
*/
|
||||||
timeout.tv_sec = (_res.retrans << try);
|
timeout.tv_sec = (_resolver_configuration.retrans << try);
|
||||||
if (try > 0)
|
if (try > 0)
|
||||||
timeout.tv_sec /= _res.nscount;
|
timeout.tv_sec /= _resolver_configuration.nscount;
|
||||||
if ((long) timeout.tv_sec <= 0)
|
if ((long) timeout.tv_sec <= 0)
|
||||||
timeout.tv_sec = 1;
|
timeout.tv_sec = 1;
|
||||||
timeout.tv_usec = 0;
|
timeout.tv_usec = 0;
|
||||||
@ -708,7 +708,7 @@ read_len:
|
|||||||
/*
|
/*
|
||||||
* timeout
|
* timeout
|
||||||
*/
|
*/
|
||||||
Dprint(_res.options & RES_DEBUG,
|
Dprint(_resolver_configuration.options & RES_DEBUG,
|
||||||
(stdout, ";; timeout\n"));
|
(stdout, ";; timeout\n"));
|
||||||
gotsomewhere = 1;
|
gotsomewhere = 1;
|
||||||
res_close();
|
res_close();
|
||||||
@ -731,8 +731,8 @@ read_len:
|
|||||||
* XXX - potential security hazard could
|
* XXX - potential security hazard could
|
||||||
* be detected here.
|
* be detected here.
|
||||||
*/
|
*/
|
||||||
DprintQ((_res.options & RES_DEBUG) ||
|
DprintQ((_resolver_configuration.options & RES_DEBUG) ||
|
||||||
(_res.pfcode & RES_PRF_REPLY),
|
(_resolver_configuration.pfcode & RES_PRF_REPLY),
|
||||||
(stdout, ";; old answer:\n"),
|
(stdout, ";; old answer:\n"),
|
||||||
ans, (resplen>anssiz)?anssiz:resplen);
|
ans, (resplen>anssiz)?anssiz:resplen);
|
||||||
goto wait;
|
goto wait;
|
||||||
@ -744,22 +744,22 @@ read_len:
|
|||||||
* Can other people remove the comment and see if this works for them?
|
* Can other people remove the comment and see if this works for them?
|
||||||
*/
|
*/
|
||||||
#if 0//CHECK_SRVR_ADDR
|
#if 0//CHECK_SRVR_ADDR
|
||||||
if (!(_res.options & RES_INSECURE1) &&
|
if (!(_resolver_configuration.options & RES_INSECURE1) &&
|
||||||
!res_isourserver((struct sockaddr_in *)&from)) {
|
!res_isourserver((struct sockaddr_in *)&from)) {
|
||||||
/*
|
/*
|
||||||
* response from wrong server? ignore it.
|
* response from wrong server? ignore it.
|
||||||
* XXX - potential security hazard could
|
* XXX - potential security hazard could
|
||||||
* be detected here.
|
* be detected here.
|
||||||
*/
|
*/
|
||||||
DprintQ((_res.options & RES_DEBUG) ||
|
DprintQ((_resolver_configuration.options & RES_DEBUG) ||
|
||||||
(_res.pfcode & RES_PRF_REPLY),
|
(_resolver_configuration.pfcode & RES_PRF_REPLY),
|
||||||
(stdout, ";; not our server:\n"),
|
(stdout, ";; not our server:\n"),
|
||||||
ans, (resplen>anssiz)?anssiz:resplen);
|
ans, (resplen>anssiz)?anssiz:resplen);
|
||||||
|
|
||||||
goto wait;
|
goto wait;
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
if (!(_res.options & RES_INSECURE2) &&
|
if (!(_resolver_configuration.options & RES_INSECURE2) &&
|
||||||
!res_queriesmatch(buf, buf + buflen,
|
!res_queriesmatch(buf, buf + buflen,
|
||||||
ans, ans + anssiz)) {
|
ans, ans + anssiz)) {
|
||||||
/*
|
/*
|
||||||
@ -767,8 +767,8 @@ read_len:
|
|||||||
* XXX - potential security hazard could
|
* XXX - potential security hazard could
|
||||||
* be detected here.
|
* be detected here.
|
||||||
*/
|
*/
|
||||||
DprintQ((_res.options & RES_DEBUG) ||
|
DprintQ((_resolver_configuration.options & RES_DEBUG) ||
|
||||||
(_res.pfcode & RES_PRF_REPLY),
|
(_resolver_configuration.pfcode & RES_PRF_REPLY),
|
||||||
(stdout, ";; wrong query name:\n"),
|
(stdout, ";; wrong query name:\n"),
|
||||||
ans, (resplen>anssiz)?anssiz:resplen);
|
ans, (resplen>anssiz)?anssiz:resplen);
|
||||||
goto wait;
|
goto wait;
|
||||||
@ -777,33 +777,33 @@ read_len:
|
|||||||
if (anhp->rcode == SERVFAIL ||
|
if (anhp->rcode == SERVFAIL ||
|
||||||
anhp->rcode == NOTIMP ||
|
anhp->rcode == NOTIMP ||
|
||||||
anhp->rcode == REFUSED) {
|
anhp->rcode == REFUSED) {
|
||||||
DprintQ(_res.options & RES_DEBUG,
|
DprintQ(_resolver_configuration.options & RES_DEBUG,
|
||||||
(stdout, "server rejected query:\n"),
|
(stdout, "server rejected query:\n"),
|
||||||
ans, (resplen>anssiz)?anssiz:resplen);
|
ans, (resplen>anssiz)?anssiz:resplen);
|
||||||
badns |= (1 << ns);
|
badns |= (1 << ns);
|
||||||
res_close();
|
res_close();
|
||||||
/* don't retry if called from dig */
|
/* don't retry if called from dig */
|
||||||
if (!_res.pfcode)
|
if (!_resolver_configuration.pfcode)
|
||||||
goto next_ns;
|
goto next_ns;
|
||||||
}
|
}
|
||||||
if (!(_res.options & RES_IGNTC) && anhp->tc) {
|
if (!(_resolver_configuration.options & RES_IGNTC) && anhp->tc) {
|
||||||
/*
|
/*
|
||||||
* get rest of answer;
|
* get rest of answer;
|
||||||
* use TCP with same server.
|
* use TCP with same server.
|
||||||
*/
|
*/
|
||||||
Dprint(_res.options & RES_DEBUG,
|
Dprint(_resolver_configuration.options & RES_DEBUG,
|
||||||
(stdout, ";; truncated answer\n"));
|
(stdout, ";; truncated answer\n"));
|
||||||
v_circuit = 1;
|
v_circuit = 1;
|
||||||
res_close();
|
res_close();
|
||||||
goto same_ns;
|
goto same_ns;
|
||||||
}
|
}
|
||||||
} /*if vc/dg*/
|
} /*if vc/dg*/
|
||||||
Dprint((_res.options & RES_DEBUG) ||
|
Dprint((_resolver_configuration.options & RES_DEBUG) ||
|
||||||
((_res.pfcode & RES_PRF_REPLY) &&
|
((_resolver_configuration.pfcode & RES_PRF_REPLY) &&
|
||||||
(_res.pfcode & RES_PRF_HEAD1)),
|
(_resolver_configuration.pfcode & RES_PRF_HEAD1)),
|
||||||
(stdout, ";; got answer:\n"));
|
(stdout, ";; got answer:\n"));
|
||||||
DprintQ((_res.options & RES_DEBUG) ||
|
DprintQ((_resolver_configuration.options & RES_DEBUG) ||
|
||||||
(_res.pfcode & RES_PRF_REPLY),
|
(_resolver_configuration.pfcode & RES_PRF_REPLY),
|
||||||
(stdout, "%s", ""),
|
(stdout, "%s", ""),
|
||||||
ans, (resplen>anssiz)?anssiz:resplen);
|
ans, (resplen>anssiz)?anssiz:resplen);
|
||||||
/*
|
/*
|
||||||
@ -814,8 +814,8 @@ read_len:
|
|||||||
* or if we haven't been asked to keep a socket open,
|
* or if we haven't been asked to keep a socket open,
|
||||||
* close the socket.
|
* close the socket.
|
||||||
*/
|
*/
|
||||||
if ((v_circuit && (!(_res.options & RES_USEVC) || ns != 0)) ||
|
if ((v_circuit && (!(_resolver_configuration.options & RES_USEVC) || ns != 0)) ||
|
||||||
!(_res.options & RES_STAYOPEN)) {
|
!(_resolver_configuration.options & RES_STAYOPEN)) {
|
||||||
res_close();
|
res_close();
|
||||||
}
|
}
|
||||||
if (Rhook) {
|
if (Rhook) {
|
||||||
|
@ -42,15 +42,15 @@ sethostent(stayopen)
|
|||||||
int stayopen;
|
int stayopen;
|
||||||
{
|
{
|
||||||
|
|
||||||
if ((_res.options & RES_INIT) == 0 && res_init() == -1)
|
if ((_resolver_configuration.options & RES_INIT) == 0 && res_init() == -1)
|
||||||
return;
|
return;
|
||||||
if (stayopen)
|
if (stayopen)
|
||||||
_res.options |= RES_STAYOPEN | RES_USEVC;
|
_resolver_configuration.options |= RES_STAYOPEN | RES_USEVC;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
endhostent()
|
endhostent()
|
||||||
{
|
{
|
||||||
_res.options &= ~(RES_STAYOPEN | RES_USEVC);
|
_resolver_configuration.options &= ~(RES_STAYOPEN | RES_USEVC);
|
||||||
res_close();
|
res_close();
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user