dashboard_acl.go 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. package sqlstore
  2. import (
  3. "github.com/grafana/grafana/pkg/bus"
  4. m "github.com/grafana/grafana/pkg/models"
  5. )
  6. func init() {
  7. bus.AddHandler("sql", UpdateDashboardAcl)
  8. bus.AddHandler("sql", GetDashboardAclInfoList)
  9. }
  10. func UpdateDashboardAcl(cmd *m.UpdateDashboardAclCommand) error {
  11. return inTransaction(func(sess *DBSession) error {
  12. // delete existing items
  13. _, err := sess.Exec("DELETE FROM dashboard_acl WHERE dashboard_id=?", cmd.DashboardId)
  14. if err != nil {
  15. return err
  16. }
  17. for _, item := range cmd.Items {
  18. if item.UserId == 0 && item.TeamId == 0 && (item.Role == nil || !item.Role.IsValid()) {
  19. return m.ErrDashboardAclInfoMissing
  20. }
  21. if item.DashboardId == 0 {
  22. return m.ErrDashboardPermissionDashboardEmpty
  23. }
  24. sess.Nullable("user_id", "team_id")
  25. if _, err := sess.Insert(item); err != nil {
  26. return err
  27. }
  28. }
  29. // Update dashboard HasAcl flag
  30. dashboard := m.Dashboard{HasAcl: true}
  31. if _, err := sess.Cols("has_acl").Where("id=?", cmd.DashboardId).Update(&dashboard); err != nil {
  32. return err
  33. }
  34. return nil
  35. })
  36. }
  37. // GetDashboardAclInfoList returns a list of permissions for a dashboard. They can be fetched from three
  38. // different places.
  39. // 1) Permissions for the dashboard
  40. // 2) permissions for its parent folder
  41. // 3) if no specific permissions have been set for the dashboard or its parent folder then get the default permissions
  42. func GetDashboardAclInfoList(query *m.GetDashboardAclInfoListQuery) error {
  43. var err error
  44. falseStr := dialect.BooleanStr(false)
  45. if query.DashboardId == 0 {
  46. sql := `SELECT
  47. da.id,
  48. da.org_id,
  49. da.dashboard_id,
  50. da.user_id,
  51. da.team_id,
  52. da.permission,
  53. da.role,
  54. da.created,
  55. da.updated,
  56. '' as user_login,
  57. '' as user_email,
  58. '' as team,
  59. '' as title,
  60. '' as slug,
  61. '' as uid,` +
  62. falseStr + ` AS is_folder
  63. FROM dashboard_acl as da
  64. WHERE da.dashboard_id = -1`
  65. query.Result = make([]*m.DashboardAclInfoDTO, 0)
  66. err = x.SQL(sql).Find(&query.Result)
  67. } else {
  68. rawSQL := `
  69. -- get permissions for the dashboard and its parent folder
  70. SELECT
  71. da.id,
  72. da.org_id,
  73. da.dashboard_id,
  74. da.user_id,
  75. da.team_id,
  76. da.permission,
  77. da.role,
  78. da.created,
  79. da.updated,
  80. u.login AS user_login,
  81. u.email AS user_email,
  82. ug.name AS team,
  83. d.title,
  84. d.slug,
  85. d.uid,
  86. d.is_folder
  87. FROM dashboard as d
  88. LEFT JOIN dashboard folder on folder.id = d.folder_id
  89. LEFT JOIN dashboard_acl AS da ON
  90. da.dashboard_id = d.id OR
  91. da.dashboard_id = d.folder_id OR
  92. (
  93. -- include default permissions -->
  94. da.org_id = -1 AND (
  95. (folder.id IS NOT NULL AND folder.has_acl = ` + falseStr + `) OR
  96. (folder.id IS NULL AND d.has_acl = ` + falseStr + `)
  97. )
  98. )
  99. LEFT JOIN ` + dialect.Quote("user") + ` AS u ON u.id = da.user_id
  100. LEFT JOIN team ug on ug.id = da.team_id
  101. WHERE d.org_id = ? AND d.id = ? AND da.id IS NOT NULL
  102. ORDER BY 1 ASC
  103. `
  104. query.Result = make([]*m.DashboardAclInfoDTO, 0)
  105. err = x.SQL(rawSQL, query.OrgId, query.DashboardId).Find(&query.Result)
  106. }
  107. for _, p := range query.Result {
  108. p.PermissionName = p.Permission.String()
  109. }
  110. return err
  111. }