1
0
mirror of https://github.com/rofl0r/proxychains-ng synced 2025-01-24 10:12:55 +08:00

bug fixes

This commit is contained in:
hugoc 2023-09-11 13:22:16 +02:00
parent 8348e42608
commit 68180a6b66
2 changed files with 17 additions and 8 deletions

View File

@ -544,7 +544,7 @@ either of them. */
if(len != read_n_bytes(sock, (char *) buff, len)) if(len != read_n_bytes(sock, (char *) buff, len))
goto err; goto err;
memcpy(bnd_addr->addr.v6, buff+4,(len==16)?16:4); memcpy(bnd_addr->addr.v6, buff,(len==16)?16:4);
if(2 != read_n_bytes(sock, (char *) buff, 2)) if(2 != read_n_bytes(sock, (char *) buff, 2))
goto err; goto err;
@ -653,13 +653,13 @@ int send_udp_packet(int sockfd, udp_relay_chain chain, ip_type target_ip, unsign
len = 6; len = 6;
break; break;
case ATYP_DOM: case ATYP_DOM:
len = (tmp->next)->bnd_addr.addr.dom.len; len = (tmp->next)->bnd_addr.addr.dom.len + 1;
break; break;
default: default:
break; break;
} }
headers_size += len; headers_size += len + 6;
tmp = tmp->next; tmp = tmp->next;
} }
@ -672,13 +672,13 @@ int send_udp_packet(int sockfd, udp_relay_chain chain, ip_type target_ip, unsign
len = 6; len = 6;
break; break;
case ATYP_DOM: case ATYP_DOM:
len = target_addr.addr.dom.len; len = target_addr.addr.dom.len + 1;
break; break;
default: default:
break; break;
} }
headers_size += len; headers_size += len + 6;
char * buff = NULL; char * buff = NULL;
if (NULL == (buff = (char*)malloc(headers_size+data_len))){ if (NULL == (buff = (char*)malloc(headers_size+data_len))){
@ -735,7 +735,15 @@ int send_udp_packet(int sockfd, udp_relay_chain chain, ip_type target_ip, unsign
}; };
if(v6) memcpy(&addr6.sin6_addr.s6_addr, chain.head->bnd_addr.addr.v6, 16); if(v6) memcpy(&addr6.sin6_addr.s6_addr, chain.head->bnd_addr.addr.v6, 16);
sendto(sockfd, buff, offset+data_len, 0, (struct sockaddr *) (v6?(void*)&addr6:(void*)&addr), v6?sizeof(addr6):sizeof(addr) ); int sent = 0;
sent = true_sendto(sockfd, buff, offset+data_len, 0, (struct sockaddr *) (v6?(void*)&addr6:(void*)&addr), v6?sizeof(addr6):sizeof(addr) );
if (sent != offset+data_len){
PDEBUG("true_sendto error\n");
goto err;
}
return SUCCESS;
err: err:
free(buff); free(buff);
@ -1221,10 +1229,10 @@ udp_relay_chain * open_relay_chain(proxy_data *pd, unsigned int proxy_count, cha
while((p1 = select_proxy(FIFOLY, pd, proxy_count, &offset))) { while((p1 = select_proxy(FIFOLY, pd, proxy_count, &offset))) {
if(SUCCESS != add_node_to_chain(p1, new_chain)) { if(SUCCESS != add_node_to_chain(p1, new_chain)) {
PDEBUG("add_node_to_chain failed\n"); PDEBUG("add_node_to_chain failed\n");
p1->pt = BLOCKED_STATE; p1->ps = BLOCKED_STATE;
goto error; goto error;
} }
p1->pt = BUSY_STATE; p1->ps = BUSY_STATE;
} }
return new_chain; return new_chain;

View File

@ -177,6 +177,7 @@ extern getaddrinfo_t true_getaddrinfo;
extern freeaddrinfo_t true_freeaddrinfo; extern freeaddrinfo_t true_freeaddrinfo;
extern getnameinfo_t true_getnameinfo; extern getnameinfo_t true_getnameinfo;
extern gethostbyaddr_t true_gethostbyaddr; extern gethostbyaddr_t true_gethostbyaddr;
extern sendto_t true_sendto;
struct gethostbyname_data { struct gethostbyname_data {
struct hostent hostent_space; struct hostent hostent_space;