Resources »

Packages »

Mention Bot

Introduction

This package adds a new bot (Mention Bot) that automatically sends an email notification to a worker when they’re @mentioned in a comment.

Importing the package

Navigate to Setup » Configure » Import Package.

Paste the following package into the large text box:



{
  "package": {
    "name": "Mention Bot",
    "cerb_version": "8.0.4",
    "revision": 1,
    "requires": {
      "cerb_version": "8.0.0",
      "plugins": [

      ]
    },
    "configure": {
      "prompts": [

      ],
      "placeholders": [

      ]
    }
  },
  "bots": [
    {
      "uid": "bot_29",
      "name": "Mention Bot",
      "owner": {
        "context": "cerberusweb.contexts.app",
        "id": 0
      },
      "is_disabled": false,
      "params": {
        "config": null,
        "events": {
          "mode": "allow",
          "items": [
            "event.macro.worker",
            "event.record.changed"
          ]
        },
        "actions": {
          "mode": "allow",
          "items": [

          ]
        }
      },
      "image": "",
      "behaviors": [
        {
          "uid": "behavior_168",
          "title": "Relay new @mention notifications to worker email",
          "is_disabled": false,
          "is_private": false,
          "priority": 50,
          "event": {
            "key": "event.record.changed",
            "label": "Record changed",
            "params": {
              "context": "cerberusweb.contexts.notification"
            }
          },
          "variables": {
            "var_comment": {
              "key": "var_comment",
              "label": "Comment",
              "type": "ctx_cerberusweb.contexts.comment",
              "is_private": "1",
              "params": [

              ]
            }
          },
          "nodes": [
            {
              "type": "switch",
              "title": "Is a new comment notification?",
              "status": "live",
              "nodes": [
                {
                  "type": "outcome",
                  "title": "Yes",
                  "status": "live",
                  "params": {
                    "groups": [
                      {
                        "any": 0,
                        "conditions": [
                          {
                            "condition": "old_notification_activity_point",
                            "oper": "is",
                            "value": ""
                          },
                          {
                            "condition": "notification_activity_point",
                            "oper": "is",
                            "value": "comment.create"
                          }
                        ]
                      }
                    ]
                  },
                  "nodes": [
                    {
                      "type": "action",
                      "title": "Load comment",
                      "status": "live",
                      "params": {
                        "actions": [
                          {
                            "action": "_set_custom_var",
                            "value": "{% set ctx_url = json_decode(notification_event_json)['urls']['common.commented'] %}\r\n{% set ctx_id = ctx_url|split(':')[2] %}\r\n{{ctx_id}}",
                            "format": "",
                            "is_simulator_only": "0",
                            "var": "comment_id"
                          },
                          {
                            "action": "var_comment",
                            "search_mode": "quick_search",
                            "quick_search": "id:[{{comment_id|round}}]",
                            "limit": "first",
                            "limit_count": "1",
                            "mode": "replace",
                            "worklist_model": null
                          }
                        ]
                      }
                    },
                    {
                      "type": "switch",
                      "title": "Mentions this worker?",
                      "status": "live",
                      "nodes": [
                        {
                          "type": "outcome",
                          "title": "Yes",
                          "status": "live",
                          "params": {
                            "groups": [
                              {
                                "any": 0,
                                "conditions": [
                                  {
                                    "condition": "_custom_script",
                                    "tpl": "{% set comment = var_comment|first %}\r\n{% set mention = \"@\"~notification_assignee_at_mention_name %}\r\n{% if mention in comment.comment %}true{% endif %}",
                                    "oper": "is",
                                    "value": "true"
                                  }
                                ]
                              }
                            ]
                          },
                          "nodes": [
                            {
                              "type": "action",
                              "title": "Relay to worker email",
                              "status": "live",
                              "params": {
                                "actions": [
                                  {
                                    "action": "_run_behavior",
                                    "on": "notification_assignee_id",
                                    "behavior_id": "{{{uid.behavior_169}}}",
                                    "var_subject": "New @mention in Cerb",
                                    "var_body": "{% set comment = var_comment|first %}\r\n{{notification_message}}:\r\n{{comment.comment}}\r\n\r\n{{notification_url_markread}}",
                                    "run_in_simulator": "0",
                                    "var": "_behavior"
                                  }
                                ]
                              }
                            }
                          ]
                        }
                      ]
                    }
                  ]
                }
              ]
            }
          ]
        },
        {
          "uid": "behavior_169",
          "title": "Send email to worker",
          "is_disabled": false,
          "is_private": true,
          "priority": 50,
          "event": {
            "key": "event.macro.worker",
            "label": "Custom behavior on worker"
          },
          "variables": {
            "var_subject": {
              "key": "var_subject",
              "label": "Subject",
              "type": "S",
              "is_private": "0",
              "params": {
                "widget": "single"
              }
            },
            "var_body": {
              "key": "var_body",
              "label": "Body",
              "type": "S",
              "is_private": "0",
              "params": {
                "widget": "multiple"
              }
            }
          },
          "nodes": [
            {
              "type": "action",
              "title": "Send email",
              "status": "live",
              "params": {
                "actions": [
                  {
                    "action": "send_email",
                    "from_address_id": "0",
                    "to": "{{worker_address_address}}",
                    "cc": "",
                    "bcc": "",
                    "subject": "{{var_subject}}",
                    "html_template_id": "",
                    "format": "",
                    "content": "{{var_body}}",
                    "headers": ""
                  }
                ]
              }
            }
          ]
        }
      ]
    }
  ]
}


Customizing the behavior

Click on the Mention Bot bubble:

Click the Behaviors button.

Click on Relay new @mention notifications to worker email.

Click on the Relay to worker email node and select Edit from the menu.

Modify the Subject: and Body: of the notification to suit your needs.

Click the Save & Close button.