misuzu/public-legacy/auth/logout.php

28 lines
800 B
PHP
Raw Permalink Normal View History

2019-03-08 01:35:53 +01:00
<?php
namespace Misuzu;
use Misuzu\Auth\AuthTokenCookie;
2024-12-02 02:28:08 +00:00
if(!isset($msz) || !($msz instanceof \Misuzu\MisuzuContext))
die('Script must be called through the Misuzu route dispatcher.');
2025-02-02 02:09:56 +00:00
if($msz->authInfo->loggedIn) {
if(!CSRF::validateRequest()) {
Template::render('auth.logout');
return;
}
$tokenInfo = $msz->authInfo->tokenInfo;
$msz->authCtx->sessions->deleteSessions(sessionTokens: $tokenInfo->sessionToken);
$tokenBuilder = $tokenInfo->toBuilder();
$tokenBuilder->removeUserId();
$tokenBuilder->removeSessionToken();
$tokenBuilder->removeImpersonatedUserId();
2019-03-08 01:35:53 +01:00
$tokenInfo = $tokenBuilder->toInfo();
2024-12-02 02:28:08 +00:00
AuthTokenCookie::apply($msz->authCtx->createAuthTokenPacker()->pack($tokenInfo));
2019-03-08 01:35:53 +01:00
}
Tools::redirect($msz->urls->format('index'));;