106 lines
3.1 KiB
Ruby
106 lines
3.1 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class IssueEntity < IssuableEntity
|
|
include TimeTrackableEntity
|
|
|
|
format_with(:upcase) do |item|
|
|
item.try(:upcase)
|
|
end
|
|
|
|
format_with(:iso8601) do |item|
|
|
item.try(:iso8601)
|
|
end
|
|
|
|
expose :state
|
|
expose :milestone_id
|
|
expose :updated_by_id
|
|
expose :created_at, format_with: :iso8601
|
|
expose :updated_at, format_with: :iso8601
|
|
expose :milestone, using: API::Entities::Milestone
|
|
expose :labels, using: LabelEntity
|
|
expose :lock_version
|
|
expose :author_id
|
|
expose :confidential
|
|
expose :discussion_locked
|
|
expose :assignees, using: API::Entities::UserBasic
|
|
expose :due_date
|
|
expose :project_id
|
|
|
|
expose :moved_to_id do |issue|
|
|
if issue.moved? && can?(request.current_user, :read_issue, issue.moved_to)
|
|
issue.moved_to_id
|
|
end
|
|
end
|
|
|
|
expose :duplicated_to_id do |issue|
|
|
if issue.duplicated? && can?(request.current_user, :read_issue, issue.duplicated_to)
|
|
issue.duplicated_to_id
|
|
end
|
|
end
|
|
|
|
expose :web_url do |issue|
|
|
Gitlab::UrlBuilder.build(issue, only_path: true)
|
|
end
|
|
|
|
expose :current_user do
|
|
expose :can_create_note do |issue|
|
|
can?(request.current_user, :create_note, issue)
|
|
end
|
|
|
|
expose :can_create_confidential_note do |issue|
|
|
can?(request.current_user, :mark_note_as_confidential, issue)
|
|
end
|
|
|
|
expose :can_update do |issue|
|
|
can?(request.current_user, :update_issue, issue)
|
|
end
|
|
|
|
expose :can_set_issue_metadata do |issue|
|
|
can?(request.current_user, :set_issue_metadata, issue)
|
|
end
|
|
|
|
expose :can_award_emoji do |issue|
|
|
can?(request.current_user, :award_emoji, issue)
|
|
end
|
|
end
|
|
|
|
expose :create_note_path do |issue|
|
|
project_notes_path(issue.project, target_type: 'issue', target_id: issue.id)
|
|
end
|
|
|
|
expose :preview_note_path do |issue|
|
|
preview_markdown_path(issue.project, target_type: 'Issue', target_id: issue.iid)
|
|
end
|
|
|
|
expose :confidential_issues_docs_path, if: -> (issue) { issue.confidential? } do |issue|
|
|
help_page_path('user/project/issues/confidential_issues.md')
|
|
end
|
|
|
|
expose :locked_discussion_docs_path, if: -> (issue) { issue.discussion_locked? } do |issue|
|
|
help_page_path('user/discussions/index.md', anchor: 'prevent-comments-by-locking-an-issue')
|
|
end
|
|
|
|
expose :is_project_archived do |issue|
|
|
issue.project.archived?
|
|
end
|
|
|
|
expose :archived_project_docs_path, if: -> (issue) { issue.project.archived? } do |issue|
|
|
help_page_path('user/project/settings/index.md', anchor: 'archive-a-project')
|
|
end
|
|
|
|
expose :issue_email_participants do |issue|
|
|
# TODO - This is a Temporary solution to avoid leaking participants' emails
|
|
# on public/internal projects when issue is not confidential.
|
|
# Should be removed when https://gitlab.com/gitlab-org/gitlab/-/issues/383448 is implemented.
|
|
next [] unless issue.confidential?
|
|
|
|
issue.issue_email_participants.map { |x| { email: x.email } }
|
|
end
|
|
|
|
expose :issue_type,
|
|
as: :type,
|
|
format_with: :upcase,
|
|
documentation: { type: "String", desc: "One of #{::WorkItems::Type.base_types.keys.map(&:upcase)}" }
|
|
end
|
|
|
|
IssueEntity.prepend_mod_with('IssueEntity')
|