dashboard.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. package sqlstore
  2. import (
  3. "bytes"
  4. "fmt"
  5. "github.com/go-xorm/xorm"
  6. "github.com/grafana/grafana/pkg/bus"
  7. m "github.com/grafana/grafana/pkg/models"
  8. )
  9. func init() {
  10. bus.AddHandler("sql", SaveDashboard)
  11. bus.AddHandler("sql", GetDashboard)
  12. bus.AddHandler("sql", DeleteDashboard)
  13. bus.AddHandler("sql", SearchDashboards)
  14. bus.AddHandler("sql", GetDashboardTags)
  15. }
  16. func SaveDashboard(cmd *m.SaveDashboardCommand) error {
  17. return inTransaction(func(sess *xorm.Session) error {
  18. dash := cmd.GetDashboardModel()
  19. // try get existing dashboard
  20. existing := m.Dashboard{Slug: dash.Slug, AccountId: dash.AccountId}
  21. hasExisting, err := sess.Get(&existing)
  22. if err != nil {
  23. return err
  24. }
  25. if hasExisting && dash.Id != existing.Id {
  26. return m.ErrDashboardWithSameNameExists
  27. }
  28. if dash.Id == 0 {
  29. _, err = sess.Insert(dash)
  30. } else {
  31. _, err = sess.Id(dash.Id).Update(dash)
  32. }
  33. // delete existing tabs
  34. _, err = sess.Exec("DELETE FROM dashboard_tag WHERE dashboard_id=?", dash.Id)
  35. if err != nil {
  36. return err
  37. }
  38. // insert new tags
  39. tags := dash.GetTags()
  40. if len(tags) > 0 {
  41. for _, tag := range tags {
  42. if _, err := sess.Insert(&DashboardTag{DashboardId: dash.Id, Term: tag}); err != nil {
  43. return err
  44. }
  45. }
  46. }
  47. cmd.Result = dash
  48. return err
  49. })
  50. }
  51. func GetDashboard(query *m.GetDashboardQuery) error {
  52. dashboard := m.Dashboard{Slug: query.Slug, AccountId: query.AccountId}
  53. has, err := x.Get(&dashboard)
  54. if err != nil {
  55. return err
  56. } else if has == false {
  57. return m.ErrDashboardNotFound
  58. }
  59. dashboard.Data["id"] = dashboard.Id
  60. query.Result = &dashboard
  61. return nil
  62. }
  63. type DashboardSearchProjection struct {
  64. Id int64
  65. Title string
  66. Slug string
  67. Term string
  68. }
  69. func SearchDashboards(query *m.SearchDashboardsQuery) error {
  70. var sql bytes.Buffer
  71. params := make([]interface{}, 0)
  72. sql.WriteString(`SELECT
  73. dashboard.id,
  74. dashboard.title,
  75. dashboard.slug,
  76. dashboard_tag.term
  77. FROM dashboard
  78. LEFT OUTER JOIN dashboard_tag on dashboard_tag.dashboard_id = dashboard.id`)
  79. if query.IsStarred {
  80. sql.WriteString(" INNER JOIN star on star.dashboard_id = dashboard.id")
  81. }
  82. sql.WriteString(` WHERE dashboard.account_id=?`)
  83. params = append(params, query.AccountId)
  84. if query.IsStarred {
  85. sql.WriteString(` AND star.user_id=?`)
  86. params = append(params, query.UserId)
  87. }
  88. if len(query.Title) > 0 {
  89. sql.WriteString(" AND dashboard.title LIKE ?")
  90. params = append(params, "%"+query.Title+"%")
  91. }
  92. if len(query.Tag) > 0 {
  93. sql.WriteString(" AND dashboard_tag.term=?")
  94. params = append(params, query.Tag)
  95. }
  96. if query.Limit == 0 || query.Limit > 10000 {
  97. query.Limit = 300
  98. }
  99. sql.WriteString(fmt.Sprintf(" LIMIT %d", query.Limit))
  100. var res []DashboardSearchProjection
  101. err := x.Sql(sql.String(), params...).Find(&res)
  102. if err != nil {
  103. return err
  104. }
  105. query.Result = make([]*m.DashboardSearchHit, 0)
  106. hits := make(map[int64]*m.DashboardSearchHit)
  107. for _, item := range res {
  108. hit, exists := hits[item.Id]
  109. if !exists {
  110. hit = &m.DashboardSearchHit{
  111. Id: item.Id,
  112. Title: item.Title,
  113. Slug: item.Slug,
  114. Tags: []string{},
  115. }
  116. query.Result = append(query.Result, hit)
  117. hits[item.Id] = hit
  118. }
  119. if len(item.Term) > 0 {
  120. hit.Tags = append(hit.Tags, item.Term)
  121. }
  122. }
  123. return err
  124. }
  125. func GetDashboardTags(query *m.GetDashboardTagsQuery) error {
  126. sql := `SELECT
  127. COUNT(*) as count,
  128. term
  129. FROM dashboard
  130. INNER JOIN dashboard_tag on dashboard_tag.dashboard_id = dashboard.id
  131. WHERE dashboard.account_id=?
  132. GROUP BY term`
  133. query.Result = make([]*m.DashboardTagCloudItem, 0)
  134. sess := x.Sql(sql, query.AccountId)
  135. err := sess.Find(&query.Result)
  136. return err
  137. }
  138. func DeleteDashboard(cmd *m.DeleteDashboardCommand) error {
  139. sess := x.NewSession()
  140. defer sess.Close()
  141. rawSql := "DELETE FROM Dashboard WHERE account_id=? and slug=?"
  142. _, err := sess.Exec(rawSql, cmd.AccountId, cmd.Slug)
  143. return err
  144. }