Class: Cms::UsersController
Instance Method Summary
collapse
Methods included from AdminTab
#new_button_path
#destroy, #edit, #show, #update
allow_guests_to
#no_browser_caching
Instance Method Details
#change_password ⇒ Object
52
53
54
|
# File 'app/controllers/cms/users_controller.rb', line 52
def change_password
user
end
|
#create ⇒ Object
42
43
44
45
46
47
48
49
50
|
# File 'app/controllers/cms/users_controller.rb', line 42
def create
@user = Cms::User.new(cms_user_params)
if @user.save
flash[:notice] = "User '#{@user.login}' was created"
redirect_to users_path
else
render :action => 'new'
end
end
|
#disable ⇒ Object
65
66
67
68
69
70
71
72
73
|
# File 'app/controllers/cms/users_controller.rb', line 65
def disable
begin
user.disable!
flash[:notice] = "User #{user.login} disabled"
rescue Exception => e
flash[:error] = e.message
end
redirect_to users_path
end
|
#enable ⇒ Object
75
76
77
78
|
# File 'app/controllers/cms/users_controller.rb', line 75
def enable
user.enable!
redirect_to users_path
end
|
#index ⇒ Object
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
|
# File 'app/controllers/cms/users_controller.rb', line 10
def index
@have_external_users = Cms::ExternalUser.count > 0
query, conditions = [], []
unless params[:show_expired]
query << "expires_at IS NULL OR expires_at >= ?"
conditions << Time.now.utc
end
unless params[:key_word].blank?
query << %w(login email first_name last_name).collect { |f| "lower(#{f}) LIKE lower(?)" }.join(" OR ")
4.times { conditions << "%#{params[:key_word]}%" }
end
unless params[:group_id].to_i == 0
query << "#{UserGroupMembership.table_name}.group_id = ?"
conditions << params[:group_id]
end
query.collect! { |q| "(#{q})" }
conditions = conditions.unshift(query.join(" AND "))
per_page = params[:per_page] || 10
page_num = params[:page] ? params[:page].to_i : 1
@users = PersistentUser.where(conditions).paginate(page: page_num, per_page: per_page).includes(:user_group_memberships).references(:user_group_memberships).order("first_name, last_name, email")
end
|
#new ⇒ Object
38
39
40
|
# File 'app/controllers/cms/users_controller.rb', line 38
def new
@user = Cms::User.new
end
|
#update_password ⇒ Object
56
57
58
59
60
61
62
63
|
# File 'app/controllers/cms/users_controller.rb', line 56
def update_password
if user.update(cms_user_params)
flash[:notice] = "Password for '#{user.login}' was changed"
redirect_to(current_user.able_to?(:administrate) ? users_path : "/")
else
render :action => 'change_password'
end
end
|