module RailsConnector # This class provides a basic implementation for accessing the search using the cms api. # It can be activated by making it the superclass of SearchRequest. # It should be customized by subclassing. class CmsApiSearchRequest # Takes +query_string+ and +options+ for accessing Cms Api Search. # # +options+ is a hash and may include: # # :limit:: The maximum number of hits # :offset:: The search offset def initialize(query_string, options = {}) @query_string = query_string @options = Configuration.cms_api_options.merge(options) end # Accesses Cms Api Search using #query and fetches search hits. def fetch_hits hits = CmsRestApi.get(resource_path, { :query => query, :offset => @options[:offset], :size => @options[:limit], }) result = SES::SearchResult.new(hits['total']) hits['results'].each do |hit| hard_coded_score = 1 result << SES::Hit.new(hit['id'], hard_coded_score, hit) end result end private def resource_path "revisions/#{Workspace.current.revision_id}/objs/search" end def query now = Time.now q = [ { "field" => "_obj_class", "operator" => "equal", "value" => "Image", "negate" => true }, { "field" => "_valid_from", "operator" => "less_than", "value" => now.to_iso }, { "field" => "_valid_until", "operator" => "less_than", "value" => now.to_iso, "negate" => true } ] @query_string.split(/[\s]+/).each do |word| q << { "field" => "*", "operator" => "prefix_search", "value" => word, } end q end end end