mirror of
https://github.com/yusing/godoxy.git
synced 2025-06-15 22:46:47 +02:00
refactor: move servemux to gphttp/servemux
This commit is contained in:
parent
2b44ac5bcb
commit
12a63a66f6
2 changed files with 63 additions and 50 deletions
|
@ -1,7 +1,6 @@
|
||||||
package api
|
package api
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"fmt"
|
|
||||||
"net/http"
|
"net/http"
|
||||||
|
|
||||||
"github.com/prometheus/client_golang/prometheus/promhttp"
|
"github.com/prometheus/client_golang/prometheus/promhttp"
|
||||||
|
@ -14,58 +13,11 @@ import (
|
||||||
"github.com/yusing/go-proxy/internal/logging"
|
"github.com/yusing/go-proxy/internal/logging"
|
||||||
"github.com/yusing/go-proxy/internal/logging/memlogger"
|
"github.com/yusing/go-proxy/internal/logging/memlogger"
|
||||||
"github.com/yusing/go-proxy/internal/metrics/uptime"
|
"github.com/yusing/go-proxy/internal/metrics/uptime"
|
||||||
"github.com/yusing/go-proxy/internal/net/gphttp/httpheaders"
|
"github.com/yusing/go-proxy/internal/net/gphttp/servemux"
|
||||||
"github.com/yusing/go-proxy/internal/utils/strutils"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type (
|
|
||||||
ServeMux struct {
|
|
||||||
*http.ServeMux
|
|
||||||
cfg config.ConfigInstance
|
|
||||||
}
|
|
||||||
WithCfgHandler = func(config.ConfigInstance, http.ResponseWriter, *http.Request)
|
|
||||||
)
|
|
||||||
|
|
||||||
func (mux ServeMux) HandleFunc(methods, endpoint string, h any, requireAuth ...bool) {
|
|
||||||
var handler http.HandlerFunc
|
|
||||||
switch h := h.(type) {
|
|
||||||
case func(http.ResponseWriter, *http.Request):
|
|
||||||
handler = h
|
|
||||||
case http.Handler:
|
|
||||||
handler = h.ServeHTTP
|
|
||||||
case WithCfgHandler:
|
|
||||||
handler = func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
h(mux.cfg, w, r)
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
panic(fmt.Errorf("unsupported handler type: %T", h))
|
|
||||||
}
|
|
||||||
|
|
||||||
matchDomains := mux.cfg.Value().MatchDomains
|
|
||||||
if len(matchDomains) > 0 {
|
|
||||||
origHandler := handler
|
|
||||||
handler = func(w http.ResponseWriter, r *http.Request) {
|
|
||||||
if httpheaders.IsWebsocket(r.Header) {
|
|
||||||
httpheaders.SetWebsocketAllowedDomains(r.Header, matchDomains)
|
|
||||||
}
|
|
||||||
origHandler(w, r)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if len(requireAuth) > 0 && requireAuth[0] {
|
|
||||||
handler = auth.RequireAuth(handler)
|
|
||||||
}
|
|
||||||
if methods == "" {
|
|
||||||
mux.ServeMux.HandleFunc(endpoint, handler)
|
|
||||||
} else {
|
|
||||||
for _, m := range strutils.CommaSeperatedList(methods) {
|
|
||||||
mux.ServeMux.HandleFunc(m+" "+endpoint, handler)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func NewHandler(cfg config.ConfigInstance) http.Handler {
|
func NewHandler(cfg config.ConfigInstance) http.Handler {
|
||||||
mux := ServeMux{http.NewServeMux(), cfg}
|
mux := servemux.NewServeMux(cfg)
|
||||||
mux.HandleFunc("GET", "/v1", v1.Index)
|
mux.HandleFunc("GET", "/v1", v1.Index)
|
||||||
mux.HandleFunc("GET", "/v1/version", v1.GetVersion)
|
mux.HandleFunc("GET", "/v1/version", v1.GetVersion)
|
||||||
|
|
||||||
|
|
61
internal/net/gphttp/servemux/mux.go
Normal file
61
internal/net/gphttp/servemux/mux.go
Normal file
|
@ -0,0 +1,61 @@
|
||||||
|
package servemux
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"net/http"
|
||||||
|
|
||||||
|
"github.com/yusing/go-proxy/internal/api/v1/auth"
|
||||||
|
config "github.com/yusing/go-proxy/internal/config/types"
|
||||||
|
"github.com/yusing/go-proxy/internal/net/gphttp/httpheaders"
|
||||||
|
"github.com/yusing/go-proxy/internal/utils/strutils"
|
||||||
|
)
|
||||||
|
|
||||||
|
type (
|
||||||
|
ServeMux struct {
|
||||||
|
*http.ServeMux
|
||||||
|
cfg config.ConfigInstance
|
||||||
|
}
|
||||||
|
WithCfgHandler = func(config.ConfigInstance, http.ResponseWriter, *http.Request)
|
||||||
|
)
|
||||||
|
|
||||||
|
func NewServeMux(cfg config.ConfigInstance) ServeMux {
|
||||||
|
return ServeMux{http.NewServeMux(), cfg}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (mux ServeMux) HandleFunc(methods, endpoint string, h any, requireAuth ...bool) {
|
||||||
|
var handler http.HandlerFunc
|
||||||
|
switch h := h.(type) {
|
||||||
|
case func(http.ResponseWriter, *http.Request):
|
||||||
|
handler = h
|
||||||
|
case http.Handler:
|
||||||
|
handler = h.ServeHTTP
|
||||||
|
case WithCfgHandler:
|
||||||
|
handler = func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
h(mux.cfg, w, r)
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
panic(fmt.Errorf("unsupported handler type: %T", h))
|
||||||
|
}
|
||||||
|
|
||||||
|
matchDomains := mux.cfg.Value().MatchDomains
|
||||||
|
if len(matchDomains) > 0 {
|
||||||
|
origHandler := handler
|
||||||
|
handler = func(w http.ResponseWriter, r *http.Request) {
|
||||||
|
if httpheaders.IsWebsocket(r.Header) {
|
||||||
|
httpheaders.SetWebsocketAllowedDomains(r.Header, matchDomains)
|
||||||
|
}
|
||||||
|
origHandler(w, r)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if len(requireAuth) > 0 && requireAuth[0] {
|
||||||
|
handler = auth.RequireAuth(handler)
|
||||||
|
}
|
||||||
|
if methods == "" {
|
||||||
|
mux.ServeMux.HandleFunc(endpoint, handler)
|
||||||
|
} else {
|
||||||
|
for _, m := range strutils.CommaSeperatedList(methods) {
|
||||||
|
mux.ServeMux.HandleFunc(m+" "+endpoint, handler)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue