]> git.immae.eu Git - github/shaarli/Shaarli.git/blame - application/front/controller/visitor/LoginController.php
Use multi-level routes for existing controllers instead of 1 level everywhere
[github/shaarli/Shaarli.git] / application / front / controller / visitor / LoginController.php
CommitLineData
6c50a6cc
A
1<?php
2
3declare(strict_types=1);
4
2899ebb5 5namespace Shaarli\Front\Controller\Visitor;
6c50a6cc
A
6
7use Shaarli\Front\Exception\LoginBannedException;
8use Slim\Http\Request;
9use Slim\Http\Response;
10
11/**
12 * Class LoginController
13 *
14 * Slim controller used to render the login page.
15 *
16 * The login page is not available if the user is banned
17 * or if open shaarli setting is enabled.
6c50a6cc 18 */
2899ebb5 19class LoginController extends ShaarliVisitorController
6c50a6cc
A
20{
21 public function index(Request $request, Response $response): Response
22 {
27ceea2a
A
23 if ($this->container->loginManager->isLoggedIn()
24 || $this->container->conf->get('security.open_shaarli', false)
25 ) {
9c75f877 26 return $this->redirect($response, '/');
6c50a6cc
A
27 }
28
27ceea2a 29 $userCanLogin = $this->container->loginManager->canLogin($request->getServerParams());
6c50a6cc
A
30 if ($userCanLogin !== true) {
31 throw new LoginBannedException();
32 }
33
34 if ($request->getParam('username') !== null) {
35 $this->assignView('username', escape($request->getParam('username')));
36 }
37
38 $this
39 ->assignView('returnurl', escape($request->getServerParam('HTTP_REFERER')))
27ceea2a
A
40 ->assignView('remember_user_default', $this->container->conf->get('privacy.remember_user_default', true))
41 ->assignView('pagetitle', t('Login') .' - '. $this->container->conf->get('general.title', 'Shaarli'))
6c50a6cc
A
42 ;
43
0498b209 44 return $response->write($this->render('loginform'));
6c50a6cc
A
45 }
46}