librenms/scripts/syslog-notify-oxidized.php
deepseth 809c9ea591 feature: Added Syslog hook for ASA support (#7268)
* Added limited support for ASA using emblem logging

* Updated documentation

* Updated ASA support to cover regular and emblem logging

* Gave the variable a more suitable name

* Removed debug output
2017-09-01 18:37:01 +01:00

42 lines
1.5 KiB
PHP
Executable File

#!/usr/bin/env php
<?php
$init_modules = array();
require __DIR__ . '/../includes/init.php';
function oxidized_node_update($hostname, $username, $msg)
{
global $config;
// Work around https://github.com/rack/rack/issues/337
$msg = str_replace("%", "", $msg);
$postdata = array("user" => $username, "msg" => $msg);
$version = `git rev-parse --short HEAD`;
if ($version != "") {
$version = "/".$version;
}
$curl = curl_init();
curl_setopt($curl, CURLOPT_CUSTOMREQUEST, "PUT");
curl_setopt($curl, CURLOPT_POSTFIELDS, json_encode($postdata));
curl_setopt($curl, CURLOPT_USERAGENT, "librenms".$version);
curl_setopt($curl, CURLOPT_URL, $config['oxidized']['url'].'/node/next/'.$hostname);
$result = curl_exec($curl);
}//end oxidized_node_update()
$hostname = $argv[1];
$os = $argv[2];
$msg = $argv[3];
if (preg_match('/(SYS-(SW[0-9]+-)?5-CONFIG_I|VSHD-5-VSHD_SYSLOG_CONFIG_I): Configured from .+ by (?P<user>.+) on .*/', $msg, $matches)) {
$username = $matches['user'];
oxidized_node_update($hostname, $username, $msg);
} elseif (preg_match('/GBL-CONFIG-6-DB_COMMIT : Configuration committed by user \\\\\'(?P<user>.+?)\\\\\'..*/', $msg, $matches)) {
$username = $matches['user'];
oxidized_node_update($hostname, $username, $msg);
} elseif (preg_match('/ASA-(config-)?5-111005: (?P<user>.+) end configuration: OK/', $msg, $matches)) {
$username = $matches['user'];
oxidized_node_update($hostname, $username, $msg);
}