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->ci
->loginManager
->isLoggedIn() || $this->ci
->conf
->get('security.open_shaarli', false)) {
26 return $response->withRedirect('./');
29 $userCanLogin = $this->ci
->loginManager
->canLogin($request->getServerParams());
30 if ($userCanLogin !== true) {
31 throw new LoginBannedException();
34 if ($request->getParam('username') !== null) {
35 $this->assignView('username', escape($request->getParam('username')));
39 ->assignView('returnurl', escape($request->getServerParam('HTTP_REFERER')))
40 ->assignView('remember_user_default', $this->ci
->conf
->get('privacy.remember_user_default', true))
41 ->assignView('pagetitle', t('Login') .' - '. $this->ci
->conf
->get('general.title', 'Shaarli'))
44 return $response->write($this->ci
->pageBuilder
->render('loginform'));