bin/create_rewrite_rules.pl: helper script to create/delete rewrite_rules described at scenario.yml files
parent
a4fbfec180
commit
79a8195738
@ -0,0 +1,127 @@
|
||||
#!/usr/bin/perl
|
||||
use strict;
|
||||
use warnings;
|
||||
|
||||
use Getopt::Std;
|
||||
use Cwd 'abs_path';
|
||||
use YAML;
|
||||
use Getopt::Long;
|
||||
use Sipwise::Provisioning::Voip;
|
||||
use Sipwise::Provisioning::Billing;
|
||||
use Sipwise::Provisioning::Config;
|
||||
|
||||
our %CONFIG = ( admin => 'cmd' );
|
||||
|
||||
my $config = Sipwise::Provisioning::Config->new()->get_config();
|
||||
|
||||
unless ($CONFIG{password} = $config->{acl}->{$CONFIG{admin}}->{password}) {
|
||||
die "Error: No provisioning password found for user $CONFIG{admin}\n";
|
||||
}
|
||||
|
||||
sub usage;
|
||||
sub call_prov;
|
||||
|
||||
my $help = 0;
|
||||
my $del = 0;
|
||||
GetOptions ("h|help" => \$help,
|
||||
"d|delete" => \$del)
|
||||
or die("Error in command line arguments\n".usage());
|
||||
|
||||
die(usage()) unless (!$help);
|
||||
die("Wrong number of arguments\n".usage()) unless ($#ARGV == 0);
|
||||
|
||||
our $bprov = Sipwise::Provisioning::Billing->new();
|
||||
our $vprov = Sipwise::Provisioning::Voip->new();
|
||||
|
||||
my $filename = abs_path($ARGV[0]);
|
||||
my $r = YAML::LoadFile($filename);
|
||||
|
||||
if ($del)
|
||||
{
|
||||
do_delete($r);
|
||||
}
|
||||
else
|
||||
{
|
||||
do_create($r);
|
||||
}
|
||||
|
||||
sub do_delete
|
||||
{
|
||||
my ($data) = @_;
|
||||
for my $rule_set_name (keys $data)
|
||||
{
|
||||
my $rule_set;
|
||||
my $result = call_prov( $vprov, 'get_rewrite_rule_sets');
|
||||
foreach (@{$result})
|
||||
{
|
||||
$rule_set->{$_->{name}} = $_->{id};
|
||||
}
|
||||
if ($rule_set)
|
||||
{
|
||||
for my $rule_set_name (keys $rule_set)
|
||||
{
|
||||
call_prov($vprov, 'delete_rewrite_rule_set', {id => $rule_set->{$rule_set_name}});
|
||||
}
|
||||
}
|
||||
}
|
||||
exit;
|
||||
}
|
||||
|
||||
sub do_create
|
||||
{
|
||||
my ($data) = @_;
|
||||
for my $rule_set_name (keys $data)
|
||||
{
|
||||
my $param = { name => $rule_set_name };
|
||||
call_prov( $vprov, 'create_rewrite_rule_set', $param );
|
||||
}
|
||||
my $rule_set;
|
||||
my $result = call_prov( $vprov, 'get_rewrite_rule_sets');
|
||||
foreach (@{$result})
|
||||
{
|
||||
$rule_set->{$_->{name}} = $_->{id};
|
||||
}
|
||||
# rules
|
||||
for my $rule_set_name (keys $data)
|
||||
{
|
||||
my $rs = $data->{$rule_set_name};
|
||||
foreach (@{$rs})
|
||||
{
|
||||
my $param = { set_id => $rule_set->{$rule_set_name}, data => $_ };
|
||||
call_prov($vprov, 'create_rewrite_rule', $param);
|
||||
}
|
||||
}
|
||||
exit;
|
||||
}
|
||||
|
||||
sub call_prov {
|
||||
# scalar, scalar, hash-ref
|
||||
my ($prov, $function, $parameter) = @_;
|
||||
my $result;
|
||||
|
||||
eval {
|
||||
$result = $prov->handle_request( $function,
|
||||
{
|
||||
authentication => {
|
||||
type => 'system',
|
||||
username => $CONFIG{admin},
|
||||
password => $CONFIG{password},
|
||||
},
|
||||
parameters => $parameter,
|
||||
});
|
||||
};
|
||||
|
||||
if($@) {
|
||||
if(ref $@ eq 'SOAP::Fault') {
|
||||
die "Voip\::$function failed: ". $@->faultstring;
|
||||
} else {
|
||||
die "Voip\::$function failed: $@";
|
||||
}
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
sub usage {
|
||||
return "Usage:\n$0 scenario.yml\n";
|
||||
}
|
||||
Loading…
Reference in new issue