trabajo-afectivo/app/controllers/search_controller.rb

126 lines
3.5 KiB
Ruby
Raw Normal View History

2014-02-03 19:24:49 +00:00
# Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
2013-05-21 22:30:09 +00:00
class SearchController < ApplicationController
before_action :authentication_check
2013-05-21 22:30:09 +00:00
# GET|POST /api/v1/search
# GET|POST /api/v1/search/:objects
def search_generic
2014-09-19 21:35:40 +00:00
# enable search only for users with valid session
if !current_user
2014-09-19 21:35:40 +00:00
response_access_deny
return true
end
# get params
query = params[:query]
limit = params[:limit] || 10
# convert objects string into array of class names
# e.g. user-ticket-another_object = %w( User Ticket AnotherObject )
if !params[:objects]
objects = Setting.get('models_searchable')
else
objects = params[:objects].split('-').map(&:camelize)
end
# get priorities of result
objects_in_order = []
objects_in_order_hash = {}
objects.each { |object|
preferences = object.constantize.search_preferences(current_user)
next if !preferences
objects_in_order_hash[preferences[:prio]] = object
}
2015-08-21 21:53:53 +00:00
objects_in_order_hash.keys.sort.reverse_each {|prio|
objects_in_order.push objects_in_order_hash[prio]
}
2014-09-19 21:35:40 +00:00
# try search index backend
assets = {}
result = []
if SearchIndexBackend.enabled?
# get direct search index based objects
objects_with_direct_search_index = []
objects_without_direct_search_index = []
objects.each { |object|
preferences = object.constantize.search_preferences(current_user)
next if !preferences
if preferences[:direct_search_index]
objects_with_direct_search_index.push object
else
objects_without_direct_search_index.push object
end
2014-09-19 21:35:40 +00:00
}
# do only one query to index search backend
if !objects_with_direct_search_index.empty?
items = SearchIndexBackend.search( query, limit, objects_with_direct_search_index )
items.each { |item|
require item[:type].to_filename
record = Kernel.const_get( item[:type] ).find( item[:id] )
assets = record.assets(assets)
result.push item
}
end
# e. g. do ticket query by Ticket class to handle ticket permissions
objects_without_direct_search_index.each { |object|
object_result = search_generic_backend(object, query, limit, current_user, assets)
if !object_result.empty?
result = result.concat(object_result)
end
}
# sort order by object priority
result_in_order = []
objects_in_order.each { |object|
result.each {|item|
next if item[:type] != object
item[:id] = item[:id].to_i
result_in_order.push item
}
}
result = result_in_order
2014-09-19 21:35:40 +00:00
else
2014-09-19 21:35:40 +00:00
# do query
objects_in_order.each { |object|
object_result = search_generic_backend(object, query, limit, current_user, assets)
if !object_result.empty?
result = result.concat(object_result)
end
}
2014-09-19 21:35:40 +00:00
end
render json: {
assets: assets,
result: result,
2014-09-19 21:35:40 +00:00
}
end
private
def search_generic_backend(object, query, limit, current_user, assets)
found_objects = object.constantize.search(
query: query,
limit: limit,
current_user: current_user,
)
result = []
found_objects.each do |found_object|
item = {
id: found_object.id,
type: found_object.class.to_s
}
result.push item
assets = found_object.assets(assets)
end
result
end
2013-05-21 22:30:09 +00:00
end