From 632e6b038b072e5e326b40832dda612cfba016b1 Mon Sep 17 00:00:00 2001 From: dartvader316 Date: Wed, 7 Aug 2024 14:25:26 +0300 Subject: [PATCH 1/6] fix headers --- .gitignore | 5 ++++- conev.c | 2 +- conev.h | 6 +++++- desync.c | 3 ++- desync.h | 16 +++++++++++++++- error.h | 7 ++++++- extend.c | 3 +++ extend.h | 13 ++++++++++++- mpool.c | 4 +++- mpool.h | 5 +++++ packets.c | 3 ++- packets.h | 6 ++++++ params.h | 7 ++++++- proxy.c | 3 ++- proxy.h | 5 +++++ win_service.c | 4 +++- win_service.h | 8 +++++++- 17 files changed, 87 insertions(+), 13 deletions(-) diff --git a/.gitignore b/.gitignore index 3a3cff5..097adc5 100644 --- a/.gitignore +++ b/.gitignore @@ -1,2 +1,5 @@ .vscode -ciadpi.exe \ No newline at end of file +ciadpi.exe +ciadpi +*.o +compile_flags.txt diff --git a/conev.c b/conev.c index 5831919..6387775 100644 --- a/conev.c +++ b/conev.c @@ -1,4 +1,4 @@ -#define CONEV_H + #include "conev.h" #include diff --git a/conev.h b/conev.h index 6df99a1..eed9079 100644 --- a/conev.h +++ b/conev.h @@ -1,4 +1,6 @@ -#pragma once +#ifndef CONEV_H +#define CONEV_H + #include #ifndef __linux__ @@ -107,3 +109,5 @@ void destroy_pool(struct poolhd *pool); struct eval *next_event(struct poolhd *pool, int *offs, int *type); int mod_etype(struct poolhd *pool, struct eval *val, int type); + +#endif diff --git a/desync.c b/desync.c index 1b0fbb9..da5cbe5 100644 --- a/desync.c +++ b/desync.c @@ -1,5 +1,7 @@ #define _GNU_SOURCE +#include "desync.h" + #include #include @@ -16,7 +18,6 @@ #include #include - #include #ifdef MFD_CLOEXEC #include diff --git a/desync.h b/desync.h index db0632a..a1a67db 100644 --- a/desync.h +++ b/desync.h @@ -1,3 +1,15 @@ +#ifndef DESYNC_H +#define DESYNC_H + +#include +#include + +#ifdef _WIN32 + #include +#else + #include +#endif + ssize_t desync(int sfd, char *buffer, size_t bfsize, ssize_t n, ssize_t offset, struct sockaddr *dst, int dp_c); ssize_t desync_udp(int sfd, char *buffer, size_t bfsize, ssize_t n, struct sockaddr *dst, int dp_c); @@ -9,4 +21,6 @@ struct tcpi { uint32_t unacked; uint32_t rrr[29]; uint32_t notsent_bytes; -}; \ No newline at end of file +}; + +#endif diff --git a/error.h b/error.h index 0352f7a..2e343e4 100644 --- a/error.h +++ b/error.h @@ -1,3 +1,6 @@ +#ifndef ERROR_H +#define ERROR_H + #include #include @@ -18,7 +21,7 @@ #ifdef _WIN32 #define uniperror(str) \ - fprintf(stderr, "%s: %d\n", str, GetLastError()) + fprintf(stderr, "%s: %ld\n", str, GetLastError()) #else #ifdef ANDROID_APP #define uniperror(str) \ @@ -72,3 +75,5 @@ static inline const int unie(int e) inet_ntop(AF_INET, &dst.in.sin_addr, ADDR_STR, sizeof(ADDR_STR)); \ else \ inet_ntop(AF_INET6, &dst.in6.sin6_addr, ADDR_STR, sizeof(ADDR_STR)); + +#endif diff --git a/extend.c b/extend.c index b91edf1..d5d6d59 100644 --- a/extend.c +++ b/extend.c @@ -1,3 +1,6 @@ + +#include "extend.h" + #ifdef _WIN32 #include diff --git a/extend.h b/extend.h index d861966..b3d923f 100644 --- a/extend.h +++ b/extend.h @@ -1,3 +1,12 @@ +#ifndef EXTEND_H +#define EXTEND_H + +#include + +#include "mpool.h" +#include "conev.h" +#include "proxy.h" + int connect_hook(struct poolhd *pool, struct eval *val, struct sockaddr_ina *dst, int next); @@ -14,4 +23,6 @@ ssize_t udp_hook(struct eval *val, int protect(int conn_fd, const char *path); #else #define protect(fd, path) 0 -#endif \ No newline at end of file +#endif + +#endif diff --git a/mpool.c b/mpool.c index bcc0792..9d4fd42 100644 --- a/mpool.c +++ b/mpool.c @@ -1,7 +1,9 @@ + +#include "mpool.h" + #include #include -#include "mpool.h" static inline int scmp(const struct elem *p, const struct elem *q) diff --git a/mpool.h b/mpool.h index 8f5d47d..c209dc0 100644 --- a/mpool.h +++ b/mpool.h @@ -1,3 +1,6 @@ +#ifndef MPOOL_H +#define MPOOL_H + #include #include #include "kavl.h" @@ -24,3 +27,5 @@ struct elem *mem_add(struct mphdr *hdr, char *str, int len); void mem_delete(struct mphdr *hdr, char *str, int len); void mem_destroy(struct mphdr *hdr); + +#endif diff --git a/packets.c b/packets.c index 540ba86..ebe4d39 100644 --- a/packets.c +++ b/packets.c @@ -1,6 +1,7 @@ #define _GNU_SOURCE -#include +#include "packets.h" + #include #include #include diff --git a/packets.h b/packets.h index 5ef44c4..2c04449 100644 --- a/packets.h +++ b/packets.h @@ -1,3 +1,6 @@ +#ifndef PACKETS_H +#define PACKETS_H + #include #include #include @@ -43,3 +46,6 @@ int part_tls(char *buffer, size_t bsize, ssize_t n, long pos); //bool is_dns_req(char *buffer, size_t n); //bool is_quic_initial(char *buffer, size_t bsize); + + +#endif diff --git a/params.h b/params.h index 825950c..a8ff74b 100644 --- a/params.h +++ b/params.h @@ -1,3 +1,6 @@ +#ifndef PARAMS_H +#define PARAMS_H + #include #include @@ -107,4 +110,6 @@ extern struct packet fake_http; extern struct packet oob_data; extern struct packet fake_udp; -extern char ip_option[1]; \ No newline at end of file +extern char ip_option[1]; + +#endif diff --git a/proxy.c b/proxy.c index de5ad7a..787b5fd 100644 --- a/proxy.c +++ b/proxy.c @@ -1,6 +1,8 @@ #define _GNU_SOURCE #define EID_STR +#include "proxy.h" + #include #include #include @@ -8,7 +10,6 @@ #include #include -#include "proxy.h" #include "params.h" #include "conev.h" #include "extend.h" diff --git a/proxy.h b/proxy.h index b9db0a8..43e5756 100644 --- a/proxy.h +++ b/proxy.h @@ -1,3 +1,6 @@ +#ifndef PROXY_H +#define PROXY_H + #include #ifdef _WIN32 @@ -111,3 +114,5 @@ int listen_socket(struct sockaddr_ina *srv); int event_loop(int srvfd); int run(struct sockaddr_ina *srv); + +#endif diff --git a/win_service.c b/win_service.c index 0bfd7a4..8645f45 100644 --- a/win_service.c +++ b/win_service.c @@ -1,4 +1,6 @@ + #include "win_service.h" + #include #define SERVICE_NAME "ByeDPI" @@ -76,4 +78,4 @@ int register_winsvc(int argc, char *argv[]) svc_argv = argv; return StartServiceCtrlDispatcher(ServiceTable); -} \ No newline at end of file +} diff --git a/win_service.h b/win_service.h index 6c15d5d..65b797a 100644 --- a/win_service.h +++ b/win_service.h @@ -1 +1,7 @@ -int register_winsvc(int argc, char *argv[]); \ No newline at end of file +#ifndef WIN_SERVICE_H +#define WIN_SERVICE_H + +int register_winsvc(int argc, char *argv[]); + + +#endif From ff4f811692dff679ac89bab95638d2a74f345e87 Mon Sep 17 00:00:00 2001 From: dartvader316 Date: Wed, 7 Aug 2024 14:44:12 +0300 Subject: [PATCH 2/6] fix ssize_t print format --- desync.c | 16 ++++++++-------- proxy.c | 6 +++--- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/desync.c b/desync.c index da5cbe5..a87496a 100644 --- a/desync.c +++ b/desync.c @@ -392,12 +392,12 @@ ssize_t desync(int sfd, char *buffer, size_t bfsize, type = IS_HTTP; } if (len && host) { - LOG(LOG_S, "host: %.*s (%ld)\n", + LOG(LOG_S, "host: %.*s (%zd)\n", len, host, host - buffer); } // modify packet if (type == IS_HTTP && dp.mod_http) { - LOG(LOG_S, "modify HTTP: n=%ld\n", n); + LOG(LOG_S, "modify HTTP: n=%zd\n", n); if (mod_http(buffer, n, dp.mod_http)) { LOG(LOG_E, "mod http error\n"); return -1; @@ -421,10 +421,10 @@ ssize_t desync(int sfd, char *buffer, size_t bfsize, } if (!part_tls(buffer + lp, bfsize - lp, n - lp, pos - lp)) { - LOG(LOG_E, "tlsrec error: pos=%ld, n=%ld\n", pos, n); + LOG(LOG_E, "tlsrec error: pos=%ld, n=%zd\n", pos, n); break; } - LOG(LOG_S, "tlsrec: pos=%ld, n=%ld\n", pos, n); + LOG(LOG_S, "tlsrec: pos=%ld, n=%zd\n", pos, n); n += 5; lp = pos + 5; } @@ -463,7 +463,7 @@ ssize_t desync(int sfd, char *buffer, size_t bfsize, continue; } else if (pos <= 0 || pos >= n || pos <= lp) { - LOG(LOG_E, "split cancel: pos=%ld-%ld, n=%ld\n", lp, pos, n); + LOG(LOG_E, "split cancel: pos=%ld-%ld, n=%zd\n", lp, pos, n); break; } // send part @@ -495,7 +495,7 @@ ssize_t desync(int sfd, char *buffer, size_t bfsize, default: return -1; } - LOG(LOG_S, "split: pos=%ld-%ld (%ld), m: %s\n", lp, pos, s, demode_str[part.m]); + LOG(LOG_S, "split: pos=%ld-%ld (%zd), m: %s\n", lp, pos, s, demode_str[part.m]); if (s < 0) { if (get_e() == EAGAIN) { @@ -504,14 +504,14 @@ ssize_t desync(int sfd, char *buffer, size_t bfsize, return -1; } else if (s != (pos - lp)) { - LOG(LOG_E, "%ld != %ld\n", s, pos - lp); + LOG(LOG_E, "%zd != %ld\n", s, pos - lp); return lp + s; } lp = pos; } // send all/rest if (lp < n) { - LOG((lp ? LOG_S : LOG_L), "send: pos=%ld-%ld\n", lp, n); + LOG((lp ? LOG_S : LOG_L), "send: pos=%ld-%zd\n", lp, n); if (send(sfd, buffer + lp, n - lp, 0) < 0) { if (get_e() == EAGAIN) { return lp; diff --git a/proxy.c b/proxy.c index 787b5fd..a321609 100644 --- a/proxy.c +++ b/proxy.c @@ -618,7 +618,7 @@ int on_tunnel(struct poolhd *pool, struct eval *val, } sn = 0; } - LOG(LOG_S, "send: %ld != %ld (fd: %d)\n", sn, n, pair->fd); + LOG(LOG_S, "send: %zd != %zd (fd: %d)\n", sn, n, pair->fd); assert(!(val->buff.size || val->buff.offset)); val->buff.size = n - sn; @@ -739,7 +739,7 @@ static inline int on_request(struct poolhd *pool, struct eval *val, return 0; } if (n < S_SIZE_MIN) { - LOG(LOG_E, "ss: request to small (%ld)\n", n); + LOG(LOG_E, "ss: request to small (%zd)\n", n); return -1; } struct s5_req *r = (struct s5_req *)buffer; @@ -781,7 +781,7 @@ static inline int on_request(struct poolhd *pool, struct eval *val, error = connect_hook(pool, val, &dst, EV_CONNECT); } else { - LOG(LOG_E, "ss: invalid version: 0x%x (%lu)\n", *buffer, n); + LOG(LOG_E, "ss: invalid version: 0x%x (%zd)\n", *buffer, n); return -1; } if (error) { From 64639d6661ab3d8f37d5f49dda9dbbb44a7f31c2 Mon Sep 17 00:00:00 2001 From: dartvader316 Date: Wed, 7 Aug 2024 15:52:56 +0300 Subject: [PATCH 3/6] fix dereferencing type-punned pointer warning --- proxy.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/proxy.c b/proxy.c index a321609..c938857 100644 --- a/proxy.c +++ b/proxy.c @@ -58,7 +58,8 @@ void map_fix(struct sockaddr_ina *addr, char f6) else if (!ipv6m->o64 && !ipv6m->o16 && ipv6m->t16 == 0xffff && !f6) { addr->sa.sa_family = AF_INET; - addr->in.sin_addr = *(struct in_addr *)(&ipv6m->o32); + const struct in_addr *sin_addr_ptr = (struct in_addr *) &ipv6m->o32; + addr->in.sin_addr = *sin_addr_ptr; } } From a7a219c4f8cc8e8de2dbb587664e4c4a984fad20 Mon Sep 17 00:00:00 2001 From: dartvader316 Date: Wed, 7 Aug 2024 16:05:14 +0300 Subject: [PATCH 4/6] better include guards for error.h --- error.h | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/error.h b/error.h index 2e343e4..9eddcee 100644 --- a/error.h +++ b/error.h @@ -1,5 +1,5 @@ -#ifndef ERROR_H -#define ERROR_H +#ifndef CIADPI_ERROR_H +#define CIADPI_ERROR_H #include #include From b49d0edbbad9a94127cb08a2d2ef957592fdaa5e Mon Sep 17 00:00:00 2001 From: dartvader316 Date: Sun, 11 Aug 2024 22:57:56 +0300 Subject: [PATCH 5/6] remove mpool.h from extend.h --- extend.h | 1 - 1 file changed, 1 deletion(-) diff --git a/extend.h b/extend.h index b3d923f..8a6ab8f 100644 --- a/extend.h +++ b/extend.h @@ -3,7 +3,6 @@ #include -#include "mpool.h" #include "conev.h" #include "proxy.h" From d61756dd951e1e659c64ed76ef15eda6945d7593 Mon Sep 17 00:00:00 2001 From: ruti <> Date: Mon, 12 Aug 2024 20:38:14 +0300 Subject: [PATCH 6/6] fix headers, sa_size macros, replace getopt_long_only --- Makefile | 2 +- conev.c | 1 - extend.c | 1 - extend.h | 1 - main.c | 5 +++-- mpool.c | 2 -- packets.c | 3 +-- params.h | 3 +++ proxy.c | 16 ++++++++-------- proxy.h | 5 +++++ win_service.c | 1 - win_service.h | 6 ------ 12 files changed, 21 insertions(+), 25 deletions(-) diff --git a/Makefile b/Makefile index 40f6708..4d96fe8 100644 --- a/Makefile +++ b/Makefile @@ -1,6 +1,6 @@ TARGET = ciadpi -CPPFLAGS = -D_XOPEN_SOURCE=500 +#CPPFLAGS = -D_XOPEN_SOURCE=500 CFLAGS += -I. -std=c99 -Wall -Wno-unused -O2 WIN_LDFLAGS = -lws2_32 -lmswsock diff --git a/conev.c b/conev.c index 6387775..a3f1ce0 100644 --- a/conev.c +++ b/conev.c @@ -1,4 +1,3 @@ - #include "conev.h" #include diff --git a/extend.c b/extend.c index d5d6d59..ac90b02 100644 --- a/extend.c +++ b/extend.c @@ -1,4 +1,3 @@ - #include "extend.h" #ifdef _WIN32 diff --git a/extend.h b/extend.h index 8a6ab8f..22d8ed8 100644 --- a/extend.h +++ b/extend.h @@ -3,7 +3,6 @@ #include -#include "conev.h" #include "proxy.h" int connect_hook(struct poolhd *pool, struct eval *val, diff --git a/main.c b/main.c index 19e0c2b..28a17a3 100644 --- a/main.c +++ b/main.c @@ -16,8 +16,9 @@ #include #include #include + #include #include - #include + #include #else #include #include "win_service.h" @@ -441,7 +442,7 @@ int main(int argc, char **argv) return -1; } - while (!invalid && (rez = getopt_long_only( + while (!invalid && (rez = getopt_long( argc, argv, opt, options, 0)) != -1) { switch (rez) { diff --git a/mpool.c b/mpool.c index 9d4fd42..50fe43e 100644 --- a/mpool.c +++ b/mpool.c @@ -1,11 +1,9 @@ - #include "mpool.h" #include #include - static inline int scmp(const struct elem *p, const struct elem *q) { if (p->len != q ->len) { diff --git a/packets.c b/packets.c index ebe4d39..ecc84ab 100644 --- a/packets.c +++ b/packets.c @@ -1,5 +1,3 @@ -#define _GNU_SOURCE - #include "packets.h" #include @@ -8,6 +6,7 @@ #include #include #include +#include #ifdef _WIN32 #include diff --git a/params.h b/params.h index a8ff74b..d329108 100644 --- a/params.h +++ b/params.h @@ -10,6 +10,9 @@ #include #else #include + #include + #include + #include #endif #if defined(__linux__) || defined(_WIN32) diff --git a/proxy.c b/proxy.c index c938857..88539e4 100644 --- a/proxy.c +++ b/proxy.c @@ -346,7 +346,7 @@ int create_conn(struct poolhd *pool, } } if (bind(sfd, (struct sockaddr *)¶ms.baddr, - sizeof(params.baddr)) < 0) { + SA_SIZE(¶ms.baddr)) < 0) { uniperror("bind"); close(sfd); return -1; @@ -376,7 +376,7 @@ int create_conn(struct poolhd *pool, close(sfd); return -1; } - int status = connect(sfd, &addr.sa, sizeof(addr)); + int status = connect(sfd, &addr.sa, SA_SIZE(&addr)); if (status == 0 && params.tfo) { LOG(LOG_S, "TFO supported!\n"); } @@ -432,7 +432,7 @@ int udp_associate(struct poolhd *pool, map_fix(&addr, 6); } if (bind(ufd, (struct sockaddr *)¶ms.baddr, - sizeof(params.baddr)) < 0) { + SA_SIZE(¶ms.baddr)) < 0) { uniperror("bind"); close(ufd); return -1; @@ -443,7 +443,7 @@ int udp_associate(struct poolhd *pool, return -1; } if (dst->in6.sin6_port != 0) { - if (connect(ufd, &addr.sa, sizeof(addr)) < 0) { + if (connect(ufd, &addr.sa, SA_SIZE(&addr)) < 0) { uniperror("connect"); del_event(pool, pair); return -1; @@ -465,7 +465,7 @@ int udp_associate(struct poolhd *pool, del_event(pool, pair); return -1; } - if (bind(cfd, &addr.sa, sizeof(addr)) < 0) { + if (bind(cfd, &addr.sa, SA_SIZE(&addr)) < 0) { uniperror("bind"); del_event(pool, pair); close(cfd); @@ -670,7 +670,7 @@ int on_udp_tunnel(struct eval *val, char *buffer, size_t bfsize) if (!addr_equ(&addr, (struct sockaddr_ina *)&val->in6)) { return 0; } - if (connect(val->fd, &addr.sa, sizeof(addr)) < 0) { + if (connect(val->fd, &addr.sa, SA_SIZE(&addr)) < 0) { uniperror("connect"); return -1; } @@ -691,7 +691,7 @@ int on_udp_tunnel(struct eval *val, char *buffer, size_t bfsize) if (params.baddr.sin6_family != addr.sa.sa_family) { return -1; } - if (connect(val->pair->fd, &addr.sa, sizeof(addr)) < 0) { + if (connect(val->pair->fd, &addr.sa, SA_SIZE(&addr)) < 0) { uniperror("connect"); return -1; } @@ -940,7 +940,7 @@ int listen_socket(struct sockaddr_ina *srv) close(srvfd); return -1; } - if (bind(srvfd, &srv->sa, sizeof(*srv)) < 0) { + if (bind(srvfd, &srv->sa, SA_SIZE(srv)) < 0) { uniperror("bind"); close(srvfd); return -1; diff --git a/proxy.h b/proxy.h index 43e5756..29eaee2 100644 --- a/proxy.h +++ b/proxy.h @@ -7,10 +7,15 @@ #include #else #include + #include #endif #include "conev.h" +#define SA_SIZE(s) \ + (((struct sockaddr *)s)->sa_family == AF_INET6) ? \ + sizeof(struct sockaddr_in6) : sizeof(struct sockaddr_in) + struct sockaddr_ina { union { struct sockaddr sa; diff --git a/win_service.c b/win_service.c index 8645f45..9399974 100644 --- a/win_service.c +++ b/win_service.c @@ -1,4 +1,3 @@ - #include "win_service.h" #include diff --git a/win_service.h b/win_service.h index 65b797a..104c44c 100644 --- a/win_service.h +++ b/win_service.h @@ -1,7 +1 @@ -#ifndef WIN_SERVICE_H -#define WIN_SERVICE_H - int register_winsvc(int argc, char *argv[]); - - -#endif