From 45a4cd83c9a971ced0a11d339aac1d072ad3304c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?David=20Sabati=C3=A9?= Date: Tue, 13 Jan 2015 18:46:58 +0100 Subject: [PATCH] asterisk: merge sipshowpeers and iaxshowpeers --- .../asterisk/ami/mode/{iax => }/showpeers.pm | 18 +- .../ami/mode/sip/.asterisk_sipshowpeer.pm.swo | Bin 16384 -> 0 bytes .../ami/mode/sip/.asterisk_sipshowpeer.pm.swp | Bin 16384 -> 0 bytes .../asterisk/ami/mode/sip/.showpeers.pm.swp | Bin 24576 -> 0 bytes apps/voip/asterisk/ami/mode/sip/showpeers.pm | 169 ------------------ apps/voip/asterisk/ami/plugin.pm | 3 +- 6 files changed, 16 insertions(+), 174 deletions(-) rename apps/voip/asterisk/ami/mode/{iax => }/showpeers.pm (91%) delete mode 100644 apps/voip/asterisk/ami/mode/sip/.asterisk_sipshowpeer.pm.swo delete mode 100644 apps/voip/asterisk/ami/mode/sip/.asterisk_sipshowpeer.pm.swp delete mode 100644 apps/voip/asterisk/ami/mode/sip/.showpeers.pm.swp delete mode 100644 apps/voip/asterisk/ami/mode/sip/showpeers.pm diff --git a/apps/voip/asterisk/ami/mode/iax/showpeers.pm b/apps/voip/asterisk/ami/mode/showpeers.pm similarity index 91% rename from apps/voip/asterisk/ami/mode/iax/showpeers.pm rename to apps/voip/asterisk/ami/mode/showpeers.pm index 5ea0fe5d5..dabfb6b40 100644 --- a/apps/voip/asterisk/ami/mode/iax/showpeers.pm +++ b/apps/voip/asterisk/ami/mode/showpeers.pm @@ -33,7 +33,7 @@ # #################################################################################### -package apps::voip::asterisk::ami::mode::iax::showpeers; +package apps::voip::asterisk::ami::mode::showpeers; use base qw(centreon::plugins::mode); @@ -58,6 +58,7 @@ sub new { "password:s" => { name => 'password' }, "filter-name:s" => { name => 'filter_name', }, "timeout:s" => { name => 'timeout', default => 20 }, + "protocol:s" => { name => 'protocol', }, }); return $self; } @@ -89,7 +90,14 @@ sub run { # Get data from asterisk apps::voip::asterisk::lib::ami::connect($self); - $self->{command} = 'iax2 show peers'; + if ($self->{option_results}->{protocol} eq 'sip' || $self->{option_results}->{protocol} eq 'SIP') + { + $self->{command} = 'sip show peers'; + } + elif ($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(); @@ -136,7 +144,7 @@ __END__ =head1 MODE -List partitions. +Show peers for different protocols. =over 8 @@ -164,6 +172,10 @@ Filter on trunkname (regexp can be used). connection timeout. +=item B<--protocol> + +show peer for this protocol (sip or iax). + =back =cut diff --git a/apps/voip/asterisk/ami/mode/sip/.asterisk_sipshowpeer.pm.swo b/apps/voip/asterisk/ami/mode/sip/.asterisk_sipshowpeer.pm.swo deleted file mode 100644 index 45abee12a90257be516c766f272cc9424e89efa5..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16384 zcmeI2TWlOx8OIOh>Of1B@KB!kvb)5)$$DmX-Oy$on`~_-*%CWucbzuGi8DKUcK49k zIn%k=u}nZh0vd!+RS**5QXx?!9zci(5aO-n_5?3b5E2(bp`wTYbRBZ zcmXjh{jxjf`hEZNo$t&z)3Gi#mgqsF%J4bJ*f(2WZ9n_g1MJg>7z?C~RPo(DLq|+G zJe(u{Po&?k+V}nH^m_DtYhQhOnSEsnWC~;oWC~;oWC~;oWC~;o zWC~;oWC~;oWD5KjDqwe$Xa70%2LSy4|LFPuPj6=IkKjw-i=YdRf?waq*w4W8;FF*Q z4uco&W$ZWL^WYjd1P+4ly@|1>z?0zP;KN`I)WAdFr8hG61uzE=fnOb9>=)q2U>iIJ zE`l~V1!}+m1&{;xfxk>J_Gj=S_&xXu_&WF+_!#&oxCJDrgDG$r{QV7#{SEvMya2uf zo&z5OOW-`10|X9$3Gm|U8T&4H2HXNqfXko`ra&1S1TVjiu^)jSf^UP*fh}+e%z`pF z4(!U0KN~t1-=443qAvGfscUqfHtUuw}D?G9-akX22TSCI9LEWR&*>AJ~x^ASAG0I zco7vs-xYYDBaGe1$gO#~8K!IT&u&vyGTxA8_goq|${B^}-JaV_^-v$tqhgo$gvYzZ z!gQ&`Ciah0F>*E4y}H}IpxzSk>>;Pw_mg?GxVCw$v}WR8GLBL4!n@wL>IK|(26o5g zB`U5Jjbm%2l6l7gU}$7Vai~mQ-)-RxA zaAKSFq_%*HrxWQ)j19N;h%%ED=*g4cBd=z#AAIRg%{i_Nc@ZXT-(;Hu;c_Y#3of)$ z#_AS*9;xdR*dPR%597fzzPl{Cx2(Y`>g~XxDsJx==&~suLQ^VAP6c!dQHs%*o!4vJc8*(k;zdMq0R*Bdu0Lpf33}3k4IEYzSTQzs=b9_lD)0f!6dUZ`Ci`IjQx7onuJk06YN$N7MCw>PbOMU z-b~yX>8ASL5F2uR7<x+CQnL7?P%Y?EPr|Qg5LVE zD~S(E7TCaVh%kcu+EP_Ed6V9`_YyIE!kT^v=Yw)jX|}(gDjVyUUZP*cGEP`V#dyaF z^w!+zhT50@Q9#$Hfd$AMBRm?dp$lIv!#b?lJqGpS%*gOOJOs&R>83nO-y+U2SAsn8hUUEa43d!{CXkbQi=Y`Ml*E`ANkz?w3-g#$qWZrnY z^<;cKurRnbM5T9{BGFYzt|yQwM5wYHfzun z)8>E&$_LnAcU^=tZcmVtpjRrXI!Syul*ma%7-uS#;l+-JG9WEV$-qEO=pL#pUoomg zRjXo|m5OOSKozT2sc5Cn##l2u#*Na$G7jiezk{#SejsssGQ<&qGsVDGo6{>ik2@Be z71Y_HrtC`BA8>kiEVwerb=3lo&4}@dtZnuWpuJ<+moUiJ%V2g|hDsw>rPS7M=3pRl?x5Katd)SWEc!a@gXD82Zc z&IFuOOZK8oJ5UNTIlvD>AA4aWlRaIpc=ZLN-qOr_M>c}IKR`eshje)aA#it)r=`W_{JHvayZ&(Fe4~Ad(Bw>`y}a0J(U}WPs?$on z*>23Qp077)Wwp6-p|xlbwO~1HLH|x1(W8y_xeKdpsxM!nN9)ZdhPyPQWss=lxLMGK zW5HZR48h&N_M$B~gaO)W8>B+1J=n!z5(o^7mLlmmz>$j)?1)5!VUcM%h>wu>Vz;b) zuADqs(fVT~rARnPLRHDNM`hYw@0p$0s1hOo9Uh52j`1K-SM;{jTq>nvS78+7y&>|$ z-B;i?e|l<_!*rErbmTg=hsE7>R857HYRW)+GrzMHit{DClkT|Z=#<(|YA2q?$uQc9 zh79_8%O26M;CF;)B5}AhwaL`;|8sb*SI_$D`5%vd`twg*|06AbN!4YaOo2>+Oo2>+ sOo2>+Oo2>+Oo2>+Oo2>+Oo2>+{{;o|v>}GIaLbGA8?);9U;WMbU#1ho^Z)<= diff --git a/apps/voip/asterisk/ami/mode/sip/.asterisk_sipshowpeer.pm.swp b/apps/voip/asterisk/ami/mode/sip/.asterisk_sipshowpeer.pm.swp deleted file mode 100644 index 5296ed9aaa51dcf9dc0c158fe574acfaab281f2a..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 16384 zcmeHNTWlOx89tP20xeO(LwVxQ?h@}N>zUnkLz{JMvbCLfOYE54b=nXo&g{(D-9u*Q zOy^?9G64w*Xb`F@K)i6NkSG!l6^I8A;*D~9f)^+ViHo36QN$BaUbubd%&fh3QU!?@ z5Hr%3ojI5P{Qvh~&Wv-qm5a?KdeEpbT!$F@^3`WMUw`XC_GF&1K*~rp-|ZUOV$$Z} z)ZNCJaTu7c=$f9@7cw+`H|`5BG;Quh0hiw7sKN66(6qvc2O_*~4yD7*Q20A7>v#wU za?|HLF#O@&md*Mz1~LXT1NXA2TD78X^SPsRrWrEpNxTwfsBESfsBESfsBESfsBES zfsBESfsBESf&W4VEGPN)pH+VV!2kb`zW@LDX2$*id=dBp-~h*fU){&pPl4xwPXcY= z2=KzajQtw;9B>Ud3>*T!`zFRd4m<@s349n>1M0v-z)Npr?DN1Za2WXILB@U#{0P_v z9s@1{9pE%j2MnM9fzUj@Dbd<^&~a0`$?1DFJk0DpS}V}AvH z3%me)8+Z=*5U>QC2W9~R4gv>&7hliVcYtSrTfh^*WuO5}0%hP3@bc>z`yucH;G4i_ zfi2(?Fawl<6Ttnz%dchZFTnG_*MLs|9|W!fE#NJ{VSoX@e+^^50iFS#20jHm1zZMJ zfk%Kvpak3x{0x7v`3dlS;CsL~fM$@ZDfgJk9!g?ub+GZnVcePzF zmFU02EBN4KeB2X`QS@`a@KZb$cs>6 z`zG5Q2$xf_Sa89WQdW=X^GH3H$nqR$qWg}5lZEAZn!B*H)L5Q3B@{|VYmXLlIY`{o z(6A#Ry*jzFFMB=Jow&B(bx)i~2-x*?Au;GOIrcylN{5rI)>k4P0e=~BcWr-_LY%PTjffvXe)b^jrA%4=R1hE}wb zQg`CHII%3Ff$;jYG}3NjKe4wlJtv1lxJn1Ko!sxAGjc}StwiMW)Z&lFJd7v}R@tK= z4@0ZZLj$KjmXiBAHR5Q1<5$AAlt;<3ZSF_hVfhvhed&d~PVE?tVK|DhSBi;+4af=W zlm^6}cxiJx;87jntZ#0!ay3lS6C>jE_O>x2GZAybOO0%EM6sGdD!E~pBX}BDvFAeR z@gQrA4wNOyqr-4tTBOWb4%yQ4xQ_A>Z;*Zfv9cnAh-PM0It9^=E2Pi8;-UoKs%wCo zvd&iI96aywO~&LGoHYi%41HU1{2=r@BRolc(dgtCp#PrF^)I-=GlzED?{qt1Y*u3-+^Qsl& zWW}f&?>LFsdU_iC%6gm*By~KHRCx?xJlm#G)}wo38vBqgF55fRpoDp68m)5|)4n~M zjB3AJxuUA{n4Dapnp304Yl_}nb{H8urMQj_rBpCWTGgc1&0OnRA=i6Sp>hpMrWF)< z0%daJ;o`}NdNTGL7`v?(JW71Saw!)e$wk1&gKIjMtdhvVB;JE?co3B!5O#!z{M++n zTfWs5*r){$XRJ7q2>71v=~+YJZq1C$V0qNY14&${yHPCY_7y8Y-r<~PNUBO%D7jm8 z)uZd`rf^+KD>1d3D`phL-t{Uud_&kgDZS)|G#QfVThYLbm=lF1|6)bYG?W^|<9 z_*u~PM7|a*46YSX<((!;II76?1S*9HRh0vskuDlktX67e@GHw?7)H7yU`oX8ff_8a zd!l+m|1vcjkCkb@u{htBxMv$>I(dpZdbv6g&N}U2t?rRAWusRt+~a&i7@1Bv$MR=ZqwNdEo#t8 zqt$87t)6eRXl1pva-qFo5VfH>biw>?9MPlA&fnJ>}&v_42fiT-);C++9P}QYfjW474?KJE>5dE9p$SW6sfOl}{=Y&tPX5WuhU2 zzE0Vr`UrkkcqR&mOOu;Seg8j)?|SvEufG5B>8G!M;Q8-q`%9`XyD|nc1~LXR1~LXR q1~LXR1~LXR1~LXR1~LXR2L2Zq$kT=x*266?vTn?%?|=0-=YIjo7s>em diff --git a/apps/voip/asterisk/ami/mode/sip/.showpeers.pm.swp b/apps/voip/asterisk/ami/mode/sip/.showpeers.pm.swp deleted file mode 100644 index 6c94a68f62398ab52858e5e0181edb04eff1b1eb..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 24576 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. -# -# 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::sip::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 }, - }); - 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); - $self->{command} = 'sip 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) = ($1, $2, $3); - - 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}; - } - - # 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}, - # 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 - -List partitions. - -=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. - -=back - -=cut diff --git a/apps/voip/asterisk/ami/plugin.pm b/apps/voip/asterisk/ami/plugin.pm index ae8c113ca..32344c00f 100644 --- a/apps/voip/asterisk/ami/plugin.pm +++ b/apps/voip/asterisk/ami/plugin.pm @@ -49,8 +49,7 @@ sub new { $self->{version} = '0.1'; %{$self->{modes}} = ( - 'sipshowpeers' => 'apps::voip::asterisk::ami::mode::sip::showpeers', - 'iaxshowpeers' => 'apps::voip::asterisk::ami::mode::iax::showpeers', + 'showpeers' => 'apps::voip::asterisk::ami::mode::showpeers', ); return $self;