Commit 8edc6b6a8c240322499356df96e1199bb6bbc872
1 parent
61833bcb
Exists in
master
and in
4 other branches
Add api for creating/listing/viewing groups
Showing
3 changed files
with
62 additions
and
1 deletions
Show diff stats
lib/api.rb
@@ -11,7 +11,8 @@ module Gitlab | @@ -11,7 +11,8 @@ module Gitlab | ||
11 | format :json | 11 | format :json |
12 | error_format :json | 12 | error_format :json |
13 | helpers APIHelpers | 13 | helpers APIHelpers |
14 | - | 14 | + |
15 | + mount Groups | ||
15 | mount Users | 16 | mount Users |
16 | mount Projects | 17 | mount Projects |
17 | mount Issues | 18 | mount Issues |
lib/api/entities.rb
@@ -32,6 +32,16 @@ module Gitlab | @@ -32,6 +32,16 @@ module Gitlab | ||
32 | end | 32 | end |
33 | end | 33 | end |
34 | 34 | ||
35 | + class Group < Grape::Entity | ||
36 | + expose :id, :name, :path, :name, :owner_id, :type | ||
37 | + end | ||
38 | + | ||
39 | + class GroupDetail < Grape::Entity | ||
40 | + expose :id, :name, :path, :name, :owner_id, :type | ||
41 | + expose :projects, using: Entities::Project | ||
42 | + end | ||
43 | + | ||
44 | + | ||
35 | class RepoObject < Grape::Entity | 45 | class RepoObject < Grape::Entity |
36 | expose :name, :commit | 46 | expose :name, :commit |
37 | expose :protected do |repo, options| | 47 | expose :protected do |repo, options| |
@@ -0,0 +1,50 @@ | @@ -0,0 +1,50 @@ | ||
1 | +module Gitlab | ||
2 | + # groups API | ||
3 | + class Groups < Grape::API | ||
4 | + before { authenticate! } | ||
5 | + | ||
6 | + resource :groups do | ||
7 | + # Get a groups list | ||
8 | + # | ||
9 | + # Example Request: | ||
10 | + # GET /groups | ||
11 | + get do | ||
12 | + @groups = paginate Group | ||
13 | + present @groups, with: Entities::Group | ||
14 | + | ||
15 | + end | ||
16 | + | ||
17 | + # Create group. Available only for admin | ||
18 | + # | ||
19 | + # Parameters: | ||
20 | + # name (required) - Name | ||
21 | + # path (required) - Path | ||
22 | + # Example Request: | ||
23 | + # POST /groups | ||
24 | + post do | ||
25 | + authenticated_as_admin! | ||
26 | + attrs = attributes_for_keys [:name, :path] | ||
27 | + @group = Group.new(attrs) | ||
28 | + @group.owner = current_user | ||
29 | + | ||
30 | + if @group.save | ||
31 | + present @group, with: Entities::Group | ||
32 | + else | ||
33 | + not_found! | ||
34 | + end | ||
35 | + end | ||
36 | + | ||
37 | + # Get a single group, with containing projects | ||
38 | + # | ||
39 | + # Parameters: | ||
40 | + # id (required) - The ID of a group | ||
41 | + # Example Request: | ||
42 | + # GET /groups/:id | ||
43 | + get ":id" do | ||
44 | + @group = Group.find(params[:id]) | ||
45 | + present @group, with: Entities::GroupDetail | ||
46 | + end | ||
47 | + | ||
48 | + end | ||
49 | + end | ||
50 | +end |