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-panel/lib/NGCP/Panel/Role/API/CallRecordings.pm

187 lines
6.1 KiB

package NGCP::Panel::Role::API::CallRecordings;
use NGCP::Panel::Utils::Generic qw(:all);
use Sipwise::Base;
use parent 'NGCP::Panel::Role::API';
use boolean qw(true);
use Data::HAL qw();
use Data::HAL::Link qw();
use HTTP::Status qw(:constants);
use NGCP::Panel::Utils::Subscriber;
sub item_name {
return 'callrecording';
}
sub resource_name {
return 'callrecordings';
}
sub get_form {
my ($self, $c) = @_;
return NGCP::Panel::Form::get("NGCP::Panel::Form::CallRecording::Recording", $c);
}
#Todo: maybe put it into Entities as common checking for all collections?
sub validate_request {
my($self, $c) = @_;
my $method = uc($c->request->method);
if ($method eq 'GET') {
if($c->req->param('tz') && !DateTime::TimeZone->is_valid_name($c->req->param('tz'))) {
$self->error($c, HTTP_UNPROCESSABLE_ENTITY, "Query parameter 'tz' value is not a valid time zone");
return;
}
}
return 1;
}
sub _item_rs {
my ($self, $c) = @_;
my $item_rs = $c->model('DB')->resultset('recording_calls')->search_rs(
undef, undef); #{ prefetch => 'recording_metakeys' }
my $join_idx = 0;
if($c->user->roles eq "reseller") {
my $res_rs = $c->model('DB')->resultset('voip_subscribers')->search({
'contact.reseller_id' => $c->user->reseller_id
},{
join => { 'contract' => 'contact' }
});
$join_idx += 1;
$item_rs = $item_rs->search({
status => { -in => [qw/completed confirmed/] },
$self->get_join_alias('recording_metakeys%s.key',$join_idx) => 'uuid',
$self->get_join_alias('recording_metakeys%s.value',$join_idx) => { -in => $res_rs->get_column('uuid')->as_query }
},undef);
} elsif ($c->user->roles eq "subscriberadmin") {
my $res_rs = $c->model('DB')->resultset('provisioning_voip_subscribers')->search({
'account_id' => $c->user->account_id
});
$join_idx += 1;
$item_rs = $item_rs->search({
status => { -in => [qw/completed confirmed/] },
$self->get_join_alias('recording_metakeys%s.key',$join_idx) => 'uuid',
$self->get_join_alias('recording_metakeys%s.value',$join_idx) => { -in => $res_rs->get_column('uuid')->as_query }
},undef);
} elsif ($c->user->roles eq "subscriber") {
$join_idx += 1;
$item_rs = $item_rs->search({
status => { -in => [qw/completed confirmed/] },
$self->get_join_alias('recording_metakeys%s.key',$join_idx) => 'uuid',
$self->get_join_alias('recording_metakeys%s.value',$join_idx) => $c->user->uuid,
},undef);
}
if($c->req->params->{subscriber_id}) {
my $res_rs = $c->model('DB')->resultset('voip_subscribers')->search({
id => $c->req->params->{subscriber_id}
});
$join_idx += 1;
$item_rs = $item_rs->search({
$self->get_join_alias('recording_metakeys%s.key',$join_idx) => 'uuid',
$self->get_join_alias('recording_metakeys%s.value',$join_idx) => { -in => $res_rs->get_column('uuid')->as_query }
},undef);
}
$item_rs = $self->apply_caller_filter(
rs => $item_rs,
params => $c->req->params,
conjunctions => { 'recording_metakeys%s.key' => 'caller', },
col => 'recording_metakeys%s.value',
join_idx => \$join_idx,
);
$item_rs = $self->apply_callee_filter(
rs => $item_rs,
params => $c->req->params,
conjunctions => { 'recording_metakeys%s.key' => 'callee', },
col => 'recording_metakeys%s.value',
join_idx => \$join_idx,
);
if ($join_idx > 0) {
$item_rs = $item_rs->search_rs(undef,{
distinct => 1,
join => [ ('recording_metakeys') x $join_idx ],
});
}
return $item_rs;
}
sub hal_links {
my($self, $c, $item, $resource, $form) = @_;
my $res_rs = $item->recording_metakeys->search({
key => 'uuid'
});
my @sub_ids = $c->model('DB')->resultset('voip_subscribers')->search({
uuid => { -in => $res_rs->get_column('value')->as_query }
})->get_column('id')->all;
return [
(map { Data::HAL::Link->new(relation => 'ngcp:subscribers', href => sprintf("/api/subscribers/%d", $_)) } @sub_ids),
Data::HAL::Link->new(relation => 'ngcp:callrecordingstreams', href => sprintf("/api/callrecordingstreams/?recording_id=%d", $item->id)),
];
}
sub resource_from_item {
my ($self, $c, $item, $form) = @_;
my %resource = ();
$resource{id} = int($item->id);
$resource{status} = $item->status;
$resource{callid} = $item->call_id;
my $caller_meta_row = $item->recording_metakeys->search({key => 'caller'})->first;
$resource{caller} = $caller_meta_row ? $caller_meta_row->value : undef;
my $callee_meta_row = $item->recording_metakeys->search({key => 'callee'})->first;
$resource{callee} = $callee_meta_row ? $callee_meta_row->value : undef;
my $datetime_fmt = DateTime::Format::Strptime->new(
pattern => '%F %T',
);
my $tz = $c->req->param('tz');
unless($tz && DateTime::TimeZone->is_valid_name($tz)) {
$tz = undef;
}
if($item->start_timestamp) {
if($tz) {
$item->start_timestamp->set_time_zone($tz);
}
$resource{start_time} = $datetime_fmt->format_datetime($item->start_timestamp);
# no need to show millisec precision here, I guess...
#$resource{start_time} .= '.'.sprintf("%03d",$item->start_timestamp->millisecond)
# if $item->start_timestamp->millisecond > 0.0;
} else {
$resource{start_time} = undef;
}
if($item->end_timestamp) {
if($tz) {
$item->end_timestamp->set_time_zone($tz);
}
$resource{end_time} = $datetime_fmt->format_datetime($item->end_timestamp);
#$resource{end_time} .= '.'.sprintf("%03d",$item->end_timestamp->millisecond)
# if $item->end_timestamp->millisecond > 0.0;
} else {
$resource{end_time} = undef;
}
return \%resource;
}
1;
# vim: set tabstop=4 expandtab: