blob: ca69c87b9690192f1a152fdf241d35f141b23f31 (
plain)
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
|
# app/controllers/admin_user_controller.rb:
# Controller for viewing user accounts from the admin interface.
#
# Copyright (c) 2008 UK Citizens Online Democracy. All rights reserved.
# Email: francis@mysociety.org; WWW: http://www.mysociety.org/
#
# $Id: admin_user_controller.rb,v 1.7 2008-09-15 11:11:13 francis Exp $
class AdminUserController < ApplicationController
layout "admin"
before_filter :assign_http_auth_user
def index
list
render :action => 'list'
end
def list
@query = params[:query]
@admin_users = User.paginate :order => "name", :page => params[:page], :per_page => 100,
:conditions => @query.nil? ? nil : ["lower(name) like lower('%'||?||'%') or
lower(email) like lower('%'||?||'%')", @query, @query]
end
def show
# Don't use @user as that is any logged in user
@admin_user = User.find(params[:id])
end
def edit
@admin_user = User.find(params[:id])
end
def update
@admin_user = User.find(params[:id])
@admin_user.name = params[:admin_user][:name]
@admin_user.email = params[:admin_user][:email]
@admin_user.admin_level = params[:admin_user][:admin_level]
if @admin_user.valid?
@admin_user.save!
flash[:notice] = 'User successfully updated.'
redirect_to user_admin_url(@admin_user)
else
render :action => 'edit'
end
end
def destroy_track
track_thing = TrackThing.find(params[:track_id].to_i)
track_thing.destroy
flash[:notice] = 'Track destroyed'
redirect_to user_admin_url(track_thing.tracking_user)
end
private
end
|