 Mark Oudsen
		
	
	
		624ce29a39
		
	
	
	
	v2.15 - Fixed issues found in Zabbix 5.4.12 and refactored Javascript for better error handling
			Mark Oudsen
		
	
	
		624ce29a39
		
	
	
	
	v2.15 - Fixed issues found in Zabbix 5.4.12 and refactored Javascript for better error handling
		
	
Introduction
Over the years I've been using Zabbix as both personal and business solution for monitoring. One of the missing features in Zabbix itself was the ability to have graphs generated and associated to monitoring messages as well as an easy way to jump back into Zabbix when searching for monitoring information for specific events, problems or to have a direct link to the associated Zabbix item or host.
This initiated the development of mailGraph v1 in Zabbix 5.4 delivering an elementary solution for sending HTML enriched messages from Zabbix including graphs. To facilitate in a very flexible way to setup and format messages including the graphs, Twig made its introduction towards mailGraph v2, the current release branch of mailGraph.
The below message is just an example of what MailGraph is capable of. The template engine in Twig allows for a fully customized message creation to your needs! It is also possible to add more Zabbix fields as any field is passed to Twig when accessible in Zabbix through the macro mechanism. Example: {ITEM.ID}.
Note that all Zabbix host, item or screen related information is made available to Twig automatically.
Example message:
mailGraph is capable of adding several series of graphs into a single message delivering a unique experience when and how groups of graph images per the requested periods of time are added. Currently mailGraph supports hosts, (one or more related) items and screens (applicable to Zabbix 5.4 only).
More information can be found in the Wiki.
Installation
Please refer to the Wiki how to get mailGraph installed and configured on your system.
mailGraph v2.15 release
(2023/08/16)
This version has been verified with Zabbix 5.4 and 6.0 LTS and is expected to work with 6.4 and later (based on v2.10 testing)
Release notes
- Fixed new error condition found in Zabbix 5.4.12 where zeroed or blank parameters for a webhook are no longer added as parameters in the Javascript.
- Refactored error handling inside the Javascript to distinguish automatically between 'email ID response' or a debug or warning level message (this prevents the code of throwing an unknown error like 'Invalid JSON').
mailGraph v2.14 release
(2023/07/10)
This version has been verified with Zabbix 5.4 and 6.0 LTS and is expected to work with 6.4 and later (based on v2.10 testing)
Release notes
- Adding the ability to define FROM details for the emails generated by mailGraph
- smtp_from_addressto set the from mail address (if not set uses mailing system default). Note: obsolete- mail_frombut retained for backwards compatibility.
- smtp_from_nameto set the name that goes with the mail address (if not set uses "mailGraph").
 
- Adding the ability to define REPLY_TO details for the emails generated by mailGraph
- smtp_reply_addressto set the reply-to mail address (if not set, no reply-to will be added to the message).
- smtp_reply_nameto set the reply-to name of the mailbox (if not set defaults to "mailGraph feedback").
 
- Adding a new URL for use in the template:
- ACK_URLpoints to the function in Zabbix for editing and submitting an Acknowledge statement.
 
mailGraph v2.13 release
(2023/07/03)
This version has been verified with Zabbix 5.4 and 6.0 LTS and is expected to work with 6.4 and later (based on v2.10 testing)
Release notes
- Fixed references into Zabbix
- Trigger was missing "context" parameter
- Item was missing "context" parameter
- Problems reference to this host was not generated at all
 
mailGraph v2.12 release
(2023/07/02)
This version has been verified with Zabbix 5.4 and 6.0 LTS and is expected to work with 6.4 and later (based on v2.10 testing)
Release notes
- Replaced Swiftmailer with PHPMailer
- Configuration option "smtp_transport" removed (using PHPMailer AutoTLS)
- Code cleanup (markup and obsolete related parts)
- Addressed any PHP message (deprecation or error) - mailGraph debug output is now "clean" in PHP 7.4.x and PHP 8.2.x
- Increased maximum number of graphs from 4 to 8
Please consider to move to PHPMailer as soon as possible as Swiftmailer is abandoned. Installation instructions are included on the wiki.
Principal approach: composer require phpmailer/phpmailer, install mailGraph v2.12 or higher.
In case Swiftmailer is no longer used elsewhere you can consider to remove this package with swiftmailer/swiftmailer.
mailGraph v2.11 release
(2023/07/01)
This version has been verified with Zabbix 5.4 and 6.0 LTS and is expected to work with 6.4 and later (based on v2.10 testing)
Release notes
- Added pre- and postchecking of variables to the Zabbix javascript - this will prevent the 'invalid JSON' messages and provide better feedback for errors
- When testing MailGraph it is now possible to set the eventId to zero - a random problem will be picked up via the API
- Zabbix Media Type XML reverted back to version 5.4 (for backwards compatibility)
Modified files
- mailGraph.php
- mailGraph.xml
- javascript/zabbix.mailGraph.js
For those upgrading to the latest release without installing the media type:
- copy new mailGraph.php over existing mailGraph.php
- open the Media type MailGraph in Zabbix and edit the javascript -- replace the script contents with the contents of javascript/zabbix.mailGraph.js
Changes are in effect immediately, no need to restart any services.
mailGraph v2.10 release
(2023/06/30)
This version has been verified with Zabbix 5.4, 6.0 LTS and 6.4, PHP 7.4 and 8.2 and recent versions of libraries used via composer.
Minor updates to the mailGraph code
- When not defining zabbix_api_user and zabbix_api_pwd in the configuration file the zbx_user and zbx_user_pwd wll be used
Zabbix 6.4.x testing
(2023/06/30)
Zabbix 6.4 verification has succesfully completed.
- Refactored code to remove deprecated and removed functions since Zabbix 6.4.0 -- Zabbix Javascript now using HttpRequest instead of CurlHttpRequest (function name changes implemented) -- Zabbix API user.login is now based on "username" (instead of "user")
Sidenotes
- Zabbix logging still shows deprecation messages however it is believed these are internal to Zabbix and not related to mailGraph
(2023/06/29)
Zabbix 6.4.x verification is in progress. Required intermediate release to fix one major issue (Zabbix login parameters deprecation) and some minor coding updates. Expect to continue with automatic configuration within the next 2 months.
Special thank you
I would like to express my gratitude to the following people that have actively contributed to bring bugs and improvements to my attention:
IMPORTANT NOTE for users of mailGraph v1 and Zabbix versions under 5.4
As a result of a major functional change in Zabbix 5.4 (Screens no longer exist and are all moved into Dashboards) the mailGraph.screen macro no longer functions under Zabbix 5.4+. A code rewrite is in progress to deal with detecting the Zabbix version and to pick dashboard.get instead of screen.get as a source list for the graphs that should be included in the mail message.
v1.x is no longer supported; please upgrade to the current v2 release
