sshota
(shota)
November 13, 2019, 1:48am
1
お世話になります。
基礎的な質問で大変恐縮なのですが、
Watcher の advanced watch に設定するconditionで、scriptを記述したいのですが、
下記URLのような書き方(scriptのプログラムを「"""」で囲む)をすると、エラーが発生します。
こんにちわ。
以前Watcherの質問でありました内容に少し付け足せば可能かと思います。
transformでこのようにしております。
ctx.payload.hits.hits[i]['打率'] = の部分がフィールドを追加しているところになります。
(蛇足ですが、ゼロ除算、ぬるぽなどは別途考慮ください)
"actions": {
"index_payload": {
"transform": {
"script": """
for (int i = 0; i < ctx.payload.hits.hits.length; ++i) {
ctx.payload.hits.hits[i] = ctx.payload.hits.hits[i]._source;
ctx.payload.hits.hits[i]['打率'] = (double)ctx.payload.hits.hits[i]['安打'] / (double)ctx.payload.hits.hits[i]['打数']…
エラーメッセージ
Watch JSON(抜粋)
"condition": {
"script": {
"source": """
ctx.payload.hits.hits[0] = ctx.payload.hits.hits[0]._source;
int i = ctx.payload.hits.hits[0]['value0'];
return i > 0
"""
,
"lang": "painless"
}
},
補足
scriptのプログラムを 「"""」で囲って複数行 → 「"」で囲って1行にまとめる と変更すると、問題なく動作します。
該当URLの情報は、actionに対しての記述だったので、conditionの記述方と比較しようとaction部分に丸写ししてみましたが、同様のエラーメッセージが表示されました。
視認性のためにも、複数行で記述したいのですが、作法等に間違いがあるのでしょうか。
分かりにくい部分もあるかと思いますが、お知恵を頂けますと幸いです。
tsgkdt
(tsgkdt)
November 13, 2019, 2:48am
2
KibanaのManagement画面のWatcherにて設定されているかと思います。
その内容を一度、Dev Toolsに張り付けて実行してみるとどうですか?
(こちらではエラーなく登録できました)
advancedの画面で作成しているjsonを、watcherのエンドポイントを指定して実行します。
PUT _watcher/watch/<WatcherのID文字列>
{
"trigger": { ... },
"input": { ... },
"conditions": {
以下略
もし、そちらでも同様に登録が可能であったならば、”””を使った複数行の記述方法がAdvancedのエディタの画面で対応できていないように考えられます。
Dev Toolsで登録したWatcherの条件をAdvancedのエディタで開きなおすと、""" ではなく " で1行に変更されていました。
以上のことから、一度Dev Tools側から登録いただくことをお試しいただきたいです。
sshota
(shota)
November 13, 2019, 4:46am
3
早速のご回答ありがとうございます。
ご推察の通り、KibanaのManagement画面のWatcherにて設定をしておりました。
Dev Toolsで実行したところ、複数行の記述で、確かにエラーなく登録ができました。
ありがとうございます。
ただ、細かいですが一点気になるのは、改行文字(\n)が入ってしまいました。
確認した感じでは動作的に問題はなさそうなのですが、見た目少し気持ち悪いです。
これは、そういう仕様だと割り切るしかないのでしょうか。
system
(system)
Closed
December 11, 2019, 4:46am
4
This topic was automatically closed 28 days after the last reply. New replies are no longer allowed.