diff --git a/.gitignore b/.gitignore index 97d8b30..d73a741 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,7 @@ .vscode ciadpi.exe +ciadpi +*.o +compile_flags.txt build -*.user \ No newline at end of file +*.user 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 5831919..a3f1ce0 100644 --- a/conev.c +++ b/conev.c @@ -1,4 +1,3 @@ -#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..a87496a 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 @@ -391,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; @@ -420,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; } @@ -462,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 @@ -494,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) { @@ -503,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/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..9eddcee 100644 --- a/error.h +++ b/error.h @@ -1,3 +1,6 @@ +#ifndef CIADPI_ERROR_H +#define CIADPI_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..ac90b02 100644 --- a/extend.c +++ b/extend.c @@ -1,3 +1,5 @@ +#include "extend.h" + #ifdef _WIN32 #include diff --git a/extend.h b/extend.h index d861966..22d8ed8 100644 --- a/extend.h +++ b/extend.h @@ -1,3 +1,10 @@ +#ifndef EXTEND_H +#define EXTEND_H + +#include + +#include "proxy.h" + int connect_hook(struct poolhd *pool, struct eval *val, struct sockaddr_ina *dst, int next); @@ -14,4 +21,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/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 bcc0792..50fe43e 100644 --- a/mpool.c +++ b/mpool.c @@ -1,8 +1,8 @@ +#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..ecc84ab 100644 --- a/packets.c +++ b/packets.c @@ -1,12 +1,12 @@ -#define _GNU_SOURCE +#include "packets.h" -#include #include #include #include #include #include #include +#include #ifdef _WIN32 #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..d329108 100644 --- a/params.h +++ b/params.h @@ -1,3 +1,6 @@ +#ifndef PARAMS_H +#define PARAMS_H + #include #include @@ -7,6 +10,9 @@ #include #else #include + #include + #include + #include #endif #if defined(__linux__) || defined(_WIN32) @@ -107,4 +113,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..88539e4 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" @@ -57,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; } } @@ -344,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; @@ -374,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"); } @@ -430,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; @@ -441,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; @@ -463,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); @@ -617,7 +619,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; @@ -668,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; } @@ -689,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; } @@ -738,7 +740,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; @@ -780,7 +782,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) { @@ -938,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 b9db0a8..29eaee2 100644 --- a/proxy.h +++ b/proxy.h @@ -1,13 +1,21 @@ +#ifndef PROXY_H +#define PROXY_H + #include #ifdef _WIN32 #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; @@ -111,3 +119,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..9399974 100644 --- a/win_service.c +++ b/win_service.c @@ -1,4 +1,5 @@ #include "win_service.h" + #include #define SERVICE_NAME "ByeDPI" @@ -76,4 +77,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..104c44c 100644 --- a/win_service.h +++ b/win_service.h @@ -1 +1 @@ -int register_winsvc(int argc, char *argv[]); \ No newline at end of file +int register_winsvc(int argc, char *argv[]);