1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
|
#
# Sonar, entreprise quality control tool.
# Copyright (C) 2008-2012 SonarSource
# mailto:contact AT sonarsource DOT com
#
# Sonar is free software; you can redistribute it and/or
# modify it under the terms of the GNU Lesser General Public
# License as published by the Free Software Foundation; either
# version 3 of the License, or (at your option) any later version.
#
# Sonar is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
# Lesser General Public License for more details.
#
# You should have received a copy of the GNU Lesser General Public
# License along with Sonar; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02
#
module RolesHelper
def users(role, resource_id=nil)
resource_id=(resource_id.blank? ? nil : resource_id.to_i)
user_roles=UserRole.find(:all, :include => 'user', :conditions => {:role => role, :resource_id => resource_id})
users = user_roles.map { |ur| ur.user }
Api::Utils.insensitive_sort(users) {|user| user.name}
end
def all_users
users = User.find(:all, :conditions => ["active=?", true])
Api::Utils.insensitive_sort(users) {|user| user.name}
end
def groups(role, resource_id=nil)
resource_id=(resource_id.blank? ? nil : resource_id.to_i)
group_roles=GroupRole.find(:all, :include => 'group', :conditions => {:role => role, :resource_id => resource_id})
groups = group_roles.map{|ur| ur.group}
Api::Utils.insensitive_sort(groups) {|group| group ? group.name : ''}
end
def all_groups
[nil].concat(Api::Utils.insensitive_sort(Group.all) {|group| group.name})
end
def group_name(group)
group ? group.name : 'Anyone'
end
def role_name(role)
case(role.to_s)
when 'admin': 'Administrators'
when 'default-admin': 'Administrators'
when 'user': 'Users'
when 'default-user': 'Users'
when 'codeviewer': 'Code viewers'
when 'default-codeviewer': 'Code viewers'
else role.to_s
end
end
end
|