query temp data across multiple buckets

pull/228/head
Jason Kulatunga 3 years ago
parent 03bfdd3890
commit bff83de3a0

@ -15,6 +15,7 @@ import (
"gorm.io/driver/sqlite" "gorm.io/driver/sqlite"
"gorm.io/gorm" "gorm.io/gorm"
"gorm.io/gorm/clause" "gorm.io/gorm/clause"
"strings"
"time" "time"
) )
@ -520,19 +521,7 @@ func (sr *scrutinyRepository) GetSmartTemperatureHistory(ctx context.Context, du
deviceTempHistory := map[string][]measurements.SmartTemperature{} deviceTempHistory := map[string][]measurements.SmartTemperature{}
//TODO: change the query range to a variable. //TODO: change the query range to a variable.
queryStr := fmt.Sprintf(` queryStr := sr.aggregateTempQuery(durationKey)
import "influxdata/influxdb/schema"
from(bucket: "%s")
|> range(start: %s, stop: now())
|> filter(fn: (r) => r["_measurement"] == "temp" )
|> aggregateWindow(every: 1h, fn: mean, createEmpty: false)
|> schema.fieldsAsCols()
|> group(columns: ["device_wwn"])
|> yield(name: "last")
`,
sr.lookupBucketName(durationKey),
sr.lookupDuration(durationKey),
)
result, err := sr.influxQueryApi.Query(ctx, queryStr) result, err := sr.influxQueryApi.Query(ctx, queryStr)
if err == nil { if err == nil {
@ -671,21 +660,96 @@ func (sr *scrutinyRepository) lookupBucketName(durationKey string) string {
return sr.appConfig.GetString("web.influxdb.bucket") return sr.appConfig.GetString("web.influxdb.bucket")
} }
func (sr *scrutinyRepository) lookupDuration(durationKey string) string { func (sr *scrutinyRepository) lookupDuration(durationKey string) []string {
switch durationKey { switch durationKey {
case "week": case "week":
//data stored in the last week //data stored in the last week
return "-1w" return []string{"-1w", "now()"}
case "month": case "month":
// data stored in the last month (after the first week) // data stored in the last month (after the first week)
return "-1mo" return []string{"-1mo", "-1w"}
case "year":
// data stored in the last year (after the first month)
return []string{"-1y", "-1mo"}
case "forever":
//data stored before the last year
return []string{"-10y", "-1y"}
}
return []string{"-1w", "now()"}
}
func (sr *scrutinyRepository) lookupNestedDurationKeys(durationKey string) []string {
switch durationKey {
case "week":
//all data is stored in a single bucket
return []string{"week"}
case "month":
//data is stored in the week bucket and the month bucket
return []string{"week", "month"}
case "year": case "year":
// data stored in the last year (after the first month) // data stored in the last year (after the first month)
return "-1y" return []string{"week", "month", "year"}
case "forever": case "forever":
//data stored before the last year //data stored before the last year
return "-10y" return []string{"week", "month", "year"}
}
return []string{"week"}
} }
return "-1w"
func (sr *scrutinyRepository) aggregateTempQuery(durationKey string) string {
//TODO: change the query range to a variable.
//queryStr := fmt.Sprintf(`
//import "influxdata/influxdb/schema"
//from(bucket: "%s")
//|> range(start: %s, stop: now())
//|> filter(fn: (r) => r["_measurement"] == "temp" )
//|> aggregateWindow(every: 1h, fn: mean, createEmpty: false)
//|> schema.fieldsAsCols()
//|> group(columns: ["device_wwn"])
//|> yield(name: "last")
// `,
// sr.lookupBucketName(durationKey),
// sr.lookupDuration(durationKey),
//)
partialQueryStr := []string{`import "influxdata/influxdb/schema"`}
nestedDurationKeys := sr.lookupNestedDurationKeys(durationKey)
subQueryNames := []string{}
for _, nestedDurationKey := range nestedDurationKeys {
bucketName := sr.lookupBucketName(nestedDurationKey)
durationRange := sr.lookupDuration(nestedDurationKey)
subQueryNames = append(subQueryNames, fmt.Sprintf(`%sData`, nestedDurationKey))
partialQueryStr = append(partialQueryStr, []string{
fmt.Sprintf(`%sData = from(bucket: "%s")`, nestedDurationKey, bucketName),
fmt.Sprintf(`|> range(start: %s, stop: %s)`, durationRange[0], durationRange[1]),
`|> filter(fn: (r) => r["_measurement"] == "temp" )`,
`|> aggregateWindow(every: 1h, fn: mean, createEmpty: false)`,
`|> group(columns: ["device_wwn"])`,
`|> toInt()`,
"",
}...)
}
if len(subQueryNames) == 1 {
//there's only one bucket being queried, no need to union, just aggregate the dataset and return
partialQueryStr = append(partialQueryStr, []string{
subQueryNames[0],
"|> schema.fieldsAsCols()",
"|> yield()",
}...)
} else {
partialQueryStr = append(partialQueryStr, []string{
fmt.Sprintf("union(tables: [%s])", strings.Join(subQueryNames, ", ")),
`|> group(columns: ["device_wwn"])`,
`|> sort(columns: ["_time"], desc: false)`,
"|> schema.fieldsAsCols()",
}...)
}
return strings.Join(partialQueryStr, "\n")
} }

Loading…
Cancel
Save