3 declare(strict_types
=1);
5 namespace Shaarli\Front\Controller
;
7 use Shaarli\Front\Exception\LoginBannedException
;
9 use Slim\Http\Response
;
12 * Class LoginController
14 * Slim controller used to render the login page.
16 * The login page is not available if the user is banned
17 * or if open shaarli setting is enabled.
19 * @package Front\Controller
21 class LoginController
extends ShaarliController
23 public function index(Request
$request, Response
$response): Response
25 if ($this->container
->loginManager
->isLoggedIn()
26 || $this->container
->conf
->get('security.open_shaarli', false)
28 return $response->withRedirect('./');
31 $userCanLogin = $this->container
->loginManager
->canLogin($request->getServerParams());
32 if ($userCanLogin !== true) {
33 throw new LoginBannedException();
36 if ($request->getParam('username') !== null) {
37 $this->assignView('username', escape($request->getParam('username')));
41 ->assignView('returnurl', escape($request->getServerParam('HTTP_REFERER')))
42 ->assignView('remember_user_default', $this->container
->conf
->get('privacy.remember_user_default', true))
43 ->assignView('pagetitle', t('Login') .' - '. $this->container
->conf
->get('general.title', 'Shaarli'))
46 return $response->write($this->render('loginform'));