diff options
| author | George Hazan <ghazan@miranda.im> | 2022-07-24 16:44:24 +0300 |
|---|---|---|
| committer | George Hazan <ghazan@miranda.im> | 2022-07-24 16:44:24 +0300 |
| commit | e55d071e5485a937efd427d159b76c208cccdcce (patch) | |
| tree | 48d09dc5cf1df2581fd6471b5ccf1560015fa3a4 /protocols/Tox/libtox/src/toxcore/TCP_client.h | |
| parent | f36629f67153bc500c828cf51de31988122a1024 (diff) | |
fixes #3118 (Update toxcore to 0.2.18)
Diffstat (limited to 'protocols/Tox/libtox/src/toxcore/TCP_client.h')
| -rw-r--r-- | protocols/Tox/libtox/src/toxcore/TCP_client.h | 78 |
1 files changed, 55 insertions, 23 deletions
diff --git a/protocols/Tox/libtox/src/toxcore/TCP_client.h b/protocols/Tox/libtox/src/toxcore/TCP_client.h index dd170d7849..fdc91de70d 100644 --- a/protocols/Tox/libtox/src/toxcore/TCP_client.h +++ b/protocols/Tox/libtox/src/toxcore/TCP_client.h @@ -9,6 +9,8 @@ #ifndef C_TOXCORE_TOXCORE_TCP_CLIENT_H #define C_TOXCORE_TOXCORE_TCP_CLIENT_H +#include "crypto_core.h" +#include "forwarding.h" #include "mono_time.h" #include "network.h" @@ -38,84 +40,114 @@ typedef enum TCP_Client_Status { typedef struct TCP_Client_Connection TCP_Client_Connection; +non_null() const uint8_t *tcp_con_public_key(const TCP_Client_Connection *con); +non_null() IP_Port tcp_con_ip_port(const TCP_Client_Connection *con); +non_null() TCP_Client_Status tcp_con_status(const TCP_Client_Connection *con); +non_null() void *tcp_con_custom_object(const TCP_Client_Connection *con); +non_null() uint32_t tcp_con_custom_uint(const TCP_Client_Connection *con); +non_null() void tcp_con_set_custom_object(TCP_Client_Connection *con, void *object); +non_null() void tcp_con_set_custom_uint(TCP_Client_Connection *con, uint32_t value); -/** Create new TCP connection to ip_port/public_key - */ -TCP_Client_Connection *new_TCP_connection(const Logger *logger, const Mono_Time *mono_time, const IP_Port *ip_port, +/** Create new TCP connection to ip_port/public_key */ +non_null(1, 2, 3, 4, 5, 6, 7, 8) nullable(9) +TCP_Client_Connection *new_TCP_connection( + const Logger *logger, const Mono_Time *mono_time, const Random *rng, const Network *ns, const IP_Port *ip_port, const uint8_t *public_key, const uint8_t *self_public_key, const uint8_t *self_secret_key, const TCP_Proxy_Info *proxy_info); -/** Run the TCP connection - */ +/** Run the TCP connection */ +non_null(1, 2, 3) nullable(4) void do_TCP_connection(const Logger *logger, const Mono_Time *mono_time, TCP_Client_Connection *tcp_connection, void *userdata); -/** Kill the TCP connection - */ +/** Kill the TCP connection */ +nullable(1) void kill_TCP_connection(TCP_Client_Connection *tcp_connection); typedef int tcp_onion_response_cb(void *object, const uint8_t *data, uint16_t length, void *userdata); -/** return 1 on success. - * return 0 if could not send packet. - * return -1 on failure (connection must be killed). +/** + * @retval 1 on success. + * @retval 0 if could not send packet. + * @retval -1 on failure (connection must be killed). */ +non_null() int send_onion_request(const Logger *logger, TCP_Client_Connection *con, const uint8_t *data, uint16_t length); +non_null() void onion_response_handler(TCP_Client_Connection *con, tcp_onion_response_cb *onion_callback, void *object); +non_null() +int send_forward_request_tcp(const Logger *logger, TCP_Client_Connection *con, const IP_Port *dest, const uint8_t *data, + uint16_t length); +non_null() +void forwarding_handler(TCP_Client_Connection *con, forwarded_response_cb *forwarded_response_callback, void *object); + typedef int tcp_routing_response_cb(void *object, uint8_t connection_id, const uint8_t *public_key); typedef int tcp_routing_status_cb(void *object, uint32_t number, uint8_t connection_id, uint8_t status); -/** return 1 on success. - * return 0 if could not send packet. - * return -1 on failure (connection must be killed). +/** + * @retval 1 on success. + * @retval 0 if could not send packet. + * @retval -1 on failure (connection must be killed). */ +non_null() int send_routing_request(const Logger *logger, TCP_Client_Connection *con, const uint8_t *public_key); +non_null() void routing_response_handler(TCP_Client_Connection *con, tcp_routing_response_cb *response_callback, void *object); +non_null() void routing_status_handler(TCP_Client_Connection *con, tcp_routing_status_cb *status_callback, void *object); -/** return 1 on success. - * return 0 if could not send packet. - * return -1 on failure (connection must be killed). +/** + * @retval 1 on success. + * @retval 0 if could not send packet. + * @retval -1 on failure (connection must be killed). */ +non_null() int send_disconnect_request(const Logger *logger, TCP_Client_Connection *con, uint8_t con_id); -/** Set the number that will be used as an argument in the callbacks related to con_id. +/** @brief Set the number that will be used as an argument in the callbacks related to con_id. * * When not set by this function, the number is -1. * * return 0 on success. * return -1 on failure. */ +non_null() int set_tcp_connection_number(TCP_Client_Connection *con, uint8_t con_id, uint32_t number); typedef int tcp_routing_data_cb(void *object, uint32_t number, uint8_t connection_id, const uint8_t *data, uint16_t length, void *userdata); -/** return 1 on success. - * return 0 if could not send packet. - * return -1 on failure. +/** + * @retval 1 on success. + * @retval 0 if could not send packet. + * @retval -1 on failure. */ +non_null() int send_data(const Logger *logger, TCP_Client_Connection *con, uint8_t con_id, const uint8_t *data, uint16_t length); +non_null() void routing_data_handler(TCP_Client_Connection *con, tcp_routing_data_cb *data_callback, void *object); typedef int tcp_oob_data_cb(void *object, const uint8_t *public_key, const uint8_t *data, uint16_t length, void *userdata); -/** return 1 on success. - * return 0 if could not send packet. - * return -1 on failure. +/** + * @retval 1 on success. + * @retval 0 if could not send packet. + * @retval -1 on failure. */ +non_null() int send_oob_packet(const Logger *logger, TCP_Client_Connection *con, const uint8_t *public_key, const uint8_t *data, uint16_t length); +non_null() void oob_data_handler(TCP_Client_Connection *con, tcp_oob_data_cb *oob_data_callback, void *object); |
