Cleaned up and fixed various things.

This commit is contained in:
irungentoo 2013-12-08 19:48:18 -05:00
parent 48c50b5cef
commit d5092e7cf8
2 changed files with 64 additions and 69 deletions

View File

@ -661,17 +661,28 @@ int addto_lists(DHT *dht, IP_Port ip_port, uint8_t *client_id)
used++; used++;
} }
if (dht->assoc) {
IPPTs ippts;
ippts.ip_port = ip_port;
ippts.timestamp = unix_time();
Assoc_add_entry(dht->assoc, client_id, &ippts, NULL, used ? 1 : 0);
}
return used; return used;
} }
/* If client_id is a friend or us, update ret_ip_port /* If client_id is a friend or us, update ret_ip_port
* nodeclient_id is the id of the node that sent us this info. * nodeclient_id is the id of the node that sent us this info.
*/ */
static int returnedip_ports(DHT *dht, IP_Port ip_port, uint8_t *client_id, uint8_t *nodeclient_id) static int returnedip_ports(DHT *dht, IP_Port ip_port, uint8_t *client_id, uint8_t *nodeclient_id, IP_Port source)
{ {
uint32_t i, j; uint32_t i, j;
uint64_t temp_time = unix_time(); uint64_t temp_time = unix_time();
uint32_t used = 0;
/* convert IPv4-in-IPv6 to IPv4 */ /* convert IPv4-in-IPv6 to IPv4 */
if ((ip_port.ip.family == AF_INET6) && IN6_IS_ADDR_V4MAPPED(&ip_port.ip.ip6.in6_addr)) { if ((ip_port.ip.family == AF_INET6) && IN6_IS_ADDR_V4MAPPED(&ip_port.ip.ip6.in6_addr)) {
ip_port.ip.family = AF_INET; ip_port.ip.family = AF_INET;
@ -689,7 +700,8 @@ static int returnedip_ports(DHT *dht, IP_Port ip_port, uint8_t *client_id, uint8
dht->close_clientlist[i].assoc6.ret_timestamp = temp_time; dht->close_clientlist[i].assoc6.ret_timestamp = temp_time;
} }
return 1; ++used;
break;
} }
} }
} else { } else {
@ -705,13 +717,23 @@ static int returnedip_ports(DHT *dht, IP_Port ip_port, uint8_t *client_id, uint8
dht->friends_list[i].client_list[j].assoc6.ret_timestamp = temp_time; dht->friends_list[i].client_list[j].assoc6.ret_timestamp = temp_time;
} }
return 1; ++used;
goto end;
} }
} }
} }
} }
} }
end:
if (dht->assoc) {
IPPTs ippts;
ippts.ip_port = source;
ippts.timestamp = temp_time;
Assoc_add_entry(dht->assoc, nodeclient_id, &ippts, &ip_port, used ? 1 : 0);
}
return 0; return 0;
} }
@ -853,6 +875,7 @@ void to_net_family(IP *ip)
ip->padding[0] = 0; ip->padding[0] = 0;
ip->padding[1] = 0; ip->padding[1] = 0;
ip->padding[2] = 0; ip->padding[2] = 0;
if (ip->family == AF_INET) if (ip->family == AF_INET)
ip->family = TOX_AF_INET; ip->family = TOX_AF_INET;
else if (ip->family == AF_INET6) else if (ip->family == AF_INET6)
@ -889,6 +912,7 @@ static int sendnodes_ipv6(DHT *dht, IP_Port ip_port, uint8_t *public_key, uint8_
new_nonce(nonce); new_nonce(nonce);
uint32_t i; uint32_t i;
for (i = 0; i < num_nodes; ++i) for (i = 0; i < num_nodes; ++i)
to_net_family(&nodes_list[i].ip_port.ip); to_net_family(&nodes_list[i].ip_port.ip);
@ -1016,16 +1040,7 @@ static int handle_sendnodes_core(void *object, IP_Port source, uint8_t *packet,
return 1; return 1;
/* store the address the *request* was sent to */ /* store the address the *request* was sent to */
int used = addto_lists(dht, source, packet + 1); addto_lists(dht, source, packet + 1);
if (dht->assoc) {
IPPTs ippts;
ippts.ip_port = source;
ippts.timestamp = unix_time();
Assoc_add_entry(dht->assoc, packet + 1, &ippts, &source, used ? 1 : 0);
}
*num_nodes_out = num_nodes; *num_nodes_out = num_nodes;
@ -1065,13 +1080,11 @@ static int handle_sendnodes(void *object, IP_Port source, uint8_t *packet, uint3
ippts.ip_port.port = nodes4_list[i].ip_port.port; ippts.ip_port.port = nodes4_list[i].ip_port.port;
send_ping_request(dht->ping, ippts.ip_port, nodes4_list[i].client_id); send_ping_request(dht->ping, ippts.ip_port, nodes4_list[i].client_id);
int used = returnedip_ports(dht, ippts.ip_port, nodes4_list[i].client_id, packet + 1); returnedip_ports(dht, ippts.ip_port, nodes4_list[i].client_id, packet + 1, source);
memcpy(nodes_list[i].client_id, nodes4_list[i].client_id, CLIENT_ID_SIZE); memcpy(nodes_list[i].client_id, nodes4_list[i].client_id, CLIENT_ID_SIZE);
ipport_copy(&nodes_list[i].ip_port, &ippts.ip_port); ipport_copy(&nodes_list[i].ip_port, &ippts.ip_port);
if (dht->assoc)
Assoc_add_entry(dht->assoc, nodes4_list[i].client_id, &ippts, NULL, used ? 1 : 0);
} }
send_hardening_getnode_res(dht, &sendback_node, packet + 1, nodes_list, num_nodes); send_hardening_getnode_res(dht, &sendback_node, packet + 1, nodes_list, num_nodes);
@ -1095,23 +1108,18 @@ static int handle_sendnodes_ipv6(void *object, IP_Port source, uint8_t *packet,
return 0; return 0;
Node_format *nodes_list = (Node_format *)(plain); Node_format *nodes_list = (Node_format *)(plain);
uint64_t time_now = unix_time();
uint32_t i; uint32_t i;
send_hardening_getnode_res(dht, &sendback_node, packet + 1, nodes_list, num_nodes); send_hardening_getnode_res(dht, &sendback_node, packet + 1, nodes_list, num_nodes);
for (i = 0; i < num_nodes; i++) { for (i = 0; i < num_nodes; i++) {
to_host_family(&nodes_list[i].ip_port.ip); to_host_family(&nodes_list[i].ip_port.ip);
if (ipport_isset(&nodes_list[i].ip_port)) { if (ipport_isset(&nodes_list[i].ip_port)) {
send_ping_request(dht->ping, nodes_list[i].ip_port, nodes_list[i].client_id); send_ping_request(dht->ping, nodes_list[i].ip_port, nodes_list[i].client_id);
int used = returnedip_ports(dht, nodes_list[i].ip_port, nodes_list[i].client_id, packet + 1); returnedip_ports(dht, nodes_list[i].ip_port, nodes_list[i].client_id, packet + 1, source);
if (dht->assoc) { }
IPPTs ippts; }
ippts.ip_port = nodes_list[i].ip_port;
ippts.timestamp = time_now;
Assoc_add_entry(dht->assoc, nodes_list[i].client_id, &ippts, NULL, used ? 1 : 0);
}
}
}
return 0; return 0;
} }
@ -1852,39 +1860,7 @@ static int send_hardening_getnode_res(DHT *dht, Node_format *sendto, uint8_t *qu
return sendpacket(dht->c->lossless_udp->net, sendto->ip_port, packet, len); return sendpacket(dht->c->lossless_udp->net, sendto->ip_port, packet, len);
} }
/*
* check how many nodes in nodes are also present in the closelist.
* TODO: make this function better.
*/
static uint32_t have_nodes_closelist(DHT *dht, Node_format *nodes, uint16_t num, sa_family_t sa_family)
{
Node_format nodes_list[MAX_SENT_NODES];
uint32_t num_nodes = get_close_nodes(dht, dht->c->self_public_key, nodes_list, sa_family, 1, 1);
if (num_nodes < num) {
num_nodes = get_close_nodes(dht, dht->c->self_public_key, nodes_list, sa_family, 1, 0);
}
uint32_t counter = 0;
uint32_t i, j;
for (i = 0; i < num; ++i) {
if (id_equal(nodes[i].client_id, dht->c->self_public_key)) {
++counter;
}
for (j = 0; j < num_nodes; ++j) {
if (id_equal(nodes[i].client_id, nodes_list[j].client_id)) {
if (ipport_equal(&nodes[i].ip_port, &nodes_list[j].ip_port)) {
++counter;
break;
}
}
}
}
return counter;
}
/* TODO: improve */ /* TODO: improve */
static IPPTsPng *get_closelist_IPPTsPng(DHT *dht, uint8_t *client_id, sa_family_t sa_family) static IPPTsPng *get_closelist_IPPTsPng(DHT *dht, uint8_t *client_id, sa_family_t sa_family)
{ {
@ -1903,6 +1879,33 @@ static IPPTsPng *get_closelist_IPPTsPng(DHT *dht, uint8_t *client_id, sa_family_
return NULL; return NULL;
} }
/*
* check how many nodes in nodes are also present in the closelist.
* TODO: make this function better.
*/
static uint32_t have_nodes_closelist(DHT *dht, Node_format *nodes, uint16_t num)
{
uint32_t counter = 0;
uint32_t i;
for (i = 0; i < num; ++i) {
if (id_equal(nodes[i].client_id, dht->c->self_public_key)) {
++counter;
continue;
}
IPPTsPng *temp = get_closelist_IPPTsPng(dht, nodes[i].client_id, nodes[i].ip_port.ip.family);
if (temp) {
if (!is_timeout(temp->timestamp, BAD_NODE_TIMEOUT)) {
++counter;
}
}
}
return counter;
}
/* Interval in seconds between hardening checks */ /* Interval in seconds between hardening checks */
#define HARDENING_INTERVAL 5 #define HARDENING_INTERVAL 5
#define HARDEN_TIMEOUT 500 #define HARDEN_TIMEOUT 500
@ -1949,10 +1952,12 @@ static int handle_hardening(void *object, IP_Port source, uint8_t *source_pubkey
Node_format nodes[num]; Node_format nodes[num];
memcpy(nodes, packet + 1 + CLIENT_ID_SIZE, sizeof(Node_format)*num); memcpy(nodes, packet + 1 + CLIENT_ID_SIZE, sizeof(Node_format)*num);
uint32_t i; uint32_t i;
for (i = 0; i < num; ++i) for (i = 0; i < num; ++i)
to_host_family(&nodes[i].ip_port.ip); to_host_family(&nodes[i].ip_port.ip);
/* NOTE: This should work for now but should be changed to something better. */ /* NOTE: This should work for now but should be changed to something better. */
if (have_nodes_closelist(dht, nodes, num, nodes[0].ip_port.ip.family) < (uint32_t)((num + 1) / 2)) if (have_nodes_closelist(dht, nodes, num) < (uint32_t)((num + 2) / 2))
return 1; return 1;

View File

@ -30,7 +30,6 @@
#include <stdint.h> #include <stdint.h>
#include "DHT.h" #include "DHT.h"
#include "assoc.h"
#include "ping.h" #include "ping.h"
#include "network.h" #include "network.h"
@ -260,16 +259,7 @@ static int handle_ping_response(void *_dht, IP_Port source, uint8_t *packet, uin
if (!ping_index) if (!ping_index)
return 1; return 1;
/* Associate client_id with the ip the request was sent to */ addto_lists(dht, source, packet + 1);
int used = addto_lists(dht, ping->pings[ping_index - 1].ip_port, packet + 1);
if (dht->assoc) {
IPPTs ippts;
ippts.ip_port = ping->pings[ping_index - 1].ip_port;
ippts.timestamp = ping->pings[ping_index - 1].timestamp;
Assoc_add_entry(dht->assoc, packet + 1, &ippts, &source, used > 0 ? 1 : 0);
}
return 0; return 0;
} }