eson-dsl 0.7.0
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE.md +20 -0
- data/README.md +179 -0
- data/Rakefile +30 -0
- data/TODO.md +1 -0
- data/eson-dsl.gemspec +21 -0
- data/examples/facets/date_histogram.rb +5 -0
- data/examples/facets/filter.rb +7 -0
- data/examples/facets/geo_distance.rb +14 -0
- data/examples/facets/histogram.rb +5 -0
- data/examples/facets/query.rb +7 -0
- data/examples/facets/range.rb +8 -0
- data/examples/facets/scoped.rb +17 -0
- data/examples/facets/statistical.rb +5 -0
- data/examples/facets/term_stats.rb +9 -0
- data/examples/facets/terms.rb +8 -0
- data/examples/filters/and.rb +11 -0
- data/examples/filters/and_without_keyword.rb +9 -0
- data/examples/filters/bool.rb +16 -0
- data/examples/filters/exists.rb +9 -0
- data/examples/filters/fquery.rb +11 -0
- data/examples/filters/geo_bounding_box.rb +8 -0
- data/examples/filters/geo_distance.rb +8 -0
- data/examples/filters/geo_distance_alternate.rb +9 -0
- data/examples/filters/geo_distance_range.rb +10 -0
- data/examples/filters/geo_polygon.rb +10 -0
- data/examples/filters/has_child.rb +9 -0
- data/examples/filters/ids.rb +8 -0
- data/examples/filters/missing.rb +9 -0
- data/examples/filters/not.rb +10 -0
- data/examples/filters/numeric_range.rb +9 -0
- data/examples/filters/or.rb +11 -0
- data/examples/filters/range.rb +5 -0
- data/examples/filters/type.rb +5 -0
- data/examples/queries/bool.rb +16 -0
- data/examples/queries/boosting.rb +12 -0
- data/examples/queries/constant_score.rb +9 -0
- data/examples/queries/constant_score_with_filter.rb +9 -0
- data/examples/queries/custom_score.rb +15 -0
- data/examples/queries/dis_max.rb +10 -0
- data/examples/queries/field.rb +5 -0
- data/examples/queries/filters_and_facets.rb +11 -0
- data/examples/queries/flt.rb +7 -0
- data/examples/queries/flt_field.rb +7 -0
- data/examples/queries/fuzzy.rb +5 -0
- data/examples/queries/fuzzy_complex.rb +5 -0
- data/examples/queries/has_child.rb +9 -0
- data/examples/queries/has_child_complex.rb +12 -0
- data/examples/queries/ids.rb +5 -0
- data/examples/queries/match_all.rb +5 -0
- data/examples/queries/mlt.rb +7 -0
- data/examples/queries/mlt_field.rb +7 -0
- data/examples/queries/nested.rb +12 -0
- data/examples/queries/prefix.rb +5 -0
- data/examples/queries/prefix_short.rb +5 -0
- data/examples/queries/query_string.rb +6 -0
- data/examples/queries/query_string_with_multiple_fields.rb +7 -0
- data/examples/queries/query_string_without_default_field.rb +5 -0
- data/examples/queries/range.rb +5 -0
- data/examples/queries/span_first.rb +7 -0
- data/examples/queries/span_near.rb +11 -0
- data/examples/queries/span_not.rb +8 -0
- data/examples/queries/span_or.rb +11 -0
- data/examples/queries/span_term.rb +5 -0
- data/examples/queries/term.rb +5 -0
- data/examples/queries/term_with_parameters.rb +5 -0
- data/examples/queries/terms.rb +5 -0
- data/examples/queries/text.rb +5 -0
- data/examples/queries/top_children.rb +7 -0
- data/examples/queries/wildcard.rb +5 -0
- data/examples/queries/wildcard_short.rb +5 -0
- data/lib/eson/modules/query_plugin.rb +44 -0
- data/lib/eson/search/and.rb +27 -0
- data/lib/eson/search/base_query.rb +39 -0
- data/lib/eson/search/bool.rb +51 -0
- data/lib/eson/search/boosting.rb +45 -0
- data/lib/eson/search/constant_score.rb +21 -0
- data/lib/eson/search/custom_score.rb +19 -0
- data/lib/eson/search/date_histogram.rb +13 -0
- data/lib/eson/search/dis_max.rb +22 -0
- data/lib/eson/search/exists.rb +18 -0
- data/lib/eson/search/facet.rb +39 -0
- data/lib/eson/search/facets.rb +37 -0
- data/lib/eson/search/field.rb +16 -0
- data/lib/eson/search/field_based.rb +24 -0
- data/lib/eson/search/filter.rb +28 -0
- data/lib/eson/search/filter_facet.rb +13 -0
- data/lib/eson/search/filters.rb +69 -0
- data/lib/eson/search/fquery.rb +22 -0
- data/lib/eson/search/fuzzy.rb +29 -0
- data/lib/eson/search/fuzzy_like_this.rb +16 -0
- data/lib/eson/search/fuzzy_like_this_field.rb +20 -0
- data/lib/eson/search/geo_bounding_box.rb +35 -0
- data/lib/eson/search/geo_distance.rb +34 -0
- data/lib/eson/search/geo_distance_range.rb +29 -0
- data/lib/eson/search/geo_polygon.rb +32 -0
- data/lib/eson/search/has_child.rb +29 -0
- data/lib/eson/search/histogram.rb +20 -0
- data/lib/eson/search/ids.rb +27 -0
- data/lib/eson/search/match_all.rb +21 -0
- data/lib/eson/search/missing.rb +21 -0
- data/lib/eson/search/more_like_this.rb +16 -0
- data/lib/eson/search/more_like_this_field.rb +20 -0
- data/lib/eson/search/nested.rb +24 -0
- data/lib/eson/search/node.rb +28 -0
- data/lib/eson/search/not.rb +23 -0
- data/lib/eson/search/numeric_range.rb +20 -0
- data/lib/eson/search/or.rb +23 -0
- data/lib/eson/search/parametrized.rb +15 -0
- data/lib/eson/search/prefix.rb +22 -0
- data/lib/eson/search/queries.rb +65 -0
- data/lib/eson/search/query.rb +28 -0
- data/lib/eson/search/query_facet.rb +16 -0
- data/lib/eson/search/query_field.rb +33 -0
- data/lib/eson/search/query_group.rb +34 -0
- data/lib/eson/search/query_string.rb +20 -0
- data/lib/eson/search/range.rb +26 -0
- data/lib/eson/search/span_first.rb +27 -0
- data/lib/eson/search/span_near.rb +29 -0
- data/lib/eson/search/span_not.rb +29 -0
- data/lib/eson/search/span_or.rb +29 -0
- data/lib/eson/search/span_term.rb +18 -0
- data/lib/eson/search/statistical.rb +20 -0
- data/lib/eson/search/sub_query.rb +7 -0
- data/lib/eson/search/term.rb +22 -0
- data/lib/eson/search/terms.rb +22 -0
- data/lib/eson/search/terms_stats.rb +20 -0
- data/lib/eson/search/text.rb +23 -0
- data/lib/eson/search/top_children.rb +28 -0
- data/lib/eson/search/type.rb +20 -0
- data/lib/eson/search/wildcard.rb +18 -0
- data/lib/eson-dsl.rb +64 -0
- data/log4j.properties +18 -0
- data/test/search/facet_test.rb +92 -0
- data/test/search/facets/date_histogram.documents +1 -0
- data/test/search/facets/date_histogram.mapping +1 -0
- data/test/search/facets/date_histogram.rb +13 -0
- data/test/search/facets/geo_distance.documents +1 -0
- data/test/search/facets/geo_distance.mapping +8 -0
- data/test/search/facets/geo_distance.rb +1 -0
- data/test/search/facets/histogram.documents +1 -0
- data/test/search/facets/histogram.rb +13 -0
- data/test/search/facets/query.documents +1 -0
- data/test/search/facets/query.rb +14 -0
- data/test/search/facets/range.documents +1 -0
- data/test/search/facets/range.rb +17 -0
- data/test/search/facets/scoped.documents +1 -0
- data/test/search/facets/scoped.json +1 -0
- data/test/search/facets/scoped.mapping +9 -0
- data/test/search/facets/statistical.documents +1 -0
- data/test/search/facets/statistical.rb +12 -0
- data/test/search/facets/tag_facet.documents +1 -0
- data/test/search/facets/tag_facet.rb +14 -0
- data/test/search/facets/terms.rb +14 -0
- data/test/search/facets/terms_stats.documents +1 -0
- data/test/search/facets/terms_stats.json +1 -0
- data/test/search/facets/terms_stats.rb +13 -0
- data/test/search/filters/and.rb +15 -0
- data/test/search/filters/bool.json +1 -0
- data/test/search/filters/bool.rb +27 -0
- data/test/search/filters/exists.json +1 -0
- data/test/search/filters/exists.rb +1 -0
- data/test/search/filters/filter_query.rb +14 -0
- data/test/search/filters/geo_bounding_box_hash.documents +1 -0
- data/test/search/filters/geo_bounding_box_hash.json +1 -0
- data/test/search/filters/geo_bounding_box_hash.mapping +8 -0
- data/test/search/filters/geo_distance_hash.documents +1 -0
- data/test/search/filters/geo_distance_hash.json +1 -0
- data/test/search/filters/geo_distance_hash.mapping +8 -0
- data/test/search/filters/geo_distance_range_hash.documents +1 -0
- data/test/search/filters/geo_distance_range_hash.json +1 -0
- data/test/search/filters/geo_distance_range_hash.mapping +8 -0
- data/test/search/filters/geo_polygon_hash.documents +1 -0
- data/test/search/filters/geo_polygon_hash.json +1 -0
- data/test/search/filters/geo_polygon_hash.mapping +8 -0
- data/test/search/filters/has_child.blog.mapping +1 -0
- data/test/search/filters/has_child.blog_tag.mapping +1 -0
- data/test/search/filters/has_child.rb +15 -0
- data/test/search/filters/ids.rb +14 -0
- data/test/search/filters/missing.rb +1 -0
- data/test/search/filters/not.rb +16 -0
- data/test/search/filters/numeric_range.documents +1 -0
- data/test/search/filters/numeric_range.rb +1 -0
- data/test/search/filters/or.rb +15 -0
- data/test/search/filters/range.rb +16 -0
- data/test/search/filters/type.json +1 -0
- data/test/search/filters/type.rb +1 -0
- data/test/search/filters_test.rb +166 -0
- data/test/search/queries/bool.json +1 -0
- data/test/search/queries/bool.rb +21 -0
- data/test/search/queries/boosting.json +1 -0
- data/test/search/queries/boosting.rb +17 -0
- data/test/search/queries/constant_score.rb +10 -0
- data/test/search/queries/constant_score_filter.rb +10 -0
- data/test/search/queries/custom_score.documents +1 -0
- data/test/search/queries/custom_score.rb +14 -0
- data/test/search/queries/dis_max.rb +15 -0
- data/test/search/queries/field.rb +7 -0
- data/test/search/queries/filters_and_facets.documents +1 -0
- data/test/search/queries/filters_and_facets.json +1 -0
- data/test/search/queries/flt.rb +9 -0
- data/test/search/queries/flt_field.rb +10 -0
- data/test/search/queries/fuzzy_complex.rb +5 -0
- data/test/search/queries/fuzzy_simple.rb +5 -0
- data/test/search/queries/has_child.blog.mapping +1 -0
- data/test/search/queries/has_child.blog_tag.mapping +1 -0
- data/test/search/queries/has_child.rb +10 -0
- data/test/search/queries/has_child_complex.blog.mapping +1 -0
- data/test/search/queries/has_child_complex.blog_tag.mapping +1 -0
- data/test/search/queries/has_child_complex.rb +17 -0
- data/test/search/queries/ids.rb +1 -0
- data/test/search/queries/match_all.rb +1 -0
- data/test/search/queries/mlt.json +1 -0
- data/test/search/queries/mlt.rb +9 -0
- data/test/search/queries/mlt_field.rb +10 -0
- data/test/search/queries/nested.json +1 -0
- data/test/search/queries/nested.mapping +9 -0
- data/test/search/queries/phrase_prefix.rb +8 -0
- data/test/search/queries/prefix.rb +1 -0
- data/test/search/queries/prefix_short.rb +1 -0
- data/test/search/queries/query_string.rb +8 -0
- data/test/search/queries/query_string_with_multiple_fields.rb +9 -0
- data/test/search/queries/query_string_without_default_field.rb +7 -0
- data/test/search/queries/range.rb +11 -0
- data/test/search/queries/span_near.json +1 -0
- data/test/search/queries/span_not.json +1 -0
- data/test/search/queries/span_or.json +1 -0
- data/test/search/queries/span_term.json +1 -0
- data/test/search/queries/term.json +1 -0
- data/test/search/queries/term.rb +1 -0
- data/test/search/queries/terms.rb +1 -0
- data/test/search/queries/text.json +1 -0
- data/test/search/queries/text.rb +8 -0
- data/test/search/queries/top_children.blog.mapping +1 -0
- data/test/search/queries/top_children.blog_tag.mapping +1 -0
- data/test/search/queries/top_children.rb +11 -0
- data/test/search/queries/wildcard.rb +1 -0
- data/test/search/queries/wildcard_short.rb +1 -0
- data/test/search/query_test.rb +311 -0
- data/test/test_config.rb +157 -0
- metadata +413 -0
@@ -0,0 +1,92 @@
|
|
1
|
+
require './test/test_config'
|
2
|
+
context "Facets" do
|
3
|
+
setup do
|
4
|
+
create_index :index => "default"
|
5
|
+
end
|
6
|
+
|
7
|
+
context '#match_all with #terms facet' do
|
8
|
+
set :query_name, "test/search/facets/terms"
|
9
|
+
|
10
|
+
setup do
|
11
|
+
example("facets/terms")
|
12
|
+
end
|
13
|
+
|
14
|
+
end
|
15
|
+
|
16
|
+
context '#match_all with #range facet' do
|
17
|
+
set :query_name, "test/search/facets/range"
|
18
|
+
|
19
|
+
setup do
|
20
|
+
example("facets/range")
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
context '#match_all with #histogram facet' do
|
25
|
+
set :query_name, "test/search/facets/histogram"
|
26
|
+
|
27
|
+
setup do
|
28
|
+
example("facets/histogram")
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
context '#match_all with #date_histogram facet' do
|
33
|
+
set :query_name, "test/search/facets/date_histogram"
|
34
|
+
set :type, "date_hist"
|
35
|
+
set :index, "date_hist"
|
36
|
+
|
37
|
+
setup do
|
38
|
+
example("facets/date_histogram")
|
39
|
+
end
|
40
|
+
end
|
41
|
+
|
42
|
+
context '#match_all with #query facet' do
|
43
|
+
set :query_name, "test/search/facets/query"
|
44
|
+
|
45
|
+
setup do
|
46
|
+
example("facets/query")
|
47
|
+
end
|
48
|
+
end
|
49
|
+
|
50
|
+
context '#match_all with #filter facet' do
|
51
|
+
set :query_name, "test/search/facets/tag_facet"
|
52
|
+
|
53
|
+
setup do
|
54
|
+
example("facets/filter")
|
55
|
+
end
|
56
|
+
end
|
57
|
+
|
58
|
+
context '#match_all with #statistical facet' do
|
59
|
+
set :index, "statistical"
|
60
|
+
set :query_name, "test/search/facets/statistical"
|
61
|
+
|
62
|
+
setup do
|
63
|
+
example("facets/statistical")
|
64
|
+
end
|
65
|
+
end
|
66
|
+
|
67
|
+
context '#nested scoped facet' do
|
68
|
+
set :query_name, "test/search/facets/scoped"
|
69
|
+
|
70
|
+
setup do
|
71
|
+
example("facets/scoped")
|
72
|
+
end
|
73
|
+
end
|
74
|
+
|
75
|
+
context '#match_all with #terms_stats facet' do
|
76
|
+
set :query_name, "test/search/facets/terms_stats"
|
77
|
+
|
78
|
+
setup do
|
79
|
+
example("facets/term_stats")
|
80
|
+
end
|
81
|
+
|
82
|
+
end
|
83
|
+
|
84
|
+
context '#match_all with #geo_distance facet' do
|
85
|
+
set :query_name, "test/search/facets/geo_distance"
|
86
|
+
|
87
|
+
setup do
|
88
|
+
example("facets/geo_distance")
|
89
|
+
end
|
90
|
+
|
91
|
+
end
|
92
|
+
end
|
@@ -0,0 +1 @@
|
|
1
|
+
{"time": "2009-11-15T14:12:12"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"date_hist": {"time" : {"type" : "date" }}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"pin":{"location":{"lat": 40.72, "lon": -74.01 }}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{:query=>{:match_all=>{}}, :facets=>{:geo1=>{:geo_distance=>{:location=>{:lat=>40, :lon=>-70}, :ranges=>[{:to=>10}, {:from=>10, :to=>20}, {:from=>20, :to=>100}, {:from=>100}]}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"age" : 100}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"tag": "wow"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"age" : 100}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"age":100}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"nested":{"query":{"filtered":{"query":{"match_all":{}},"filter":{"range":{"age":{"from":10,"to":20}}}}},"path":"obj1","score_mode":"avg","_scope":"my_scope"}},"facets":{"hist1":{"histogram":{"field":"age","interval":2,"scope":"my_scope"}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"field":"test", "field1":1.20}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"tag": "wow"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"tag":"test", "price":1.20}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"match_all":{}},"facets":{"tag_price_stats":{"terms_stats":{"key_field":"tag","value_field":"price"}}}}
|
@@ -0,0 +1,15 @@
|
|
1
|
+
{
|
2
|
+
:query => {
|
3
|
+
:filtered => {
|
4
|
+
:query => {
|
5
|
+
:term => {:tag => "something"}
|
6
|
+
},
|
7
|
+
:filter => {
|
8
|
+
:and => [
|
9
|
+
{ :range => { :post_date => {:from => "2010-03-01", :to => "2010-04-01"} } },
|
10
|
+
{ :prefix => { "name.second" => "ba"} }
|
11
|
+
]
|
12
|
+
}
|
13
|
+
}
|
14
|
+
}
|
15
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"filtered":{"query":{"match_all":{}},"filter":{"bool":{"must":{"term":{"user":"kimchy"}},"must_not":{"range":{"age":{"from":10,"to":20}}},"should":[{"term":{"tag":"wow"}},{"term":{"tag":"elasticsearch"}}]}}}}}
|
@@ -0,0 +1,27 @@
|
|
1
|
+
{
|
2
|
+
:query =>
|
3
|
+
{
|
4
|
+
:filtered => {
|
5
|
+
:query => {:match_all => {}},
|
6
|
+
:filter => {
|
7
|
+
:bool => {
|
8
|
+
:must => {
|
9
|
+
:term => { "user" => "kimchy"}
|
10
|
+
},
|
11
|
+
:must_not => {
|
12
|
+
:range => {
|
13
|
+
:age => {
|
14
|
+
:from => 10,
|
15
|
+
:to => 20
|
16
|
+
}
|
17
|
+
}
|
18
|
+
},
|
19
|
+
:should => [
|
20
|
+
{ :term => { "tag" => "wow" } },
|
21
|
+
{ :term => { "tag" => "elasticsearch" } }
|
22
|
+
]
|
23
|
+
}
|
24
|
+
}
|
25
|
+
}
|
26
|
+
}
|
27
|
+
}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"constant_score":{"filter":{"exists":{"field":"user"}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{:query => {:constant_score => {:filter => {:exists => {:field => "user"}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"pin":{"location":{"lat": 40.72, "lon": -74.01 }}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"filtered":{"query":{"match_all":{}},"filter":{"geo_bounding_box":{"location":{"top_left":{"lat":40.73,"lon":-74.1},"bottom_right":{"lat":40.717,"lon":-73.99}}}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"pin":{"location":{"lat": 40.72, "lon": -74.01 }}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"filtered":{"query":{"match_all":{}},"filter":{"geo_distance":{"distance":"200km","location":{"lat":40,"lon":-70}}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"pin":{"location":{"lat": 40.72, "lon": -74.01 }}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"filtered":{"query":{"match_all":{}},"filter":{"geo_distance_range":{"from":"200km","to":"400km","location":{"lat":40,"lon":-70}}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"pin":{"location":{"lat": 40.72, "lon": -74.01 }}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"filtered":{"query":{"match_all":{}},"filter":{"geo_polygon":{"location":{"points":[{"lat":40,"lon":-70},{"lat":30,"lon":-80},{"lat":20,"lon":-90}]}}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"blog": {"foo": "string"} }
|
@@ -0,0 +1 @@
|
|
1
|
+
{"blog_tag": {"_parent" : { "type" : "blog" } } }
|
@@ -0,0 +1 @@
|
|
1
|
+
{:query => {:constant_score => {:filter => {:missing => {:field => "user"}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"age": 100}
|
@@ -0,0 +1 @@
|
|
1
|
+
{:query => {:constant_score => {:filter => {:numeric_range => {:age => {:from => 10, :to => 20}}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"query":{"filtered":{"query":{"match_all":{}},"filter":{"type":{"value":"my_type"}}}}}
|
@@ -0,0 +1 @@
|
|
1
|
+
{:query => {:filtered => {:query => {:match_all => {}}, :filter => {:type => {:value => :my_type}}}}}
|