login consent app sql
This commit is contained in:
48
vendor/symfony/security-http/RateLimiter/DefaultLoginRateLimiter.php
vendored
Normal file
48
vendor/symfony/security-http/RateLimiter/DefaultLoginRateLimiter.php
vendored
Normal file
@ -0,0 +1,48 @@
|
||||
<?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\RateLimiter;
|
||||
|
||||
use Symfony\Component\HttpFoundation\RateLimiter\AbstractRequestRateLimiter;
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
use Symfony\Component\RateLimiter\RateLimiterFactory;
|
||||
use Symfony\Component\Security\Core\Security;
|
||||
|
||||
/**
|
||||
* A default login throttling limiter.
|
||||
*
|
||||
* This limiter prevents breadth-first attacks by enforcing
|
||||
* a limit on username+IP and a (higher) limit on IP.
|
||||
*
|
||||
* @author Wouter de Jong <wouter@wouterj.nl>
|
||||
*/
|
||||
final class DefaultLoginRateLimiter extends AbstractRequestRateLimiter
|
||||
{
|
||||
private $globalFactory;
|
||||
private $localFactory;
|
||||
|
||||
public function __construct(RateLimiterFactory $globalFactory, RateLimiterFactory $localFactory)
|
||||
{
|
||||
$this->globalFactory = $globalFactory;
|
||||
$this->localFactory = $localFactory;
|
||||
}
|
||||
|
||||
protected function getLimiters(Request $request): array
|
||||
{
|
||||
$username = $request->attributes->get(Security::LAST_USERNAME, '');
|
||||
$username = preg_match('//u', $username) ? mb_strtolower($username, 'UTF-8') : strtolower($username);
|
||||
|
||||
return [
|
||||
$this->globalFactory->create($request->getClientIp()),
|
||||
$this->localFactory->create($username.'-'.$request->getClientIp()),
|
||||
];
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user