user_policy.rb 1.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. # Copyright (C) 2012-2022 Zammad Foundation, https://zammad-foundation.org/
  2. class UserPolicy < ApplicationPolicy
  3. def show?
  4. return true if user.permissions?('admin.*')
  5. return true if own_account?
  6. return true if user.permissions?('ticket.agent')
  7. # check same organization for customers
  8. return false if !user.permissions?('ticket.customer')
  9. same_organization?
  10. end
  11. def update?
  12. # full access for admins
  13. return true if user.permissions?('admin.user')
  14. # forbid non-agents to change users
  15. return false if !user.permissions?('ticket.agent')
  16. # allow agents to change customers only
  17. return false if record.permissions?(['admin.user', 'ticket.agent'])
  18. record.permissions?('ticket.customer')
  19. end
  20. def destroy?
  21. user.permissions?('admin.user')
  22. end
  23. private
  24. def own_account?
  25. record.id == user.id
  26. end
  27. def same_organization?
  28. return false if record.organization_id.blank?
  29. return false if user.organization_id.blank?
  30. record.organization_id == user.organization_id
  31. end
  32. end