dashboard.go 3.7 KB

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