| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393 | [role="xpack"][[watcher-api-execute-watch]]=== Execute watch API++++<titleabbrev>Execute watch</titleabbrev>++++Forces the execution of a stored watch.[[watcher-api-execute-watch-request]]==== {api-request-title}`POST _watcher/watch/<watch_id>/_execute` +`POST _watcher/watch/_execute`[[watcher-api-execute-watch-prereqs]]==== {api-prereq-title}* You must have `manage_watcher` cluster privileges to use this API. For moreinformation, see <<security-privileges>>.[[watcher-api-execute-watch-desc]]==== {api-description-title}This API can be used to force execution of the watch outside of its triggeringlogic or to simulate the watch execution for debugging purposes.For testing and debugging purposes, you also have fine-grained control on howthe watch runs. You can execute the watch without executing all of its actionsor alternatively by simulating them. You can also force execution by ignoringthe watch condition and control whether a watch record would be written to thewatch history after execution.[[watcher-api-execute-inline-watch]]===== Inline watch executionYou can use the Execute API to execute watches that are not yet registered byspecifying the watch definition inline. This serves as great tool for testingand debugging your watches prior to adding them to {watcher}.[[watcher-api-execute-watch-path-params]]==== {api-path-parms-title}`<watch_id>`::  (Optional, string) Identifier for the watch.[[watcher-api-execute-watch-query-params]]==== {api-query-parms-title}`debug`::  (Optional, Boolean) Defines whether the watch runs in debug mode. The default  value is `false`.[[watcher-api-execute-watch-request-body]]==== {api-request-body-title}This API supports the following fields:[cols=",^,^,", options="header"]|======| Name                | Required | Default  | Description| `trigger_data`      | no       |          | This structure is parsed as the data of the trigger event                                              that will be used during the watch execution| `ignore_condition`  | no       | false    | When set to `true`, the watch execution uses the                                              <<condition-always,always condition>>.                                              This can also be specified as an HTTP parameter.| `alternative_input` | no       | null     | When present, the watch uses this object as a payload                                              instead of executing its own input.| `action_modes`      | no       | null     | Determines how to handle the watch actions as part of the                                              watch execution. See <<watcher-api-execute-watch-action-mode>>                                              for more information.| `record_execution`  | no       | false    | When set to `true`, the watch record representing the watch                                              execution result is persisted to the `.watcher-history`                                              index for the current time. In addition, the status of the                                              watch is updated, possibly throttling subsequent executions.                                              This can also be specified as an HTTP parameter.| `watch`             | no       | null     | When present, this <<watch-definition,watch>> is used                                              instead of the one specified in the request. This watch is                                              not persisted to the index and record_execution cannot be set.|======[[watcher-api-execute-watch-action-mode]]===== Action execution modesAction modes define how actions are handled during the watch execution. Thereare five possible modes an action can be associated with:[options="header"]|======| Name              | Description| `simulate`        | The action execution is simulated. Each action type                      defines its own simulation operation mode. For example, the                      <<actions-email,`email` action>> creates                      the email that would have been sent but does not actually                      send it. In this mode, the action might be throttled if the                      current state of the watch indicates it should be.| `force_simulate`  | Similar to the `simulate` mode, except the action is                      not throttled even if the current state of the watch                      indicates it should be.| `execute`         | Executes the action as it would have been executed if the                      watch had been triggered by its own trigger. The                      execution might be throttled if the current state of the                      watch indicates it should be.| `force_execute`   | Similar to the `execute` mode, except the action is not                      throttled even if the current state of the watch indicates                      it should be.| `skip`            | The action is skipped and is not executed or simulated.                      Effectively forces the action to be throttled.|======[[watcher-api-execute-watch-security]]===== Security integrationWhen {es} {security-features} are enabled on your cluster, watchesare executed with the privileges of the user that stored the watches. If youruser is allowed to read index `a`, but not index `b`, then the exact same set ofrules will apply during execution of a watch.When using the execute watch API, the authorization data of the user thatcalled the API will be used as a base, instead of the information who storedthe watch.//[[watcher-api-execute-watch-response-body]]//==== {api-response-body-title}//[[watcher-api-execute-watch-response-codes]]//==== {api-response-codes-title}[[watcher-api-execute-watch-example]]==== {api-examples-title}The following example executes the `my_watch` watch:[source,console]--------------------------------------------------POST _watcher/watch/my_watch/_execute--------------------------------------------------// TEST[setup:my_active_watch]The following example shows a comprehensive example of executing the `my-watch` watch:[source,console]--------------------------------------------------POST _watcher/watch/my_watch/_execute{  "trigger_data" : { <1>     "triggered_time" : "now",     "scheduled_time" : "now"  },  "alternative_input" : { <2>    "foo" : "bar"  },  "ignore_condition" : true, <3>  "action_modes" : {    "my-action" : "force_simulate" <4>  },  "record_execution" : true <5>}--------------------------------------------------// TEST[setup:my_active_watch]<1> The triggered and schedule times are provided.<2> The input as defined by the watch is ignored and instead the provided input    is used as the execution payload.<3> The condition as defined by the watch is ignored and is assumed to    evaluate to `true`.<4> Forces the simulation of `my-action`. Forcing the simulation means that    throttling is ignored and the watch is simulated by {watcher} instead of    being executed normally.<5> The execution of the watch creates a watch record in the watch history,    and the throttling state of the watch is potentially updated accordingly.This is an example of the output:[source,console-result]--------------------------------------------------{  "_id": "my_watch_0-2015-06-02T23:17:55.124Z", <1>  "watch_record": { <2>    "@timestamp": "2015-06-02T23:17:55.124Z",    "watch_id": "my_watch",    "node": "my_node",    "messages": [],    "trigger_event": {      "type": "manual",      "triggered_time": "2015-06-02T23:17:55.124Z",      "manual": {        "schedule": {          "scheduled_time": "2015-06-02T23:17:55.124Z"        }      }    },    "state": "executed",    "status": {      "version": 1,      "execution_state": "executed",      "state": {        "active": true,        "timestamp": "2015-06-02T23:17:55.111Z"      },      "last_checked": "2015-06-02T23:17:55.124Z",      "last_met_condition": "2015-06-02T23:17:55.124Z",      "actions": {        "test_index": {          "ack": {            "timestamp": "2015-06-02T23:17:55.124Z",            "state": "ackable"          },          "last_execution": {            "timestamp": "2015-06-02T23:17:55.124Z",            "successful": true          },          "last_successful_execution": {            "timestamp": "2015-06-02T23:17:55.124Z",            "successful": true          }        }      }    },    "input": {      "simple": {        "payload": {          "send": "yes"        }      }    },    "condition": {      "always": {}    },    "result": { <3>      "execution_time": "2015-06-02T23:17:55.124Z",      "execution_duration": 12608,      "input": {        "type": "simple",        "payload": {          "foo": "bar"        },        "status": "success"      },      "condition": {        "type": "always",        "met": true,        "status": "success"      },      "actions": [        {          "id": "test_index",          "index": {            "response": {              "index": "test",              "version": 1,              "created": true,              "result": "created",              "id": "AVSHKzPa9zx62AzUzFXY"            }          },          "status": "success",          "type": "index"        }      ]    },    "user": "test_admin" <4>  }}--------------------------------------------------// TESTRESPONSE[s/my_watch_0-2015-06-02T23:17:55.124Z/$body._id/]// TESTRESPONSE[s/"triggered_time": "2015-06-02T23:17:55.124Z"/"triggered_time": "$body.watch_record.trigger_event.triggered_time"/]// TESTRESPONSE[s/"@timestamp": "2015-06-02T23:17:55.124Z"/"@timestamp": "$body.watch_record.trigger_event.triggered_time"/]// TESTRESPONSE[s/"scheduled_time": "2015-06-02T23:17:55.124Z"/"scheduled_time": "$body.watch_record.trigger_event.manual.schedule.scheduled_time"/]// TESTRESPONSE[s/"execution_time": "2015-06-02T23:17:55.124Z"/"execution_time": "$body.watch_record.result.execution_time"/]// TESTRESPONSE[s/"timestamp": "2015-06-02T23:17:55.111Z"/"timestamp": "$body.watch_record.status.state.timestamp"/]// TESTRESPONSE[s/"timestamp": "2015-06-02T23:17:55.124Z"/"timestamp": "$body.watch_record.status.actions.test_index.ack.timestamp"/]// TESTRESPONSE[s/"last_checked": "2015-06-02T23:17:55.124Z"/"last_checked": "$body.watch_record.status.last_checked"/]// TESTRESPONSE[s/"last_met_condition": "2015-06-02T23:17:55.124Z"/"last_met_condition": "$body.watch_record.status.last_met_condition"/]// TESTRESPONSE[s/"execution_duration": 12608/"execution_duration": "$body.watch_record.result.execution_duration"/]// TESTRESPONSE[s/"id": "AVSHKzPa9zx62AzUzFXY"/"id": "$body.watch_record.result.actions.0.index.response.id"/]// TESTRESPONSE[s/"node": "my_node"/"node": "$body.watch_record.node"/]<1> The id of the watch record as it would be stored in the `.watcher-history` index.<2> The watch record document as it would be stored in the `.watcher-history` index.<3> The watch execution results.<4> The user used to execute the watch.You can set a different execution mode for every action by associating the modename with the action id:[source,console]--------------------------------------------------POST _watcher/watch/my_watch/_execute{  "action_modes" : {    "action1" : "force_simulate",    "action2" : "skip"  }}--------------------------------------------------// TEST[setup:my_active_watch]You can also associate a single execution mode with all the actions in the watchusing `_all` as the action id:[source,console]--------------------------------------------------POST _watcher/watch/my_watch/_execute{  "action_modes" : {    "_all" : "force_execute"  }}--------------------------------------------------// TEST[setup:my_active_watch]The following example shows how to execute a watch inline:[source,console]--------------------------------------------------POST _watcher/watch/_execute{  "watch" : {    "trigger" : { "schedule" : { "interval" : "10s" } },    "input" : {      "search" : {        "request" : {          "indices" : [ "logs" ],          "body" : {            "query" : {              "match" : { "message": "error" }            }          }        }      }    },    "condition" : {      "compare" : { "ctx.payload.hits.total" : { "gt" : 0 }}    },    "actions" : {      "log_error" : {        "logging" : {          "text" : "Found {{ctx.payload.hits.total}} errors in the logs"        }      }    }  }}--------------------------------------------------All other settings for this API still apply when inlining a watch. In thefollowing snippet, while the inline watch defines a `compare` condition,during the execution this condition will be ignored:[source,console]--------------------------------------------------POST _watcher/watch/_execute{  "ignore_condition" : true,  "watch" : {    "trigger" : { "schedule" : { "interval" : "10s" } },    "input" : {      "search" : {        "request" : {          "indices" : [ "logs" ],          "body" : {            "query" : {              "match" : { "message": "error" }            }          }        }      }    },    "condition" : {      "compare" : { "ctx.payload.hits.total" : { "gt" : 0 }}    },    "actions" : {      "log_error" : {        "logging" : {          "text" : "Found {{ctx.payload.hits.total}} errors in the logs"        }      }    }  }}--------------------------------------------------
 |