mirror of
https://github.com/xvzc/SpoofDPI.git
synced 2025-01-04 13:24:46 +00:00
add request module
This commit is contained in:
parent
1581f9c4d1
commit
81938445a1
@ -6,6 +6,7 @@ import (
|
|||||||
"os"
|
"os"
|
||||||
|
|
||||||
"github.com/xvzc/SpoofDPI/config"
|
"github.com/xvzc/SpoofDPI/config"
|
||||||
|
"github.com/xvzc/SpoofDPI/request"
|
||||||
"github.com/xvzc/SpoofDPI/util"
|
"github.com/xvzc/SpoofDPI/util"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -30,40 +31,35 @@ func Start() {
|
|||||||
go func() {
|
go func() {
|
||||||
defer clientConn.Close()
|
defer clientConn.Close()
|
||||||
|
|
||||||
message, err := ReadBytes(clientConn)
|
b, err := ReadBytes(clientConn)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
util.Debug("Client sent data: ", len(message))
|
util.Debug("Client sent data: ", len(b))
|
||||||
|
|
||||||
util.Debug("")
|
r := request.New(&b)
|
||||||
util.Debug("Request : ")
|
|
||||||
util.Debug("\n" + string(message))
|
|
||||||
|
|
||||||
method := util.ExtractMethod(&message)
|
if !r.IsValidMethod() {
|
||||||
|
log.Println("Unsupported method: ", r.Method)
|
||||||
if !util.IsValidMethod(method) {
|
|
||||||
util.Debug("Not a valid method: " + method)
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
domain := util.ExtractDomain(&message)
|
// Dns lookup over https
|
||||||
|
ip, err := util.DnsLookupOverHttps(config.GetConfig().DNS, r.Domain)
|
||||||
ip, err := util.DnsLookupOverHttps(config.GetConfig().DNS, domain) // Dns lookup over https
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
log.Println("Error looking up dns: "+domain, err)
|
log.Println("Error looking up dns: "+r.Domain, err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
util.Debug("ip: " + ip)
|
util.Debug("ip: " + ip)
|
||||||
|
|
||||||
if util.ExtractMethod(&message) == "CONNECT" {
|
if r.Method == "CONNECT" {
|
||||||
util.Debug("HTTPS Requested")
|
util.Debug("HTTPS Requested")
|
||||||
HandleHttps(clientConn, ip)
|
HandleHttps(clientConn, ip)
|
||||||
} else {
|
} else {
|
||||||
util.Debug("HTTP Requested.")
|
util.Debug("HTTP Requested.")
|
||||||
HandleHttp(clientConn, ip, message)
|
HandleHttp(clientConn, ip, b)
|
||||||
}
|
}
|
||||||
}()
|
}()
|
||||||
}
|
}
|
||||||
|
107
request/http.go
Normal file
107
request/http.go
Normal file
@ -0,0 +1,107 @@
|
|||||||
|
package request
|
||||||
|
|
||||||
|
import (
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
type Request struct {
|
||||||
|
Raw *[]byte
|
||||||
|
Method string
|
||||||
|
Domain string
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *Request) IsValidMethod() bool {
|
||||||
|
if _, exists := getValidMethods()[r.Method]; exists {
|
||||||
|
return true
|
||||||
|
}
|
||||||
|
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
|
||||||
|
func New(raw *[]byte) Request {
|
||||||
|
return Request{
|
||||||
|
Raw: raw,
|
||||||
|
Method: extractMethod(raw),
|
||||||
|
Domain: extractDomain(raw),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (r *Request) ToChunks() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
func extractDomain(request *[]byte) string {
|
||||||
|
i := 0
|
||||||
|
for ; i < len(*request); i++ {
|
||||||
|
if (*request)[i] == ' ' {
|
||||||
|
i++
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
j := i
|
||||||
|
for ; j < len(*request); j++ {
|
||||||
|
if (*request)[j] == ' ' {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
domain := string((*request)[i:j])
|
||||||
|
domain = strings.Replace(domain, "http://", "", 1)
|
||||||
|
domain = strings.Replace(domain, "https://", "", 1)
|
||||||
|
domain = strings.Split(domain, ":")[0]
|
||||||
|
domain = strings.Split(domain, "/")[0]
|
||||||
|
|
||||||
|
return strings.TrimSpace(domain)
|
||||||
|
}
|
||||||
|
|
||||||
|
func extractMethod(message *[]byte) string {
|
||||||
|
i := 0
|
||||||
|
for ; i < len(*message); i++ {
|
||||||
|
if (*message)[i] == ' ' {
|
||||||
|
break
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
method := strings.TrimSpace(string((*message)[:i]))
|
||||||
|
|
||||||
|
return strings.ToUpper(method)
|
||||||
|
}
|
||||||
|
|
||||||
|
func getValidMethods() map[string]struct{} {
|
||||||
|
return map[string]struct{}{
|
||||||
|
"DELETE": {},
|
||||||
|
"GET": {},
|
||||||
|
"HEAD": {},
|
||||||
|
"POST": {},
|
||||||
|
"PUT": {},
|
||||||
|
"CONNECT": {},
|
||||||
|
"OPTIONS": {},
|
||||||
|
"TRACE": {},
|
||||||
|
"COPY": {},
|
||||||
|
"LOCK": {},
|
||||||
|
"MKCOL": {},
|
||||||
|
"MOVE": {},
|
||||||
|
"PROPFIND": {},
|
||||||
|
"PROPPATCH": {},
|
||||||
|
"SEARCH": {},
|
||||||
|
"UNLOCK": {},
|
||||||
|
"BIND": {},
|
||||||
|
"REBIND": {},
|
||||||
|
"UNBIND": {},
|
||||||
|
"ACL": {},
|
||||||
|
"REPORT": {},
|
||||||
|
"MKACTIVITY": {},
|
||||||
|
"CHECKOUT": {},
|
||||||
|
"MERGE": {},
|
||||||
|
"M-SEARCH": {},
|
||||||
|
"NOTIFY": {},
|
||||||
|
"SUBSCRIBE": {},
|
||||||
|
"UNSUBSCRIBE": {},
|
||||||
|
"PATCH": {},
|
||||||
|
"PURGE": {},
|
||||||
|
"MKCALENDAR": {},
|
||||||
|
"LINK": {},
|
||||||
|
"UNLINK": {},
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user