123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- # Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- class KnowledgeBase
- class EffectivePermission
- def initialize(user, object)
- @user = user
- @object = object
- end
- def access_effective
- return 'none' if !@user
- @user.roles.reduce('none') do |memo, role|
- access = access_role_effective(role)
- return 'editor' if access == 'editor'
- access_role_reducer(memo, access)
- end
- end
- private
- def access_role_reducer(memo, access)
- case access
- when 'reader'
- 'reader'
- when 'public_reader'
- memo == 'reader' ? memo : access
- when 'none'
- memo
- end
- end
- def permissions
- @permissions ||= @object.permissions_effective
- end
- def access_role_effective(role)
- permission = permissions.find { |elem| elem.role == role }
- return default_role_access(role) if !permission
- calculate_role(role, permission)
- end
- def calculate_role(role, permission)
- if permission.access == 'editor' && role.with_permission?('knowledge_base.editor')
- 'editor'
- elsif %w[editor reader].include?(permission.access) && role.with_permission?(%w[knowledge_base.editor knowledge_base.reader])
- 'reader'
- elsif @object.public_content?
- 'public_reader'
- else
- 'none'
- end
- end
- def default_role_access(role)
- if role.with_permission?('knowledge_base.editor')
- 'editor'
- elsif role.with_permission?('knowledge_base.reader')
- 'reader'
- else
- 'none'
- end
- end
- end
- end
|