1 package SL::Dispatcher::AuthHandler::Admin;
 
   4 use parent qw(Rose::Object);
 
   6 use SL::Layout::Dispatcher;
 
   9   my ($self, %params) = @_;
 
  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   $::request->layout->no_menu(1);
 
  27   $::auth->delete_session_value('admin_password');
 
  28   $::auth->punish_wrong_login;
 
  29   SL::Dispatcher::show_error('admin/adminlogin', 'password');