diff options
Diffstat (limited to 'lib/api')
| -rw-r--r-- | lib/api/entities.rb | 2 | ||||
| -rw-r--r-- | lib/api/groups.rb | 92 | 
2 files changed, 50 insertions, 44 deletions
| diff --git a/lib/api/entities.rb b/lib/api/entities.rb index 3bbbd831548..b78fc1b86fe 100644 --- a/lib/api/entities.rb +++ b/lib/api/entities.rb @@ -33,7 +33,7 @@ module Gitlab      end      class Group < Grape::Entity -      expose :id, :name, :path, :name, :owner_id, :type +      expose :id, :name, :path, :owner_id      end      class GroupDetail < Grape::Entity diff --git a/lib/api/groups.rb b/lib/api/groups.rb index bc856eccdab..a67caef0bc5 100644 --- a/lib/api/groups.rb +++ b/lib/api/groups.rb @@ -2,49 +2,55 @@ module Gitlab    # groups API    class Groups < Grape::API      before { authenticate! } -    -       resource :groups do -         # Get a groups list -         # -         # Example Request: -         #  GET /groups -         get do -           @groups = paginate Group -           present @groups, with: Entities::Group -         end -          -         # Create group. Available only for admin -         # -         # Parameters: -         #   name (required)                   - Name -         #   path (required)                   - Path -         # Example Request: -         #   POST /groups -         post do -           authenticated_as_admin! -           attrs = attributes_for_keys [:name, :path] -           @group = Group.new(attrs) -           @group.owner = current_user -            -           if @group.save -             present @group, with: Entities::Group -           else -             not_found! -           end -         end -          -         # Get a single group, with containing projects -         # -         # Parameters: -         #   id (required) - The ID of a group -         # Example Request: -         #   GET /groups/:id -         get ":id" do -           @group = Group.find(params[:id]) -           present @group, with: Entities::GroupDetail -         end -          -       end +    resource :groups do +      # Get a groups list +      # +      # Example Request: +      #  GET /groups +      get do +        if current_user.admin +          @groups = paginate Group +        else +          @groups = paginate current_user.groups +        end +        present @groups, with: Entities::Group +      end + +      # Create group. Available only for admin +      # +      # Parameters: +      #   name (required)                   - Name +      #   path (required)                   - Path +      # Example Request: +      #   POST /groups +      post do +        authenticated_as_admin! +        attrs = attributes_for_keys [:name, :path] +        @group = Group.new(attrs) +        @group.owner = current_user + +        if @group.save +          present @group, with: Entities::Group +        else +          not_found! +        end +      end + +      # Get a single group, with containing projects +      # +      # Parameters: +      #   id (required) - The ID of a group +      # Example Request: +      #   GET /groups/:id +      get ":id" do +        @group = Group.find(params[:id]) +        if current_user.admin or current_user.groups.include? @group +          present @group, with: Entities::GroupDetail +        else +          not_found! +        end +      end +    end    end  end | 
