Class: OpenSearch::DSL::Search::Filters::HasChild

Inherits:
Object
  • Object
show all
Includes:
BaseComponent
Defined in:
lib/opensearch/dsl/search/filters/has_child.rb

Overview

A filter which returns parent documents for children documents matching a query or a filter

Examples:

Return articles where John has commented


search do
  query do
    filtered do
      filter do
        has_child do
          type 'comment'
          query do
            match author: 'John'
          end
        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)


74
75
76
77
# File 'lib/opensearch/dsl/search/filters/has_child.rb', line 74

def filter(*args, &block)
  @filter = block ? OpenSearch::DSL::Search::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)


65
66
67
68
# File 'lib/opensearch/dsl/search/filters/has_child.rb', line 65

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

#to_hashHash

Converts the query definition to a Hash

Returns:

  • (Hash)


83
84
85
86
87
88
89
90
91
92
93
94
# File 'lib/opensearch/dsl/search/filters/has_child.rb', line 83

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