Commit 00e4a479d3732a528745513e4150fe28fee178e2
1 parent
585a53c4
Exists in
master
and in
4 other branches
allow/deny user to create group/team
Showing
4 changed files
with
32 additions
and
10 deletions
Show diff stats
app/controllers/groups_controller.rb
@@ -6,6 +6,7 @@ class GroupsController < ApplicationController | @@ -6,6 +6,7 @@ class GroupsController < ApplicationController | ||
6 | 6 | ||
7 | # Authorize | 7 | # Authorize |
8 | before_filter :authorize_read_group!, except: [:new, :create] | 8 | before_filter :authorize_read_group!, except: [:new, :create] |
9 | + before_filter :authorize_create_group!, only: [:new, :create] | ||
9 | 10 | ||
10 | # Load group projects | 11 | # Load group projects |
11 | before_filter :projects, except: [:new, :create] | 12 | before_filter :projects, except: [:new, :create] |
@@ -103,4 +104,8 @@ class GroupsController < ApplicationController | @@ -103,4 +104,8 @@ class GroupsController < ApplicationController | ||
103 | return render_404 | 104 | return render_404 |
104 | end | 105 | end |
105 | end | 106 | end |
107 | + | ||
108 | + def authorize_create_group! | ||
109 | + can?(current_user, :create_group, nil) | ||
110 | + end | ||
106 | end | 111 | end |
app/models/ability.rb
1 | class Ability | 1 | class Ability |
2 | class << self | 2 | class << self |
3 | - def allowed(object, subject) | 3 | + def allowed(user, subject) |
4 | + return [] unless user.kind_of?(User) | ||
5 | + | ||
4 | case subject.class.name | 6 | case subject.class.name |
5 | - when "Project" then project_abilities(object, subject) | ||
6 | - when "Issue" then issue_abilities(object, subject) | ||
7 | - when "Note" then note_abilities(object, subject) | ||
8 | - when "Snippet" then snippet_abilities(object, subject) | ||
9 | - when "MergeRequest" then merge_request_abilities(object, subject) | ||
10 | - when "Group", "Namespace" then group_abilities(object, subject) | ||
11 | - when "UserTeam" then user_team_abilities(object, subject) | 7 | + when "Project" then project_abilities(user, subject) |
8 | + when "Issue" then issue_abilities(user, subject) | ||
9 | + when "Note" then note_abilities(user, subject) | ||
10 | + when "Snippet" then snippet_abilities(user, subject) | ||
11 | + when "MergeRequest" then merge_request_abilities(user, subject) | ||
12 | + when "Group", "Namespace" then group_abilities(user, subject) | ||
13 | + when "UserTeam" then user_team_abilities(user, subject) | ||
12 | else [] | 14 | else [] |
13 | - end | 15 | + end.concat(global_abilities(user)) |
16 | + end | ||
17 | + | ||
18 | + def global_abilities(user) | ||
19 | + rules = [] | ||
20 | + rules << :create_group if user.can_create_group | ||
21 | + rules << :create_team if user.can_create_team | ||
22 | + rules | ||
14 | end | 23 | end |
15 | 24 | ||
16 | def project_abilities(user, project) | 25 | def project_abilities(user, project) |
app/models/user.rb
@@ -232,7 +232,7 @@ class User < ActiveRecord::Base | @@ -232,7 +232,7 @@ class User < ActiveRecord::Base | ||
232 | end | 232 | end |
233 | 233 | ||
234 | def can_create_group? | 234 | def can_create_group? |
235 | - can_create_project? | 235 | + can?(:create_group, nil) |
236 | end | 236 | end |
237 | 237 | ||
238 | def abilities | 238 | def abilities |
app/views/admin/users/_form.html.haml
@@ -47,6 +47,14 @@ | @@ -47,6 +47,14 @@ | ||
47 | .input= f.number_field :projects_limit | 47 | .input= f.number_field :projects_limit |
48 | 48 | ||
49 | .clearfix | 49 | .clearfix |
50 | + = f.label :can_create_group | ||
51 | + .input= f.check_box :can_create_group | ||
52 | + | ||
53 | + .clearfix | ||
54 | + = f.label :can_create_team | ||
55 | + .input= f.check_box :can_create_team | ||
56 | + | ||
57 | + .clearfix | ||
50 | = f.label :admin do | 58 | = f.label :admin do |
51 | %strong.cred Administrator | 59 | %strong.cred Administrator |
52 | .input= f.check_box :admin | 60 | .input= f.check_box :admin |