package Portal::Api::admin::Articles;
=head1 NAME
Portal articles manage
# Рекомендуем в подах записывать к каким
# группам эндпойнтов относится данный контроллер
Endpoints:
/portal/articles/*
=cut
use strict;
use warnings FATAL => 'all';
use Control::Errors;
# Импортируем объект Portal для работы с базой
# он должен находиться в /usr/abills/Abills/mysql/Portal.pm
use Portal; use Portal::Misc::Attachments;
my Control::Errors $Errors;
my Portal $Portal;
my Portal::Misc::Attachments $Attachments;
#**********************************************************
=head2 new($db, $admin, $conf)
=cut
#**********************************************************
sub new {
my ($class, $db, $admin, $conf, $attr) = @_;
my $self = {
db => $db,
admin => $admin,
conf => $conf,
attr => $attr
};
bless($self, $class);
$Portal = Portal->new($db, $admin, $conf);
$Attachments = Portal::Misc::Attachments->new($self->{db}, $self->{admin}, $self->{conf});
# Определяем словарь ошибок, который нам пришёл выше
$Errors = $self->{attr}->{Errors};
return $self;
}
#**********************************************************
=head2 get_portal_articles($path_params, $query_params)
# Всегда пишите в подах Endpoint *METHOD* *path*
# Это позволит легче искать путь во время разработки.
Endpoint GET /portal/articles
=cut
#**********************************************************
sub get_portal_articles {
my $self = shift;
my ($path_params, $query_params) = @_;
# Определяем системные параметры, сортировки, пагинации
my %PARAMS = (
COLS_NAME => 1,
PAGE_ROWS => $query_params->{PAGE_ROWS} ? $query_params->{PAGE_ROWS} : 25,
SORT => $query_params->{SORT} ? $query_params->{SORT} : 1,
PG => $query_params->{PG} ? $query_params->{PG} : 0,
DESC => $query_params->{DESC},
);
# Даём возможность сортировки с помощью ?filename&file_size&file_type
foreach my $param (keys %{$query_params}) {
$query_params->{$param} = ($query_params->{$param} || "$query_params->{$param}" eq '0')
? $query_params->{$param}
: '_SHOW';
}
# Вызываем функцию для извлечения списка из базы, с нашими параметрами и которые определены вызовом
# которые будут внутри обрабатываться search_former my $list = $Portal->portal_articles_list({ %$query_params, %PARAMS });
my @result = map {
my $article_sublink = $_->{permalink} || $_->{id};
my $picture_link = $_->{picture} ? $self->_portal_picture_link($_->{picture}) : '';
$_->{url} = $self->_portal_news_link($article_sublink);
$_->{picture} = $picture_link;
$_
} @$list; # Рекомендация: когда вы создаёте путь, который возвращает массив, то возвращайте
# его с объектом с ключём list, а в total возвращайте общее число айтемов - это позволит работать пагинации
return {
list => \@result,
total => $Portal->{TOTAL}
};
}
|