mirror of
https://github.com/prometheus/prometheus
synced 2025-01-11 17:19:45 +00:00
aggregate booleans for ease of reading
Signed-off-by: schou <pschou@users.noreply.github.com>
This commit is contained in:
parent
71712183ac
commit
22bfc11738
@ -400,43 +400,47 @@ func (ng *Engine) validateOpts(expr parser.Expr) error {
|
||||
return nil
|
||||
}
|
||||
|
||||
atModifierUsed := false
|
||||
negativeOffsetUsed := false
|
||||
|
||||
var validationErr error
|
||||
parser.Inspect(expr, func(node parser.Node, path []parser.Node) error {
|
||||
switch n := node.(type) {
|
||||
case *parser.VectorSelector:
|
||||
if !ng.enableAtModifier &&
|
||||
(n.Timestamp != nil || n.StartOrEnd == parser.START || n.StartOrEnd == parser.END) {
|
||||
validationErr = ErrValidationAtModifierDisabled
|
||||
return validationErr
|
||||
if n.Timestamp != nil || n.StartOrEnd == parser.START || n.StartOrEnd == parser.END {
|
||||
atModifierUsed = true
|
||||
}
|
||||
if !ng.enableNegativeOffset && n.OriginalOffset < 0 {
|
||||
validationErr = ErrValidationNegativeOffsetDisabled
|
||||
return validationErr
|
||||
if n.OriginalOffset < 0 {
|
||||
negativeOffsetUsed = true
|
||||
}
|
||||
|
||||
case *parser.MatrixSelector:
|
||||
vs := n.VectorSelector.(*parser.VectorSelector)
|
||||
if !ng.enableAtModifier &&
|
||||
(vs.Timestamp != nil || vs.StartOrEnd == parser.START || vs.StartOrEnd == parser.END) {
|
||||
if vs.Timestamp != nil || vs.StartOrEnd == parser.START || vs.StartOrEnd == parser.END {
|
||||
atModifierUsed = true
|
||||
}
|
||||
if vs.OriginalOffset < 0 {
|
||||
negativeOffsetUsed = true
|
||||
}
|
||||
|
||||
case *parser.SubqueryExpr:
|
||||
if n.Timestamp != nil || n.StartOrEnd == parser.START || n.StartOrEnd == parser.END {
|
||||
atModifierUsed = true
|
||||
}
|
||||
if n.OriginalOffset < 0 {
|
||||
negativeOffsetUsed = true
|
||||
}
|
||||
}
|
||||
|
||||
if atModifierUsed && !ng.enableAtModifier {
|
||||
validationErr = ErrValidationAtModifierDisabled
|
||||
return validationErr
|
||||
}
|
||||
if !ng.enableNegativeOffset && vs.OriginalOffset < 0 {
|
||||
if negativeOffsetUsed && !ng.enableNegativeOffset {
|
||||
validationErr = ErrValidationNegativeOffsetDisabled
|
||||
return validationErr
|
||||
}
|
||||
|
||||
case *parser.SubqueryExpr:
|
||||
if !ng.enableAtModifier &&
|
||||
(n.Timestamp != nil || n.StartOrEnd == parser.START || n.StartOrEnd == parser.END) {
|
||||
validationErr = ErrValidationAtModifierDisabled
|
||||
return validationErr
|
||||
}
|
||||
if !ng.enableNegativeOffset && n.OriginalOffset < 0 {
|
||||
validationErr = ErrValidationNegativeOffsetDisabled
|
||||
return validationErr
|
||||
}
|
||||
}
|
||||
return nil
|
||||
})
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user