Support routing forge clients
This commit is contained in:
+12
-1
@@ -5,6 +5,7 @@ import (
|
|||||||
"github.com/gorilla/mux"
|
"github.com/gorilla/mux"
|
||||||
"github.com/sirupsen/logrus"
|
"github.com/sirupsen/logrus"
|
||||||
"net/http"
|
"net/http"
|
||||||
|
"strings"
|
||||||
"sync"
|
"sync"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -95,6 +96,14 @@ type IRoutes interface {
|
|||||||
|
|
||||||
var Routes IRoutes = &routesImpl{}
|
var Routes IRoutes = &routesImpl{}
|
||||||
|
|
||||||
|
func NewRoutes() IRoutes {
|
||||||
|
r := &routesImpl{
|
||||||
|
mappings: make(map[string]string),
|
||||||
|
}
|
||||||
|
|
||||||
|
return r
|
||||||
|
}
|
||||||
|
|
||||||
func (r *routesImpl) RegisterAll(mappings map[string]string) {
|
func (r *routesImpl) RegisterAll(mappings map[string]string) {
|
||||||
r.Lock()
|
r.Lock()
|
||||||
defer r.Unlock()
|
defer r.Unlock()
|
||||||
@@ -120,11 +129,13 @@ func (r *routesImpl) FindBackendForServerAddress(serverAddress string) string {
|
|||||||
r.RLock()
|
r.RLock()
|
||||||
defer r.RUnlock()
|
defer r.RUnlock()
|
||||||
|
|
||||||
|
addressParts := strings.Split(serverAddress, `\x00`)
|
||||||
|
|
||||||
if r.mappings == nil {
|
if r.mappings == nil {
|
||||||
return r.defaultRoute
|
return r.defaultRoute
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
if route, exists := r.mappings[serverAddress]; exists {
|
if route, exists := r.mappings[addressParts[0]]; exists {
|
||||||
return route
|
return route
|
||||||
} else {
|
} else {
|
||||||
return r.defaultRoute
|
return r.defaultRoute
|
||||||
|
|||||||
@@ -0,0 +1,53 @@
|
|||||||
|
package server
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
|
func Test_routesImpl_FindBackendForServerAddress(t *testing.T) {
|
||||||
|
type args struct {
|
||||||
|
serverAddress string
|
||||||
|
}
|
||||||
|
type mapping struct {
|
||||||
|
serverAddress string
|
||||||
|
backend string
|
||||||
|
}
|
||||||
|
tests := []struct {
|
||||||
|
name string
|
||||||
|
mapping mapping
|
||||||
|
args args
|
||||||
|
want string
|
||||||
|
}{
|
||||||
|
{
|
||||||
|
name: "typical",
|
||||||
|
mapping: mapping{
|
||||||
|
serverAddress: "typical.my.domain", backend: "backend:25565",
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
serverAddress: `typical.my.domain`,
|
||||||
|
},
|
||||||
|
want: "backend:25565",
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "forge",
|
||||||
|
mapping: mapping{
|
||||||
|
serverAddress: "forge.my.domain", backend: "backend:25566",
|
||||||
|
},
|
||||||
|
args: args{
|
||||||
|
serverAddress: `forge.my.domain\x00FML2\x00`,
|
||||||
|
},
|
||||||
|
want: "backend:25566",
|
||||||
|
},
|
||||||
|
}
|
||||||
|
for _, tt := range tests {
|
||||||
|
t.Run(tt.name, func(t *testing.T) {
|
||||||
|
r := NewRoutes()
|
||||||
|
|
||||||
|
r.CreateMapping(tt.mapping.serverAddress, tt.mapping.backend)
|
||||||
|
|
||||||
|
if got := r.FindBackendForServerAddress(tt.args.serverAddress); got != tt.want {
|
||||||
|
t.Errorf("routesImpl.FindBackendForServerAddress() = %v, want %v", got, tt.want)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user