Use ping_array to store onion announce information instead of sending

over a huge cookie.

This reduces the size of the onion announce packets by 100 bytes.
This commit is contained in:
irungentoo 2014-05-12 14:39:12 -04:00
parent 10da970e0d
commit 8783bea25e
No known key found for this signature in database
GPG Key ID: 10349DC9BED89E98
5 changed files with 34 additions and 34 deletions

View File

@ -50,14 +50,14 @@
* return 0 on success. * return 0 on success.
*/ */
int send_announce_request(Networking_Core *net, Onion_Path *path, Node_format dest, uint8_t *public_key, int send_announce_request(Networking_Core *net, Onion_Path *path, Node_format dest, uint8_t *public_key,
uint8_t *secret_key, uint8_t *ping_id, uint8_t *client_id, uint8_t *data_public_key, uint8_t *sendback_data) uint8_t *secret_key, uint8_t *ping_id, uint8_t *client_id, uint8_t *data_public_key, uint64_t sendback_data)
{ {
uint8_t plain[ONION_PING_ID_SIZE + crypto_box_PUBLICKEYBYTES + crypto_box_PUBLICKEYBYTES + ONION_ANNOUNCE_SENDBACK_DATA_LENGTH]; uint8_t plain[ONION_PING_ID_SIZE + crypto_box_PUBLICKEYBYTES + crypto_box_PUBLICKEYBYTES + ONION_ANNOUNCE_SENDBACK_DATA_LENGTH];
memcpy(plain, ping_id, ONION_PING_ID_SIZE); memcpy(plain, ping_id, ONION_PING_ID_SIZE);
memcpy(plain + ONION_PING_ID_SIZE, client_id, crypto_box_PUBLICKEYBYTES); memcpy(plain + ONION_PING_ID_SIZE, client_id, crypto_box_PUBLICKEYBYTES);
memcpy(plain + ONION_PING_ID_SIZE + crypto_box_PUBLICKEYBYTES, data_public_key, crypto_box_PUBLICKEYBYTES); memcpy(plain + ONION_PING_ID_SIZE + crypto_box_PUBLICKEYBYTES, data_public_key, crypto_box_PUBLICKEYBYTES);
memcpy(plain + ONION_PING_ID_SIZE + crypto_box_PUBLICKEYBYTES + crypto_box_PUBLICKEYBYTES, sendback_data, memcpy(plain + ONION_PING_ID_SIZE + crypto_box_PUBLICKEYBYTES + crypto_box_PUBLICKEYBYTES, &sendback_data,
ONION_ANNOUNCE_SENDBACK_DATA_LENGTH); sizeof(sendback_data));
uint8_t packet[ANNOUNCE_REQUEST_SIZE]; uint8_t packet[ANNOUNCE_REQUEST_SIZE];
packet[0] = NET_PACKET_ANNOUNCE_REQUEST; packet[0] = NET_PACKET_ANNOUNCE_REQUEST;
random_nonce(packet + 1); random_nonce(packet + 1);

View File

@ -29,7 +29,7 @@
#define ONION_ANNOUNCE_TIMEOUT 300 #define ONION_ANNOUNCE_TIMEOUT 300
#define ONION_PING_ID_SIZE crypto_hash_sha256_BYTES #define ONION_PING_ID_SIZE crypto_hash_sha256_BYTES
#define ONION_ANNOUNCE_SENDBACK_DATA_LENGTH (crypto_box_NONCEBYTES + sizeof(uint32_t) + sizeof(uint64_t) + crypto_box_PUBLICKEYBYTES + sizeof(IP_Port) + crypto_box_MACBYTES) #define ONION_ANNOUNCE_SENDBACK_DATA_LENGTH (sizeof(uint64_t))
#define ONION_ANNOUNCE_RESPONSE_MIN_SIZE (1 + ONION_ANNOUNCE_SENDBACK_DATA_LENGTH + crypto_box_NONCEBYTES + 1 + ONION_PING_ID_SIZE + crypto_box_MACBYTES) #define ONION_ANNOUNCE_RESPONSE_MIN_SIZE (1 + ONION_ANNOUNCE_SENDBACK_DATA_LENGTH + crypto_box_NONCEBYTES + 1 + ONION_PING_ID_SIZE + crypto_box_MACBYTES)
#define ONION_ANNOUNCE_RESPONSE_MAX_SIZE (ONION_ANNOUNCE_RESPONSE_MIN_SIZE + sizeof(Node_format)*MAX_SENT_NODES) #define ONION_ANNOUNCE_RESPONSE_MAX_SIZE (ONION_ANNOUNCE_RESPONSE_MIN_SIZE + sizeof(Node_format)*MAX_SENT_NODES)
@ -76,7 +76,7 @@ typedef struct {
* return 0 on success. * return 0 on success.
*/ */
int send_announce_request(Networking_Core *net, Onion_Path *path, Node_format dest, uint8_t *public_key, int send_announce_request(Networking_Core *net, Onion_Path *path, Node_format dest, uint8_t *public_key,
uint8_t *secret_key, uint8_t *ping_id, uint8_t *client_id, uint8_t *data_public_key, uint8_t *sendback_data); uint8_t *secret_key, uint8_t *ping_id, uint8_t *client_id, uint8_t *data_public_key, uint64_t sendback_data);
/* Create and send an onion data request packet. /* Create and send an onion data request packet.
* *

View File

@ -28,6 +28,9 @@
#include "util.h" #include "util.h"
#include "LAN_discovery.h" #include "LAN_discovery.h"
/* defines for the array size and
timeout for onion announce packets. */
#define ANNOUNCE_ARRAY_SIZE 256
#define ANNOUNCE_TIMEOUT 10 #define ANNOUNCE_TIMEOUT 10
/* Create a new path or use an old suitable one (if pathnum is valid) /* Create a new path or use an old suitable one (if pathnum is valid)
@ -105,20 +108,15 @@ static uint32_t set_path_timeouts(Onion_Client *onion_c, uint32_t num, IP_Port s
* return 0 on success * return 0 on success
* *
*/ */
static int new_sendback(Onion_Client *onion_c, uint32_t num, uint8_t *public_key, IP_Port ip_port, uint8_t *sendback) static int new_sendback(Onion_Client *onion_c, uint32_t num, uint8_t *public_key, IP_Port ip_port, uint64_t *sendback)
{ {
uint8_t plain[sizeof(uint32_t) + sizeof(uint64_t) + crypto_box_PUBLICKEYBYTES + sizeof(IP_Port)]; uint8_t data[sizeof(uint32_t) + crypto_box_PUBLICKEYBYTES + sizeof(IP_Port)];
uint64_t time = unix_time(); memcpy(data, &num, sizeof(uint32_t));
random_nonce(sendback); memcpy(data + sizeof(uint32_t), public_key, crypto_box_PUBLICKEYBYTES);
memcpy(plain, &num, sizeof(uint32_t)); memcpy(data + sizeof(uint32_t) + crypto_box_PUBLICKEYBYTES, &ip_port, sizeof(IP_Port));
memcpy(plain + sizeof(uint32_t), &time, sizeof(uint64_t)); *sendback = ping_array_add(&onion_c->announce_ping_array, data, sizeof(data));
memcpy(plain + sizeof(uint32_t) + sizeof(uint64_t), public_key, crypto_box_PUBLICKEYBYTES);
memcpy(plain + sizeof(uint32_t) + sizeof(uint64_t) + crypto_box_PUBLICKEYBYTES, &ip_port, sizeof(IP_Port));
int len = encrypt_data_symmetric(onion_c->secret_symmetric_key, sendback, plain, sizeof(plain), if (*sendback == 0)
sendback + crypto_box_NONCEBYTES);
if ((uint32_t)len + crypto_box_NONCEBYTES != ONION_ANNOUNCE_SENDBACK_DATA_LENGTH)
return -1; return -1;
return 0; return 0;
@ -136,24 +134,17 @@ static int new_sendback(Onion_Client *onion_c, uint32_t num, uint8_t *public_key
*/ */
static uint32_t check_sendback(Onion_Client *onion_c, uint8_t *sendback, uint8_t *ret_pubkey, IP_Port *ret_ip_port) static uint32_t check_sendback(Onion_Client *onion_c, uint8_t *sendback, uint8_t *ret_pubkey, IP_Port *ret_ip_port)
{ {
uint8_t plain[sizeof(uint32_t) + sizeof(uint64_t) + crypto_box_PUBLICKEYBYTES + sizeof(IP_Port)]; uint64_t sback;
int len = decrypt_data_symmetric(onion_c->secret_symmetric_key, sendback, sendback + crypto_box_NONCEBYTES, memcpy(&sback, sendback, sizeof(uint64_t));
ONION_ANNOUNCE_SENDBACK_DATA_LENGTH - crypto_box_NONCEBYTES, plain); uint8_t data[sizeof(uint32_t) + crypto_box_PUBLICKEYBYTES + sizeof(IP_Port)];
if ((uint32_t)len != sizeof(plain)) if (ping_array_check(data, sizeof(data), &onion_c->announce_ping_array, sback) != sizeof(data))
return ~0; return ~0;
uint64_t timestamp; memcpy(ret_pubkey, data + sizeof(uint32_t), crypto_box_PUBLICKEYBYTES);
memcpy(&timestamp, plain + sizeof(uint32_t), sizeof(uint64_t)); memcpy(ret_ip_port, data + sizeof(uint32_t) + crypto_box_PUBLICKEYBYTES, sizeof(IP_Port));
uint64_t temp_time = unix_time();
if (timestamp + ANNOUNCE_TIMEOUT < temp_time || temp_time < timestamp)
return ~0;
memcpy(ret_pubkey, plain + sizeof(uint32_t) + sizeof(uint64_t), crypto_box_PUBLICKEYBYTES);
memcpy(ret_ip_port, plain + sizeof(uint32_t) + sizeof(uint64_t) + crypto_box_PUBLICKEYBYTES, sizeof(IP_Port));
uint32_t num; uint32_t num;
memcpy(&num, plain, sizeof(uint32_t)); memcpy(&num, data, sizeof(uint32_t));
return num; return num;
} }
@ -163,9 +154,9 @@ static int client_send_announce_request(Onion_Client *onion_c, uint32_t num, IP_
if (num > onion_c->num_friends) if (num > onion_c->num_friends)
return -1; return -1;
uint8_t sendback[ONION_ANNOUNCE_SENDBACK_DATA_LENGTH]; uint64_t sendback;
if (new_sendback(onion_c, num, dest_pubkey, dest, sendback) == -1) if (new_sendback(onion_c, num, dest_pubkey, dest, &sendback) == -1)
return -1; return -1;
uint8_t zero_ping_id[ONION_PING_ID_SIZE] = {0}; uint8_t zero_ping_id[ONION_PING_ID_SIZE] = {0};
@ -1010,6 +1001,11 @@ Onion_Client *new_onion_client(Net_Crypto *c)
if (onion_c == NULL) if (onion_c == NULL)
return NULL; return NULL;
if (ping_array_init(&onion_c->announce_ping_array, ANNOUNCE_ARRAY_SIZE, ANNOUNCE_TIMEOUT) != 0) {
free(onion_c);
return NULL;
}
onion_c->dht = c->dht; onion_c->dht = c->dht;
onion_c->net = c->dht->net; onion_c->net = c->dht->net;
onion_c->c = c; onion_c->c = c;
@ -1028,6 +1024,7 @@ void kill_onion_client(Onion_Client *onion_c)
if (onion_c == NULL) if (onion_c == NULL)
return; return;
ping_array_free_all(&onion_c->announce_ping_array);
realloc_onion_friends(onion_c, 0); realloc_onion_friends(onion_c, 0);
networking_registerhandler(onion_c->net, NET_PACKET_ANNOUNCE_RESPONSE, NULL, NULL); networking_registerhandler(onion_c->net, NET_PACKET_ANNOUNCE_RESPONSE, NULL, NULL);
networking_registerhandler(onion_c->net, NET_PACKET_ONION_DATA_RESPONSE, NULL, NULL); networking_registerhandler(onion_c->net, NET_PACKET_ONION_DATA_RESPONSE, NULL, NULL);

View File

@ -26,6 +26,7 @@
#include "onion_announce.h" #include "onion_announce.h"
#include "net_crypto.h" #include "net_crypto.h"
#include "ping_array.h"
#define MAX_ONION_CLIENTS 8 #define MAX_ONION_CLIENTS 8
#define ONION_NODE_PING_INTERVAL 30 #define ONION_NODE_PING_INTERVAL 30
@ -124,6 +125,8 @@ typedef struct {
uint32_t ping_nodes_sent_second; uint32_t ping_nodes_sent_second;
Last_Pinged last_pinged[MAX_STORED_PINGED_NODES]; Last_Pinged last_pinged[MAX_STORED_PINGED_NODES];
Ping_Array announce_ping_array;
uint8_t last_pinged_index; uint8_t last_pinged_index;
struct { struct {
oniondata_handler_callback function; oniondata_handler_callback function;