summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorGrzegorz Bizon <grzegorz@gitlab.com>2018-06-29 13:50:02 +0000
committerGrzegorz Bizon <grzegorz@gitlab.com>2018-06-29 13:50:02 +0000
commitf316cb9b9a5d0d13d54ef0bb94845310ff640aae (patch)
tree054ec2caa0f6db9fdd1058ce697aa5a499e61c38 /lib
parentcf55dd8b402dc400955039e5617cf701ef1c9930 (diff)
parentc3de6a86734f8756de214cc87ac230820fa33acc (diff)
downloadgitlab-ce-f316cb9b9a5d0d13d54ef0bb94845310ff640aae.tar.gz
Merge branch 'transfer_project_api_endpoint' into 'master'
Add transfer project endpoint to the Projects API Closes #45146 See merge request gitlab-org/gitlab-ce!20122
Diffstat (limited to 'lib')
-rw-r--r--lib/api/projects.rb17
1 files changed, 17 insertions, 0 deletions
diff --git a/lib/api/projects.rb b/lib/api/projects.rb
index 3ef3680c5d9..b83da00502d 100644
--- a/lib/api/projects.rb
+++ b/lib/api/projects.rb
@@ -459,6 +459,23 @@ module API
conflict!(error.message)
end
end
+
+ desc 'Transfer a project to a new namespace'
+ params do
+ requires :namespace, type: String, desc: 'The ID or path of the new namespace'
+ end
+ put ":id/transfer" do
+ authorize! :change_namespace, user_project
+
+ namespace = find_namespace!(params[:namespace])
+ result = ::Projects::TransferService.new(user_project, current_user).execute(namespace)
+
+ if result
+ present user_project, with: Entities::Project
+ else
+ render_api_error!("Failed to transfer project #{user_project.errors.messages}", 400)
+ end
+ end
end
end
end