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
130
131
132
133
134
135
136
|
# File 'app/controllers/symphonia/users_controller.rb', line 130
def archive
@user.archive!
respond_to do |format|
format.html { redirect_to params[:back_url] || users_url }
format.json { head :no_content }
end
end
|
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
|
# File 'app/controllers/symphonia/users_controller.rb', line 74
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
|
120
121
122
123
124
125
126
127
128
|
# File 'app/controllers/symphonia/users_controller.rb', line 120
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
|
92
93
94
|
# File 'app/controllers/symphonia/users_controller.rb', line 92
def edit
@roles = Role.all
end
|
43
44
45
46
47
48
49
50
51
52
53
54
|
# File 'app/controllers/symphonia/users_controller.rb', line 43
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
|
66
67
68
69
70
71
72
|
# File 'app/controllers/symphonia/users_controller.rb', line 66
def new
@user = Symphonia::User.new
@roles = Symphonia::Role.sorted
respond_to do |format|
format.html
end
end
|
56
57
58
59
60
61
62
63
64
|
# File 'app/controllers/symphonia/users_controller.rb', line 56
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
138
139
140
141
142
143
144
145
146
|
# File 'app/controllers/symphonia/users_controller.rb', line 138
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
|
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
# File 'app/controllers/symphonia/users_controller.rb', line 96
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.all
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
|