Adding conditions to Watcher actions

Adding conditions to Watcher actions

When a watch is triggered, its condition determines whether or not to execute the watch actions. Within each action, you can also add a condition per action. These additional conditions enable a single alert to execute different actions depending on a their respective conditions. The following watch would always send an email, when hits are found from the input search, but only trigger the notify_pager action when there are more than 5 hits in the search result.

  1. resp = client.watcher.put_watch(
  2. id="log_event_watch",
  3. trigger={
  4. "schedule": {
  5. "interval": "5m"
  6. }
  7. },
  8. input={
  9. "search": {
  10. "request": {
  11. "indices": "log-events",
  12. "body": {
  13. "size": 0,
  14. "query": {
  15. "match": {
  16. "status": "error"
  17. }
  18. }
  19. }
  20. }
  21. }
  22. },
  23. condition={
  24. "compare": {
  25. "ctx.payload.hits.total": {
  26. "gt": 0
  27. }
  28. }
  29. },
  30. actions={
  31. "email_administrator": {
  32. "email": {
  33. "to": "sys.admino@host.domain",
  34. "subject": "Encountered {{ctx.payload.hits.total}} errors",
  35. "body": "Too many error in the system, see attached data",
  36. "attachments": {
  37. "attached_data": {
  38. "data": {
  39. "format": "json"
  40. }
  41. }
  42. },
  43. "priority": "high"
  44. }
  45. },
  46. "notify_pager": {
  47. "condition": {
  48. "compare": {
  49. "ctx.payload.hits.total": {
  50. "gt": 5
  51. }
  52. }
  53. },
  54. "webhook": {
  55. "method": "POST",
  56. "host": "pager.service.domain",
  57. "port": 1234,
  58. "path": "/{{watch_id}}",
  59. "body": "Encountered {{ctx.payload.hits.total}} errors"
  60. }
  61. }
  62. },
  63. )
  64. print(resp)
  1. const response = await client.watcher.putWatch({
  2. id: "log_event_watch",
  3. trigger: {
  4. schedule: {
  5. interval: "5m",
  6. },
  7. },
  8. input: {
  9. search: {
  10. request: {
  11. indices: "log-events",
  12. body: {
  13. size: 0,
  14. query: {
  15. match: {
  16. status: "error",
  17. },
  18. },
  19. },
  20. },
  21. },
  22. },
  23. condition: {
  24. compare: {
  25. "ctx.payload.hits.total": {
  26. gt: 0,
  27. },
  28. },
  29. },
  30. actions: {
  31. email_administrator: {
  32. email: {
  33. to: "sys.admino@host.domain",
  34. subject: "Encountered {{ctx.payload.hits.total}} errors",
  35. body: "Too many error in the system, see attached data",
  36. attachments: {
  37. attached_data: {
  38. data: {
  39. format: "json",
  40. },
  41. },
  42. },
  43. priority: "high",
  44. },
  45. },
  46. notify_pager: {
  47. condition: {
  48. compare: {
  49. "ctx.payload.hits.total": {
  50. gt: 5,
  51. },
  52. },
  53. },
  54. webhook: {
  55. method: "POST",
  56. host: "pager.service.domain",
  57. port: 1234,
  58. path: "/{{watch_id}}",
  59. body: "Encountered {{ctx.payload.hits.total}} errors",
  60. },
  61. },
  62. },
  63. });
  64. console.log(response);
  1. PUT _watcher/watch/log_event_watch
  2. {
  3. "trigger" : {
  4. "schedule" : { "interval" : "5m" }
  5. },
  6. "input" : {
  7. "search" : {
  8. "request" : {
  9. "indices" : "log-events",
  10. "body" : {
  11. "size" : 0,
  12. "query" : { "match" : { "status" : "error" } }
  13. }
  14. }
  15. }
  16. },
  17. "condition" : {
  18. "compare" : { "ctx.payload.hits.total" : { "gt" : 0 } }
  19. },
  20. "actions" : {
  21. "email_administrator" : {
  22. "email" : {
  23. "to" : "sys.admino@host.domain",
  24. "subject" : "Encountered {{ctx.payload.hits.total}} errors",
  25. "body" : "Too many error in the system, see attached data",
  26. "attachments" : {
  27. "attached_data" : {
  28. "data" : {
  29. "format" : "json"
  30. }
  31. }
  32. },
  33. "priority" : "high"
  34. }
  35. },
  36. "notify_pager" : {
  37. "condition": {
  38. "compare" : { "ctx.payload.hits.total" : { "gt" : 5 } }
  39. },
  40. "webhook" : {
  41. "method" : "POST",
  42. "host" : "pager.service.domain",
  43. "port" : 1234,
  44. "path" : "/{{watch_id}}",
  45. "body" : "Encountered {{ctx.payload.hits.total}} errors"
  46. }
  47. }
  48. }
  49. }

A condition that only applies to the notify_pager action, which restricts its execution to when the condition succeeds (at least 5 hits in this case).