mirror of
https://github.com/openSUSE/osem.git
synced 2026-01-01 02:30:38 -05:00
Resolves: - inability to filter, order, or paginate datatables - exception AjaxDatatablesRails::Error::InvalidSearchColumn Continues: -81853d1ef9-83636afee0
77 lines
2.5 KiB
Ruby
77 lines
2.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Admin
|
|
class UsersController < Admin::BaseController
|
|
load_and_authorize_resource
|
|
|
|
def new
|
|
@user = User.new
|
|
end
|
|
|
|
def create
|
|
@user = User.new(user_params)
|
|
@user.skip_confirmation!
|
|
if @user.save
|
|
redirect_to admin_users_path, notice: 'User successfully created.'
|
|
else
|
|
flash.now[:error] = "Creating User failed: #{@user.errors.full_messages.join('. ')}."
|
|
render :new
|
|
end
|
|
end
|
|
|
|
def index
|
|
respond_to do |format|
|
|
format.html
|
|
format.json do
|
|
render json: UserDatatable.new(params, view_context: view_context)
|
|
end
|
|
end
|
|
end
|
|
|
|
# This action allow admins to manually toggle confirmation state of another user
|
|
def toggle_confirmation
|
|
if user_params[:to_confirm] == 'true'
|
|
@user.confirm
|
|
elsif user_params[:to_confirm] == 'false'
|
|
@user.confirmed_at = nil
|
|
@user.save
|
|
end
|
|
head :ok
|
|
end
|
|
|
|
def show
|
|
# Variable @show_attributes holds the attributes that are visible for the 'show' action
|
|
# If you want to change the attributes that are shown in the 'show' action of users
|
|
# add/remove the attributes in the following string array
|
|
@show_attributes = %w(name email username nickname affiliation biography registered attended roles created_at
|
|
updated_at sign_in_count current_sign_in_at last_sign_in_at
|
|
current_sign_in_ip last_sign_in_ip)
|
|
end
|
|
|
|
def update
|
|
message = ''
|
|
if params[:user] && !params[:user][:email].nil?
|
|
if (new_email = params[:user][:email]) != @user.email
|
|
message = " Confirmation email sent to #{new_email}. The new email needs to be confirmed before it can be used."
|
|
end
|
|
end
|
|
|
|
if @user.update(user_params)
|
|
redirect_to admin_users_path, notice: "Updated #{@user.name} (#{@user.email})!" + message
|
|
else
|
|
redirect_to admin_users_path, error: "Could not update #{@user.name} (#{@user.email}). #{@user.errors.full_messages.join('. ')}."
|
|
end
|
|
end
|
|
|
|
def edit; end
|
|
|
|
private
|
|
|
|
def user_params
|
|
params.require(:user).permit(:email, :name, :email_public, :biography, :nickname, :affiliation, :is_admin,
|
|
:username, :login, :is_disabled, :tshirt, :mobile, :volunteer_experience,
|
|
:languages, :to_confirm, :password, role_ids: [])
|
|
end
|
|
end
|
|
end
|