mirror of
https://github.com/CodeforLeipzig/stadtratmonitor.git
synced 2025-01-22 13:37:58 +01:00
Extract search query into own class
This commit is contained in:
parent
267e56d18a
commit
71d3b3086e
2 changed files with 65 additions and 53 deletions
|
@ -62,59 +62,7 @@ class Paper < ActiveRecord::Base
|
|||
# see https://github.com/elastic/elasticsearch-ruby/tree/master/elasticsearch-dsl
|
||||
# and https://github.com/elastic/elasticsearch-rails/tree/master/elasticsearch-rails/lib/rails/templates
|
||||
def search(q, options={})
|
||||
@search_definition = Elasticsearch::DSL::Search.search do
|
||||
|
||||
query do
|
||||
# search query
|
||||
unless q.blank?
|
||||
multi_match do
|
||||
query q
|
||||
fields ["name", "content"]
|
||||
end
|
||||
else
|
||||
match_all
|
||||
end
|
||||
end
|
||||
|
||||
# apply filter after aggregations
|
||||
post_filter do
|
||||
bool do
|
||||
must { term paper_type: options[:paper_type] } if options[:paper_type].present?
|
||||
must { term originator: options[:originator] } if options[:originator].present?
|
||||
# catchall when no filters set
|
||||
must { match_all } if options.keys.none? {|k| [:paper_type, :originator].include?(k) }
|
||||
end
|
||||
end
|
||||
|
||||
aggregation :paper_types do
|
||||
# filter by originator
|
||||
f = Elasticsearch::DSL::Search::Filters::Bool.new
|
||||
f.must { match_all }
|
||||
f.must { term originator: options[:originator] } if options[:originator].present?
|
||||
filter f.to_hash do
|
||||
aggregation :paper_types do
|
||||
terms do
|
||||
field 'paper_type'
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
aggregation :originators do
|
||||
# filter by paper_type
|
||||
f = Elasticsearch::DSL::Search::Filters::Bool.new
|
||||
f.must { match_all }
|
||||
f.must { term paper_type: options[:paper_type] } if options[:paper_type].present?
|
||||
filter f.to_hash do
|
||||
aggregation :originators do
|
||||
terms do
|
||||
field 'originator'
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
@search_definition = PaperSearch.definition(q, options)
|
||||
Rails.logger.debug "Query: #{@search_definition.to_json}"
|
||||
__elasticsearch__.search(@search_definition)
|
||||
end
|
||||
|
|
64
app/models/paper_search.rb
Normal file
64
app/models/paper_search.rb
Normal file
|
@ -0,0 +1,64 @@
|
|||
class PaperSearch
|
||||
|
||||
def self.definition(q, options={})
|
||||
Elasticsearch::DSL::Search.search do
|
||||
|
||||
sort do
|
||||
if options[:sort_by] == 'date'
|
||||
by :published_at, order: 'desc'
|
||||
end
|
||||
by '_score'
|
||||
end
|
||||
|
||||
query do
|
||||
# search query
|
||||
unless q.blank?
|
||||
multi_match do
|
||||
query q
|
||||
fields ["name", "content"]
|
||||
end
|
||||
else
|
||||
match_all
|
||||
end
|
||||
end
|
||||
|
||||
# apply filter after aggregations
|
||||
post_filter do
|
||||
bool do
|
||||
must { term paper_type: options[:paper_type] } if options[:paper_type].present?
|
||||
must { term originator: options[:originator] } if options[:originator].present?
|
||||
# catchall when no filters set
|
||||
must { match_all } if options.keys.none? {|k| [:paper_type, :originator].include?(k) }
|
||||
end
|
||||
end
|
||||
|
||||
aggregation :paper_types do
|
||||
# filter by originator
|
||||
f = Elasticsearch::DSL::Search::Filters::Bool.new
|
||||
f.must { match_all }
|
||||
f.must { term originator: options[:originator] } if options[:originator].present?
|
||||
filter f.to_hash do
|
||||
aggregation :paper_types do
|
||||
terms do
|
||||
field 'paper_type'
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
aggregation :originators do
|
||||
# filter by paper_type
|
||||
f = Elasticsearch::DSL::Search::Filters::Bool.new
|
||||
f.must { match_all }
|
||||
f.must { term paper_type: options[:paper_type] } if options[:paper_type].present?
|
||||
filter f.to_hash do
|
||||
aggregation :originators do
|
||||
terms do
|
||||
field 'originator'
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
Loading…
Reference in a new issue