2021-03-04 11:30:38 +00:00
|
|
|
#pragma once
|
|
|
|
|
2023-10-26 12:12:32 +00:00
|
|
|
#include "pools.h"
|
2021-03-18 14:21:25 +00:00
|
|
|
#include "conntrack.h"
|
2021-03-04 11:30:38 +00:00
|
|
|
#include "desync.h"
|
2024-06-18 14:39:06 +00:00
|
|
|
#include "protocol.h"
|
2021-03-04 11:30:38 +00:00
|
|
|
|
|
|
|
#include <sys/param.h>
|
|
|
|
#include <sys/types.h>
|
2022-05-15 12:54:35 +00:00
|
|
|
#include <net/if.h>
|
2021-03-04 11:30:38 +00:00
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include <stdio.h>
|
2024-03-23 19:57:05 +00:00
|
|
|
#include <time.h>
|
2021-03-04 11:30:38 +00:00
|
|
|
|
2023-11-15 16:36:34 +00:00
|
|
|
#define TLS_PARTIALS_ENABLE true
|
|
|
|
|
2021-03-04 11:30:38 +00:00
|
|
|
#define Q_RCVBUF (128*1024) // in bytes
|
|
|
|
#define Q_SNDBUF (64*1024) // in bytes
|
|
|
|
#define RAW_SNDBUF (64*1024) // in bytes
|
|
|
|
|
|
|
|
#define Q_MAXLEN 1024 // in packets
|
|
|
|
|
2021-12-26 14:11:21 +00:00
|
|
|
#define BADSEQ_INCREMENT_DEFAULT -10000
|
2021-12-28 09:50:04 +00:00
|
|
|
#define BADSEQ_ACK_INCREMENT_DEFAULT -66000
|
2021-12-26 14:11:21 +00:00
|
|
|
|
2022-01-03 09:38:18 +00:00
|
|
|
#define IPFRAG_UDP_DEFAULT 8
|
|
|
|
#define IPFRAG_TCP_DEFAULT 32
|
|
|
|
|
2022-04-12 12:52:06 +00:00
|
|
|
#define UDPLEN_INCREMENT_DEFAULT 2
|
|
|
|
|
2024-03-02 14:53:37 +00:00
|
|
|
#define HOSTLIST_AUTO_FAIL_THRESHOLD_DEFAULT 3
|
2023-10-26 12:12:32 +00:00
|
|
|
#define HOSTLIST_AUTO_FAIL_TIME_DEFAULT 60
|
|
|
|
#define HOSTLIST_AUTO_RETRANS_THRESHOLD_DEFAULT 3
|
|
|
|
|
2024-08-23 11:42:21 +00:00
|
|
|
enum log_target { LOG_TARGET_CONSOLE=0, LOG_TARGET_FILE, LOG_TARGET_SYSLOG };
|
|
|
|
|
2021-03-04 11:30:38 +00:00
|
|
|
struct params_s
|
|
|
|
{
|
2024-08-23 11:42:21 +00:00
|
|
|
enum log_target debug_target;
|
|
|
|
char debug_logfile[PATH_MAX];
|
2021-03-04 11:30:38 +00:00
|
|
|
bool debug;
|
2024-08-23 11:42:21 +00:00
|
|
|
|
2021-03-12 11:33:48 +00:00
|
|
|
uint16_t wsize,wssize;
|
|
|
|
uint8_t wscale,wsscale;
|
2021-12-27 13:51:30 +00:00
|
|
|
char wssize_cutoff_mode; // n - packets, d - data packets, s - relative sequence
|
2021-03-18 14:21:25 +00:00
|
|
|
unsigned int wssize_cutoff;
|
2021-03-04 11:30:38 +00:00
|
|
|
#ifdef __linux__
|
|
|
|
int qnum;
|
|
|
|
#elif defined(BSD)
|
|
|
|
uint16_t port; // divert port
|
|
|
|
#endif
|
2022-05-15 12:54:35 +00:00
|
|
|
char bind_fix4,bind_fix6;
|
2021-03-04 11:30:38 +00:00
|
|
|
bool hostcase, hostnospace, domcase;
|
|
|
|
char hostspell[4];
|
2021-04-07 09:13:46 +00:00
|
|
|
enum dpi_desync_mode desync_mode0,desync_mode,desync_mode2;
|
2021-03-04 11:30:38 +00:00
|
|
|
bool desync_retrans,desync_skip_nosni,desync_any_proto;
|
2024-06-24 13:51:06 +00:00
|
|
|
unsigned int desync_repeats,desync_split_pos,desync_seqovl,desync_ipfrag_pos_tcp,desync_ipfrag_pos_udp;
|
2024-06-18 14:39:06 +00:00
|
|
|
enum httpreqpos desync_split_http_req;
|
|
|
|
enum tlspos desync_split_tls;
|
2024-04-13 08:13:11 +00:00
|
|
|
char desync_start_mode, desync_cutoff_mode; // n - packets, d - data packets, s - relative sequence
|
|
|
|
unsigned int desync_start, desync_cutoff;
|
2021-12-10 19:08:52 +00:00
|
|
|
uint8_t desync_ttl, desync_ttl6;
|
2024-03-02 14:53:37 +00:00
|
|
|
autottl desync_autottl, desync_autottl6;
|
|
|
|
uint32_t desync_fooling_mode;
|
2021-03-04 11:30:38 +00:00
|
|
|
uint32_t desync_fwmark; // unused in BSD
|
2021-12-26 14:11:21 +00:00
|
|
|
uint32_t desync_badseq_increment, desync_badseq_ack_increment;
|
2024-06-24 13:51:06 +00:00
|
|
|
uint8_t fake_http[1460],fake_tls[1460],fake_unknown[1460],fake_syndata[1460],seqovl_pattern[1460];
|
2024-03-19 10:50:20 +00:00
|
|
|
uint8_t fake_unknown_udp[1472],udplen_pattern[1472],fake_quic[1472],fake_wg[1472],fake_dht[1472];
|
|
|
|
size_t fake_http_size,fake_tls_size,fake_quic_size,fake_wg_size,fake_dht_size,fake_unknown_size,fake_syndata_size,fake_unknown_udp_size;
|
2022-07-27 09:00:36 +00:00
|
|
|
int udplen_increment;
|
2024-04-26 18:36:27 +00:00
|
|
|
|
2024-06-19 16:46:16 +00:00
|
|
|
#ifdef __CYGWIN__
|
2024-07-12 12:13:18 +00:00
|
|
|
struct str_list_head ssid_filter,nlm_filter;
|
2024-06-19 16:46:16 +00:00
|
|
|
#else
|
2021-03-04 11:30:38 +00:00
|
|
|
bool droproot;
|
|
|
|
uid_t uid;
|
|
|
|
gid_t gid;
|
2024-04-26 18:36:27 +00:00
|
|
|
#endif
|
2021-03-18 14:21:25 +00:00
|
|
|
|
2022-07-26 16:15:28 +00:00
|
|
|
strpool *hostlist, *hostlist_exclude;
|
|
|
|
struct str_list_head hostlist_files, hostlist_exclude_files;
|
2023-11-09 09:08:09 +00:00
|
|
|
char hostlist_auto_filename[PATH_MAX], hostlist_auto_debuglog[PATH_MAX];
|
2023-10-26 12:12:32 +00:00
|
|
|
int hostlist_auto_fail_threshold, hostlist_auto_fail_time, hostlist_auto_retrans_threshold;
|
2024-03-23 19:57:05 +00:00
|
|
|
time_t hostlist_auto_mod_time;
|
2023-10-26 12:12:32 +00:00
|
|
|
hostfail_pool *hostlist_auto_fail_counters;
|
2022-07-26 16:15:28 +00:00
|
|
|
|
2022-01-01 17:22:04 +00:00
|
|
|
unsigned int ctrack_t_syn, ctrack_t_est, ctrack_t_fin, ctrack_t_udp;
|
2021-03-18 14:21:25 +00:00
|
|
|
t_conntrack conntrack;
|
2021-03-04 11:30:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
extern struct params_s params;
|
2024-08-23 11:42:21 +00:00
|
|
|
extern const char *progname;
|
2021-03-04 11:30:38 +00:00
|
|
|
|
2024-08-23 11:42:21 +00:00
|
|
|
int DLOG(const char *format, ...);
|
|
|
|
int DLOG_ERR(const char *format, ...);
|
|
|
|
int DLOG_PERROR(const char *s);
|
|
|
|
int DLOG_CONDUP(const char *format, ...);
|
|
|
|
int HOSTLIST_DEBUGLOG_APPEND(const char *format, ...);
|