From 13f92521c22f63140adbf933737e0c5dc988a8d4 Mon Sep 17 00:00:00 2001 From: Grzegorz Bizon Date: Wed, 3 Feb 2016 14:12:33 +0100 Subject: Move build eraseable API to proper API context --- lib/api/builds.rb | 22 +++++++++++++++++++++- 1 file changed, 21 insertions(+), 1 deletion(-) (limited to 'lib/api') diff --git a/lib/api/builds.rb b/lib/api/builds.rb index a8bd3842ce4..06ec03fc4e0 100644 --- a/lib/api/builds.rb +++ b/lib/api/builds.rb @@ -115,13 +115,33 @@ module API authorize_update_builds! build = get_build(params[:build_id]) - return forbidden!('Build is not retryable') unless build && build.retryable? + return not_found!(build) unless build + return forbidden!('Build is not retryable') unless build.retryable? build = Ci::Build.retry(build) present build, with: Entities::Build, user_can_download_artifacts: can?(current_user, :read_build, user_project) end + + # Erase build (remove artifacts and build trace) + # + # Parameters: + # id (required) - the id of a project + # build_id (required) - the id of a build + # example Request: + # delete /projects/:id/build/:build_id/content + delete ':id/builds/:build_id/content' do + authorize_manage_builds! + + build = get_build(params[:build_id]) + return not_found!(build) unless build + return forbidden!('Build is not eraseable!') unless build.eraseable? + + build.erase! + present build, with: Entities::Build, + user_can_download_artifacts: can?(current_user, :download_build_artifacts, user_project) + end end helpers do -- cgit v1.2.1