diff --git a/src/RuntimeConfigurableRateLimiter.php b/src/RuntimeConfigurableRateLimiter.php new file mode 100644 index 0000000..e023bbe --- /dev/null +++ b/src/RuntimeConfigurableRateLimiter.php @@ -0,0 +1,41 @@ +rateLimiter instanceof RateLimiter) { + throw new LogicException('Decorated Rate Limiter must implement RateLimiter interface'); + } + + if ($this->rateLimiter instanceof ConfigurableRateLimiter) { + $this->rateLimiter->rate = $rate; + } + + $this->rateLimiter->limit($identifier); + } + + public function limitSilently(string $identifier, Rate $rate = null): Status + { + if (!$this->rateLimiter instanceof SilentRateLimiter) { + throw new LogicException('Decorated Rate Limiter must implement SilentRateLimiter interface'); + } + + if ($this->rateLimiter instanceof ConfigurableRateLimiter) { + $this->rateLimiter->rate = $rate; + } + + return $this->rateLimiter->limitSilently($identifier); + } +} diff --git a/tests/RuntimeConfigurableRateLimiterTest.php b/tests/RuntimeConfigurableRateLimiterTest.php new file mode 100644 index 0000000..eaafc6f --- /dev/null +++ b/tests/RuntimeConfigurableRateLimiterTest.php @@ -0,0 +1,35 @@ +limitSilently($identifier, $rate); + + try { + $rateLimiter->limit($identifier, $rate); + + $this->fail('Limit should have been reached'); + } catch (LimitExceeded $exception) { + $this->assertSame($identifier, $exception->getIdentifier()); + $this->assertSame($rate, $exception->getRate()); + } + } +}