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 | end |
|
151 | end |
|
152 | end |
|
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 | protected |
|
189 | protected |
|
155 |
|
190 | ||
|
156 | def random_password(length=5) |
|
191 | def random_password(length=5) |
@@ -29,6 +29,7 | |||||
|
29 | <b>What else: </b> |
|
29 | <b>What else: </b> |
|
30 | <%= link_to '[New user]', :action => 'new' %> |
|
30 | <%= link_to '[New user]', :action => 'new' %> |
|
31 | <%= link_to '[New list of users]', :action => 'new_list' %> |
|
31 | <%= link_to '[New list of users]', :action => 'new_list' %> |
|
|
32 | + <%= link_to '[View administrators]', :action => 'admin' %> | ||
|
32 | <%= link_to '[Random passwords]', :action => 'random_all_passwords' %> |
|
33 | <%= link_to '[Random passwords]', :action => 'random_all_passwords' %> |
|
33 | <%= link_to '[View active users]', :action => 'active' %> |
|
34 | <%= link_to '[View active users]', :action => 'active' %> |
|
34 |
|
35 |
You need to be logged in to leave comments.
Login now