From 5f83624ab3a56fba162e6cb2d5f50a8d9e7bdc4c Mon Sep 17 00:00:00 2001 From: Lisa Cawley Date: Wed, 2 Oct 2019 08:27:20 -0700 Subject: [PATCH] [DOCS] Moves Watcher content into Elasticsearch book (#47147) (#47453) Co-Authored-By: James Rodewig --- .../high-level/watcher/ack-watch.asciidoc | 2 +- docs/painless/painless-contexts.asciidoc | 4 +- ...ainless-watcher-condition-context.asciidoc | 4 +- ...ainless-watcher-transform-context.asciidoc | 4 +- docs/reference/commands/syskeygen.asciidoc | 3 +- docs/reference/index.asciidoc | 2 + docs/reference/release-notes/6.0.asciidoc | 3 +- docs/reference/release-notes/6.2.asciidoc | 5 +- .../settings/notification-settings.asciidoc | 45 ++++++------ .../setup/bootstrap-checks-xes.asciidoc | 3 +- .../en/rest-api/watcher/ack-watch.asciidoc | 2 +- .../rest-api/watcher/activate-watch.asciidoc | 3 +- .../watcher/deactivate-watch.asciidoc | 3 +- .../rest-api/watcher/execute-watch.asciidoc | 9 +-- .../en/rest-api/watcher/put-watch.asciidoc | 14 ++-- x-pack/docs/en/watcher/actions.asciidoc | 17 ++--- x-pack/docs/en/watcher/actions/email.asciidoc | 39 +++++----- .../docs/en/watcher/actions/hipchat.asciidoc | 44 +++++------ x-pack/docs/en/watcher/actions/index.asciidoc | 12 +-- x-pack/docs/en/watcher/actions/jira.asciidoc | 12 +-- .../docs/en/watcher/actions/logging.asciidoc | 6 +- .../en/watcher/actions/pagerduty.asciidoc | 22 +++--- x-pack/docs/en/watcher/actions/slack.asciidoc | 18 ++--- .../docs/en/watcher/actions/webhook.asciidoc | 26 +++---- x-pack/docs/en/watcher/condition.asciidoc | 16 ++-- .../docs/en/watcher/condition/always.asciidoc | 6 +- .../watcher/condition/array-compare.asciidoc | 20 ++--- .../en/watcher/condition/compare.asciidoc | 12 +-- .../docs/en/watcher/condition/never.asciidoc | 4 +- .../docs/en/watcher/condition/script.asciidoc | 34 ++++----- .../en/watcher/customizing-watches.asciidoc | 69 +++++++++--------- .../docs/en/watcher/encrypting-data.asciidoc | 11 ++- .../docs/en/watcher/example-watches.asciidoc | 8 +- .../example-watch-clusterstatus.asciidoc | 40 +++++----- .../example-watch-meetupdata.asciidoc | 6 +- .../watching-time-series-data.asciidoc | 4 +- .../docs/en/watcher/getting-started.asciidoc | 35 +++++---- x-pack/docs/en/watcher/gs-index.asciidoc | 2 +- .../en/watcher/how-watcher-works.asciidoc | 47 ++++++------ .../watcher/images/watcher-ui-edit-watch.png | Bin 0 -> 250698 bytes x-pack/docs/en/watcher/index.asciidoc | 4 + x-pack/docs/en/watcher/input.asciidoc | 8 +- x-pack/docs/en/watcher/input/chain.asciidoc | 7 +- x-pack/docs/en/watcher/input/http.asciidoc | 34 ++++----- x-pack/docs/en/watcher/input/search.asciidoc | 37 +++++----- x-pack/docs/en/watcher/input/simple.asciidoc | 2 +- .../docs/en/watcher/java/ack-watch.asciidoc | 6 +- .../en/watcher/java/activate-watch.asciidoc | 6 +- .../en/watcher/java/deactivate-watch.asciidoc | 6 +- .../en/watcher/java/delete-watch.asciidoc | 4 +- .../en/watcher/java/execute-watch.asciidoc | 2 +- .../docs/en/watcher/java/get-watch.asciidoc | 2 +- .../docs/en/watcher/java/put-watch.asciidoc | 4 +- x-pack/docs/en/watcher/limitations.asciidoc | 32 ++++++++ .../docs/en/watcher/managing-watches.asciidoc | 16 ++-- x-pack/docs/en/watcher/release-notes.asciidoc | 50 ++++++------- x-pack/docs/en/watcher/transform.asciidoc | 6 +- .../docs/en/watcher/transform/chain.asciidoc | 8 +- .../docs/en/watcher/transform/script.asciidoc | 14 ++-- .../docs/en/watcher/transform/search.asciidoc | 26 +++---- x-pack/docs/en/watcher/trigger.asciidoc | 2 +- .../docs/en/watcher/trigger/schedule.asciidoc | 6 +- .../en/watcher/trigger/schedule/cron.asciidoc | 24 +++--- .../watcher/trigger/schedule/daily.asciidoc | 12 +-- .../watcher/trigger/schedule/hourly.asciidoc | 8 +- .../trigger/schedule/interval.asciidoc | 6 +- .../watcher/trigger/schedule/monthly.asciidoc | 8 +- .../watcher/trigger/schedule/weekly.asciidoc | 8 +- .../watcher/trigger/schedule/yearly.asciidoc | 8 +- .../docs/en/watcher/troubleshooting.asciidoc | 66 +++++++++++++++++ 70 files changed, 568 insertions(+), 470 deletions(-) create mode 100644 x-pack/docs/en/watcher/images/watcher-ui-edit-watch.png create mode 100644 x-pack/docs/en/watcher/limitations.asciidoc create mode 100644 x-pack/docs/en/watcher/troubleshooting.asciidoc diff --git a/docs/java-rest/high-level/watcher/ack-watch.asciidoc b/docs/java-rest/high-level/watcher/ack-watch.asciidoc index 46a516798594b..2b865cbd2e7cd 100644 --- a/docs/java-rest/high-level/watcher/ack-watch.asciidoc +++ b/docs/java-rest/high-level/watcher/ack-watch.asciidoc @@ -10,7 +10,7 @@ [id="{upid}-{api}-request"] ==== Execution -{xpack-ref}/actions.html#actions-ack-throttle[Acknowledging a watch] enables you +{ref}/actions.html#actions-ack-throttle[Acknowledging a watch] enables you to manually throttle execution of a watch's actions. A watch can be acknowledged through the following request: diff --git a/docs/painless/painless-contexts.asciidoc b/docs/painless/painless-contexts.asciidoc index 7c342a3da7a5a..75b1a450c0dcd 100644 --- a/docs/painless/painless-contexts.asciidoc +++ b/docs/painless/painless-contexts.asciidoc @@ -49,9 +49,9 @@ specialized code may define new ways to use a Painless script. | Bucket selector aggregation | <> | {ref}/search-aggregations-pipeline-bucket-selector-aggregation.html[Elasticsearch Documentation] | Watcher condition | <> - | {xpack-ref}/condition-script.html[Elasticsearch Documentation] + | {ref}/condition-script.html[Elasticsearch Documentation] | Watcher transform | <> - | {xpack-ref}/transform-script.html[Elasticsearch Documentation] + | {ref}/transform-script.html[Elasticsearch Documentation] |==== include::painless-contexts/painless-context-examples.asciidoc[] diff --git a/docs/painless/painless-contexts/painless-watcher-condition-context.asciidoc b/docs/painless/painless-contexts/painless-watcher-condition-context.asciidoc index 713bcf32daec4..506bc3b967e5a 100644 --- a/docs/painless/painless-contexts/painless-watcher-condition-context.asciidoc +++ b/docs/painless/painless-contexts/painless-watcher-condition-context.asciidoc @@ -1,7 +1,7 @@ [[painless-watcher-condition-context]] === Watcher condition context -Use a Painless script as a {xpack-ref}/condition-script.html[watcher condition] +Use a Painless script as a {ref}/condition-script.html[watcher condition] to test if a response is necessary. *Variables* @@ -26,7 +26,7 @@ to test if a response is necessary. `ctx['payload']` (`Map`, read-only):: The accessible watch data based upon the - {xpack-ref}/input.html[watch input]. + {ref}/input.html[watch input]. *Return* diff --git a/docs/painless/painless-contexts/painless-watcher-transform-context.asciidoc b/docs/painless/painless-contexts/painless-watcher-transform-context.asciidoc index 27cb4eb15056d..4a2bab6554bbf 100644 --- a/docs/painless/painless-contexts/painless-watcher-transform-context.asciidoc +++ b/docs/painless/painless-contexts/painless-watcher-transform-context.asciidoc @@ -1,7 +1,7 @@ [[painless-watcher-transform-context]] === Watcher transform context -Use a Painless script to {xpack-ref}/transform-script.html[transform] watch +Use a Painless script to {ref}/transform-script.html[transform] watch data into a new payload for use in a response to a condition. *Variables* @@ -26,7 +26,7 @@ data into a new payload for use in a response to a condition. `ctx['payload']` (`Map`, read-only):: The accessible watch data based upon the - {xpack-ref}/input.html[watch input]. + {ref}/input.html[watch input]. *Return* diff --git a/docs/reference/commands/syskeygen.asciidoc b/docs/reference/commands/syskeygen.asciidoc index 3ae7456448d83..06d8330a1222a 100644 --- a/docs/reference/commands/syskeygen.asciidoc +++ b/docs/reference/commands/syskeygen.asciidoc @@ -21,7 +21,8 @@ bin/elasticsearch-syskeygen The command generates a `system_key` file, which you can use to symmetrically encrypt sensitive data. For example, you can use this key to prevent {watcher} -from returning and storing information that contains clear text credentials. See {xpack-ref}/encrypting-data.html[Encrypting sensitive data in {watcher}]. +from returning and storing information that contains clear text credentials. See +<>. IMPORTANT: The system key is a symmetric key, so the same key must be used on every node in the cluster. diff --git a/docs/reference/index.asciidoc b/docs/reference/index.asciidoc index e6d7a979f808c..288b402aaeb4b 100644 --- a/docs/reference/index.asciidoc +++ b/docs/reference/index.asciidoc @@ -67,6 +67,8 @@ include::rollup/index.asciidoc[] include::frozen-indices.asciidoc[] +include::{xes-repo-dir}/watcher/index.asciidoc[] + include::rest-api/index.asciidoc[] include::commands/index.asciidoc[] diff --git a/docs/reference/release-notes/6.0.asciidoc b/docs/reference/release-notes/6.0.asciidoc index 4a063236c92d8..28657e257a94b 100644 --- a/docs/reference/release-notes/6.0.asciidoc +++ b/docs/reference/release-notes/6.0.asciidoc @@ -1279,8 +1279,7 @@ Security:: Watcher:: * Added verification that the required templates exist before {watcher} starts. -For more information, see -{stack-ov}/how-watcher-works.html#scripts-templates[Scripts and Templates]. +For more information, see <>. * Added the `xpack.watcher.history.cleaner_service.enabled` setting. You can use this setting to enable or disable the cleaner service, which removes previous versions of {watcher} indices (for example, .watcher-history*) when it diff --git a/docs/reference/release-notes/6.2.asciidoc b/docs/reference/release-notes/6.2.asciidoc index 15292b812559f..63b4ba3d7d5a7 100644 --- a/docs/reference/release-notes/6.2.asciidoc +++ b/docs/reference/release-notes/6.2.asciidoc @@ -220,8 +220,7 @@ Watcher:: * Fixed the serialization of failed hipchat messages, such that it no longer tries to write the status field twice. * Fixed TransformInput toXContent serialization errors. For more information, -see -{stack-ov}/input-chain.html#_transforming_chained_input_data[Transforming Chained Input Data]. +see <<_transforming_chained_input_data>>. Allocation:: @@ -434,7 +433,7 @@ more information, see {stack-ov}/saml-realm.html[SAML authentication]. Watcher:: * Added a transform input for chained input. For more information, see -{stack-ov}/input-chain.html#_transforming_chained_input_data[Transforming Chained Input Data]. +<<_transforming_chained_input_data>>. [float] === Enhancements diff --git a/docs/reference/settings/notification-settings.asciidoc b/docs/reference/settings/notification-settings.asciidoc index 500b425fdc3a2..e96e3702a25b6 100644 --- a/docs/reference/settings/notification-settings.asciidoc +++ b/docs/reference/settings/notification-settings.asciidoc @@ -8,10 +8,11 @@ ++++ You configure `xpack.notification` settings in `elasticsearch.yml` to -send set up {watcher} and send notifications via <>, -<>, +send set up {watcher} and send notifications via +<>, +<>, <>, and -<>. Dynamic settings can also be updated +<>. Dynamic settings can also be updated across a cluster with the <>. [float] @@ -23,14 +24,12 @@ Set to `false` to disable {watcher} on the node. `xpack.watcher.encrypt_sensitive_data`:: Set to `true` to encrypt sensitive data. If this setting is enabled, you must also specify the `xpack.watcher.encryption_key` setting. For more -information, see -{stack-ov}/encrypting-data.html[Encrypting sensitive data in {watcher}]. +information, see <>. `xpack.watcher.encryption_key` (<>):: Specifies the path to a file that contains a key for encrypting sensitive data. If `xpack.watcher.encrypt_sensitive_data` is set to `true`, this setting is -required. For more information, see -{stack-ov}/encrypting-data.html[Encrypting sensitive data in {watcher}]. +required. For more information, see <>. `xpack.watcher.history.cleaner_service.enabled`:: ifdef::asciidoctor[] @@ -80,7 +79,7 @@ include::ssl-settings.asciidoc[] ==== Email Notification Settings You can configure the following email notification settings in `elasticsearch.yml`. For more information about sending notifications -via email, see {stack-ov}/actions-email.html#configuring-email-actions[Configuring Email]. +via email, see <>. `xpack.notification.email.account`:: Specifies account information for sending notifications via email. You @@ -90,14 +89,15 @@ can specify the following email account attributes: [[email-account-attributes]] `profile` (<>);; - The {stack-ov}/actions-email.html#configuring-email[email profile] to use to build the MIME + The <> to use to build the MIME messages that are sent from the account. Valid values: `standard`, `gmail` and `outlook`. Defaults to `standard`. `email_defaults.*` (<>);; An optional set of email attributes to use as defaults - for the emails sent from the account. See {stack-ov}/actions-email.html#email-action-attributes[ - Email Action Attributes] for the supported attributes. + for the emails sent from the account. See + <> for the supported + attributes. `smtp.auth` (<>);; Set to `true` to attempt to authenticate the user using the @@ -161,9 +161,9 @@ can specify the following email account attributes: `xpack.notification.email.html.sanitization.allow`:: Specifies the HTML elements that are allowed in email notifications. For -more information, see {stack-ov}/actions-email.html#email-html-sanitization[Configuring HTML -Sanitization Options]. You can specify individual HTML elements -and the following HTML feature groups: +more information, see +<>. You can +specify individual HTML elements and the following HTML feature groups: + -- [[html-feature-groups]] @@ -212,10 +212,10 @@ Defaults to `true`. [float] [[hipchat-notification-settings]] -==== HipChat Notification Settings +==== HipChat notification settings You can configure the following HipChat notification settings in `elasticsearch.yml`. For more information about sending notifications -via HipChat, see {stack-ov}/actions-hipchat.html#configuring-hipchat-actions[Configuring HipChat]. +via HipChat, see <>. `xpack.notification.hipchat` :: Specifies account information for sending notifications @@ -266,7 +266,7 @@ via HipChat. You can specify the following HipChat account attributes: ==== Slack Notification Settings You can configure the following Slack notification settings in `elasticsearch.yml`. For more information about sending notifications -via Slack, see {stack-ov}/actions-slack.html#configuring-slack-actions[Configuring Slack]. +via Slack, see <>. `xpack.notification.slack` :: Specifies account information for sending notifications @@ -310,7 +310,7 @@ via Slack. You can specify the following Slack account attributes: ==== Jira Notification Settings You can configure the following Jira notification settings in `elasticsearch.yml`. For more information about using notifications -to create issues in Jira, see {stack-ov}/actions-jira.html#configuring-jira-actions[Configuring Jira]. +to create issues in Jira, see <>. `xpack.notification.jira` :: Specifies account information for using notifications to create @@ -339,7 +339,7 @@ issues in Jira. You can specify the following Jira account attributes: `issue_defaults`;; Default fields values for the issue created in Jira. See - {stack-ov}/actions-jira.html#jira-action-attributes[Jira Action Attributes] for more information. + <> for more information. Optional. -- @@ -348,7 +348,7 @@ issues in Jira. You can specify the following Jira account attributes: ==== PagerDuty Notification Settings You can configure the following PagerDuty notification settings in `elasticsearch.yml`. For more information about sending notifications -via PagerDuty, see {stack-ov}/actions-pagerduty.html#configuring-pagerduty-actions[Configuring PagerDuty]. +via PagerDuty, see <>. [[pagerduty-account-attributes]] @@ -372,8 +372,9 @@ PagerDuty API key] to use to access PagerDuty. Required. -- + `event_defaults`;; -Default values for {stack-ov}/actions-pagerduty.html#pagerduty-event-trigger-incident-attributes[ -PagerDuty event attributes]. Optional. +Default values for +<>. +Optional. + -- `description`:: diff --git a/docs/reference/setup/bootstrap-checks-xes.asciidoc b/docs/reference/setup/bootstrap-checks-xes.asciidoc index a7b27e3e4e506..3c680fa3cbdb2 100644 --- a/docs/reference/setup/bootstrap-checks-xes.asciidoc +++ b/docs/reference/setup/bootstrap-checks-xes.asciidoc @@ -14,8 +14,7 @@ If you use {watcher} and have chosen to encrypt sensitive data (by setting the secure settings store. To pass this bootstrap check, you must set the `xpack.watcher.encryption_key` -on each node in the cluster. For more information, see -{xpack-ref}/encrypting-data.html[Encrypting Sensitive Data in {watcher}]. +on each node in the cluster. For more information, see <>. [float] === PKI realm check diff --git a/x-pack/docs/en/rest-api/watcher/ack-watch.asciidoc b/x-pack/docs/en/rest-api/watcher/ack-watch.asciidoc index 3b3550ac61f90..620b213eb74da 100644 --- a/x-pack/docs/en/rest-api/watcher/ack-watch.asciidoc +++ b/x-pack/docs/en/rest-api/watcher/ack-watch.asciidoc @@ -5,7 +5,7 @@ Ack watch ++++ -{stack-ov}/actions.html#actions-ack-throttle[Acknowledging a watch] enables you +<> enables you to manually throttle execution of the watch's actions. An action's _acknowledgement state_ is stored in the `status.actions..ack.state` structure. diff --git a/x-pack/docs/en/rest-api/watcher/activate-watch.asciidoc b/x-pack/docs/en/rest-api/watcher/activate-watch.asciidoc index b1770b66aa591..6ed21812d9ec5 100644 --- a/x-pack/docs/en/rest-api/watcher/activate-watch.asciidoc +++ b/x-pack/docs/en/rest-api/watcher/activate-watch.asciidoc @@ -5,8 +5,7 @@ Activate watch ++++ -A watch can be either -{stack-ov}/how-watcher-works.html#watch-active-state[active or inactive]. This +A watch can be either <>. This API enables you to activate a currently inactive watch. [float] diff --git a/x-pack/docs/en/rest-api/watcher/deactivate-watch.asciidoc b/x-pack/docs/en/rest-api/watcher/deactivate-watch.asciidoc index 8ef501941c187..f1499b527f151 100644 --- a/x-pack/docs/en/rest-api/watcher/deactivate-watch.asciidoc +++ b/x-pack/docs/en/rest-api/watcher/deactivate-watch.asciidoc @@ -5,8 +5,7 @@ Deactivate watch ++++ -A watch can be either -{stack-ov}/how-watcher-works.html#watch-active-state[active or inactive]. This +A watch can be either <>. This API enables you to deactivate a currently active watch. [float] diff --git a/x-pack/docs/en/rest-api/watcher/execute-watch.asciidoc b/x-pack/docs/en/rest-api/watcher/execute-watch.asciidoc index 52700a112f61f..81c448ac56c82 100644 --- a/x-pack/docs/en/rest-api/watcher/execute-watch.asciidoc +++ b/x-pack/docs/en/rest-api/watcher/execute-watch.asciidoc @@ -59,14 +59,14 @@ This API supports the following fields: that will be used during the watch execution | `ignore_condition` | no | false | When set to `true`, the watch execution uses the - {stack-ov}/condition-always.html[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 <> + watch execution. See <> for more information. | `record_execution` | no | false | When set to `true`, the watch record representing the watch @@ -75,8 +75,7 @@ This API supports the following fields: watch is updated, possibly throttling subsequent executions. This can also be specified as an HTTP parameter. -| `watch` | no | null | When present, this - {stack-ov}/how-watcher-works.html#watch-definition[watch] is used +| `watch` | no | null | When present, this <> is used instead of the one specified in the request. This watch is not persisted to the index and record_execution cannot be set. |====== @@ -94,7 +93,7 @@ are five possible modes an action can be associated with: | `simulate` | The action execution is simulated. Each action type define its own simulation operation mode. For example, the - {stack-ov}/actions-email.html[email] action creates + <> 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. diff --git a/x-pack/docs/en/rest-api/watcher/put-watch.asciidoc b/x-pack/docs/en/rest-api/watcher/put-watch.asciidoc index ea784852cbb4c..ee8e7e6e33544 100644 --- a/x-pack/docs/en/rest-api/watcher/put-watch.asciidoc +++ b/x-pack/docs/en/rest-api/watcher/put-watch.asciidoc @@ -27,7 +27,7 @@ IMPORTANT: Putting a watch must be done via this API only. Do not put a watch privileges are granted to anyone over the `.watches` index. When adding a watch you can also define its initial -{xpack-ref}/how-watcher-works.html#watch-active-state[active state]. You do that +<>. You do that by setting the `active` parameter. [float] @@ -52,16 +52,16 @@ A watch has the following fields: |====== | Name | Description -| `trigger` | The {xpack-ref}/trigger.html[trigger] that defines when +| `trigger` | The <> that defines when the watch should run. -| `input` | The {xpack-ref}/input.html[input] that defines the input +| `input` | The <> that defines the input that loads the data for the watch. -| `condition` | The {xpack-ref}/condition.html[condition] that defines if +| `condition` | The <> that defines if the actions should be run. -| `actions` | The list of {xpack-ref}/actions.html[actions] that will be +| `actions` | The list of <> that will be run if the condition matches | `metadata` | Metadata json that will be copied into the history entries. @@ -75,7 +75,7 @@ A watch has the following fields: ==== Authorization You must have `manage_watcher` cluster privileges to use this API. For more -information, see {xpack-ref}/security-privileges.html[Security Privileges]. +information, see {stack-ov}/security-privileges.html[Security Privileges]. [float] ==== Security Integration @@ -148,7 +148,7 @@ PUT _xpack/watcher/watch/my-watch // CONSOLE When you add a watch you can also define its initial -{xpack-ref}/how-watcher-works.html#watch-active-state[active state]. You do that +<>. You do that by setting the `active` parameter. The following command adds a watch and sets it to be inactive by default: diff --git a/x-pack/docs/en/watcher/actions.asciidoc b/x-pack/docs/en/watcher/actions.asciidoc index de2516b0589cc..d3b147b8231da 100644 --- a/x-pack/docs/en/watcher/actions.asciidoc +++ b/x-pack/docs/en/watcher/actions.asciidoc @@ -2,7 +2,7 @@ == Actions When a watch's condition is met, its actions are executed unless it is being -<>. A watch can perform multiple actions. +<>. A watch can perform multiple actions. The actions are executed one at a time and each action executes independently. Any failures encountered while executing an action are recorded in the action result and in the watch history. @@ -15,13 +15,13 @@ support their execution in any way they need. For example, the payload might serve as a model for a templated email body. {watcher} supports the following types of actions: -<>, <>, <>, -<>, <>, <>, and <>. +<>, <>, <>, +<>, <>, +and <>. [float] [[actions-ack-throttle]] -=== Acknowledgement and Throttling +=== Acknowledgement and throttling During the watch execution, once the condition is met, a decision is made per configured action as to whether it should be throttled. The main purpose of @@ -93,7 +93,7 @@ PUT _xpack/watcher/watch/error_logs_alert // CONSOLE <1> There will be at least 15 minutes between subsequent `email_administrator` action executions. -<2> See <> for more information. +<2> See <> for more information. You can also define a throttle period at the watch level. The watch-level throttle period serves as the default throttle period for all of the actions @@ -165,15 +165,14 @@ xpack.watcher.execution.default_throttle_period: 15m -------------------------------------------------- {watcher} also supports acknowledgement-based throttling. You can acknowledge a -watch using the {ref}/watcher-api-ack-watch.html[Ack Watch API] to prevent the +watch using the <> to prevent the watch actions from being executed again while the watch condition remains `true`. This essentially tells {watcher} "I received the notification and I'm handling it, please do not notify me about this error again". An acknowledged watch action remains in the `acked` state until the watch's condition evaluates to `false`. When that happens, the action's state changes to `awaits_successful_execution`. -To acknowledge an action, you use the -{ref}/watcher-api-ack-watch.html[Ack Watch API]: +To acknowledge an action, you use the <>: [source,js] ---------------------------------------------------------------------- diff --git a/x-pack/docs/en/watcher/actions/email.asciidoc b/x-pack/docs/en/watcher/actions/email.asciidoc index 9ec65a070df12..9f1e53608b1a9 100644 --- a/x-pack/docs/en/watcher/actions/email.asciidoc +++ b/x-pack/docs/en/watcher/actions/email.asciidoc @@ -1,5 +1,5 @@ [[actions-email]] -=== Email Action +=== Email action Use the `email` action to send email notifications. To send email, you must <> in @@ -15,7 +15,7 @@ account configuration. The required attributes must either be set in the email action definition or the account's `email_defaults`. [[configuring-email-actions]] -==== Configuring Email Actions +==== Configuring email actions You configure email actions in the `actions` array. Action-specific attributes are specified using the `email` keyword. @@ -47,7 +47,7 @@ the watch payload in the email body: account configuration. [[configuring-email-attachments]] -==== Configuring Email Attachments +==== Configuring email attachments You can attach the execution context payload or data from an any HTTP service to the email notification. There is no limit on the number of attachments you can @@ -151,20 +151,15 @@ killed by firewalls or load balancers in-between. [[email-action-reports]] -===== Attaching Reports to an Email +===== Attaching reports to an email You can use the `reporting` attachment type in an `email` action to automatically generate a Kibana report and distribute it via email. -include::{kib-repo-dir}/reporting/watch-example.asciidoc[] - -include::{kib-repo-dir}/reporting/report-intervals.asciidoc[] - -For more information, see -{kibana-ref}/automating-report-generation.html[Automating Report Generation]. +See {kibana-ref}/automating-report-generation.html[Automating report generation]. [[email-action-attributes]] -==== Email Action Attributes +==== Email action attributes [cols=",^,,", options="header"] |====== @@ -251,7 +246,7 @@ A list of addresses can be specified as a an array: `[ 'Personal Name ', 'user2@host.domain' ]`. [[configuring-email]] -==== Configuring Email Accounts +==== Configuring email accounts {watcher} can send email using any SMTP email service. Email messages can contain basic HTML tags. You can control which groups of tags are @@ -280,14 +275,14 @@ email system. For more information about configuring {watcher} to work with different email systems, see: -* <> -* <> -* <> -* <> +* <> +* <> +* <> +* <> If you configure multiple email accounts, you must either configure a default account or specify which account the email should be sent with in the -<> action. +<> action. [source,yaml] -------------------------------------------------- @@ -302,7 +297,7 @@ xpack.notification.email: [float] [[gmail]] -===== Sending Email From Gmail +===== Sending email from Gmail Use the following email account settings to send email from the https://mail.google.com[Gmail] SMTP service: @@ -340,7 +335,7 @@ for more information. [float] [[outlook]] -===== Sending Email from Outlook.com +===== Sending email from Outlook.com Use the following email account settings to send email action from the https://www.outlook.com/[Outlook.com] SMTP service: @@ -376,7 +371,7 @@ NOTE: You need to use a unique App Password if two-step verification is enable [float] [[amazon-ses]] -===== Sending Email from Amazon SES (Simple Email Service) +===== Sending email from Amazon SES (Simple Email Service) Use the following email account settings to send email from the http://aws.amazon.com/ses[Amazon Simple Email Service] (SES) SMTP service: @@ -413,7 +408,7 @@ NOTE: You need to use your Amazon SES SMTP credentials to send email through [float] [[exchange]] -===== Sending Email from Microsoft Exchange +===== Sending email from Microsoft Exchange Use the following email account settings to send email action from Microsoft Exchange: @@ -448,7 +443,7 @@ bin/elasticsearch-keystore xpack.notification.email.account.exchange_account.smt [float] [[email-html-sanitization]] -===== Configuring HTML Sanitization Options +===== Configuring HTML sanitization options The `email` action supports sending messages with an HTML body. However, for security reasons, {watcher} https://en.wikipedia.org/wiki/HTML_sanitization[sanitizes] diff --git a/x-pack/docs/en/watcher/actions/hipchat.asciidoc b/x-pack/docs/en/watcher/actions/hipchat.asciidoc index 49799567410ea..30bb1374ad3b6 100644 --- a/x-pack/docs/en/watcher/actions/hipchat.asciidoc +++ b/x-pack/docs/en/watcher/actions/hipchat.asciidoc @@ -1,12 +1,12 @@ [[actions-hipchat]] -=== HipChat Action +=== HipChat action Use the `hipchat` action to send messages to https://www.hipchat.com[HipChat] rooms or users. To send HipChat messages, you must -<> in `elasticsearch.yml`. +<> in `elasticsearch.yml`. [[configuring-hipchat-actions]] -==== Configuring HipChat Actions +==== Configuring HipChat actions You configure HipChat actions in a `actions` array. Action-specific attributes are specified using the `hipchat` keyword. You must specify the `message` @@ -15,7 +15,7 @@ message is sent using the default HipChat account configured in `elasticsearch.yml`. For example, the following action is configured to send messages using a HipChat -account that uses the <> profile. Because +account that uses the <> profile. Because this type of account can only send messages to a specific room, the only required attribute is the message itself: @@ -41,7 +41,7 @@ attribute is the message itself: <1> The name of a HipChat account configured in `elasticsearch.yml`. <2> The message you want to send to HipChat. -To send messages with a HipChat account that uses the <> +To send messages with a HipChat account that uses the <> profile, you need to specify what rooms and users you want to send the message to. For example, the following action is configured to send messages to the `mission-control` and `devops` rooms as well as the user `website-admin@example.com`. @@ -69,7 +69,7 @@ For example, the following action is configured to send messages to the -------------------------------------------------- // NOTCONSOLE -To send messages with a HipChat account that uses the <> +To send messages with a HipChat account that uses the <> profile, you need to specify what room or rooms you want to send the message to. For example, the following action is configured to send messages to the `server-status` room. (To send to multiple rooms, specify an array of strings.) @@ -97,7 +97,7 @@ For example, the following action is configured to send messages to the // NOTCONSOLE [[hipchat-action-attributes]] -==== HipChat Action Attributes +==== HipChat action attributes [cols=",^,,", options="header"] |====== @@ -136,7 +136,7 @@ For example, the following action is configured to send messages to the [[configuring-hipchat]] -==== Configuring HipChat Accounts +==== Configuring HipChat accounts You configure the accounts {watcher} can use to communicate with HipChat in the `xpack.notification.hipchat` namespace in `elasticsearch.yml`. Both @@ -165,11 +165,11 @@ NOTE: The `v1` profile is provided because it is simple to set up and this API If you configure multiple HipChat accounts, you either need to set a default HipChat account or specify which account the notification should be sent with -in the <> action. +in the <> action. Storing the `auth_token` in the configuration file or using via updating the settings now is still supported, but you should use the keystore for this, see -{ref}/secure-settings.html[secure settings] +<>. [source,yaml] -------------------------------------------------- @@ -184,7 +184,7 @@ xpack.notification.hipchat: [[hipchat-api-integration]] -===== Using the Hipchat Integration Profile +===== Using the Hipchat integration profile You can use the `integration` profile to send messages to specific rooms. When you set an account's profile to `integration`, the messages are sent through @@ -194,11 +194,11 @@ Send room notification] API. When you use the `integration` profile, you need to configure a separate HipChat account for each room you want to send messages--the account configuration contains a room-specific authentication token. Alternatively, you can use the -<> or <> profile to send messages +<> or <> profile to send messages to multiple rooms. NOTE: The `integration` profile only supports sending messages to rooms, it does - not support sending private messages. Use the <> + not support sending private messages. Use the <> profile to notify a particular HipChat user. You need a room-specific authentication token to configure an `integration` @@ -242,8 +242,8 @@ xpack.notification.hipchat: room: monitoring -------------------------------------------------- -You can also specify defaults for the {ref}/notification-settings.html#hipchat-account-attributes[ -message attributes]: +You can also specify defaults for the +<>: [source,yaml] -------------------------------------------------- @@ -260,7 +260,7 @@ xpack.notification.hipchat: [[hipchat-api-user]] -===== Using the HipChat User Profile +===== Using the HipChat user profile You can use the `user` profile to send messages to rooms as well as individual HipChat users. When you set an account's profile to `user`, {watcher} sends @@ -307,8 +307,8 @@ xpack.notification.hipchat: profile: user -------------------------------------------------- -You can also specify defaults for the <{ref}/notification-settings.html#hipchat-account-attributes[ -message attributes]: +You can also specify defaults for the +<>: [source,shell] -------------------------------------------------- @@ -329,7 +329,7 @@ xpack.notification.hipchat: [[hipchat-api-v1]] -===== Using the HipChat v1 Profile +===== Using the HipChat v1 profile You can use the `v1` profile to send messages to particular rooms. When you set an account's profile to `v1`, messages are sent through HipChat's v1 @@ -339,7 +339,7 @@ WARNING: The `v1` profile uses a deprecated API that is expected to be removed by HipChat in the future. The `v1` profile only supports sending messages to rooms, it does not support -sending private messages. Use the <> profile to send +sending private messages. Use the <> profile to send private messages to HipChat users. Before you can configure a `v1` account, you need to generate a `v1` API token: @@ -379,8 +379,8 @@ xpack.notification.hipchat: profile: v1 -------------------------------------------------- -You can also specify defaults for the {ref}/notification-settings.html#hipchat-account-attributes[ -message attributes]. +You can also specify defaults for the +<>. [source,yaml] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/actions/index.asciidoc b/x-pack/docs/en/watcher/actions/index.asciidoc index 8a31b150f22cb..4e54956cc79e8 100644 --- a/x-pack/docs/en/watcher/actions/index.asciidoc +++ b/x-pack/docs/en/watcher/actions/index.asciidoc @@ -1,10 +1,10 @@ [[actions-index]] -=== Index Action +=== Index action Use the `index` action to index data into Elasticsearch. See <> for the supported attributes. -==== Configuring Index Actions +==== Configuring index actions The following snippet shows a simple `index` action definition: @@ -24,15 +24,15 @@ The following snippet shows a simple `index` action definition: -------------------------------------------------- // NOTCONSOLE <1> The id of the action -<2> An optional <> to restrict action execution -<3> An optional <> to transform the payload and prepare the data that should be indexed +<2> An optional <> to restrict action execution +<3> An optional <> to transform the payload and prepare the data that should be indexed <4> The elasticsearch index to store the data to <5> The document type to store the data as <6> An optional `_id` for the document, if it should always be the same document. [[index-action-attributes]] -==== Index Action Attributes +==== Index action attributes [options="header"] |====== @@ -58,7 +58,7 @@ The following snippet shows a simple `index` action definition: |====== [[anatomy-actions-index-multi-doc-support]] -==== Multi-Document Support +==== Multi-document support Like with all other actions, you can use a <> to replace the current execution context payload with another and by that change the document diff --git a/x-pack/docs/en/watcher/actions/jira.asciidoc b/x-pack/docs/en/watcher/actions/jira.asciidoc index 7d50a75df3fa3..e13bc15f701ae 100644 --- a/x-pack/docs/en/watcher/actions/jira.asciidoc +++ b/x-pack/docs/en/watcher/actions/jira.asciidoc @@ -1,11 +1,11 @@ [[actions-jira]] -=== Jira Action +=== Jira action Use the `jira` action to create issues in https://www.atlassian.com/software/jira[Atlassian's Jira Software]. To create issues you need to <> in `elasticsearch.yml`. [[configuring-jira-actions]] -==== Configuring Jira Actions +==== Configuring Jira actions You configure Jira actions in the `actions` array. Action-specific attributes are specified using the `jira` keyword. @@ -48,7 +48,7 @@ The following snippet shows a simple jira action definition: <7> The priority of the Jira issue. [[jira-action-attributes]] -==== Jira Action Attributes +==== Jira action attributes Depending of how Jira projects are configured, the issues can have many different fields and values. Therefore the `jira` action can accept any type of sub fields within its `issue` field. These fields will be directly used @@ -99,7 +99,7 @@ always required to create an issue in Jira. |====== [[configuring-jira]] -==== Configuring Jira Accounts +==== Configuring Jira accounts You configure the accounts {watcher} can use to communicate with Jira in the `xpack.notification.jira` namespace in `elasticsearch.yml`. @@ -138,7 +138,7 @@ WARNING: It is strongly advised to use Basic Authentication with secured HTTPS protocol only. You can also specify defaults for the -{ref}/notification-settings.html#jira-account-attributes[Jira issues]: +<>: [source,yaml] -------------------------------------------------- @@ -156,7 +156,7 @@ xpack.notification.jira: If you configure multiple Jira accounts, you either need to configure a default account or specify which account the notification should be sent with in the -<> action. +<> action. [source,yaml] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/actions/logging.asciidoc b/x-pack/docs/en/watcher/actions/logging.asciidoc index a8a4454c377eb..9493f18dce29a 100644 --- a/x-pack/docs/en/watcher/actions/logging.asciidoc +++ b/x-pack/docs/en/watcher/actions/logging.asciidoc @@ -1,5 +1,5 @@ [[actions-logging]] -=== Logging Action +=== Logging action Use the `logging` action to log text to the standard Elasticsearch logs. See <> for the supported attributes. @@ -7,7 +7,7 @@ logs. See <> for the supported attributes. This action is primarily used during development and for debugging purposes. [[configuring-logging-actions]] -==== Configuring Logging Actions +==== Configuring logging actions You configure logging actions in the `actions` array. Action-specific attributes are specified using the `logging` keyword. @@ -33,7 +33,7 @@ The following snippet shows a simple logging action definition: [[logging-action-attributes]] -==== Logging Action Attributes +==== Logging action attributes [options="header"] |====== diff --git a/x-pack/docs/en/watcher/actions/pagerduty.asciidoc b/x-pack/docs/en/watcher/actions/pagerduty.asciidoc index f7ae06ad9648d..1969bf8d0943d 100644 --- a/x-pack/docs/en/watcher/actions/pagerduty.asciidoc +++ b/x-pack/docs/en/watcher/actions/pagerduty.asciidoc @@ -1,12 +1,12 @@ [[actions-pagerduty]] -=== PagerDuty Action +=== PagerDuty action Use the PagerDuty action to create events in https://pagerduty.com/[ PagerDuty]. To create PagerDuty events, you must <> in `elasticsearch.yml`. [[configuring-pagerduty-actions]] -==== Configuring PagerDuty Actions +==== Configuring PagerDuty actions You configure PagerDuty actions in the `actions` array. Action-specific attributes are specified using the `pagerduty` keyword. @@ -30,7 +30,7 @@ The following snippet shows a simple PagerDuty action definition: [[adding-context-and-payloads-to-pagerduty-actions]] -==== Adding Meta Information to a PagerDuty Incident +==== Adding meta information to a PagerDuty incident To give the PagerDuty incident some more context, you can attach the payload as well as an array of contexts to the action. @@ -64,7 +64,7 @@ payload as well as an array of contexts to the action. [[pagerduty-action-attributes]] -==== Pagerduty Action Attributes +==== Pagerduty action attributes [cols=",^,", options="header"] |====== @@ -75,7 +75,7 @@ payload as well as an array of contexts to the action. [[pagerduty-event-trigger-incident-attributes]] -.Pagerduty Event Trigger Incident Attributes +.Pagerduty event trigger incident attributes [cols=",^,", options="header"] |====== | Name |Required | Description @@ -114,7 +114,7 @@ NOTE: All of those objects have templating support, so you can use data from the context and the payload as part of all the fields. [[pagerduty-event-trigger-context-attributes]] -.Pagerduty Event Trigger Context Attributes +.Pagerduty event trigger context attributes [cols=",^,", options="header"] |====== | Name |Required | Description @@ -128,7 +128,7 @@ NOTE: All of those objects have templating support, so you can use data from the |====== [[configuring-pagerduty]] -==== Configuring PagerDuty Accounts +==== Configuring PagerDuty accounts You configure the accounts {watcher} uses to communicate with PagerDuty in the `xpack.notification.pagerduty` namespace in `elasticsearch.yml`. @@ -148,7 +148,7 @@ image::images/pagerduty-services.jpg[] image::images/pagerduty-integrations.jpg[] To configure a PagerDuty account in the keystore, you -must specify an account name and integration key, (see {ref}/secure-settings.html[secure settings]): +must specify an account name and integration key, (see <>): [source,yaml] -------------------------------------------------- @@ -158,8 +158,8 @@ bin/elasticsearch-keystore add xpack.notification.pagerduty.account.my_pagerduty Storing the service api key in the YAML file or via cluster update settings is still supported, but the keystore setting should be used -You can also specify defaults for the <>: +You can also specify defaults for the +<>: . [source,yaml] @@ -178,7 +178,7 @@ xpack.notification.pagerduty: If you configure multiple PagerDuty accounts, you either need to set a default account or specify which account the event should be sent with in the -<> action. +<> action. [source,yaml] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/actions/slack.asciidoc b/x-pack/docs/en/watcher/actions/slack.asciidoc index 05ee7b7b340d9..7dad9ea8c9fc1 100644 --- a/x-pack/docs/en/watcher/actions/slack.asciidoc +++ b/x-pack/docs/en/watcher/actions/slack.asciidoc @@ -1,13 +1,13 @@ [[actions-slack]] -=== Slack Action +=== Slack action Use the `slack` action to send messages to a https://slack.com/[Slack] team's channels or users. To send Slack messages, you need to -<> in +<> in `elasticsearch.yml`. [[configuring-slack-actions]] -==== Configuring Slack Actions +==== Configuring Slack actions You configure Slack actions in the `actions` array. Action-specific attributes are specified using the `slack` keyword. @@ -35,7 +35,7 @@ The following snippet shows a simple slack action definition: [[formatting-slack-messages]] -==== Using Attachments to Format Slack Messages +==== Using attachments to format Slack messages In addition to sending simple text-based messages, you can use the Slack https://api.slack.com/docs/attachments[attachment] mechanism to send formatted @@ -139,7 +139,7 @@ aggregation and the Slack action: generated by the transform. [[slack-action-attributes]] -==== Slack Action Attributes +==== Slack action attributes [cols=",^,", options="header"] |====== @@ -167,7 +167,7 @@ aggregation and the Slack action: | `message.dynamic_attachments` | no | Slack message attachments that can be populated dynamically based on the current watch payload. For more information, see - <>. + <>. | `proxy.host` | no | The proxy host to use (only in combination with `proxy.port`) @@ -207,8 +207,8 @@ You can also configure this via settings in the `elasticsearch.yml` file by removing the `secure_` prefix, but using the keystore is the preferred and secure way of doing this. -You can also specify defaults for the {ref}/notification-settings.html#slack-account-attributes[Slack -notification attributes]: +You can also specify defaults for the +<>: [source,yaml] -------------------------------------------------- @@ -230,7 +230,7 @@ xpack.notification.slack: If you configure multiple Slack accounts, you either need to configure a default account or specify which account the notification should be sent with in the -<> action. +<> action. [source,yaml] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/actions/webhook.asciidoc b/x-pack/docs/en/watcher/actions/webhook.asciidoc index 5d6dc4f91fce1..0ab4fe8227564 100644 --- a/x-pack/docs/en/watcher/actions/webhook.asciidoc +++ b/x-pack/docs/en/watcher/actions/webhook.asciidoc @@ -1,13 +1,12 @@ [[actions-webhook]] -=== Webhook Action +=== Webhook action Use the `webhook` action to send a request to any web service. The webhook action supports both HTTP and HTTPS connections. See -<> for the supported -attributes. +<> for the supported attributes. [[configuring-webook-actions]] -==== Configuring Webhook Actions +==== Configuring webhook actions You configure webhook actions in the `actions` array. Action-specific attributes are specified using the `webhook` keyword. @@ -32,9 +31,9 @@ The following snippet shows a simple webhook action definition: -------------------------------------------------- // NOTCONSOLE <1> The id of the action -<2> An optional <> to transform the payload before +<2> An optional <> to transform the payload before executing the `webhook` action -<3> An optional <> for the action +<3> An optional <> for the action (5 minutes in this example) <4> The HTTP method to use when connecting to the host <5> The host to connect to @@ -76,8 +75,9 @@ NOTE: By default, both the username and the password are stored in the `.watches You can also use PKI-based authentication when submitting requests to a cluster that has {es} {security-features} enabled. When you use PKI-based authentication instead of HTTP basic auth, you don't need to store any authentication -information in the watch itself. To use PKI-based authentication, you {ref}/notification-settings.html#ssl-notification-settings -[configure the SSL key settings] for {watcher} in `elasticsearch.yml`. +information in the watch itself. To use PKI-based authentication, you +<> for {watcher} in +`elasticsearch.yml`. [[webhook-query-parameters]] @@ -135,7 +135,7 @@ the values serve as the header values: <1> The header values can contain templated strings. -==== Webhook Action Attributes +==== Webhook action attributes [[webhook-action-attributes]] [cols=",^,^,", options="header"] |====== @@ -148,23 +148,23 @@ the values serve as the header values: | `port` | yes | - | The port the HTTP service is listening on. | `path` | no | - | The URL path. The path can be static text or include Mustache - <>. URL query string parameters must be + <>. URL query string parameters must be specified via the `request.params` attribute. | `method` | no | get | The HTTP method. Valid values are: `head`, `get`, `post`, `put` and `delete`. | `headers` | no | - | The HTTP request headers. The header values can be static text - or include Mustache <>. + or include Mustache <>. | `params` | no | - | The URL query string parameters. The parameter values can be - static text or include Mustache <>. + static text or include Mustache <>. | `auth` | no | - | Authentication related HTTP headers. Currently, only basic authentication is supported. | `body` | no | - | The HTTP request body. The body can be static text or include - Mustache <>. When not specified, an empty + Mustache <>. When not specified, an empty body is sent. | `proxy.host` | no | - | The proxy host to use when connecting to the host. diff --git a/x-pack/docs/en/watcher/condition.asciidoc b/x-pack/docs/en/watcher/condition.asciidoc index 01f55f9b6682a..40d15c8c74ac6 100644 --- a/x-pack/docs/en/watcher/condition.asciidoc +++ b/x-pack/docs/en/watcher/condition.asciidoc @@ -4,29 +4,29 @@ When a watch is triggered, its condition determines whether or not to execute the watch actions. {watcher} supports the following condition types: -* <>: set the watch condition to `true` so the watch +* <>: set the watch condition to `true` so the watch actions are always executed. -* <>: set the watch condition to `false` so the watch +* <>: set the watch condition to `false` so the watch actions are never executed. -* <>: perform simple comparisons against values +* <>: perform simple comparisons against values in the watch payload to determine whether or not to execute the watch actions. -* <>: compare an array of values in the +* <>: compare an array of values in the watch payload to a given value to determine whether or not to execute the watch actions. -* <>: use a script to determine whether or not to +* <>: use a script to determine whether or not to execute the watch actions. NOTE: If you omit the condition definition from a watch, the condition defaults to `always`. When a condition is evaluated, it has full access to the watch execution context, -including the watch payload (`ctx.payload.*`). The <>, -<> and <> +including the watch payload (`ctx.payload.*`). The <>, +<> and <> conditions can use the payload data to determine whether or not the necessary conditions are met. In addition to the watch wide condition, you can also configure conditions -per <>. +per <>. :edit_url: https://github.com/elastic/elasticsearch/edit/{branch}/x-pack/docs/en/watcher/condition/always.asciidoc include::condition/always.asciidoc[] diff --git a/x-pack/docs/en/watcher/condition/always.asciidoc b/x-pack/docs/en/watcher/condition/always.asciidoc index c2eb37be52c8f..81026af092682 100644 --- a/x-pack/docs/en/watcher/condition/always.asciidoc +++ b/x-pack/docs/en/watcher/condition/always.asciidoc @@ -1,14 +1,14 @@ [[condition-always]] -=== Always Condition +=== Always condition Use the `always` condition to set the condition to `true`. This forces the watch -actions to be executed unless they are <>. +actions to be executed unless they are <>. The `always` condition enables you to perform watch actions on a fixed schedule, such as, _"Every Friday at noon, send a status report email to sys.admin@example.com."_ -==== Using the Always Condition +==== Using the always condition This is the default if you omit the condition definition from a watch. diff --git a/x-pack/docs/en/watcher/condition/array-compare.asciidoc b/x-pack/docs/en/watcher/condition/array-compare.asciidoc index e82eaf5384061..fcca9c660a695 100644 --- a/x-pack/docs/en/watcher/condition/array-compare.asciidoc +++ b/x-pack/docs/en/watcher/condition/array-compare.asciidoc @@ -1,19 +1,19 @@ [[condition-array-compare]] -=== Array Compare Condition +=== Array compare condition Use `array_compare` to compare an array of values in the execution context to a -given value. See <> +given value. See <> for the operators you can use. -==== Using an Array Compare Condition +==== Using an array compare condition To use the `array_compare` condition, you specify the array in the execution -context that you want to evaluate, a <>, and the value you want to compare against. Optionally, you -can specify the path to the field in each array element that you want to -evaluate. +context that you want to evaluate, a +<>, and the value you want to +compare against. Optionally, you can specify the path to the field in each array +element that you want to evaluate. For example, the following `array_compare` condition returns `true` if there is at least one bucket in the aggregation that has a `doc_count` greater @@ -38,14 +38,14 @@ than or equal to 25: <1> The path to the array in the execution context that you want to evaluate, specified in dot notation. <2> The path to the field in each array element that you want to evaluate. -<3> The <> to use. +<3> The <> to use. <4> The comparison value. Supports date math like the - <>. + <>. NOTE: When using fieldnames that contain a dot this condition will not work, use a <> instead. -==== Array-Compare Condition Attributes +==== Array-compare condition attributes [options="header"] |====== diff --git a/x-pack/docs/en/watcher/condition/compare.asciidoc b/x-pack/docs/en/watcher/condition/compare.asciidoc index d58638e6fe472..5741732fb014f 100644 --- a/x-pack/docs/en/watcher/condition/compare.asciidoc +++ b/x-pack/docs/en/watcher/condition/compare.asciidoc @@ -1,12 +1,12 @@ [[condition-compare]] -=== Compare Condition +=== Compare condition Use the `compare` condition to perform a simple comparison against a value in the watch payload. You can use the `compare` condition without enabling dynamic scripting. [[condition-compare-operators]] -. Supported Comparison Operators +. Supported comparison operators [options="header"] |====== | Name | Description @@ -30,13 +30,13 @@ dynamic scripting. given one (applies to numeric and string values) |====== -==== Using a Compare Condition +==== Using a compare condition To use the `compare` condition, you specify the value in the execution context that you want to evaluate, a <>, and the value you want to compare against. For example, the following `compare` -condition returns `true` if the number of the total hits in the <> is greater than or equal to 5: +condition returns `true` if the number of the total hits in the +<> is greater than or equal to 5: [source,js] -------------------------------------------------- @@ -89,7 +89,7 @@ to the `ctx.payload.aggregations.handled.buckets.true.doc_count`: -------------------------------------------------- // NOTCONSOLE -==== Accessing Values in the Execution Context +==== Accessing values in the execution context You use "dot-notation" to access values in the execution context. Values loaded into the execution context by the input are prefixed by `ctx.payload`. diff --git a/x-pack/docs/en/watcher/condition/never.asciidoc b/x-pack/docs/en/watcher/condition/never.asciidoc index b8cad0b8c04d5..e7aa2745d75ad 100644 --- a/x-pack/docs/en/watcher/condition/never.asciidoc +++ b/x-pack/docs/en/watcher/condition/never.asciidoc @@ -1,12 +1,12 @@ [[condition-never]] -=== Never Condition +=== Never condition Use the `never` condition to set the condition to `false`. This means the watch actions are never executed when the watch is triggered. The watch input is executed, a record is added to the watch history, and the watch execution ends. This condition is generally used for testing. -==== Using the Never Condition +==== Using the never condition There are no attributes to specify for the `never` condition. To use the it, you specify the condition type and associate it with an empty object: diff --git a/x-pack/docs/en/watcher/condition/script.asciidoc b/x-pack/docs/en/watcher/condition/script.asciidoc index 5e94551a5ef17..a69ae05509fb6 100644 --- a/x-pack/docs/en/watcher/condition/script.asciidoc +++ b/x-pack/docs/en/watcher/condition/script.asciidoc @@ -1,14 +1,13 @@ [[condition-script]] -=== Script Condition +=== Script condition -A watch <> that evaluates a script. The default scripting +A watch <> that evaluates a script. The default scripting language is `painless`. You can use any of the scripting languages supported by Elasticsearch as long as the language supports evaluating expressions to Boolean values. Note that the `mustache` and `expression` languages are too limited to be -used by this condition. For more information, see {ref}/modules-scripting.html[Scripting] -in the Elasticsearch Reference. +used by this condition. For more information, see <>. -==== Using a Script Condition +==== Using a script condition The following snippet configures an inline `script` condition that always returns `true`: @@ -22,11 +21,11 @@ The following snippet configures an inline `script` condition that always return // NOTCONSOLE This example defines a script as a simple string. This format is actually a -shortcut for defining an <> script. The +shortcut for defining an <> script. The formal definition of a script is an object that specifies the script type and optional language and parameter values. If the `lang` attribute is omitted, the language defaults to `painless`. Elasticsearch supports two types of scripts, -<> and <>. +<> and <>. For example, the following snippet shows a formal definition of an `inline` script that explicitly specifies the language and defines a single script @@ -47,7 +46,7 @@ parameter, `result`: // NOTCONSOLE [[condition-script-inline]] -==== Inline Scripts +==== Inline scripts Inline scripts are scripts that are defined in the condition itself. The following snippet shows the formal configuration of a simple painless script that @@ -64,10 +63,11 @@ always returns `true`. // NOTCONSOLE [[condition-script-stored]] -==== Stored Scripts +==== Stored scripts -Stored scripts refer to scripts that were {ref}/modules-scripting-using.html#modules-scripting-stored-scripts[stored] -in Elasticsearch. The following snippet shows how to refer to a script by its `id`: +Stored scripts refer to scripts that were +<> in Elasticsearch. The following +snippet shows how to refer to a script by its `id`: [source,js] -------------------------------------------------- @@ -79,8 +79,8 @@ in Elasticsearch. The following snippet shows how to refer to a script by its `i -------------------------------------------------- // NOTCONSOLE -As with <> -scripts, you can also specify the script language and parameters: +As with <> scripts, you can also specify the +script language and parameters: [source,js] -------------------------------------------------- @@ -95,14 +95,14 @@ scripts, you can also specify the script language and parameters: // NOTCONSOLE [[accessing-watch-payload]] -==== Accessing the Watch Payload +==== Accessing the watch payload A script can access the current watch execution context, including the payload data, as well as any parameters passed in through the condition definition. -For example, the following snippet defines a watch that uses a <> -and uses a `script` condition to check if the number of hits is above a specified -threshold: +For example, the following snippet defines a watch that uses a +<> and uses a `script` condition to check if the +number of hits is above a specified threshold: [source,js] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/customizing-watches.asciidoc b/x-pack/docs/en/watcher/customizing-watches.asciidoc index 34b9c38229f4b..edc88e3e68bff 100644 --- a/x-pack/docs/en/watcher/customizing-watches.asciidoc +++ b/x-pack/docs/en/watcher/customizing-watches.asciidoc @@ -1,29 +1,30 @@ [[customizing-watches]] -== Customizing Watches +== Customizing watches -Now that you've seen how to set up simple watches to <> -and <>, let's take a closer -look at how you can customize a watch by modifying its <>, -<>, <>, and -<>. +Now that you've seen how to set up simple watches to +<> and +<>, let's take a closer +look at how you can customize a watch by modifying its <>, +<>, <>, and +<>. [[changing-inputs]] -=== Changing Inputs +=== Changing inputs The Watch Input is called when the watch triggered to load an initial payload. This payload is stored in the _Watch Execution Context_ and from then on is available for other watch elements to access (e.g. watch conditions can be evaluated based on the data in this payload). -{watcher} supports four types of inputs <>, -<>, <>, and -<>. +{watcher} supports four types of inputs <>, +<>, <>, and +<>. [[loading-static-data]] -==== Loading a Static Payload with the Simple Input +==== Loading a static payload with the simple input To load static data into the watch payload for testing purposes, you can use the -<> input. For example, the following input stores three +<> input. For example, the following input stores three fields in the payload: [source,js] @@ -41,13 +42,13 @@ fields in the payload: See <> for more details. [[loading-search-results]] -==== Loading a Payload from Elasticsearch with the Search Input +==== Loading a payload from Elasticsearch with the search input You can use the `search` input to load Elasticsearch search results as the watch initial payload. -A <> input contains a `request` object that specifies the -indices you want to search, the {ref}/search-request-search-type.html[search type], +A <> input contains a `request` object that specifies the +indices you want to search, the <>, and the search request body. The `body` field of a search input is the same as the body of an Elasticsearch `_search` request, making the full Elaticsearch Query DSL available for you to use. @@ -81,7 +82,7 @@ For example, the following `search` input loads the latest VIX quote: See <> for more details. [[loading-http-data]] -==== Loading a Payload from a remote HTTP Service with HTTP Input +==== Loading a payload from a remote HTTP service with HTTP input Use the `http` input to issue an HTTP request and load the returned response as the watch initial payload. This input expects the response body content type @@ -111,28 +112,28 @@ Amsterdam using http://openweathermap.org/appid[OpenWeatherMap] online service: See <> for more details. [[chaining-inputs]] -==== Chaining Inputs +==== Chaining inputs -You can create an <> to load data from multiple sources +You can create an <> to load data from multiple sources into a watch payload. The inputs in a chain are processed in order, so the the data loaded by one input can be used by subsequent inputs. See <> for more details. [[changing-conditions]] -=== Changing Conditions +=== Changing conditions The Watch Condition is evaluated as part of the watch execution. The condition determines whether the actions associated with the watch should execute or not. -{watcher} supports four types of conditions <>, -<>, <>, and -<>. +{watcher} supports four types of conditions <>, +<>, <>, and +<>. The first two are pretty self-explanatory--they are shortcuts for setting a watch's condition to `true` or `false`. -==== Simple Value Comparison with the Compare Condition +==== Simple value comparison with the compare condition The `compare` condition enables you to perform simple comparisons against values in the Watch payload. While you can also do this with a `script` condition, with @@ -151,7 +152,7 @@ returned any hits: // NOTCONSOLE See <> for more details. -==== Powerful Comparison Logic with the Script Condition +==== Powerful comparison logic with the script condition For more complex conditional logic you can use the `script` condition. The `script` condition accepts a script that when executed returns `true` (indicating @@ -160,7 +161,7 @@ language defaults to the default script language in Elasticsearch, but you can also use any other supported language in the system. NOTE: Starting with 5.0, Elasticsearch is shipped with the new - {ref}/modules-scripting-painless.html[Painless] scripting language. + <> scripting language. Painless was created and designed specifically for use in Elasticsearch. Beyond providing an extensive feature set, its biggest trait is that it's properly sandboxed and safe to use anywhere in the system (including in @@ -182,13 +183,13 @@ VIX quote loaded by the `http` input is either greater than 5% or lower than -5% See <> for more details. [[using-transforms]] -=== Using Transforms +=== Using transforms Transforms are constructs in a watch that can change the current payload associated with the watch execution context. -{watcher} supports three types of transforms <>, -<> and <>. A `search` transform +{watcher} supports three types of transforms <>, +<> and <>. A `search` transform replaces the existing payload with the response of a new search request. You can use `script` transforms to modify the existing payload. A `chain` transform enables you to perform a series of `search` and `script` transforms. @@ -196,19 +197,19 @@ enables you to perform a series of `search` and `script` transforms. See <> for more details. [[customizing-actions]] -=== Customizing Actions +=== Customizing actions Actions are associated with a watch and are executed as part of the watch execution only when the watch condition is met. -{watcher} supports the following action types: <>, -<>, <>, <>, -<>, <>, and <>. +{watcher} supports the following action types: <>, +<>, <>, <>, +<>, <>, and <>. -To use the `email` action, you need to <> +To use the `email` action, you need to <> in `elasticsearch.yml` that {watcher} can use to send email. Your custom email messages can be plain text or styled using HTML. You can include information from -the watch execution payload using <>, as well as attach the +the watch execution payload using <>, as well as attach the entire watch payload to the message. For example, the following email action uses a template in the email body and diff --git a/x-pack/docs/en/watcher/encrypting-data.asciidoc b/x-pack/docs/en/watcher/encrypting-data.asciidoc index 66138b54efba2..8c5e012fa55e7 100644 --- a/x-pack/docs/en/watcher/encrypting-data.asciidoc +++ b/x-pack/docs/en/watcher/encrypting-data.asciidoc @@ -1,5 +1,5 @@ [[encrypting-data]] -== Encrypting Sensitive Data in {watcher} +== Encrypting sensitive data in {watcher} Watches might have access to sensitive data such as HTTP basic authentication information or details about your SMTP email service. You can encrypt this @@ -14,7 +14,7 @@ encrypted. To encrypt sensitive data in {watcher}: -. Use the {ref}/syskeygen.html[elasticsearch-syskeygen] command to create a system key file. +. Use the <> command to create a system key file. . Copy the `system_key` file to all of the nodes in your cluster. + @@ -24,8 +24,7 @@ every node in the cluster. -- -. Set the -{ref}/notification-settings.html[`xpack.watcher.encrypt_sensitive_data` setting]: +. Set the <>: + -- @@ -36,8 +35,8 @@ xpack.watcher.encrypt_sensitive_data: true -- . Set the -{ref}/notification-settings.html[`xpack.watcher.encryption_key` setting] in the -{ref}/secure-settings.html[{es} keystore] on each node in the cluster. +<> in the +<> on each node in the cluster. + -- For example, run the following command to import the `system_key` file on diff --git a/x-pack/docs/en/watcher/example-watches.asciidoc b/x-pack/docs/en/watcher/example-watches.asciidoc index 2a402b20261d7..4f3b0564fd1b0 100644 --- a/x-pack/docs/en/watcher/example-watches.asciidoc +++ b/x-pack/docs/en/watcher/example-watches.asciidoc @@ -1,13 +1,13 @@ [[example-watches]] -== Example Watches +== Example watches The following examples show how to set up watches to: -* <> -* <> +* <> +* <> For more example watches you can use as a starting point for building custom watches, see the https://github.com/elastic/examples/tree/master/Alerting[Example -Watches] in the Elastic Examples repo. +watches] in the Elastic Examples repo. :edit_url: https://github.com/elastic/elasticsearch/edit/{branch}/x-pack/docs/en/watcher/example-watches/example-watch-clusterstatus.asciidoc include::example-watches/example-watch-clusterstatus.asciidoc[] diff --git a/x-pack/docs/en/watcher/example-watches/example-watch-clusterstatus.asciidoc b/x-pack/docs/en/watcher/example-watches/example-watch-clusterstatus.asciidoc index 0add5d99ccd2a..47653a90f63bf 100644 --- a/x-pack/docs/en/watcher/example-watches/example-watch-clusterstatus.asciidoc +++ b/x-pack/docs/en/watcher/example-watches/example-watch-clusterstatus.asciidoc @@ -1,23 +1,23 @@ [[watch-cluster-status]] -=== Watching the Status of an Elasticsearch Cluster +=== Watching the status of an Elasticsearch cluster You can easily configure a basic watch to monitor the health of your Elasticsearch cluster: -* <> that gets the +* <> that gets the cluster health status. -* <> that evaluates the health status to +* <> that evaluates the health status to determine if action is required. -* <> if the cluster is RED. +* <> if the cluster is RED. [float] [[health-add-input]] -==== Schedule the Watch and Add an Input +==== Schedule the watch and add an input -A watch <> controls how often a watch is triggered. -The watch <> gets the data that you want to evaluate. +A watch <> controls how often a watch is triggered. +The watch <> gets the data that you want to evaluate. The simplest way to define a schedule is to specify an interval. For example, the following schedule runs every 10 seconds: @@ -48,7 +48,7 @@ GET _cluster/health?pretty // TEST[continued] To load the health status into your watch, you simply add an -<> that calls the cluster health API: +<> that calls the cluster health API: [source,js] -------------------------------------------------- @@ -70,7 +70,8 @@ PUT _xpack/watcher/watch/cluster_health_watch -------------------------------------------------- // CONSOLE -If you're using Security, then you'll also need to supply some authentication credentials as part of the watch configuration: +If you're using Security, then you'll also need to supply some authentication +credentials as part of the watch configuration: [source,js] -------------------------------------------------- @@ -98,9 +99,12 @@ PUT _xpack/watcher/watch/cluster_health_watch -------------------------------------------------- // CONSOLE -It would be a good idea to create a user with the minimum privileges required for use with such a watch configuration. +It would be a good idea to create a user with the minimum privileges required +for use with such a watch configuration. -Depending on how your cluster is configured, there may be additional settings required before the watch can access your cluster such as keystores, truststores or certificates. For more information, see {ref}/notification-settings.html[Notification Settings]. +Depending on how your cluster is configured, there may be additional settings +required before the watch can access your cluster such as keystores, truststores, +or certificates. For more information, see <>. If you check the watch history, you'll see that the cluster status is recorded @@ -123,9 +127,9 @@ GET .watcher-history*/_search [float] [[health-add-condition]] -==== Add a Condition +==== Add a condition -A <> evaluates the data you've loaded into the watch and +A <> evaluates the data you've loaded into the watch and determines if any action is required. Since you've defined an input that loads the cluster status into the watch, you can define a condition that checks that status. @@ -178,11 +182,11 @@ GET .watcher-history*/_search?pretty [float] [[health-take-action]] -==== Take Action +==== Take action Recording `watch_records` in the watch history is nice, but the real power of {watcher} is being able to do something in response to an alert. A watch's -<> define what to do when the watch condition is true--you +<> define what to do when the watch condition is true--you can send emails, call third-party webhooks, or write documents to an Elasticsearch index or log when the watch condition is met. @@ -251,7 +255,7 @@ xpack.notification.email.account: NOTE: If you have advanced security options enabled for your email account, you need to take additional steps to send email from {watcher}. For more - information, see <>. + information, see <>. You can check the watch history or the `status_index` to see that the action was performed. @@ -270,13 +274,13 @@ GET .watcher-history*/_search?pretty [float] [[health-delete]] -==== Delete the Watch +==== Delete the watch Since the `cluster_health_watch` is configured to run every 10 seconds, make sure you delete it when you're done experimenting. Otherwise, you'll spam yourself indefinitely. -To remove the watch, use the {ref}/watcher-api-delete-watch.html[DELETE watch API]: +To remove the watch, use the <>: [source,js] ------------------------------------------------------- diff --git a/x-pack/docs/en/watcher/example-watches/example-watch-meetupdata.asciidoc b/x-pack/docs/en/watcher/example-watches/example-watch-meetupdata.asciidoc index 082ff77f4a20c..6669bcd1d5c82 100644 --- a/x-pack/docs/en/watcher/example-watches/example-watch-meetupdata.asciidoc +++ b/x-pack/docs/en/watcher/example-watches/example-watch-meetupdata.asciidoc @@ -1,5 +1,5 @@ [[watching-meetup-data]] -=== Watching Event Data +=== Watching event data If you are indexing event data, such as log messages, network traffic, or a web feed, you can create a watch to email notifications when certain events occur. For example, if you index a feed of RSVPs for meetup events happening around the world, you can create a watch that alerts you to interesting events. @@ -188,7 +188,7 @@ To set up the watch: // NOTCONSOLE -- -NOTE: To enable Watcher to send emails, you must configure an email account in `elasticsearch.yml`. For more information, see <>. +NOTE: To enable Watcher to send emails, you must configure an email account in `elasticsearch.yml`. For more information, see <>. The complete watch looks like this: @@ -290,7 +290,7 @@ PUT _xpack/watcher/watch/meetup -------------------------------------------------- // CONSOLE -<1> The email body can include Mustache templates to reference data in the watch payload. By default,it will be <> to block dangerous content. +<1> The email body can include Mustache templates to reference data in the watch payload. By default,it will be <> to block dangerous content. <2> Replace the `from` address with the email address you configured in `elasticsearch.yml`. <3> Replace the `to` address with your email address to receive notifications. diff --git a/x-pack/docs/en/watcher/example-watches/watching-time-series-data.asciidoc b/x-pack/docs/en/watcher/example-watches/watching-time-series-data.asciidoc index c594687382b90..217cd857414f5 100644 --- a/x-pack/docs/en/watcher/example-watches/watching-time-series-data.asciidoc +++ b/x-pack/docs/en/watcher/example-watches/watching-time-series-data.asciidoc @@ -1,5 +1,5 @@ [[watching-time-series-data]] -=== Watching Time Series Data +=== Watching time series data If you are indexing time-series data such as logs, RSS feeds, or network traffic, you can use {watcher} to send notifications when certain events occur. @@ -151,7 +151,7 @@ you can then reference it by name in the watch condition. NOTE: To use the email action, you must configure at least one email account in `elasticsearch.yml`. If you configure multiple email accounts, you need to specify which one you want to send the email with. For more information, see -<>. +<>. The complete watch looks like this: diff --git a/x-pack/docs/en/watcher/getting-started.asciidoc b/x-pack/docs/en/watcher/getting-started.asciidoc index 41eb654bab30c..7f8a3e1e05da7 100644 --- a/x-pack/docs/en/watcher/getting-started.asciidoc +++ b/x-pack/docs/en/watcher/getting-started.asciidoc @@ -3,7 +3,10 @@ By default, when you install {es} and {kib}, {xpack} is installed and the {watcher} is enabled. You cannot use {watcher} with the free basic license, but -you can try all of the {xpack} features with a <>. +you can try all of the {xpack} features with a trial license. For more +information about Elastic license levels, see +https://www.elastic.co/subscriptions and +{stack-ov}/license-management.html[License management] [[watch-log-data]] To set up a watch to start sending alerts: @@ -16,14 +19,14 @@ condition is met. [float] [[log-add-input]] -=== Schedule the Watch and Define an Input +=== Schedule the watch and define an input -A watch {xpack-ref}/trigger-schedule.html[schedule] controls how often a watch is triggered. -The watch {xpack-ref}/input.html[input] gets the data that you want to evaluate. +A watch <> controls how often a watch is triggered. +The watch <> gets the data that you want to evaluate. To periodically search log data and load the results into the -watch, you could use an {xpack-ref}/trigger-schedule.html#schedule-interval[interval] schedule and a -{xpack-ref}/input-search.html[search] input. For example, the following Watch searches +watch, you could use an <> schedule and a +<> input. For example, the following Watch searches the `logs` index for errors every 10 seconds: [source,js] @@ -74,9 +77,9 @@ GET .watcher-history*/_search?pretty [float] [[log-add-condition]] -=== Add a Condition +=== Add a condition -A {xpack-ref}/condition.html[condition] evaluates the data you've loaded into the watch and +A <> evaluates the data you've loaded into the watch and determines if any action is required. Now that you've loaded log errors into the watch, you can define a condition that checks to see if any errors were found. @@ -107,7 +110,7 @@ PUT _xpack/watcher/watch/log_error_watch } -------------------------------------------------- // CONSOLE -<1> The {xpack-ref}/condition-compare.html[compare] condition lets you easily compare against +<1> The <> condition lets you easily compare against values in the execution context. For this compare condition to evaluate to `true`, you need to add an event @@ -151,11 +154,11 @@ GET .watcher-history*/_search?pretty [float] [[log-take-action]] -=== Configure an Action +=== Configure an action Recording watch records in the watch history is nice, but the real power of {watcher} is being able to do something when the watch condition is met. A -watch's {xpack-ref}/actions.html[actions] define what to do when the watch condition +watch's <> define what to do when the watch condition evaluates to `true`. You can send emails, call third-party webhooks, write documents to an Elasticsearch index, or log messages to the standard Elasticsearch log files. @@ -203,7 +206,7 @@ delete it when you're done experimenting. Otherwise, the noise from this sample watch will make it hard to see what else is going on in your watch history and log file. -To remove the watch, use the {ref}/watcher-api-delete-watch.html[DELETE watch API]: +To remove the watch, use the <>: [source,js] -------------------------------------------------- @@ -214,7 +217,7 @@ DELETE _xpack/watcher/watch/log_error_watch [float] [[required-security-privileges]] -=== Required Security Privileges +=== Required security privileges To enable users to create and manipulate watches, assign them the `watcher_admin` security role. Watcher admins can also view watches, watch history, and triggered watches. @@ -225,11 +228,11 @@ allowed to execute read-only watch operations. [float] [[next-steps]] -=== Where to Go Next +=== Where to go next -* See {xpack-ref}/how-watcher-works.html[How {watcher} Works] for more information about the +* See <> for more information about the anatomy of a watch and the watch lifecycle. -* See {xpack-ref}/example-watches.html[Example Watches] for more examples of setting up +* See <> for more examples of setting up a watch. * See the https://github.com/elastic/examples/tree/master/Alerting[Example Watches] in the Elastic Examples repo for additional sample watches you can use diff --git a/x-pack/docs/en/watcher/gs-index.asciidoc b/x-pack/docs/en/watcher/gs-index.asciidoc index e799adec40a34..15de767244a1c 100644 --- a/x-pack/docs/en/watcher/gs-index.asciidoc +++ b/x-pack/docs/en/watcher/gs-index.asciidoc @@ -1,5 +1,5 @@ [[xpack-alerting]] -= Alerting on Cluster and Index Events += Alerting on cluster and index events [partintro] -- diff --git a/x-pack/docs/en/watcher/how-watcher-works.asciidoc b/x-pack/docs/en/watcher/how-watcher-works.asciidoc index 2bd19c1a41e02..6179cb7b03bc0 100644 --- a/x-pack/docs/en/watcher/how-watcher-works.asciidoc +++ b/x-pack/docs/en/watcher/how-watcher-works.asciidoc @@ -1,5 +1,5 @@ [[how-watcher-works]] -== How {watcher} Works +== How {watcher} works You <> to automatically perform an action when certain conditions are met. The conditions are generally based on data you've @@ -15,7 +15,7 @@ This topic describes the elements of a watch and how watches operate. [float] [[watch-definition]] -=== Watch Definition +=== Watch definition A watch consists of a _trigger_, _input_, _condition_, and _actions_. The actions define what needs to be done once the condition is met. In addition, you can @@ -43,7 +43,7 @@ Specify what happens when the watch condition is met. [[watch-definition-example]] For example, the following snippet shows a -{ref}/watcher-api-put-watch.html[Put Watch] request that defines a watch that +<> request that defines a watch that looks for log error events: [source,js] @@ -130,7 +130,7 @@ PUT _xpack/watcher/watch/log_errors [float] [[watch-execution]] -=== Watch Execution +=== Watch execution [[schedule-scheduler]] When you add a watch, {watcher} immediately registers its trigger with the @@ -198,7 +198,7 @@ image::images/watch-execution.jpg[align="center"] [float] [[watch-acknowledgment-throttling]] -=== Watch Acknowledgment and Throttling +=== Watch acknowledgment and throttling {watcher} supports both time-based and acknowledgment-based throttling. This enables you to prevent actions from being repeatedly executed for the same event. @@ -218,7 +218,7 @@ For more information, see <>. [float] [[watch-active-state]] -=== Watch Active State +=== Watch active state By default, when you add a watch it is immediately set to the _active_ state, registered with the appropriate trigger engine, and executed according @@ -228,13 +228,13 @@ You can also set a watch to the _inactive_ state. Inactive watches are not registered with a trigger engine and can never be triggered. To set a watch to the inactive state when you create it, set the -{ref}/watcher-api-put-watch.html[`active`] parameter to _inactive_. To +<> parameter to _inactive_. To deactivate an existing watch, use the -{ref}/watcher-api-deactivate-watch.html[Deactivate Watch API]. To reactivate an +<>. To reactivate an inactive watch, use the -{ref}/watcher-api-activate-watch.html[Activate Watch API]. +<>. -NOTE: You can use the {ref}/watcher-api-execute-watch.html[Execute Watch API] +NOTE: You can use the <> to force the execution of a watch even when it is inactive. Deactivating watches is useful in a variety of situations. For example, if you @@ -247,7 +247,7 @@ deleting it from the system. [float] [[scripts-templates]] -=== Scripts and Templates +=== Scripts and templates You can use scripts and templates when defining a watch. Scripts and templates can reference elements in the watch execution context, including the watch payload. @@ -258,13 +258,12 @@ placeholders in a template. <> and <>. Scripts and templates are compiled and cached by Elasticsearch to optimize recurring execution. Autoloading is also -supported. For more information, see {ref}/modules-scripting.html[Scripting] and -{ref}/modules-scripting-using.html[How to use scripts] in the Elasticsearch -Reference. +supported. For more information, see <> and +<>. [float] [[watch-execution-context]] -==== Watch Execution Context +==== Watch execution context The following snippet shows the basic structure of the _Watch Execution Context_: @@ -298,14 +297,14 @@ The following snippet shows the basic structure of the _Watch Execution Context_ [float] [[scripts]] -==== Using Scripts +==== Using scripts -You can use scripts to define <> and -<>. The default scripting language is -{ref}/modules-scripting-painless.html[Painless]. +You can use scripts to define <> and +<>. The default scripting language is +<>. NOTE: Starting with 5.0, Elasticsearch is shipped with the new - {ref}/modules-scripting-painless.html[Painless] scripting language. + <> scripting language. Painless was created and designed specifically for use in Elasticsearch. Beyond providing an extensive feature set, its biggest trait is that it's properly sandboxed and safe to use anywhere in the system (including in @@ -323,7 +322,7 @@ access its value via the `color` variable. [float] [[templates]] -==== Using Templates +==== Using templates You use templates to define dynamic content for a watch. At execution time, templates pull in data from the watch execution context. For example, you can use @@ -353,7 +352,7 @@ in sent emails: [float] [[inline-templates-scripts]] -===== Inline Templates and Scripts +===== Inline templates and scripts To define an inline template or script, you simply specify it directly in the value of a field. For example, the following snippet configures the subject of @@ -415,9 +414,9 @@ The formal object definition for a script would be: [float] [[stored-templates-scripts]] -===== Stored Templates and Scripts +===== Stored templates and scripts -If you {ref}/modules-scripting-using.html#modules-scripting-stored-scripts[store] +If you <> your templates and scripts, you can reference them by id. To reference a stored script or template, you use the formal object definition diff --git a/x-pack/docs/en/watcher/images/watcher-ui-edit-watch.png b/x-pack/docs/en/watcher/images/watcher-ui-edit-watch.png new file mode 100644 index 0000000000000000000000000000000000000000..f6a3ab4354a214a6cf1af8c37709f454a076888b GIT binary patch literal 250698 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�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­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%0A<>M-VdOfj2a0`eR2w&_| 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

W%DY(va7T+gihk63UsNgX-vqBRV4F1ZEeR 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%0A)64*E%IIzH` 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 literal 0 HcmV?d00001 diff --git a/x-pack/docs/en/watcher/index.asciidoc b/x-pack/docs/en/watcher/index.asciidoc index 2be3638971929..fe006fc3a23ff 100644 --- a/x-pack/docs/en/watcher/index.asciidoc +++ b/x-pack/docs/en/watcher/index.asciidoc @@ -97,3 +97,7 @@ include::managing-watches.asciidoc[] :edit_url: https://github.com/elastic/elasticsearch/edit/{branch}/x-pack/docs/en/watcher/example-watches.asciidoc include::example-watches.asciidoc[] + +include::troubleshooting.asciidoc[] + +include::limitations.asciidoc[] \ No newline at end of file diff --git a/x-pack/docs/en/watcher/input.asciidoc b/x-pack/docs/en/watcher/input.asciidoc index 6dee849c735f9..f248d69644e62 100644 --- a/x-pack/docs/en/watcher/input.asciidoc +++ b/x-pack/docs/en/watcher/input.asciidoc @@ -8,12 +8,12 @@ input. {watcher} supports four input types: -* <>: load static data into the execution context. -* <>: load the results of a search into the execution +* <>: load static data into the execution context. +* <>: load the results of a search into the execution context. -* <>: load the results of an HTTP request into the execution +* <>: load the results of an HTTP request into the execution context. -* <>: use a series of inputs to load data into the +* <>: use a series of inputs to load data into the execution context. NOTE: If you don't define an input for a watch, an empty payload is loaded diff --git a/x-pack/docs/en/watcher/input/chain.asciidoc b/x-pack/docs/en/watcher/input/chain.asciidoc index 9898880a9a760..c6151d3d0ed5b 100644 --- a/x-pack/docs/en/watcher/input/chain.asciidoc +++ b/x-pack/docs/en/watcher/input/chain.asciidoc @@ -1,5 +1,5 @@ [[input-chain]] -=== Chain Input +=== Chain input Use the `chain` input to load data from multiple sources into the watch execution context when the watch is triggered. The inputs in a chain @@ -44,12 +44,13 @@ path set by a `simple` input: arbitrary objects.) <2> Loads the `path` set by the `first` input. -==== Accessing Chained Input Data +==== Accessing chained input data To reference data loaded by a particular input, you use the input's name, `ctx.payload..`. -==== Transforming Chained Input Data +[[_transforming_chained_input_data]] +==== Transforming chained input data In certain use-cases the output of the first input should be used as input in a subsequent input. This requires you to do a transform, before you pass diff --git a/x-pack/docs/en/watcher/input/http.asciidoc b/x-pack/docs/en/watcher/input/http.asciidoc index 79d37d14a1bf4..d6fca8a7ad326 100644 --- a/x-pack/docs/en/watcher/input/http.asciidoc +++ b/x-pack/docs/en/watcher/input/http.asciidoc @@ -1,9 +1,9 @@ [[input-http]] -=== HTTP Input +=== HTTP input Use the `http` input to submit a request to an HTTP endpoint and load the response into the watch execution context when the watch is triggered. See -<> for all of the supported attributes. +<> for all of the supported attributes. With the `http` input, you can: @@ -13,15 +13,14 @@ With the `http` input, you can: need to search clusters that are running different Elasticsearch versions. * Query Elasticsearch APIs other than the search API. For example, you might want - to load data from the {ref}/cluster-nodes-stats.html[Nodes Stats], - {ref}/cluster-health.html[Cluster Health] or {ref}/cluster-state.html[Cluster - State] APIs. + to load data from the <>, + <> or <> APIs. * Query external web services. The `http` input enables you to load data from any service that exposes an HTTP endpoint. This provides a bridge between Elasticsearch clusters and other systems. -==== Querying External Elasticsearch Clusters +==== Querying external Elasticsearch clusters To query an external Elasticsearch cluster, you specify the cluster's `host` and `port` attributes and the index's search endpoint as the `path`. @@ -42,7 +41,7 @@ index: -------------------------------------------------- // NOTCONSOLE -You can use the full Elasticsearch {ref}/query-dsl.html[Query DSL] to perform +You can use the full Elasticsearch <> to perform more sophisticated searches. For example, the following `http` input retrieves all documents that contain `event` in the `category` field: @@ -66,8 +65,7 @@ all documents that contain `event` in the `category` field: To load the data from other Elasticsearch APIs, specify the API endpoint as the `path` attribute. Use the `params` attribute to specify query string parameters. For example, the following `http` input -calls the {ref}/cluster-stats.html[Cluster -Stats] API and enables the `human` attribute: +calls the <> API and enables the `human` attribute: [source,js] -------------------------------------------------- @@ -89,7 +87,7 @@ Stats] API and enables the `human` attribute: readable format. [[input-http-auth-basic-example]] -==== Calling External Web Services +==== Calling external web services You can use `http` input to get data from any external web service. The `http` input supports basic authentication. For example, the following input provides @@ -137,9 +135,9 @@ http://openweathermap.org/appid[OpenWeatherMap] service: -------------------------------------------------- // NOTCONSOLE -==== Using Templates +==== Using templates -The `http` input supports templating. You can use <> when +The `http` input supports templating. You can use <> when specifying the `path`, `body`, header values, and parameter values. For example, the following snippet uses templates to specify what index to query @@ -160,7 +158,7 @@ and restrict the results to documents added within the last five minutes: -------------------------------------------------- // NOTCONSOLE -==== Accessing the HTTP Response +==== Accessing the HTTP response If the response body is formatted in JSON or YAML, it is parsed and loaded into the execution context. If the response body is not formatted in JSON or YAML, it @@ -176,7 +174,7 @@ In addition all the headers from the response can be accessed using the [[http-input-attributes]] -==== HTTP Input Attributes +==== HTTP input attributes [cols=",^,^,", options="header"] |====== @@ -189,17 +187,17 @@ In addition all the headers from the response can be accessed using the | `request.port` | yes | - | The port the http service is listening on. | `request.path` | no | - | The URL path. The path can be static text or contain `mustache` - <>. URL query string parameters must be + <>. URL query string parameters must be specified via the `request.params` attribute. | `request.method` | no | get | The HTTP method. Supported values are: `head`, `get`, `post`, `put` and `delete`. | `request.headers` | no | - | The HTTP request headers. The header values can be static text - or include `mustache` <>. + or include `mustache` <>. | `request.params` | no | - | The URL query string parameters. The parameter values can be - static text or contain `mustache` <>. + static text or contain `mustache` <>. | `request.url` | no | - | Allows you to set `request.scheme`, `request.host`, `request.port` and `request.params` add once by specifying a real URL, like @@ -224,7 +222,7 @@ In addition all the headers from the response can be accessed using the | `request.body` | no | - | The HTTP request body. The body can be static text or include - `mustache` <>. + `mustache` <>. | `extract` | no | - | A array of JSON keys to extract from the input response and use as payload. In cases when an input generates a large diff --git a/x-pack/docs/en/watcher/input/search.asciidoc b/x-pack/docs/en/watcher/input/search.asciidoc index 7ce67bfc1dc2b..57f30ea26544c 100644 --- a/x-pack/docs/en/watcher/input/search.asciidoc +++ b/x-pack/docs/en/watcher/input/search.asciidoc @@ -1,15 +1,14 @@ [[input-search]] -=== Search Input +=== Search input Use the `search` input to load the results of an Elasticsearch search request into the execution context when the watch is triggered. See -<> for all of the -supported attributes. +<> for all of the supported attributes. In the search input's `request` object, you specify: * The indices you want to search -* The {ref}/search-request-search-type.html[search type] +* The <> * The search request body The search request body supports the full Elasticsearch Query DSL--it's the @@ -60,7 +59,7 @@ the following input loads the latest VIXZ quote from today's daily quotes index: -------------------------------------------------- // NOTCONSOLE -==== Extracting Specific Fields +==== Extracting specific fields You can specify which fields in the search response you want to load into the watch payload with the `extract` attribute. This is useful when a search @@ -82,9 +81,9 @@ watch payload: -------------------------------------------------- // NOTCONSOLE -==== Using Templates +==== Using templates -The `search` input supports {ref}/search-template.html[search templates]. For +The `search` input supports <>. For example, the following snippet references the indexed template called `my_template` and passes a value of 23 to fill in the template's `value` parameter: @@ -110,11 +109,11 @@ parameter: -------------------------------------------------- // NOTCONSOLE -==== Applying Conditions +==== Applying conditions -The `search` input is often used in conjunction with the <> condition. For example, the following snippet adds a condition to -check if the search returned more than five hits: +The `search` input is often used in conjunction with the +<> condition. For example, the following snippet adds +a condition to check if the search returned more than five hits: [source,js] -------------------------------------------------- @@ -137,7 +136,7 @@ check if the search returned more than five hits: -------------------------------------------------- // NOTCONSOLE -==== Accessing the Search Results +==== Accessing the search results Conditions, transforms, and actions can access the search results through the watch execution context. For example: @@ -157,7 +156,7 @@ watch execution context. For example: |====== | Name |Required | Default | Description -| `request.search_type` | no | `query_then_fetch` | The {ref}/search-request-search-type.html#search-request-search-type[type] +| `request.search_type` | no | `query_then_fetch` | The <> of search request to perform. Valid values are: `dfs_query_and_fetch`, `dfs_query_then_fetch`, `query_and_fetch`, and `query_then_fetch`. The Elasticsearch default is `query_then_fetch`. @@ -168,21 +167,21 @@ watch execution context. For example: | `request.types` | no | - | The document types to search for. If omitted, all document types are are searched, which is the default behaviour in Elasticsearch. -| `request.body` | no | - | The body of the request. The {ref}/search-request-body.html[request body] +| `request.body` | no | - | The body of the request. The <> follows the same structure you normally send in the body of a REST `_search` - request. The body can be static text or include `mustache` <>. + request. The body can be static text or include `mustache` <>. -| `request.template` | no | - | The body of the search template. See <> +| `request.template` | no | - | The body of the search template. See <> for more information. | `request.indices_options.expand_wildcards` | no | `open` | How to expand wildcards. Valid values are: `all`, `open`, `closed`, and `none` - See {ref}/multi-index.html#multi-index[`expand_wildcards`] for more information. + See <> for more information. | `request.indices_options.ignore_unavailable` | no | `true` | Whether the search should ignore unavailable indices. See - {ref}/multi-index.html#multi-index[`ignore_unavailable`] for more information. + <> for more information. | `request.indices_options.allow_no_indices` | no | `true` | Whether to allow a search where a wildcard indices expression results in no - concrete indices. See {ref}/multi-index.html#multi-index[allow_no_indices] + concrete indices. See <> for more information. | `extract` | no | - | A array of JSON keys to extract from the search response and load as the payload. diff --git a/x-pack/docs/en/watcher/input/simple.asciidoc b/x-pack/docs/en/watcher/input/simple.asciidoc index c756a4e5403e2..0cc9303dfa4a9 100644 --- a/x-pack/docs/en/watcher/input/simple.asciidoc +++ b/x-pack/docs/en/watcher/input/simple.asciidoc @@ -1,5 +1,5 @@ [[input-simple]] -=== Simple Input +=== Simple input Use the `simple` input to load static data into the execution context when the watch is triggered. This enables you to store the data diff --git a/x-pack/docs/en/watcher/java/ack-watch.asciidoc b/x-pack/docs/en/watcher/java/ack-watch.asciidoc index f24f0b89a0e1c..7cef48d6e3373 100644 --- a/x-pack/docs/en/watcher/java/ack-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/ack-watch.asciidoc @@ -1,13 +1,13 @@ [float] [[api-java-ack-watch]] -=== Ack Watch API +=== Ack watch API -<> a watch enables you to manually throttle +<> a watch enables you to manually throttle execution of the watch actions. The action's _acknowledgement state_ is stored in the `status.actions..ack.state` structure. The current status of the watch and the state of its actions are returned as part -of the <> response: +of the <> response: [source,java] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/java/activate-watch.asciidoc b/x-pack/docs/en/watcher/java/activate-watch.asciidoc index 63e88001a4be0..96ea3f5e23d8a 100644 --- a/x-pack/docs/en/watcher/java/activate-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/activate-watch.asciidoc @@ -1,12 +1,12 @@ [float] [[api-java-activate-watch]] -=== Activate Watch API +=== Activate watch API -A watch can be either <>. This API +A watch can be either <>. This API enables you to activate a currently inactive watch. The status of an inactive watch is returned with the watch definition -when you call the <>: +when you call the <>: [source,java] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/java/deactivate-watch.asciidoc b/x-pack/docs/en/watcher/java/deactivate-watch.asciidoc index 325f37bf32587..98c4220e68c88 100644 --- a/x-pack/docs/en/watcher/java/deactivate-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/deactivate-watch.asciidoc @@ -1,12 +1,12 @@ [float] [[api-java-deactivate-watch]] -=== Deactivate Watch API +=== Deactivate watch API -A watch can be either <>. This API +A watch can be either <>. This API enables you to deactivate a currently active watch. The status of an active watch is returned with the watch definition -when you call the <>: +when you call the <>: [source,java] -------------------------------------------------- diff --git a/x-pack/docs/en/watcher/java/delete-watch.asciidoc b/x-pack/docs/en/watcher/java/delete-watch.asciidoc index 4d37b910fd179..a019db933748c 100644 --- a/x-pack/docs/en/watcher/java/delete-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/delete-watch.asciidoc @@ -1,8 +1,8 @@ [float] [[api-java-delete-watch]] -=== Delete Watch API +=== Delete watch API -The DELETE watch API removes a watch (identified by its `id`) from {watcher}. +The delete watch API removes a watch (identified by its `id`) from {watcher}. Once removed, the document representing the watch in the `.watches` index is gone and it will never be executed again. diff --git a/x-pack/docs/en/watcher/java/execute-watch.asciidoc b/x-pack/docs/en/watcher/java/execute-watch.asciidoc index 34f2b8aa1e767..6379c09ed23d6 100644 --- a/x-pack/docs/en/watcher/java/execute-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/execute-watch.asciidoc @@ -1,6 +1,6 @@ [float] [[api-java-execute-watch]] -=== Execute Watch API +=== Execute watch API This API enables on-demand execution of a watch stored in the `.watches` index. It can be used to test a watch without executing all its actions or by ignoring diff --git a/x-pack/docs/en/watcher/java/get-watch.asciidoc b/x-pack/docs/en/watcher/java/get-watch.asciidoc index e4fcd86d85c85..f7a8c92fc20c2 100644 --- a/x-pack/docs/en/watcher/java/get-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/get-watch.asciidoc @@ -1,6 +1,6 @@ [float] [[api-java-get-watch]] -=== Get Watch API +=== Get watch API This API retrieves a watch by its id. diff --git a/x-pack/docs/en/watcher/java/put-watch.asciidoc b/x-pack/docs/en/watcher/java/put-watch.asciidoc index 1ac7b7f4db970..5552830477c15 100644 --- a/x-pack/docs/en/watcher/java/put-watch.asciidoc +++ b/x-pack/docs/en/watcher/java/put-watch.asciidoc @@ -1,8 +1,8 @@ [float] [[api-java-put-watch]] -=== PUT Watch API +=== Put watch API -The PUT watch API either registers a new watch in {watcher} or update an +The put watch API either registers a new watch in {watcher} or update an existing one. Once registered, a new document will be added to the `.watches` index, representing the watch, and the watch trigger will immediately be registered with the relevant trigger engine (typically the scheduler, for the diff --git a/x-pack/docs/en/watcher/limitations.asciidoc b/x-pack/docs/en/watcher/limitations.asciidoc new file mode 100644 index 0000000000000..f22c992327d31 --- /dev/null +++ b/x-pack/docs/en/watcher/limitations.asciidoc @@ -0,0 +1,32 @@ +[role="xpack"] +[[watcher-limitations]] +== Watcher limitations +++++ +Limitations +++++ + +[float] +=== Watches are not updated when file based scripts change + +When you refer to a file script in a watch, the watch itself is not updated +if you change the script on the filesystem. + +Currently, the only way to reload a file script in a watch is to delete +the watch and recreate it. + +[float] +=== Watcher UI + +When you create a new watch or edit an existing watch, if you navigate away +from the page without saving your changes they will be lost without warning. +Make sure to save your changes before leaving the page. + +image::images/watcher-ui-edit-watch.png[Editing a watch in Kibana] + +[float] +=== Security integration + +When the {security-features} are enabled, a watch stores information about what +the user who stored the watch is allowed to execute **at that time**. This means, +if those permissions change over time, the watch will still be able to execute +with the permissions that existed when the watch was created. diff --git a/x-pack/docs/en/watcher/managing-watches.asciidoc b/x-pack/docs/en/watcher/managing-watches.asciidoc index a155132d5e4b1..1d1069c257e7e 100644 --- a/x-pack/docs/en/watcher/managing-watches.asciidoc +++ b/x-pack/docs/en/watcher/managing-watches.asciidoc @@ -1,18 +1,18 @@ [[managing-watches]] -== Managing Watches +== Managing watches {watcher} provides as set of APIs you can use to manage your watches: -* Use the {ref}/watcher-api-put-watch.html[Put Watch API] to add or update watches -* Use the {ref}/watcher-api-get-watch.html[Get Watch API] to retrieve watches -* Use the {ref}/watcher-api-delete-watch.html[Delete Watch API] to delete watches -* Use the {ref}/watcher-api-activate-watch.html[Activate Watch API] to activate watches -* Use the {ref}/watcher-api-deactivate-watch.html[Deactivate Watch API] to deactivate watches -* Use the {ref}/watcher-api-ack-watch.html[Ack Watch API] to acknowledge watches +* Use the <> to add or update watches +* Use the <> to retrieve watches +* Use the <> to delete watches +* Use the <> to activate watches +* Use the <> to deactivate watches +* Use the <> to acknowledge watches [float] [[listing-watches]] -=== Listing Watches +=== Listing watches Currently there is not dedicated API for listing the stored watches. However, since {watcher} stores its watches in the `.watches` index, you can list them diff --git a/x-pack/docs/en/watcher/release-notes.asciidoc b/x-pack/docs/en/watcher/release-notes.asciidoc index 627c45829d3e2..a5678c0abc292 100644 --- a/x-pack/docs/en/watcher/release-notes.asciidoc +++ b/x-pack/docs/en/watcher/release-notes.asciidoc @@ -119,9 +119,9 @@ March 30, 2016 {ref}/watcher-api-execute-watch.html[Execute Watch API] .New Features -* Added <> -* Added support for adding <> - via HTTP requests and superceding and deprecating the usage of `attach_data` +* Added <> +* Added support for adding <> + via HTTP requests and superseding and deprecating the usage of `attach_data` in order to use this feature [float] @@ -157,7 +157,7 @@ December 17, 2015 November 24, 2015 .New Features -* Adds support for <> +* Adds support for <> .Enhancements * Adds support for Elasticsearch 2.1.0. @@ -204,13 +204,13 @@ October 28, 2015 use the following index name ``. .New Features -* Added new <> -* Added new <> -* Watches now have an <>. In addition, a new +* Added new <> +* Added new <> +* Watches now have an <>. In addition, a new API was added to {ref}/watcher-api-activate-watch.html[activate] /{ref}watcher-api-deactivate-watch.html[deactivate] registered watches. -* Added new <>, that can compare an array - of values in the <> +* Added new <>, that can compare an array + of values in the <> to a given value. .Enhancements @@ -273,40 +273,40 @@ June 25, 2015 June 19, 2015 .New Features -* Added <> support to the Execute API +* Added <> support to the Execute API .Enhancements -* Added execution context <> support. -* Email html body sanitization is now <>. +* Added execution context <> support. +* Email html body sanitization is now <>. * It is now possible to configure timeouts for http requests in - <> and <>. + <> and <>. [float] ==== 1.0.0-Beta2 June 10, 2015 .New Features -* <> are now applied at the action +* <> are now applied at the action level rather than the watch level. -* Added support for <> +* Added support for <> indexing to the index action. -* Added a queued watches metric that's accessible via the <>. +* Added a queued watches metric that's accessible via the <>. * Added a currently-executing watches metric that's accessible via the - <>. + <>. .Enhancements -* The <> result now includes the value of +* The <> result now includes the value of each field that was referenced in the comparison. -* The <> now supports a default trigger +* The <> now supports a default trigger event (**breaking change**). * The `watch_record` document structure in the `.watch_history-*` indices has changed significantly (**breaking change**). * A new internal index was introduced - `.triggered_watches` -* Added support for headers in the <> result - and the <> result. -* Add plain text response body support for the <>. +* Added support for headers in the <> result + and the <> result. +* Add plain text response body support for the <>. .Bug Fixes -* Disallow negative time value settings for <> -* Added support for separate keystore and truststore in <> - and <>. +* Disallow negative time value settings for <> +* Added support for separate keystore and truststore in <> + and <>. diff --git a/x-pack/docs/en/watcher/transform.asciidoc b/x-pack/docs/en/watcher/transform.asciidoc index 8241d7b0cb442..eb180969b1f46 100644 --- a/x-pack/docs/en/watcher/transform.asciidoc +++ b/x-pack/docs/en/watcher/transform.asciidoc @@ -1,10 +1,10 @@ [[transform]] == Transforms -A _Transform_ processes and changes the payload in the watch execution context +A _transform_ processes and changes the payload in the watch execution context to prepare it for the watch actions. {watcher} supports three types of -transforms: <>, -<> and <>. +transforms: <>, +<> and <>. NOTE: Transforms are optional. When none are defined, the actions have access to diff --git a/x-pack/docs/en/watcher/transform/chain.asciidoc b/x-pack/docs/en/watcher/transform/chain.asciidoc index 9ad27fe48ed81..b50d47e15562f 100644 --- a/x-pack/docs/en/watcher/transform/chain.asciidoc +++ b/x-pack/docs/en/watcher/transform/chain.asciidoc @@ -1,15 +1,15 @@ [[transform-chain]] -=== Chain Transform +=== Chain transform -A <> that executes an ordered list of configured transforms +A <> that executes an ordered list of configured transforms in a chain, where the output of one transform serves as the input of the next transform in the chain. The payload that is accepted by this transform serves as the input of the first transform in the chain and the output of the last transform in the chain is the output of the `chain` transform as a whole. You can use chain transforms to build more complex transforms out of the other -available transforms. For example, you can combine a <> -transform and a <> transform, as shown in the +available transforms. For example, you can combine a <> +transform and a <> transform, as shown in the following snippet: [source,js] diff --git a/x-pack/docs/en/watcher/transform/script.asciidoc b/x-pack/docs/en/watcher/transform/script.asciidoc index 9a1377eb5eab7..0a5dd1d579642 100644 --- a/x-pack/docs/en/watcher/transform/script.asciidoc +++ b/x-pack/docs/en/watcher/transform/script.asciidoc @@ -1,14 +1,14 @@ [[transform-script]] -=== Script Transform +=== Script transform -A <> that executes a script on the current payload in the +A <> that executes a script on the current payload in the watch execution context and replaces it with a newly generated one. The following snippet shows how a simple script transform can be defined on the watch level: TIP: The `script` transform is often useful when used in combination with the - <> transform, where the script can extract only + <> transform, where the script can extract only the significant data from a search result, and by that, keep the payload - minimal. This can be achieved with the <> + minimal. This can be achieved with the <> transform. @@ -32,13 +32,13 @@ NOTE: The executed script may either return a valid model that is the equivalent The `script` attribute may hold a string value in which case it will be treated as an inline script and the default elasticsearch script languages will be assumed -(as described in {ref}/modules-scripting.html#modules-scripting[here]). You can +(as described in <>). You can use the other scripting languages supported by Elasticsearch. For this, you need to set the `script` field to an object describing the script and its language. The following table lists the possible settings that can be configured: [[transform-script-settings]] -.Script Transform Settings +.Script transform settings [options="header"] |====== | Name |Required | Default | Description @@ -59,5 +59,5 @@ When using the object notation of the script, one (and only one) of `inline`, or `id` fields must be defined. NOTE: In addition to the provided `params`, the scripts also have access to the - <>. + <>. diff --git a/x-pack/docs/en/watcher/transform/search.asciidoc b/x-pack/docs/en/watcher/transform/search.asciidoc index 56f9304d986ce..4025d0fb45acb 100644 --- a/x-pack/docs/en/watcher/transform/search.asciidoc +++ b/x-pack/docs/en/watcher/transform/search.asciidoc @@ -1,7 +1,7 @@ [[transform-search]] -=== Search Transform +=== Search transform -A <> that executes a search on the cluster and replaces +A <> that executes a search on the cluster and replaces the current payload in the watch execution context with the returned search response. The following snippet shows how a simple search transform can be defined on the watch level: @@ -47,12 +47,12 @@ execute a search over all events indices, matching events with `error` priority: The following table lists all available settings for the search transform: [[transform-search-settings]] -.Search Transform Settings +.Search transform settings [cols=",^,,", options="header"] |====== | Name |Required | Default | Description -| `request.search_type` | no | query_then_fetch | The search {ref}/search-request-search-type.html[type]. +| `request.search_type` | no | query_then_fetch | The search <>. | `request.indices` | no | all indices | One or more indices to search on. @@ -61,25 +61,25 @@ The following table lists all available settings for the search transform: names) | `request.body` | no | `match_all` query | The body of the request. The - {ref}/search-request-body.html[request body] follows + <> follows the same structure you normally send in the body of a REST `_search` request. The body can be static text - or include `mustache` <>. + or include `mustache` <>. | `request.indices_options.expand_wildcards` | no | `open` | Determines how to expand indices wildcards. Can be one of `open`, `closed`, `none` or `all` - (see {ref}/multi-index.html[multi-index support]) + (see <>) | `request.indices_options.ignore_unavailable` | no | `true` | A boolean value that determines whether the search should leniently ignore unavailable indices - (see {ref}/multi-index.html[multi-index support]) + (see <>) | `request.indices_options.allow_no_indices` | no | `true` | A boolean value that determines whether the search should leniently return no results when no indices - are resolved (see {ref}/multi-index.html[multi-index support]) + are resolved (see <>) | `request.template` | no | - | The body of the search template. See - <> for more information. + <> for more information. | `timeout` | no | 30s | The timeout for waiting for the search api call to return. If no response is returned within this time, @@ -88,11 +88,11 @@ The following table lists all available settings for the search transform: |====== [[transform-search-template]] -==== Template Support +==== Template support The search transform support mustache <>. This can either be as part of the body definition, or alternatively, point to an existing -template (either defined in a file or {ref}/search-template.html#pre-registered-templates[registered] +template (either defined in a file or <> as a script in Elasticsearch). For example, the following snippet shows a search that refers to the scheduled @@ -134,7 +134,7 @@ time of the watch: // NOTCONSOLE The model of the template is a union between the provided `template.params` -settings and the <>. +settings and the <>. The following is an example of using templates that refer to provided parameters: diff --git a/x-pack/docs/en/watcher/trigger.asciidoc b/x-pack/docs/en/watcher/trigger.asciidoc index af830e829a45e..1a7aca77f68cd 100644 --- a/x-pack/docs/en/watcher/trigger.asciidoc +++ b/x-pack/docs/en/watcher/trigger.asciidoc @@ -7,7 +7,7 @@ appropriate _Trigger Engine_. The trigger engine is responsible for evaluating the trigger and triggering the watch when needed. {watcher} is designed to support different types of triggers, but only time-based -<> triggers are currently available. +<> triggers are currently available. :edit_url: https://github.com/elastic/elasticsearch/edit/{branch}/x-pack/docs/en/watcher/trigger/schedule.asciidoc include::trigger/schedule.asciidoc[] diff --git a/x-pack/docs/en/watcher/trigger/schedule.asciidoc b/x-pack/docs/en/watcher/trigger/schedule.asciidoc index abbc3f5cfe8e5..7300756803321 100644 --- a/x-pack/docs/en/watcher/trigger/schedule.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule.asciidoc @@ -1,7 +1,7 @@ [[trigger-schedule]] -=== Schedule Trigger +=== Schedule trigger -Schedule <> define when the watch execution should start based +Schedule <> define when the watch execution should start based on date and time. All times are specified in UTC time. {watcher} uses the system clock to determine the current time. To ensure schedules @@ -14,7 +14,7 @@ that's more frequent than the throttle period, the throttle period overrides the schedule. For example, if you set the throttle period to one minute (60000 ms) and set the schedule to every 10 seconds, the watch is executed no more than once per minute. For more information about throttling, see -<>. +<>. {watcher} provides several types of schedule triggers: diff --git a/x-pack/docs/en/watcher/trigger/schedule/cron.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/cron.asciidoc index 57a6ebdfd92ef..d19a6fda500a8 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/cron.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/cron.asciidoc @@ -1,7 +1,7 @@ [[schedule-cron]] ==== `cron` Schedule -A <> trigger that enables you to use a +A <> trigger that enables you to use a https://en.wikipedia.org/wiki/Cron[cron] style expression to specify when you want the scheduler to start the watch execution. {watcher} uses the cron parser from the http://www.quartz-scheduler.org[Quartz Job Scheduler]. For more @@ -12,10 +12,10 @@ WARNING: While `cron` triggers are super powerful, we recommend using one of the other schedule types if you can, as they are much more straightforward to configure. If you use `cron`, construct your `cron` expressions with care to be sure you are actually setting the schedule - you want. You can use the <> tool to validate + you want. You can use the <> tool to validate your cron expressions and see what the resulting trigger times will be. -===== Cron Expressions +===== Cron expressions A cron expression is a string of the following form: @@ -28,7 +28,7 @@ All elements are required except for `year`. <> shows the valid values for each element in a cron expression. [[schedule-cron-elements]] -.Cron Expression Elements +.Cron expression elements [cols=",^,,", options="header"] |====== | Name | Required | Valid Values | Valid Special Characters @@ -49,7 +49,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or `day_of_month`. Explicitly specifying both values is not supported. [[schedule-cron-special-characters]] -.Cron Special Characters +.Cron special characters [options="header"] |====== | Special Character | Description @@ -116,7 +116,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or |====== -.Setting Daily Triggers +.Setting daily triggers [options="header"] |====== | Cron Expression | Description @@ -124,7 +124,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or | `0 5 9 * * ? 2015` | Trigger at 9:05 AM every day during the year 2015. |====== -.Restricting Triggers to a Range of Days or Times +.Restricting triggers to a range of days or times [options="header"] |====== | Cron Expression | Description @@ -133,7 +133,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or at 9:05 AM every day. |====== -.Setting Interval Triggers +.Setting interval triggers [options="header"] |====== | Cron Expression | Description @@ -143,7 +143,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or on the first day of the month. |====== -.Setting Schedules that Trigger on a Particular Day +.Setting schedules that trigger on a particular day [options="header"] |====== | Cron Expression | Description @@ -156,7 +156,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or | `0 5 9 ? * 6#1` | Trigger at 9:05 AM on the first Friday of every month. |====== -.Setting Triggers Using Last +.Setting triggers using last [options="header"] |====== | Cron Expression | Description @@ -166,7 +166,7 @@ NOTE: Currently, you must specify `?` for either the `day_of_week` or |====== -===== Configuring a Cron Schedule +===== Configuring a cron schedule To configure a `cron` schedule, you simply specify the cron expression as a string value. For example, the following snippet configures a `cron` schedule @@ -186,7 +186,7 @@ that triggers every day at noon: -------------------------------------------------- // NOTCONSOLE -===== Configuring a Multiple Times Cron Schedule +===== Configuring a multiple times cron schedule To configure a `cron` schedule that triggers multiple times, you can specify an array of cron expressions. For example, the following `cron` diff --git a/x-pack/docs/en/watcher/trigger/schedule/daily.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/daily.asciidoc index e729335d59b29..c380edf066860 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/daily.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/daily.asciidoc @@ -1,18 +1,18 @@ [[schedule-daily]] -==== Daily Schedule +==== Daily schedule -A <> that triggers at a particular time +A <> that triggers at a particular time every day. To use the `daily` schedule, you specify the time of day (or times) when you want the scheduler to start the watch execution with the `at` attribute. Times are specified in the form `HH:mm` on a 24-hour clock. You can also use the reserved values `midnight` and `noon` for `00:00` and `12:00`, and -<>. +<>. NOTE: If you don't specify the `at` attribute for a `daily` schedule, it defaults to firing once daily at midnight, `00:00`. -===== Configuring a Daily Schedule +===== Configuring a daily schedule To configure a once a day schedule, you specify a single time with the `at` attribute. For example, the following `daily` schedule triggers once every @@ -30,7 +30,7 @@ day at 5:00 PM: -------------------------------------------------- // NOTCONSOLE -===== Configuring a Multiple Times Daily Schedule +===== Configuring a multiple times daily schedule To configure a `daily` schedule that triggers at multiple times during the day, you specify an array of times. For example, the following `daily` schedule @@ -49,7 +49,7 @@ triggers at `00:00`, `12:00`, and `17:00` every day. // NOTCONSOLE [[specifying-times-using-objects]] -===== Specifying Times Using Objects +===== Specifying times using objects In addition to using the `HH:mm` string syntax to specify times, you can specify a time as an object that has `hour` and `minute` attributes. diff --git a/x-pack/docs/en/watcher/trigger/schedule/hourly.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/hourly.asciidoc index 9ec750eebcd2b..9b5a09b0fff5d 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/hourly.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/hourly.asciidoc @@ -1,7 +1,7 @@ [[schedule-hourly]] -==== Hourly Schedule +==== Hourly schedule -A <> that triggers at a particular minute every +A <> that triggers at a particular minute every hour of the day. To use the `hourly` schedule, you specify the minute (or minutes) when you want the scheduler to start the watch execution with the `minute` attribute. @@ -10,7 +10,7 @@ NOTE: If you don't specify the `minute` attribute for an `hourly` schedule, it defaults to `0` and the schedule triggers on the hour every hour--`12:00`, `13:00`, `14:00`, and so on. -===== Configuring a Once an Hour Schedule +===== Configuring a once an hour schedule To configure a once an hour schedule, you specify a single time with the `minute` attribute. @@ -30,7 +30,7 @@ For example, the following `hourly` schedule triggers at minute 30 every hour-- -------------------------------------------------- // NOTCONSOLE -===== Configuring a Multiple Times Hourly Schedule +===== Configuring a multiple times hourly schedule To configure an `hourly` schedule that triggers at multiple times during the hour, you specify an array of minutes. For example, the following schedule diff --git a/x-pack/docs/en/watcher/trigger/schedule/interval.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/interval.asciidoc index e534181ec0c2f..1b86d166455c2 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/interval.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/interval.asciidoc @@ -1,7 +1,7 @@ [[schedule-interval]] -==== Interval Schedule +==== Interval schedule -A <> that triggers at a fixed time interval. The +A <> that triggers at a fixed time interval. The interval can be set in seconds, minutes, hours, days, or weeks: * `"Xs"` - trigger every `X` seconds. For example, `"30s"` means every 30 seconds. @@ -16,7 +16,7 @@ NOTE: The interval value differs from the standard _time value_ used in Elasticsearch. You cannot configure intervals in milliseconds or nanoseconds. -===== Configuring an Interval Schedule +===== Configuring an interval schedule To configure an `interval` schedule, you specify a string value that represents the interval. If you omit the unit of time (`s`,`m`, `h`, `d`, or `w`), it diff --git a/x-pack/docs/en/watcher/trigger/schedule/monthly.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/monthly.asciidoc index d2cfe409992a7..97e5e63da3d0c 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/monthly.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/monthly.asciidoc @@ -1,7 +1,7 @@ [[schedule-monthly]] -==== Monthly Schedule +==== Monthly schedule -A <> that triggers at a specific day and time +A <> that triggers at a specific day and time every month. To use the `monthly` schedule, you specify the day of the month and time (or days and times) when you want the scheduler to start the watch execution with the `on` and `at` attributes. @@ -10,7 +10,7 @@ You specify the day of month as a numeric value between `1` and `31` (inclusive) Times are specified in the form `HH:mm` on a 24-hour clock. You can also use the reserved values `midnight` and `noon` for `00:00` and `12:00`. -===== Configuring a Monthly Schedule +===== Configuring a monthly schedule To configure a once a month schedule, you specify a single day and time with the `on` and `at` attributes. For example, the following `monthly` schedule triggers @@ -31,7 +31,7 @@ on the 10th of each month at noon: NOTE: You can also specify the day and time with the `day` and `time` attributes, they are interchangeable with `on` and `at`. -===== Configuring a Multiple Times Monthly Schedule +===== Configuring a multiple times monthly schedule To configure a `monthly` schedule that triggers multiple times a month, you can specify an array of day and time values. For example, the following `monthly` diff --git a/x-pack/docs/en/watcher/trigger/schedule/weekly.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/weekly.asciidoc index d6a403cb125c6..283089a8d5398 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/weekly.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/weekly.asciidoc @@ -1,7 +1,7 @@ [[schedule-weekly]] -==== Weekly Schedule +==== Weekly schedule -A <> that triggers at a specific day and time +A <> that triggers at a specific day and time every week. To use the `weekly` schedule, you specify the day and time (or days and times) when you want the scheduler to start the watch execution with the `on` and `at` attributes. @@ -16,7 +16,7 @@ being the first day of the week): Times are specified in the form `HH:mm` on a 24-hour clock. You can also use the reserved values `midnight` and `noon` for `00:00` and `12:00`. -===== Configuring a Weekly Schedule +===== Configuring a weekly schedule To configure a once a week schedule, you specify the day with the `on` attribute and the time with the `at` attribute. For example, the following `weekly` schedule @@ -37,7 +37,7 @@ triggers once a week on Friday at 5:00 PM: NOTE: You can also specify the day and time with the `day` and `time` attributes, they are interchangeable with `on` and `at`. -===== Configuring a Multiple Times Weekly Schedule +===== Configuring a multiple times weekly schedule To configure a `weekly` schedule that triggers multiple times a week, you can specify an array of day and time values. For example, the following `weekly` diff --git a/x-pack/docs/en/watcher/trigger/schedule/yearly.asciidoc b/x-pack/docs/en/watcher/trigger/schedule/yearly.asciidoc index d11cc5d072787..c6240e1bb958c 100644 --- a/x-pack/docs/en/watcher/trigger/schedule/yearly.asciidoc +++ b/x-pack/docs/en/watcher/trigger/schedule/yearly.asciidoc @@ -1,7 +1,7 @@ [[schedule-yearly]] -==== Yearly Schedule +==== Yearly schedule -A <> that triggers at a specific day and time +A <> that triggers at a specific day and time every year. To use the `yearly` schedule, you specify the month, day, and time (or months, days, and times) when you want the scheduler to start the watch execution with the `in`, `on`, and `at` attributes. @@ -20,7 +20,7 @@ You specify the day of month as a numeric value between `1` and `31` (inclusive) The Times are specified in the form `HH:mm` on a 24-hour clock. You can also use the reserved values `midnight` and `noon` for `00:00` and `12:00`. -===== Configuring a Yearly Schedule +===== Configuring a yearly schedule To configure a once a year schedule, you specify the month with the `in` attribute, the day with the `on` attribute, and the time with the `at` attribute. For @@ -42,7 +42,7 @@ example, the following `yearly` schedule triggers once a year at noon on January NOTE: You can also specify the month, day, and time with the `month`, `day`, and `time` attributes, they are interchangeable with `in`, `on`, and `at`. -===== Configuring a Multiple Times Yearly Schedule +===== Configuring a multiple times yearly schedule To configure a `yearly` schedule that triggers multiple times a year, you can specify an array of month, day, and time values. For example, the following diff --git a/x-pack/docs/en/watcher/troubleshooting.asciidoc b/x-pack/docs/en/watcher/troubleshooting.asciidoc new file mode 100644 index 0000000000000..5ddc108e6a2fc --- /dev/null +++ b/x-pack/docs/en/watcher/troubleshooting.asciidoc @@ -0,0 +1,66 @@ +[role="xpack"] +[testenv="gold"] +[[watcher-troubleshooting]] +== Troubleshooting {watcher} +++++ +Troubleshooting +++++ + +[float] +=== Dynamic mapping error when trying to add a watch + +If you get the _Dynamic Mapping is Disabled_ error when you try to add a watch, +verify that the index mappings for the `.watches` index are available. You can +do that by submitting the following request: + +[source,js] +-------------------------------------------------- +GET .watches/_mapping +-------------------------------------------------- +// CONSOLE +// TEST[setup:my_active_watch] + +If the index mappings are missing, follow these steps to restore the correct +mappings: + +. Stop the Elasticsearch node. +. Add `xpack.watcher.index.rest.direct_access : true` to `elasticsearch.yml`. +. Restart the Elasticsearch node. +. Delete the `.watches` index: ++ +-- +[source,js] +-------------------------------------------------- +DELETE .watches +-------------------------------------------------- +// CONSOLE +// TEST[skip:index deletion] +-- +. Disable direct access to the `.watches` index: +.. Stop the Elasticsearch node. +.. Remove `xpack.watcher.index.rest.direct_access : true` from `elasticsearch.yml`. +.. Restart the Elasticsearch node. + +[float] +=== Unable to send email + +If you get an authentication error indicating that you need to continue the +sign-in process from a web browser when Watcher attempts to send email, you need +to configure Gmail to +https://support.google.com/accounts/answer/6010255?hl=en[Allow Less Secure Apps to access your account]. + +If you have two-step verification enabled for your email account, you must +generate and use an App Specific password to send email from {watcher}. For more +information, see: + +- Gmail: https://support.google.com/accounts/answer/185833?hl=en[Sign in using App Passwords] +- Outlook.com: http://windows.microsoft.com/en-us/windows/app-passwords-two-step-verification[App passwords and two-step verification] + +[float] +=== {watcher} not responsive + +Keep in mind that there's no built-in validation of scripts that you add to a +watch. Buggy or deliberately malicious scripts can negatively impact {watcher} +performance. For example, if you add multiple watches with buggy script +conditions in a short period of time, {watcher} might be temporarily unable to +process watches until the bad watches time out.