model_parser.go 3.5 KB

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