orbit4-5/app/controllers/orbit_admin_controller.rb

71 lines
2.1 KiB
Ruby

class OrbitAdminController < ApplicationController
include OrbitCoreLib::Authorize
include OrbitCoreLib::PermissionUtility
include Authorize
include OrbitBackendHelper
before_action :authenticate_user, :log_user_action
layout "back_end"
def sort
unless params[:sort].blank?
case params[:sort]
when "status"
@sort = [[:is_top, params[:order]],
[:is_hot, params[:order]],
[:is_hidden,params[:order]]]
when "category"
@sort = {:category_id=>params[:order]}
when "title"
@sort = {:title=>params[:order]}
when "start_date"
@sort = {:postdate=>params[:order]}
when "end_date"
@sort = {:deadline=>params[:order]}
when "last_modified"
@sort = {:update_user_id=>params[:order]}
end
else
@sort = {:created_at=>'desc'}
end
@sort
end
def filter_fields(categories, tags)
{
:status=>[{:title=>"is_top",:id=>"is_top"},{:title=>"is_hot",:id=>"is_hot"},{:title=>"is_hidden",:id=>"is_hidden"}],
:category=>categories.map{|c| {:title=>c.title, :id=>c.id}},
:tags=>tags.map{|tag| {:title=>tag.name, :id=>tag.id}}
}
end
def filters(type)
case type
when "status"
params[:filters][:status].blank? ? [] : params[:filters][:status] rescue []
when "category"
params[:filters][:category].blank? ? [] : params[:filters][:category] rescue []
when "tag"
params[:filters][:tags].blank? ? [] : params[:filters][:tags] rescue []
end
end
private
def log_user_action
unless (request.filtered_parameters['action'].eql? "system_info") and (request.filtered_parameters['controller'].eql? "admin/sites")
log = UserAction.new
log.action = request.filtered_parameters['action']
log.controller = request.filtered_parameters['controller']
log.request_path = request.original_fullpath
log.request_method = request.request_method
log.remote_ip = request.remote_ip
log.referer = request.referer
log.save
current_user.user_actions << log
end
end
end