1 package SL::Dispatcher::AuthHandler::Admin;
4 use parent qw(Rose::Object);
6 use SL::Layout::Dispatcher;
9 my ($self, %params) = @_;
11 %::myconfig = User->get_default_myconfig;
13 my $ok = $::auth->is_api_token_cookie_valid;
14 $ok ||= $::form->{'{AUTH}admin_password'} && ($::auth->authenticate_root($::form->{'{AUTH}admin_password'}) == $::auth->OK());
15 $ok ||= !$::form->{'{AUTH}admin_password'} && ($::auth->authenticate_root($::auth->get_session_value('admin_password')) == $::auth->OK());
16 $ok ||= $params{action} eq 'login';
18 $::auth->create_or_refresh_session;
21 $::auth->delete_session_value('FLASH');
25 $::request->{layout} = SL::Layout::Dispatcher->new(style => 'admin');
26 $::auth->delete_session_value('admin_password');
27 $::auth->punish_wrong_login;
28 SL::Dispatcher::show_error('admin/adminlogin', 'password');