mirror of
https://github.com/yusing/godoxy.git
synced 2025-05-19 20:32:35 +02:00
feat(rules.on): support route directive
This commit is contained in:
parent
7b0ed09772
commit
f190483b4e
3 changed files with 59 additions and 0 deletions
|
@ -8,6 +8,7 @@ import (
|
|||
|
||||
"github.com/gobwas/glob"
|
||||
"github.com/yusing/go-proxy/internal/gperr"
|
||||
"github.com/yusing/go-proxy/internal/net/gphttp/httpheaders"
|
||||
"github.com/yusing/go-proxy/internal/net/types"
|
||||
"github.com/yusing/go-proxy/internal/utils/strutils"
|
||||
)
|
||||
|
@ -31,6 +32,7 @@ const (
|
|||
OnPath = "path"
|
||||
OnRemote = "remote"
|
||||
OnBasicAuth = "basic_auth"
|
||||
OnRoute = "route"
|
||||
)
|
||||
|
||||
var checkers = map[string]struct {
|
||||
|
@ -229,6 +231,21 @@ var checkers = map[string]struct {
|
|||
}
|
||||
},
|
||||
},
|
||||
OnRoute: {
|
||||
help: Help{
|
||||
command: OnRoute,
|
||||
args: map[string]string{
|
||||
"route": "the route name",
|
||||
},
|
||||
},
|
||||
validate: validateSingleArg,
|
||||
builder: func(args any) CheckFunc {
|
||||
route := args.(string)
|
||||
return func(_ Cache, r *http.Request) bool {
|
||||
return r.Header.Get(httpheaders.HeaderUpstreamName) == route
|
||||
}
|
||||
},
|
||||
},
|
||||
}
|
||||
|
||||
var asciiSpace = [256]uint8{'\t': 1, '\n': 1, '\v': 1, '\f': 1, '\r': 1, ' ': 1}
|
||||
|
|
|
@ -8,6 +8,7 @@ import (
|
|||
"testing"
|
||||
|
||||
"github.com/yusing/go-proxy/internal/gperr"
|
||||
"github.com/yusing/go-proxy/internal/net/gphttp/httpheaders"
|
||||
. "github.com/yusing/go-proxy/internal/utils/testing"
|
||||
"golang.org/x/crypto/bcrypt"
|
||||
)
|
||||
|
@ -168,6 +169,22 @@ func TestParseOn(t *testing.T) {
|
|||
input: "unknown",
|
||||
wantErr: ErrInvalidOnTarget,
|
||||
},
|
||||
// route
|
||||
{
|
||||
name: "route_valid",
|
||||
input: "route example",
|
||||
wantErr: nil,
|
||||
},
|
||||
{
|
||||
name: "route_missing_arg",
|
||||
input: "route",
|
||||
wantErr: ErrExpectOneArg,
|
||||
},
|
||||
{
|
||||
name: "route_extra_arg",
|
||||
input: "route example1 example2",
|
||||
wantErr: ErrExpectOneArg,
|
||||
},
|
||||
}
|
||||
|
||||
for _, tt := range tests {
|
||||
|
@ -285,6 +302,24 @@ func TestOnCorrectness(t *testing.T) {
|
|||
},
|
||||
want: false,
|
||||
},
|
||||
{
|
||||
name: "route_match",
|
||||
checker: "route example",
|
||||
input: &http.Request{
|
||||
Header: http.Header{
|
||||
httpheaders.HeaderUpstreamName: {"example"},
|
||||
},
|
||||
},
|
||||
want: true,
|
||||
},
|
||||
{
|
||||
name: "route_no_match",
|
||||
checker: "route example",
|
||||
input: &http.Request{
|
||||
Header: http.Header{},
|
||||
},
|
||||
want: false,
|
||||
},
|
||||
}
|
||||
|
||||
tests = append(tests, genCorrectnessTestCases("header", func(k, v string) *http.Request {
|
||||
|
|
|
@ -30,6 +30,13 @@ func (t *Tuple[T1, T2]) String() string {
|
|||
return fmt.Sprintf("%v:%v", t.First, t.Second)
|
||||
}
|
||||
|
||||
func validateSingleArg(args []string) (any, gperr.Error) {
|
||||
if len(args) != 1 {
|
||||
return nil, ErrExpectOneArg
|
||||
}
|
||||
return args[0], nil
|
||||
}
|
||||
|
||||
// toStrTuple returns *StrTuple.
|
||||
func toStrTuple(args []string) (any, gperr.Error) {
|
||||
if len(args) != 2 {
|
||||
|
|
Loading…
Add table
Reference in a new issue