dashboard_snapshot.go 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/go-xorm/xorm"
  5. "github.com/grafana/grafana/pkg/bus"
  6. "github.com/grafana/grafana/pkg/log"
  7. m "github.com/grafana/grafana/pkg/models"
  8. "github.com/grafana/grafana/pkg/setting"
  9. )
  10. func init() {
  11. bus.AddHandler("sql", CreateDashboardSnapshot)
  12. bus.AddHandler("sql", GetDashboardSnapshot)
  13. bus.AddHandler("sql", DeleteDashboardSnapshot)
  14. bus.AddHandler("sql", SearchDashboardSnapshots)
  15. bus.AddEventListener(DeleteExpiredSnapshots)
  16. }
  17. func DeleteExpiredSnapshots(cmd *m.HourCommand) error {
  18. return inTransaction(func(sess *xorm.Session) error {
  19. var expiredCount int64 = 0
  20. var oldCount int64 = 0
  21. if setting.SnapShotRemoveExpired {
  22. deleteExpiredSql := "DELETE FROM dashboard_snapshot WHERE expires < ?"
  23. expiredResponse, err := x.Exec(deleteExpiredSql, cmd.Time)
  24. if err != nil {
  25. return err
  26. }
  27. expiredCount, _ = expiredResponse.RowsAffected()
  28. }
  29. oldSnapshotsSql := "DELETE FROM dashboard_snapshot WHERE created < ?"
  30. oldResponse, err := x.Exec(oldSnapshotsSql, cmd.Time.AddDate(0, 0, setting.SnapShotTTLDays*-1))
  31. oldCount, _ = oldResponse.RowsAffected()
  32. log.Debug2("Deleted old/expired snaphots", "to old", oldCount, "expired", expiredCount)
  33. return err
  34. })
  35. }
  36. func CreateDashboardSnapshot(cmd *m.CreateDashboardSnapshotCommand) error {
  37. return inTransaction(func(sess *xorm.Session) error {
  38. // never
  39. var expires = time.Now().Add(time.Hour * 24 * 365 * 50)
  40. if cmd.Expires > 0 {
  41. expires = time.Now().Add(time.Second * time.Duration(cmd.Expires))
  42. }
  43. snapshot := &m.DashboardSnapshot{
  44. Name: cmd.Name,
  45. Key: cmd.Key,
  46. DeleteKey: cmd.DeleteKey,
  47. OrgId: cmd.OrgId,
  48. UserId: cmd.UserId,
  49. External: cmd.External,
  50. Dashboard: cmd.Dashboard,
  51. Expires: expires,
  52. Created: time.Now(),
  53. Updated: time.Now(),
  54. }
  55. _, err := sess.Insert(snapshot)
  56. cmd.Result = snapshot
  57. return err
  58. })
  59. }
  60. func DeleteDashboardSnapshot(cmd *m.DeleteDashboardSnapshotCommand) error {
  61. return inTransaction(func(sess *xorm.Session) error {
  62. var rawSql = "DELETE FROM dashboard_snapshot WHERE delete_key=?"
  63. _, err := sess.Exec(rawSql, cmd.DeleteKey)
  64. return err
  65. })
  66. }
  67. func GetDashboardSnapshot(query *m.GetDashboardSnapshotQuery) error {
  68. snapshot := m.DashboardSnapshot{Key: query.Key}
  69. has, err := x.Get(&snapshot)
  70. if err != nil {
  71. return err
  72. } else if has == false {
  73. return m.ErrDashboardSnapshotNotFound
  74. }
  75. query.Result = &snapshot
  76. return nil
  77. }
  78. func SearchDashboardSnapshots(query *m.GetDashboardSnapshotsQuery) error {
  79. var snapshots = make(m.DashboardSnapshots, 0)
  80. sess := x.Limit(query.Limit)
  81. if query.Name != "" {
  82. sess.Where("name LIKE ?", query.Name)
  83. }
  84. sess.Where("org_id = ?", query.OrgId)
  85. err := sess.Find(&snapshots)
  86. query.Result = snapshots
  87. return err
  88. }