debian-mirror-gitlab/lib/api/milestone_responses.rb

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

130 lines
5 KiB
Ruby
Raw Normal View History

2018-12-05 23:21:45 +05:30
# frozen_string_literal: true
2017-09-10 17:25:29 +05:30
module API
module MilestoneResponses
extend ActiveSupport::Concern
included do
helpers do
params :optional_params do
optional :description, type: String, desc: 'The description of the milestone'
optional :due_date, type: String, desc: 'The due date of the milestone. The ISO 8601 date format (%Y-%m-%d)'
optional :start_date, type: String, desc: 'The start date of the milestone. The ISO 8601 date format (%Y-%m-%d)'
end
params :list_params do
optional :state, type: String, values: %w[active closed all], default: 'all',
2022-08-27 11:52:29 +05:30
desc: 'Return "active", "closed", or "all" milestones'
2020-07-28 23:09:34 +05:30
optional :iids, type: Array[Integer], coerce_with: ::API::Validations::Types::CommaSeparatedToIntegerArray.coerce, desc: 'The IIDs of the milestones'
2019-07-07 11:18:12 +05:30
optional :title, type: String, desc: 'The title of the milestones'
2017-09-10 17:25:29 +05:30
optional :search, type: String, desc: 'The search criteria for the title or description of the milestone'
2020-10-24 23:57:45 +05:30
optional :include_parent_milestones, type: Grape::API::Boolean, default: false,
2022-08-27 11:52:29 +05:30
desc: 'Include group milestones from parent and its ancestors'
2023-06-09 08:11:10 +05:30
optional :updated_before, type: DateTime, desc: 'Return milestones updated before the specified datetime. Format: ISO 8601 YYYY-MM-DDTHH:MM:SSZ'
optional :updated_after, type: DateTime, desc: 'Return milestones updated after the specified datetime. Format: ISO 8601 YYYY-MM-DDTHH:MM:SSZ'
2017-09-10 17:25:29 +05:30
use :pagination
end
params :update_params do
requires :milestone_id, type: Integer, desc: 'The milestone ID number'
optional :title, type: String, desc: 'The title of the milestone'
optional :state_event, type: String, values: %w[close activate],
2022-08-27 11:52:29 +05:30
desc: 'The state event of the milestone '
2017-09-10 17:25:29 +05:30
use :optional_params
2018-11-08 19:23:39 +05:30
at_least_one_of :title, :description, :start_date, :due_date, :state_event
2017-09-10 17:25:29 +05:30
end
def list_milestones_for(parent)
2023-06-09 08:11:10 +05:30
milestones = MilestonesFinder.new(
params.merge(parent_finder_params(parent))
).execute
2017-09-10 17:25:29 +05:30
present paginate(milestones), with: Entities::Milestone
end
def get_milestone_for(parent)
milestone = parent.milestones.find(params[:milestone_id])
present milestone, with: Entities::Milestone
end
def create_milestone_for(parent)
milestone = ::Milestones::CreateService.new(parent, current_user, declared_params).execute
if milestone.valid?
present milestone, with: Entities::Milestone
else
render_api_error!("Failed to create milestone #{milestone.errors.messages}", 400)
end
end
def update_milestone_for(parent)
milestone = parent.milestones.find(params.delete(:milestone_id))
milestone_params = declared_params(include_missing: false)
milestone = ::Milestones::UpdateService.new(parent, current_user, milestone_params).execute(milestone)
if milestone.valid?
present milestone, with: Entities::Milestone
else
render_api_error!("Failed to update milestone #{milestone.errors.messages}", 400)
end
end
def milestone_issuables_for(parent, type)
milestone = parent.milestones.find(params[:milestone_id])
finder_klass, entity = get_finder_and_entity(type)
params = build_finder_params(milestone, parent)
2021-04-29 21:17:54 +05:30
issuables = finder_klass.new(current_user, params).execute.with_api_entity_associations
2017-09-10 17:25:29 +05:30
present paginate(issuables), with: entity, current_user: current_user
end
2023-06-09 08:11:10 +05:30
def parent_finder_params(parent)
include_parent = params[:include_parent_milestones].present?
if parent.is_a?(Project)
{ project_ids: parent.id, group_ids: (include_parent ? project_group_ids(parent) : nil) }
else
{ group_ids: (include_parent ? group_and_ancestor_ids(parent) : parent.id) }
end
end
2017-09-10 17:25:29 +05:30
def build_finder_params(milestone, parent)
finder_params = { milestone_title: milestone.title, sort: 'label_priority' }
if parent.is_a?(Group)
finder_params.merge(group_id: parent.id)
else
finder_params.merge(project_id: parent.id)
end
end
def get_finder_and_entity(type)
if type == :issue
[IssuesFinder, Entities::IssueBasic]
else
[MergeRequestsFinder, Entities::MergeRequestBasic]
end
end
2020-10-24 23:57:45 +05:30
def project_group_ids(parent)
group = parent.group
return unless group.present?
group.self_and_ancestors.select(:id)
end
2023-06-09 08:11:10 +05:30
def group_and_ancestor_ids(group)
2020-10-24 23:57:45 +05:30
return unless group.present?
group.self_and_ancestors
.public_or_visible_to_user(current_user)
.select(:id)
end
2017-09-10 17:25:29 +05:30
end
end
end
end