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.
187 lines
6.1 KiB
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:
|