Implement new SkRateLimiterServer with Leaky Bucket rate limits (resolves #592)
-
Review changes -
-
Download -
Patches
-
Plain diff
What does this MR do?
Introduces a new SkRateLimiterService
which uses Leaky Bucket logic instead of Misskey's "time-box" rate limits. All internal servers are updated to use the new limiter, and FileServerService
is patched to respect role-based rate limit scaling.
Additionally, all API endpoints now return detailed rate limit headers. The new headers are:
-
X-RateLimit-Remaining
- number of calls that can be made without triggering the rate limit. Will be zero if the limit is already exceeded, or will be exceeded by the next request.
Example:X-RateLimit-Remaining: 1
. -
X-RateLimit-Clear
- time in seconds required to completely clear the rate limit "bucket".
Example:X-RateLimit-Clear: 1.5
. -
X-RateLimit-Reset
- if the rate limit is currently exceeded, then contains the number of seconds to wait before retrying. Clients should delay for at least this long before retrying their request. Only included if the rate limit has been exceeded.
Example:X-RateLimit-Reset: 0.755
. -
Retry-After
- likeX-RateLimit-Reset
, but measured in seconds (rounded up). Preserved for backwards compatibility, and only included if the rate limit has been exceeded.
Example:Retry-After: 2
.
Note: rate limit headers are not standardized, except for Retry-After
. Header meanings and usage have been devised by adapting common patterns to work with a leaky bucket model instead. Some helpful resources for context, ideas, and prior work:
- https://ietf-wg-httpapi.github.io/ratelimit-headers/darrelmiller-policyname/draft-ietf-httpapi-ratelimit-headers.txt
- https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Retry-After
- https://stackoverflow.com/a/16022625
Contribution Guidelines
By submitting this merge request, you agree to follow our Contribution Guidelines
-
I agree to follow this project's Contribution Guidelines -
I have made sure to test this merge request
Edited by Hazelnoot
Merge request reports
Loading