package NGCP::Panel::Controller::API::TimeSets; use NGCP::Panel::Utils::Generic qw(:all); use Sipwise::Base; use parent qw/NGCP::Panel::Role::Entities NGCP::Panel::Role::API::TimeSets/; use HTTP::Status qw(:constants); use NGCP::Panel::Utils::TimeSet; __PACKAGE__->set_config({ allowed_roles => [qw/admin reseller/], }); sub allowed_methods{ return [qw/GET POST OPTIONS HEAD/]; } sub api_description { return 'Defines a collection of (generic) Time Sets, which can each specify a number of ' . '(recurring) time-slots, which can be currently used in PeeringRules to select certain peerings.'; } sub query_params { return [ { param => 'reseller_id', description => 'Filter for Time Sets belonging to a specific reseller', query_type => 'string_eq', }, { param => 'name', description => 'Filter for items matching a Time Set name pattern', query_type => 'string_like', }, ]; } sub create_item { my ($self, $c, $resource, $form, $process_extras) = @_; my $schema = $c->model('DB'); my $tset; try { # # no checks, they are in check_resource $tset = NGCP::Panel::Utils::TimeSet::create_timesets( c => $c, resource => $resource ); } catch($e) { $c->log->error("failed to create timeset: $e"); $self->error($c, HTTP_INTERNAL_SERVER_ERROR, "Failed to create timeset."); return; } return $tset; } 1; # vim: set tabstop=4 expandtab: