Project

General

Profile

Download (2.63 KB) Statistics
| Branch: | Tag: | Revision:
class FiltersController < ApplicationController
include Foreman::Controller::AutoCompleteSearch
include Foreman::Controller::Parameters::Filter

before_action :find_role
before_action :setup_search_options, :only => :index

def index
@filters = resource_base.includes(:role, :permissions).search_for(params[:search], :order => params[:order])
@filters = @filters.paginate(:page => params[:page], :per_page => params[:per_page]) unless params[:paginate] == 'client'
@roles_authorizer = Authorizer.new(User.current, :collection => @filters.map(&:role_id))
end

def new
@filter = resource_base.build
end

def create
@filter = Filter.new(filter_params)
if @filter.save
process_success :success_redirect => saved_redirect_url_or(filters_path(:role_id => @role))
else
process_error
end
end

def edit
@filter = resource_base.includes(:permissions).find(params[:id])
end

def update
@filter = resource_base.find(params[:id])
if @filter.update(filter_params)
process_success :success_redirect => saved_redirect_url_or(filters_path(:role_id => @role))
else
process_error
end
end

def destroy
@filter = resource_base.find(params[:id])
if @filter.destroy
process_success :success_redirect => saved_redirect_url_or(filters_path(:role_id => @role))
else
process_error
end
end

def disable_overriding
@filter = resource_base.find(params[:id])
@filter.disable_overriding!
process_success :success_msg => _('Filter overriding has been disabled')
end

private

def action_permission
case params[:action]
when 'disable_overriding'
'edit'
else
super
end
end

def find_role
@role = Role.find_by_id(role_id)
end

def resource_base
@resource_base ||= if @role.present?
@role.filters.authorized(current_permission)
else
Filter.where(nil).authorized(current_permission)
end
end

def role_id
params[:role_id]
end

def setup_search_options
@original_search_parameter = params[:search]
params[:search] ||= ""
params.keys.each do |param|
if param =~ /role_id$/
if (role = Role.find_by_id(params[param])).present?
query = "role_id = #{role.id}"
params[:search] += query unless params[:search].include? query
end
elsif param =~ /(\w+)_id$/
if params[param].present?
query = "#{Regexp.last_match(1)} = #{params[param]}"
params[:search] += query unless params[:search].include? query
end
end
end
end
end
(21-21/58)