#!/usr/bin/perl
########################################################################
#
# $Id: xvb-ctl,v 1.15 2024/08/15 20:02:26 gosha Exp $
#
# Copyright (c) 2014 - 2024 Okunev Igor <igor[at]prv.mts-nn.ru>
#
########################################################################
my @crypt_arr;{local($_,$^W);$_=tell DATA;seek DATA,$?,$^W=scalar @crypt_arr;read DATA,my $crypt_str,"$^F$=";seek DATA,$?,$_;@crypt_arr=map{ord($_)}split //,$crypt_str;}sub xg613_x{local$_;rd613l:{if($#_>$#crypt_arr){@crypt_arr=(@crypt_arr,@crypt_arr);redo rd613l;}}my $JGBwMOlASH="";for(my $Vd89m0QsEZ=0;$Vd89m0QsEZ<=$#_;$Vd89m0QsEZ++){$JGBwMOlASH.=chr($_[$Vd89m0QsEZ]/ ord($crypt_arr[$Vd89m0QsEZ]));}$JGBwMOlASH;}use strict;use Data::Dumper;my $KiXoNMmKU3=$ARGV[0];my $rCUGv9cT5pBRY18V06uw="list";if($KiXoNMmKU3 eq main::xg613_x(5049,4947,5616,5292,5635)){my $FZAxc2TrFwIg6qWovp0J=0;if($rCUGv9cT5pBRY18V06uw ne main::xg613_x(5049,4947,5616,5292)){my $H5BNhGPOy9Mr2C3bqSf1=main::xg613_x(4947,5865,6032,4949,5586,5145,5980,6099,1568,2205,5928,5880,1568)."'".main::xg613_x(5049,5661,5928,4949,1568,5635,5408,6327,5831,1568,5148,5096,4753,5390,5390,4949,5508,5865,1632,5049,5661,5610,5049,5355,5865,5151)."'".main::xg613_x(1632,2550,3224,2303,4900,4949,6136,2679,5390,5733,5616,5292);my @lUgRoN1yPn=`$H5BNhGPOy9Mr2C3bqSf1`;foreach my $gl2uEq7FLb(@lUgRoN1yPn){if($gl2uEq7FLb=~ m#SIP/[^\!]+\!xvb-phones\!#){$FZAxc2TrFwIg6qWovp0J++;}elsif($gl2uEq7FLb=~ m#\!macro-xvb-smartdial\!#){$FZAxc2TrFwIg6qWovp0J++;}elsif($gl2uEq7FLb=~ m#\!xvb-main\!.*show-must-go-on#){$FZAxc2TrFwIg6qWovp0J++;}}}else{my $Sf1PDnmOVv=time;my $H5BNhGPOy9Mr2C3bqSf1=main::xg613_x(4947,5865,6032,4949,5586,5145,5980,6099,1568,2205,5928,5880,1568)."'".main::xg613_x(5049,5304,5044,5390,5390,4949,5616,1824,5439,5586,5460,5047,5145,5390,4753,5684,5151,1632,3876,5661,5049,4947,5508,2397).$Sf1PDnmOVv.main::xg613_x(2346,5049,5044,5292,5292,5635,3328,6156,5145,5341,5460,5684,5635,1568,4949,5880,5916,5151,5610,5865,5355,5661,5610,1632,4998,5508,5151,5253,3264,5508,5355,5559,5355,5916,5865)."' >/dev/null";system $H5BNhGPOy9Mr2C3bqSf1;for(0..5){$H5BNhGPOy9Mr2C3bqSf1=main::xg613_x(5049,4947,6032,1568,2303,5684,5668,6384,2303).$Sf1PDnmOVv.main::xg613_x(2346,5049,5044,5292,5292,5635);$FZAxc2TrFwIg6qWovp0J=`$H5BNhGPOy9Mr2C3bqSf1`;chomp($FZAxc2TrFwIg6qWovp0J);if(length($FZAxc2TrFwIg6qWovp0J)){last;}else{sleep 1;}}unlink main::xg613_x(2397,5916,5668,5488,2303).$Sf1PDnmOVv.main::xg613_x(2346,5049,5044,5292,5292,5635);}print "$FZAxc2TrFwIg6qWovp0J\n";}elsif($KiXoNMmKU3 eq main::xg613_x(5049,5661,6084,5390,5684,4949,5928,6555)){system "/opt/VirtualPBX/contrib/utils/user_counters.pl '$ARGV[3]' $ARGV[1]";}elsif($KiXoNMmKU3 eq main::xg613_x(5049,4947,5148,5096,4949)){system "/opt/VirtualPBX/contrib/utils/mc_view.pl '$ARGV[1]' '$ARGV[2]' '$ARGV[3]'";}elsif($KiXoNMmKU3 eq main::xg613_x(5049,4947,5148,5096,4949,2205,5564,5757,5929,5635)){system "/opt/VirtualPBX/contrib/utils/mc_view.pl '' 'dump'";}elsif($KiXoNMmKU3 eq main::xg613_x(5814,5151,5616,5439,4753,4900)){system "service xvb-perl-worker restart";system "service xvb-fagi restart";system "service xvb-gearman-worker restart";system "service xvb-callblast restart";system "service httpd restart";}elsif($KiXoNMmKU3 eq main::xg613_x(5814,5151,5616,5439,4753,4900,2340,5643,4753,4851,5408,4949)){system "service memcached restart";system "/opt/VirtualPBX/contrib/utils/MemCached.pl";}elsif($KiXoNMmKU3 eq main::xg613_x(5814,5151,5616,5439,4753,4900,2340,6612,5684)){system "/opt/VirtualPBX/contrib/utils/nodes_admin/mc_cleanup";}elsif($KiXoNMmKU3 eq main::xg613_x(5100,4998,5200,4949,5292)){system "/opt/VirtualPBX/contrib/utils/db_data_cli.pl $ARGV[1] del $ARGV[2]";}elsif($KiXoNMmKU3 eq main::xg613_x(5100,4998,5200,4753,5684,4753)or $KiXoNMmKU3 eq main::xg613_x(5100,4998,6136,5145,4949,5831)){system "/opt/VirtualPBX/contrib/utils/db_data_cli.pl $ARGV[1] view $ARGV[2]";}elsif($KiXoNMmKU3 eq main::xg613_x(5916,5916,5980,5047,4949,5390)){my $dGnxJ9KdhY=$ARGV[1];if(length($dGnxJ9KdhY)==0 or !-e $dGnxJ9KdhY){DnmHOAMLGT();}system "cat $dGnxJ9KdhY | /opt/VirtualPBX/contrib/utils/tts-gen.pl $ARGV[2] $ARGV[3]";}elsif($KiXoNMmKU3 eq main::xg613_x(5712,5355,5720,4998,5439)){my $KiXoNMmKU3="/opt/VirtualPBX/contrib/utils/db_data_cli.pl $ARGV[1] view phones";my $inofgtlx9hepm28Tzdi7=`$KiXoNMmKU3`;my $VAR1;unless($inofgtlx9hepm28Tzdi7=~ s/^\x24VAR1\s+=//){print main::xg613_x(3723,5610,6032,4949,5586,5390,5044,6156,1568,4949,5928,5586,5439,5586),"\n";exit;}eval "\$VAR1 = $inofgtlx9hepm28Tzdi7";exit unless ref $VAR1 eq main::xg613_x(3672,3315,4316,3528);my $Ea8E9btsqr=$ARGV[2]||main::xg613_x(2448);my $sH5eEm9YFGIvPghBTzZa=$VAR1->{$Ea8E9btsqr}->{main::xg613_x(5610,4947,5668,4949)};if($sH5eEm9YFGIvPghBTzZa){if($VAR1->{$Ea8E9btsqr}->{main::xg613_x(5814,5151,5356,5635,4949,4851,5772,6270,4900,5635)}>time){$VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,4067,4116,3380,4788,4165,4067)}=main::xg613_x(4182,5151,5356,5145,5635,5684,5252,6498,4949,4900);}else{$VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,4067,4116,3380,4788,4165,4067)}=main::xg613_x(4335,5610,4264,4949,5047,5145,5980,6612,4949,5586,5252,4900);}if($VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,4116,3577,4004,3933)}){$VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,3332,3185,4368,3933)}=localtime($VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,4116,3577,4004,3933)});}$KiXoNMmKU3="/usr/sbin/asterisk -rx 'database get SIP/Registry ".$VAR1->{$Ea8E9btsqr}->{main::xg613_x(5610,4947,5668,4949)}."'";my $lxQCtcFDgRK5r4e8Md6w=`$KiXoNMmKU3`;$lxQCtcFDgRK5r4e8Md6w=~ s{Privilege escalation protection.*}{}s;chomp $lxQCtcFDgRK5r4e8Md6w;if($lxQCtcFDgRK5r4e8Md6w=~ s/^Value://){my @X0gCme7p9P=split(/:/,$lxQCtcFDgRK5r4e8Md6w,5);if(scalar(@X0gCme7p9P)==4){$VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,3577,3822,3640,4503)}={REG_ADDR=>$X0gCme7p9P[0],EXPIRE=>$X0gCme7p9P[1],USERNAME=>$X0gCme7p9P[2],CONTACT=>$X0gCme7p9P[3]};}else{$VAR1->{$Ea8E9btsqr}->{main::xg613_x(4182,3519,3692,4655,3577,3822,3640,4503)}={REG_ADDR=>$X0gCme7p9P[0].main::xg613_x(2958).$X0gCme7p9P[1],EXPIRE=>$X0gCme7p9P[2],USERNAME=>$X0gCme7p9P[3],CONTACT=>$X0gCme7p9P[4]};}}print Dumper($VAR1->{$Ea8E9btsqr});}}elsif($KiXoNMmKU3 eq main::xg613_x(5967,5865,5252,5586,4753,4900,5200)){my $KiXoNMmKU3="sudo -u asterisk /opt/VirtualPBX/web/cgi-bin/ai 'action=user_add&phone=000&group_id=1&user_ac=".$ARGV[1]."&user_id=".$ARGV[2]."&conf_file=".$ARGV[3]."'";my $yrHSclFTzt=`$KiXoNMmKU3`;if($yrHSclFTzt=~ /&ac=(\d+)&/){print "Created. AC: $1\n";}else{print "Error\n";}}else{DnmHOAMLGT();}sub DnmHOAMLGT{print "
Valid commands:
	calls
	counters [show|clean] ac
	cache cache-key [del|set|view] [new-value]
	cache-keys
	reload-cache
	reload-tt
	reload
	dbview ac [user|peers|phones|routes|pbook|wl|bl|c2c|calls]
	dbdel ac [cdr]
	pinfo ac phone
	ttsgen BOM-file engine voice
";exit;};package main;
__DATA__
