fix(websocket): fix local address checks

This commit is contained in:
yusing 2025-05-31 13:55:29 +08:00
parent 57200bc1e9
commit 54bf84dcba

View file

@ -3,7 +3,6 @@ package gpwebsocket
import ( import (
"net" "net"
"net/http" "net/http"
"slices"
"strings" "strings"
"sync" "sync"
"time" "time"
@ -30,8 +29,6 @@ func SetWebsocketAllowedDomains(h http.Header, domains []string) {
h[HeaderXGoDoxyWebsocketAllowedDomains] = domains h[HeaderXGoDoxyWebsocketAllowedDomains] = domains
} }
var localAddresses = []string{"127.0.0.1", "10.0.*.*", "172.16.*.*", "192.168.*.*"}
const writeTimeout = time.Second * 10 const writeTimeout = time.Second * 10
func Initiate(w http.ResponseWriter, r *http.Request) (*websocket.Conn, error) { func Initiate(w http.ResponseWriter, r *http.Request) (*websocket.Conn, error) {
@ -49,9 +46,13 @@ func Initiate(w http.ResponseWriter, r *http.Request) (*websocket.Conn, error) {
if err != nil { if err != nil {
host = r.Host host = r.Host
} }
if slices.Contains(localAddresses, host) { if host == "localhost" {
return true return true
} }
ip := net.ParseIP(host)
if ip != nil {
return ip.IsLoopback() || ip.IsPrivate()
}
for _, domain := range allowedDomains { for _, domain := range allowedDomains {
if domain[0] == '.' { if domain[0] == '.' {
if host == domain[1:] || strings.HasSuffix(host, domain) { if host == domain[1:] || strings.HasSuffix(host, domain) {