user_policy.rb 947 B

12345678910111213141516171819202122232425262728293031323334353637383940
  1. # Copyright (C) 2012-2021 Zammad Foundation, http://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. return true if user.permissions?('admin.user')
  13. # forbid non-agents to change users
  14. return false if !user.permissions?('ticket.agent')
  15. # allow agents to change customers
  16. record.permissions?('ticket.customer')
  17. end
  18. def destroy?
  19. user.permissions?('admin.user')
  20. end
  21. private
  22. def own_account?
  23. record.id == user.id
  24. end
  25. def same_organization?
  26. return false if record.organization_id.blank?
  27. return false if user.organization_id.blank?
  28. record.organization_id == user.organization_id
  29. end
  30. end