fix: Session and user zone rate limits can be bypassed via trailing-slash or case path variants#10501
Conversation
|
I will reformat the title to use the proper commit message syntax. |
|
🚀 Thanks for opening this pull request! We appreciate your effort in improving the project. Please let us know once your pull request is ready for review. Tip
Note Please respond to review comments from AI agents just like you would to comments from a human reviewer. Let the reviewer resolve their own comments, unless they have reviewed and accepted your commit, or agreed with your explanation for why the feedback was incorrect. Caution Pull requests must be written using an AI agent with human supervision. Pull requests written entirely by a human will likely be rejected, because of lower code quality, higher review effort and the higher risk of introducing bugs. Please note that AI review comments on this pull request alone do not satisfy this requirement. Our CI and AI review are safeguards, not development tools. If many issues are flagged, rethink your development approach. Invest more effort in planning and design rather than using review cycles to fix low-quality code. |
|
No actionable comments were generated in the recent review. 🎉 ℹ️ Recent review info⚙️ Run configurationConfiguration used: Organization UI Review profile: CHILL Plan: Pro Run ID: 📒 Files selected for processing (3)
📝 WalkthroughWalkthroughPR adds ChangesRoute normalization for exact static route matching
Estimated code review effort🎯 2 (Simple) | ⏱️ ~12 minutes Possibly related PRs
🚥 Pre-merge checks | ✅ 5 | ❌ 2❌ Failed checks (1 warning, 1 inconclusive)
✅ Passed checks (5 passed)
✏️ Tip: You can configure your own custom pre-merge checks in the settings. ✨ Finishing Touches🧪 Generate unit tests (beta)
Warning There were issues while running some tools. Please review the errors and either fix the tool's configuration or disable the tool if it's a critical failure. 🔧 OpenGrep (1.22.0)OpenGrep fatal error (exit code 2): [00.10][ERROR]: Error: exception Unix_error: No such file or directory stat src/batch.js Thanks for using CodeRabbit! It's free for OSS, and your support helps us grow. If you like it, consider giving us a shout-out. Comment |
…lash or case path variants
f5421c5 to
c5349e8
Compare
Codecov Report✅ All modified and coverable lines are covered by tests. Additional details and impacted files@@ Coverage Diff @@
## alpha #10501 +/- ##
==========================================
- Coverage 92.62% 92.61% -0.01%
==========================================
Files 193 193
Lines 16941 16942 +1
Branches 240 240
==========================================
Hits 15691 15691
- Misses 1227 1228 +1
Partials 23 23 ☔ View full report in Codecov by Harness. 🚀 New features to boost your workflow:
|
Issue
Express routes case-insensitively and tolerates a trailing slash by default, so
/login/,/LOGIN, and/sessions/me/reach the same handlers as their canonical paths. The middleware checks that drop the inbound session token on/login(used for rate-limit zone keying) and that short-circuit session resolution onGET /sessions/meused a strict string comparison, so they did not recognize these routing-equivalent variants. As a result, asession- oruser-zone rate limit configured on those routes could be keyed inconsistently (by token or user id instead of the client IP) and drawn from a separate window when the request used a variant path, splitting or evading the configured limit.Tasks
Summary by CodeRabbit
/login,/login/, and/LOGINnow correctly share the same rate-limit window. Similarly,/sessions/meand/sessions/me/are treated identically for session-zone rate limiting.