Commit c9461083 authored by Alex Kalderimis's avatar Alex Kalderimis

Cleaner implementation of visible_to_user?

This splits the ability check into two parts: the capability name and
the object of the check, simplifying matters considerably and reducing
repetition.
parent 960eff07
...@@ -135,29 +135,11 @@ class Event < ApplicationRecord ...@@ -135,29 +135,11 @@ class Event < ApplicationRecord
super(presenter_class: ::EventPresenter) super(presenter_class: ::EventPresenter)
end end
# rubocop:disable Metrics/CyclomaticComplexity
# rubocop:disable Metrics/PerceivedComplexity
def visible_to_user?(user = nil) def visible_to_user?(user = nil)
if push_action? || commit_note? return false unless capability.present?
Ability.allowed?(user, :download_code, project)
elsif membership_changed? Ability.allowed?(user, capability, permission_object)
Ability.allowed?(user, :read_project, project)
elsif created_project_action?
Ability.allowed?(user, :read_project, project)
elsif issue? || issue_note?
Ability.allowed?(user, :read_issue, note? ? note_target : target)
elsif merge_request? || merge_request_note?
Ability.allowed?(user, :read_merge_request, note? ? note_target : target)
elsif personal_snippet_note? || project_snippet_note?
Ability.allowed?(user, :read_snippet, note_target)
elsif milestone?
Ability.allowed?(user, :read_milestone, project)
else
false # No other event types are visible
end
end end
# rubocop:enable Metrics/PerceivedComplexity
# rubocop:enable Metrics/CyclomaticComplexity
def resource_parent def resource_parent
project || group project || group
...@@ -364,8 +346,38 @@ class Event < ApplicationRecord ...@@ -364,8 +346,38 @@ class Event < ApplicationRecord
Event._to_partial_path Event._to_partial_path
end end
protected
def capability
@capability ||= begin
if push_action? || commit_note?
:download_code
elsif membership_changed? || created_project_action?
:read_project
elsif issue? || issue_note?
:read_issue
elsif merge_request? || merge_request_note?
:read_merge_request
elsif personal_snippet_note? || project_snippet_note?
:read_snippet
elsif milestone?
:read_milestone
end
end
end
private private
def permission_object
if note?
note_target
elsif target_id.present?
target
else
project
end
end
def push_action_name def push_action_name
if new_ref? if new_ref?
"pushed new" "pushed new"
......
...@@ -18,16 +18,22 @@ module EE ...@@ -18,16 +18,22 @@ module EE
scope :epics, -> { where(target_type: 'Epic') } scope :epics, -> { where(target_type: 'Epic') }
end end
override :visible_to_user? override :capability
def visible_to_user?(user = nil) def capability
if epic? @capability ||= begin
Ability.allowed?(user, :read_epic, target) if epic? || epic_note?
elsif epic_note? :read_epic
Ability.allowed?(user, :read_epic, note_target) elsif design_note?
:read_design
else else
super super
end end
end end
end
def design_note?
note? && note.for_design?
end
def epic_note? def epic_note?
note? && note_target.is_a?(::Epic) note? && note_target.is_a?(::Epic)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment