Class: Symphonia::UsersController
Instance Method Summary
collapse
#admin_require, #back_url, #current_user, #current_user_session, #handle_unverified_request, #login_require, #menu_item, #redirect_back_or_default, #redirect_to_referer_or, #render_403, #render_404, #render_api_head, #render_api_ok, #set_default_locale, #set_locale, #store_location
Instance Method Details
97
98
99
100
101
102
103
|
# File 'app/controllers/symphonia/users_controller.rb', line 97
def archive
@user.archive!
respond_to do |format|
format.html { redirect_to params[:back_url] || users_url }
format.json { head :no_content }
end
end
|
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
# File 'app/controllers/symphonia/users_controller.rb', line 41
def create
@user = Symphonia::User.new(user_params)
respond_to do |format|
if @user.save
format.html { redirect_to @user, notice: t(:text_created) }
format.xml { render xml: @user, status: :created, location: @user }
format.json { render json: @user, status: :created, location: @user }
else
format.html do
@roles = Symphonia::Role.sorted
render action: 'new'
end
format.xml { render xml: @user.errors, status: :unprocessable_entity }
format.json { render json: @user.errors, status: :unprocessable_entity }
end
end
end
|
87
88
89
90
91
92
93
94
95
|
# File 'app/controllers/symphonia/users_controller.rb', line 87
def destroy
@user.destroy
respond_to do |format|
format.html { redirect_to params[:back_url] || users_url }
format.js { render js: "Symphonia.filters.removeRow('#{view_context.dom_id(@user)}')" }
format.json { head :no_content }
end
end
|
59
60
61
|
# File 'app/controllers/symphonia/users_controller.rb', line 59
def edit
@roles = Role.all
end
|
10
11
12
13
14
15
16
17
18
19
20
21
|
# File 'app/controllers/symphonia/users_controller.rb', line 10
def index
@query = Symphonia::User.query.new
@query.from_params params
@entities = @query.entities
respond_to do |format|
format.html do
@entities = @entities.page(params[:page])
render layout: !request.xhr?
end
format.json { render json: @entities.all, only: %i[id] + Symphonia::User.registered_attributes.keys }
end
end
|
33
34
35
36
37
38
39
|
# File 'app/controllers/symphonia/users_controller.rb', line 33
def new
@user = Symphonia::User.new
@roles = Symphonia::Role.sorted
respond_to do |format|
format.html
end
end
|
23
24
25
26
27
28
29
30
31
|
# File 'app/controllers/symphonia/users_controller.rb', line 23
def show
@user = Symphonia::User.find(params[:id]) if params[:id]
@user ||= Symphonia::User.current
authorize
respond_to do |format|
format.html
format.json { render json: @user, except: %w[crypted_password password_salt persistence_token perishable_token] }
end
end
|
#unarchive ⇒ Object
105
106
107
108
109
110
111
112
113
|
# File 'app/controllers/symphonia/users_controller.rb', line 105
def unarchive
Notifier.user_change_to_active(@user).deliver_later
@user.unarchive!
respond_to do |format|
format.html { redirect_to params[:back_url] || users_url }
format.xml { head :no_content }
end
end
|
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
# File 'app/controllers/symphonia/users_controller.rb', line 63
def update
@user.attributes = user_params
@user.admin = params[:admin] if params[:admin] && Symphonia::User.current.admin?
if params[:role_id].present? && Symphonia::User.current.admin?
@role = Role.find(params[:role_id])
@user.role = @role
end
respond_to do |format|
@user.edited_by = current_user
@user.edited_at = DateTime.now
if @user.save
format.html { redirect_back_or_default user_path(@user), notice: t(:text_updated) }
format.any(:json, :xml) { head :no_content }
else
format.html do
@roles = Symphonia::Role.sorted
render action: 'edit'
end
format.xml { render xml: @user.errors, status: :unprocessable_entity }
format.json { render json: @user.errors, status: :unprocessable_entity }
end
end
end
|