aboutsummaryrefslogblamecommitdiffhomepage
path: root/application/front/controller/admin/LogoutController.php
blob: 41e81984a4c89ef6407e3e0c3463dfe0e649a473 (plain) (tree)
1
2
3
4
5



                        
                                         









                                                                                               
   
                                                     











                                                                                                   
<?php

declare(strict_types=1);

namespace Shaarli\Front\Controller\Admin;

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.
 */
class LogoutController extends ShaarliAdminController
{
    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('./');
    }
}