You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
128 lines
3.1 KiB
128 lines
3.1 KiB
#!/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";
|
|
}
|