'login', 'postLogin' => 'login', ]; /** * @param Response $response * @param SessionInterface $session * @param UrlGeneratorInterface $url * @param Config $config * @param Authenticator $auth */ public function __construct( Response $response, SessionInterface $session, UrlGeneratorInterface $url, Config $config, Authenticator $auth ) { $this->response = $response; $this->session = $session; $this->url = $url; $this->config = $config; $this->auth = $auth; } /** * @return Response */ public function login(): Response { return $this->showLogin(); } /** * @return Response */ protected function showLogin(): Response { $errors = Collection::make(Arr::flatten($this->session->get('errors', []))); $this->session->remove('errors'); return $this->response->withView( 'pages/login', ['errors' => $errors] ); } /** * 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->session->set('errors', array_merge($this->session->get('errors', []), ['auth.not-found'])); return $this->showLogin(); } $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->response->redirectTo($this->config->get('home_site')); } /** * @return Response */ public function logout(): Response { $this->session->invalidate(); return $this->response->redirectTo($this->url->to('/')); } }