mirror of
https://github.com/hufrea/byedpi.git
synced 2025-01-16 11:35:07 +00:00
--no-udp
This commit is contained in:
parent
d922bb0590
commit
3ede6651f4
8
main.c
8
main.c
@ -34,6 +34,7 @@ struct params params = {
|
|||||||
|
|
||||||
.ipv6 = 1,
|
.ipv6 = 1,
|
||||||
.resolve = 1,
|
.resolve = 1,
|
||||||
|
.udp = 1,
|
||||||
.de_known = 0,
|
.de_known = 0,
|
||||||
.max_open = 512,
|
.max_open = 512,
|
||||||
|
|
||||||
@ -113,6 +114,7 @@ int main(int argc, char **argv)
|
|||||||
" -f, --pidfile <file> Write pid to file\n"
|
" -f, --pidfile <file> Write pid to file\n"
|
||||||
" -c, --max-conn <count> Connection count limit, default 512\n"
|
" -c, --max-conn <count> Connection count limit, default 512\n"
|
||||||
" -N, --no-domain Deny domain resolving\n"
|
" -N, --no-domain Deny domain resolving\n"
|
||||||
|
" -U, --no-udp Deny UDP associate\n"
|
||||||
" -K, --desync-known Desync only HTTP and TLS with SNI\n"
|
" -K, --desync-known Desync only HTTP and TLS with SNI\n"
|
||||||
//"Desync:\n"
|
//"Desync:\n"
|
||||||
" -m, --method <s|d|f> Desync method: split,disorder,fake\n"
|
" -m, --method <s|d|f> Desync method: split,disorder,fake\n"
|
||||||
@ -129,6 +131,7 @@ int main(int argc, char **argv)
|
|||||||
{"daemon", 0, 0, 'D'},
|
{"daemon", 0, 0, 'D'},
|
||||||
{"no-domain", 0, 0, 'N'},
|
{"no-domain", 0, 0, 'N'},
|
||||||
{"no-ipv6", 0, 0, 'X'}, //
|
{"no-ipv6", 0, 0, 'X'}, //
|
||||||
|
{"no-udp", 0, 0, 'U'},
|
||||||
{"desync-known ", 0, 0, 'K'},
|
{"desync-known ", 0, 0, 'K'},
|
||||||
{"split-at-host", 0, 0, 'H'},
|
{"split-at-host", 0, 0, 'H'},
|
||||||
{"help", 0, 0, 'h'},
|
{"help", 0, 0, 'h'},
|
||||||
@ -159,7 +162,7 @@ int main(int argc, char **argv)
|
|||||||
char *end = 0;
|
char *end = 0;
|
||||||
|
|
||||||
while (!invalid && (rez = getopt_long_only(argc, argv,
|
while (!invalid && (rez = getopt_long_only(argc, argv,
|
||||||
"DNXKHhvf:i:p:b:B:c:m:s:t:l:o:n:M:g:w:x:", options, 0)) != -1) {
|
"DNXUKHhvf:i:p:b:B:c:m:s:t:l:o:n:M:g:w:x:", options, 0)) != -1) {
|
||||||
switch (rez) {
|
switch (rez) {
|
||||||
|
|
||||||
case 'D':
|
case 'D':
|
||||||
@ -174,6 +177,9 @@ int main(int argc, char **argv)
|
|||||||
case 'X':
|
case 'X':
|
||||||
params.ipv6 = 0;
|
params.ipv6 = 0;
|
||||||
break;
|
break;
|
||||||
|
case 'U':
|
||||||
|
params.udp = 0;
|
||||||
|
break;
|
||||||
case 'K':
|
case 'K':
|
||||||
params.de_known = 1;
|
params.de_known = 1;
|
||||||
break;
|
break;
|
||||||
|
1
params.h
1
params.h
@ -18,6 +18,7 @@ struct params {
|
|||||||
|
|
||||||
char ipv6;
|
char ipv6;
|
||||||
char resolve;
|
char resolve;
|
||||||
|
char udp;
|
||||||
char de_known;
|
char de_known;
|
||||||
int max_open;
|
int max_open;
|
||||||
|
|
||||||
|
59
proxy.c
59
proxy.c
@ -61,7 +61,8 @@ static inline void map_fix(struct sockaddr_ina *addr, int f6)
|
|||||||
ipv6m->o16 = 0;
|
ipv6m->o16 = 0;
|
||||||
ipv6m->t16 = 0xffff;
|
ipv6m->t16 = 0xffff;
|
||||||
}
|
}
|
||||||
else if (ipv6m->o64 == 0 && ipv6m->t16 == 0xffff && !f6) {
|
else if ((ipv6m->o64 | ipv6m->o16) == 0 &&
|
||||||
|
ipv6m->t16 == 0xffff && !f6) {
|
||||||
addr->sa.sa_family = AF_INET;
|
addr->sa.sa_family = AF_INET;
|
||||||
addr->in.sin_addr = *(struct in_addr *)(&ipv6m->o32);
|
addr->in.sin_addr = *(struct in_addr *)(&ipv6m->o32);
|
||||||
}
|
}
|
||||||
@ -136,7 +137,7 @@ int auth_socks5(int fd, char *buffer, ssize_t n)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
int resp_error(int fd, int e, int flag)
|
int resp_error(int fd, int e, int flag, int re)
|
||||||
{
|
{
|
||||||
if (flag & FLAG_S4) {
|
if (flag & FLAG_S4) {
|
||||||
struct s4_req s4r = {
|
struct s4_req s4r = {
|
||||||
@ -146,7 +147,8 @@ int resp_error(int fd, int e, int flag)
|
|||||||
}
|
}
|
||||||
else if (flag & FLAG_S5) {
|
else if (flag & FLAG_S5) {
|
||||||
uint8_t se;
|
uint8_t se;
|
||||||
switch (e) {
|
if (re) se = (uint8_t )re;
|
||||||
|
else switch (e) {
|
||||||
case 0: se = S_ER_OK;
|
case 0: se = S_ER_OK;
|
||||||
break;
|
break;
|
||||||
case ECONNREFUSED:
|
case ECONNREFUSED:
|
||||||
@ -204,10 +206,7 @@ int handle_socks4(int fd, char *bf,
|
|||||||
dst->in.sin_addr = r->i4;
|
dst->in.sin_addr = r->i4;
|
||||||
}
|
}
|
||||||
if (er) {
|
if (er) {
|
||||||
struct s4_req s4r = {
|
if (resp_error(fd, 1, FLAG_S4, 0) < 0)
|
||||||
.cmd = S4_ER
|
|
||||||
};
|
|
||||||
if (send(fd, &s4r, sizeof(s4r), 0) < 0)
|
|
||||||
perror("send");
|
perror("send");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -291,8 +290,8 @@ int s_set_addr(char *buffer, ssize_t n,
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
static inline int create_conn(struct poolhd *pool, struct eval *val,
|
int create_conn(struct poolhd *pool,
|
||||||
enum eid nxt, struct sockaddr_ina *dst)
|
struct eval *val, struct sockaddr_ina *dst)
|
||||||
{
|
{
|
||||||
int sfd = nb_socket(dst->sa.sa_family, SOCK_STREAM);
|
int sfd = nb_socket(dst->sa.sa_family, SOCK_STREAM);
|
||||||
if (sfd < 0) {
|
if (sfd < 0) {
|
||||||
@ -327,7 +326,7 @@ static inline int create_conn(struct poolhd *pool, struct eval *val,
|
|||||||
close(sfd);
|
close(sfd);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
struct eval *pair = add_event(pool, nxt, sfd, POLLOUT);
|
struct eval *pair = add_event(pool, EV_CONNECT, sfd, POLLOUT);
|
||||||
if (!pair) {
|
if (!pair) {
|
||||||
close(sfd);
|
close(sfd);
|
||||||
return -1;
|
return -1;
|
||||||
@ -397,7 +396,7 @@ static inline int on_request(struct poolhd *pool, struct eval *val,
|
|||||||
char *buffer, size_t bfsize)
|
char *buffer, size_t bfsize)
|
||||||
{
|
{
|
||||||
struct sockaddr_ina dst = {0};
|
struct sockaddr_ina dst = {0};
|
||||||
int s = 0;
|
int s = 0, ss_e = 0;
|
||||||
|
|
||||||
ssize_t n = recv(val->fd, buffer, bfsize, 0);
|
ssize_t n = recv(val->fd, buffer, bfsize, 0);
|
||||||
if (n < 1) {
|
if (n < 1) {
|
||||||
@ -418,42 +417,34 @@ static inline int on_request(struct poolhd *pool, struct eval *val,
|
|||||||
}
|
}
|
||||||
struct s5_req *r = (struct s5_req *)buffer;
|
struct s5_req *r = (struct s5_req *)buffer;
|
||||||
|
|
||||||
int offs = s_get_addr(buffer, n, &dst, SOCK_STREAM);
|
ss_e = s_get_addr(buffer, n, &dst, SOCK_STREAM);
|
||||||
if (offs > 0) {
|
if (ss_e > 0) switch (r->cmd) {
|
||||||
if (r->cmd == S_CMD_AUDP) {
|
case S_CMD_CONN:
|
||||||
|
s = create_conn(pool, val, &dst);
|
||||||
|
break;
|
||||||
|
case S_CMD_AUDP:
|
||||||
|
if (params.udp) {
|
||||||
s = udp_asc(pool, val, &dst);
|
s = udp_asc(pool, val, &dst);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
else if (r->cmd == S_CMD_CONN) {
|
default:
|
||||||
s = create_conn(pool, val, EV_CONNECT, &dst);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
fprintf(stderr, "ss: unsupported cmd: 0x%x\n", r->cmd);
|
fprintf(stderr, "ss: unsupported cmd: 0x%x\n", r->cmd);
|
||||||
offs = -S_ER_CMD;
|
ss_e = -S_ER_CMD;
|
||||||
}
|
|
||||||
}
|
|
||||||
if (offs < 0) {
|
|
||||||
struct s5_rep s5r = {
|
|
||||||
.ver = 0x05, .code = (uint8_t )-offs,
|
|
||||||
.atp = S_ATP_I4
|
|
||||||
};
|
|
||||||
if (send(val->fd, &s5r, sizeof(s5r), 0) < 0)
|
|
||||||
perror("send");
|
|
||||||
return -1;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (*buffer == S_VER4) {
|
else if (*buffer == S_VER4) {
|
||||||
if (handle_socks4(val->fd, buffer, n, &dst)) {
|
if (handle_socks4(val->fd, buffer, n, &dst)) {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
s = create_conn(pool, val, EV_CONNECT, &dst);
|
s = create_conn(pool, val, &dst);
|
||||||
val->flag |= FLAG_S4;
|
val->flag |= FLAG_S4;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
fprintf(stderr, "ss: invalid version: 0x%x (%lu)\n", *buffer, n);
|
fprintf(stderr, "ss: invalid version: 0x%x (%lu)\n", *buffer, n);
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
if (s) {
|
if (s || ss_e < 0) {
|
||||||
if (resp_error(val->fd, errno, val->flag) < 0)
|
if (resp_error(val->fd, errno, val->flag, -ss_e) < 0)
|
||||||
perror("send");
|
perror("send");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -533,7 +524,7 @@ static inline int on_connect(struct poolhd *pool, struct eval *val,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (resp_error(val->pair->fd,
|
if (resp_error(val->pair->fd,
|
||||||
error, val->pair->flag) < 0) {
|
error, val->pair->flag, 0) < 0) {
|
||||||
perror("send");
|
perror("send");
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
@ -635,7 +626,7 @@ int on_udp_tunnel(struct eval *val, char *buffer, size_t bfsize)
|
|||||||
if (!ip_cmp((struct sockaddr_ina *)&val->in6, &addr) &&
|
if (!ip_cmp((struct sockaddr_ina *)&val->in6, &addr) &&
|
||||||
addr.in6.sin6_port == val->in6.sin6_port) {
|
addr.in6.sin6_port == val->in6.sin6_port) {
|
||||||
if (buffer[skip + 2]) { // frag
|
if (buffer[skip + 2]) { // frag
|
||||||
return 0;
|
continue;
|
||||||
}
|
}
|
||||||
offs = s_get_addr(buffer + skip, n, &addr, SOCK_DGRAM);
|
offs = s_get_addr(buffer + skip, n, &addr, SOCK_DGRAM);
|
||||||
if (offs < 0) {
|
if (offs < 0) {
|
||||||
|
Loading…
Reference in New Issue
Block a user