elastic_query 0.1.0 → 0.1.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA1:
3
- metadata.gz: b32205036e3213b2463a73ed622673113f5f58c6
4
- data.tar.gz: 299718483f5eb901b6e15dd815c6bac3877a7d6d
3
+ metadata.gz: de207ca4fb2147781175ef0915edc4ad14bd9345
4
+ data.tar.gz: 4ee91de6a55bb5b109650b91b861159a64c26302
5
5
  SHA512:
6
- metadata.gz: 7e614212fc89732d869cb1848ed83c5d0039f4a15bc697883feb79116a5dc2c4031e3359517dc0715e1704998de1eeed026ef811671b5cd77a6ecd46da8a1b57
7
- data.tar.gz: 3b74350272a7cc5d0741f00fd6dec85262e74762cb325a3fb8e58af5854dc5846e48ee4c4c730ce9d79d85ccb86a9c30acadcea711d804d669d9d61607646303
6
+ metadata.gz: a4e7b46586192d4b32c192ec1531ec1c77f0547910907a82e5e2273414aa8605a741b8a90d48a8eea7abc0752575ce268126272afe615790ce4572186c89c47d
7
+ data.tar.gz: f9401f6a59b632ce777949a1441e00b0746f95a0a3430072bddbbf280006484fe835c6475d861a66c57cb915a29bd8e203a1055e2d21b8d1467aabc23cc46f30
@@ -1,18 +1,18 @@
1
1
  module ElasticQuery
2
2
  class Builder
3
- attr_reader :query
3
+ attr_accessor :query
4
4
 
5
5
  def initialize(query)
6
- @query = Query.new(query)
6
+ self.query = Query.new(query)
7
7
  end
8
8
 
9
9
  def filter(filter_query)
10
- @query = FilteredQuery.new(filter_query, query)
10
+ self.query = FilteredQuery.new(filter_query, query)
11
11
  self
12
12
  end
13
13
 
14
14
  def rescore(rescore_query, rescore_options = {})
15
- @query = RescoreQuery.new(query, rescore_query, rescore_options)
15
+ self.query = RescoreQuery.new(query, rescore_query, rescore_options)
16
16
  self
17
17
  end
18
18
 
@@ -25,5 +25,10 @@ module ElasticQuery
25
25
  def filter_nested(object_name, query, options = {})
26
26
  filter(NestedQuery.new(object_name, query, options))
27
27
  end
28
+
29
+ def function_score(functions, options = {})
30
+ self.query = FunctionScore.new(query, functions, options)
31
+ self
32
+ end
28
33
  end
29
34
  end
@@ -0,0 +1,19 @@
1
+ module ElasticQuery
2
+ class FunctionScore < Query
3
+ attr_reader :functions, :options
4
+
5
+ def initialize(query, functions, options = {})
6
+ @functions = functions
7
+ @options = options
8
+ super(query)
9
+ end
10
+
11
+ def to_hash
12
+ {
13
+ function_score: {
14
+ query: query.to_hash,
15
+ }.merge(functions.to_hash).merge(options)
16
+ }
17
+ end
18
+ end
19
+ end
@@ -3,7 +3,7 @@ module ElasticQuery
3
3
  # @example
4
4
  # Quey.new(match_all: {})
5
5
  class Query < BaseQuery
6
- attr_reader :query
6
+ attr_accessor :query
7
7
 
8
8
  def initialize(query)
9
9
  if query.class < BaseQuery
@@ -1,3 +1,3 @@
1
1
  module ElasticQuery
2
- VERSION = "0.1.0"
2
+ VERSION = "0.1.1"
3
3
  end
data/lib/elastic_query.rb CHANGED
@@ -6,6 +6,7 @@ end
6
6
  require "elastic_query/version"
7
7
  require "elastic_query/base_query"
8
8
  require "elastic_query/query"
9
+ require "elastic_query/function_score"
9
10
  require "elastic_query/nested_query"
10
11
  require "elastic_query/query_collection"
11
12
  require "elastic_query/filtered_query"
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: elastic_query
3
3
  version: !ruby/object:Gem::Version
4
- version: 0.1.0
4
+ version: 0.1.1
5
5
  platform: ruby
6
6
  authors:
7
7
  - Kristopher Bredemeier
@@ -74,6 +74,7 @@ files:
74
74
  - lib/elastic_query/base_query.rb
75
75
  - lib/elastic_query/builder.rb
76
76
  - lib/elastic_query/filtered_query.rb
77
+ - lib/elastic_query/function_score.rb
77
78
  - lib/elastic_query/nested_query.rb
78
79
  - lib/elastic_query/query.rb
79
80
  - lib/elastic_query/query_collection.rb