model_parser.go 3.1 KB

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