Add Redis-based rate limiting with FastAPI Depends integration + configurable strategy via environment variables #1985
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
This PR introduces a complete, dependency-based Rate Limiting system for the FastAPI backend with Redis integration, configurable strategies, and automated validation through Settings. The implementation avoids middleware complexity and instead leverages FastAPI’s dependency injection system to enforce rate limiting at the endpoint level.
Rate Limiting via FastAPI Depends
Adds a RateLimiter class usable via Depends.
@router.get("/users", dependencies=[Depends(RateLimiter(times=2, seconds=5))])Redis-backed Sliding Window Strategy
Implements a redis-based sliding window rate limiter.
Uses Redis key patterns containing:
Strategy & Redis URL now configurable via .env
New environment variables added:
RATE_LIMITER_STRATEGY=sliding_window
RATE_LIMIT_FAIL_OPEN=True
REDIS_URL=redis://redis:6379/0