dashboard_acl.go 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  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", SetDashboardAcl)
  9. bus.AddHandler("sql", RemoveDashboardAcl)
  10. bus.AddHandler("sql", GetDashboardAclInfoList)
  11. bus.AddHandler("sql", GetInheritedDashboardAcl)
  12. }
  13. func SetDashboardAcl(cmd *m.SetDashboardAclCommand) error {
  14. return inTransaction(func(sess *DBSession) error {
  15. if cmd.UserId == 0 && cmd.UserGroupId == 0 {
  16. return m.ErrDashboardAclInfoMissing
  17. }
  18. if cmd.DashboardId == 0 {
  19. return m.ErrDashboardPermissionDashboardEmpty
  20. }
  21. 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 {
  22. return err
  23. } else if len(res) == 1 {
  24. entity := m.DashboardAcl{
  25. Permission: cmd.Permission,
  26. Updated: time.Now(),
  27. }
  28. if _, err := sess.Cols("updated", "permission").Where("dashboard_id =? and (user_group_id=? or user_id=?)", cmd.DashboardId, cmd.UserGroupId, cmd.UserId).Update(&entity); err != nil {
  29. return err
  30. }
  31. return nil
  32. }
  33. entity := m.DashboardAcl{
  34. OrgId: cmd.OrgId,
  35. UserGroupId: cmd.UserGroupId,
  36. UserId: cmd.UserId,
  37. Created: time.Now(),
  38. Updated: time.Now(),
  39. DashboardId: cmd.DashboardId,
  40. Permission: cmd.Permission,
  41. }
  42. cols := []string{"org_id", "created", "updated", "dashboard_id", "permission"}
  43. if cmd.UserId != 0 {
  44. cols = append(cols, "user_id")
  45. }
  46. if cmd.UserGroupId != 0 {
  47. cols = append(cols, "user_group_id")
  48. }
  49. _, err := sess.Cols(cols...).Insert(&entity)
  50. if err != nil {
  51. return err
  52. }
  53. cmd.Result = entity
  54. // Update dashboard HasAcl flag
  55. dashboard := m.Dashboard{
  56. HasAcl: true,
  57. }
  58. if _, err := sess.Cols("has_acl").Where("id=? OR parent_id=?", cmd.DashboardId, cmd.DashboardId).Update(&dashboard); err != nil {
  59. return err
  60. }
  61. return nil
  62. })
  63. }
  64. func RemoveDashboardAcl(cmd *m.RemoveDashboardAclCommand) error {
  65. return inTransaction(func(sess *DBSession) error {
  66. var rawSQL = "DELETE FROM " + dialect.Quote("dashboard_acl") + " WHERE org_id =? and id=?"
  67. _, err := sess.Exec(rawSQL, cmd.OrgId, cmd.AclId)
  68. if err != nil {
  69. return err
  70. }
  71. return err
  72. })
  73. }
  74. func GetInheritedDashboardAcl(query *m.GetInheritedDashboardAclQuery) error {
  75. rawSQL := `SELECT
  76. da.id,
  77. da.org_id,
  78. da.dashboard_id,
  79. da.user_id,
  80. da.user_group_id,
  81. da.permission,
  82. da.created,
  83. da.updated
  84. FROM dashboard_acl as da
  85. WHERE da.dashboard_id IN (
  86. SELECT id FROM dashboard where id = ?
  87. UNION
  88. SELECT parent_id from dashboard where id = ?
  89. ) AND org_id = ?`
  90. query.Result = make([]*m.DashboardAcl, 0)
  91. return x.SQL(rawSQL, query.DashboardId, query.DashboardId, query.OrgId).Find(&query.Result)
  92. }
  93. func GetDashboardAclInfoList(query *m.GetDashboardAclInfoListQuery) error {
  94. rawSQL := `
  95. SELECT
  96. da.id,
  97. da.org_id,
  98. da.dashboard_id,
  99. da.user_id,
  100. da.user_group_id,
  101. da.permission,
  102. da.role,
  103. da.created,
  104. da.updated,
  105. u.login AS user_login,
  106. u.email AS user_email,
  107. ug.name AS user_group
  108. FROM` + dialect.Quote("dashboard_acl") + ` as da
  109. LEFT OUTER JOIN ` + dialect.Quote("user") + ` AS u ON u.id = da.user_id
  110. LEFT OUTER JOIN user_group ug on ug.id = da.user_group_id
  111. WHERE dashboard_id = ?
  112. -- Also include default permission if has_acl = 0
  113. UNION
  114. SELECT
  115. da.id,
  116. da.org_id,
  117. da.dashboard_id,
  118. da.user_id,
  119. da.user_group_id,
  120. da.permission,
  121. da.role,
  122. da.created,
  123. da.updated,
  124. '' as user_login,
  125. '' as user_email,
  126. '' as user_group
  127. FROM dashboard_acl as da, dashboard as dash
  128. WHERE dash.id = ? AND dash.has_acl = 0 AND da.dashboard_id = -1
  129. `
  130. query.Result = make([]*m.DashboardAclInfoDTO, 0)
  131. err := x.SQL(rawSQL, query.DashboardId, query.DashboardId).Find(&query.Result)
  132. for _, p := range query.Result {
  133. p.PermissionName = p.Permission.String()
  134. }
  135. return err
  136. }