mirror of
https://github.com/itzg/mc-router.git
synced 2024-12-22 16:17:38 +01:00
Support routing forge clients
This commit is contained in:
parent
be0f2a8c56
commit
5875b0d231
@ -5,6 +5,7 @@ import (
|
||||
"github.com/gorilla/mux"
|
||||
"github.com/sirupsen/logrus"
|
||||
"net/http"
|
||||
"strings"
|
||||
"sync"
|
||||
)
|
||||
|
||||
@ -95,6 +96,14 @@ type IRoutes interface {
|
||||
|
||||
var Routes IRoutes = &routesImpl{}
|
||||
|
||||
func NewRoutes() IRoutes {
|
||||
r := &routesImpl{
|
||||
mappings: make(map[string]string),
|
||||
}
|
||||
|
||||
return r
|
||||
}
|
||||
|
||||
func (r *routesImpl) RegisterAll(mappings map[string]string) {
|
||||
r.Lock()
|
||||
defer r.Unlock()
|
||||
@ -120,11 +129,13 @@ func (r *routesImpl) FindBackendForServerAddress(serverAddress string) string {
|
||||
r.RLock()
|
||||
defer r.RUnlock()
|
||||
|
||||
addressParts := strings.Split(serverAddress, `\x00`)
|
||||
|
||||
if r.mappings == nil {
|
||||
return r.defaultRoute
|
||||
} else {
|
||||
|
||||
if route, exists := r.mappings[serverAddress]; exists {
|
||||
if route, exists := r.mappings[addressParts[0]]; exists {
|
||||
return route
|
||||
} else {
|
||||
return r.defaultRoute
|
||||
|
53
server/routes_test.go
Normal file
53
server/routes_test.go
Normal file
@ -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)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user