guardian.go 1.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. package sqlstore
  2. import (
  3. "fmt"
  4. "strings"
  5. "github.com/grafana/grafana/pkg/bus"
  6. m "github.com/grafana/grafana/pkg/models"
  7. )
  8. func init() {
  9. bus.AddHandler("sql", GetAllowedDashboards)
  10. }
  11. func GetAllowedDashboards(query *m.GetAllowedDashboardsQuery) error {
  12. dashboardIds := arrayToString(query.DashList, ",")
  13. rawSQL := `select distinct d.id as DashboardId
  14. from dashboard as d
  15. left join dashboard as df on d.parent_id = df.id
  16. left join dashboard_acl as dfa on d.parent_id = dfa.dashboard_id or d.id = dfa.dashboard_id
  17. left join user_group_member as ugm on ugm.user_group_id = dfa.user_group_id
  18. where (
  19. (d.has_acl = 1 and (dfa.user_id = ? or ugm.user_id = ? or df.created_by = ? or (d.is_folder = 1 and d.created_by = ?)))
  20. or d.has_acl = 0)
  21. and d.org_id = ?`
  22. rawSQL = fmt.Sprintf("%v and d.id in(%v)", rawSQL, dashboardIds)
  23. query.Result = make([]int64, 0)
  24. err := x.SQL(rawSQL, query.UserId, query.UserId, query.UserId, query.UserId, query.OrgId).Find(&query.Result)
  25. if err != nil {
  26. return err
  27. }
  28. return nil
  29. }
  30. func arrayToString(a []int64, delim string) string {
  31. return strings.Trim(strings.Replace(fmt.Sprint(a), " ", delim, -1), "[]")
  32. }