Stackdriver: Load example metric and start parsing response

pull/13289/head
Erik Sundell 7 years ago committed by Daniel Lee
parent 31417b795c
commit 1fe70f8290
  1. 35
      pkg/tsdb/stackdriver/stackdriver.go
  2. 33
      pkg/tsdb/stackdriver/types.go

@ -13,6 +13,8 @@ import (
"golang.org/x/net/context/ctxhttp" "golang.org/x/net/context/ctxhttp"
"github.com/grafana/grafana/pkg/api/pluginproxy"
"github.com/grafana/grafana/pkg/cmd/grafana-cli/logger"
"github.com/grafana/grafana/pkg/log" "github.com/grafana/grafana/pkg/log"
"github.com/grafana/grafana/pkg/models" "github.com/grafana/grafana/pkg/models"
"github.com/grafana/grafana/pkg/setting" "github.com/grafana/grafana/pkg/setting"
@ -36,7 +38,7 @@ func init() {
func (e *StackdriverExecutor) Query(ctx context.Context, dsInfo *models.DataSource, tsdbQuery *tsdb.TsdbQuery) (*tsdb.Response, error) { func (e *StackdriverExecutor) Query(ctx context.Context, dsInfo *models.DataSource, tsdbQuery *tsdb.TsdbQuery) (*tsdb.Response, error) {
result := &tsdb.Response{} result := &tsdb.Response{}
logger.Info("tsdbQuery", "tsdbQuery", tsdbQuery)
from := "-" + formatTimeRange(tsdbQuery.TimeRange.From) from := "-" + formatTimeRange(tsdbQuery.TimeRange.From)
until := formatTimeRange(tsdbQuery.TimeRange.To) until := formatTimeRange(tsdbQuery.TimeRange.To)
var target string var target string
@ -73,7 +75,7 @@ func (e *StackdriverExecutor) Query(ctx context.Context, dsInfo *models.DataSour
return nil, err return nil, err
} }
span, ctx := opentracing.StartSpanFromContext(ctx, "graphite query") span, ctx := opentracing.StartSpanFromContext(ctx, "stackdriver query")
span.SetTag("target", target) span.SetTag("target", target)
span.SetTag("from", from) span.SetTag("from", from)
span.SetTag("until", until) span.SetTag("until", until)
@ -100,14 +102,14 @@ func (e *StackdriverExecutor) Query(ctx context.Context, dsInfo *models.DataSour
result.Results = make(map[string]*tsdb.QueryResult) result.Results = make(map[string]*tsdb.QueryResult)
queryRes := tsdb.NewQueryResult() queryRes := tsdb.NewQueryResult()
for _, series := range data { for _, series := range data.TimeSeries {
queryRes.Series = append(queryRes.Series, &tsdb.TimeSeries{ queryRes.Series = append(queryRes.Series, &tsdb.TimeSeries{
Name: series.Target, Name: series.Metric.Type,
Points: series.DataPoints, // Points: [],
}) })
if setting.Env == setting.DEV { if setting.Env == setting.DEV {
glog.Debug("Graphite response", "target", series.Target, "datapoints", len(series.DataPoints)) // glog.Debug("Graphite response", "target", series.Target, "datapoints", len(series.DataPoints))
} }
} }
@ -115,23 +117,23 @@ func (e *StackdriverExecutor) Query(ctx context.Context, dsInfo *models.DataSour
return result, nil return result, nil
} }
func (e *StackdriverExecutor) parseResponse(res *http.Response) ([]TargetResponseDTO, error) { func (e *StackdriverExecutor) parseResponse(res *http.Response) (StackDriverResponse, error) {
body, err := ioutil.ReadAll(res.Body) body, err := ioutil.ReadAll(res.Body)
defer res.Body.Close() defer res.Body.Close()
if err != nil { if err != nil {
return nil, err return StackDriverResponse{}, err
} }
if res.StatusCode/100 != 2 { if res.StatusCode/100 != 2 {
glog.Info("Request failed", "status", res.Status, "body", string(body)) glog.Info("Request failed", "status", res.Status, "body", string(body))
return nil, fmt.Errorf("Request failed status: %v", res.Status) return StackDriverResponse{}, fmt.Errorf("Request failed status: %v", res.Status)
} }
var data []TargetResponseDTO var data StackDriverResponse
err = json.Unmarshal(body, &data) err = json.Unmarshal(body, &data)
if err != nil { if err != nil {
glog.Info("Failed to unmarshal graphite response", "error", err, "status", res.Status, "body", string(body)) glog.Info("Failed to unmarshal graphite response", "error", err, "status", res.Status, "body", string(body))
return nil, err return StackDriverResponse{}, err
} }
return data, nil return data, nil
@ -141,15 +143,18 @@ func (e *StackdriverExecutor) createRequest(dsInfo *models.DataSource, data url.
u, _ := url.Parse(dsInfo.Url) u, _ := url.Parse(dsInfo.Url)
u.Path = path.Join(u.Path, "render") u.Path = path.Join(u.Path, "render")
req, err := http.NewRequest(http.MethodPost, u.String(), strings.NewReader(data.Encode())) req, err := http.NewRequest(http.MethodGet, "https://monitoring.googleapis.com/v3/projects/raintank-production/timeSeries?&filter=metric.type%20%3D%20%22compute.googleapis.com%2Finstance%2Fcpu%2Fusage_time%22&aggregation.perSeriesAligner=ALIGN_NONE&interval.startTime=2018-09-04T11%3A14%3A02.383Z&interval.endTime=2018-09-04T11%3A16%3A02.383Z", nil)
if err != nil { if err != nil {
glog.Info("Failed to create request", "error", err) glog.Info("Failed to create request", "error", err)
return nil, fmt.Errorf("Failed to create request. error: %v", err) return nil, fmt.Errorf("Failed to create request. error: %v", err)
} }
req.Header.Set("Content-Type", "application/x-www-form-urlencoded") req.Header.Set("Content-Type", "application/json")
if dsInfo.BasicAuth {
req.SetBasicAuth(dsInfo.BasicAuthUser, dsInfo.BasicAuthPassword) if token, err := pluginproxy.GetAccessTokenFromCache(dsInfo.Id, "stackdriver", "GET"); err != nil {
logger.Error("Failed to get access token", "error", err)
} else {
req.Header.Set("Authorization", fmt.Sprintf("Bearer %s", token))
} }
return req, err return req, err

@ -1,8 +1,33 @@
package stackdriver package stackdriver
import "github.com/grafana/grafana/pkg/tsdb" import "time"
type TargetResponseDTO struct { type StackDriverResponse struct {
Target string `json:"target"` TimeSeries []struct {
DataPoints tsdb.TimeSeriesPoints `json:"datapoints"` Metric struct {
Labels struct {
InstanceName string `json:"instance_name"`
} `json:"labels"`
Type string `json:"type"`
} `json:"metric"`
Resource struct {
Type string `json:"type"`
Labels struct {
InstanceID string `json:"instance_id"`
Zone string `json:"zone"`
ProjectID string `json:"project_id"`
} `json:"labels"`
} `json:"resource"`
MetricKind string `json:"metricKind"`
ValueType string `json:"valueType"`
Points []struct {
Interval struct {
StartTime time.Time `json:"startTime"`
EndTime time.Time `json:"endTime"`
} `json:"interval"`
Value struct {
DoubleValue float64 `json:"doubleValue"`
} `json:"value"`
} `json:"points"`
} `json:"timeSeries"`
} }

Loading…
Cancel
Save