login consent app sql
This commit is contained in:
49
vendor/symfony/security-http/Logout/CookieClearingLogoutHandler.php
vendored
Normal file
49
vendor/symfony/security-http/Logout/CookieClearingLogoutHandler.php
vendored
Normal file
@ -0,0 +1,49 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
|
||||
use Symfony\Component\Security\Http\EventListener\CookieClearingLogoutListener;
|
||||
|
||||
trigger_deprecation('symfony/security-http', '5.4', 'The "%s" class is deprecated, use "%s" instead.', CookieClearingLogoutHandler::class, CookieClearingLogoutListener::class);
|
||||
|
||||
/**
|
||||
* This handler clears the passed cookies when a user logs out.
|
||||
*
|
||||
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
||||
*
|
||||
* @deprecated since Symfony 5.4, use {@link CookieClearingLogoutListener} instead
|
||||
*/
|
||||
class CookieClearingLogoutHandler implements LogoutHandlerInterface
|
||||
{
|
||||
private $cookies;
|
||||
|
||||
/**
|
||||
* @param array $cookies An array of cookie names to unset
|
||||
*/
|
||||
public function __construct(array $cookies)
|
||||
{
|
||||
$this->cookies = $cookies;
|
||||
}
|
||||
|
||||
/**
|
||||
* Implementation for the LogoutHandlerInterface. Deletes all requested cookies.
|
||||
*/
|
||||
public function logout(Request $request, Response $response, TokenInterface $token)
|
||||
{
|
||||
foreach ($this->cookies as $cookieName => $cookieData) {
|
||||
$response->headers->clearCookie($cookieName, $cookieData['path'], $cookieData['domain'], $cookieData['secure'] ?? false, true, $cookieData['samesite'] ?? null);
|
||||
}
|
||||
}
|
||||
}
|
40
vendor/symfony/security-http/Logout/CsrfTokenClearingLogoutHandler.php
vendored
Normal file
40
vendor/symfony/security-http/Logout/CsrfTokenClearingLogoutHandler.php
vendored
Normal file
@ -0,0 +1,40 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
|
||||
use Symfony\Component\Security\Csrf\TokenStorage\ClearableTokenStorageInterface;
|
||||
use Symfony\Component\Security\Http\EventListener\CsrfTokenClearingLogoutListener;
|
||||
|
||||
trigger_deprecation('symfony/security-http', '5.4', 'The "%s" class is deprecated, use "%s" instead.', CsrfTokenClearingLogoutHandler::class, CsrfTokenClearingLogoutListener::class);
|
||||
|
||||
/**
|
||||
* @author Christian Flothmann <christian.flothmann@sensiolabs.de>
|
||||
*
|
||||
* @deprecated since Symfony 5.4, use {@link CsrfTokenClearingLogoutListener} instead
|
||||
*/
|
||||
class CsrfTokenClearingLogoutHandler implements LogoutHandlerInterface
|
||||
{
|
||||
private $csrfTokenStorage;
|
||||
|
||||
public function __construct(ClearableTokenStorageInterface $csrfTokenStorage)
|
||||
{
|
||||
$this->csrfTokenStorage = $csrfTokenStorage;
|
||||
}
|
||||
|
||||
public function logout(Request $request, Response $response, TokenInterface $token)
|
||||
{
|
||||
$this->csrfTokenStorage->clear();
|
||||
}
|
||||
}
|
46
vendor/symfony/security-http/Logout/DefaultLogoutSuccessHandler.php
vendored
Normal file
46
vendor/symfony/security-http/Logout/DefaultLogoutSuccessHandler.php
vendored
Normal file
@ -0,0 +1,46 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\Security\Http\EventListener\DefaultLogoutListener;
|
||||
use Symfony\Component\Security\Http\HttpUtils;
|
||||
|
||||
trigger_deprecation('symfony/security-http', '5.1', 'The "%s" class is deprecated, use "%s" instead.', DefaultLogoutSuccessHandler::class, DefaultLogoutListener::class);
|
||||
|
||||
/**
|
||||
* Default logout success handler will redirect users to a configured path.
|
||||
*
|
||||
* @author Fabien Potencier <fabien@symfony.com>
|
||||
* @author Alexander <iam.asm89@gmail.com>
|
||||
*
|
||||
* @deprecated since Symfony 5.1
|
||||
*/
|
||||
class DefaultLogoutSuccessHandler implements LogoutSuccessHandlerInterface
|
||||
{
|
||||
protected $httpUtils;
|
||||
protected $targetUrl;
|
||||
|
||||
public function __construct(HttpUtils $httpUtils, string $targetUrl = '/')
|
||||
{
|
||||
$this->httpUtils = $httpUtils;
|
||||
$this->targetUrl = $targetUrl;
|
||||
}
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
public function onLogoutSuccess(Request $request)
|
||||
{
|
||||
return $this->httpUtils->createRedirectResponse($request, $this->targetUrl);
|
||||
}
|
||||
}
|
33
vendor/symfony/security-http/Logout/LogoutHandlerInterface.php
vendored
Normal file
33
vendor/symfony/security-http/Logout/LogoutHandlerInterface.php
vendored
Normal file
@ -0,0 +1,33 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
|
||||
|
||||
/**
|
||||
* Interface that needs to be implemented by LogoutHandlers.
|
||||
*
|
||||
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
||||
*
|
||||
* @deprecated since Symfony 5.1
|
||||
*/
|
||||
interface LogoutHandlerInterface
|
||||
{
|
||||
/**
|
||||
* This method is called by the LogoutListener when a user has requested
|
||||
* to be logged out. Usually, you would unset session variables, or remove
|
||||
* cookies, etc.
|
||||
*/
|
||||
public function logout(Request $request, Response $response, TokenInterface $token);
|
||||
}
|
41
vendor/symfony/security-http/Logout/LogoutSuccessHandlerInterface.php
vendored
Normal file
41
vendor/symfony/security-http/Logout/LogoutSuccessHandlerInterface.php
vendored
Normal file
@ -0,0 +1,41 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Symfony\Component\Security\Http\Event\LogoutEvent;
|
||||
|
||||
trigger_deprecation('symfony/security-http', '5.1', 'The "%s" interface is deprecated, create a listener for the "%s" event instead.', LogoutSuccessHandlerInterface::class, LogoutEvent::class);
|
||||
|
||||
/**
|
||||
* LogoutSuccesshandlerInterface.
|
||||
*
|
||||
* In contrast to the LogoutHandlerInterface, this interface can return a response
|
||||
* which is then used instead of the default behavior.
|
||||
*
|
||||
* If you want to only perform some logout related clean-up task, use the
|
||||
* LogoutHandlerInterface instead.
|
||||
*
|
||||
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
||||
*
|
||||
* @deprecated since Symfony 5.1
|
||||
*/
|
||||
interface LogoutSuccessHandlerInterface
|
||||
{
|
||||
/**
|
||||
* Creates a Response object to send upon a successful logout.
|
||||
*
|
||||
* @return Response
|
||||
*/
|
||||
public function onLogoutSuccess(Request $request);
|
||||
}
|
170
vendor/symfony/security-http/Logout/LogoutUrlGenerator.php
vendored
Normal file
170
vendor/symfony/security-http/Logout/LogoutUrlGenerator.php
vendored
Normal file
@ -0,0 +1,170 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\RequestStack;
|
||||
use Symfony\Component\Routing\Generator\UrlGeneratorInterface;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\AnonymousToken;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\Storage\TokenStorageInterface;
|
||||
use Symfony\Component\Security\Csrf\CsrfTokenManagerInterface;
|
||||
|
||||
/**
|
||||
* Provides generator functions for the logout URL.
|
||||
*
|
||||
* @author Fabien Potencier <fabien@symfony.com>
|
||||
* @author Jeremy Mikola <jmikola@gmail.com>
|
||||
*/
|
||||
class LogoutUrlGenerator
|
||||
{
|
||||
private $requestStack;
|
||||
private $router;
|
||||
private $tokenStorage;
|
||||
private $listeners = [];
|
||||
/** @var string|null */
|
||||
private $currentFirewallName;
|
||||
/** @var string|null */
|
||||
private $currentFirewallContext;
|
||||
|
||||
public function __construct(RequestStack $requestStack = null, UrlGeneratorInterface $router = null, TokenStorageInterface $tokenStorage = null)
|
||||
{
|
||||
$this->requestStack = $requestStack;
|
||||
$this->router = $router;
|
||||
$this->tokenStorage = $tokenStorage;
|
||||
}
|
||||
|
||||
/**
|
||||
* Registers a firewall's LogoutListener, allowing its URL to be generated.
|
||||
*
|
||||
* @param string $key The firewall key
|
||||
* @param string $logoutPath The path that starts the logout process
|
||||
* @param string|null $csrfTokenId The ID of the CSRF token
|
||||
* @param string|null $csrfParameter The CSRF token parameter name
|
||||
* @param string|null $context The listener context
|
||||
*/
|
||||
public function registerListener(string $key, string $logoutPath, ?string $csrfTokenId, ?string $csrfParameter, CsrfTokenManagerInterface $csrfTokenManager = null, string $context = null)
|
||||
{
|
||||
$this->listeners[$key] = [$logoutPath, $csrfTokenId, $csrfParameter, $csrfTokenManager, $context];
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates the absolute logout path for the firewall.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getLogoutPath(string $key = null)
|
||||
{
|
||||
return $this->generateLogoutUrl($key, UrlGeneratorInterface::ABSOLUTE_PATH);
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates the absolute logout URL for the firewall.
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
public function getLogoutUrl(string $key = null)
|
||||
{
|
||||
return $this->generateLogoutUrl($key, UrlGeneratorInterface::ABSOLUTE_URL);
|
||||
}
|
||||
|
||||
public function setCurrentFirewall(?string $key, string $context = null)
|
||||
{
|
||||
$this->currentFirewallName = $key;
|
||||
$this->currentFirewallContext = $context;
|
||||
}
|
||||
|
||||
/**
|
||||
* Generates the logout URL for the firewall.
|
||||
*/
|
||||
private function generateLogoutUrl(?string $key, int $referenceType): string
|
||||
{
|
||||
[$logoutPath, $csrfTokenId, $csrfParameter, $csrfTokenManager] = $this->getListener($key);
|
||||
|
||||
if (null === $logoutPath) {
|
||||
throw new \LogicException('Unable to generate the logout URL without a path.');
|
||||
}
|
||||
|
||||
$parameters = null !== $csrfTokenManager ? [$csrfParameter => (string) $csrfTokenManager->getToken($csrfTokenId)] : [];
|
||||
|
||||
if ('/' === $logoutPath[0]) {
|
||||
if (!$this->requestStack) {
|
||||
throw new \LogicException('Unable to generate the logout URL without a RequestStack.');
|
||||
}
|
||||
|
||||
$request = $this->requestStack->getCurrentRequest();
|
||||
|
||||
$url = UrlGeneratorInterface::ABSOLUTE_URL === $referenceType ? $request->getUriForPath($logoutPath) : $request->getBaseUrl().$logoutPath;
|
||||
|
||||
if (!empty($parameters)) {
|
||||
$url .= '?'.http_build_query($parameters, '', '&');
|
||||
}
|
||||
} else {
|
||||
if (!$this->router) {
|
||||
throw new \LogicException('Unable to generate the logout URL without a Router.');
|
||||
}
|
||||
|
||||
$url = $this->router->generate($logoutPath, $parameters, $referenceType);
|
||||
}
|
||||
|
||||
return $url;
|
||||
}
|
||||
|
||||
/**
|
||||
* @throws \InvalidArgumentException if no LogoutListener is registered for the key or could not be found automatically
|
||||
*/
|
||||
private function getListener(?string $key): array
|
||||
{
|
||||
if (null !== $key) {
|
||||
if (isset($this->listeners[$key])) {
|
||||
return $this->listeners[$key];
|
||||
}
|
||||
|
||||
throw new \InvalidArgumentException(sprintf('No LogoutListener found for firewall key "%s".', $key));
|
||||
}
|
||||
|
||||
// Fetch the current provider key from token, if possible
|
||||
if (null !== $this->tokenStorage) {
|
||||
$token = $this->tokenStorage->getToken();
|
||||
|
||||
// @deprecated since Symfony 5.4
|
||||
if ($token instanceof AnonymousToken) {
|
||||
throw new \InvalidArgumentException('Unable to generate a logout url for an anonymous token.');
|
||||
}
|
||||
|
||||
if (null !== $token) {
|
||||
if (method_exists($token, 'getFirewallName')) {
|
||||
$key = $token->getFirewallName();
|
||||
} elseif (method_exists($token, 'getProviderKey')) {
|
||||
trigger_deprecation('symfony/security-http', '5.2', 'Method "%s::getProviderKey()" has been deprecated, rename it to "getFirewallName()" instead.', \get_class($token));
|
||||
|
||||
$key = $token->getProviderKey();
|
||||
}
|
||||
|
||||
if (isset($this->listeners[$key])) {
|
||||
return $this->listeners[$key];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// Fetch from injected current firewall information, if possible
|
||||
if (isset($this->listeners[$this->currentFirewallName])) {
|
||||
return $this->listeners[$this->currentFirewallName];
|
||||
}
|
||||
|
||||
foreach ($this->listeners as $listener) {
|
||||
if (isset($listener[4]) && $this->currentFirewallContext === $listener[4]) {
|
||||
return $listener;
|
||||
}
|
||||
}
|
||||
|
||||
throw new \InvalidArgumentException('Unable to find the current firewall LogoutListener, please provide the provider key manually.');
|
||||
}
|
||||
}
|
37
vendor/symfony/security-http/Logout/SessionLogoutHandler.php
vendored
Normal file
37
vendor/symfony/security-http/Logout/SessionLogoutHandler.php
vendored
Normal file
@ -0,0 +1,37 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
* This file is part of the Symfony package.
|
||||
*
|
||||
* (c) Fabien Potencier <fabien@symfony.com>
|
||||
*
|
||||
* For the full copyright and license information, please view the LICENSE
|
||||
* file that was distributed with this source code.
|
||||
*/
|
||||
|
||||
namespace Symfony\Component\Security\Http\Logout;
|
||||
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
|
||||
use Symfony\Component\Security\Http\EventListener\SessionLogoutListener;
|
||||
|
||||
trigger_deprecation('symfony/security-http', '5.4', 'The "%s" class is deprecated, use "%s" instead.', SessionLogoutHandler::class, SessionLogoutListener::class);
|
||||
|
||||
/**
|
||||
* Handler for clearing invalidating the current session.
|
||||
*
|
||||
* @author Johannes M. Schmitt <schmittjoh@gmail.com>
|
||||
*
|
||||
* @deprecated since Symfony 5.4, use {@link SessionLogoutListener} instead
|
||||
*/
|
||||
class SessionLogoutHandler implements LogoutHandlerInterface
|
||||
{
|
||||
/**
|
||||
* Invalidate the current session.
|
||||
*/
|
||||
public function logout(Request $request, Response $response, TokenInterface $token)
|
||||
{
|
||||
$request->getSession()->invalidate();
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user