67 lines
2.0 KiB
PHP
67 lines
2.0 KiB
PHP
<?php
|
|
|
|
declare(strict_types=1);
|
|
|
|
namespace App\Middleware;
|
|
|
|
use App\Acl;
|
|
use App\Auth;
|
|
use App\Container\EnvironmentAwareTrait;
|
|
use App\Customization;
|
|
use App\Entity\AuditLog;
|
|
use App\Entity\Repository\UserRepository;
|
|
use App\Http\ServerRequest;
|
|
use Psr\Http\Message\ResponseInterface;
|
|
use Psr\Http\Server\RequestHandlerInterface;
|
|
|
|
/**
|
|
* Get the current user entity object and assign it into the request if it exists.
|
|
*/
|
|
final class GetCurrentUser extends AbstractMiddleware
|
|
{
|
|
use EnvironmentAwareTrait;
|
|
|
|
public function __construct(
|
|
private readonly UserRepository $userRepo,
|
|
private readonly Acl $acl,
|
|
private readonly Customization $customization
|
|
) {
|
|
}
|
|
|
|
public function __invoke(ServerRequest $request, RequestHandlerInterface $handler): ResponseInterface
|
|
{
|
|
// Initialize the Auth for this request.
|
|
$auth = new Auth(
|
|
userRepo: $this->userRepo,
|
|
session: $request->getSession(),
|
|
);
|
|
$auth->setEnvironment($this->environment);
|
|
|
|
$user = ($auth->isLoggedIn()) ? $auth->getLoggedInUser() : null;
|
|
|
|
$request = $request
|
|
->withAttribute(ServerRequest::ATTR_AUTH, $auth)
|
|
->withAttribute(ServerRequest::ATTR_USER, $user);
|
|
|
|
// Initialize Customization (timezones, locales, etc) based on the current logged in user.
|
|
$customization = $this->customization->withRequest($request);
|
|
|
|
// Initialize ACL (can only be initialized after Customization as it contains localizations).
|
|
$acl = $this->acl->withRequest($request);
|
|
|
|
$request = $request
|
|
->withAttribute(ServerRequest::ATTR_LOCALE, $customization->getLocale())
|
|
->withAttribute(ServerRequest::ATTR_CUSTOMIZATION, $customization)
|
|
->withAttribute(ServerRequest::ATTR_ACL, $acl);
|
|
|
|
// Set the Audit Log user.
|
|
AuditLog::setCurrentUser($user);
|
|
|
|
$response = $handler->handle($request);
|
|
|
|
AuditLog::setCurrentUser();
|
|
|
|
return $response;
|
|
}
|
|
}
|