79 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
			
		
		
	
	
			79 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Ruby
		
	
	
	
| class Admin::UsersController < ApplicationController
 | |
|   
 | |
|   layout "admin"
 | |
|   before_filter :authenticate_user!
 | |
|   before_filter :set_attribute, :only => [:index, :show, :new, :edit]
 | |
|   
 | |
|   def index
 | |
|     @users = User.all.entries
 | |
|   end
 | |
|   
 | |
|   def show
 | |
|     @user = User.find(params[:id])
 | |
|     get_info_and_roles
 | |
|   end
 | |
|   
 | |
|   def new
 | |
|     @user = User.new
 | |
|     get_info_and_roles
 | |
|   end
 | |
|   
 | |
|   def create
 | |
|     puts params.to_yaml
 | |
|     @user = User.new(params[:user])
 | |
|     if @user.save
 | |
|       flash[:notice] = t('create.success.user')
 | |
|       redirect_to :action => :index
 | |
|     else
 | |
|       render :action => :new      
 | |
|     end
 | |
|   end
 | |
|   
 | |
|   def edit
 | |
|     @user = User.find(params[:id])
 | |
|     get_info_and_roles
 | |
|   end
 | |
|   
 | |
|   def update
 | |
|     @user = User.find(params[:id])
 | |
|     
 | |
|     # Update changes to the avatar
 | |
|     @user.remove_avatar! if params[:file]
 | |
|     @user.avatar = params[:file] if params[:file]
 | |
|     
 | |
|     if @user.id.to_s.eql?(session['warden.user.user.key'][1].to_s) && @user.admin != params[:user][:admin].to_i.to_b
 | |
|       flash.now[:error] = t(:cant_revoke_self_admin)
 | |
|     end
 | |
|     if !flash[:error] && @user.update_attributes(params[:user])
 | |
|       flash[:notice] = t('update.success.user')
 | |
|       redirect_to :action => :index
 | |
|     else
 | |
|       get_info_and_roles
 | |
|       render :action => :edit
 | |
|     end
 | |
|   end
 | |
|   
 | |
|   def destroy
 | |
|     if params[:id].eql?(session['warden.user.user.key'][1].to_s)
 | |
|       flash[:error] = t(:cant_delete_self)
 | |
|     else
 | |
|       @user = User.find(params[:id]) 
 | |
|       @user.destroy
 | |
|     end
 | |
|     
 | |
|     redirect_to :action => :index
 | |
|   end
 | |
|   
 | |
|   protected
 | |
|   
 | |
|   def get_info_and_roles
 | |
|     @infos = Info.excludes('disabled' => true)
 | |
|     @roles = Role.excludes('disabled' => true)
 | |
|   end
 | |
| 
 | |
|   def set_attribute
 | |
|     @class = 'users'
 | |
|   end
 | |
|   
 | |
| end
 |