44 lines
1.1 KiB
PHP
44 lines
1.1 KiB
PHP
|
<?php
|
||
|
|
||
|
declare(strict_types=1);
|
||
|
|
||
|
namespace App\Controller\Frontend\Account;
|
||
|
|
||
|
use App\Entity;
|
||
|
use App\Exception\NotFoundException;
|
||
|
use App\Http\Response;
|
||
|
use App\Http\ServerRequest;
|
||
|
use App\Session\Flash;
|
||
|
use Psr\Http\Message\ResponseInterface;
|
||
|
|
||
|
class MasqueradeAction
|
||
|
{
|
||
|
public const CSRF_NAMESPACE = 'user_masquerade';
|
||
|
|
||
|
public function __invoke(
|
||
|
ServerRequest $request,
|
||
|
Response $response,
|
||
|
Entity\Repository\UserRepository $userRepo,
|
||
|
int $id,
|
||
|
string $csrf
|
||
|
): ResponseInterface {
|
||
|
$request->getCsrf()->verify($csrf, self::CSRF_NAMESPACE);
|
||
|
|
||
|
$user = $userRepo->find($id);
|
||
|
|
||
|
if (!($user instanceof Entity\User)) {
|
||
|
throw new NotFoundException(__('User not found.'));
|
||
|
}
|
||
|
|
||
|
$auth = $request->getAuth();
|
||
|
$auth->masqueradeAsUser($user);
|
||
|
|
||
|
$request->getFlash()->addMessage(
|
||
|
'<b>' . __('Logged in successfully.') . '</b><br>' . $user->getEmail(),
|
||
|
Flash::SUCCESS
|
||
|
);
|
||
|
|
||
|
return $response->withRedirect((string)$request->getRouter()->named('dashboard'));
|
||
|
}
|
||
|
}
|