diff options
| author | Eric <eric.yu@twosigma.com> | 2017-08-02 10:16:17 +0000 | 
|---|---|---|
| committer | Rémy Coutable <remy@rymai.me> | 2017-08-02 10:16:17 +0000 | 
| commit | fb5b2d8d0eb544630f97233731466a18380301c7 (patch) | |
| tree | 692486a690ae1b8b5153fc72ccd4e0e860281159 /lib/api | |
| parent | 30413fd2fffb42424d83c68814a2e8e70bf94671 (diff) | |
| download | gitlab-ce-fb5b2d8d0eb544630f97233731466a18380301c7.tar.gz | |
Extending API for protected branches
Diffstat (limited to 'lib/api')
| -rw-r--r-- | lib/api/api.rb | 1 | ||||
| -rw-r--r-- | lib/api/branches.rb | 6 | ||||
| -rw-r--r-- | lib/api/entities.rb | 15 | ||||
| -rw-r--r-- | lib/api/protected_branches.rb | 85 | 
4 files changed, 104 insertions, 3 deletions
| diff --git a/lib/api/api.rb b/lib/api/api.rb index ae10da2d85f..e08f4e2995f 100644 --- a/lib/api/api.rb +++ b/lib/api/api.rb @@ -123,6 +123,7 @@ module API      mount ::API::ProjectHooks      mount ::API::Projects      mount ::API::ProjectSnippets +    mount ::API::ProtectedBranches      mount ::API::Repositories      mount ::API::Runner      mount ::API::Runners diff --git a/lib/api/branches.rb b/lib/api/branches.rb index 9dd60d1833b..d3dbf941298 100644 --- a/lib/api/branches.rb +++ b/lib/api/branches.rb @@ -37,6 +37,7 @@ module API          present branch, with: Entities::RepoBranch, project: user_project        end +      # Note: This API will be deprecated in favor of the protected branches API.        # Note: The internal data model moved from `developers_can_{merge,push}` to `allowed_to_{merge,push}`        # in `gitlab-org/gitlab-ce!5081`. The API interface has not been changed (to maintain compatibility),        # but it works with the changed data model to infer `developers_can_merge` and `developers_can_push`. @@ -65,9 +66,9 @@ module API          service_args = [user_project, current_user, protected_branch_params]          protected_branch = if protected_branch -                             ProtectedBranches::ApiUpdateService.new(*service_args).execute(protected_branch) +                             ::ProtectedBranches::ApiUpdateService.new(*service_args).execute(protected_branch)                             else -                             ProtectedBranches::ApiCreateService.new(*service_args).execute +                             ::ProtectedBranches::ApiCreateService.new(*service_args).execute                             end          if protected_branch.valid? @@ -77,6 +78,7 @@ module API          end        end +      # Note: This API will be deprecated in favor of the protected branches API.        desc 'Unprotect a single branch' do          success Entities::RepoBranch        end diff --git a/lib/api/entities.rb b/lib/api/entities.rb index ce25be34ec4..f31fe704e0c 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -240,7 +240,7 @@ module API        end        expose :protected do |repo_branch, options| -        ProtectedBranch.protected?(options[:project], repo_branch.name) +        ::ProtectedBranch.protected?(options[:project], repo_branch.name)        end        expose :developers_can_push do |repo_branch, options| @@ -299,6 +299,19 @@ module API        expose :deleted_file?, as: :deleted_file      end +    class ProtectedRefAccess < Grape::Entity +      expose :access_level +      expose :access_level_description do |protected_ref_access| +        protected_ref_access.humanize +      end +    end + +    class ProtectedBranch < Grape::Entity +      expose :name +      expose :push_access_levels, using: Entities::ProtectedRefAccess +      expose :merge_access_levels, using: Entities::ProtectedRefAccess +    end +      class Milestone < Grape::Entity        expose :id, :iid        expose :project_id, if: -> (entity, options) { entity&.project_id } diff --git a/lib/api/protected_branches.rb b/lib/api/protected_branches.rb new file mode 100644 index 00000000000..d742f2e18d0 --- /dev/null +++ b/lib/api/protected_branches.rb @@ -0,0 +1,85 @@ +module API +  class ProtectedBranches < Grape::API +    include PaginationParams + +    BRANCH_ENDPOINT_REQUIREMENTS = API::PROJECT_ENDPOINT_REQUIREMENTS.merge(branch: API::NO_SLASH_URL_PART_REGEX) + +    before { authorize_admin_project } + +    params do +      requires :id, type: String, desc: 'The ID of a project' +    end +    resource :projects, requirements: API::PROJECT_ENDPOINT_REQUIREMENTS do +      desc "Get a project's protected branches" do +        success Entities::ProtectedBranch +      end +      params do +        use :pagination +      end +      get ':id/protected_branches' do +        protected_branches = user_project.protected_branches.preload(:push_access_levels, :merge_access_levels) + +        present paginate(protected_branches), with: Entities::ProtectedBranch, project: user_project +      end + +      desc 'Get a single protected branch' do +        success Entities::ProtectedBranch +      end +      params do +        requires :name, type: String, desc: 'The name of the branch or wildcard' +      end +      get ':id/protected_branches/:name', requirements: BRANCH_ENDPOINT_REQUIREMENTS do +        protected_branch = user_project.protected_branches.find_by!(name: params[:name]) + +        present protected_branch, with: Entities::ProtectedBranch, project: user_project +      end + +      desc 'Protect a single branch or wildcard' do +        success Entities::ProtectedBranch +      end +      params do +        requires :name, type: String, desc: 'The name of the protected branch' +        optional :push_access_level, type: Integer, default: Gitlab::Access::MASTER, +                                     values: ProtectedBranchAccess::ALLOWED_ACCESS_LEVELS, +                                     desc: 'Access levels allowed to push (defaults: `40`, master access level)' +        optional :merge_access_level, type: Integer, default: Gitlab::Access::MASTER, +                                      values: ProtectedBranchAccess::ALLOWED_ACCESS_LEVELS, +                                      desc: 'Access levels allowed to merge (defaults: `40`, master access level)' +      end +      post ':id/protected_branches' do +        protected_branch = user_project.protected_branches.find_by(name: params[:name]) +        if protected_branch +          conflict!("Protected branch '#{params[:name]}' already exists") +        end + +        protected_branch_params = { +          name: params[:name], +          push_access_levels_attributes: [{ access_level: params[:push_access_level] }], +          merge_access_levels_attributes: [{ access_level: params[:merge_access_level] }] +        } + +        service_args = [user_project, current_user, protected_branch_params] + +        protected_branch = ::ProtectedBranches::CreateService.new(*service_args).execute +         +        if protected_branch.persisted? +          present protected_branch, with: Entities::ProtectedBranch, project: user_project +        else +          render_api_error!(protected_branch.errors.full_messages, 422) +        end +      end + +      desc 'Unprotect a single branch' +      params do +        requires :name, type: String, desc: 'The name of the protected branch' +      end +      delete ':id/protected_branches/:name', requirements: BRANCH_ENDPOINT_REQUIREMENTS do +        protected_branch = user_project.protected_branches.find_by!(name: params[:name]) + +        protected_branch.destroy + +        status 204 +      end +    end +  end +end | 
