Added kill packets.

There should be no more delay between a peer closing their client
and their friend being notified of them going offline. (unless the
kill packet is lost)
This commit is contained in:
irungentoo 2014-05-11 18:27:23 -04:00
parent ff4368add7
commit 1580a5c696
No known key found for this signature in database
GPG Key ID: 10349DC9BED89E98
3 changed files with 30 additions and 0 deletions

View File

@ -100,6 +100,7 @@ lossy][data]
data ids: data ids:
0: padding (skipped until we hit a non zero (data id) byte) 0: padding (skipped until we hit a non zero (data id) byte)
1: packet request packet (lossy packet) 1: packet request packet (lossy packet)
2: connection kill packet (lossy packet) (tells the other that the connection is over)
... ...
16+: reserved for Messenger usage (lossless packets). 16+: reserved for Messenger usage (lossless packets).

View File

@ -918,6 +918,23 @@ static int create_send_handshake(Net_Crypto *c, int crypt_connection_id, uint8_t
return 0; return 0;
} }
/* Send a kill packet.
*
* return -1 on failure.
* return 0 on success.
*/
static int send_kill_packet(Net_Crypto *c, int crypt_connection_id)
{
Crypto_Connection *conn = get_crypto_connection(c, crypt_connection_id);
if (conn == 0)
return -1;
uint8_t kill_packet = PACKET_ID_KILL;
return send_data_packet_helper(c, crypt_connection_id, conn->recv_array.buffer_start, conn->send_array.buffer_end,
&kill_packet, sizeof(kill_packet));
}
/* Handle a recieved data packet. /* Handle a recieved data packet.
* *
* return -1 on failure. * return -1 on failure.
@ -969,6 +986,9 @@ static int handle_data_packet_helper(Net_Crypto *c, int crypt_connection_id, uin
} }
set_buffer_end(&conn->recv_array, num); set_buffer_end(&conn->recv_array, num);
} else if (real_data[0] == PACKET_ID_KILL) {
conn->killed = 1;
return 0;
} else { } else {
Packet_Data dt; Packet_Data dt;
dt.time = current_time_monotonic(); dt.time = current_time_monotonic();
@ -1627,6 +1647,7 @@ int64_t write_cryptpacket(Net_Crypto *c, int crypt_connection_id, uint8_t *data,
int crypto_kill(Net_Crypto *c, int crypt_connection_id) int crypto_kill(Net_Crypto *c, int crypt_connection_id)
{ {
//TODO //TODO
send_kill_packet(c, crypt_connection_id);
return wipe_crypto_connection(c, crypt_connection_id); return wipe_crypto_connection(c, crypt_connection_id);
} }
@ -1713,6 +1734,11 @@ static void kill_timedout(Net_Crypto *c)
if (conn->temp_packet_num_sent < MAX_NUM_SENDPACKET_TRIES) if (conn->temp_packet_num_sent < MAX_NUM_SENDPACKET_TRIES)
continue; continue;
conn->killed = 1;
}
if (conn->killed) {
if (conn->connection_status_callback) { if (conn->connection_status_callback) {
conn->connection_status_callback(conn->connection_status_callback_object, conn->connection_status_callback_id, 0); conn->connection_status_callback(conn->connection_status_callback_object, conn->connection_status_callback_id, 0);
crypto_kill(c, i); crypto_kill(c, i);

View File

@ -56,6 +56,7 @@
#define PACKET_ID_PADDING 0 #define PACKET_ID_PADDING 0
#define PACKET_ID_REQUEST 1 #define PACKET_ID_REQUEST 1
#define PACKET_ID_KILL 2
#define CRYPTO_RESERVED_PACKETS 16 #define CRYPTO_RESERVED_PACKETS 16
@ -119,6 +120,8 @@ typedef struct {
uint64_t last_packets_left_set; uint64_t last_packets_left_set;
uint8_t sending; /* indicates if data is being sent or not. */ uint8_t sending; /* indicates if data is being sent or not. */
uint8_t killed; /* set to 1 to kill the connection. */
} Crypto_Connection; } Crypto_Connection;
typedef struct { typedef struct {