2013-07-23 13:30:25 +02:00
|
|
|
#!/usr/bin/perl
|
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
# Pandora FMS - Remote Event Tool (via WEB API)
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
# Copyright (c) 2013 Artica Soluciones Tecnologicas S.L
|
|
|
|
#
|
|
|
|
# This program is free software; you can redistribute it and/or
|
|
|
|
# modify it under the terms of the GNU General Public License version 2
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
# Includes list
|
|
|
|
use strict;
|
|
|
|
use LWP::Simple;
|
2014-12-05 12:02:21 +01:00
|
|
|
use URI::Escape;
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
# Init
|
|
|
|
tool_api_init();
|
|
|
|
|
|
|
|
# Main
|
|
|
|
tool_api_main();
|
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
# Print a help screen and exit.
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
|
|
|
sub help_screen () {
|
|
|
|
|
|
|
|
print "
|
|
|
|
Options to create event:
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
\t$0 -p <path_to_consoleAPI> -create event <options>
|
|
|
|
|
|
|
|
Where options:\n
|
2014-12-05 12:02:21 +01:00
|
|
|
-u <credentials>
|
2013-07-23 13:30:25 +02:00
|
|
|
-create_event
|
2014-12-05 12:02:21 +01:00
|
|
|
-name <event_name> : Free text
|
|
|
|
-group <id_group> : Group ID (use 0 for 'all')
|
|
|
|
-type <event_type> : unknown, alert_fired, alert_recovered, alert_ceased
|
|
|
|
alert_manual_validation, system, error, new_agent
|
|
|
|
configuration_change, going_unknown, going_down_critical,
|
|
|
|
going_down_warning, going_up_normal
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
Optional parameters:
|
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
[-agent <id_agent>] : Agent ID
|
|
|
|
[-user <id_user>] : User comment (use in combination with -comment option)
|
|
|
|
[-status <status>] : 0 New, 1 Validated, 2 In process
|
|
|
|
[-am <id_agent_module>] : ID Agent Module linked to event
|
|
|
|
[-alert <id_alert_am>] : ID Alert Module linked to event
|
|
|
|
[-criticity <criticity>] : 0 Maintance, 1 Informative, 2 Normal,
|
|
|
|
3 Warning, 4 Crit, 5 Minor, 6 Major
|
2013-07-23 13:30:25 +02:00
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
[-comment <user_comment>] : Free text for comment
|
|
|
|
[-tag <tags>] : Tag (must exist in the system to be imported)
|
|
|
|
[-source <source>] : (By default 'Pandora')
|
|
|
|
[-c_instructions <critical_instructions>]
|
|
|
|
[-w_instructions <warning_instructions>]
|
|
|
|
[-u_instructions <unknown_instructions>]
|
|
|
|
[-owner <owner_user>] : Use the login name, not the descriptive
|
|
|
|
|
|
|
|
|
|
|
|
Credential/API syntax:
|
|
|
|
|
|
|
|
<credentials> : API credentials separated by comma: <api_pass>,<user>,<pass>
|
2013-07-23 13:30:25 +02:00
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
Example of event generation:
|
|
|
|
|
|
|
|
$0 -p http://localhost/pandora_console/include/api.php -u 1234,admin,pandora
|
|
|
|
-create_event -name \"SampleEvent\" -group 2 -type \"system\" -agent 189 -status 0 -user \"admin\"
|
|
|
|
-criticity 3 -am 0 -alert 9 -c_instructions \"Critical instructions\" -w_instructions \"Warning instructions\"
|
|
|
|
-u_instructions \"Unknown instructions\" -source \"Commandline\" -tag \"Tags\" -owner \"other\"
|
|
|
|
|
|
|
|
|
|
|
|
";
|
|
|
|
|
|
|
|
exit;
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
# Init screen
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
sub tool_api_init () {
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-07-23 13:30:25 +02:00
|
|
|
print "\nPandora FMS Remote Event Tool Copyright (c) 2013 Artica ST\n";
|
|
|
|
print "This program is Free Software, licensed under the terms of GPL License v2\n";
|
|
|
|
print "You can download latest versions and documentation at http://www.pandorafms.org\n\n";
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-07-23 13:30:25 +02:00
|
|
|
if ($#ARGV < 0) {
|
|
|
|
help_screen();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (($ARGV[0] eq '-h') || ($ARGV[0] eq '-help')) {
|
|
|
|
help_screen();
|
|
|
|
}
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
########################################################################
|
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
# MAIN
|
2014-12-05 12:02:21 +01:00
|
|
|
########################################################################
|
|
|
|
########################################################################
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
sub tool_api_main () {
|
|
|
|
|
|
|
|
my $api_path;
|
|
|
|
my $event_name;
|
|
|
|
my $id_group;
|
|
|
|
my $event_type;
|
|
|
|
my $data_event;
|
|
|
|
my $credentials;
|
|
|
|
my $api_pass;
|
|
|
|
my $db_user;
|
|
|
|
my $db_pass;
|
|
|
|
my @db_info;
|
|
|
|
my $id_agent;
|
|
|
|
my $agent_name;
|
|
|
|
my $id_user = '';
|
|
|
|
my $status = '';
|
|
|
|
my $id_agent_module = '';
|
|
|
|
my $module_name = '';
|
|
|
|
my $id_alert_am = '';
|
|
|
|
my $criticity = '';
|
|
|
|
my $user_comment = '';
|
|
|
|
my $tags = '';
|
|
|
|
my $source = '';
|
|
|
|
my $id_extra = '';
|
|
|
|
my $critical_instructions = '';
|
|
|
|
my $warning_instructions = '';
|
|
|
|
my $unknown_instructions = '';
|
|
|
|
my $owner_user = '';
|
|
|
|
my $id_event;
|
|
|
|
my $option = $ARGV[4];
|
|
|
|
my $call_api;
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-07-23 13:30:25 +02:00
|
|
|
#~ help or api path (required)
|
|
|
|
if ($ARGV[0] eq '-h') {
|
|
|
|
print "HELP!\n";
|
|
|
|
help_screen();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
elsif ($ARGV[0] ne '-p') {
|
2013-07-23 13:30:25 +02:00
|
|
|
print "[ERROR] Missing API path! Read help info:\n\n";
|
|
|
|
help_screen ();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-07-23 13:30:25 +02:00
|
|
|
$api_path = $ARGV[1];
|
|
|
|
}
|
|
|
|
|
|
|
|
#~ credentials of database
|
|
|
|
if ($ARGV[2] eq '-u') {
|
|
|
|
$credentials = $ARGV[3];
|
|
|
|
@db_info = split(',', $credentials);
|
|
|
|
|
|
|
|
if ($#db_info < 2) {
|
|
|
|
print "[ERROR] Invalid database credentials! Read help info:\n\n";
|
|
|
|
help_screen();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-07-23 13:30:25 +02:00
|
|
|
$api_pass = $db_info[0];
|
|
|
|
$db_user = $db_info[1];
|
|
|
|
$db_pass = $db_info[2];
|
|
|
|
}
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-07-23 13:30:25 +02:00
|
|
|
print "[ERROR] Missing database credentials! Read help info:\n\n";
|
|
|
|
help_screen ();
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($ARGV[4] eq '-create_event') {
|
2014-12-05 12:02:21 +01:00
|
|
|
#~ event name (required)
|
2013-07-23 13:30:25 +02:00
|
|
|
if ($ARGV[5] ne '-name') {
|
|
|
|
print "[ERROR] Missing event name! Read help info:\n\n";
|
|
|
|
help_screen ();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
$event_name = uri_escape($ARGV[6]);
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
|
2014-12-05 12:02:21 +01:00
|
|
|
#~ id group (required)
|
2013-07-23 13:30:25 +02:00
|
|
|
if ($ARGV[7] ne '-group') {
|
|
|
|
print "[ERROR] Missing event group! Read help info:\n\n";
|
|
|
|
help_screen ();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-07-23 13:30:25 +02:00
|
|
|
$id_group = $ARGV[8];
|
|
|
|
}
|
|
|
|
|
|
|
|
#~ id group (required)
|
|
|
|
if ($ARGV[9] ne '-type') {
|
|
|
|
print "[ERROR] Missing event type! Read help info:\n\n";
|
|
|
|
help_screen ();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-07-23 13:30:25 +02:00
|
|
|
$event_type = $ARGV[10];
|
|
|
|
}
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-07-23 13:30:25 +02:00
|
|
|
my $i = 0;
|
|
|
|
foreach (@ARGV) {
|
|
|
|
my $line = $_;
|
|
|
|
if ($line eq '-agent') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$id_agent = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-user') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$id_user = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-status') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$status = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-am') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$id_agent_module = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-alert') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$id_alert_am = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-criticity') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$criticity = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-comment') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$user_comment = $ARGV[$i + 1];
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-tag') {
|
|
|
|
$tags = $ARGV[$i+1];
|
|
|
|
}
|
|
|
|
if ($line eq '-source') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$source = uri_escape($ARGV[$i + 1]);
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-c_instructions') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$critical_instructions = uri_escape($ARGV[$i + 1]);
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-w_instructions') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$warning_instructions = uri_escape($ARGV[$i + 1]);
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-u_instructions') {
|
2014-12-05 12:02:21 +01:00
|
|
|
$unknown_instructions = uri_escape($ARGV[$i + 1]);
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
|
|
|
if ($line eq '-owner') {
|
|
|
|
$owner_user = $ARGV[$i+1];
|
|
|
|
}
|
|
|
|
$i++;
|
|
|
|
}
|
2014-12-05 12:02:21 +01:00
|
|
|
|
|
|
|
$data_event = $event_name . "|" .
|
|
|
|
$id_group . "|" .
|
|
|
|
$id_agent . "|" .
|
|
|
|
$status . "|" .
|
|
|
|
$id_user . "|" .
|
|
|
|
$event_type . "|" .
|
|
|
|
$criticity . "|" .
|
|
|
|
$id_agent_module . "|" .
|
|
|
|
$id_alert_am . "|" .
|
|
|
|
$critical_instructions . "|" .
|
|
|
|
$warning_instructions . "|" .
|
|
|
|
$unknown_instructions . "|" .
|
|
|
|
$user_comment . "|" .
|
|
|
|
$owner_user . "|" .
|
|
|
|
$source . "|" .
|
|
|
|
$tags;
|
|
|
|
|
|
|
|
$call_api = $api_path . '?' .
|
|
|
|
'op=set&' .
|
|
|
|
'op2=create_event&' .
|
|
|
|
'id=' . $event_name . '&' .
|
|
|
|
'other=' . $data_event . '&' .
|
|
|
|
'other_mode=url_encode_separator_|&' .
|
|
|
|
'apipass=' . $api_pass . '&' .
|
|
|
|
'user=' . $db_user . '&' .
|
|
|
|
'pass=' . $db_pass;
|
|
|
|
|
2013-11-06 13:15:42 +01:00
|
|
|
#DEBUG TRACE#
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-11-06 13:15:42 +01:00
|
|
|
#print "$call_api\n";
|
2014-12-05 12:02:21 +01:00
|
|
|
|
2013-11-06 13:15:42 +01:00
|
|
|
}
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
my @args = @ARGV;
|
2014-12-05 12:02:21 +01:00
|
|
|
my $ltotal = $#args;
|
|
|
|
|
2013-07-23 13:30:25 +02:00
|
|
|
if ($ltotal < 0) {
|
|
|
|
print "[ERROR] No valid arguments. Read help info:\n\n";
|
|
|
|
help_screen ();
|
|
|
|
exit;
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
2013-07-23 13:30:25 +02:00
|
|
|
else {
|
|
|
|
my $content = get($call_api);
|
2014-12-05 12:02:21 +01:00
|
|
|
print("\n\n");
|
|
|
|
print($call_api);
|
|
|
|
print("\n\n");
|
2013-07-23 13:30:25 +02:00
|
|
|
|
|
|
|
if ($option eq '-create_event') {
|
|
|
|
if ($content eq undef) {
|
|
|
|
print "[ERROR] Not respond or bad syntax. Read help info:\n\n";
|
|
|
|
help_screen();
|
2014-12-05 12:02:21 +01:00
|
|
|
}
|
|
|
|
else {
|
2013-07-23 13:30:25 +02:00
|
|
|
print "Event ID: $content";
|
|
|
|
}
|
2013-11-06 13:15:42 +01:00
|
|
|
}
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|
2014-12-05 12:02:21 +01:00
|
|
|
|
|
|
|
print "\nExiting!\n\n";
|
|
|
|
|
|
|
|
exit;
|
2013-07-23 13:30:25 +02:00
|
|
|
}
|