From 9ce06179f43a0373d39437a431ad390ec962e3e8 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20Sabati=C3=A9?= Date: Fri, 16 Jan 2015 10:47:15 +0100 Subject: [PATCH] asterisk: merge ami and ssh remote connexion --- apps/voip/asterisk/ami/mode/showpeers.pm | 181 ------------------ apps/voip/asterisk/{ami => remote}/lib/ami.pm | 4 +- .../{ssh => remote}/mode/showpeers.pm | 73 +++++-- apps/voip/asterisk/{ami => remote}/plugin.pm | 5 +- apps/voip/asterisk/ssh/plugin.pm | 66 ------- 5 files changed, 63 insertions(+), 266 deletions(-) delete mode 100644 apps/voip/asterisk/ami/mode/showpeers.pm rename apps/voip/asterisk/{ami => remote}/lib/ami.pm (97%) rename apps/voip/asterisk/{ssh => remote}/mode/showpeers.pm (75%) rename apps/voip/asterisk/{ami => remote}/plugin.pm (95%) delete mode 100644 apps/voip/asterisk/ssh/plugin.pm diff --git a/apps/voip/asterisk/ami/mode/showpeers.pm b/apps/voip/asterisk/ami/mode/showpeers.pm deleted file mode 100644 index ccef8fdd8..000000000 --- a/apps/voip/asterisk/ami/mode/showpeers.pm +++ /dev/null @@ -1,181 +0,0 @@ -################################################################################ -# Copyright 2005-2015 MERETHIS -# Centreon is developped by : Julien Mathis and Romain Le Merlus under -# GPL Licence 2.0. -# -# This program 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 ; either version 2 of the License. -# -# This program is distributed in the hope that it will be useful, but WITHOUT ANY -# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. See the GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License along with -# this program; if not, see . -# -# Linking this program statically or dynamically with other modules is making a -# combined work based on this program. Thus, the terms and conditions of the GNU -# General Public License cover the whole combination. -# -# As a special exception, the copyright holders of this program give MERETHIS -# permission to link this program with independent modules to produce an executable, -# regardless of the license terms of these independent modules, and to copy and -# distribute the resulting executable under terms of MERETHIS choice, provided that -# MERETHIS also meet, for each linked independent module, the terms and conditions -# of the license of that module. An independent module is a module which is not -# derived from this program. If you modify this program, you may extend this -# exception to your version of the program, but you are not obliged to do so. If you -# do not wish to do so, delete this exception statement from your version. -# -# For more information : contact@centreon.com -# Authors : Mathieu Cinquin -# -#################################################################################### - -package apps::voip::asterisk::ami::mode::showpeers; - -use base qw(centreon::plugins::mode); - -use strict; -use warnings; -use centreon::plugins::misc; -use apps::voip::asterisk::ami::lib::ami; - -use Data::Dumper; - -sub new { - my ($class, %options) = @_; - my $self = $class->SUPER::new(package => __PACKAGE__, %options); - bless $self, $class; - - $self->{version} = '1.0'; - $options{options}->add_options(arguments => - { - "hostname:s" => { name => 'hostname' }, - "port:s" => { name => 'port', default => 5038 }, - "username:s" => { name => 'username' }, - "password:s" => { name => 'password' }, - "filter-name:s" => { name => 'filter_name', }, - "timeout:s" => { name => 'timeout', default => 20 }, - "protocol:s" => { name => 'protocol', }, - }); - return $self; -} - -sub check_options { - my ($self, %options) = @_; - $self->SUPER::init(%options); - - if (!defined($self->{option_results}->{hostname})) { - $self->{output}->add_option_msg(short_msg => "Please set the --hostname option"); - $self->{output}->option_exit(); - } - - if (!defined($self->{option_results}->{username})) { - $self->{output}->add_option_msg(short_msg => "Please set the --username option"); - $self->{output}->option_exit(); - } - - if (!defined($self->{option_results}->{password})) { - $self->{output}->add_option_msg(short_msg => "Please set the --password option"); - $self->{output}->option_exit(); - } - -} - - -sub run { - my ($self, %options) = @_; - - # Get data from asterisk - apps::voip::asterisk::lib::ami::connect($self); - if ($self->{option_results}->{protocol} eq 'sip' || $self->{option_results}->{protocol} eq 'SIP') - { - $self->{command} = 'sip show peers'; - } - elsif ($self->{option_results}->{protocol} eq 'iax' || $self->{option_results}->{protocol} eq 'IAX') - { - $self->{command} = 'iax2 show peers'; - } - my @result = apps::voip::asterisk::lib::ami::action($self); - apps::voip::asterisk::lib::ami::quit(); - - # Compute data - foreach my $line (@result) { - next if ($line !~ /^(\w*)\/\w* .* (OK|Unreachable) \((.*) (.*)\)/); - my ($trunkname, $trunkstatus, $trunkvalue, $trunkunit) = ($1, $2, $3, $4); - - if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' && - $trunkname !~ /$self->{option_results}->{filter_name}/) { - $self->{output}->output_add(long_msg => "Skipping trunk '" . $trunkname . "': no matching filter name"); - next; - } - - $self->{result}->{$trunkname} = {name => $trunkname, status => $trunkstatus, value => $trunkvalue, unit => $trunkunit}; - } - - # Send formated data to Centreon - my $msg; - $self->{output}->output_add(severity => 'OK', - short_msg => 'Everything is OK'); - - foreach my $name (sort(keys %{$self->{result}})) { - $msg = sprintf("Trunk: %s %s", $self->{result}->{$name}->{name}, $self->{result}->{$name}->{status}); - $self->{output}->perfdata_add(label => $self->{result}->{$name}->{name}, - value => $self->{result}->{$name}->{value}.$self->{result}->{$name}->{unit}, - # keep this lines for future upgrade of this plugin - #warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn1'), - #critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit1'), - min => 0); - if (!$self->{output}->is_status(value => $self->{result}->{$name}->{status}, compare => 'ok', litteral => 1)) { - $self->{output}->output_add(severity => $self->{result}->{$name}->{status}, - short_msg => $msg); - } - } - - $self->{output}->display(); - $self->{output}->exit(); -} - -1; - -__END__ - -=head1 MODE - -Show peers for different protocols. - -=over 8 - -=item B<--hostname> - -Hostname to query. - -=item B<--port> - -port to connect. - -=item B<--username> - -username for conection. - -=item B<--password> - -password for conection. - -=item B<--filter-name> - -Filter on trunkname (regexp can be used). - -=item B<--timeout> - -connection timeout. - -=item B<--protocol> - -show peer for this protocol (sip or iax). - -=back - -=cut diff --git a/apps/voip/asterisk/ami/lib/ami.pm b/apps/voip/asterisk/remote/lib/ami.pm similarity index 97% rename from apps/voip/asterisk/ami/lib/ami.pm rename to apps/voip/asterisk/remote/lib/ami.pm index 29f21bc58..b68635091 100644 --- a/apps/voip/asterisk/ami/lib/ami.pm +++ b/apps/voip/asterisk/remote/lib/ami.pm @@ -33,7 +33,7 @@ # #################################################################################### -package apps::voip::asterisk::lib::ami; +package apps::voip::asterisk::remote::lib::ami; use strict; use warnings; @@ -104,7 +104,7 @@ sub action { my ($self) = @_; $ami_handle->print("Action: command"); - $ami_handle->print("Command: $self->{command}"); + $ami_handle->print("Command: $self->{asterisk_command}"); $ami_handle->print(""); diff --git a/apps/voip/asterisk/ssh/mode/showpeers.pm b/apps/voip/asterisk/remote/mode/showpeers.pm similarity index 75% rename from apps/voip/asterisk/ssh/mode/showpeers.pm rename to apps/voip/asterisk/remote/mode/showpeers.pm index 6aa59d445..694dc3fd9 100644 --- a/apps/voip/asterisk/ssh/mode/showpeers.pm +++ b/apps/voip/asterisk/remote/mode/showpeers.pm @@ -33,13 +33,14 @@ # #################################################################################### -package apps::voip::asterisk::ssh::mode::showpeers; +package apps::voip::asterisk::remote::mode::showpeers; use base qw(centreon::plugins::mode); use strict; use warnings; use centreon::plugins::misc; +use apps::voip::asterisk::remote::lib::ami; sub new { my ($class, %options) = @_; @@ -51,7 +52,10 @@ sub new { $options{options}->add_options(arguments => { "hostname:s" => { name => 'hostname' }, - "remote" => { name => 'remote' }, + "port:s" => { name => 'port', default => 5038 }, + "username:s" => { name => 'username' }, + "password:s" => { name => 'password' }, + "remote:s" => { name => 'remote', default => 'ssh' }, "ssh-option:s@" => { name => 'ssh_option' }, "ssh-path:s" => { name => 'ssh_path' }, "ssh-command:s" => { name => 'ssh_command', default => 'ssh' }, @@ -68,30 +72,58 @@ sub new { sub check_options { my ($self, %options) = @_; $self->SUPER::init(%options); + + if (!defined($self->{option_results}->{hostname})) { + $self->{output}->add_option_msg(short_msg => "Please set the --hostname option"); + $self->{output}->option_exit(); + } + + if ($self->{option_results}->{remote} eq 'ami') + { + if (!defined($self->{option_results}->{username})) { + $self->{output}->add_option_msg(short_msg => "Please set the --username option"); + $self->{output}->option_exit(); + } + + if (!defined($self->{option_results}->{password})) { + $self->{output}->add_option_msg(short_msg => "Please set the --password option"); + $self->{output}->option_exit(); + } + } } sub manage_selection { my ($self, %options) = @_; - my $asterisk_command; + my @result; + if ($self->{option_results}->{protocol} eq 'sip' || $self->{option_results}->{protocol} eq 'SIP') { - $asterisk_command = 'sip show peers'; + $self->{asterisk_command} = 'sip show peers'; } elsif ($self->{option_results}->{protocol} eq 'iax' || $self->{option_results}->{protocol} eq 'IAX') { - $asterisk_command = 'iax2 show peers'; + $self->{asterisk_command} = 'iax2 show peers'; } - my $stdout = centreon::plugins::misc::execute(output => $self->{output}, + if ($self->{option_results}->{remote} eq 'ami') + { + apps::voip::asterisk::remote::lib::ami::connect($self); + @result = apps::voip::asterisk::remote::lib::ami::action($self); + apps::voip::asterisk::remote::lib::ami::quit(); + } + else + { + my $stdout = centreon::plugins::misc::execute(output => $self->{output}, options => $self->{option_results}, - sudo => $self->{option_results}->{sudo}, command => $self->{option_results}->{command}, command_path => $self->{option_results}->{command_path}, - command_options => "'".$asterisk_command."'", - trunkname => $self->{option_results}->{trunkname}); - my @lines = split /\n/, $stdout; + command_options => "'".$self->{asterisk_command}."'", + ); + @result = split /\n/, $stdout; + } - foreach my $line (@lines) { + # Compute data + foreach my $line (@result) { next if ($line !~ /^(\w*)\/\w* .* (OK|Unreachable) \((.*) (.*)\)/); my ($trunkname, $trunkstatus, $trunkvalue, $trunkunit) = ($1, $2, $3, $4); @@ -108,6 +140,7 @@ sub manage_selection { sub run { my ($self, %options) = @_; + # Send formated data to Centreon my $msg; $self->{output}->output_add(severity => 'OK', short_msg => 'Everything is OK'); @@ -144,11 +177,23 @@ Show peers for different protocols. =item B<--remote> -Execute command remotely in 'ssh'. +Execute command remotely; can be 'ami' or 'ssh' (default: ssh). =item B<--hostname> -Hostname to query (need --remote). +Hostname to query (need --remote option). + +=item B<--port> + +AMI remote port (default: 5038). + +=item B<--username> + +AMI username. + +=item B<--password> + +AMI password. =item B<--ssh-option> @@ -181,7 +226,7 @@ Filter on trunkname (regexp can be used). =item B<--protocol> -show peer for this protocol (sip or iax). +show peer for the choosen protocol (sip or iax). =back diff --git a/apps/voip/asterisk/ami/plugin.pm b/apps/voip/asterisk/remote/plugin.pm similarity index 95% rename from apps/voip/asterisk/ami/plugin.pm rename to apps/voip/asterisk/remote/plugin.pm index a92230ac4..a1a35f8f7 100644 --- a/apps/voip/asterisk/ami/plugin.pm +++ b/apps/voip/asterisk/remote/plugin.pm @@ -33,12 +33,11 @@ # #################################################################################### -package apps::voip::asterisk::ami::plugin; +package apps::voip::asterisk::remote::plugin; use strict; use warnings; use base qw(centreon::plugins::script_simple); -#use base qw(centreon::plugins::script_snmp); sub new { my ($class, %options) = @_; @@ -49,7 +48,7 @@ sub new { $self->{version} = '0.1'; %{$self->{modes}} = ( - 'showpeers' => 'apps::voip::asterisk::ami::mode::showpeers', + 'showpeers' => 'apps::voip::asterisk::remote::mode::showpeers', ); return $self; diff --git a/apps/voip/asterisk/ssh/plugin.pm b/apps/voip/asterisk/ssh/plugin.pm deleted file mode 100644 index af122aa8f..000000000 --- a/apps/voip/asterisk/ssh/plugin.pm +++ /dev/null @@ -1,66 +0,0 @@ -################################################################################ -# Copyright 2005-2014 MERETHIS -# Centreon is developped by : Julien Mathis and Romain Le Merlus under -# GPL Licence 2.0. -# -# This program 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 ; either version 2 of the License. -# -# This program is distributed in the hope that it will be useful, but WITHOUT ANY -# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A -# PARTICULAR PURPOSE. See the GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License along with -# this program; if not, see . -# -# Linking this program statically or dynamically with other modules is making a -# combined work based on this program. Thus, the terms and conditions of the GNU -# General Public License cover the whole combination. -# -# As a special exception, the copyright holders of this program give MERETHIS -# permission to link this program with independent modules to produce an executable, -# regardless of the license terms of these independent modules, and to copy and -# distribute the resulting executable under terms of MERETHIS choice, provided that -# MERETHIS also meet, for each linked independent module, the terms and conditions -# of the license of that module. An independent module is a module which is not -# derived from this program. If you modify this program, you may extend this -# exception to your version of the program, but you are not obliged to do so. If you -# do not wish to do so, delete this exception statement from your version. -# -# For more information : contact@centreon.com -# Authors : Mathieu Cinquin -# -#################################################################################### - -package apps::voip::asterisk::ssh::plugin; - -use strict; -use warnings; -use base qw(centreon::plugins::script_simple); - -sub new { - my ($class, %options) = @_; - - my $self = $class->SUPER::new(package => __PACKAGE__, %options); - bless $self, $class; - # $options->{options} = options object - - $self->{version} = '0.1'; - %{$self->{modes}} = ( - 'showpeers' => 'apps::voip::asterisk::ssh::mode::showpeers', - ); - - return $self; -} - - -1; - -__END__ - -=head1 PLUGIN DESCRIPTION - -Check Asterisk through AMI interface (ssh connection) - -=cut