dashboard_acl.go 2.6 KB

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