'login', 'postLogin' => 'login', ]; /** * @param Response $response * @param SessionInterface $session * @param Redirector $redirect * @param Config $config * @param Authenticator $auth */ public function __construct( Response $response, SessionInterface $session, Redirector $redirect, Config $config, Authenticator $auth ) { $this->response = $response; $this->session = $session; $this->redirect = $redirect; $this->config = $config; $this->auth = $auth; } /** * @return Response */ public function login(): Response { return $this->showLogin(); } /** * @return Response */ protected function showLogin(): Response { return $this->response->withView( 'pages/login', $this->getNotifications() ); } /** * Posted login form * * @param Request $request * @return Response */ public function postLogin(Request $request): Response { $data = $this->validate($request, [ 'login' => 'required', 'password' => 'required', ]); $user = $this->auth->authenticate($data['login'], $data['password']); if (!$user instanceof User) { $this->addNotification('auth.not-found', 'errors'); return $this->showLogin(); } return $this->loginUser($user); } /** * @param User $user * * @return Response */ public function loginUser(User $user): Response { $previousPage = $this->session->get('previous_page'); $this->session->invalidate(); $this->session->set('user_id', $user->id); $this->session->set('locale', $user->settings->language); $user->last_login_at = new Carbon(); $user->save(['touch' => false]); return $this->redirect->to($previousPage ?: $this->config->get('home_site')); } /** * @return Response */ public function logout(): Response { $this->session->invalidate(); return $this->redirect->to('/'); } }