Class: Elasticsearch::DSL::Search::Queries::Filtered

Inherits:
Object
  • Object
show all
Includes:
BaseComponent
Defined in:
lib/elasticsearch/dsl/search/queries/filtered.rb

Overview

Note:

It’s possible and common to define just the ‘filter` part of the search definition, for a structured search use case.

A query which allows to combine a query with a filter

Examples:

Find documents about Twitter published last month


search do
  query do
    filtered do
      query do
        multi_match do
          query 'twitter'
          fields [ :title, :abstract, :content ]
        end
      end
      filter do
        range :published_on do
          gte 'now-1M/M'
        end
      end
    end
  end
end

See Also:

Instance Method Summary collapse

Methods included from BaseComponent

included, #initialize

Instance Method Details

#filter(*args, &block) ⇒ self

DSL method for building the ‘filter` part of the query definition

Returns:

  • (self)


68
69
70
71
# File 'lib/elasticsearch/dsl/search/queries/filtered.rb', line 68

def filter(*args, &block)
  @filter = block ? Filter.new(*args, &block) : args.first
  self
end

#query(*args, &block) ⇒ self

DSL method for building the ‘query` part of the query definition

Returns:

  • (self)


59
60
61
62
# File 'lib/elasticsearch/dsl/search/queries/filtered.rb', line 59

def query(*args, &block)
  @query = block ? @query = Query.new(*args, &block) : args.first
  self
end

#to_hashHash

Converts the query definition to a Hash

Returns:

  • (Hash)


77
78
79
80
81
82
83
84
85
86
87
88
# File 'lib/elasticsearch/dsl/search/queries/filtered.rb', line 77

def to_hash
  hash = super
  if @query
    _query = @query.respond_to?(:to_hash) ? @query.to_hash : @query
    hash[self.name].update(query: _query)
  end
  if @filter
    _filter = @filter.respond_to?(:to_hash) ? @filter.to_hash : @filter
    hash[self.name].update(filter: _filter)
  end
  hash
end