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.
ngcp-api-tools/bin/ngcp-create-soundset

189 lines
3.5 KiB

#!/usr/bin/perl
use strict;
use warnings;
use English;
use Getopt::Long;
use Pod::Usage;
use NGCP::API::Client;
use Readonly;
Readonly my @required => qw(reseller_id name);
my $opts = {
type => 'sipaccount',
status => 'active',
verbose => 0,
};
sub parse_option {
my ($name, $value) = @_;
$name =~ tr/-/_/;
$opts->{$name} = $value;
}
GetOptions($opts,
'help|h' => sub { usage() },
'reseller-id=i' => \&parse_option,
'name=s',
'description=s',
'copy-from-default' => \&parse_option,
'contract-default' => \&parse_option,
'language=s' => \&parse_option,
'loop-play' => \$opts->{loopplay}, # Use the name as on the remote API.
'verbose',
) or usage();
sub check_params {
my @missing;
foreach my $param (@required) {
push @missing, $param unless $opts->{$param};
}
usage(join(' ', @missing)) if scalar @missing;
return;
}
sub usage {
my $missing = shift;
pod2usage(
-exitval => $missing ? 1 : 0,
-verbose => 99,
-sections => 'SYNOPSIS|REQUIRED ARGUMENTS|OPTIONS',
-message => $missing ? "Missing parameters: $missing" : '',
);
return;
}
sub main {
check_params();
my $client = NGCP::API::Client->new(verbose => $opts->{verbose});
my $uri = '/api/soundsets/';
my %data = map {
$_ => $opts->{$_};
} grep {
length $opts->{$_}
} qw(reseller_id name description copy_from_default contract_default loopplay language status);
my $res = $client->request('POST', $uri, \%data);
print $res->result . "\n";
return !$res->is_success;
}
exit main();
__END__
=head1 NAME
ngcp-create-soundset - create a soundset
=head1 SYNOPSIS
B<ngcp-create-soundset> [I<options>...] I<required-arguments>...
=head1 DESCRIPTION
B<This program> creates a soundset on the NGCP platform.
=head1 REQUIRED ARGUMENTS
=over 8
=item B<--reseller-id> I<rid>
Reseller id. Default 1.
=item B<--name> I<soundset-name>
Soundset name.
=back
=head1 OPTIONS
=over 8
=item B<--contract-default>
If enabled the sound set is used for all existing and new subscribers within the customer.
=item B<--copy-from-default>
Use system default sound files.
=item B<--description> I<description>
Description of the soundset default empty.
=item B<--language> I<language>
The language of the default sound files.
=item B<--loop-play>
Play files in a loop.
=item B<--verbose>
Show additional debug information. Default false.
=item B<--help>
Print a brief help message.
=back
=head1 EXIT STATUS
=over
=item B<0>
Command completed successfully.
=item B<1>
Command failed with errors.
=back
=head1 SEE ALSO
NGCP::API::Client
=head1 BUGS AND LIMITATIONS
Please report problems you notice to the Sipwise
Development Team <support@sipwise.com>.
=head1 AUTHOR
Alessio Garzi <agarzi@sipwise.com>
=head1 LICENSE
Copyright (C) 2021 Sipwise GmbH, Austria
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 3 of the License, or
(at your option) any later version.
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 <http://www.gnu.org/licenses/>.
=cut