model_parser.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. package influxdb
  2. import (
  3. "strconv"
  4. "github.com/grafana/grafana/pkg/components/simplejson"
  5. "github.com/grafana/grafana/pkg/tsdb"
  6. )
  7. type InfluxdbQueryParser struct{}
  8. func (qp *InfluxdbQueryParser) Parse(model *simplejson.Json, dsInfo *tsdb.DataSourceInfo) (*Query, error) {
  9. policy := model.Get("policy").MustString("default")
  10. rawQuery := model.Get("query").MustString("")
  11. alias := model.Get("alias").MustString("")
  12. measurement := model.Get("measurement").MustString("")
  13. resultFormat, err := model.Get("resultFormat").String()
  14. if err != nil {
  15. return nil, err
  16. }
  17. tags, err := qp.parseTags(model)
  18. if err != nil {
  19. return nil, err
  20. }
  21. groupBys, err := qp.parseGroupBy(model)
  22. if err != nil {
  23. return nil, err
  24. }
  25. selects, err := qp.parseSelects(model)
  26. if err != nil {
  27. return nil, err
  28. }
  29. interval := model.Get("interval").MustString("")
  30. if interval == "" && dsInfo.JsonData != nil {
  31. dsInterval := dsInfo.JsonData.Get("timeInterval").MustString("")
  32. if dsInterval != "" {
  33. interval = dsInterval
  34. }
  35. }
  36. return &Query{
  37. Measurement: measurement,
  38. Policy: policy,
  39. ResultFormat: resultFormat,
  40. GroupBy: groupBys,
  41. Tags: tags,
  42. Selects: selects,
  43. RawQuery: rawQuery,
  44. Interval: interval,
  45. Alias: alias,
  46. }, nil
  47. }
  48. func (qp *InfluxdbQueryParser) parseSelects(model *simplejson.Json) ([]*Select, error) {
  49. var result []*Select
  50. for _, selectObj := range model.Get("select").MustArray() {
  51. selectJson := simplejson.NewFromAny(selectObj)
  52. var parts Select
  53. for _, partObj := range selectJson.MustArray() {
  54. part := simplejson.NewFromAny(partObj)
  55. queryPart, err := qp.parseQueryPart(part)
  56. if err != nil {
  57. return nil, err
  58. }
  59. parts = append(parts, *queryPart)
  60. }
  61. result = append(result, &parts)
  62. }
  63. return result, nil
  64. }
  65. func (*InfluxdbQueryParser) parseTags(model *simplejson.Json) ([]*Tag, error) {
  66. var result []*Tag
  67. for _, t := range model.Get("tags").MustArray() {
  68. tagJson := simplejson.NewFromAny(t)
  69. tag := &Tag{}
  70. var err error
  71. tag.Key, err = tagJson.Get("key").String()
  72. if err != nil {
  73. return nil, err
  74. }
  75. tag.Value, err = tagJson.Get("value").String()
  76. if err != nil {
  77. return nil, err
  78. }
  79. operator, err := tagJson.Get("operator").String()
  80. if err == nil {
  81. tag.Operator = operator
  82. }
  83. condition, err := tagJson.Get("condition").String()
  84. if err == nil {
  85. tag.Condition = condition
  86. }
  87. result = append(result, tag)
  88. }
  89. return result, nil
  90. }
  91. func (*InfluxdbQueryParser) parseQueryPart(model *simplejson.Json) (*QueryPart, error) {
  92. typ, err := model.Get("type").String()
  93. if err != nil {
  94. return nil, err
  95. }
  96. var params []string
  97. for _, paramObj := range model.Get("params").MustArray() {
  98. param := simplejson.NewFromAny(paramObj)
  99. stringParam, err := param.String()
  100. if err == nil {
  101. params = append(params, stringParam)
  102. continue
  103. }
  104. intParam, err := param.Int()
  105. if err == nil {
  106. params = append(params, strconv.Itoa(intParam))
  107. continue
  108. }
  109. return nil, err
  110. }
  111. qp, err := NewQueryPart(typ, params)
  112. if err != nil {
  113. return nil, err
  114. }
  115. return qp, nil
  116. }
  117. func (qp *InfluxdbQueryParser) parseGroupBy(model *simplejson.Json) ([]*QueryPart, error) {
  118. var result []*QueryPart
  119. for _, groupObj := range model.Get("groupBy").MustArray() {
  120. groupJson := simplejson.NewFromAny(groupObj)
  121. queryPart, err := qp.parseQueryPart(groupJson)
  122. if err != nil {
  123. return nil, err
  124. }
  125. result = append(result, queryPart)
  126. }
  127. return result, nil
  128. }