dashboard_acl.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. package sqlstore
  2. import (
  3. "time"
  4. "fmt"
  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 *DBSession) error {
  15. if cmd.UserId == 0 && cmd.UserGroupId == 0 {
  16. return m.ErrDashboardPermissionUserOrUserGroupEmpty
  17. }
  18. 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 {
  19. return err
  20. } else if len(res) == 1 {
  21. entity := m.DashboardAcl{
  22. Permissions: cmd.PermissionType,
  23. Updated: time.Now(),
  24. }
  25. 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 {
  26. return err
  27. }
  28. return nil
  29. }
  30. entity := m.DashboardAcl{
  31. OrgId: cmd.OrgId,
  32. UserGroupId: cmd.UserGroupId,
  33. UserId: cmd.UserId,
  34. Created: time.Now(),
  35. Updated: time.Now(),
  36. DashboardId: cmd.DashboardId,
  37. Permissions: cmd.PermissionType,
  38. }
  39. cols := []string{"org_id", "created", "updated", "dashboard_id", "permissions"}
  40. if cmd.UserId != 0 {
  41. cols = append(cols, "user_id")
  42. }
  43. if cmd.UserGroupId != 0 {
  44. cols = append(cols, "user_group_id")
  45. }
  46. entityId, err := sess.Cols(cols...).Insert(&entity)
  47. if err != nil {
  48. return err
  49. }
  50. cmd.Result = entity
  51. cmd.Result.Id = entityId
  52. // Update dashboard HasAcl flag
  53. dashboard := m.Dashboard{
  54. HasAcl: true,
  55. }
  56. if _, err := sess.Cols("has_acl").Where("id=? OR parent_id=?", cmd.DashboardId, cmd.DashboardId).Update(&dashboard); err != nil {
  57. return err
  58. }
  59. return nil
  60. })
  61. }
  62. func RemoveDashboardPermission(cmd *m.RemoveDashboardPermissionCommand) error {
  63. return inTransaction(func(sess *DBSession) error {
  64. var rawSQL = "DELETE FROM " + dialect.Quote("dashboard_acl") + " WHERE dashboard_id =? and (user_group_id=? or user_id=?)"
  65. _, err := sess.Exec(rawSQL, cmd.DashboardId, cmd.UserGroupId, cmd.UserId)
  66. if err != nil {
  67. return err
  68. }
  69. return err
  70. })
  71. }
  72. func GetDashboardPermissions(query *m.GetDashboardPermissionsQuery) error {
  73. rawSQL := `SELECT
  74. da.id,
  75. da.org_id,
  76. da.id,
  77. da.dashboard_id,
  78. da.user_id,
  79. da.user_group_id,
  80. da.permissions as permission_type,
  81. da.created,
  82. da.updated,
  83. u.login AS user_login,
  84. u.email AS user_email,
  85. ug.name AS user_group
  86. FROM` + dialect.Quote("dashboard_acl") + ` as da
  87. LEFT OUTER JOIN ` + dialect.Quote("user") + ` AS u ON u.id = da.user_id
  88. LEFT OUTER JOIN user_group ug on ug.id = da.user_group_id
  89. WHERE dashboard_id=?`
  90. query.Result = make([]*m.DashboardAclInfoDTO, 0)
  91. err := x.SQL(rawSQL, query.DashboardId).Find(&query.Result)
  92. for _, p := range query.Result {
  93. p.Permissions = fmt.Sprint(p.PermissionType)
  94. }
  95. return err
  96. }