2021-11-24 09:56:53 -06:00
|
|
|
package loki
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"math"
|
|
|
|
"strconv"
|
|
|
|
"strings"
|
|
|
|
"time"
|
|
|
|
|
|
|
|
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
|
|
|
"github.com/grafana/grafana/pkg/tsdb/intervalv2"
|
|
|
|
)
|
|
|
|
|
|
|
|
const (
|
|
|
|
varInterval = "$__interval"
|
|
|
|
varIntervalMs = "$__interval_ms"
|
|
|
|
varRange = "$__range"
|
|
|
|
varRangeS = "$__range_s"
|
|
|
|
varRangeMs = "$__range_ms"
|
|
|
|
)
|
|
|
|
|
2021-12-09 08:16:01 -06:00
|
|
|
const (
|
|
|
|
varIntervalAlt = "${__interval}"
|
|
|
|
varIntervalMsAlt = "${__interval_ms}"
|
|
|
|
varRangeAlt = "${__range}"
|
|
|
|
varRangeSAlt = "${__range_s}"
|
|
|
|
varRangeMsAlt = "${__range_ms}"
|
|
|
|
)
|
|
|
|
|
2021-11-24 09:56:53 -06:00
|
|
|
func interpolateVariables(expr string, interval time.Duration, timeRange time.Duration) string {
|
|
|
|
intervalText := intervalv2.FormatDuration(interval)
|
|
|
|
intervalMsText := strconv.FormatInt(int64(interval/time.Millisecond), 10)
|
|
|
|
|
|
|
|
rangeMs := timeRange.Milliseconds()
|
|
|
|
rangeSRounded := int64(math.Round(float64(rangeMs) / 1000.0))
|
|
|
|
rangeMsText := strconv.FormatInt(rangeMs, 10)
|
|
|
|
rangeSText := strconv.FormatInt(rangeSRounded, 10)
|
|
|
|
|
|
|
|
expr = strings.ReplaceAll(expr, varIntervalMs, intervalMsText)
|
|
|
|
expr = strings.ReplaceAll(expr, varInterval, intervalText)
|
|
|
|
expr = strings.ReplaceAll(expr, varRangeMs, rangeMsText)
|
|
|
|
expr = strings.ReplaceAll(expr, varRangeS, rangeSText)
|
|
|
|
expr = strings.ReplaceAll(expr, varRange, rangeSText+"s")
|
|
|
|
|
2021-12-09 08:16:01 -06:00
|
|
|
// this is duplicated code, hopefully this can be handled in a nicer way when
|
|
|
|
// https://github.com/grafana/grafana/issues/42928 is done.
|
|
|
|
expr = strings.ReplaceAll(expr, varIntervalMsAlt, intervalMsText)
|
|
|
|
expr = strings.ReplaceAll(expr, varIntervalAlt, intervalText)
|
|
|
|
expr = strings.ReplaceAll(expr, varRangeMsAlt, rangeMsText)
|
|
|
|
expr = strings.ReplaceAll(expr, varRangeSAlt, rangeSText)
|
|
|
|
expr = strings.ReplaceAll(expr, varRangeAlt, rangeSText+"s")
|
2021-11-24 09:56:53 -06:00
|
|
|
return expr
|
|
|
|
}
|
|
|
|
|
2021-12-09 06:16:52 -06:00
|
|
|
func parseQuery(queryContext *backend.QueryDataRequest) ([]*lokiQuery, error) {
|
2021-11-24 09:56:53 -06:00
|
|
|
qs := []*lokiQuery{}
|
|
|
|
for _, query := range queryContext.Queries {
|
2021-12-07 00:57:52 -06:00
|
|
|
model := &QueryModel{}
|
2021-11-24 09:56:53 -06:00
|
|
|
err := json.Unmarshal(query.JSON, model)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
start := query.TimeRange.From
|
|
|
|
end := query.TimeRange.To
|
|
|
|
|
|
|
|
var resolution int64 = 1
|
|
|
|
if model.Resolution >= 1 && model.Resolution <= 5 || model.Resolution == 10 {
|
|
|
|
resolution = model.Resolution
|
|
|
|
}
|
|
|
|
|
|
|
|
interval := query.Interval
|
|
|
|
timeRange := query.TimeRange.To.Sub(query.TimeRange.From)
|
|
|
|
|
|
|
|
step := calculateStep(interval, timeRange, resolution)
|
|
|
|
|
|
|
|
expr := interpolateVariables(model.Expr, interval, timeRange)
|
|
|
|
|
|
|
|
qs = append(qs, &lokiQuery{
|
|
|
|
Expr: expr,
|
|
|
|
Step: step,
|
|
|
|
LegendFormat: model.LegendFormat,
|
|
|
|
Start: start,
|
|
|
|
End: end,
|
|
|
|
RefID: query.RefID,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
return qs, nil
|
|
|
|
}
|