mirror of
https://github.com/rofl0r/proxychains-ng
synced 2025-01-23 01:12:59 +08:00
improve DNS failure handling with old proxyresolv method
should fix #493
This commit is contained in:
parent
199d03d8b4
commit
66f99b19dd
18
src/core.c
18
src/core.c
@ -824,7 +824,8 @@ struct hostent* proxy_gethostbyname_old(const char *name)
|
|||||||
close(pipe_fd[0]);
|
close(pipe_fd[0]);
|
||||||
got_buff:
|
got_buff:
|
||||||
l = strlen(buff);
|
l = strlen(buff);
|
||||||
if(l && buff[l-1] == '\n') buff[l-1] = 0;
|
if (!l) goto err_dns;
|
||||||
|
if (buff[l-1] == '\n') buff[l-1] = 0;
|
||||||
addr = inet_addr(buff);
|
addr = inet_addr(buff);
|
||||||
if (addr == (in_addr_t) (-1))
|
if (addr == (in_addr_t) (-1))
|
||||||
goto err_dns;
|
goto err_dns;
|
||||||
@ -839,8 +840,7 @@ got_buff:
|
|||||||
name, inet_ntoa(*(struct in_addr*)&addr));
|
name, inet_ntoa(*(struct in_addr*)&addr));
|
||||||
return &hostent_space;
|
return &hostent_space;
|
||||||
err_dns:
|
err_dns:
|
||||||
proxychains_write_log("|DNS-response|: %s does not exist\n", name);
|
proxychains_write_log("|DNS-response|: %s lookup error\n", name);
|
||||||
perror("err_dns");
|
|
||||||
err:
|
err:
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -969,12 +969,13 @@ int proxy_getaddrinfo(const char *node, const char *service, const struct addrin
|
|||||||
node?node:"",service?service:"",hints?(int)hints->ai_flags:0);
|
node?node:"",service?service:"",hints?(int)hints->ai_flags:0);
|
||||||
|
|
||||||
space = calloc(1, sizeof(struct addrinfo_data));
|
space = calloc(1, sizeof(struct addrinfo_data));
|
||||||
if(!space) goto err1;
|
if(!space) return EAI_MEMORY;
|
||||||
|
|
||||||
if(node && !my_inet_aton(node, space)) {
|
if(node && !my_inet_aton(node, space)) {
|
||||||
/* some folks (nmap) use getaddrinfo() with AI_NUMERICHOST to check whether a string
|
/* some folks (nmap) use getaddrinfo() with AI_NUMERICHOST to check whether a string
|
||||||
containing a numeric ip was passed. we must return failure in that case. */
|
containing a numeric ip was passed. we must return failure in that case. */
|
||||||
if(hints && (hints->ai_flags & AI_NUMERICHOST)) {
|
if(hints && (hints->ai_flags & AI_NUMERICHOST)) {
|
||||||
|
err_nn:
|
||||||
free(space);
|
free(space);
|
||||||
return EAI_NONAME;
|
return EAI_NONAME;
|
||||||
}
|
}
|
||||||
@ -987,7 +988,7 @@ int proxy_getaddrinfo(const char *node, const char *service, const struct addrin
|
|||||||
memcpy(&((struct sockaddr_in *) &space->sockaddr_space)->sin_addr,
|
memcpy(&((struct sockaddr_in *) &space->sockaddr_space)->sin_addr,
|
||||||
*(hp->h_addr_list), sizeof(in_addr_t));
|
*(hp->h_addr_list), sizeof(in_addr_t));
|
||||||
else
|
else
|
||||||
goto err2;
|
goto err_nn;
|
||||||
} else if(node) {
|
} else if(node) {
|
||||||
af = ((struct sockaddr_in *) &space->sockaddr_space)->sin_family;
|
af = ((struct sockaddr_in *) &space->sockaddr_space)->sin_family;
|
||||||
} else if(!node && !(hints->ai_flags & AI_PASSIVE)) {
|
} else if(!node && !(hints->ai_flags & AI_PASSIVE)) {
|
||||||
@ -1026,12 +1027,5 @@ int proxy_getaddrinfo(const char *node, const char *service, const struct addrin
|
|||||||
#endif
|
#endif
|
||||||
p->ai_flags = (AI_V4MAPPED | AI_ADDRCONFIG);
|
p->ai_flags = (AI_V4MAPPED | AI_ADDRCONFIG);
|
||||||
}
|
}
|
||||||
|
|
||||||
goto out;
|
|
||||||
err2:
|
|
||||||
free(space);
|
|
||||||
err1:
|
|
||||||
return 1;
|
|
||||||
out:
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user