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/Controller/Root.pm

271 lines
6.9 KiB

package NGCP::Panel::Controller::Root;
use Moose;
use namespace::autoclean;
BEGIN { extends 'Catalyst::Controller' }
use NGCP::Panel::Widget;
#
# Sets the actions in this controller to be registered with no prefix
# so they function identically to actions created in MyApp.pm
#
__PACKAGE__->config(namespace => '');
=head1 NAME
NGCP::Panel::Controller::Root - Root Controller for NGCP::Panel
=head1 DESCRIPTION
[enter your description here]
=head1 METHODS
=head2 auto
Verify user is logged in.
=cut
sub auto :Private {
my($self, $c) = @_;
$c->log->debug("*** Root::auto called");
if($c->controller =~ /::Root\b/
or $c->controller =~ /::Login\b/) {
$c->log->debug("*** Root::auto grant access to " . $c->request->path);
return 1;
}
unless($c->user_exists) {
$c->log->debug("*** Root::auto user not authenticated");
# don't redirect to login page for ajax uris
if($c->request->path =~ /\/ajax$/) {
$c->response->body("403 - Permission denied");
$c->response->status(403);
return;
}
# store uri for redirect after login
my $target = undef;
if($c->request->method eq 'GET') {
if($c->request->uri !~ /\/logout$/) {
$target = $c->request->uri;
}
} else {
$target = $c->request->headers->referer;
}
$c->log->debug("*** Root::auto do login, target='$target'");
$c->session(target => $target);
$c->response->redirect($c->uri_for('/login'));
return;
}
$c->log->debug("*** Root::auto grant access for authenticated user");
# load top menu widgets
my $plugin_finder = NGCP::Panel::Widget->new;
my $topmenu_templates = [];
foreach($plugin_finder->instantiate_plugins($c, 'topmenu_widgets')) {
$_->handle($c);
push @{ $topmenu_templates }, $_->template;
}
$c->stash(topmenu => $topmenu_templates);
return 1;
}
=head2 index
The root page (/)
=cut
sub index :Path :Args(0) {
my ( $self, $c ) = @_;
$c->response->redirect($c->uri_for('/dashboard'));
}
=head2 default
Standard 404 error page
=cut
sub default :Path {
my ( $self, $c ) = @_;
$c->detach( '/error_page' );
}
=head2 end
Attempt to render a view, if needed.
=cut
sub end : ActionClass('RenderView') {}
sub ajax_process :Private {
my ($self,$c,@arguments) = @_;
my ($data,$columns,$searchable) = @arguments;
#Process Arguments
my $sEcho = $c->request->params->{sEcho} // "1"; #/
my $sSearch = $c->request->params->{sSearch} // ""; #/
my $iDisplayStart = $c->request->params->{iDisplayStart};
my $iDisplayLength = $c->request->params->{iDisplayLength};
my $iSortCol_0 = $c->request->params->{iSortCol_0};
my $sSortDir_0 = $c->request->params->{sSortDir_0};
my $iIdOnTop = $c->request->params->{iIdOnTop};
#parse $data into $aaData
my $aaData = [];
for my $row (@$data) {
my @aaRow = @$row{@$columns};
#my %aaRow = %$row; #in case of using mData
if (grep /$sSearch/, @aaRow[@$searchable]) {
push @$aaData, \@aaRow;
}
}
#Sorting
if(defined($iSortCol_0) && defined($sSortDir_0)) {
if($sSortDir_0 eq "asc") {
@$aaData = sort {$a->[$iSortCol_0] cmp
$b->[$iSortCol_0]} @$aaData;
} else {
@$aaData = sort {$b->[$iSortCol_0] cmp
$a->[$iSortCol_0]} @$aaData;
}
}
#potentially selected Id (search it (col 0) and move on top)
if( defined($iIdOnTop) ) {
my $elem;
for (my $i=0; $i<@$aaData; $i++) {
if(@$aaData[$i]->[0] == $iIdOnTop) {
$elem = splice(@$aaData, $i, 1);
unshift(@$aaData, $elem);
}
}
}
my $totalRecords = scalar(@$data);
my $totalDisplayRecords = scalar(@$aaData);
#Pagination
if($iDisplayStart || $iDisplayLength ) {
my $endIndex = $iDisplayLength+$iDisplayStart-1;
$endIndex = $#$aaData if $endIndex > $#$aaData;
@$aaData = @$aaData[$iDisplayStart .. $endIndex];
}
$c->stash(aaData => $aaData,
iTotalRecords => $totalRecords,
iTotalDisplayRecords => $totalDisplayRecords);
$c->stash(sEcho => $sEcho);
}
sub ajax_process_resultset :Private {
my ($self,$c,@arguments) = @_;
my ($rs,$columns,$searchable) = @arguments;
#Process Arguments
my $sEcho = $c->request->params->{sEcho} // "1"; #/
my $sSearch = $c->request->params->{sSearch} // ""; #/
my $iDisplayStart = $c->request->params->{iDisplayStart};
my $iDisplayLength = $c->request->params->{iDisplayLength};
my $iSortCol_0 = $c->request->params->{iSortCol_0};
my $sSortDir_0 = $c->request->params->{sSortDir_0};
my $iIdOnTop = $c->request->params->{iIdOnTop};
#will contain final data to be sent
my $aaData = [];
my $totalRecords = $rs->count;
my @searchdata = map{ +{ $_ => { like => '%'.$sSearch.'%' } } } @$columns[@$searchable];
$rs = $rs->search(\@searchdata);
#potentially selected Id as first element
if (defined($iIdOnTop)) {
my $topRow = $rs->find($iIdOnTop);
if (defined($topRow)) {
my %tmpTopRow = $topRow->get_columns;
my @tmpTopRowArray = @tmpTopRow{@$columns};
push @$aaData, \@tmpTopRowArray;
$rs = $rs->search({ id => { '!=', $iIdOnTop}});
}
}
#Sorting
if(defined($iSortCol_0) && defined($sSortDir_0)) {
my $sortdata = {
order_by => {
"-".$sSortDir_0 => $columns->[$iSortCol_0],
}};
$rs = $rs->search(undef, $sortdata);
}
my $totalDisplayRecords = $rs->count;
#Pagination
if (defined($iDisplayStart) && $iDisplayLength) {
$rs = $rs->search(
undef,
{
offset => $iDisplayStart,
rows => $iDisplayLength,
});
}
for my $row ($rs->all) {
my %tmpRow = $row->get_columns;
my @aaRow = @tmpRow{@$columns};
push @$aaData, \@aaRow;
}
$c->stash(
aaData => $aaData,
iTotalRecords => $totalRecords,
iTotalDisplayRecords => $totalDisplayRecords
);
$c->stash(sEcho => $sEcho);
}
sub error_page :Private {
my ($self,$c) = @_;
$c->log->info( 'Failed to find: ' . $c->request->path );
$c->stash(template => 'error_page.tt');
#$c->response->body( 'Page not found' );
$c->response->status(404);
}
=head1 AUTHOR
Andreas Granig,,,
=head1 LICENSE
This library is free software. You can redistribute it and/or modify
it under the same terms as Perl itself.
=cut
__PACKAGE__->meta->make_immutable;
1;
# vim: set tabstop=4 expandtab: