...
Code Block | ||||
---|---|---|---|---|
| ||||
# Мы объявляем package с названием "*модуль*::Api". package Portal::Api; =head1 NAME Portal Api =cut use strict; use warnings FATAL => 'all'; # Импортируем сообщения для ошибок use Control::Errors; my Control::Errors $Errors; #********************************************************** =head2 new($db, $conf, $admin, $lang, $debug, $type) =cut #********************************************************** # Создаём конструктор sub new { my ($class, $db, $admin, $conf, $lang, $debug, $type) = @_; my $self = { db => $db, admin => $admin, conf => $conf, lang => $lang, debug => $debug }; bless($self, $class); $Errors = Control::Errors->new($self->{dbroutes_list}, $self->{admin}, $self->{conf}, = (); # Определяем, #для Обязательночего обозначитьроутер чтовызвал этонаш замодуль модуль,API # чтобыСоответственно, системали моглаэто подгрузитьUSER сообщенияAPI дляили ошибокADMIN со словаря модуля за потребностиAPI # И { lang => $lang, module => 'Portal' } ); записываем routes_list if ($type eq 'user') { $self->{routes_list} = $self->user_routes(); # Определяем, для чего роутер вызвал наш модуль API # Соответственно, ли это USER API или ADMIN API # И записываем routes_list if ($type eq 'user') { $self->{routes_list} = $self->user_routes(); } elsif ($type eq 'admin') { $self->{routes_list} = $self->admin_routes(); } return } elsif ($type eq 'admin') { $self->{routes_list} = $self->admin_routes(); } $Errors = Control::Errors->new($self->{db}, $self->{admin}, $self->{conf}, # Обязательно обозначить что это за модуль, # чтобы система могла подгрузить сообщения для ошибок со словаря модуля за потребности { lang => $lang, module => 'Portal' } ); # Сохраняем словарь ошибок в объект, он нам потом будет нужен $self->{Errors} = $Errors; return $self; } 1; |
Создание роутов для ADMIN API
...