mirror of
https://github.com/moudsen/mailGraph
synced 2025-10-28 16:17:39 +01:00
Compare commits
33 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
e80a2a56a3 | ||
|
|
4b28d3f066 | ||
|
|
93535d4006 | ||
|
|
b9622da72f | ||
|
|
56fb68ae9c | ||
|
|
fa51c3e59e | ||
|
|
4ae62b3a1f | ||
|
|
0731b87d44 | ||
|
|
bdf4b05a6b | ||
|
|
df16444665 | ||
|
|
bccd134523 | ||
|
|
27c1d64511 | ||
|
|
8597658670 | ||
|
|
b7e2062486 | ||
|
|
2955ffc404 | ||
|
|
2976a4af9c | ||
|
|
2882367308 | ||
|
|
8b4885038a | ||
|
|
f541719fbe | ||
|
|
9edab245d8 | ||
|
|
341bd561ab | ||
|
|
e2f657f3dd | ||
|
|
82a8fe4121 | ||
|
|
bee76b63c0 | ||
|
|
ba0d474bdb | ||
|
|
a5a0f0ace1 | ||
|
|
8655d4ca2c | ||
|
|
76321be3f8 | ||
|
|
9d4f00ce87 | ||
|
|
1278d43acb | ||
|
|
18c22abf17 | ||
|
|
0a623f3137 | ||
|
|
634134b423 |
25
README.md
25
README.md
@@ -1,10 +1,25 @@
|
|||||||
## mailGraph (v1.26)
|
## Zabbix 6.4.x testing ##
|
||||||
Zabbix Media module and scripts for sending e-mail alerts with graphs.
|
_(2023/06/29)_
|
||||||
|
|
||||||
**Please use the Wiki for information on how to install, configure and use MailGraph in Zabbix.**
|
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.
|
||||||
|
|
||||||
## Upgrade notes
|
## Zabbix 6.2.x testing ##
|
||||||
Per v1.25 and higher the template data provisioning and code has fundamentally changed. If you upgrade from an earlier version as v1.25, make sure you understand the changes in templates/html.template (now making use of arrays for lists of items).
|
_(2022/10/10)_
|
||||||
|
|
||||||
|
Testing completed. No immediate issues found.
|
||||||
|
|
||||||
|
_(2022/08/22)_
|
||||||
|
|
||||||
|
Zabbix 6.2.x testing is in progress. Once completed the next effort will be to deliver on automatic configuration detection and automatic updates.
|
||||||
|
|
||||||
|
## IMPORTANT NOTE ##
|
||||||
|
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**
|
||||||
|
**Please use the Wiki for information on how to install, configure and use MailGraph in Zabbix**
|
||||||
|
|
||||||
## Example message
|
## Example message
|
||||||
|
The below message is just an example of what MailGraph is capable of. The template engine ("Twig") allows for a fully customized message creation to your needs! It is also possible to add more Zabbix fields. If you need additional fields just raise an issue ticket and ask and I'll see what I can do.
|
||||||
|
|
||||||
[](images/Example-mail-message-v122.png)
|
[](images/Example-mail-message-v122.png)
|
||||||
|
|||||||
@@ -27,7 +27,7 @@
|
|||||||
$content = file_get_contents($argv[1]);
|
$content = file_get_contents($argv[1]);
|
||||||
$data = json_decode($content,TRUE);
|
$data = json_decode($content,TRUE);
|
||||||
|
|
||||||
if ($data==NULL)
|
if (($data==NULL) && (sizeof($content)>2))
|
||||||
{
|
{
|
||||||
echo 'Invalid JSON format in config file?!'.$cCRLF;
|
echo 'Invalid JSON format in config file?!'.$cCRLF;
|
||||||
die;
|
die;
|
||||||
|
|||||||
BIN
images/Example-Zabbix-MediaType-Config.png
Normal file
BIN
images/Example-Zabbix-MediaType-Config.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 85 KiB |
7
javascript/READ.ME
Normal file
7
javascript/READ.ME
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
As per the details captured in issue #32 the javascript code portion of this Media Type has changed due to a platform/library change at Zabbix side.
|
||||||
|
A distinction is now made for the following Zabbix versions:
|
||||||
|
|
||||||
|
Zabbix <6.2 - use "zabbix.mailGraph.js"
|
||||||
|
Zabbix >=6.2 - <coming soon>
|
||||||
|
|
||||||
|
Please make sure you install the right javascript in your environment!
|
||||||
441
mailGraph.php
441
mailGraph.php
@@ -33,6 +33,17 @@
|
|||||||
// 1.25 2021/03/16 - Mark Oudsen - Refactoring for optimized flow and relevant data retrieval
|
// 1.25 2021/03/16 - Mark Oudsen - Refactoring for optimized flow and relevant data retrieval
|
||||||
// 1.26 2021/03/19 - Mark Oudsen - Bugfixes after refactor (wrong itemId and incorrect eventValue)
|
// 1.26 2021/03/19 - Mark Oudsen - Bugfixes after refactor (wrong itemId and incorrect eventValue)
|
||||||
// Suppressing Zabbix username-password in log
|
// Suppressing Zabbix username-password in log
|
||||||
|
// 1.27 2021/03/19 - Mark Oudsen - Added ability to define "mailGraph.screen" tag to embed graphs from
|
||||||
|
// Added PHP informational and warnings to log for easier debug/spotting
|
||||||
|
// 1.28 2021/03/24 - Mark Oudsen - Added ability to specify username/password for TLS/SSL
|
||||||
|
// 1.29 2021/04/03 - Mark Oudsen - Bugfix due to stricter JSONRPC version check since Zabbix 5.0.10
|
||||||
|
// 2021/07/05 - Mark Oudsen - Minor detail added: CLI debug mode now also outputs version
|
||||||
|
// 2021/07/07 - Mark Oudsen - Fixed HTTPProxy typo in code (instead of HTTPPRoxy)
|
||||||
|
// ------------------------------------------------------------------------------------------------------
|
||||||
|
// 2.00 2021/12/16 - Mark Oudsen - itemId not always provisioned by Zabbix
|
||||||
|
// Several fixes on warning - several small bug fixes
|
||||||
|
// 2.01 2021/12/16 - Mark Oudsen - Screens are no longer available - reverting to using Dashboards now
|
||||||
|
// 2.02 2022/01/30 - Mark Oudsen - Added cleanup routine for old logs and images
|
||||||
// ------------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------------
|
||||||
//
|
//
|
||||||
// (C) M.J.Oudsen, mark.oudsen@puzzl.nl
|
// (C) M.J.Oudsen, mark.oudsen@puzzl.nl
|
||||||
@@ -54,18 +65,22 @@
|
|||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// CONSTANTS
|
// CONSTANTS
|
||||||
|
$cVersion = 'v2.020';
|
||||||
$cVersion = 'v1.26';
|
|
||||||
$cCRLF = chr(10).chr(13);
|
$cCRLF = chr(10).chr(13);
|
||||||
$maskDateTime = 'Y-m-d H:i:s';
|
$maskDateTime = 'Y-m-d H:i:s';
|
||||||
|
$maxGraphs = 4;
|
||||||
|
|
||||||
// DEBUG SETTINGS
|
// DEBUG SETTINGS
|
||||||
// -- Should be FALSE for production level use
|
// -- Should be FALSE for production level use
|
||||||
|
|
||||||
$cDebug = FALSE; // Extended debug logging mode
|
$cDebug = TRUE; // Extended debug logging mode
|
||||||
$cDebugMail = FALSE; // If TRUE, includes log in the mail message (html and plain text attachments)
|
$cDebugMail = FALSE; // If TRUE, includes log in the mail message (html and plain text attachments)
|
||||||
$showLog = FALSE; // Display the log - !!! only use in combination with CLI mode !!!
|
$showLog = FALSE; // Display the log - !!! only use in combination with CLI mode !!!
|
||||||
|
|
||||||
|
// Limit server level output errors
|
||||||
|
|
||||||
|
error_reporting(E_ERROR | E_PARSE);
|
||||||
|
|
||||||
// INCLUDE REQUIRED LIBRARIES (Composer)
|
// INCLUDE REQUIRED LIBRARIES (Composer)
|
||||||
// (configure at same location as the script is running or load in your own central library)
|
// (configure at same location as the script is running or load in your own central library)
|
||||||
// -- swiftmailer/swiftmailer https://swiftmailer.symfony.com/docs/introduction.html
|
// -- swiftmailer/swiftmailer https://swiftmailer.symfony.com/docs/introduction.html
|
||||||
@@ -95,23 +110,24 @@
|
|||||||
$ch = curl_init();
|
$ch = curl_init();
|
||||||
|
|
||||||
// Set options
|
// Set options
|
||||||
curl_setopt($ch, CURLOPT_USERAGENT, 'Zabbix-mailGraph - '.$cVersion);
|
|
||||||
|
|
||||||
if ((isset($HTTPProxy)) && ($HTTPProxy!=''))
|
if ((isset($HTTPProxy)) && ($HTTPProxy!=''))
|
||||||
{
|
{
|
||||||
_log('% Using proxy: '.$HTTPProxy);
|
if ($cDebug) { _log('% Using proxy: '.$HTTPProxy); }
|
||||||
curl_setopt($ch, CURLOPT_PROXY, $HTTPProxy);
|
curl_setopt($ch, CURLOPT_PROXY, $HTTPProxy);
|
||||||
}
|
}
|
||||||
|
|
||||||
curl_setopt($ch, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
|
curl_setopt($ch, CURLOPT_IPRESOLVE, CURL_IPRESOLVE_V4);
|
||||||
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
|
|
||||||
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 20);
|
curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 20);
|
||||||
|
|
||||||
|
curl_setopt($ch, CURLOPT_POST, TRUE);
|
||||||
|
curl_setopt($ch, CURLOPT_POSTFIELDS, json_encode($data));
|
||||||
|
|
||||||
curl_setopt($ch, CURLOPT_URL, $url);
|
curl_setopt($ch, CURLOPT_URL, $url);
|
||||||
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type:application/json'));
|
curl_setopt($ch, CURLOPT_HTTPHEADER, array('Content-Type:application/json'));
|
||||||
curl_setopt($ch, CURLOPT_POST, TRUE);
|
curl_setopt($ch, CURLOPT_RETURNTRANSFER, TRUE);
|
||||||
curl_setopt($ch, CURLOPT_POSTFIELDS,
|
|
||||||
json_encode($data,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
curl_setopt($ch, CURLOPT_USERAGENT, 'Zabbix-mailGraph - '.$cVersion);
|
||||||
|
|
||||||
// Execute Curl
|
// Execute Curl
|
||||||
$data = curl_exec($ch);
|
$data = curl_exec($ch);
|
||||||
@@ -120,9 +136,10 @@
|
|||||||
{
|
{
|
||||||
_log('! Failed: '.curl_error($ch));
|
_log('! Failed: '.curl_error($ch));
|
||||||
|
|
||||||
$data = 'An error occurred while retreiving the requested page.'.$cCRLF;
|
$data = array();
|
||||||
$data .= 'Requested page = '.$url.$cCRLF;
|
$data[] = 'An error occurred while retreiving the requested page.';
|
||||||
$data .= 'Error = '.curl_error($ch).$cCRLF;
|
$data[] .= 'Requested page = '.$url;
|
||||||
|
$data[] .= 'Error = '.curl_error($ch);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
@@ -268,6 +285,22 @@
|
|||||||
if ($showLog) { echo $logString.$cCRLF; }
|
if ($showLog) { echo $logString.$cCRLF; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Catch PHP warnings/notices/errors
|
||||||
|
|
||||||
|
function catchPHPerrors($errno, $errstr, $errfile, $errline)
|
||||||
|
{
|
||||||
|
// --- Just log ...
|
||||||
|
|
||||||
|
_log('!! ('.$errno.') "'.$errstr.'" at line #'.$errline.' of "'.$errfile.'"');
|
||||||
|
|
||||||
|
// --- We do not take care of any errors, etc.
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
set_error_handler("catchPHPerrors");
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
// Read configuration file
|
// Read configuration file
|
||||||
@@ -357,6 +390,40 @@
|
|||||||
return($info);
|
return($info);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Cleanup 'path': remove files with 'ext' older than 'daysOld'
|
||||||
|
|
||||||
|
function cleanupDir($path, $ext, $daysOld)
|
||||||
|
{
|
||||||
|
_log('- Scanning "'.$path.'"');
|
||||||
|
|
||||||
|
$files = glob($path.'/*'.$ext);
|
||||||
|
$now = time();
|
||||||
|
|
||||||
|
$filesRemoved = 0;
|
||||||
|
$filesKept = 0;
|
||||||
|
|
||||||
|
foreach ($files as $file)
|
||||||
|
{
|
||||||
|
if (is_file($file))
|
||||||
|
{
|
||||||
|
if ($now - filemtime($file) >= (60 * 60 * 24 * $daysOld))
|
||||||
|
{
|
||||||
|
_log('> Removing "'.$file.'"');
|
||||||
|
unlink($file);
|
||||||
|
$filesRemoved++;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$filesKept++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_log(': Done. Cleaned up '.$filesRemoved.' file(s), kept '.$filesKept.' file(s)');
|
||||||
|
}
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
// Initialize ///////////////////////////////////////////////////////////////////////////////////////////
|
// Initialize ///////////////////////////////////////////////////////////////////////////////////////////
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
@@ -384,6 +451,10 @@
|
|||||||
{
|
{
|
||||||
if (($argc>1) && ($argv[1]=='test'))
|
if (($argc>1) && ($argv[1]=='test'))
|
||||||
{
|
{
|
||||||
|
// Switch on CLI log display
|
||||||
|
$showLog = TRUE;
|
||||||
|
|
||||||
|
_log('<<< mailGraph '.$cVersion.' >>>');
|
||||||
_log('# Invoked from CLI');
|
_log('# Invoked from CLI');
|
||||||
|
|
||||||
// Assumes that config.json file has the correct information
|
// Assumes that config.json file has the correct information
|
||||||
@@ -403,19 +474,42 @@
|
|||||||
if (isset($config['cli_periods_headers'])) { $problemData['periods_headers'] = $config['cli_periods_headers']; }
|
if (isset($config['cli_periods_headers'])) { $problemData['periods_headers'] = $config['cli_periods_headers']; }
|
||||||
if (isset($config['cli_debug'])) { $problemData['debug'] = $config['cli_debug']; }
|
if (isset($config['cli_debug'])) { $problemData['debug'] = $config['cli_debug']; }
|
||||||
if (isset($config['cli_proxy'])) { $problemData['HTTPProxy'] = $config['cli_proxy']; }
|
if (isset($config['cli_proxy'])) { $problemData['HTTPProxy'] = $config['cli_proxy']; }
|
||||||
|
}
|
||||||
|
|
||||||
|
if (($argc>1) && ($argv[1]=='cleanup'))
|
||||||
|
{
|
||||||
// Switch on CLI log display
|
// Switch on CLI log display
|
||||||
$showLog = TRUE;
|
$showLog = TRUE;
|
||||||
|
|
||||||
|
// Check for configuration of retention period for images and logs
|
||||||
|
_log('<<< mailGraph '.$cVersion.' >>>');
|
||||||
|
_log('# Invoked from CLI');
|
||||||
|
|
||||||
|
// Set defaults
|
||||||
|
$retImages = 30;
|
||||||
|
$retLogs = 14;
|
||||||
|
|
||||||
|
// Check if configured settings
|
||||||
|
if (isset($config['retention_images'])) { $retImages = intval($config['retention_images']); }
|
||||||
|
if (isset($config['retention_logs'])) { $retLogs = intval($config['retention_logs']); }
|
||||||
|
|
||||||
|
_log('Cleaning up IMAGES ('.$retImages.' days) and LOGS ('.$retLogs.' days)');
|
||||||
|
|
||||||
|
cleanupDir(getcwd().'/images', '.png', $retImages);
|
||||||
|
cleanupDir(getcwd().'/log', '.dump', $retLogs);
|
||||||
|
|
||||||
|
exit(0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
_log('# Data passed to MailGraph main routine and used for processing'.$cCRLF.json_encode($problemData,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
_log('# Data passed to MailGraph main routine and used for processing'.
|
||||||
|
$cCRLF.json_encode($problemData,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
||||||
|
|
||||||
// --- CHECK AND SET P_ VARIABLES ---
|
// --- CHECK AND SET P_ VARIABLES ---
|
||||||
// FROM POST OR CLI DATA
|
// FROM POST OR CLI DATA
|
||||||
|
|
||||||
if (!isset($problemData['itemId'])) { echo "Missing ITEM ID?\n"; die; }
|
// if (!isset($problemData['itemId'])) { echo "Missing ITEM ID?\n"; die; }
|
||||||
$p_itemId = intval($problemData['itemId']);
|
// $p_itemId = intval($problemData['itemId']);
|
||||||
|
|
||||||
if (!isset($problemData['eventId'])) { echo "Missing EVENT ID?\n"; die; }
|
if (!isset($problemData['eventId'])) { echo "Missing EVENT ID?\n"; die; }
|
||||||
$p_eventId = intval($problemData['eventId']);
|
$p_eventId = intval($problemData['eventId']);
|
||||||
@@ -444,7 +538,7 @@
|
|||||||
$p_period = '48h';
|
$p_period = '48h';
|
||||||
if (isset($problemData['period'])) { $p_period = $problemData['period']; }
|
if (isset($problemData['period'])) { $p_period = $problemData['period']; }
|
||||||
|
|
||||||
if (isset($problemData['HTTPProxy'])) { $HTTPProxy = $problemData['HTTPPRoxy']; }
|
if (isset($problemData['HTTPProxy'])) { $HTTPProxy = $problemData['HTTPProxy']; }
|
||||||
|
|
||||||
// DYNAMIC VARIABLES FROM ZABBIX
|
// DYNAMIC VARIABLES FROM ZABBIX
|
||||||
|
|
||||||
@@ -468,6 +562,12 @@
|
|||||||
$p_smtp_strict = 'yes';
|
$p_smtp_strict = 'yes';
|
||||||
if ((isset($config['smtp_strict'])) && ($config['smtp_strict']=='no')) { $p_smtp_strict = 'no'; }
|
if ((isset($config['smtp_strict'])) && ($config['smtp_strict']=='no')) { $p_smtp_strict = 'no'; }
|
||||||
|
|
||||||
|
$p_smtp_username = '';
|
||||||
|
if (isset($config['smtp_username'])) { $p_smtp_username = $config['smtp_username']; }
|
||||||
|
|
||||||
|
$p_smtp_password = '';
|
||||||
|
if (isset($config['smtp_password'])) { $p_smtp_password = $config['smtp_password']; }
|
||||||
|
|
||||||
$p_graph_match = 'any';
|
$p_graph_match = 'any';
|
||||||
if ((isset($config['graph_match'])) && ($config['graph_match']=='exact')) { $p_graph_match = 'exact'; }
|
if ((isset($config['graph_match'])) && ($config['graph_match']=='exact')) { $p_graph_match = 'exact'; }
|
||||||
|
|
||||||
@@ -537,7 +637,13 @@
|
|||||||
$token = '';
|
$token = '';
|
||||||
if (isset($result['result'])) { $token = $result['result']; }
|
if (isset($result['result'])) { $token = $result['result']; }
|
||||||
|
|
||||||
if ($token=='') { echo 'Error logging in to Zabbix? ('.$z_url_api.')'; die; }
|
if ($token=='')
|
||||||
|
{
|
||||||
|
echo 'Error logging in to Zabbix? ('.$z_url_api.'): '.$cCRLF;
|
||||||
|
echo var_dump($request).$cCRLF;
|
||||||
|
echo var_dump($result).$cCRLF;
|
||||||
|
die;
|
||||||
|
}
|
||||||
|
|
||||||
_log('> Token = '.$token);
|
_log('> Token = '.$token);
|
||||||
|
|
||||||
@@ -594,10 +700,10 @@
|
|||||||
'params'=>array('triggerids'=>$p_triggerId,
|
'params'=>array('triggerids'=>$p_triggerId,
|
||||||
'output'=>'extend',
|
'output'=>'extend',
|
||||||
'selectFunctions'=>'extend',
|
'selectFunctions'=>'extend',
|
||||||
'selectTags'=>'extend'),
|
'selectTags'=>'extend',
|
||||||
'expandComment'=>1,
|
'expandComment'=>1,
|
||||||
'expandDescription'=>1,
|
'expandDescription'=>1,
|
||||||
'expandExpression'=>1,
|
'expandExpression'=>1),
|
||||||
'auth'=>$token,
|
'auth'=>$token,
|
||||||
'id'=>nextRequestID());
|
'id'=>nextRequestID());
|
||||||
|
|
||||||
@@ -613,6 +719,9 @@
|
|||||||
// --- Custom settings?
|
// --- Custom settings?
|
||||||
|
|
||||||
$forceGraph = 0;
|
$forceGraph = 0;
|
||||||
|
$triggerScreen = 0;
|
||||||
|
$triggerScreenPeriod = '';
|
||||||
|
$triggerScreenPeriodHeader = '';
|
||||||
|
|
||||||
foreach($thisTrigger['result'][0]['tags'] as $aTag)
|
foreach($thisTrigger['result'][0]['tags'] as $aTag)
|
||||||
{
|
{
|
||||||
@@ -662,6 +771,31 @@
|
|||||||
$problemData['debug'] = 1;
|
$problemData['debug'] = 1;
|
||||||
_log('+ Mail debug log enabled');
|
_log('+ Mail debug log enabled');
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screen':
|
||||||
|
$triggerScreen = intval($aTag['value']);
|
||||||
|
_log('+ Trigger screen = '.$triggerScreen);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screenPeriod':
|
||||||
|
$triggerScreenPeriod = $aTag['value'];
|
||||||
|
_log('+ Trigger screen period = '.$triggerScreenPeriod);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screenPeriodHeader':
|
||||||
|
$triggerScreenPeriodHeader = $aTag['value'];
|
||||||
|
_log('+ Trigger screen header = '.$triggerScreenPeriodHeader);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!isset($p_itemId))
|
||||||
|
{
|
||||||
|
foreach($thisTrigger['result'][0]['functions'] as $aFunction)
|
||||||
|
{
|
||||||
|
$p_itemId = $aFunction['itemid'];
|
||||||
|
_log('- Item ID taken from trigger (first) function = '.$p_itemId);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -709,7 +843,8 @@
|
|||||||
$request = array('jsonrpc'=>'2.0',
|
$request = array('jsonrpc'=>'2.0',
|
||||||
'method'=>'host.get',
|
'method'=>'host.get',
|
||||||
'params'=>array('hostids'=>$hostId,
|
'params'=>array('hostids'=>$hostId,
|
||||||
'output'=>'extend'),
|
'output'=>'extend',
|
||||||
|
'selectTags'=>'extend'),
|
||||||
'auth'=>$token,
|
'auth'=>$token,
|
||||||
'id'=>nextRequestID());
|
'id'=>nextRequestID());
|
||||||
|
|
||||||
@@ -720,9 +855,36 @@
|
|||||||
|
|
||||||
$mailData['HOST_ID'] = $thisHost['result'][0]['hostid'];
|
$mailData['HOST_ID'] = $thisHost['result'][0]['hostid'];
|
||||||
$mailData['HOST_NAME'] = $thisHost['result'][0]['name'];
|
$mailData['HOST_NAME'] = $thisHost['result'][0]['name'];
|
||||||
$mailData['HOST_ERROR'] = $thisHost['result'][0]['error'];
|
if (isset($thisHost['result'][0]['error'])) { $mailData['HOST_ERROR'] = $thisHost['result'][0]['error']; }
|
||||||
$mailData['HOST_DESCRIPTION'] = $thisHost['result'][0]['description'];
|
$mailData['HOST_DESCRIPTION'] = $thisHost['result'][0]['description'];
|
||||||
|
|
||||||
|
// --- Custom settings?
|
||||||
|
|
||||||
|
$hostScreen = 0;
|
||||||
|
$hostScreenPeriod = '';
|
||||||
|
$hostScreenPeriodHeader = '';
|
||||||
|
|
||||||
|
foreach($thisHost['result'][0]['tags'] as $aTag)
|
||||||
|
{
|
||||||
|
switch ($aTag['tag'])
|
||||||
|
{
|
||||||
|
case 'mailGraph.screen':
|
||||||
|
$hostScreen = intval($aTag['value']);
|
||||||
|
_log('+ Host screen (from TAG) = '.$hostScreen);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screenPeriod':
|
||||||
|
$hostScreenPeriod = $aTag['value'];
|
||||||
|
_log('+ Host screen period (from TAG) = '.$hostScreenPeriod);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screenPeriodHeader':
|
||||||
|
$hostScreenPeriodHeader = $aTag['value'];
|
||||||
|
_log('+ Host screen period header (from TAG) = '.$hostScreenPeriodHeader);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
_log('# Retreive HOST macro information');
|
_log('# Retreive HOST macro information');
|
||||||
|
|
||||||
$request = array('jsonrpc'=>'2.0',
|
$request = array('jsonrpc'=>'2.0',
|
||||||
@@ -735,9 +897,30 @@
|
|||||||
$thisMacros = postJSON($z_url_api,$request);
|
$thisMacros = postJSON($z_url_api,$request);
|
||||||
_log('> Host macro data'.$cCRLF.json_encode($thisMacros,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
_log('> Host macro data'.$cCRLF.json_encode($thisMacros,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
||||||
|
|
||||||
// --------------------------------------------
|
foreach($thisMacros['result'] as $aMacro)
|
||||||
// --- GET GRAPHS ASSOCIATED WITH THIS HOST ---
|
{
|
||||||
// --------------------------------------------
|
switch($aMacro['macro'])
|
||||||
|
{
|
||||||
|
case 'mailGraph.screen':
|
||||||
|
$hostScreen = intval($aMacro['value']);
|
||||||
|
_log('+ Host screen (from MACRO) = '.$hostScreen);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screenPeriod':
|
||||||
|
$hostScreenPeriod = $aMacro['value'];
|
||||||
|
_log('+ Host screen period (from MACRO) = '.$hostScreenPeriod);
|
||||||
|
break;
|
||||||
|
|
||||||
|
case 'mailGraph.screenPeriodHeader':
|
||||||
|
$hostScreenPeriodHeader = $aMacro['value'];
|
||||||
|
_log('+ Host screen header (from MACRO) = '.$hostScreenPeriodHeader);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------
|
||||||
|
// --- GET GRAPHS ASSOCIATED WITH THIS HOST AND THE TRIGGER ITEMS ---
|
||||||
|
// ------------------------------------------------------------------
|
||||||
|
|
||||||
_log('# Retrieve associated graphs to this HOST and the TRIGGER ITEMS');
|
_log('# Retrieve associated graphs to this HOST and the TRIGGER ITEMS');
|
||||||
|
|
||||||
@@ -781,7 +964,8 @@
|
|||||||
'id'=>nextRequestID());
|
'id'=>nextRequestID());
|
||||||
|
|
||||||
$forceGraphInfo = postJSON($z_url_api,$request);
|
$forceGraphInfo = postJSON($z_url_api,$request);
|
||||||
_log('> Forced graph data'.$cCRLF.json_encode($forceGraphInfo,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
_log('> Forced graph data'.$cCRLF.
|
||||||
|
json_encode($forceGraphInfo,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
||||||
|
|
||||||
if (!isset($forceGraphInfo['result'][0]))
|
if (!isset($forceGraphInfo['result'][0]))
|
||||||
{
|
{
|
||||||
@@ -840,11 +1024,96 @@
|
|||||||
|
|
||||||
_log('> Graphs found (matching/partial) = '.sizeof($matchedGraphs).' / '.sizeof($otherGraphs));
|
_log('> Graphs found (matching/partial) = '.sizeof($matchedGraphs).' / '.sizeof($otherGraphs));
|
||||||
|
|
||||||
|
// ---------------------------------------------------------------------------
|
||||||
|
// --- FIND MATCHING GRAPH ITEMS WITH TRIGGER AND/OR HOST SCREEN REFERENCE ---
|
||||||
|
// ---------------------------------------------------------------------------
|
||||||
|
|
||||||
|
function _sort($a,$b)
|
||||||
|
{
|
||||||
|
if ($a['screen']['y']>$b['screen']['y']) { return(1); }
|
||||||
|
if ($a['screen']['y']<$b['screen']['y']) { return(-1); }
|
||||||
|
if ($a['screen']['x']>$b['screen']['x']) { return(1); }
|
||||||
|
if ($a['screen']['x']<$b['screen']['x']) { return(-1); }
|
||||||
|
return(0);
|
||||||
|
}
|
||||||
|
|
||||||
|
function fetchGraphsFromScreen($screenId)
|
||||||
|
{
|
||||||
|
global $token;
|
||||||
|
global $z_url_api;
|
||||||
|
global $cCRLF;
|
||||||
|
|
||||||
|
// --- Pick up the SCREEN ITEMS associated to the SCREEN
|
||||||
|
|
||||||
|
$request = array('jsonrpc'=>'2.0',
|
||||||
|
'method'=>'screen.get',
|
||||||
|
'params'=>array('screenids'=>$screenId,
|
||||||
|
'output'=>'extend',
|
||||||
|
'selectScreenItems'=>'extend'),
|
||||||
|
'auth'=>$token,
|
||||||
|
'id'=>nextRequestID());
|
||||||
|
|
||||||
|
$screenGraphs = postJSON($z_url_api,$request);
|
||||||
|
_log('> Screen items data for screen #'.$screenId.$cCRLF.json_encode($screenGraphs,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
||||||
|
|
||||||
|
// --- Filter on specific type(s) and enrich the graph data
|
||||||
|
|
||||||
|
$result = array();
|
||||||
|
|
||||||
|
foreach($screenGraphs['result'][0]['screenitems'] as $anItem)
|
||||||
|
{
|
||||||
|
switch($anItem['resourcetype'])
|
||||||
|
{
|
||||||
|
case 0: // Graph
|
||||||
|
$request = array('jsonrpc'=>'2.0',
|
||||||
|
'method'=>'graph.get',
|
||||||
|
'params'=>array('graphids'=>$anItem['resourceid'],
|
||||||
|
'expandName'=>1,
|
||||||
|
'output'=>'extend'),
|
||||||
|
'auth'=>$token,
|
||||||
|
'id'=>nextRequestID());
|
||||||
|
|
||||||
|
$screenGraph = postJSON($z_url_api,$request);
|
||||||
|
_log('+ Graph data for screen item #'.$anItem['screenitemid'].$cCRLF.
|
||||||
|
json_encode($screenGraph,JSON_PRETTY_PRINT|JSON_NUMERIC_CHECK));
|
||||||
|
|
||||||
|
$result[] = array('screen'=>$anItem,'name'=>$screenGraphs['result'][0]['name'],'graph'=>$screenGraph['result'][0]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// --- Sort the result according to SCREEN x,y position
|
||||||
|
|
||||||
|
usort($result,"_sort");
|
||||||
|
|
||||||
|
// --- Done
|
||||||
|
|
||||||
|
return($result);
|
||||||
|
}
|
||||||
|
|
||||||
|
$triggerGraphs = array();
|
||||||
|
|
||||||
|
if ($triggerScreen>0)
|
||||||
|
{
|
||||||
|
_log('# Fetching graph information for TRIGGER for screen #'.$hostScreen);
|
||||||
|
$triggerGraphs = fetchGraphsFromScreen($triggerScreen);
|
||||||
|
_log('> Graphs found = '.sizeof($triggerGraphs));
|
||||||
|
}
|
||||||
|
|
||||||
|
$hostGraphs = array();
|
||||||
|
|
||||||
|
if ($hostScreen>0)
|
||||||
|
{
|
||||||
|
_log('# Fetching graph information for HOST for screen #'.$hostScreen);
|
||||||
|
$hostGraphs = fetchGraphsFromScreen($hostScreen);
|
||||||
|
_log('> Graphs found = '.sizeof($hostGraphs));
|
||||||
|
}
|
||||||
|
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
// Fetch Graph //////////////////////////////////////////////////////////////////////////////////////////
|
// Fetch Graph(s) ///////////////////////////////////////////////////////////////////////////////////////
|
||||||
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// Determine number of periods for this graph
|
// Determine number of periods for the ITEM graphs
|
||||||
|
|
||||||
$p_periods = array();
|
$p_periods = array();
|
||||||
$p_periods_headers = array();
|
$p_periods_headers = array();
|
||||||
@@ -883,8 +1152,12 @@
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
while (sizeof($p_periods)>4) { array_pop($p_periods); }
|
// Strip off any excessive elements from the end
|
||||||
while (sizeof($p_periods_headers)>4) { array_pop($p_periods_headers); }
|
|
||||||
|
while (sizeof($p_periods)>$maxGraphs) { array_pop($p_periods); }
|
||||||
|
while (sizeof($p_periods_headers)>$maxGraphs) { array_pop($p_periods_headers); }
|
||||||
|
|
||||||
|
// Fetching of the ITEM graphs
|
||||||
|
|
||||||
$graphFiles = array();
|
$graphFiles = array();
|
||||||
$graphURL = '';
|
$graphURL = '';
|
||||||
@@ -930,14 +1203,78 @@
|
|||||||
|
|
||||||
$graphFiles[] = $graphFile;
|
$graphFiles[] = $graphFile;
|
||||||
|
|
||||||
$mailData['GRAPHS'][$aKey]['URL'] = $z_url_image . $graphFile;
|
$mailData['GRAPHS_I'][$aKey]['PATH'] = $z_images_path . $graphFile;
|
||||||
$mailData['GRAPHS'][$aKey]['HEADER'] = $p_periods_headers[$aKey];
|
$mailData['GRAPHS_I'][$aKey]['URL'] = $z_url_image . $graphFile;
|
||||||
|
$mailData['GRAPHS_I'][$aKey]['HEADER'] = $p_periods_headers[$aKey];
|
||||||
}
|
}
|
||||||
|
|
||||||
$mailData['GRAPH_ZABBIXLINK'] = $z_server.'graphs.php?form=update&graphid='.$mailData['GRAPH_ID'];
|
$mailData['GRAPH_ZABBIXLINK'] = $z_server.'graphs.php?form=update&graphid='.$mailData['GRAPH_ID'];
|
||||||
}
|
}
|
||||||
|
|
||||||
// Prepare HTML LOG content
|
// Fetch graphs associated to TRIGGER or HOST screen references obtained earlier
|
||||||
|
|
||||||
|
function addGraphs($varName,$info,$period,$periodHeader)
|
||||||
|
{
|
||||||
|
global $p_graphWidth;
|
||||||
|
global $p_graphHeight;
|
||||||
|
global $p_showLegend;
|
||||||
|
global $z_url_image;
|
||||||
|
global $z_images_path;
|
||||||
|
global $z_server;
|
||||||
|
global $mailData;
|
||||||
|
|
||||||
|
$files = array();
|
||||||
|
|
||||||
|
foreach($info as $aKey=>$anItem)
|
||||||
|
{
|
||||||
|
$graphFile = GraphImageById($anItem['graph']['graphid'],
|
||||||
|
$p_graphWidth,$p_graphHeight,
|
||||||
|
$anItem['graph']['graphtype'],
|
||||||
|
$p_showLegend,$period);
|
||||||
|
|
||||||
|
$mailData['GRAPHS_'.$varName][$aKey]['URL'] = $z_url_image . $graphFile;
|
||||||
|
$mailData['GRAPHS_'.$varName][$aKey]['PATH'] = $z_images_path . $graphFile;
|
||||||
|
}
|
||||||
|
|
||||||
|
$mailData['GRAPHS_'.$varName.'_LINK'] = $z_server.'screens.php?elementid='.$info[0]['screen']['screenid'];
|
||||||
|
$mailData['GRAPHS_'.$varName.'_HEADER'] = $info[0]['name'];
|
||||||
|
$mailData['GRAPHS_'.$varName.'_PERIODHEADER'] = $periodHeader;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sizeof($triggerGraphs)>0)
|
||||||
|
{
|
||||||
|
if ($triggerScreenPeriod=='')
|
||||||
|
{
|
||||||
|
$triggerScreenPeriod = $p_periods[0];
|
||||||
|
$triggerScreenPeriodHeader = $p_periods_headers[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($triggerScreenPeriodHeader=='') { $triggerScreenPeriodHeader = $triggerScreenPeriod; }
|
||||||
|
|
||||||
|
addGraphs('T',$triggerGraphs,$triggerScreenPeriod,$triggerScreenPeriodHeader);
|
||||||
|
|
||||||
|
$mailData['TRIGGER_SCREEN'] = $triggerScreen;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (sizeof($hostGraphs)>0)
|
||||||
|
{
|
||||||
|
if ($hostScreenPeriod=='')
|
||||||
|
{
|
||||||
|
$hostScreenPeriod = $p_periods[0];
|
||||||
|
$hostScreenPeriodHeader = $p_periods_headers[0];
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($hostScreenPeriodHeader=='') { $hostScreenPeriodHeader = $hostScreenPeriod; }
|
||||||
|
|
||||||
|
addGraphs('H',$hostGraphs,$hostScreenPeriod,$hostScreenPeriodHeader);
|
||||||
|
|
||||||
|
$mailData['HOST_SCREEN'] = $hostScreen;
|
||||||
|
}
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Prepare HTML LOG content /////////////////////////////////////////////////////////////////////////////
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
$mailData['LOG_HTML'] = implode('</br/>',$logging);
|
$mailData['LOG_HTML'] = implode('</br/>',$logging);
|
||||||
$mailData['LOG_HTML'] = str_replace($cCRLF,'<br/>',$mailData['LOG_HTML']);
|
$mailData['LOG_HTML'] = str_replace($cCRLF,'<br/>',$mailData['LOG_HTML']);
|
||||||
@@ -1002,11 +1339,18 @@
|
|||||||
$transport = (new Swift_SmtpTransport($p_smtp_server, $p_smtp_port));
|
$transport = (new Swift_SmtpTransport($p_smtp_server, $p_smtp_port));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Username/password?
|
||||||
|
|
||||||
|
if ($p_smtp_username!='') { $transport->setUsername($p_smtp_username); }
|
||||||
|
if ($p_smtp_password!='') { $transport->setPassword($p_smtp_password); }
|
||||||
|
|
||||||
|
// Start actual mail(er)
|
||||||
|
|
||||||
$mailer = new Swift_Mailer($transport);
|
$mailer = new Swift_Mailer($transport);
|
||||||
|
|
||||||
$message = (new Swift_Message());
|
$message = (new Swift_Message());
|
||||||
|
|
||||||
// Fetch mailer ID from this message (no Swift function available for it ...)
|
// --- Fetch mailer ID from this message (no Swift function available for it ...)
|
||||||
// --- "Message-ID: <...id...@swift.generated>"
|
// --- "Message-ID: <...id...@swift.generated>"
|
||||||
|
|
||||||
$content = $message->toString();
|
$content = $message->toString();
|
||||||
@@ -1031,19 +1375,26 @@
|
|||||||
|
|
||||||
$twig = new \Twig\Environment($loader);
|
$twig = new \Twig\Environment($loader);
|
||||||
|
|
||||||
if (sizeof($graphFiles)>0)
|
// --- Embed the images
|
||||||
|
|
||||||
|
function embedGraphs($graphs,$varName,$type)
|
||||||
{
|
{
|
||||||
// Embed the image(s)
|
global $message;
|
||||||
|
global $mailData;
|
||||||
|
|
||||||
$graphReference = 0;
|
foreach($graphs as $aKey=>$anItem)
|
||||||
|
|
||||||
foreach($graphFiles as $graphFile)
|
|
||||||
{
|
{
|
||||||
$mailData['GRAPHS'][$graphReference++]['CID'] = $message->embed(Swift_Image::fromPath($z_images_path.$graphFile));
|
$mailData['GRAPHS_'.$varName][$aKey]['CID'] = $message->embed(Swift_Image::fromPath($mailData['GRAPHS_'.$varName][$aKey]['PATH']));
|
||||||
_log('> Embedded graph image '.$z_images_path.$graphFile);
|
_log('> Embedded graph image ('.$type.') '.$mailData['GRAPHS_'.$varName][$aKey]['PATH']);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
embedGraphs($graphFiles,'I','ITEM');
|
||||||
|
embedGraphs($triggerGraphs,'T','TRIGGER');
|
||||||
|
embedGraphs($hostGraphs,'H','HOST');
|
||||||
|
|
||||||
|
// --- Render the content
|
||||||
|
|
||||||
$bodyHTML = $twig->render('html', $mailData);
|
$bodyHTML = $twig->render('html', $mailData);
|
||||||
$bodyPlain = $twig->render('plain', $mailData);
|
$bodyPlain = $twig->render('plain', $mailData);
|
||||||
$mailSubject = $twig->render('subject', $mailData);
|
$mailSubject = $twig->render('subject', $mailData);
|
||||||
@@ -1076,6 +1427,10 @@
|
|||||||
$response = array('messageId.mailGraph'=>$messageId);
|
$response = array('messageId.mailGraph'=>$messageId);
|
||||||
echo json_encode($response).$cCRLF;
|
echo json_encode($response).$cCRLF;
|
||||||
|
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// Wrap up //////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
/////////////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
// Store log?
|
// Store log?
|
||||||
|
|
||||||
if (($cDebug) || (isset($problemData['debug'])))
|
if (($cDebug) || (isset($problemData['debug'])))
|
||||||
@@ -1089,6 +1444,6 @@
|
|||||||
$logName = 'log.'.$p_eventId.'.'.date('YmdHis').'.dump';
|
$logName = 'log.'.$p_eventId.'.'.date('YmdHis').'.dump';
|
||||||
|
|
||||||
file_put_contents($z_log_path.$logName,$content);
|
file_put_contents($z_log_path.$logName,$content);
|
||||||
_log('= Log stored to '.$z_log_path.$logName);
|
_log('= Log stored to '.$z_log_path.$logName);
|
||||||
}
|
}
|
||||||
?>
|
?>
|
||||||
|
|||||||
@@ -114,16 +114,6 @@
|
|||||||
</table>
|
</table>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
{% for aGraph in GRAPHS %}
|
|
||||||
<tr>
|
|
||||||
<div align=justify>
|
|
||||||
<td align="center">
|
|
||||||
<span class="graphHeader">{{ aGraph.HEADER }}</span><br/>
|
|
||||||
<img id="mainimage" border=0 style="width: 100%; max-width: 790px" alt="Zabbix Graph" src="{{ aGraph.CID }}" />
|
|
||||||
</td>
|
|
||||||
</div>
|
|
||||||
</tr>
|
|
||||||
{% endfor %}
|
|
||||||
<tr>
|
<tr>
|
||||||
<td class="links">
|
<td class="links">
|
||||||
<div align=center>
|
<div align=center>
|
||||||
@@ -137,6 +127,66 @@
|
|||||||
</div>
|
</div>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
{% for aGraph in GRAPHS_I %}
|
||||||
|
<tr>
|
||||||
|
<div align=justify>
|
||||||
|
<td align="center">
|
||||||
|
<span class="graphHeader">{{ aGraph.HEADER }}</span><br/>
|
||||||
|
<img id="mainimage" border=0 style="width: 100%; max-width: 790px" alt="Zabbix Graph" src="{{ aGraph.CID }}" />
|
||||||
|
</td>
|
||||||
|
</div>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
{% if TRIGGER_SCREEN > 0 %}
|
||||||
|
<tr>
|
||||||
|
<div align=justify>
|
||||||
|
<td align="center">
|
||||||
|
<span class="graphHeader">{{ GRAPHS_T_HEADER }} - {{ GRAPHS_T_PERIODHEADER }}</span>
|
||||||
|
</td>
|
||||||
|
</div>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td class="links">
|
||||||
|
<div align="center">
|
||||||
|
Screen ID: <a href="{{ GRAPHS_T_LINK }}">{{ TRIGGER_SCREEN }}</a>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% for aGraph in GRAPHS_T %}
|
||||||
|
<tr>
|
||||||
|
<div align=justify>
|
||||||
|
<td align="center">
|
||||||
|
<img id="mainimage" border=0 style="width: 100%; max-width: 790px" alt="Zabbix Graph" src="{{ aGraph.CID }}" />
|
||||||
|
</td>
|
||||||
|
</div>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
|
{% if HOST_SCREEN > 0 %}
|
||||||
|
<tr>
|
||||||
|
<div align=justify>
|
||||||
|
<td align="center">
|
||||||
|
<span class="graphHeader">{{ GRAPHS_H_HEADER }} - {{ GRAPHS_H_PERIODHEADER }}</span>
|
||||||
|
</td>
|
||||||
|
</div>
|
||||||
|
</tr>
|
||||||
|
<tr>
|
||||||
|
<td class="links">
|
||||||
|
<div align="center">
|
||||||
|
Screen ID: <a href="{{ GRAPHS_H_LINK }}">{{ HOST_SCREEN }}</a>
|
||||||
|
</div>
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
{% for aGraph in GRAPHS_H %}
|
||||||
|
<tr>
|
||||||
|
<div align=justify>
|
||||||
|
<td align="center">
|
||||||
|
<img id="mainimage" border=0 style="width: 100%; max-width: 790px" alt="Zabbix Graph" src="{{ aGraph.CID }}" />
|
||||||
|
</td>
|
||||||
|
</div>
|
||||||
|
</tr>
|
||||||
|
{% endfor %}
|
||||||
|
{% endif %}
|
||||||
</table>
|
</table>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
Reference in New Issue
Block a user