mirror of
https://github.com/irungentoo/toxcore.git
synced 2024-03-22 13:30:51 +08:00
Merge branch 'master' of https://github.com/irungentoo/ProjectTox-Core
This commit is contained in:
commit
7dd63b45ca
|
@ -202,15 +202,16 @@ int new_connection(IP_Port ip_port)
|
||||||
for (i = 0; i < MAX_CONNECTIONS; ++i) {
|
for (i = 0; i < MAX_CONNECTIONS; ++i) {
|
||||||
if(connections[i].status == 0) {
|
if(connections[i].status == 0) {
|
||||||
memset(&connections[i], 0, sizeof(Connection));
|
memset(&connections[i], 0, sizeof(Connection));
|
||||||
|
uint32_t handshake_id1 = handshake_id(ip_port);
|
||||||
|
|
||||||
connections[i] = (Connection) {
|
connections[i] = (Connection) {
|
||||||
.ip_port = ip_port,
|
.ip_port = ip_port,
|
||||||
.status = 1,
|
.status = 1,
|
||||||
.inbound = 0,
|
.inbound = 0,
|
||||||
.handshake_id1 = handshake_id(ip_port),
|
.handshake_id1 = handshake_id1,
|
||||||
.sent_packetnum = connections[i].handshake_id1,
|
.sent_packetnum = handshake_id1,
|
||||||
.sendbuff_packetnum = connections[i].handshake_id1,
|
.sendbuff_packetnum = handshake_id1,
|
||||||
.successful_sent = connections[i].handshake_id1,
|
.successful_sent = handshake_id1,
|
||||||
.SYNC_rate = SYNC_RATE,
|
.SYNC_rate = SYNC_RATE,
|
||||||
.data_rate = DATA_SYNC_RATE,
|
.data_rate = DATA_SYNC_RATE,
|
||||||
.last_recvSYNC = current_time(),
|
.last_recvSYNC = current_time(),
|
||||||
|
@ -254,6 +255,7 @@ int new_inconnection(IP_Port ip_port)
|
||||||
for (i = 0; i < MAX_CONNECTIONS; ++i) {
|
for (i = 0; i < MAX_CONNECTIONS; ++i) {
|
||||||
if (connections[i].status == 0) {
|
if (connections[i].status == 0) {
|
||||||
memset(&connections[i], 0, sizeof(Connection));
|
memset(&connections[i], 0, sizeof(Connection));
|
||||||
|
uint64_t timeout = CONNEXION_TIMEOUT + rand() % CONNEXION_TIMEOUT;
|
||||||
|
|
||||||
connections[i] = (Connection){
|
connections[i] = (Connection){
|
||||||
.ip_port = ip_port,
|
.ip_port = ip_port,
|
||||||
|
@ -266,10 +268,10 @@ int new_inconnection(IP_Port ip_port)
|
||||||
.send_counter = 127,
|
.send_counter = 127,
|
||||||
|
|
||||||
/* add randomness to timeout to prevent connections getting stuck in a loop. */
|
/* add randomness to timeout to prevent connections getting stuck in a loop. */
|
||||||
.timeout = CONNEXION_TIMEOUT + rand() % CONNEXION_TIMEOUT,
|
.timeout = timeout,
|
||||||
|
|
||||||
/* if this connection isn't handled within the timeout kill it. */
|
/* if this connection isn't handled within the timeout kill it. */
|
||||||
.killat = current_time() + 1000000UL*connections[i].timeout
|
.killat = current_time() + 1000000UL*timeout
|
||||||
};
|
};
|
||||||
++connections_number;
|
++connections_number;
|
||||||
return i;
|
return i;
|
||||||
|
|
|
@ -66,11 +66,11 @@ static int incoming_connections[MAX_INCOMING];
|
||||||
int encrypt_data(uint8_t *public_key, uint8_t *secret_key, uint8_t *nonce,
|
int encrypt_data(uint8_t *public_key, uint8_t *secret_key, uint8_t *nonce,
|
||||||
uint8_t *plain, uint32_t length, uint8_t *encrypted)
|
uint8_t *plain, uint32_t length, uint8_t *encrypted)
|
||||||
{
|
{
|
||||||
if (length - crypto_box_BOXZEROBYTES + crypto_box_ZEROBYTES > MAX_DATA_SIZE || length == 0)
|
if (length + crypto_box_MACBYTES > MAX_DATA_SIZE || length == 0)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
uint8_t temp_plain[MAX_DATA_SIZE + crypto_box_ZEROBYTES - crypto_box_BOXZEROBYTES] = {0};
|
uint8_t temp_plain[MAX_DATA_SIZE + crypto_box_BOXZEROBYTES] = {0};
|
||||||
uint8_t temp_encrypted[MAX_DATA_SIZE + crypto_box_ZEROBYTES];
|
uint8_t temp_encrypted[MAX_DATA_SIZE + crypto_box_BOXZEROBYTES];
|
||||||
|
|
||||||
memcpy(temp_plain + crypto_box_ZEROBYTES, plain, length); /* pad the message with 32 0 bytes. */
|
memcpy(temp_plain + crypto_box_ZEROBYTES, plain, length); /* pad the message with 32 0 bytes. */
|
||||||
|
|
||||||
|
@ -87,7 +87,7 @@ int encrypt_data(uint8_t *public_key, uint8_t *secret_key, uint8_t *nonce,
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
/* unpad the encrypted message */
|
/* unpad the encrypted message */
|
||||||
memcpy(encrypted, temp_encrypted + crypto_box_BOXZEROBYTES, length - crypto_box_BOXZEROBYTES + crypto_box_ZEROBYTES);
|
memcpy(encrypted, temp_encrypted + crypto_box_BOXZEROBYTES, length + crypto_box_MACBYTES);
|
||||||
return length - crypto_box_BOXZEROBYTES + crypto_box_ZEROBYTES;
|
return length - crypto_box_BOXZEROBYTES + crypto_box_ZEROBYTES;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,8 +101,8 @@ int decrypt_data(uint8_t *public_key, uint8_t *secret_key, uint8_t *nonce,
|
||||||
if (length > MAX_DATA_SIZE || length <= crypto_box_BOXZEROBYTES)
|
if (length > MAX_DATA_SIZE || length <= crypto_box_BOXZEROBYTES)
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
uint8_t temp_plain[MAX_DATA_SIZE - crypto_box_ZEROBYTES + crypto_box_BOXZEROBYTES];
|
uint8_t temp_plain[MAX_DATA_SIZE + crypto_box_BOXZEROBYTES];
|
||||||
uint8_t temp_encrypted[MAX_DATA_SIZE + crypto_box_ZEROBYTES] = {0};
|
uint8_t temp_encrypted[MAX_DATA_SIZE + crypto_box_BOXZEROBYTES] = {0};
|
||||||
|
|
||||||
memcpy(temp_encrypted + crypto_box_BOXZEROBYTES, encrypted, length); /* pad the message with 16 0 bytes. */
|
memcpy(temp_encrypted + crypto_box_BOXZEROBYTES, encrypted, length); /* pad the message with 16 0 bytes. */
|
||||||
|
|
||||||
|
@ -121,7 +121,7 @@ int decrypt_data(uint8_t *public_key, uint8_t *secret_key, uint8_t *nonce,
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
/* unpad the plain message */
|
/* unpad the plain message */
|
||||||
memcpy(plain, temp_plain + crypto_box_ZEROBYTES, length - crypto_box_ZEROBYTES + crypto_box_BOXZEROBYTES);
|
memcpy(plain, temp_plain + crypto_box_ZEROBYTES, length - crypto_box_MACBYTES);
|
||||||
return length - crypto_box_ZEROBYTES + crypto_box_BOXZEROBYTES;
|
return length - crypto_box_ZEROBYTES + crypto_box_BOXZEROBYTES;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -44,13 +44,37 @@ int x, y;
|
||||||
uint8_t pending_requests[256][CLIENT_ID_SIZE];
|
uint8_t pending_requests[256][CLIENT_ID_SIZE];
|
||||||
uint8_t num_requests = 0;
|
uint8_t num_requests = 0;
|
||||||
|
|
||||||
|
void get_id(char *data)
|
||||||
|
{
|
||||||
|
char idstring0[200];
|
||||||
|
char idstring1[PUB_KEY_BYTES][5];
|
||||||
|
char idstring2[PUB_KEY_BYTES][5];
|
||||||
|
int i = 0;
|
||||||
|
for(i = 0; i < PUB_KEY_BYTES; i++)
|
||||||
|
{
|
||||||
|
if (self_public_key[i] < (PUB_KEY_BYTES / 2))
|
||||||
|
strcpy(idstring1[i],"0");
|
||||||
|
else
|
||||||
|
strcpy(idstring1[i], "");
|
||||||
|
sprintf(idstring2[i], "%hhX",self_public_key[i]);
|
||||||
|
}
|
||||||
|
strcpy(idstring0,"[i] ID: ");
|
||||||
|
int j = 0;
|
||||||
|
for (j = 0; j < PUB_KEY_BYTES; j++) {
|
||||||
|
strcat(idstring0,idstring1[j]);
|
||||||
|
strcat(idstring0,idstring2[j]);
|
||||||
|
}
|
||||||
|
|
||||||
|
memcpy(data, idstring0, strlen(idstring0));
|
||||||
|
}
|
||||||
|
|
||||||
void new_lines(char *line)
|
void new_lines(char *line)
|
||||||
{
|
{
|
||||||
int i;
|
int i = 0;
|
||||||
for (i = HISTORY-1; i > 0; i--)
|
for (i = HISTORY-1; i > 0; i--)
|
||||||
strcpy(lines[i], lines[i-1]);
|
strncpy(lines[i], lines[i-1], STRING_LENGTH - 1);
|
||||||
|
|
||||||
strcpy(lines[0], line);
|
strncpy(lines[0], line, STRING_LENGTH - 1);
|
||||||
do_refresh();
|
do_refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -216,26 +240,9 @@ void line_eval(char lines[HISTORY][STRING_LENGTH], char *line)
|
||||||
new_lines("[i] /l list (list friends), /h for help, /i for info, /n nick (to change nickname), /q (to quit)");
|
new_lines("[i] /l list (list friends), /h for help, /i for info, /n nick (to change nickname), /q (to quit)");
|
||||||
}
|
}
|
||||||
else if (inpt_command == 'i') { //info
|
else if (inpt_command == 'i') { //info
|
||||||
char idstring0[200];
|
char idstring[200];
|
||||||
char idstring1[PUB_KEY_BYTES][5];
|
get_id(idstring);
|
||||||
char idstring2[PUB_KEY_BYTES][5];
|
new_lines(idstring);
|
||||||
int i;
|
|
||||||
for (i = 0; i < PUB_KEY_BYTES; i++)
|
|
||||||
{
|
|
||||||
if (self_public_key[i] < (PUB_KEY_BYTES/2))
|
|
||||||
strcpy(idstring1[i],"0");
|
|
||||||
else
|
|
||||||
strcpy(idstring1[i], "");
|
|
||||||
sprintf(idstring2[i], "%hhX", self_public_key[i]);
|
|
||||||
}
|
|
||||||
//
|
|
||||||
strcpy(idstring0,"[i] ID: ");
|
|
||||||
int j;
|
|
||||||
for (j = 0; j < PUB_KEY_BYTES; j++) {
|
|
||||||
strcat(idstring0,idstring1[j]);
|
|
||||||
strcat(idstring0,idstring2[j]);
|
|
||||||
}
|
|
||||||
new_lines(idstring0);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
else if (inpt_command == 'q') { //exit
|
else if (inpt_command == 'q') { //exit
|
||||||
|
@ -396,29 +403,14 @@ int main(int argc, char *argv[])
|
||||||
m_callback_friendmessage(print_message);
|
m_callback_friendmessage(print_message);
|
||||||
m_callback_namechange(print_nickchange);
|
m_callback_namechange(print_nickchange);
|
||||||
m_callback_userstatus(print_statuschange);
|
m_callback_userstatus(print_statuschange);
|
||||||
char idstring0[200];
|
|
||||||
char idstring1[PUB_KEY_BYTES][5];
|
char idstring[200];
|
||||||
char idstring2[PUB_KEY_BYTES][5];
|
get_id(idstring);
|
||||||
int i;
|
|
||||||
for(i = 0; i < PUB_KEY_BYTES; i++)
|
|
||||||
{
|
|
||||||
if (self_public_key[i] < (PUB_KEY_BYTES / 2))
|
|
||||||
strcpy(idstring1[i],"0");
|
|
||||||
else
|
|
||||||
strcpy(idstring1[i], "");
|
|
||||||
sprintf(idstring2[i], "%hhX",self_public_key[i]);
|
|
||||||
}
|
|
||||||
strcpy(idstring0,"[i] your ID: ");
|
|
||||||
int j;
|
|
||||||
for (j = 0; j < PUB_KEY_BYTES; j++) {
|
|
||||||
strcat(idstring0,idstring1[j]);
|
|
||||||
strcat(idstring0,idstring2[j]);
|
|
||||||
}
|
|
||||||
initscr();
|
initscr();
|
||||||
noecho();
|
noecho();
|
||||||
raw();
|
raw();
|
||||||
getmaxyx(stdscr, y, x);
|
getmaxyx(stdscr, y, x);
|
||||||
new_lines(idstring0);
|
new_lines(idstring);
|
||||||
new_lines(help);
|
new_lines(help);
|
||||||
strcpy(line, "");
|
strcpy(line, "");
|
||||||
IP_Port bootstrap_ip_port;
|
IP_Port bootstrap_ip_port;
|
||||||
|
|
Loading…
Reference in New Issue
Block a user