2018-03-23 23:50:16 +08:00
|
|
|
package elasticsearch
|
|
|
|
|
|
|
|
import (
|
|
|
|
"context"
|
|
|
|
"fmt"
|
2018-05-23 20:36:41 +08:00
|
|
|
|
2021-05-20 05:53:41 +08:00
|
|
|
"github.com/grafana/grafana/pkg/infra/httpclient"
|
2018-05-23 20:36:41 +08:00
|
|
|
"github.com/grafana/grafana/pkg/models"
|
2021-03-08 14:02:49 +08:00
|
|
|
"github.com/grafana/grafana/pkg/plugins"
|
2019-10-02 19:59:05 +08:00
|
|
|
es "github.com/grafana/grafana/pkg/tsdb/elasticsearch/client"
|
2021-03-08 14:02:49 +08:00
|
|
|
"github.com/grafana/grafana/pkg/tsdb/interval"
|
2018-03-23 23:50:16 +08:00
|
|
|
)
|
|
|
|
|
2018-05-23 21:09:58 +08:00
|
|
|
// ElasticsearchExecutor represents a handler for handling elasticsearch datasource request
|
2021-03-08 14:02:49 +08:00
|
|
|
type Executor struct {
|
2021-05-20 05:53:41 +08:00
|
|
|
httpClientProvider httpclient.Provider
|
2021-03-08 14:02:49 +08:00
|
|
|
intervalCalculator interval.Calculator
|
2018-03-23 23:50:16 +08:00
|
|
|
}
|
|
|
|
|
2021-05-20 05:53:41 +08:00
|
|
|
// New creates a new Executor func.
|
|
|
|
// nolint:staticcheck // plugins.DataPlugin deprecated
|
|
|
|
func New(httpClientProvider httpclient.Provider) func(*models.DataSource) (plugins.DataPlugin, error) {
|
|
|
|
// nolint:staticcheck // plugins.DataPlugin deprecated
|
|
|
|
return func(dsInfo *models.DataSource) (plugins.DataPlugin, error) {
|
|
|
|
return &Executor{
|
|
|
|
httpClientProvider: httpClientProvider,
|
|
|
|
intervalCalculator: interval.NewCalculator(),
|
|
|
|
}, nil
|
|
|
|
}
|
2018-03-23 23:50:16 +08:00
|
|
|
}
|
|
|
|
|
2018-05-23 21:09:58 +08:00
|
|
|
// Query handles an elasticsearch datasource request
|
2021-04-23 09:03:11 +08:00
|
|
|
//nolint: staticcheck // plugins.DataResponse deprecated
|
2021-03-08 14:02:49 +08:00
|
|
|
func (e *Executor) DataQuery(ctx context.Context, dsInfo *models.DataSource,
|
|
|
|
tsdbQuery plugins.DataQuery) (plugins.DataResponse, error) {
|
2018-05-23 20:36:41 +08:00
|
|
|
if len(tsdbQuery.Queries) == 0 {
|
2021-03-08 14:02:49 +08:00
|
|
|
return plugins.DataResponse{}, fmt.Errorf("query contains no queries")
|
2018-03-26 19:48:57 +08:00
|
|
|
}
|
|
|
|
|
2021-05-20 05:53:41 +08:00
|
|
|
client, err := es.NewClient(ctx, e.httpClientProvider, dsInfo, *tsdbQuery.TimeRange)
|
2018-03-23 23:50:16 +08:00
|
|
|
if err != nil {
|
2021-03-08 14:02:49 +08:00
|
|
|
return plugins.DataResponse{}, err
|
2018-03-23 23:50:16 +08:00
|
|
|
}
|
|
|
|
|
2019-06-25 14:52:17 +08:00
|
|
|
if tsdbQuery.Debug {
|
|
|
|
client.EnableDebug()
|
|
|
|
}
|
|
|
|
|
2021-03-08 14:02:49 +08:00
|
|
|
query := newTimeSeriesQuery(client, tsdbQuery, e.intervalCalculator)
|
2018-05-23 21:09:58 +08:00
|
|
|
return query.execute()
|
2018-03-23 23:50:16 +08:00
|
|
|
}
|