Skip to content

Commit

Permalink
fix recursive redirect issue
Browse files Browse the repository at this point in the history
  • Loading branch information
xvzc committed Jan 15, 2022
1 parent cb6a593 commit 7cd8389
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 13 deletions.
6 changes: 6 additions & 0 deletions net/conn.go
Original file line number Diff line number Diff line change
Expand Up @@ -72,6 +72,10 @@ func (conn *Conn) ReadBytes() ([]byte, error) {
}

func (lConn *Conn) HandleHttp(p packet.HttpPacket) {
p.Tidy()

log.Debug("[HTTP] request: \n\n" + string(p.Raw()))

ip, err := doh.Lookup(p.Domain())
if err != nil {
log.Debug("[HTTP] Error looking up for domain: ", err)
Expand Down Expand Up @@ -99,6 +103,8 @@ func (lConn *Conn) HandleHttp(p packet.HttpPacket) {
}

func (lConn *Conn) HandleHttps(p packet.HttpPacket) {
log.Debug("[HTTPS] request: \n\n" + string(p.Raw()))

ip, err := doh.Lookup(p.Domain())
if err != nil {
log.Debug("[HTTPS] Error looking up for domain: ", p.Domain(), " ", err)
Expand Down
45 changes: 36 additions & 9 deletions packet/http.go
Original file line number Diff line number Diff line change
Expand Up @@ -44,16 +44,18 @@ type HttpPacket struct {
raw []byte
method string
domain string
path string
version string
}

func NewHttpPacket(raw []byte) HttpPacket {
method, domain, version := parse(raw)
method, domain, path, version := parse(raw)

return HttpPacket{
raw: raw,
method: method,
domain: domain,
path: path,
version: version,
}
}
Expand All @@ -64,9 +66,11 @@ func (p *HttpPacket) Raw() []byte {
func (p *HttpPacket) Method() string {
return p.method
}

func (p *HttpPacket) Domain() string {
return p.domain
}

func (p *HttpPacket) Version() string {
return p.version
}
Expand All @@ -83,10 +87,13 @@ func (p *HttpPacket) IsConnectMethod() bool {
return p.Method() == "CONNECT"
}

func (p *HttpPacket) RemoveProxyHeader() {
func (p *HttpPacket) Tidy() {
s := string(p.raw)

lines := strings.Split(s, "\n")

lines[0] = p.method + " " + p.path + " " + p.version

for i := 0; i < len(lines); i++ {
if strings.HasPrefix(lines[i], "Proxy-Connection") {
lines[i] = ""
Expand All @@ -105,24 +112,44 @@ func (p *HttpPacket) RemoveProxyHeader() {
p.raw = []byte(result)
}

func parse(raw []byte) (string, string, string) {
func parse(raw []byte) (string, string, string, string) {
var firstLine string
for i := 0; i < len(raw); i++ {
if (raw)[i] == '\n' {
firstLine = string((raw)[:i])
break
}
}

tokens := strings.Split(firstLine, " ")

method := strings.TrimSpace(tokens[0])
domain := strings.TrimSpace(tokens[1])
url := strings.TrimSpace(tokens[1])
version := strings.TrimSpace(tokens[2])

domain = strings.Replace(domain, "http://", "", 1)
domain = strings.Replace(domain, "https://", "", 1)
domain = strings.Split(domain, ":")[0]
domain = strings.Split(domain, "/")[0]
url = strings.Replace(url, "http://", "", 1)
url = strings.Replace(url, "https://", "", 1)

domain := url
for i := 0; i < len(url); i++ {
if url[i] == ':' {
domain = url[:i]
break
}

if url[i] == '/' {
domain = url[:i]
break
}
}

path := "/"
for i := 0; i < len(url); i++ {
if url[i] == '/' {
path = url[i:]
break
}
}

return method, domain, version
return method, domain, path, version
}
4 changes: 0 additions & 4 deletions proxy/proxy.go
Original file line number Diff line number Diff line change
Expand Up @@ -54,10 +54,6 @@ func (p *Proxy) Start() {
return
}

pkt.RemoveProxyHeader()

log.Debug("New request: \n\n" + string(pkt.Raw()))

if pkt.IsConnectMethod() {
log.Debug("[HTTPS] Start")
go conn.HandleHttps(pkt)
Expand Down

0 comments on commit 7cd8389

Please sign in to comment.