Skip to content

Commit f2c1aa0

Browse files
committed
Function Score Query
Added function score query and its score functions.
1 parent 1d9c2f2 commit f2c1aa0

4 files changed

+466
-0
lines changed

README.md

+1
Original file line numberDiff line numberDiff line change
@@ -200,6 +200,7 @@ Here's the current API status.
200200
* `filtered` (ok)
201201
* `flt` (missing)
202202
* `flt_field` (missing)
203+
* `function_score` (ok)
203204
* `fuzzy` (missing)
204205
* `has_child` (ok)
205206
* `has_parent` (ok)

search_queries_fsq.go

+117
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,117 @@
1+
// Copyright 2012 Oliver Eilhard. All rights reserved.
2+
// Use of this source code is governed by a MIT-license.
3+
// See http://olivere.mit-license.org/license.txt for details.
4+
5+
package elastic
6+
7+
// The function_score allows you to modify the score of documents that
8+
// are retrieved by a query. This can be useful if, for example,
9+
// a score function is computationally expensive and it is sufficient
10+
// to compute the score on a filtered set of documents.
11+
// For more details, see
12+
// http://www.elasticsearch.org/guide/en/elasticsearch/reference/current/query-dsl-function-score-query.html
13+
type FunctionScoreQuery struct {
14+
query Query
15+
filter Filter
16+
boost *float32
17+
maxBoost *float32
18+
scoreMode string
19+
boostMode string
20+
filters []Filter
21+
scoreFuncs []ScoreFunction
22+
}
23+
24+
// NewFunctionScoreQuery creates a new function score query.
25+
func NewFunctionScoreQuery() FunctionScoreQuery {
26+
return FunctionScoreQuery{
27+
filters: make([]Filter, 0),
28+
scoreFuncs: make([]ScoreFunction, 0),
29+
}
30+
}
31+
32+
func (q FunctionScoreQuery) Query(query Query) FunctionScoreQuery {
33+
q.query = query
34+
q.filter = nil
35+
return q
36+
}
37+
38+
func (q FunctionScoreQuery) Filter(filter Filter) FunctionScoreQuery {
39+
q.query = nil
40+
q.filter = filter
41+
return q
42+
}
43+
44+
func (q FunctionScoreQuery) Add(filter Filter, scoreFunc ScoreFunction) FunctionScoreQuery {
45+
q.filters = append(q.filters, filter)
46+
q.scoreFuncs = append(q.scoreFuncs, scoreFunc)
47+
return q
48+
}
49+
50+
func (q FunctionScoreQuery) AddScoreFunc(scoreFunc ScoreFunction) FunctionScoreQuery {
51+
q.filters = append(q.filters, nil)
52+
q.scoreFuncs = append(q.scoreFuncs, scoreFunc)
53+
return q
54+
}
55+
56+
func (q FunctionScoreQuery) ScoreMode(scoreMode string) FunctionScoreQuery {
57+
q.scoreMode = scoreMode
58+
return q
59+
}
60+
61+
func (q FunctionScoreQuery) BoostMode(boostMode string) FunctionScoreQuery {
62+
q.boostMode = boostMode
63+
return q
64+
}
65+
66+
func (q FunctionScoreQuery) MaxBoost(maxBoost float32) FunctionScoreQuery {
67+
q.maxBoost = &maxBoost
68+
return q
69+
}
70+
71+
func (q FunctionScoreQuery) Boost(boost float32) FunctionScoreQuery {
72+
q.boost = &boost
73+
return q
74+
}
75+
76+
// Source returns JSON for the function score query.
77+
func (q FunctionScoreQuery) Source() interface{} {
78+
source := make(map[string]interface{})
79+
query := make(map[string]interface{})
80+
source["function_score"] = query
81+
82+
if q.query != nil {
83+
query["query"] = q.query.Source()
84+
} else if q.filter != nil {
85+
query["filter"] = q.filter.Source()
86+
}
87+
88+
if len(q.filters) == 1 && q.filters[0] == nil {
89+
query[q.scoreFuncs[0].Name()] = q.scoreFuncs[0].Source()
90+
} else {
91+
funcs := make([]interface{}, len(q.filters))
92+
for i, filter := range q.filters {
93+
hsh := make(map[string]interface{})
94+
if filter != nil {
95+
hsh["filter"] = filter.Source()
96+
}
97+
hsh[q.scoreFuncs[i].Name()] = q.scoreFuncs[i].Source()
98+
funcs[i] = hsh
99+
}
100+
query["functions"] = funcs
101+
}
102+
103+
if q.scoreMode != "" {
104+
query["score_mode"] = q.scoreMode
105+
}
106+
if q.boostMode != "" {
107+
query["boost_mode"] = q.boostMode
108+
}
109+
if q.maxBoost != nil {
110+
query["max_boost"] = *q.maxBoost
111+
}
112+
if q.boost != nil {
113+
query["boost"] = *q.boost
114+
}
115+
116+
return source
117+
}

0 commit comments

Comments
 (0)