-
Notifications
You must be signed in to change notification settings - Fork 3
/
engine_literal_query.go
62 lines (52 loc) · 1.36 KB
/
engine_literal_query.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
package logqlengine
import (
"context"
"strconv"
"time"
"github.com/go-faster/oteldb/internal/lokiapi"
)
// LiteralQuery is simple literal expression query.
type LiteralQuery struct {
Value float64
}
var _ Query = (*LiteralQuery)(nil)
// Eval implements [Query].
func (q *LiteralQuery) Eval(ctx context.Context, params EvalParams) (data lokiapi.QueryResponseData, _ error) {
if params.IsInstant() {
data.SetScalarResult(lokiapi.ScalarResult{
Result: lokiapi.FPoint{
T: getPrometheusTimestamp(params.Start),
V: strconv.FormatFloat(q.Value, 'f', -1, 64),
},
})
return data, nil
}
data.SetMatrixResult(lokiapi.MatrixResult{
Result: generateLiteralMatrix(q.Value, params),
})
return data, nil
}
func generateLiteralMatrix(value float64, params EvalParams) lokiapi.Matrix {
var (
start = params.Start
end = params.End
series = lokiapi.Series{
Metric: lokiapi.NewOptLabelSet(lokiapi.LabelSet{}),
}
)
var (
until = end.Add(params.Step)
strValue = strconv.FormatFloat(value, 'f', -1, 64)
)
for ts := start; !ts.After(until); ts = ts.Add(params.Step) {
series.Values = append(series.Values, lokiapi.FPoint{
T: getPrometheusTimestamp(ts),
V: strValue,
})
}
return lokiapi.Matrix{series}
}
func getPrometheusTimestamp(t time.Time) float64 {
// Pass milliseconds as fraction part.
return float64(t.UnixMilli()) / 1000
}