Allow tune randseq offsets.

May be useful for #94
This commit is contained in:
Vadim Vetrov 2024-08-27 23:23:54 +03:00
parent 3b5276c834
commit 725dc1a6d2
No known key found for this signature in database
GPG Key ID: E8A308689D7A73A5
4 changed files with 25 additions and 5 deletions

View File

@ -157,6 +157,8 @@ Available flags:
- `--faking-ttl=<ttl>` Tunes the time to live (TTL) of fake SNI messages. TTL is specified like that the packet will go through the DPI system and captured by it, but will not reach the destination server. Defaults to **8**. - `--faking-ttl=<ttl>` Tunes the time to live (TTL) of fake SNI messages. TTL is specified like that the packet will go through the DPI system and captured by it, but will not reach the destination server. Defaults to **8**.
- `--fake-seq-offset` Tunes the offset from original sequence number for fake packets. Used by randseq faking strategy. Defaults to 10000. If 0, random sequence number will be set.
- `--frag={tcp,ip,none}` Specifies the fragmentation strategy for the packet. tcp is used by default. Ip fragmentation may be blocked by DPI system. None specifies no fragmentation. Probably this won't work, but may be will work for some fake sni strategies. - `--frag={tcp,ip,none}` Specifies the fragmentation strategy for the packet. tcp is used by default. Ip fragmentation may be blocked by DPI system. None specifies no fragmentation. Probably this won't work, but may be will work for some fake sni strategies.
- `--frag-sni-reverse={0|1}` Specifies **youtubeUnblock** to send *ClientHello* fragments in the reverse order. Defaults to **1**. - `--frag-sni-reverse={0|1}` Specifies **youtubeUnblock** to send *ClientHello* fragments in the reverse order. Defaults to **1**.

14
args.c
View File

@ -21,6 +21,7 @@ struct config_t config = {
.frag_middle_sni = 1, .frag_middle_sni = 1,
.frag_sni_pos = 2, .frag_sni_pos = 2,
.use_ipv6 = 1, .use_ipv6 = 1,
.fakeseq_offset = 10000,
.sni_detection = SNI_DETECTION_PARSE, .sni_detection = SNI_DETECTION_PARSE,
@ -65,13 +66,14 @@ struct config_t config = {
#define OPT_QUIC_DROP 16 #define OPT_QUIC_DROP 16
#define OPT_SNI_DETECTION 17 #define OPT_SNI_DETECTION 17
#define OPT_NO_IPV6 20 #define OPT_NO_IPV6 20
#define OPT_FAKE_SEQ_OFFSET 21
#define OPT_SEG2DELAY 5 #define OPT_SEG2DELAY 5
#define OPT_THREADS 6 #define OPT_THREADS 6
#define OPT_SILENT 7 #define OPT_SILENT 7
#define OPT_NO_GSO 8 #define OPT_NO_GSO 8
#define OPT_QUEUE_NUM 9 #define OPT_QUEUE_NUM 9
#define OPT_MAX OPT_NO_IPV6 #define OPT_MAX OPT_FAKE_SEQ_OFFSET
static struct option long_opt[] = { static struct option long_opt[] = {
{"help", 0, 0, 'h'}, {"help", 0, 0, 'h'},
@ -80,6 +82,7 @@ static struct option long_opt[] = {
{"fake-sni", 1, 0, OPT_FAKE_SNI}, {"fake-sni", 1, 0, OPT_FAKE_SNI},
{"fake-sni-seq-len", 1, 0, OPT_FAKE_SNI_SEQ_LEN}, {"fake-sni-seq-len", 1, 0, OPT_FAKE_SNI_SEQ_LEN},
{"faking-strategy", 1, 0, OPT_FAKING_STRATEGY}, {"faking-strategy", 1, 0, OPT_FAKING_STRATEGY},
{"fake-seq-offset", 1, 0, OPT_FAKE_SEQ_OFFSET},
{"faking-ttl", 1, 0, OPT_FAKING_TTL}, {"faking-ttl", 1, 0, OPT_FAKING_TTL},
{"frag", 1, 0, OPT_FRAG}, {"frag", 1, 0, OPT_FRAG},
{"frag-sni-reverse", 1, 0, OPT_FRAG_SNI_REVERSE}, {"frag-sni-reverse", 1, 0, OPT_FRAG_SNI_REVERSE},
@ -132,6 +135,7 @@ void print_usage(const char *argv0) {
printf("\t--sni-domains=<comma separated domain list>|all\n"); printf("\t--sni-domains=<comma separated domain list>|all\n");
printf("\t--fake-sni={1|0}\n"); printf("\t--fake-sni={1|0}\n");
printf("\t--fake-sni-seq-len=<length>\n"); printf("\t--fake-sni-seq-len=<length>\n");
printf("\t--fake-seq-offset=<offset>\n");
printf("\t--faking-ttl=<ttl>\n"); printf("\t--faking-ttl=<ttl>\n");
printf("\t--faking-strategy={randseq|ttl|tcp_check|pastseq}\n"); printf("\t--faking-strategy={randseq|ttl|tcp_check|pastseq}\n");
printf("\t--frag={tcp,ip,none}\n"); printf("\t--frag={tcp,ip,none}\n");
@ -269,7 +273,14 @@ int parse_args(int argc, char *argv[]) {
config.faking_ttl = num; config.faking_ttl = num;
break; break;
case OPT_FAKE_SEQ_OFFSET:
num = parse_numeric_option(optarg);
if (errno != 0 || num < 0) {
goto invalid_opt;
}
config.fakeseq_offset = num;
break;
case OPT_FAKE_SNI: case OPT_FAKE_SNI:
if (strcmp(optarg, "1") == 0) { if (strcmp(optarg, "1") == 0) {
config.fake_sni = 1; config.fake_sni = 1;
@ -382,6 +393,7 @@ void print_welcome() {
break; break;
case FAKE_STRAT_RAND_SEQ: case FAKE_STRAT_RAND_SEQ:
printf("Random seq faking strategy will be used\n"); printf("Random seq faking strategy will be used\n");
printf("Fake seq offset set to %u\n", config.fakeseq_offset);
break; break;
case FAKE_STRAT_TCP_CHECK: case FAKE_STRAT_TCP_CHECK:
printf("TCP checksum faking strategy will be used\n"); printf("TCP checksum faking strategy will be used\n");

View File

@ -44,6 +44,7 @@ struct config_t {
const char *fake_sni_pkt; const char *fake_sni_pkt;
unsigned int fake_sni_pkt_sz; unsigned int fake_sni_pkt_sz;
unsigned int fk_winsize; unsigned int fk_winsize;
unsigned int fakeseq_offset;
}; };
extern struct config_t config; extern struct config_t config;

View File

@ -822,13 +822,18 @@ int fail_packet(uint8_t *payload, uint32_t plen) {
if (config.faking_strategy == FAKE_STRAT_RAND_SEQ) { if (config.faking_strategy == FAKE_STRAT_RAND_SEQ) {
lgtrace("fake seq: %u -> ", ntohl(tcph->seq)); lgtrace("fake seq: %u -> ", ntohl(tcph->seq));
if (config.fakeseq_offset) {
tcph->seq = htonl(ntohl(tcph->seq) - config.fakeseq_offset);
} else {
#ifdef KERNEL_SCOPE #ifdef KERNEL_SCOPE
tcph->seq = 124; tcph->seq = 124;
tcph->ack_seq = 124;
#else #else
tcph->seq = random(); tcph->seq = random();
tcph->ack_seq = random();
#endif #endif
}
lgtrace_addp("%u", ntohl(tcph->seq)); lgtrace_addp("%u", ntohl(tcph->seq));
} else if (config.faking_strategy == FAKE_STRAT_PAST_SEQ) { } else if (config.faking_strategy == FAKE_STRAT_PAST_SEQ) {
lgtrace("fake seq: %u -> ", ntohl(tcph->seq)); lgtrace("fake seq: %u -> ", ntohl(tcph->seq));