You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

search_queries_script_score.go 2.6KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. // Copyright 2012-present 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. package elastic
  5. import "errors"
  6. // ScriptScoreQuery uses a script to provide a custom score for returned documents.
  7. //
  8. // A ScriptScoreQuery query is useful if, for example, a scoring function is
  9. // expensive and you only need to calculate the score of a filtered set of documents.
  10. //
  11. // For more details, see
  12. // https://www.elastic.co/guide/en/elasticsearch/reference/7.4/query-dsl-script-score-query.html
  13. type ScriptScoreQuery struct {
  14. query Query
  15. script *Script
  16. minScore *float64
  17. boost *float64
  18. queryName string
  19. }
  20. // NewScriptScoreQuery creates and initializes a new script_score query.
  21. func NewScriptScoreQuery(query Query, script *Script) *ScriptScoreQuery {
  22. return &ScriptScoreQuery{
  23. query: query,
  24. script: script,
  25. }
  26. }
  27. // Query to be used in the ScriptScoreQuery.
  28. func (q *ScriptScoreQuery) Query(query Query) *ScriptScoreQuery {
  29. q.query = query
  30. return q
  31. }
  32. // Script to calculate the score.
  33. func (q *ScriptScoreQuery) Script(script *Script) *ScriptScoreQuery {
  34. q.script = script
  35. return q
  36. }
  37. // MinScore sets the minimum score.
  38. func (q *ScriptScoreQuery) MinScore(minScore float64) *ScriptScoreQuery {
  39. q.minScore = &minScore
  40. return q
  41. }
  42. // Boost sets the boost for this query.
  43. func (q *ScriptScoreQuery) Boost(boost float64) *ScriptScoreQuery {
  44. q.boost = &boost
  45. return q
  46. }
  47. // QueryName sets the query name for the filter.
  48. func (q *ScriptScoreQuery) QueryName(queryName string) *ScriptScoreQuery {
  49. q.queryName = queryName
  50. return q
  51. }
  52. // Source returns JSON for the function score query.
  53. func (q *ScriptScoreQuery) Source() (interface{}, error) {
  54. // {
  55. // "script_score" : {
  56. // "query" : {
  57. // "match" : { "message": "elasticsearch" }
  58. // },
  59. // "script" : {
  60. // "source" : "doc['likes'].value / 10"
  61. // }
  62. // }
  63. // }
  64. source := make(map[string]interface{})
  65. query := make(map[string]interface{})
  66. source["script_score"] = query
  67. if q.query == nil {
  68. return nil, errors.New("ScriptScoreQuery: Query is missing")
  69. }
  70. if q.script == nil {
  71. return nil, errors.New("ScriptScoreQuery: Script is missing")
  72. }
  73. if src, err := q.query.Source(); err != nil {
  74. return nil, err
  75. } else {
  76. query["query"] = src
  77. }
  78. if src, err := q.script.Source(); err != nil {
  79. return nil, err
  80. } else {
  81. query["script"] = src
  82. }
  83. if v := q.minScore; v != nil {
  84. query["min_score"] = *v
  85. }
  86. if v := q.boost; v != nil {
  87. query["boost"] = *v
  88. }
  89. if q.queryName != "" {
  90. query["_name"] = q.queryName
  91. }
  92. return source, nil
  93. }