model_parser.go 3.5 KB

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