testo is replaced by texto, output_add is now used, SEND_PAGE replaced by option --send_page

This commit is contained in:
Laurent Kappel 2017-07-20 22:15:04 +02:00
parent 4c3da69548
commit 107061287b
1 changed files with 42 additions and 19 deletions

View File

@ -26,8 +26,6 @@ use strict;
use warnings; use warnings;
use centreon::plugins::http; use centreon::plugins::http;
use constant SEND_PAGE => '/source/send_sms.php';
# use Data::Dumper; # use Data::Dumper;
sub new { sub new {
@ -41,9 +39,11 @@ sub new {
"username:s" => { name => 'username', default => 'centreon' }, "username:s" => { name => 'username', default => 'centreon' },
"password:s" => { name => 'password' }, "password:s" => { name => 'password' },
"from:s" => { name => 'from', default => 'centreon' }, "from:s" => { name => 'from', default => 'centreon' },
"proto:s" => { name => 'proto', default => 'http' },
"sendpage:s" => { name => 'sendpage', default => '/source/send_sms.php' },
"phonenumber:s" => { name => 'phonenumber' }, "phonenumber:s" => { name => 'phonenumber' },
"hostname:s" => { name => 'hostname' }, "hostname:s" => { name => 'hostname' },
"testo:s" => { name => 'testo' }, "texto:s" => { name => 'texto' },
"timeout:s" => { name => 'timeout', default => 10 }, "timeout:s" => { name => 'timeout', default => 10 },
} }
); );
@ -74,8 +74,8 @@ sub check_options {
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
if (!defined($self->{option_results}->{testo})) { if (!defined($self->{option_results}->{texto})) {
$self->{output}->add_option_msg(short_msg => "Please set the --testo option"); $self->{output}->add_option_msg(short_msg => "Please set the --texto option");
$self->{output}->option_exit(); $self->{output}->option_exit();
} }
@ -87,7 +87,10 @@ sub run {
my ($ua, $html_page, $response, $status_code, $litteral_code); my ($ua, $html_page, $response, $status_code, $litteral_code);
my $url = 'http' . '://' . $self->{option_results}->{hostname} . SEND_PAGE; my $url
= $self->{option_results}->{proto} . '://'
. $self->{option_results}->{hostname}
. $self->{option_results}->{sendpage};
$ua = LWP::UserAgent->new; $ua = LWP::UserAgent->new;
$ua->timeout($self->{option_results}->{timeout}); $ua->timeout($self->{option_results}->{timeout});
@ -98,33 +101,45 @@ sub run {
"pwd" => $self->{option_results}->{password}, "pwd" => $self->{option_results}->{password},
"from" => $self->{option_results}->{from}, "from" => $self->{option_results}->{from},
"nphone" => $self->{option_results}->{phonenumber}, "nphone" => $self->{option_results}->{phonenumber},
"testo" => $self->{option_results}->{testo}, "testo" => $self->{option_results}->{texto},
"nc" => $url, "nc" => $url,
] ]
); );
if ($response->{_rc} != 200) { if ($response->{_rc} != 200) {
print("ERROR: " . $response->{_msg} . "\n"); $status_code = $self->{output}->{errors}->{UNKNOWN};
$status_code = $self->{output}->{errors}->{UNKNOWN}; $litteral_code = $self->{output}->{errors_num}->{$status_code};
$self->{output}->output_add(
severity => $litteral_code,
short_msg => 'ERROR: ' . $response->{_msg}
);
} }
else { else {
$html_page = $response->{_content}; $html_page = $response->{_content};
if ($html_page =~ /p class="(\w+)"/g) { if ($html_page =~ /p class="(\w+)"/g) {
if ($1 eq "confneg") { if ($1 eq "confneg") {
print("ERROR: Unable to send SMS\n"); $status_code = $self->{output}->{errors}->{UNKNOWN};
$status_code = $self->{output}->{errors}->{UNKNOWN}; $litteral_code = $self->{output}->{errors_num}->{$status_code};
$self->{output}->output_add(
severity => $litteral_code,
short_msg => 'ERROR: Unable to send SMS'
);
} }
else { else {
$status_code = $self->{output}->{errors}->{OK}; $status_code = $self->{output}->{errors}->{OK};
$litteral_code = $self->{output}->{errors_num}->{$status_code};
} }
} }
else { else {
print("ERROR: Unknown page output\n"); $status_code = $self->{output}->{errors}->{UNKNOWN};
$status_code = $self->{output}->{errors}->{UNKNOWN}; $litteral_code = $self->{output}->{errors_num}->{$status_code};
$self->{output}->output_add(
severity => $litteral_code,
short_msg => 'ERROR: Unknown page output'
);
} }
} }
$self->{output}->display();
$litteral_code = $self->{output}->{errors_num}->{$status_code};
$self->{output}->exit(exit_litteral => $litteral_code); $self->{output}->exit(exit_litteral => $litteral_code);
} }
@ -142,6 +157,10 @@ Send SMS with Foxbox API.
url of the Foxbox Server. url of the Foxbox Server.
=item B<--sendpage>
The path describes a specific resource. (Default: /source/send_sms.php)
=item B<--username> =item B<--username>
Specify username for API authentification (Default: centreon). Specify username for API authentification (Default: centreon).
@ -150,17 +169,21 @@ Specify username for API authentification (Default: centreon).
Specify password for API authentification (Required). Specify password for API authentification (Required).
=item B<--proto>
Specify http or https protocol. (Default: http)
=item B<--phonenumber> =item B<--phonenumber>
Specify phone number (Required). Specify phone number (Required).
=item B<--testo> =item B<--texto>
Specify the testo to send (Required). Specify the content of your SMS message (Required).
=item B<--from> =item B<--from>
Specify the sender. It should NOT start with a number and have a max of 11 characters. Specify the sender. It should NOT start with a number and have a max of 11 characters (Default: centreon).
=item B<--timeout> =item B<--timeout>