mirror of
https://github.com/grafana/grafana.git
synced 2025-02-25 18:55:37 -06:00
* Prometheus: remove scope dependency temp workaround * depguard * comment * remove rules since they need a newer version of golangci-lint --------- Co-authored-by: ismail simsek <ismailsimsek09@gmail.com>
85 lines
1.9 KiB
Go
85 lines
1.9 KiB
Go
package models
|
|
|
|
import (
|
|
"fmt"
|
|
|
|
"github.com/prometheus/prometheus/model/labels"
|
|
"github.com/prometheus/prometheus/promql/parser"
|
|
)
|
|
|
|
func ApplyQueryScope(rawExpr string, scope ScopeSpec) (string, error) {
|
|
expr, err := parser.ParseExpr(rawExpr)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
matchers, err := scopeFiltersToMatchers(scope.Filters)
|
|
if err != nil {
|
|
return "", err
|
|
}
|
|
|
|
matcherNamesToIdx := make(map[string]int, len(matchers))
|
|
for i, matcher := range matchers {
|
|
if matcher == nil {
|
|
continue
|
|
}
|
|
matcherNamesToIdx[matcher.Name] = i
|
|
}
|
|
|
|
parser.Inspect(expr, func(node parser.Node, nodes []parser.Node) error {
|
|
switch v := node.(type) {
|
|
case *parser.VectorSelector:
|
|
found := make([]bool, len(matchers))
|
|
for _, matcher := range v.LabelMatchers {
|
|
if matcher == nil || matcher.Name == "__name__" { // const prob
|
|
continue
|
|
}
|
|
if _, ok := matcherNamesToIdx[matcher.Name]; ok {
|
|
found[matcherNamesToIdx[matcher.Name]] = true
|
|
newM := matchers[matcherNamesToIdx[matcher.Name]]
|
|
matcher.Name = newM.Name
|
|
matcher.Type = newM.Type
|
|
matcher.Value = newM.Value
|
|
}
|
|
}
|
|
for i, f := range found {
|
|
if f {
|
|
continue
|
|
}
|
|
v.LabelMatchers = append(v.LabelMatchers, matchers[i])
|
|
}
|
|
|
|
return nil
|
|
|
|
default:
|
|
return nil
|
|
}
|
|
})
|
|
return expr.String(), nil
|
|
}
|
|
|
|
func scopeFiltersToMatchers(filters []ScopeFilter) ([]*labels.Matcher, error) {
|
|
matchers := make([]*labels.Matcher, 0, len(filters))
|
|
for _, f := range filters {
|
|
var mt labels.MatchType
|
|
switch f.Operator {
|
|
case "=":
|
|
mt = labels.MatchEqual
|
|
case "!=":
|
|
mt = labels.MatchNotEqual
|
|
case "=~":
|
|
mt = labels.MatchRegexp
|
|
case "!~":
|
|
mt = labels.MatchNotRegexp
|
|
default:
|
|
return nil, fmt.Errorf("unknown operator %q", f.Operator)
|
|
}
|
|
m, err := labels.NewMatcher(mt, f.Key, f.Value)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
matchers = append(matchers, m)
|
|
}
|
|
return matchers, nil
|
|
}
|