dashboard_provisioning.go 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. package sqlstore
  2. import (
  3. "github.com/grafana/grafana/pkg/bus"
  4. "github.com/grafana/grafana/pkg/models"
  5. )
  6. func init() {
  7. bus.AddHandler("sql", GetProvisionedDashboardDataQuery)
  8. bus.AddHandler("sql", SaveProvisionedDashboard)
  9. bus.AddHandler("sql", GetProvisionedDataByDashboardId)
  10. bus.AddHandler("sql", UnprovisionDashboard)
  11. }
  12. type DashboardExtras struct {
  13. Id int64
  14. DashboardId int64
  15. Key string
  16. Value string
  17. }
  18. func GetProvisionedDataByDashboardId(cmd *models.GetProvisionedDashboardDataByIdQuery) error {
  19. result := &models.DashboardProvisioning{}
  20. exist, err := x.Where("dashboard_id = ?", cmd.DashboardId).Get(result)
  21. if err != nil {
  22. return err
  23. }
  24. if exist {
  25. cmd.Result = result
  26. }
  27. return nil
  28. }
  29. func SaveProvisionedDashboard(cmd *models.SaveProvisionedDashboardCommand) error {
  30. return inTransaction(func(sess *DBSession) error {
  31. err := saveDashboard(sess, cmd.DashboardCmd)
  32. if err != nil {
  33. return err
  34. }
  35. cmd.Result = cmd.DashboardCmd.Result
  36. if cmd.DashboardProvisioning.Updated == 0 {
  37. cmd.DashboardProvisioning.Updated = cmd.Result.Updated.Unix()
  38. }
  39. return saveProvisionedData(sess, cmd.DashboardProvisioning, cmd.Result)
  40. })
  41. }
  42. func saveProvisionedData(sess *DBSession, cmd *models.DashboardProvisioning, dashboard *models.Dashboard) error {
  43. result := &models.DashboardProvisioning{}
  44. exist, err := sess.Where("dashboard_id=? AND name = ?", dashboard.Id, cmd.Name).Get(result)
  45. if err != nil {
  46. return err
  47. }
  48. cmd.Id = result.Id
  49. cmd.DashboardId = dashboard.Id
  50. if exist {
  51. _, err = sess.ID(result.Id).Update(cmd)
  52. } else {
  53. _, err = sess.Insert(cmd)
  54. }
  55. return err
  56. }
  57. func GetProvisionedDashboardDataQuery(cmd *models.GetProvisionedDashboardDataQuery) error {
  58. var result []*models.DashboardProvisioning
  59. if err := x.Where("name = ?", cmd.Name).Find(&result); err != nil {
  60. return err
  61. }
  62. cmd.Result = result
  63. return nil
  64. }
  65. // UnprovisionDashboard removes row in dashboard_provisioning for the dashboard making it seem as if manually created.
  66. // The dashboard will still have `created_by = -1` to see it was not created by any particular user.
  67. func UnprovisionDashboard(cmd *models.UnprovisionDashboardCommand) error {
  68. if _, err := x.Where("dashboard_id = ?", cmd.Id).Delete(&models.DashboardProvisioning{}); err != nil {
  69. return err
  70. }
  71. return nil
  72. }