| 
									
										
										
										
											2015-01-06 16:11:00 +08:00
										 |  |  | package api | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2016-10-03 15:38:03 +08:00
										 |  |  | 	"context" | 
					
						
							| 
									
										
										
										
											2020-07-24 18:34:56 +08:00
										 |  |  | 	"errors" | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 	"net/http" | 
					
						
							| 
									
										
										
										
											2016-06-03 21:06:57 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-31 23:35:03 +08:00
										 |  |  | 	"github.com/grafana/grafana-plugin-sdk-go/backend" | 
					
						
							| 
									
										
										
										
											2020-11-19 20:17:00 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/expr" | 
					
						
							| 
									
										
										
										
											2020-03-04 19:57:20 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/models" | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/plugins" | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-06-03 21:06:57 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/api/dtos" | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/api/response" | 
					
						
							| 
									
										
										
										
											2017-03-30 04:54:07 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/bus" | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/components/simplejson" | 
					
						
							| 
									
										
										
										
											2016-06-04 03:22:34 +08:00
										 |  |  | 	"github.com/grafana/grafana/pkg/util" | 
					
						
							| 
									
										
										
										
											2015-01-06 16:11:00 +08:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-13 22:20:25 +08:00
										 |  |  | // QueryMetricsV2 returns query metrics.
 | 
					
						
							| 
									
										
										
										
											2019-11-01 07:22:00 +08:00
										 |  |  | // POST /api/ds/query   DataSource query w/ expressions
 | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | func (hs *HTTPServer) QueryMetricsV2(c *models.ReqContext, reqDTO dtos.MetricRequest) response.Response { | 
					
						
							| 
									
										
										
										
											2021-01-13 22:20:25 +08:00
										 |  |  | 	if len(reqDTO.Queries) == 0 { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 		return response.Error(http.StatusBadRequest, "No queries found in query", nil) | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	timeRange := plugins.NewDataTimeRange(reqDTO.From, reqDTO.To) | 
					
						
							|  |  |  | 	request := plugins.DataQuery{ | 
					
						
							|  |  |  | 		TimeRange: &timeRange, | 
					
						
							| 
									
										
										
										
											2021-01-13 22:20:25 +08:00
										 |  |  | 		Debug:     reqDTO.Debug, | 
					
						
							| 
									
										
										
										
											2020-03-06 21:37:36 +08:00
										 |  |  | 		User:      c.SignedInUser, | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 		Queries:   make([]plugins.DataSubQuery, 0, len(reqDTO.Queries)), | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	// Loop to see if we have an expression.
 | 
					
						
							|  |  |  | 	for _, query := range reqDTO.Queries { | 
					
						
							|  |  |  | 		if query.Get("datasource").MustString("") == expr.DatasourceName { | 
					
						
							|  |  |  | 			return hs.handleExpressions(c, reqDTO) | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-04 19:57:20 +08:00
										 |  |  | 	var ds *models.DataSource | 
					
						
							| 
									
										
										
										
											2021-01-13 22:20:25 +08:00
										 |  |  | 	for i, query := range reqDTO.Queries { | 
					
						
							| 
									
										
										
										
											2020-07-24 18:34:56 +08:00
										 |  |  | 		hs.log.Debug("Processing metrics query", "query", query) | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 		datasourceID, err := query.Get("datasourceId").Int64() | 
					
						
							|  |  |  | 		if err != nil { | 
					
						
							| 
									
										
										
										
											2020-07-24 18:34:56 +08:00
										 |  |  | 			hs.log.Debug("Can't process query since it's missing data source ID") | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 			return response.Error(http.StatusBadRequest, "Query missing data source ID", nil) | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 		// For mixed datasource case, each data source is sent in a single request.
 | 
					
						
							|  |  |  | 		// So only the datasource from the first query is needed. As all requests
 | 
					
						
							|  |  |  | 		// should be the same data source.
 | 
					
						
							|  |  |  | 		if i == 0 { | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 			ds, err = hs.DatasourceCache.GetDatasource(datasourceID, c.SignedInUser, c.SkipCache) | 
					
						
							|  |  |  | 			if err != nil { | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 				return hs.handleGetDataSourceError(err, datasourceID) | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2020-03-04 19:57:20 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 		request.Queries = append(request.Queries, plugins.DataSubQuery{ | 
					
						
							|  |  |  | 			RefID:         query.Get("refId").MustString("A"), | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 			MaxDataPoints: query.Get("maxDataPoints").MustInt64(100), | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 			IntervalMS:    query.Get("intervalMs").MustInt64(1000), | 
					
						
							| 
									
										
										
										
											2020-05-05 16:32:34 +08:00
										 |  |  | 			QueryType:     query.Get("queryType").MustString(""), | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 			Model:         query, | 
					
						
							|  |  |  | 			DataSource:    ds, | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 	err := hs.PluginRequestValidator.Validate(ds.Url, nil) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return response.Error(http.StatusForbidden, "Access denied", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	resp, err := hs.DataService.HandleRequest(c.Req.Context(), ds, request) | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 		return response.Error(http.StatusInternalServerError, "Metric request error", err) | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-31 23:35:03 +08:00
										 |  |  | 	// This is insanity... but ¯\_(ツ)_/¯, the current query path looks like:
 | 
					
						
							|  |  |  | 	//  encodeJson( decodeBase64( encodeBase64( decodeArrow( encodeArrow(frame)) ) )
 | 
					
						
							|  |  |  | 	// this will soon change to a more direct route
 | 
					
						
							|  |  |  | 	qdr, err := resp.ToBackendDataResponse() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return response.Error(http.StatusInternalServerError, "error converting results", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return toMacronResponse(qdr) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func toMacronResponse(qdr *backend.QueryDataResponse) response.Response { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 	statusCode := http.StatusOK | 
					
						
							| 
									
										
										
										
											2021-03-31 23:35:03 +08:00
										 |  |  | 	for _, res := range qdr.Responses { | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 		if res.Error != nil { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 			statusCode = http.StatusBadRequest | 
					
						
							| 
									
										
										
										
											2020-03-13 22:43:25 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2020-03-13 22:43:25 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-31 23:35:03 +08:00
										 |  |  | 	return response.JSONStreaming(statusCode, qdr) | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // handleExpressions handles POST /api/ds/query when there is an expression.
 | 
					
						
							|  |  |  | func (hs *HTTPServer) handleExpressions(c *models.ReqContext, reqDTO dtos.MetricRequest) response.Response { | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	timeRange := plugins.NewDataTimeRange(reqDTO.From, reqDTO.To) | 
					
						
							|  |  |  | 	request := plugins.DataQuery{ | 
					
						
							|  |  |  | 		TimeRange: &timeRange, | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 		Debug:     reqDTO.Debug, | 
					
						
							|  |  |  | 		User:      c.SignedInUser, | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 		Queries:   make([]plugins.DataSubQuery, 0, len(reqDTO.Queries)), | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for _, query := range reqDTO.Queries { | 
					
						
							|  |  |  | 		hs.log.Debug("Processing metrics query", "query", query) | 
					
						
							|  |  |  | 		name := query.Get("datasource").MustString("") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		datasourceID, err := query.Get("datasourceId").Int64() | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 		if err != nil { | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 			hs.log.Debug("Can't process query since it's missing data source ID") | 
					
						
							|  |  |  | 			return response.Error(400, "Query missing data source ID", nil) | 
					
						
							| 
									
										
										
										
											2019-10-31 02:38:28 +08:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		if name != expr.DatasourceName { | 
					
						
							|  |  |  | 			// Expression requests have everything in one request, so need to check
 | 
					
						
							|  |  |  | 			// all data source queries for possible permission / not found issues.
 | 
					
						
							|  |  |  | 			if _, err = hs.DatasourceCache.GetDatasource(datasourceID, c.SignedInUser, c.SkipCache); err != nil { | 
					
						
							|  |  |  | 				return hs.handleGetDataSourceError(err, datasourceID) | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 		request.Queries = append(request.Queries, plugins.DataSubQuery{ | 
					
						
							|  |  |  | 			RefID:         query.Get("refId").MustString("A"), | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 			MaxDataPoints: query.Get("maxDataPoints").MustInt64(100), | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 			IntervalMS:    query.Get("intervalMs").MustInt64(1000), | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 			QueryType:     query.Get("queryType").MustString(""), | 
					
						
							|  |  |  | 			Model:         query, | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	exprService := expr.Service{ | 
					
						
							|  |  |  | 		Cfg:         hs.Cfg, | 
					
						
							|  |  |  | 		DataService: hs.DataService, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-03-31 23:35:03 +08:00
										 |  |  | 	qdr, err := exprService.WrapTransformData(c.Req.Context(), request) | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return response.Error(500, "expression request error", err) | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-03-31 23:35:03 +08:00
										 |  |  | 	return toMacronResponse(qdr) | 
					
						
							| 
									
										
										
										
											2019-10-25 21:28:26 +08:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | func (hs *HTTPServer) handleGetDataSourceError(err error, datasourceID int64) *response.NormalResponse { | 
					
						
							|  |  |  | 	hs.log.Debug("Encountered error getting data source", "err", err, "id", datasourceID) | 
					
						
							|  |  |  | 	if errors.Is(err, models.ErrDataSourceAccessDenied) { | 
					
						
							|  |  |  | 		return response.Error(403, "Access denied to data source", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	if errors.Is(err, models.ErrDataSourceNotFound) { | 
					
						
							|  |  |  | 		return response.Error(400, "Invalid data source ID", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return response.Error(500, "Unable to load data source metadata", err) | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 21:37:36 +08:00
										 |  |  | // QueryMetrics returns query metrics
 | 
					
						
							| 
									
										
										
										
											2016-09-28 00:17:39 +08:00
										 |  |  | // POST /api/tsdb/query
 | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | func (hs *HTTPServer) QueryMetrics(c *models.ReqContext, reqDto dtos.MetricRequest) response.Response { | 
					
						
							| 
									
										
										
										
											2017-03-30 04:54:07 +08:00
										 |  |  | 	if len(reqDto.Queries) == 0 { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 		return response.Error(http.StatusBadRequest, "No queries found in query", nil) | 
					
						
							| 
									
										
										
										
											2017-03-30 04:54:07 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-09-14 15:30:32 +08:00
										 |  |  | 	datasourceId, err := reqDto.Queries[0].Get("datasourceId").Int64() | 
					
						
							| 
									
										
										
										
											2017-03-30 04:54:07 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 		return response.Error(http.StatusBadRequest, "Query missing datasourceId", nil) | 
					
						
							| 
									
										
										
										
											2017-03-30 04:54:07 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-10-26 16:40:33 +08:00
										 |  |  | 	ds, err := hs.DatasourceCache.GetDatasource(datasourceId, c.SignedInUser, c.SkipCache) | 
					
						
							| 
									
										
										
										
											2018-09-14 15:30:32 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2021-01-20 03:18:06 +08:00
										 |  |  | 		return hs.handleGetDataSourceError(err, datasourceId) | 
					
						
							| 
									
										
										
										
											2017-03-30 04:54:07 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 	err = hs.PluginRequestValidator.Validate(ds.Url, nil) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return response.Error(http.StatusForbidden, "Access denied", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	timeRange := plugins.NewDataTimeRange(reqDto.From, reqDto.To) | 
					
						
							|  |  |  | 	request := plugins.DataQuery{ | 
					
						
							|  |  |  | 		TimeRange: &timeRange, | 
					
						
							| 
									
										
										
										
											2020-03-06 21:37:36 +08:00
										 |  |  | 		Debug:     reqDto.Debug, | 
					
						
							|  |  |  | 		User:      c.SignedInUser, | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2016-09-28 00:17:39 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	for _, query := range reqDto.Queries { | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 		request.Queries = append(request.Queries, plugins.DataSubQuery{ | 
					
						
							|  |  |  | 			RefID:         query.Get("refId").MustString("A"), | 
					
						
							| 
									
										
										
										
											2016-09-28 00:17:39 +08:00
										 |  |  | 			MaxDataPoints: query.Get("maxDataPoints").MustInt64(100), | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 			IntervalMS:    query.Get("intervalMs").MustInt64(1000), | 
					
						
							| 
									
										
										
										
											2016-09-28 00:17:39 +08:00
										 |  |  | 			Model:         query, | 
					
						
							| 
									
										
										
										
											2018-09-14 15:30:32 +08:00
										 |  |  | 			DataSource:    ds, | 
					
						
							| 
									
										
										
										
											2016-09-28 00:17:39 +08:00
										 |  |  | 		}) | 
					
						
							| 
									
										
										
										
											2016-09-27 20:39:51 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	resp, err := hs.DataService.HandleRequest(c.Req.Context(), ds, request) | 
					
						
							| 
									
										
										
										
											2016-09-27 20:39:51 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 		return response.Error(http.StatusInternalServerError, "Metric request error", err) | 
					
						
							| 
									
										
										
										
											2016-09-27 20:39:51 +08:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-01-06 16:11:00 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 	statusCode := http.StatusOK | 
					
						
							| 
									
										
										
										
											2017-03-31 17:45:25 +08:00
										 |  |  | 	for _, res := range resp.Results { | 
					
						
							|  |  |  | 		if res.Error != nil { | 
					
						
							|  |  |  | 			res.ErrorString = res.Error.Error() | 
					
						
							| 
									
										
										
										
											2017-04-20 23:10:09 +08:00
										 |  |  | 			resp.Message = res.ErrorString | 
					
						
							| 
									
										
										
										
											2021-02-04 03:47:45 +08:00
										 |  |  | 			statusCode = http.StatusBadRequest | 
					
						
							| 
									
										
										
										
											2017-03-31 17:45:25 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | 	return response.JSON(statusCode, &resp) | 
					
						
							| 
									
										
										
										
											2016-09-28 00:17:39 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2016-09-27 20:39:51 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-03-31 02:23:40 +08:00
										 |  |  | // GET /api/tsdb/testdata/gensql
 | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | func GenerateSQLTestData(c *models.ReqContext) response.Response { | 
					
						
							| 
									
										
										
										
											2020-11-11 13:21:08 +08:00
										 |  |  | 	if err := bus.Dispatch(&models.InsertSQLTestDataCommand{}); err != nil { | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | 		return response.Error(500, "Failed to insert test data", err) | 
					
						
							| 
									
										
										
										
											2017-03-31 02:23:40 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | 	return response.JSON(200, &util.DynMap{"message": "OK"}) | 
					
						
							| 
									
										
										
										
											2017-03-31 02:23:40 +08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 
 | 
					
						
							|  |  |  | // GET /api/tsdb/testdata/random-walk
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | func (hs *HTTPServer) GetTestDataRandomWalk(c *models.ReqContext) response.Response { | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 	from := c.Query("from") | 
					
						
							|  |  |  | 	to := c.Query("to") | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	intervalMS := c.QueryInt64("intervalMs") | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	timeRange := plugins.NewDataTimeRange(from, to) | 
					
						
							|  |  |  | 	request := plugins.DataQuery{TimeRange: &timeRange} | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-30 01:33:23 +08:00
										 |  |  | 	dsInfo := &models.DataSource{ | 
					
						
							|  |  |  | 		Type:     "testdata", | 
					
						
							|  |  |  | 		JsonData: simplejson.New(), | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	request.Queries = append(request.Queries, plugins.DataSubQuery{ | 
					
						
							|  |  |  | 		RefID:      "A", | 
					
						
							|  |  |  | 		IntervalMS: intervalMS, | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 		Model: simplejson.NewFromAny(&util.DynMap{ | 
					
						
							|  |  |  | 			"scenario": "random_walk", | 
					
						
							|  |  |  | 		}), | 
					
						
							| 
									
										
										
										
											2017-09-22 00:04:06 +08:00
										 |  |  | 		DataSource: dsInfo, | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 	}) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-08 14:02:49 +08:00
										 |  |  | 	resp, err := hs.DataService.HandleRequest(context.Background(), dsInfo, request) | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2021-01-15 21:43:20 +08:00
										 |  |  | 		return response.Error(500, "Metric request error", err) | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-20 12:59:43 +08:00
										 |  |  | 	qdr, err := resp.ToBackendDataResponse() | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		return response.Error(http.StatusInternalServerError, "error converting results", err) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return toMacronResponse(qdr) | 
					
						
							| 
									
										
										
										
											2017-05-29 16:48:38 +08:00
										 |  |  | } |