engelsystem/src/Controllers/AuthController.php

120 lines
2.7 KiB
PHP
Raw Normal View History

2018-10-25 18:53:05 +02:00
<?php
namespace Engelsystem\Controllers;
use Carbon\Carbon;
use Engelsystem\Config\Config;
use Engelsystem\Helpers\Authenticator;
use Engelsystem\Http\Redirector;
use Engelsystem\Http\Request;
2018-10-25 18:53:05 +02:00
use Engelsystem\Http\Response;
use Engelsystem\Models\User\User;
2018-10-25 18:53:05 +02:00
use Symfony\Component\HttpFoundation\Session\SessionInterface;
class AuthController extends BaseController
{
use HasUserNotifications;
2018-10-25 18:53:05 +02:00
/** @var Response */
protected $response;
/** @var SessionInterface */
protected $session;
/** @var Redirector */
protected $redirect;
2018-10-25 18:53:05 +02:00
/** @var Config */
protected $config;
/** @var Authenticator */
protected $auth;
/** @var array */
protected $permissions = [
'login' => '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
) {
2018-10-25 18:53:05 +02:00
$this->response = $response;
$this->session = $session;
$this->redirect = $redirect;
$this->config = $config;
$this->auth = $auth;
}
/**
* @return Response
*/
2019-07-21 12:37:01 +02:00
public function login(): Response
{
2019-07-09 22:02:07 +02:00
return $this->showLogin();
}
/**
* @return Response
*/
protected function showLogin(): Response
2019-07-09 22:02:07 +02:00
{
return $this->response->withView(
'pages/login',
$this->getNotifications()
2019-07-09 22:02:07 +02:00
);
}
/**
* Posted login form
*
* @param Request $request
* @return Response
*/
public function postLogin(Request $request): Response
{
2019-07-09 22:02:07 +02:00
$data = $this->validate($request, [
'login' => 'required',
'password' => 'required',
]);
$user = $this->auth->authenticate($data['login'], $data['password']);
2019-07-09 22:02:07 +02:00
if (!$user instanceof User) {
$this->addNotification('auth.not-found', 'errors');
2019-07-09 22:02:07 +02:00
return $this->showLogin();
2019-07-09 22:02:07 +02:00
}
$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($this->config->get('home_site'));
2018-10-25 18:53:05 +02:00
}
/**
* @return Response
*/
public function logout(): Response
2018-10-25 18:53:05 +02:00
{
$this->session->invalidate();
return $this->redirect->to('/');
2018-10-25 18:53:05 +02:00
}
}