Erik Kline cleaned up ares_gethostbyaddr.c:next_lookup() somewhat
This commit is contained in:
parent
30eda92a53
commit
a1772ca406
@ -6,6 +6,8 @@
|
|||||||
/dev/urandom when built cross-compiled as then the script cannot check for
|
/dev/urandom when built cross-compiled as then the script cannot check for
|
||||||
it.
|
it.
|
||||||
|
|
||||||
|
- Erik Kline cleaned up ares_gethostbyaddr.c:next_lookup() somewhat
|
||||||
|
|
||||||
Version 1.5.1 (Nov 21, 2007)
|
Version 1.5.1 (Nov 21, 2007)
|
||||||
|
|
||||||
* November 21 2007 (Daniel Stenberg)
|
* November 21 2007 (Daniel Stenberg)
|
||||||
|
@ -58,6 +58,8 @@ static void addr_callback(void *arg, int status, int timeouts,
|
|||||||
static void end_aquery(struct addr_query *aquery, int status,
|
static void end_aquery(struct addr_query *aquery, int status,
|
||||||
struct hostent *host);
|
struct hostent *host);
|
||||||
static int file_lookup(union ares_addr *addr, int family, struct hostent **host);
|
static int file_lookup(union ares_addr *addr, int family, struct hostent **host);
|
||||||
|
static void ptr_rr_name(char *name, size_t len, int family,
|
||||||
|
union ares_addr *addr);
|
||||||
|
|
||||||
void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen,
|
void ares_gethostbyaddr(ares_channel channel, const void *addr, int addrlen,
|
||||||
int family, ares_host_callback callback, void *arg)
|
int family, ares_host_callback callback, void *arg)
|
||||||
@ -101,44 +103,18 @@ static void next_lookup(struct addr_query *aquery)
|
|||||||
{
|
{
|
||||||
const char *p;
|
const char *p;
|
||||||
char name[128];
|
char name[128];
|
||||||
int a1, a2, a3, a4, status;
|
int status;
|
||||||
struct hostent *host;
|
struct hostent *host;
|
||||||
unsigned long addr;
|
|
||||||
|
|
||||||
for (p = aquery->remaining_lookups; *p; p++)
|
for (p = aquery->remaining_lookups; *p; p++)
|
||||||
{
|
{
|
||||||
switch (*p)
|
switch (*p)
|
||||||
{
|
{
|
||||||
case 'b':
|
case 'b':
|
||||||
if (aquery->family == AF_INET)
|
ptr_rr_name(name, sizeof(name), aquery->family, &aquery->addr);
|
||||||
{
|
|
||||||
addr = ntohl(aquery->addr.addr4.s_addr);
|
|
||||||
a1 = (int)((addr >> 24) & 0xff);
|
|
||||||
a2 = (int)((addr >> 16) & 0xff);
|
|
||||||
a3 = (int)((addr >> 8) & 0xff);
|
|
||||||
a4 = (int)(addr & 0xff);
|
|
||||||
sprintf(name, "%d.%d.%d.%d.in-addr.arpa", a4, a3, a2, a1);
|
|
||||||
aquery->remaining_lookups = p + 1;
|
aquery->remaining_lookups = p + 1;
|
||||||
ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback,
|
ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback,
|
||||||
aquery);
|
aquery);
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
unsigned char *bytes;
|
|
||||||
bytes = (unsigned char *)&aquery->addr.addr6.s6_addr;
|
|
||||||
sprintf(name, "%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.ip6.arpa",
|
|
||||||
bytes[15]&0xf, bytes[15] >> 4, bytes[14]&0xf, bytes[14] >> 4,
|
|
||||||
bytes[13]&0xf, bytes[13] >> 4, bytes[12]&0xf, bytes[12] >> 4,
|
|
||||||
bytes[11]&0xf, bytes[11] >> 4, bytes[10]&0xf, bytes[10] >> 4,
|
|
||||||
bytes[9]&0xf, bytes[9] >> 4, bytes[8]&0xf, bytes[8] >> 4,
|
|
||||||
bytes[7]&0xf, bytes[7] >> 4, bytes[6]&0xf, bytes[6] >> 4,
|
|
||||||
bytes[5]&0xf, bytes[5] >> 4, bytes[4]&0xf, bytes[4] >> 4,
|
|
||||||
bytes[3]&0xf, bytes[3] >> 4, bytes[2]&0xf, bytes[2] >> 4,
|
|
||||||
bytes[1]&0xf, bytes[1] >> 4, bytes[0]&0xf, bytes[0] >> 4);
|
|
||||||
aquery->remaining_lookups = p + 1;
|
|
||||||
ares_query(aquery->channel, name, C_IN, T_PTR, addr_callback,
|
|
||||||
aquery);
|
|
||||||
}
|
|
||||||
return;
|
return;
|
||||||
case 'f':
|
case 'f':
|
||||||
status = file_lookup(&aquery->addr, aquery->family, &host);
|
status = file_lookup(&aquery->addr, aquery->family, &host);
|
||||||
@ -268,3 +244,31 @@ static int file_lookup(union ares_addr *addr, int family, struct hostent **host)
|
|||||||
*host = NULL;
|
*host = NULL;
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void ptr_rr_name(char *name, size_t len, int family,
|
||||||
|
union ares_addr *addr) {
|
||||||
|
if (family == AF_INET)
|
||||||
|
{
|
||||||
|
in_addr_t s_addr = ntohl(addr->addr4.s_addr);
|
||||||
|
int a1 = (int)((s_addr >> 24) & 0xff);
|
||||||
|
int a2 = (int)((s_addr >> 16) & 0xff);
|
||||||
|
int a3 = (int)((s_addr >> 8) & 0xff);
|
||||||
|
int a4 = (int)(s_addr & 0xff);
|
||||||
|
snprintf(name, len, "%d.%d.%d.%d.in-addr.arpa", a4, a3, a2, a1);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
unsigned char *bytes = (unsigned char *)&addr->addr6.s6_addr;
|
||||||
|
snprintf(name, len,
|
||||||
|
"%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x."
|
||||||
|
"%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.%x.ip6.arpa",
|
||||||
|
bytes[15]&0xf, bytes[15] >> 4, bytes[14]&0xf, bytes[14] >> 4,
|
||||||
|
bytes[13]&0xf, bytes[13] >> 4, bytes[12]&0xf, bytes[12] >> 4,
|
||||||
|
bytes[11]&0xf, bytes[11] >> 4, bytes[10]&0xf, bytes[10] >> 4,
|
||||||
|
bytes[9]&0xf, bytes[9] >> 4, bytes[8]&0xf, bytes[8] >> 4,
|
||||||
|
bytes[7]&0xf, bytes[7] >> 4, bytes[6]&0xf, bytes[6] >> 4,
|
||||||
|
bytes[5]&0xf, bytes[5] >> 4, bytes[4]&0xf, bytes[4] >> 4,
|
||||||
|
bytes[3]&0xf, bytes[3] >> 4, bytes[2]&0xf, bytes[2] >> 4,
|
||||||
|
bytes[1]&0xf, bytes[1] >> 4, bytes[0]&0xf, bytes[0] >> 4);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user