debian-mirror-gitlab/app/services/releases/update_service.rb

56 lines
1.7 KiB
Ruby
Raw Normal View History

2019-02-15 15:39:39 +05:30
# frozen_string_literal: true
module Releases
2021-01-03 14:25:43 +05:30
class UpdateService < Releases::BaseService
2019-02-15 15:39:39 +05:30
def execute
2021-01-29 00:20:46 +05:30
if error = validate
return error
end
2019-12-04 20:38:33 +05:30
2020-03-09 13:42:32 +05:30
if param_for_milestone_titles_provided?
previous_milestones = release.milestones.map(&:title)
params[:milestones] = milestones
end
2019-02-15 15:39:39 +05:30
2021-01-03 14:25:43 +05:30
# transaction needed as Rails applies `save!` to milestone_releases
# when it does assign_attributes instead of actual saving
# this leads to the validation error being raised
# see https://gitlab.com/gitlab-org/gitlab/-/merge_requests/43385
ActiveRecord::Base.transaction do
if release.update(params)
2021-01-29 00:20:46 +05:30
execute_hooks(release, 'update')
2021-01-03 14:25:43 +05:30
success(tag: existing_tag, release: release, milestones_updated: milestones_updated?(previous_milestones))
else
error(release.errors.messages || '400 Bad request', 400)
end
rescue ActiveRecord::RecordInvalid => e
error(e.message || '400 Bad request', 400)
2019-02-15 15:39:39 +05:30
end
end
private
2021-01-29 00:20:46 +05:30
def validate
return error('Tag does not exist', 404) unless existing_tag
return error('Release does not exist', 404) unless release
return error('Access Denied', 403) unless allowed?
return error('params is empty', 400) if empty_params?
return error("Milestone(s) not found: #{inexistent_milestones.join(', ')}", 400) if inexistent_milestones.any?
end
2019-02-15 15:39:39 +05:30
def allowed?
Ability.allowed?(current_user, :update_release, release)
end
def empty_params?
params.except(:tag).empty?
end
2020-03-09 13:42:32 +05:30
def milestones_updated?(previous_milestones)
return false unless param_for_milestone_titles_provided?
previous_milestones.to_set != release.milestones.map(&:title)
end
2019-02-15 15:39:39 +05:30
end
end