mirror of
https://github.com/caddyserver/caddy.git
synced 2025-01-18 16:55:37 +03:00
redir: Do not count multiple rules with if statements as duplicates
This allows you to have multiple redir directives conditioned solely upon if statements, without regard to path.
This commit is contained in:
parent
baf6db5b57
commit
f9cba03d25
2 changed files with 10 additions and 5 deletions
|
@ -40,6 +40,7 @@ func SetupIfMatcher(controller *caddy.Controller) (RequestMatcher, error) {
|
||||||
return matcher, err
|
return matcher, err
|
||||||
}
|
}
|
||||||
matcher.ifs = append(matcher.ifs, ifc)
|
matcher.ifs = append(matcher.ifs, ifc)
|
||||||
|
matcher.Enabled = true
|
||||||
case "if_op":
|
case "if_op":
|
||||||
if !c.NextArg() {
|
if !c.NextArg() {
|
||||||
return matcher, c.ArgErr()
|
return matcher, c.ArgErr()
|
||||||
|
@ -155,6 +156,7 @@ func (i ifCond) True(r *http.Request) bool {
|
||||||
|
|
||||||
// IfMatcher is a RequestMatcher for 'if' conditions.
|
// IfMatcher is a RequestMatcher for 'if' conditions.
|
||||||
type IfMatcher struct {
|
type IfMatcher struct {
|
||||||
|
Enabled bool // if true, matcher has been configured; otherwise it's no-op
|
||||||
ifs []ifCond // list of If
|
ifs []ifCond // list of If
|
||||||
isOr bool // if true, conditions are 'or' instead of 'and'
|
isOr bool // if true, conditions are 'or' instead of 'and'
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,11 +101,14 @@ func redirParse(c *caddy.Controller) ([]Rule, error) {
|
||||||
return c.Err("'from' and 'to' values of redirect rule cannot be the same")
|
return c.Err("'from' and 'to' values of redirect rule cannot be the same")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// prevent obvious duplicates (rules with if statements exempt)
|
||||||
|
if ifm, ok := rule.RequestMatcher.(httpserver.IfMatcher); !ok || !ifm.Enabled {
|
||||||
for _, otherRule := range redirects {
|
for _, otherRule := range redirects {
|
||||||
if otherRule.FromPath == rule.FromPath {
|
if otherRule.FromPath == rule.FromPath {
|
||||||
return c.Errf("rule with duplicate 'from' value: %s -> %s", otherRule.FromPath, otherRule.To)
|
return c.Errf("rule with duplicate 'from' value: %s -> %s", otherRule.FromPath, otherRule.To)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
redirects = append(redirects, rule)
|
redirects = append(redirects, rule)
|
||||||
return nil
|
return nil
|
||||||
|
|
Loading…
Reference in a new issue