Description:
added admin users management
Commit status:
[Not Reviewed]
References:
Diff options:
Comments:
0 Commit comments
0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
r233:ebadb70a03ab - - 3 files changed: 61 inserted, 0 deleted
@@ -0,0 +1,25 | |||
|
1 | + %h1 Administrators | |
|
2 | + | |
|
3 | + %table | |
|
4 | + %tr | |
|
5 | + %th # | |
|
6 | + %th Login | |
|
7 | + %th Full name | |
|
8 | + %th | |
|
9 | + - @admins.each_with_index do |user, i| | |
|
10 | + %tr | |
|
11 | + %td= i+1 | |
|
12 | + %td= user.login | |
|
13 | + %td= user.full_name | |
|
14 | + %td | |
|
15 | + - if user.login!='root' | |
|
16 | + = link_to '[revoke]', :action => 'revoke_admin', :id => user.id | |
|
17 | + %hr | |
|
18 | + | |
|
19 | + - form_tag :action => 'grant_admin' do | |
|
20 | + Grant admin permission to: | |
|
21 | + = text_field_tag 'login' | |
|
22 | + = submit_tag 'Grant' | |
|
23 | + | |
|
24 | + %hr/ | |
|
25 | + = link_to '[go back to index]', :action => 'index' |
@@ -151,6 +151,41 | |||
|
151 | 151 | end |
|
152 | 152 | end |
|
153 | 153 | |
|
154 | + # admin management | |
|
155 | + | |
|
156 | + def admin | |
|
157 | + @admins = User.find(:all).find_all {|user| user.admin? } | |
|
158 | + end | |
|
159 | + | |
|
160 | + def grant_admin | |
|
161 | + login = params[:login] | |
|
162 | + user = User.find_by_login(login) | |
|
163 | + if user!=nil | |
|
164 | + admin_role = Role.find_by_name('admin') | |
|
165 | + user.roles << admin_role | |
|
166 | + else | |
|
167 | + flash[:notice] = 'Unknown user' | |
|
168 | + end | |
|
169 | + flash[:notice] = 'User added as admins' | |
|
170 | + redirect_to :action => 'admin' | |
|
171 | + end | |
|
172 | + | |
|
173 | + def revoke_admin | |
|
174 | + user = User.find(params[:id]) | |
|
175 | + if user==nil | |
|
176 | + flash[:notice] = 'Unknown user' | |
|
177 | + redirect_to :action => 'admin' and return | |
|
178 | + elsif user.login == 'root' | |
|
179 | + flash[:notice] = 'You cannot revoke admisnistrator permission from root.' | |
|
180 | + redirect_to :action => 'admin' and return | |
|
181 | + end | |
|
182 | + | |
|
183 | + admin_role = Role.find_by_name('admin') | |
|
184 | + user.roles.delete(admin_role) | |
|
185 | + flash[:notice] = 'User permission revoked' | |
|
186 | + redirect_to :action => 'admin' | |
|
187 | + end | |
|
188 | + | |
|
154 | 189 | protected |
|
155 | 190 | |
|
156 | 191 | def random_password(length=5) |
@@ -29,6 +29,7 | |||
|
29 | 29 | <b>What else: </b> |
|
30 | 30 | <%= link_to '[New user]', :action => 'new' %> |
|
31 | 31 | <%= link_to '[New list of users]', :action => 'new_list' %> |
|
32 | + <%= link_to '[View administrators]', :action => 'admin' %> | |
|
32 | 33 | <%= link_to '[Random passwords]', :action => 'random_all_passwords' %> |
|
33 | 34 | <%= link_to '[View active users]', :action => 'active' %> |
|
34 | 35 |
You need to be logged in to leave comments.
Login now