1 | <?php |
||
23 | final class RateLimitMiddleware |
||
24 | { |
||
25 | const LIMIT_EXCEEDED_HTTP_STATUS_CODE = 429; //HTTP 429 "Too Many Requests" (RFC 6585) |
||
26 | |||
27 | const HEADER_LIMIT = 'X-RateLimit-Limit'; |
||
28 | const HEADER_REMAINING = 'X-RateLimit-Remaining'; |
||
29 | const HEADER_RESET = 'X-RateLimit-Reset'; |
||
30 | |||
31 | /** |
||
32 | * @var RateLimiterInterface |
||
33 | */ |
||
34 | private $rateLimiter; |
||
35 | |||
36 | /** |
||
37 | * @var IdentityResolverInterface |
||
38 | */ |
||
39 | private $identityResolver; |
||
40 | |||
41 | /** |
||
42 | * @var Options |
||
43 | */ |
||
44 | private $options; |
||
45 | |||
46 | /** |
||
47 | * @var string |
||
48 | */ |
||
49 | private $identity; |
||
50 | |||
51 | 7 | public function __construct(RateLimiterInterface $rateLimiter, IdentityResolverInterface $identityResolver, Options $options) |
|
57 | |||
58 | 7 | public static function createDefault(RateLimiterInterface $rateLimiter, array $options = []) |
|
66 | |||
67 | /** |
||
68 | * {@inheritdoc} |
||
69 | */ |
||
70 | 7 | public function __invoke(RequestInterface $request, ResponseInterface $response, callable $out = null) |
|
74 | |||
75 | 7 | public function process(RequestInterface $request, ResponseInterface $response, callable $out = null) |
|
91 | |||
92 | 7 | private function isWhitelisted(RequestInterface $request) |
|
98 | |||
99 | 6 | private function resolveIdentity(RequestInterface $request) |
|
103 | |||
104 | 3 | private function onLimitExceeded(RequestInterface $request, ResponseInterface $response) |
|
116 | |||
117 | 6 | private function onBelowLimit(RequestInterface $request, ResponseInterface $response, callable $out = null) |
|
123 | |||
124 | 7 | private function next(RequestInterface $request, ResponseInterface $response, callable $out = null) |
|
128 | |||
129 | 6 | private function setRateLimitHeaders(ResponseInterface $response) |
|
137 | } |
||
138 |