<?php
namespace App\EventSubscriber;
use Symfony\Component\HttpKernel\Event\RequestEvent;
use Symfony\Component\RateLimiter\RateLimiterFactory;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\HttpKernel\Exception\TooManyRequestsHttpException;
class RateLimiterSubscriber implements EventSubscriberInterface
{
/**
* @var RateLimiterFactory
*/
private $anonymousApiLimiter;
public function __construct(RateLimiterFactory $anonymousApiLimiter)
{
$this->anonymousApiLimiter = $anonymousApiLimiter;
}
public static function getSubscribedEvents(): array
{
return [
RequestEvent::class => 'onKernelRequest',
];
}
public function onKernelRequest(RequestEvent $event): void
{
$request = $event->getRequest();
if ($request->isMethod('get')) {
$limiter = $this->anonymousApiLimiter->create($request->getClientIp());
/* $limit = $limiter->consume();
$headers = [
'X-RateLimit-Remaining' => $limit->getRemainingTokens(),
'X-RateLimit-Retry-After' => $limit->getRetryAfter()->getTimestamp(),
'X-RateLimit-Limit' => $limit->getLimit(),
]; */
if (false === $limiter->consume(1)->isAccepted()) {
throw new TooManyRequestsHttpException();
}
}
}
}