560be84dc8
* CloudWatch: Backport aws-sdk-go-v2 update from external plugin (#107136) (cherry picked froma18ea34688) * Datasources: Update grafana-aws-sdk for new sigv4 middleware and aws-sdk-go v1 removal (#107522) (cherry picked from commit66d9a33cc9) * CloudWatch: Fix proxy transport issue (#107807) (cherry picked fromc3eeb1fcd9) * CloudWatch: Fix http client handling + assume role bug (#107893) (cherry picked from commitf34a9fc0c2) * CloudWatch: Use default region when query region is unset (#109089) (cherry picked from commit5f4097a159) * CloudWatch: Fix handling region for legacy alerts (#109217) (cherry picked from commit2bf9aea8ef) * Update go.mod owners --------- Co-authored-by: Isabella Siu <Isabella.siu@grafana.com>
35 lines
1.0 KiB
Go
35 lines
1.0 KiB
Go
package utils
|
|
|
|
import (
|
|
"github.com/grafana/grafana-plugin-sdk-go/backend"
|
|
"github.com/prometheus/client_golang/prometheus"
|
|
"github.com/prometheus/client_golang/prometheus/promauto"
|
|
)
|
|
|
|
const GetMetricDataLabel = "get_metric_data"
|
|
|
|
var QueriesTotalCounter = promauto.NewCounterVec(
|
|
prometheus.CounterOpts{
|
|
Namespace: "grafana_plugin",
|
|
Name: "aws_cloudwatch_queries_total",
|
|
Help: "Counter for AWS Queries",
|
|
},
|
|
[]string{"query_type"},
|
|
)
|
|
|
|
// BatchDataQueriesByTimeRange separates the passed in queries into batches based on time ranges
|
|
func BatchDataQueriesByTimeRange(queries []backend.DataQuery) [][]backend.DataQuery {
|
|
timeToBatch := make(map[backend.TimeRange][]backend.DataQuery)
|
|
|
|
for _, query := range queries {
|
|
key := backend.TimeRange{From: query.TimeRange.From.UTC(), To: query.TimeRange.To.UTC()}
|
|
timeToBatch[key] = append(timeToBatch[key], query)
|
|
}
|
|
|
|
finalBatches := [][]backend.DataQuery{}
|
|
for _, batch := range timeToBatch {
|
|
finalBatches = append(finalBatches, batch)
|
|
}
|
|
return finalBatches
|
|
}
|