diff options
| author | Rémy Coutable <remy@rymai.me> | 2016-06-23 17:14:31 +0200 | 
|---|---|---|
| committer | Rémy Coutable <remy@rymai.me> | 2016-08-10 19:07:05 +0200 | 
| commit | 29850364eccccc3ce7305f6706cea1d5d073de2e (patch) | |
| tree | bbf98c0a621676b7b3f3e58b4618905923ed1454 /lib/api/helpers.rb | |
| parent | b1aac0382c406b3856db90e15df8b2a9ea7ff6cd (diff) | |
| download | gitlab-ce-29850364eccccc3ce7305f6706cea1d5d073de2e.tar.gz | |
New AccessRequests API endpoints for Group & Project
Also, mutualize AccessRequests and Members endpoints for Group &
Project.
New API documentation for the AccessRequests endpoints.
Signed-off-by: Rémy Coutable <remy@rymai.me>
Diffstat (limited to 'lib/api/helpers.rb')
| -rw-r--r-- | lib/api/helpers.rb | 25 | 
1 files changed, 6 insertions, 19 deletions
| diff --git a/lib/api/helpers.rb b/lib/api/helpers.rb index 130509cdad6..f06c262fd4c 100644 --- a/lib/api/helpers.rb +++ b/lib/api/helpers.rb @@ -28,7 +28,7 @@ module API        # If the sudo is the current user do nothing        if identifier && !(@current_user.id == identifier || @current_user.username == identifier) -        render_api_error!('403 Forbidden: Must be admin to use sudo', 403) unless @current_user.is_admin? +        forbidden!('Must be admin to use sudo') unless @current_user.is_admin?          @current_user = User.by_username_or_id(identifier)          not_found!("No user id or username for: #{identifier}") if @current_user.nil?        end @@ -47,18 +47,18 @@ module API        end      end +    # Deprecated      def user_project        @project ||= find_project(params[:id]) -      @project || not_found!("Project")      end      def find_project(id)        project = Project.find_with_namespace(id) || Project.find_by(id: id) -      if project && can?(current_user, :read_project, project) +      if can?(current_user, :read_project, project)          project        else -        nil +        not_found!('Project')        end      end @@ -89,11 +89,7 @@ module API      end      def find_group(id) -      begin -        group = Group.find(id) -      rescue ActiveRecord::RecordNotFound -        group = Group.find_by!(path: id) -      end +      group = Group.find_by(path: id) || Group.find_by(id: id)        if can?(current_user, :read_group, group)          group @@ -135,7 +131,7 @@ module API      end      def authorize!(action, subject) -      forbidden! unless abilities.allowed?(current_user, action, subject) +      forbidden! unless can?(current_user, action, subject)      end      def authorize_push_project @@ -197,10 +193,6 @@ module API        errors      end -    def validate_access_level?(level) -      Gitlab::Access.options_with_owner.values.include? level.to_i -    end -      # Checks the occurrences of datetime attributes, each attribute if present in the params hash must be in ISO 8601      # format (YYYY-MM-DDTHH:MM:SSZ) or a Bad Request error is invoked.      # @@ -411,11 +403,6 @@ module API        File.read(Gitlab.config.gitlab_shell.secret_file).chomp      end -    def handle_member_errors(errors) -      error!(errors[:access_level], 422) if errors[:access_level].any? -      not_found!(errors) -    end -      def send_git_blob(repository, blob)        env['api.format'] = :txt        content_type 'text/plain' | 
