Class: Symphonia::UsersController

Inherits:
ApplicationController show all
Includes:
CanCan::ControllerAdditions
Defined in:
app/controllers/symphonia/users_controller.rb

Instance Method Summary collapse

Methods included from ControllerExtensions

#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

#archiveObject



84
85
86
87
88
89
90
# File 'app/controllers/symphonia/users_controller.rb', line 84

def archive
  @user.archive!
  respond_to do |format|
    format.html { redirect_to params[:back_url] || users_url }
    format.json { head :no_content }
  end
end

#createObject



40
41
42
43
44
45
46
47
48
49
50
51
52
53
# File 'app/controllers/symphonia/users_controller.rb', line 40

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 { render action: 'new' }
      format.xml { render xml: @user.errors, status: :unprocessable_entity }
      format.json { render json: @user.errors, status: :unprocessable_entity }
    end
  end
end

#destroyObject



74
75
76
77
78
79
80
81
82
# File 'app/controllers/symphonia/users_controller.rb', line 74

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

#editObject



55
# File 'app/controllers/symphonia/users_controller.rb', line 55

def edit; end

#indexObject



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

#newObject



33
34
35
36
37
38
# File 'app/controllers/symphonia/users_controller.rb', line 33

def new
  @user = Symphonia::User.new
  respond_to do |format|
    format.html
  end
end

#showObject



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 ||= current_user
  authorize! :show, @user
  respond_to do |format|
    format.html
    format.json { render json: @user, except: %w[crypted_password password_salt persistence_token perishable_token] }
  end
end

#unarchiveObject



92
93
94
95
96
97
98
99
100
# File 'app/controllers/symphonia/users_controller.rb', line 92

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

#updateObject



57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
# File 'app/controllers/symphonia/users_controller.rb', line 57

def update
  @user.attributes = user_params
  @user.admin = params[:admin] if params[:admin] && current_user.admin?
  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 { render action: 'edit' }
      format.xml { render xml: @user.errors, status: :unprocessable_entity }
      format.json { render json: @user.errors, status: :unprocessable_entity }
    end
  end
end