Class: Cms::UsersController

Inherits:
ResourceController show all
Includes:
AdminTab
Defined in:
app/controllers/cms/users_controller.rb

Instance Method Summary collapse

Methods included from AdminTab

#new_button_path

Methods inherited from ResourceController

#destroy, #edit, #show, #update

Methods inherited from BaseController

allow_guests_to

Methods inherited from ApplicationController

#no_browser_caching

Instance Method Details

#change_passwordObject



52
53
54
# File 'app/controllers/cms/users_controller.rb', line 52

def change_password
  user
end

#createObject



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.}' was created"
    redirect_to users_path
  else
    render :action => 'new'
  end
end

#disableObject



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.} disabled"
  rescue Exception => e
    flash[:error] = e.message
  end
  redirect_to users_path
end

#enableObject



75
76
77
78
# File 'app/controllers/cms/users_controller.rb', line 75

def enable
  user.enable!
  redirect_to users_path
end

#indexObject



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

#newObject



38
39
40
# File 'app/controllers/cms/users_controller.rb', line 38

def new
  @user = Cms::User.new
end

#update_passwordObject



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.}' was changed"
    redirect_to(current_user.able_to?(:administrate) ? users_path : "/")
  else
    render :action => 'change_password'
  end
end