dashboard_acl.go 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. package sqlstore
  2. import (
  3. "time"
  4. "github.com/grafana/grafana/pkg/bus"
  5. m "github.com/grafana/grafana/pkg/models"
  6. )
  7. func init() {
  8. bus.AddHandler("sql", AddOrUpdateDashboardPermission)
  9. bus.AddHandler("sql", RemoveDashboardPermission)
  10. bus.AddHandler("sql", GetDashboardPermissions)
  11. }
  12. func AddOrUpdateDashboardPermission(cmd *m.AddOrUpdateDashboardPermissionCommand) error {
  13. return inTransaction(func(sess *DBSession) error {
  14. if res, err := sess.Query("SELECT 1 from "+dialect.Quote("dashboard_acl")+" WHERE dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId); err != nil {
  15. return err
  16. } else if len(res) == 1 {
  17. entity := m.DashboardAcl{
  18. Permissions: cmd.PermissionType,
  19. Updated: time.Now(),
  20. }
  21. if _, err := sess.Cols("updated", "permissions").Where("dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId).Update(&entity); err != nil {
  22. return err
  23. }
  24. return nil
  25. }
  26. entity := m.DashboardAcl{
  27. OrgId: cmd.OrgId,
  28. UserGroupId: cmd.UserGroupId,
  29. UserId: cmd.UserId,
  30. Created: time.Now(),
  31. Updated: time.Now(),
  32. DashboardId: cmd.DashboardId,
  33. Permissions: cmd.PermissionType,
  34. }
  35. cols := []string{"org_id", "created", "updated", "dashboard_id", "permissions"}
  36. if cmd.UserId != 0 {
  37. cols = append(cols, "user_id")
  38. }
  39. if cmd.UserGroupId != 0 {
  40. cols = append(cols, "user_group_id")
  41. }
  42. _, err := sess.Cols(cols...).Insert(&entity)
  43. if err != nil {
  44. return err
  45. }
  46. dashboard := m.Dashboard{
  47. HasAcl: true,
  48. }
  49. if _, err := sess.Cols("has_acl").Where("id=? OR parent_id=?", cmd.DashboardId, cmd.DashboardId).Update(&dashboard); err != nil {
  50. return err
  51. }
  52. return nil
  53. })
  54. }
  55. func RemoveDashboardPermission(cmd *m.RemoveDashboardPermissionCommand) error {
  56. return inTransaction(func(sess *DBSession) error {
  57. var rawSQL = "DELETE FROM " + dialect.Quote("dashboard_acl") + " WHERE dashboard_id =? and (user_group_id=? or user_id=?)"
  58. _, err := sess.Exec(rawSQL, cmd.DashboardId, cmd.UserGroupId, cmd.UserId)
  59. if err != nil {
  60. return err
  61. }
  62. return err
  63. })
  64. }
  65. func GetDashboardPermissions(query *m.GetDashboardPermissionsQuery) error {
  66. rawSQL := `SELECT
  67. da.*,
  68. u.login AS user_login,
  69. u.email AS user_email,
  70. ug.name AS user_group
  71. FROM` + dialect.Quote("dashboard_acl") + ` as da
  72. LEFT OUTER JOIN ` + dialect.Quote("user") + ` AS u ON u.id = da.user_id
  73. LEFT OUTER JOIN user_group ug on ug.id = da.user_group_id
  74. WHERE dashboard_id=?`
  75. query.Result = make([]*m.DashboardAclInfoDTO, 0)
  76. err := x.SQL(rawSQL, query.DashboardId).Find(&query.Result)
  77. return err
  78. }