mirror of
https://github.com/honeymoose/OpenSearch.git
synced 2025-04-03 05:48:31 +00:00
This commit adds back "id" as the key within a script to specify a stored script (which with file scripts now gone is no longer ambiguous). It also adds "source" as a replacement for "code". This is in an attempt to normalize how scripts are specified across both put stored scripts and script usages, including search template requests. This also deprecates the old inline/stored keys.
58 lines
1.9 KiB
Plaintext
58 lines
1.9 KiB
Plaintext
[[modules-scripting-engine]]
|
|
=== Advanced scripts using script engines
|
|
|
|
A `ScriptEngine` is a backend for implementing a scripting language. It may also
|
|
be used to write scripts that need to use advanced internals of scripting. For example,
|
|
a script that wants to use term frequencies while scoring.
|
|
|
|
The plugin {plugins}/plugin-authors.html[documentation] has more information on
|
|
how to write a plugin so that Elasticsearch will properly load it. To register
|
|
the `ScriptEngine`, your plugin should implement the `ScriptPlugin` interface
|
|
and override the `getScriptEngine(Settings settings)` method.
|
|
|
|
The following is an example of a custom `ScriptEngine` which uses the language
|
|
name `expert_scripts`. It implements a single script called `pure_df` which
|
|
may be used as a search script to override each document's score as
|
|
the document frequency of a provided term.
|
|
|
|
["source","java",subs="attributes,callouts,macros"]
|
|
--------------------------------------------------
|
|
include-tagged::{docdir}/../../plugins/examples/script-expert-scoring/src/main/java/org/elasticsearch/example/expertscript/ExpertScriptPlugin.java[expert_engine]
|
|
--------------------------------------------------
|
|
|
|
You can execute the script by specifying its `lang` as `expert_scripts`, and the name
|
|
of the script as the the script source:
|
|
|
|
|
|
[source,js]
|
|
--------------------------------------------------
|
|
POST /_search
|
|
{
|
|
"query": {
|
|
"function_score": {
|
|
"query": {
|
|
"match": {
|
|
"body": "foo"
|
|
}
|
|
},
|
|
"functions": [
|
|
{
|
|
"script_score": {
|
|
"script": {
|
|
"source": "pure_df",
|
|
"lang" : "expert_scripts",
|
|
"params": {
|
|
"field": "body",
|
|
"term": "foo"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
]
|
|
}
|
|
}
|
|
}
|
|
--------------------------------------------------
|
|
// CONSOLE
|
|
// TEST[skip:we don't have an expert script plugin installed to test this]
|