Process logout through Slim controller
This commit is contained in:
parent
b0428aa9b0
commit
8e47af2b36
8 changed files with 128 additions and 13 deletions
|
@ -11,6 +11,7 @@
|
||||||
use Shaarli\History;
|
use Shaarli\History;
|
||||||
use Shaarli\Plugin\PluginManager;
|
use Shaarli\Plugin\PluginManager;
|
||||||
use Shaarli\Render\PageBuilder;
|
use Shaarli\Render\PageBuilder;
|
||||||
|
use Shaarli\Render\PageCacheManager;
|
||||||
use Shaarli\Security\LoginManager;
|
use Shaarli\Security\LoginManager;
|
||||||
use Shaarli\Security\SessionManager;
|
use Shaarli\Security\SessionManager;
|
||||||
|
|
||||||
|
@ -34,19 +35,30 @@ class ContainerBuilder
|
||||||
/** @var LoginManager */
|
/** @var LoginManager */
|
||||||
protected $login;
|
protected $login;
|
||||||
|
|
||||||
public function __construct(ConfigManager $conf, SessionManager $session, LoginManager $login)
|
/** @var string */
|
||||||
{
|
protected $webPath;
|
||||||
|
|
||||||
|
public function __construct(
|
||||||
|
ConfigManager $conf,
|
||||||
|
SessionManager $session,
|
||||||
|
LoginManager $login,
|
||||||
|
string $webPath
|
||||||
|
) {
|
||||||
$this->conf = $conf;
|
$this->conf = $conf;
|
||||||
$this->session = $session;
|
$this->session = $session;
|
||||||
$this->login = $login;
|
$this->login = $login;
|
||||||
|
$this->webPath = $webPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
public function build(): ShaarliContainer
|
public function build(): ShaarliContainer
|
||||||
{
|
{
|
||||||
$container = new ShaarliContainer();
|
$container = new ShaarliContainer();
|
||||||
|
|
||||||
$container['conf'] = $this->conf;
|
$container['conf'] = $this->conf;
|
||||||
$container['sessionManager'] = $this->session;
|
$container['sessionManager'] = $this->session;
|
||||||
$container['loginManager'] = $this->login;
|
$container['loginManager'] = $this->login;
|
||||||
|
$container['webPath'] = $this->webPath;
|
||||||
|
|
||||||
$container['plugins'] = function (ShaarliContainer $container): PluginManager {
|
$container['plugins'] = function (ShaarliContainer $container): PluginManager {
|
||||||
return new PluginManager($container->conf);
|
return new PluginManager($container->conf);
|
||||||
};
|
};
|
||||||
|
@ -81,6 +93,10 @@ public function build(): ShaarliContainer
|
||||||
return new FormatterFactory($container->conf, $container->loginManager->isLoggedIn());
|
return new FormatterFactory($container->conf, $container->loginManager->isLoggedIn());
|
||||||
};
|
};
|
||||||
|
|
||||||
|
$container['pageCacheManager'] = function (ShaarliContainer $container): PageCacheManager {
|
||||||
|
return new PageCacheManager($container->conf->get('resource.page_cache'));
|
||||||
|
};
|
||||||
|
|
||||||
return $container;
|
return $container;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
use Shaarli\History;
|
use Shaarli\History;
|
||||||
use Shaarli\Plugin\PluginManager;
|
use Shaarli\Plugin\PluginManager;
|
||||||
use Shaarli\Render\PageBuilder;
|
use Shaarli\Render\PageBuilder;
|
||||||
|
use Shaarli\Render\PageCacheManager;
|
||||||
use Shaarli\Security\LoginManager;
|
use Shaarli\Security\LoginManager;
|
||||||
use Shaarli\Security\SessionManager;
|
use Shaarli\Security\SessionManager;
|
||||||
use Slim\Container;
|
use Slim\Container;
|
||||||
|
@ -20,11 +21,13 @@
|
||||||
* @property ConfigManager $conf
|
* @property ConfigManager $conf
|
||||||
* @property SessionManager $sessionManager
|
* @property SessionManager $sessionManager
|
||||||
* @property LoginManager $loginManager
|
* @property LoginManager $loginManager
|
||||||
|
* @property string $webPath
|
||||||
* @property History $history
|
* @property History $history
|
||||||
* @property BookmarkServiceInterface $bookmarkService
|
* @property BookmarkServiceInterface $bookmarkService
|
||||||
* @property PageBuilder $pageBuilder
|
* @property PageBuilder $pageBuilder
|
||||||
* @property PluginManager $pluginManager
|
* @property PluginManager $pluginManager
|
||||||
* @property FormatterFactory $formatterFactory
|
* @property FormatterFactory $formatterFactory
|
||||||
|
* @property PageCacheManager $pageCacheManager
|
||||||
*/
|
*/
|
||||||
class ShaarliContainer extends Container
|
class ShaarliContainer extends Container
|
||||||
{
|
{
|
||||||
|
|
31
application/front/controllers/LogoutController.php
Normal file
31
application/front/controllers/LogoutController.php
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Shaarli\Front\Controller;
|
||||||
|
|
||||||
|
use Shaarli\Security\LoginManager;
|
||||||
|
use Slim\Http\Request;
|
||||||
|
use Slim\Http\Response;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class LogoutController
|
||||||
|
*
|
||||||
|
* Slim controller used to logout the user.
|
||||||
|
* It invalidates page cache and terminate the user session. Then it redirects to the homepage.
|
||||||
|
*
|
||||||
|
* @package Front\Controller
|
||||||
|
*/
|
||||||
|
class LogoutController extends ShaarliController
|
||||||
|
{
|
||||||
|
public function index(Request $request, Response $response): Response
|
||||||
|
{
|
||||||
|
$this->container->pageCacheManager->invalidateCaches();
|
||||||
|
$this->container->sessionManager->logout();
|
||||||
|
|
||||||
|
// TODO: switch to a simple Cookie manager allowing to check the session, and create mocks.
|
||||||
|
setcookie(LoginManager::$STAY_SIGNED_IN_COOKIE, 'false', 0, $this->container->webPath);
|
||||||
|
|
||||||
|
return $response->withRedirect('./');
|
||||||
|
}
|
||||||
|
}
|
|
@ -604,10 +604,7 @@ function renderPage($conf, $pluginManager, $bookmarkService, $history, $sessionM
|
||||||
}
|
}
|
||||||
// -------- User wants to logout.
|
// -------- User wants to logout.
|
||||||
if (isset($_SERVER['QUERY_STRING']) && startsWith($_SERVER['QUERY_STRING'], 'do=logout')) {
|
if (isset($_SERVER['QUERY_STRING']) && startsWith($_SERVER['QUERY_STRING'], 'do=logout')) {
|
||||||
invalidateCaches($conf->get('resource.page_cache'));
|
header('Location: ./logout');
|
||||||
$sessionManager->logout();
|
|
||||||
setcookie(LoginManager::$STAY_SIGNED_IN_COOKIE, 'false', 0, WEB_PATH);
|
|
||||||
header('Location: ?');
|
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1894,7 +1891,7 @@ function install($conf, $sessionManager, $loginManager)
|
||||||
exit;
|
exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
$containerBuilder = new ContainerBuilder($conf, $sessionManager, $loginManager);
|
$containerBuilder = new ContainerBuilder($conf, $sessionManager, $loginManager, WEB_PATH);
|
||||||
$container = $containerBuilder->build();
|
$container = $containerBuilder->build();
|
||||||
$app = new App($container);
|
$app = new App($container);
|
||||||
|
|
||||||
|
|
|
@ -10,6 +10,7 @@
|
||||||
use Shaarli\Formatter\FormatterFactory;
|
use Shaarli\Formatter\FormatterFactory;
|
||||||
use Shaarli\History;
|
use Shaarli\History;
|
||||||
use Shaarli\Render\PageBuilder;
|
use Shaarli\Render\PageBuilder;
|
||||||
|
use Shaarli\Render\PageCacheManager;
|
||||||
use Shaarli\Security\LoginManager;
|
use Shaarli\Security\LoginManager;
|
||||||
use Shaarli\Security\SessionManager;
|
use Shaarli\Security\SessionManager;
|
||||||
|
|
||||||
|
@ -35,7 +36,12 @@ public function setUp(): void
|
||||||
$this->loginManager = $this->createMock(LoginManager::class);
|
$this->loginManager = $this->createMock(LoginManager::class);
|
||||||
$this->loginManager->method('isLoggedIn')->willReturn(true);
|
$this->loginManager->method('isLoggedIn')->willReturn(true);
|
||||||
|
|
||||||
$this->containerBuilder = new ContainerBuilder($this->conf, $this->sessionManager, $this->loginManager);
|
$this->containerBuilder = new ContainerBuilder(
|
||||||
|
$this->conf,
|
||||||
|
$this->sessionManager,
|
||||||
|
$this->loginManager,
|
||||||
|
'UT web path'
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public function testBuildContainer(): void
|
public function testBuildContainer(): void
|
||||||
|
@ -45,9 +51,11 @@ public function testBuildContainer(): void
|
||||||
static::assertInstanceOf(ConfigManager::class, $container->conf);
|
static::assertInstanceOf(ConfigManager::class, $container->conf);
|
||||||
static::assertInstanceOf(SessionManager::class, $container->sessionManager);
|
static::assertInstanceOf(SessionManager::class, $container->sessionManager);
|
||||||
static::assertInstanceOf(LoginManager::class, $container->loginManager);
|
static::assertInstanceOf(LoginManager::class, $container->loginManager);
|
||||||
|
static::assertSame('UT web path', $container->webPath);
|
||||||
static::assertInstanceOf(History::class, $container->history);
|
static::assertInstanceOf(History::class, $container->history);
|
||||||
static::assertInstanceOf(BookmarkServiceInterface::class, $container->bookmarkService);
|
static::assertInstanceOf(BookmarkServiceInterface::class, $container->bookmarkService);
|
||||||
static::assertInstanceOf(PageBuilder::class, $container->pageBuilder);
|
static::assertInstanceOf(PageBuilder::class, $container->pageBuilder);
|
||||||
static::assertInstanceOf(FormatterFactory::class, $container->formatterFactory);
|
static::assertInstanceOf(FormatterFactory::class, $container->formatterFactory);
|
||||||
|
static::assertInstanceOf(PageCacheManager::class, $container->pageCacheManager);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
60
tests/front/controller/LogoutControllerTest.php
Normal file
60
tests/front/controller/LogoutControllerTest.php
Normal file
|
@ -0,0 +1,60 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
declare(strict_types=1);
|
||||||
|
|
||||||
|
namespace Shaarli\Front\Controller;
|
||||||
|
|
||||||
|
/** Override PHP builtin setcookie function in the local namespace to mock it... more or less */
|
||||||
|
if (!function_exists('Shaarli\Front\Controller\setcookie')) {
|
||||||
|
function setcookie(string $name, string $value): void {
|
||||||
|
$_COOKIE[$name] = $value;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
use PHPUnit\Framework\TestCase;
|
||||||
|
use Shaarli\Container\ShaarliContainer;
|
||||||
|
use Shaarli\Render\PageCacheManager;
|
||||||
|
use Shaarli\Security\LoginManager;
|
||||||
|
use Shaarli\Security\SessionManager;
|
||||||
|
use Slim\Http\Request;
|
||||||
|
use Slim\Http\Response;
|
||||||
|
|
||||||
|
class LogoutControllerTest extends TestCase
|
||||||
|
{
|
||||||
|
/** @var ShaarliContainer */
|
||||||
|
protected $container;
|
||||||
|
|
||||||
|
/** @var LogoutController */
|
||||||
|
protected $controller;
|
||||||
|
|
||||||
|
public function setUp(): void
|
||||||
|
{
|
||||||
|
$this->container = $this->createMock(ShaarliContainer::class);
|
||||||
|
$this->controller = new LogoutController($this->container);
|
||||||
|
|
||||||
|
setcookie(LoginManager::$STAY_SIGNED_IN_COOKIE, $cookie = 'hi there');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function testValidControllerInvoke(): void
|
||||||
|
{
|
||||||
|
$request = $this->createMock(Request::class);
|
||||||
|
$response = new Response();
|
||||||
|
|
||||||
|
$pageCacheManager = $this->createMock(PageCacheManager::class);
|
||||||
|
$pageCacheManager->expects(static::once())->method('invalidateCaches');
|
||||||
|
$this->container->pageCacheManager = $pageCacheManager;
|
||||||
|
|
||||||
|
$sessionManager = $this->createMock(SessionManager::class);
|
||||||
|
$sessionManager->expects(static::once())->method('logout');
|
||||||
|
$this->container->sessionManager = $sessionManager;
|
||||||
|
|
||||||
|
static::assertSame('hi there', $_COOKIE[LoginManager::$STAY_SIGNED_IN_COOKIE]);
|
||||||
|
|
||||||
|
$result = $this->controller->index($request, $response);
|
||||||
|
|
||||||
|
static::assertInstanceOf(Response::class, $result);
|
||||||
|
static::assertSame(302, $result->getStatusCode());
|
||||||
|
static::assertContains('./', $result->getHeader('Location'));
|
||||||
|
static::assertSame('false', $_COOKIE[LoginManager::$STAY_SIGNED_IN_COOKIE]);
|
||||||
|
}
|
||||||
|
}
|
|
@ -56,7 +56,7 @@
|
||||||
</li>
|
</li>
|
||||||
{if="$is_logged_in"}
|
{if="$is_logged_in"}
|
||||||
<li class="pure-menu-item pure-u-lg-0 shaarli-menu-mobile" id="shaarli-menu-mobile-logout">
|
<li class="pure-menu-item pure-u-lg-0 shaarli-menu-mobile" id="shaarli-menu-mobile-logout">
|
||||||
<a href="./?do=logout" class="pure-menu-link">{'Logout'|t}</a>
|
<a href="/logout" class="pure-menu-link">{'Logout'|t}</a>
|
||||||
</li>
|
</li>
|
||||||
{else}
|
{else}
|
||||||
<li class="pure-menu-item pure-u-lg-0 shaarli-menu-mobile" id="shaarli-menu-mobile-login">
|
<li class="pure-menu-item pure-u-lg-0 shaarli-menu-mobile" id="shaarli-menu-mobile-login">
|
||||||
|
@ -88,7 +88,7 @@
|
||||||
</li>
|
</li>
|
||||||
{else}
|
{else}
|
||||||
<li class="pure-menu-item" id="shaarli-menu-desktop-logout">
|
<li class="pure-menu-item" id="shaarli-menu-desktop-logout">
|
||||||
<a href="./?do=logout" class="pure-menu-link" aria-label="{'Logout'|t}" title="{'Logout'|t}">
|
<a href="/logout" class="pure-menu-link" aria-label="{'Logout'|t}" title="{'Logout'|t}">
|
||||||
<i class="fa fa-sign-out" aria-hidden="true"></i>
|
<i class="fa fa-sign-out" aria-hidden="true"></i>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
|
|
|
@ -18,9 +18,9 @@
|
||||||
{else}
|
{else}
|
||||||
<li><a href="{$titleLink}" class="nomobile">Home</a></li>
|
<li><a href="{$titleLink}" class="nomobile">Home</a></li>
|
||||||
{if="$is_logged_in"}
|
{if="$is_logged_in"}
|
||||||
<li><a href="./?do=logout">Logout</a></li>
|
<li><a href="/logout">Logout</a></li>
|
||||||
<li><a href="./?do=tools">Tools</a></li>
|
<li><a href="?do=tools">Tools</a></li>
|
||||||
<li><a href="./?do=addlink">Add link</a></li>
|
<li><a href="?do=addlink">Add link</a></li>
|
||||||
{elseif="$openshaarli"}
|
{elseif="$openshaarli"}
|
||||||
<li><a href="./?do=tools">Tools</a></li>
|
<li><a href="./?do=tools">Tools</a></li>
|
||||||
<li><a href="./?do=addlink">Add link</a></li>
|
<li><a href="./?do=addlink">Add link</a></li>
|
||||||
|
|
Loading…
Reference in a new issue