Fixed bug where hole punching was attempted even though the

clients were connected.

Increased the number of ports tried per interval of time.

Also astyled the files.
This commit is contained in:
irungentoo 2013-09-25 10:07:07 -04:00
parent 83c665f2c4
commit 3c78aefce0
2 changed files with 19 additions and 12 deletions

View File

@ -51,7 +51,7 @@
/* Ping interval in seconds for each random sending of a get nodes request. */ /* Ping interval in seconds for each random sending of a get nodes request. */
#define GET_NODE_INTERVAL 10 #define GET_NODE_INTERVAL 10
#define MAX_PUNCHING_PORTS 32 #define MAX_PUNCHING_PORTS 128
/* Interval in seconds between punching attempts*/ /* Interval in seconds between punching attempts*/
#define PUNCH_INTERVAL 10 #define PUNCH_INTERVAL 10
@ -137,11 +137,12 @@ static int client_or_ip_port_in_list(Client_data *list, uint32_t length, uint8_t
uint64_t temp_time = unix_time(); uint64_t temp_time = unix_time();
uint8_t candropipv4 = 1; uint8_t candropipv4 = 1;
if (ip_port.ip.family == AF_INET6) { if (ip_port.ip.family == AF_INET6) {
uint8_t ipv6cnt = 0; uint8_t ipv6cnt = 0;
/* ipv6: count how many spots are used */ /* ipv6: count how many spots are used */
for(i = 0; i < length; i++) for (i = 0; i < length; i++)
if (list[i].ip_port.ip.family == AF_INET6) if (list[i].ip_port.ip.family == AF_INET6)
ipv6cnt++; ipv6cnt++;
@ -318,11 +319,12 @@ static int replace_bad( Client_data *list,
uint64_t temp_time = unix_time(); uint64_t temp_time = unix_time();
uint8_t candropipv4 = 1; uint8_t candropipv4 = 1;
if (ip_port.ip.family == AF_INET6) { if (ip_port.ip.family == AF_INET6) {
uint32_t ipv6cnt = 0; uint32_t ipv6cnt = 0;
/* ipv6: count how many spots are used */ /* ipv6: count how many spots are used */
for(i = 0; i < length; i++) for (i = 0; i < length; i++)
if (list[i].ip_port.ip.family == AF_INET6) if (list[i].ip_port.ip.family == AF_INET6)
ipv6cnt++; ipv6cnt++;
@ -334,8 +336,9 @@ static int replace_bad( Client_data *list,
for (i = 0; i < length; ++i) { for (i = 0; i < length; ++i) {
/* If node is bad */ /* If node is bad */
Client_data *client = &list[i]; Client_data *client = &list[i];
if ((candropipv4 || (client->ip_port.ip.family == AF_INET6)) && if ((candropipv4 || (client->ip_port.ip.family == AF_INET6)) &&
is_timeout(temp_time, client->timestamp, BAD_NODE_TIMEOUT)) { is_timeout(temp_time, client->timestamp, BAD_NODE_TIMEOUT)) {
memcpy(client->client_id, client_id, CLIENT_ID_SIZE); memcpy(client->client_id, client_id, CLIENT_ID_SIZE);
client->ip_port = ip_port; client->ip_port = ip_port;
client->timestamp = temp_time; client->timestamp = temp_time;
@ -381,11 +384,12 @@ static int replace_good( Client_data *list,
sort_list(list, length, comp_client_id); sort_list(list, length, comp_client_id);
uint8_t candropipv4 = 1; uint8_t candropipv4 = 1;
if (ip_port.ip.family == AF_INET6) { if (ip_port.ip.family == AF_INET6) {
uint32_t i, ipv6cnt = 0; uint32_t i, ipv6cnt = 0;
/* ipv6: count how many spots are used */ /* ipv6: count how many spots are used */
for(i = 0; i < length; i++) for (i = 0; i < length; i++)
if (list[i].ip_port.ip.family == AF_INET6) if (list[i].ip_port.ip.family == AF_INET6)
ipv6cnt++; ipv6cnt++;
@ -419,6 +423,7 @@ static int replace_good( Client_data *list,
*/ */
for (i = 0; i < length; i++) { for (i = 0; i < length; i++) {
Client_data *client = &list[i]; Client_data *client = &list[i];
if (client->ip_port.ip.family == AF_INET6) { if (client->ip_port.ip.family == AF_INET6) {
if (id_closest(comp_client_id, list[i].client_id, client_id) == 2) if (id_closest(comp_client_id, list[i].client_id, client_id) == 2)
replace = i; replace = i;
@ -1138,14 +1143,13 @@ static int friend_iplist(DHT *dht, IP_Port *ip_portlist, uint16_t friend_num)
Client_data *client; Client_data *client;
for (i = 0; i < MAX_FRIEND_CLIENTS; ++i) { for (i = 0; i < MAX_FRIEND_CLIENTS; ++i) {
client = &friend->client_list[i]; client = &(friend->client_list[i]);
if (id_equal(client->client_id, friend->client_id) && !is_timeout(temp_time, client->timestamp, BAD_NODE_TIMEOUT))
return 0;
/* If ip is not zero and node is good. */ /* If ip is not zero and node is good. */
if (ip_isset(&client->ret_ip_port.ip) && !is_timeout(temp_time, client->ret_timestamp, BAD_NODE_TIMEOUT)) { if (ip_isset(&client->ret_ip_port.ip) && !is_timeout(temp_time, client->ret_timestamp, BAD_NODE_TIMEOUT)) {
if (id_equal(client->client_id, friend->client_id))
return 0;
ip_portlist[num_ips] = client->ret_ip_port; ip_portlist[num_ips] = client->ret_ip_port;
++num_ips; ++num_ips;
} }

View File

@ -15,7 +15,7 @@
#include "net_crypto.h" #include "net_crypto.h"
#include "DHT.h" #include "DHT.h"
#define PING_NUM_MAX 256 #define PING_NUM_MAX 384
#define PING_TIMEOUT 5 // 5s #define PING_TIMEOUT 5 // 5s
/* Ping newly announced nodes to ping per TIME_TOPING seconds*/ /* Ping newly announced nodes to ping per TIME_TOPING seconds*/
@ -180,6 +180,7 @@ static int handle_ping_request(void *_dht, IP_Port source, uint8_t *packet, uint
return 1; return 1;
PING *ping = dht->ping; PING *ping = dht->ping;
if (id_eq(packet + 1, ping->c->self_public_key)) if (id_eq(packet + 1, ping->c->self_public_key))
return 1; return 1;
@ -211,6 +212,7 @@ static int handle_ping_response(void *_dht, IP_Port source, uint8_t *packet, uin
return 1; return 1;
PING *ping = dht->ping; PING *ping = dht->ping;
if (id_eq(packet + 1, ping->c->self_public_key)) if (id_eq(packet + 1, ping->c->self_public_key))
return 1; return 1;
@ -303,6 +305,7 @@ void do_toping(PING *ping)
PING *new_ping(DHT *dht, Net_Crypto *c) PING *new_ping(DHT *dht, Net_Crypto *c)
{ {
PING *ping = calloc(1, sizeof(PING)); PING *ping = calloc(1, sizeof(PING));
if (ping == NULL) if (ping == NULL)
return NULL; return NULL;