mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-14 14:56:27 +03:00
Refactor ExtractMatcherSet()
This commit is contained in:
parent
260982b2df
commit
cef6e098bb
2 changed files with 21 additions and 6 deletions
|
@ -161,6 +161,23 @@ func (h Helper) MatcherToken() (caddy.ModuleMap, bool, error) {
|
||||||
return matcherSetFromMatcherToken(h.Dispenser.Token(), h.matcherDefs, h.warnings)
|
return matcherSetFromMatcherToken(h.Dispenser.Token(), h.matcherDefs, h.warnings)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// ExtractMatcherSet is like MatcherToken, except this is a higher-level
|
||||||
|
// method that returns the matcher set described by the matcher token,
|
||||||
|
// or nil if there is none, and deletes the matcher token from the
|
||||||
|
// dispenser and resets it as if this look-ahead never happened. Useful
|
||||||
|
// when wrapping a route (one or more handlers) in a user-defined matcher.
|
||||||
|
func (h Helper) ExtractMatcherSet() (caddy.ModuleMap, error) {
|
||||||
|
matcherSet, hasMatcher, err := h.MatcherToken()
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if hasMatcher {
|
||||||
|
h.Dispenser.Delete() // strip matcher token
|
||||||
|
}
|
||||||
|
h.Dispenser.Reset() // pretend this lookahead never happened
|
||||||
|
return matcherSet, nil
|
||||||
|
}
|
||||||
|
|
||||||
// NewRoute returns config values relevant to creating a new HTTP route.
|
// NewRoute returns config values relevant to creating a new HTTP route.
|
||||||
func (h Helper) NewRoute(matcherSet caddy.ModuleMap,
|
func (h Helper) NewRoute(matcherSet caddy.ModuleMap,
|
||||||
handler caddyhttp.MiddlewareHandler) []ConfigValue {
|
handler caddyhttp.MiddlewareHandler) []ConfigValue {
|
||||||
|
|
|
@ -167,14 +167,10 @@ func parsePHPFastCGI(h httpcaddyfile.Helper) ([]httpcaddyfile.ConfigValue, error
|
||||||
// either way, strip the matcher token and pass
|
// either way, strip the matcher token and pass
|
||||||
// the remaining tokens to the unmarshaler so that
|
// the remaining tokens to the unmarshaler so that
|
||||||
// we can gain the rest of the reverse_proxy syntax
|
// we can gain the rest of the reverse_proxy syntax
|
||||||
userMatcherSet, hasUserMatcher, err := h.MatcherToken()
|
userMatcherSet, err := h.ExtractMatcherSet()
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
if hasUserMatcher {
|
|
||||||
h.Dispenser.Delete() // strip matcher token
|
|
||||||
}
|
|
||||||
h.Dispenser.Reset() // pretend this lookahead never happened
|
|
||||||
|
|
||||||
// set up the transport for FastCGI, and specifically PHP
|
// set up the transport for FastCGI, and specifically PHP
|
||||||
fcgiTransport := Transport{SplitPath: ".php"}
|
fcgiTransport := Transport{SplitPath: ".php"}
|
||||||
|
@ -186,6 +182,8 @@ func parsePHPFastCGI(h httpcaddyfile.Helper) ([]httpcaddyfile.ConfigValue, error
|
||||||
|
|
||||||
// the rest of the config is specified by the user
|
// the rest of the config is specified by the user
|
||||||
// using the reverse_proxy directive syntax
|
// using the reverse_proxy directive syntax
|
||||||
|
// TODO: this can overwrite our fcgiTransport that we encoded and
|
||||||
|
// set on the rpHandler... even with a non-fastcgi transport!
|
||||||
err = rpHandler.UnmarshalCaddyfile(h.Dispenser)
|
err = rpHandler.UnmarshalCaddyfile(h.Dispenser)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
@ -204,7 +202,7 @@ func parsePHPFastCGI(h httpcaddyfile.Helper) ([]httpcaddyfile.ConfigValue, error
|
||||||
|
|
||||||
// the user's matcher is a prerequisite for ours, so
|
// the user's matcher is a prerequisite for ours, so
|
||||||
// wrap ours in a subroute and return that
|
// wrap ours in a subroute and return that
|
||||||
if hasUserMatcher {
|
if userMatcherSet != nil {
|
||||||
return []httpcaddyfile.ConfigValue{
|
return []httpcaddyfile.ConfigValue{
|
||||||
{
|
{
|
||||||
Class: "route",
|
Class: "route",
|
||||||
|
|
Loading…
Reference in a new issue