Skip to content

Commit

Permalink
fix: properly handle trailing / in more routes (#1900)
Browse files Browse the repository at this point in the history
  • Loading branch information
PianoPrinter authored Oct 17, 2023
1 parent 4a4e16c commit 0d6ddfb
Showing 1 changed file with 5 additions and 8 deletions.
13 changes: 5 additions & 8 deletions router/src/matching/matcher.rs
Original file line number Diff line number Diff line change
Expand Up @@ -57,13 +57,14 @@ impl Matcher {
let loc_len = loc_segments.len();
let len_diff: i32 = loc_len as i32 - self.len as i32;

let trailing_iter = location.chars().rev().take_while(|n| *n == '/');

// quick path: not a match if
// 1) matcher has add'l segments not found in location
// 2) location has add'l segments, there's no splat, and partial matches not allowed
if loc_len < self.len
|| (len_diff > 0 && self.splat.is_none() && !self.partial)
|| (self.splat.is_none()
&& location.split('/').count() > (2 * (loc_segments.len() + 1)))
|| (self.splat.is_none() && trailing_iter.clone().count() > 1)
{
None
}
Expand Down Expand Up @@ -95,12 +96,8 @@ impl Matcher {
};

// add trailing slashes to splat
let trailing_slashes = location
.chars()
.rev()
.take_while(|n| *n == '/')
.skip(1)
.collect::<String>();
let trailing_slashes =
trailing_iter.skip(1).collect::<String>();
value.push_str(&trailing_slashes);

params.insert(splat.into(), value);
Expand Down

0 comments on commit 0d6ddfb

Please sign in to comment.