package SL::Dispatcher::AuthHandler::Admin;
use strict;
-
use parent qw(Rose::Object);
+use SL::Controller::Layout;
+
sub handle {
%::myconfig = ();
- return if $::auth->authenticate_root($::auth->get_session_value('rpw')) == $::auth->OK();
+ return if $::form->{'{AUTH}admin_password'} && ($::auth->authenticate_root($::form->{'{AUTH}admin_password'}) == $::auth->OK());
+ return if !$::form->{'{AUTH}admin_password'} && ($::auth->authenticate_root($::auth->get_session_value('admin_password')) == $::auth->OK());
+
+ $::request->{layout} = SL::Controller::Layout->new(style => 'admin');
- $::auth->delete_session_value('rpw');
- SL::Dispatcher::show_error('login/password_error', 'password', is_admin => 1);
+ $::auth->punish_wrong_login;
+ $::auth->delete_session_value('admin_password');
+ SL::Dispatcher::show_error('admin/adminlogin', 'password');
}
1;