Commit 06786aa5 authored by Mario de la Ossa's avatar Mario de la Ossa

Use a Serializer for related issues/epics

Use serializers for:
- EpicLinks
- EpicIssueLinks
- IssueLinks
parent c441a155
# frozen_string_literal: true
class LinkedEpicEntity < Grape::Entity
include RequestAwareEntity
expose :id, :title, :state
expose :reference do |epic|
epic.to_reference(request.issuable.group)
end
expose :path do |epic|
group_epic_path(epic.group, epic)
end
expose :relation_path do |epic|
group_epic_link_path(epic.group, request.issuable.iid, epic.id)
end
end
# frozen_string_literal: true
class LinkedEpicIssueEntity < LinkedIssueEntity
include RequestAwareEntity
expose :relation_path, override: true do |issue|
if can_admin_issue_link?(issue)
group_epic_issue_path(issuable.group, issuable.iid, issue.epic_issue_id)
end
end
expose :reference, override: true do |issue|
issue.to_reference(full: true)
end
expose :epic_issue_id
private
def can_admin_issue_link?(issue)
Ability.allowed?(current_user, :admin_epic_issue, issue) && Ability.allowed?(current_user, :admin_epic, issuable)
end
end
# frozen_string_literal: true
class LinkedEpicIssueSerializer < BaseSerializer
entity LinkedEpicIssueEntity
end
# frozen_string_literal: true
class LinkedEpicSerializer < BaseSerializer
entity LinkedEpicEntity
end
# frozen_string_literal: true
class LinkedIssueEntity < Grape::Entity
include RequestAwareEntity
expose :id, :confidential, :title
expose :assignees, using: UserEntity
expose :state
expose :milestone, using: API::Entities::Milestone
expose :weight
expose :reference do |link|
link.to_reference(issuable.project)
end
expose :path do |link|
project_issue_path(link.project, link.iid)
end
expose :relation_path
expose :due_date, :created_at, :closed_at
private
def current_user
request.current_user
end
def issuable
request.issuable
end
end
# frozen_string_literal: true
class LinkedProjectIssueEntity < LinkedIssueEntity
include Gitlab::Utils::StrongMemoize
expose :relation_path, override: true do |issue|
# Make sure the user can admin both the current issue AND the
# referenced issue projects in order to return the removal link.
if can_admin_issue_link_on_current_project? && can_admin_issue_link?(issue.project)
project_issue_link_path(issuable.project, issuable.iid, issue.issue_link_id)
end
end
private
def can_admin_issue_link_on_current_project?
strong_memoize(:can_admin_on_current_project) do
can_admin_issue_link?(issuable.project)
end
end
def can_admin_issue_link?(project)
Ability.allowed?(current_user, :admin_issue_link, project)
end
end
# frozen_string_literal: true
class LinkedProjectIssueSerializer < BaseSerializer
entity LinkedProjectIssueEntity
end
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
module EpicIssues module EpicIssues
class ListService < IssuableLinks::ListService class ListService < IssuableLinks::ListService
extend ::Gitlab::Utils::Override
private private
def child_issuables def child_issuables
...@@ -10,22 +12,9 @@ module EpicIssues ...@@ -10,22 +12,9 @@ module EpicIssues
issuable.issues_readable_by(current_user, preload: preload_for_collection) issuable.issues_readable_by(current_user, preload: preload_for_collection)
end end
def relation_path(issue) override :serializer
if can_admin_issue_link?(issue) def serializer
group_epic_issue_path(issuable.group, issuable.iid, issue.epic_issue_id) LinkedEpicIssueSerializer
end
end
def can_admin_issue_link?(issue)
Ability.allowed?(current_user, :admin_epic_issue, issue) && Ability.allowed?(current_user, :admin_epic, issuable)
end
def reference(issue)
issue.to_reference(full: true)
end
def to_hash(issue)
super.merge(epic_issue_id: issue.epic_issue_id)
end end
end end
end end
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
module EpicLinks module EpicLinks
class ListService < IssuableLinks::ListService class ListService < IssuableLinks::ListService
extend ::Gitlab::Utils::Override
private private
def child_issuables def child_issuables
...@@ -10,27 +12,9 @@ module EpicLinks ...@@ -10,27 +12,9 @@ module EpicLinks
EpicsFinder.new(current_user, parent_id: issuable.id, group_id: issuable.group.id).execute EpicsFinder.new(current_user, parent_id: issuable.id, group_id: issuable.group.id).execute
end end
def reference(epic) override :serializer
epic.to_reference(issuable.group) def serializer
end LinkedEpicSerializer
def issuable_path(epic)
group_epic_path(epic.group, epic)
end
def relation_path(epic)
group_epic_link_path(epic.group, issuable.iid, epic.id)
end
def to_hash(object)
{
id: object.id,
title: object.title,
state: object.state,
reference: reference(object),
path: issuable_path(object),
relation_path: relation_path(object)
}
end end
end end
end end
...@@ -11,47 +11,17 @@ module IssuableLinks ...@@ -11,47 +11,17 @@ module IssuableLinks
end end
def execute def execute
child_issuables.map do |referenced_object| serializer.new(current_user: current_user, issuable: issuable).represent(child_issuables)
to_hash(referenced_object)
end
end end
private private
def preload_for_collection def serializer
[{ project: :namespace }, :assignees]
end
def relation_path(object)
raise NotImplementedError raise NotImplementedError
end end
def reference(object) def preload_for_collection
object.to_reference(issuable.project) [{ project: :namespace }, :assignees]
end
def issuable_path(object)
project_issue_path(object.project, object.iid)
end
# rubocop: disable CodeReuse/Serializer
def to_hash(object)
{
id: object.id,
confidential: object.confidential,
title: object.title,
assignees: UserSerializer.new.represent(object.assignees),
state: object.state,
milestone: MilestoneSerializer.new.represent(object.milestone),
weight: object.weight,
reference: reference(object),
path: issuable_path(object),
relation_path: relation_path(object),
due_date: object.due_date,
created_at: object.created_at,
closed_at: object.closed_at
}
end end
# rubocop: enable CodeReuse/Serializer
end end
end end
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
module IssueLinks module IssueLinks
class ListService < IssuableLinks::ListService class ListService < IssuableLinks::ListService
include Gitlab::Utils::StrongMemoize extend ::Gitlab::Utils::Override
private private
...@@ -10,26 +10,9 @@ module IssueLinks ...@@ -10,26 +10,9 @@ module IssueLinks
issuable.related_issues(current_user, preload: preload_for_collection) issuable.related_issues(current_user, preload: preload_for_collection)
end end
def relation_path(issue) override :serializer
# Make sure the user can admin both the current issue AND the def serializer
# referenced issue projects in order to return the removal link. LinkedProjectIssueSerializer
if can_admin_issue_link_on_current_project? && can_admin_issue_link?(issue.project)
project_issue_link_path(current_project, issuable.iid, issue.issue_link_id)
end
end
def can_admin_issue_link_on_current_project?
strong_memoize(:can_admin_on_current_project) do
can_admin_issue_link?(current_project)
end
end
def can_admin_issue_link?(project)
Ability.allowed?(current_user, :admin_issue_link, project)
end
def current_project
issuable.project
end end
end end
end end
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