2023-07-25 11:53:09 +02:00
|
|
|
/* SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
* Copyright © 2016-2018 The TokTok team.
|
|
|
|
* Copyright © 2014 Tox project.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Implementation of the TCP relay client part of Tox.
|
|
|
|
*/
|
|
|
|
#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"
|
|
|
|
|
|
|
|
#define TCP_CONNECTION_TIMEOUT 10
|
|
|
|
|
|
|
|
typedef enum TCP_Proxy_Type {
|
|
|
|
TCP_PROXY_NONE,
|
|
|
|
TCP_PROXY_HTTP,
|
|
|
|
TCP_PROXY_SOCKS5,
|
|
|
|
} TCP_Proxy_Type;
|
|
|
|
|
|
|
|
typedef struct TCP_Proxy_Info {
|
|
|
|
IP_Port ip_port;
|
|
|
|
uint8_t proxy_type; // a value from TCP_PROXY_TYPE
|
|
|
|
} TCP_Proxy_Info;
|
|
|
|
|
|
|
|
typedef enum TCP_Client_Status {
|
|
|
|
TCP_CLIENT_NO_STATUS,
|
|
|
|
TCP_CLIENT_PROXY_HTTP_CONNECTING,
|
|
|
|
TCP_CLIENT_PROXY_SOCKS5_CONNECTING,
|
|
|
|
TCP_CLIENT_PROXY_SOCKS5_UNCONFIRMED,
|
|
|
|
TCP_CLIENT_CONNECTING,
|
|
|
|
TCP_CLIENT_UNCONFIRMED,
|
|
|
|
TCP_CLIENT_CONFIRMED,
|
|
|
|
TCP_CLIENT_DISCONNECTED,
|
|
|
|
} 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 */
|
2023-10-10 19:37:39 +02:00
|
|
|
non_null(1, 2, 3, 4, 5, 6, 7, 8, 9) nullable(10)
|
|
|
|
TCP_Client_Connection *new_tcp_connection(
|
|
|
|
const Logger *logger, const Memory *mem, 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,
|
2023-07-25 11:53:09 +02:00
|
|
|
const TCP_Proxy_Info *proxy_info);
|
|
|
|
|
|
|
|
/** Run the TCP connection */
|
|
|
|
non_null(1, 2, 3) nullable(4)
|
2023-10-10 19:37:39 +02:00
|
|
|
void do_tcp_connection(const Logger *logger, const Mono_Time *mono_time,
|
2023-07-25 11:53:09 +02:00
|
|
|
TCP_Client_Connection *tcp_connection, void *userdata);
|
|
|
|
|
|
|
|
/** Kill the TCP connection */
|
|
|
|
nullable(1)
|
2023-10-10 19:37:39 +02:00
|
|
|
void kill_tcp_connection(TCP_Client_Connection *tcp_connection);
|
2023-07-25 11:53:09 +02:00
|
|
|
|
|
|
|
typedef int tcp_onion_response_cb(void *object, const uint8_t *data, uint16_t length, void *userdata);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
/** @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);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @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);
|
|
|
|
|
|
|
|
|
|
|
|
#endif
|