diff options
author | Grzegorz Bizon <grzegorz@gitlab.com> | 2018-06-29 13:50:02 +0000 |
---|---|---|
committer | Grzegorz Bizon <grzegorz@gitlab.com> | 2018-06-29 13:50:02 +0000 |
commit | f316cb9b9a5d0d13d54ef0bb94845310ff640aae (patch) | |
tree | 054ec2caa0f6db9fdd1058ce697aa5a499e61c38 /lib | |
parent | cf55dd8b402dc400955039e5617cf701ef1c9930 (diff) | |
parent | c3de6a86734f8756de214cc87ac230820fa33acc (diff) | |
download | gitlab-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.rb | 17 |
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 |