90 lines
3.2 KiB
PHP
Executable File
90 lines
3.2 KiB
PHP
Executable File
#!/usr/bin/php
|
|
<?php
|
|
// +------------------------------------------------------------------+
|
|
// | ____ _ _ __ __ _ __ |
|
|
// | / ___| |__ ___ ___| | __ | \/ | |/ / |
|
|
// | | | | '_ \ / _ \/ __| |/ / | |\/| | ' / |
|
|
// | | |___| | | | __/ (__| < | | | | . \ |
|
|
// | \____|_| |_|\___|\___|_|\_\___|_| |_|_|\_\ |
|
|
// | |
|
|
// | Copyright Mathias Kettner 2014 mk@mathias-kettner.de |
|
|
// +------------------------------------------------------------------+
|
|
//
|
|
// This file is part of Check_MK.
|
|
// The official homepage is at http://mathias-kettner.de/check_mk.
|
|
//
|
|
// check_mk is free software; you can redistribute it and/or modify it
|
|
// under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation in version 2. check_mk is distributed
|
|
// in the hope that it will be useful, but WITHOUT ANY WARRANTY; with-
|
|
// out even the implied warranty of MERCHANTABILITY or FITNESS FOR A
|
|
// PARTICULAR PURPOSE. See the GNU General Public License for more de-
|
|
// ails. You should have received a copy of the GNU General Public
|
|
// License along with GNU Make; see the file COPYING. If not, write
|
|
// to the Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
// Boston, MA 02110-1301 USA.
|
|
//
|
|
//
|
|
print "<<<unitrends_backup:sep(124)>>>\n";
|
|
$conn = "port=5432 dbname=bpdb user=postgres";
|
|
$db = pg_connect($conn);
|
|
|
|
$query = "SELECT
|
|
schedule_id, a.type AS app_type
|
|
FROM
|
|
bp.schedules AS s
|
|
JOIN
|
|
bp.application_lookup AS a USING(app_id)
|
|
WHERE
|
|
enabled=true AND email_report=true
|
|
ORDER BY s.name";
|
|
$res = pg_query($db, $query);
|
|
|
|
$start = time() - (24 * 3600);
|
|
$in = array("start_time" => $start);
|
|
bp_bypass_cookie(3, 'schedule_report');
|
|
|
|
while ($obj = pg_fetch_object($res)) {
|
|
if ($obj->app_type == "Archive")
|
|
continue;
|
|
|
|
$in["schedule_id"] = (int)$obj->schedule_id;
|
|
$ret = bp_get_schedule_history($in);
|
|
if (empty($ret[0]["backups"]))
|
|
continue;
|
|
|
|
print "HEADER|".
|
|
$ret[0]["schedule_name"]."|" .
|
|
$ret[0]["application_name"]."|".
|
|
$ret[0]["schedule_description"]."|".
|
|
$ret[0]["failures"]."\n";
|
|
|
|
foreach($ret[0]["backups"] as $trash => $backup) {
|
|
foreach($backup as $row) {
|
|
|
|
$name = $row["primary_name"];
|
|
switch($ret[0]["app_type"]){
|
|
case "SQL Server":
|
|
$name .= "/".$row["secondary_name"];
|
|
break;
|
|
|
|
case "VMware":
|
|
$name .= ", VM ".$row["secondary_name"];
|
|
break;
|
|
}
|
|
|
|
$backup_type = $row["type"];
|
|
|
|
if (!isset($name))
|
|
$name = $backup_tyoe;
|
|
|
|
$backup_no = (isset($row["backup_id"])) ? $row["backup_id"] : "N/A" ;
|
|
|
|
print "$name|$backup_no|$backup_type|".$row['description']."\n";
|
|
}
|
|
}
|
|
}
|
|
pg_free_result($res);
|
|
bp_destroy_cookie();
|
|
?>
|