metric_descriptors_query.go 2.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. package stackdriver
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "io/ioutil"
  7. "net/http"
  8. "strings"
  9. "github.com/grafana/grafana/pkg/cmd/grafana-cli/logger"
  10. "github.com/grafana/grafana/pkg/components/simplejson"
  11. "golang.org/x/net/context/ctxhttp"
  12. "github.com/grafana/grafana/pkg/tsdb"
  13. )
  14. func (e *StackdriverExecutor) executeMetricDescriptors(ctx context.Context, tsdbQuery *tsdb.TsdbQuery) (*tsdb.Response, error) {
  15. logger.Info("metricDescriptors", "metricDescriptors", tsdbQuery.Queries[0].RefId)
  16. queryResult := &tsdb.QueryResult{Meta: simplejson.New(), RefId: tsdbQuery.Queries[0].RefId}
  17. result := &tsdb.Response{
  18. Results: make(map[string]*tsdb.QueryResult),
  19. }
  20. req, err := e.createRequest(ctx, e.dsInfo, "metricDescriptorss")
  21. if err != nil {
  22. slog.Error("Failed to create request", "error", err)
  23. return nil, fmt.Errorf("Failed to create request. error: %v", err)
  24. }
  25. res, err := ctxhttp.Do(ctx, e.httpClient, req)
  26. if err != nil {
  27. logger.Info("error2", err)
  28. return nil, err
  29. }
  30. data, err := e.unmarshalMetricDescriptors(res)
  31. if err != nil {
  32. queryResult.ErrorString = fmt.Sprintf(`Status code: %d`, res.StatusCode)
  33. logger.Info("error2", "ErrorString", queryResult.ErrorString)
  34. queryResult.Error = err
  35. result.Results[tsdbQuery.Queries[0].RefId] = queryResult
  36. return result, nil
  37. }
  38. parts := strings.Split(req.URL.Path, "/")
  39. defaultProject := parts[3]
  40. table := transformMetricDescriptorResponseToTable(data)
  41. queryResult.Tables = append(queryResult.Tables, table)
  42. result.Results[tsdbQuery.Queries[0].RefId] = queryResult
  43. result.Results[tsdbQuery.Queries[0].RefId].Meta.Set("defaultProject", defaultProject)
  44. return result, nil
  45. }
  46. func transformMetricDescriptorResponseToTable(data MetricDescriptorsResponse) *tsdb.Table {
  47. table := &tsdb.Table{
  48. Columns: make([]tsdb.TableColumn, 1),
  49. Rows: make([]tsdb.RowValues, 0),
  50. }
  51. table.Columns[0].Text = "metricDescriptor"
  52. for _, r := range data.MetricDescriptors {
  53. values := make([]interface{}, 1)
  54. values[0] = r
  55. table.Rows = append(table.Rows, values)
  56. }
  57. return table
  58. }
  59. func (e *StackdriverExecutor) unmarshalMetricDescriptors(res *http.Response) (MetricDescriptorsResponse, error) {
  60. body, err := ioutil.ReadAll(res.Body)
  61. defer res.Body.Close()
  62. if err != nil {
  63. return MetricDescriptorsResponse{}, err
  64. }
  65. if res.StatusCode/100 != 2 {
  66. slog.Error("Request failed", "status", res.Status, "body", string(body))
  67. return MetricDescriptorsResponse{}, fmt.Errorf(`Status code: %d - %s`, res.StatusCode, string(body))
  68. }
  69. var data MetricDescriptorsResponse
  70. err = json.Unmarshal(body, &data)
  71. if err != nil {
  72. slog.Error("Failed to unmarshal MetricDescriptorResponse", "error", err, "status", res.Status, "body", string(body))
  73. return MetricDescriptorsResponse{}, err
  74. }
  75. return data, nil
  76. }