Class: Kaui::AdminAllowedUsersController
Constant Summary
EngineControllerUtil::SIMPLE_PAGINATION_THRESHOLD
Instance Method Summary
collapse
#check_for_redirect_to_tenant_screen, #current_ability, #current_user, #options_for_klient, #populate_account_details, #retrieve_allowed_users_for_current_user, #retrieve_tenants_for_current_user
Instance Method Details
#add_tenant ⇒ Object
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 81
def add_tenant
allowed_user = Kaui::AllowedUser.find(params.require(:allowed_user).require(:id))
if !current_user.root?
redirect_to admin_allowed_user_path(allowed_user.id), :alert => 'Only the root user can set tenants for user'
return
end
tenants = []
params.each do |tenant, _|
tenant_info = tenant.split('_')
next if tenant_info.size != 2 or tenant_info[0] != 'tenant'
tenants << tenant_info[1]
end
tenants_for_current_user = retrieve_tenants_for_current_user
tenants = (Kaui::Tenant.where(:id => tenants).select { |tenant| tenants_for_current_user.include?(tenant.kb_tenant_id) }).map(&:id)
allowed_user.kaui_tenant_ids = tenants
redirect_to admin_allowed_user_path(allowed_user.id), :notice => 'Successfully set tenants for user'
end
|
#create ⇒ Object
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 14
def create
@allowed_user = Kaui::AllowedUser.new(allowed_user_params)
existing_user = Kaui::AllowedUser.find_by_kb_username(@allowed_user.kb_username)
if existing_user
flash[:error] = "User with name #{@allowed_user.kb_username} already exists!"
@roles = roles_for_user(existing_user)
render :new and return
else
if params[:external] == '1'
@allowed_user.save!
else
roles = params[:roles].split(',')
@allowed_user.create_in_kb!(params.require(:password), roles, current_user.kb_username, params[:reason], params[:comment], options_for_klient)
end
redirect_to kaui_engine.admin_allowed_user_path(@allowed_user.id), :notice => 'User was successfully configured'
end
end
|
#destroy ⇒ Object
68
69
70
71
72
73
74
75
76
77
78
79
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 68
def destroy
allowed_user = Kaui::AllowedUser.find(params.require(:id))
if allowed_user
allowed_user.destroy_in_kb!(current_user.kb_username, params[:reason], params[:comment], options_for_klient)
redirect_to kaui_engine.admin_allowed_users_path, :notice => 'User was successfully deleted'
else
flash[:error] = "User #{params.require(:id)} not found"
redirect_to kaui_engine.admin_allowed_users_path
end
end
|
#edit ⇒ Object
47
48
49
50
51
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 47
def edit
@allowed_user = Kaui::AllowedUser.find(params.require(:id))
@roles = roles_for_user(@allowed_user)
end
|
#index ⇒ Object
5
6
7
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 5
def index
@allowed_users = retrieve_allowed_users_for_current_user
end
|
#new ⇒ Object
9
10
11
12
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 9
def new
@allowed_user = Kaui::AllowedUser.new
@roles = []
end
|
#show ⇒ Object
37
38
39
40
41
42
43
44
45
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 37
def show
@allowed_user = Kaui::AllowedUser.find(params.require(:id))
raise ActiveRecord::RecordNotFound.new("Could not find user #{@allowed_user.id}") unless (current_user.root? || @allowed_user.kb_username == current_user.kb_username)
@roles = roles_for_user(@allowed_user)
tenants_for_current_user = retrieve_tenants_for_current_user
@tenants = Kaui::Tenant.all.select { |tenant| tenants_for_current_user.include?(tenant.kb_tenant_id) }
end
|
#update ⇒ Object
53
54
55
56
57
58
59
60
61
62
63
64
65
66
|
# File 'app/controllers/kaui/admin_allowed_users_controller.rb', line 53
def update
@allowed_user = Kaui::AllowedUser.find(params.require(:id))
@allowed_user.description = params[:allowed_user][:description].presence
@allowed_user.update_in_kb!(params[:password].presence,
params[:roles].presence.split(','),
current_user.kb_username,
params[:reason],
params[:comment],
options_for_klient)
redirect_to kaui_engine.admin_allowed_user_path(@allowed_user.id), :notice => 'User was successfully updated'
end
|