mirror of
https://github.com/hufrea/byedpi.git
synced 2025-01-19 09:11:53 +00:00
Handle HTTP CONNECT
This commit is contained in:
parent
57046d51b3
commit
ec6c82006a
1
conev.h
1
conev.h
@ -51,6 +51,7 @@ enum eid {
|
||||
#define FLAG_S4 1
|
||||
#define FLAG_S5 2
|
||||
#define FLAG_CONN 4
|
||||
#define FLAG_HTTP 8
|
||||
|
||||
#ifdef EID_STR
|
||||
char *eid_name[] = {
|
||||
|
4
main.c
4
main.c
@ -132,6 +132,7 @@ const struct option options[] = {
|
||||
{"no-domain", 0, 0, 'N'},
|
||||
{"no-ipv6", 0, 0, 'X'},
|
||||
{"no-udp", 0, 0, 'U'},
|
||||
{"http-connect", 0, 0, 'G'},
|
||||
{"help", 0, 0, 'h'},
|
||||
{"version", 0, 0, 'v'},
|
||||
{"ip", 1, 0, 'i'},
|
||||
@ -675,6 +676,9 @@ int main(int argc, char **argv)
|
||||
case 'U':
|
||||
params.udp = 0;
|
||||
break;
|
||||
case 'G':
|
||||
params.http_connect = 1;
|
||||
break;
|
||||
#ifdef __linux__
|
||||
case 'E':
|
||||
params.transparent = 1;
|
||||
|
3
params.h
3
params.h
@ -112,12 +112,13 @@ struct params {
|
||||
bool ipv6;
|
||||
bool resolve;
|
||||
bool udp;
|
||||
bool transparent;
|
||||
bool http_connect;
|
||||
int max_open;
|
||||
int debug;
|
||||
size_t bfsize;
|
||||
union sockaddr_u baddr;
|
||||
union sockaddr_u laddr;
|
||||
bool transparent;
|
||||
struct mphdr *mempool;
|
||||
|
||||
const char *protect_path;
|
||||
|
39
proxy.c
39
proxy.c
@ -13,6 +13,7 @@
|
||||
#include "conev.h"
|
||||
#include "extend.h"
|
||||
#include "error.h"
|
||||
#include "packets.h"
|
||||
|
||||
#ifdef _WIN32
|
||||
#include <winsock2.h>
|
||||
@ -125,6 +126,8 @@ static int resolve(char *host, int len,
|
||||
|
||||
hints.ai_socktype = type;
|
||||
hints.ai_flags = AI_ADDRCONFIG;
|
||||
if (!params.resolve)
|
||||
hints.ai_flags |= AI_NUMERICHOST;
|
||||
hints.ai_family = params.ipv6 ? AF_UNSPEC : AF_INET;
|
||||
|
||||
char rchar = host[len];
|
||||
@ -202,6 +205,14 @@ static int resp_error(int fd, int e, int flag)
|
||||
}
|
||||
return resp_s5_error(fd, e);
|
||||
}
|
||||
else if (flag == FLAG_HTTP) {
|
||||
if (!e) {
|
||||
static const char r[] = "HTTP/1.1 200 OK\r\n\r\n";
|
||||
return send(fd, r, sizeof(r) - 1, 0);
|
||||
}
|
||||
static const char r[] = "HTTP/1.1 503 Fail\r\n\r\n";
|
||||
return send(fd, r, sizeof(r) - 1, 0);
|
||||
}
|
||||
#ifdef __linux__
|
||||
if (params.transparent &&
|
||||
(e == ECONNREFUSED || e == ETIMEDOUT)) {
|
||||
@ -331,6 +342,25 @@ static int s5_set_addr(char *buffer, size_t n,
|
||||
}
|
||||
|
||||
|
||||
static int http_get_addr(
|
||||
const char *buff, size_t n, union sockaddr_u *dst)
|
||||
{
|
||||
char *host = 0;
|
||||
uint16_t port = 0;
|
||||
int host_len = parse_http(buff, n, &host, &port);
|
||||
|
||||
if (host_len < 3 || host_len > 255) {
|
||||
return -1;
|
||||
}
|
||||
if (resolve(host, host_len, dst, SOCK_STREAM)) {
|
||||
LOG(LOG_E, "not resolved: %.*s\n", host_len, host);
|
||||
return -1;
|
||||
}
|
||||
dst->in.sin_port = htons(port);
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
static int remote_sock(union sockaddr_u *dst, int type)
|
||||
{
|
||||
if (params.baddr.sa.sa_family == AF_INET6) {
|
||||
@ -838,6 +868,15 @@ static inline int on_request(struct poolhd *pool, struct eval *val,
|
||||
}
|
||||
error = connect_hook(pool, val, &dst, EV_CONNECT);
|
||||
}
|
||||
else if (params.http_connect
|
||||
&& n > 7 && !memcmp(buffer, "CONNECT", 7)) {
|
||||
val->flag = FLAG_HTTP;
|
||||
|
||||
if (http_get_addr(buffer, n, &dst)) {
|
||||
return -1;
|
||||
}
|
||||
error = connect_hook(pool, val, &dst, EV_CONNECT);
|
||||
}
|
||||
else {
|
||||
LOG(LOG_E, "ss: invalid version: 0x%x (%zd)\n", *buffer, n);
|
||||
return -1;
|
||||
|
Loading…
Reference in New Issue
Block a user