Airbrake

Monitoring

Airbyte

Monitoring

Prometheus Alertmanager

Monitoring

Ansible Tower

Deployment

AppFollow

Customer support

AppVeyor

Continuous integration

Asana

Project management

Assembla

Version control

AzureDevOps

Version control

Basecamp

Project management

Beanstalk

Version control

Beeminder

Miscellaneous

BigBlueButton

Communication

Bitbucket

(Enterprise)

Version control

Bitbucket

Version control

Bitbucket Server

Version control

Bonusly

Human resources

Buildbot

Continuous integration

Thinkst Canarytokens

Monitoring

Capistrano

Deployment

Chartbeat

Marketing

CircleCI

Continuous integration

Clubhouse

Project management

Codebase

Version control

Codeship

Continuous integration

Crashlytics

Monitoring

Dark Sky

Miscellaneous

Delighted

Customer support

Desk.com

Customer support

Dialogflow

Customer support

Discourse

Communication

Dropbox

Productivity

Email

Communication

Errbit

Monitoring

Errbot

Integration frameworks

Flock

Customer support

Freshdesk

Customer support

Freshping

Monitoring

Freshstatus

Monitoring

Front

Customer support

GIPHY

Miscellaneous

Git

Version control

Gitea

Version control

GitHub

Version control

GitHub Actions

Continuous integration

GitHub Detail Bot

Version control

GitHub Sponsors

Financial

GitLab

Version control

GoCD

Continuous integration

Gogs

Version control

Google Calendar

Productivity

Google Translate

Miscellaneous

GoSquared

Marketing

Grafana

Monitoring

Greenhouse

Human resources

Groove

Customer support

Harbor

Deployment

HelloSign

Productivity

Hello World

Miscellaneous

Heroku

Deployment

Home Assistant

Miscellaneous

Hubot

Integration frameworks

IFTTT

Integration frameworks

Insping

Monitoring

Instagram

Miscellaneous

Intercom

Customer support

IRC

Communication

Jenkins

Continuous integration

Jira

Project management

Jira

(locally installed)

Project management

Jitsi Meet

Communication

Jotform

Miscellaneous

JSON formatter

Miscellaneous

Librato

Monitoring

Lidarr

Entertainment

Linear

Project management

Mailchimp

Communication

Mastodon

Communication

Matrix

Communication

Mention

Marketing

Mercurial (hg)

Version control

Nagios

Monitoring

Netlify

Continuous integration

New Relic

Monitoring

Notion

Productivity

Open Collective

Financial

OpenShift

Deployment

Opsgenie

Integration frameworks

PagerDuty

Monitoring

Papertrail

Monitoring

Patreon

Financial

Perforce

Version control

Phabricator

Version control

Pingdom

Monitoring

Pivotal Tracker

Project management

Puppet

Deployment

Radarr

Entertainment

Raygun

Monitoring

Redmine

Project management

Review Board

Version control

RhodeCode

Version control

RSS

Communication

Rundeck

Deployment

Semaphore

Continuous integration

Sentry

Monitoring

Slack

Communication

Slack-compatible webhook

Communication

SonarQube

Continuous integration

Sonarr

Entertainment

Splunk

Monitoring

Statuspage

Customer support

Stripe

Financial

Subversion

Version control

Taiga

Project management

Teamcity

Continuous integration

Thinkst

Monitoring

Trac

Project management

Transifex

Miscellaneous

Travis CI

Continuous integration

Trello

Project management

Twitter

Customer support

Updown

Monitoring

UptimeRobot

Monitoring

Wekan

Productivity

WordPress

Marketing

xkcd Bot

Interactive bots

YouTube

Miscellaneous

Zabbix

Monitoring

Zapier

Integration frameworks

Zendesk

Customer support

Zoom

Communication


Don't see an integration you need? We'd love to help.

Create your own or Request an integration
Back to list

Zabbix

Monitoring

Zulip Zabbix integration

Receive Zabbix notifications in Zulip!

Note: This guide is for Zabbix 5.4 and above; some older Zabbix versions have a different workflow for creating an outgoing webhook.

  1. Create a bot for Zabbix. Make sure that you select Incoming webhook as the Bot type.

  2. Decide where to send Zabbix notifications, and generate the integration URL.

  3. Go to Administration in your Zabbix web interface. Click on General, and select Macros from the dropdown. Click Add.

  4. Set the macro to {$ZABBIX_URL}. Set the value as the URL to your Zabbix server, e.g., https://zabbix.example.com, and ensure that there are no trailing slashes. Click Update.

  5. Go back to Administration in your Zabbix web interface. Select Media Types, and click Create Media Type.

  6. Set Name to a name of your choice, such as Zulip. Set Type to Webhook, and add the following Parameters:

    • hostname: {HOST.NAME}
    • item: {ITEM.NAME1} is {ITEM.VALUE1}
    • link: {$ZABBIX_URL}/tr_events.php?triggerid={TRIGGER.ID}&eventid={EVENT.ID}
    • severity: {TRIGGER.SEVERITY}
    • status: {TRIGGER.STATUS}
    • trigger: {TRIGGER.NAME}
    • zulip_endpoint: the URL generated above
  7. Click the Pencil to edit the script, and replace any existing content with the script below. Then, check the Enabled option.

     try {
        Zabbix.Log(4, 'zulip webhook script value='+value);
    
        var result = {
           'tags': {
                 'endpoint': 'zulip'
           }
        },
        params = JSON.parse(value),
        req = new HttpRequest(),
        payload = {},
        resp;
    
        req.addHeader('Content-Type: application/json');
    
        payload.hostname = params.hostname;
        payload.severity = params.severity;
        payload.status = params.status;
        payload.item = params.item;
        payload.trigger = params.trigger;
        payload.link = params.link;
        resp = req.post(params.zulip_endpoint,
           JSON.stringify(payload))
    
        if (req.getStatus() != 200) {
           throw 'Response code: '+req.getStatus();
        }
    
        resp = JSON.parse(resp);
        result.tags.issue_id = resp.id;
        result.tags.issue_key = resp.key;
     } catch (error) {
        Zabbix.Log(4, 'zulip issue creation failed json : '+JSON.stringify(payload));
        Zabbix.Log(4, 'zulip issue creation failed : '+error);
    
        result = {};
     }
    
     return JSON.stringify(result);
    
  8. Open Message Templates from the top bar. Click Add under Message Type, and select Problem.

  9. Set Subject to {TRIGGER.STATUS}-{TRIGGER.SEVERITY}-{TRIGGER.NAME}. Set Message to the following, and click Add:

     {
        "hostname": "{HOST.NAME}",
        "severity": "{TRIGGER.SEVERITY}",
        "status": "{TRIGGER.STATUS}",
        "item": "{ITEM.NAME1} is {ITEM.VALUE1}",
        "trigger": "{TRIGGER.NAME}",
        "link": "{$ZABBIX_URL}/tr_events.php?triggerid={TRIGGER.ID}&eventid={EVENT.ID}"
     }
    
  10. Go back to Administration in your Zabbix web interface. Click on Users, and select the alias of the user you would like to use to set the notification. Select Media, and click Add.

  11. Set Type to the name you assigned to the media type above. Set Send To to Zulip or any text, as this field requires text, but it isn't used. Set the severity and active periods for notifications as suitable, and check the Enabled option. Click Add, and select Update.

  12. Go back to your Zabbix web interface, and click Configuration. Select Actions, and choose Create Action.

  13. Set Name to a name of your choice, such as Zulip. Under New Conditions, add the conditions for triggering a notification. Check the Enabled option, and click Operations.

  14. Under Operations, click Add, and then set Operation Type to Send Message. Under Send to Users, choose Add, and select the user you added the alert to above, and click Select. Under Send only to, select Zulip or the name of your media type. Click Add twice.

You're done! Your Zabbix notifications may look like this:

Logos are trademarks of their respective owners. None of the integrations on this page are created by, affiliated with, or supported by the companies represented by the logos.