AzuraCast/src/Middleware/GetCurrentUser.php

79 lines
2.2 KiB
PHP

<?php
namespace App\Middleware;
use App\Acl;
use App\Auth;
use App\Customization;
use App\Entity;
use App\Http\ServerRequest;
use DI\FactoryInterface;
use Psr\Http\Message\ResponseInterface;
use Psr\Http\Message\ServerRequestInterface;
use Psr\Http\Server\MiddlewareInterface;
use Psr\Http\Server\RequestHandlerInterface;
/**
* Get the current user entity object and assign it into the request if it exists.
*/
class GetCurrentUser implements MiddlewareInterface
{
protected FactoryInterface $factory;
public function __construct(FactoryInterface $factory)
{
$this->factory = $factory;
}
public function process(ServerRequestInterface $request, RequestHandlerInterface $handler): ResponseInterface
{
// Initialize the Auth for this request.
$auth = $this->factory->make(
Auth::class,
[
'session' => $request->getAttribute(ServerRequest::ATTR_SESSION),
]
);
$user = ($auth->isLoggedIn()) ? $auth->getLoggedInUser() : null;
$request = $request
->withAttribute(ServerRequest::ATTR_AUTH, $auth)
->withAttribute(ServerRequest::ATTR_USER, $user)
->withAttribute('is_logged_in', (null !== $user));
// Initialize Customization (timezones, locales, etc) based on the current logged in user.
/** @var Customization $customization */
$customization = $this->factory->make(
Customization::class,
[
'request' => $request,
]
);
// Initialize ACL (can only be initialized after Customization as it contains localizations).
/** @var Acl $acl */
$acl = $this->factory->make(
Acl::class,
[
'user' => $user,
]
);
$request = $request
->withAttribute(ServerRequest::ATTR_LOCALE, $customization->getLocale())
->withAttribute(ServerRequest::ATTR_CUSTOMIZATION, $customization)
->withAttribute(ServerRequest::ATTR_ACL, $acl);
// Set the Audit Log user.
Entity\AuditLog::setCurrentUser($user);
$response = $handler->handle($request);
Entity\AuditLog::setCurrentUser(null);
return $response;
}
}