From aed0cd1ec2ca077e9e97ec84257512f3b1eab501 Mon Sep 17 00:00:00 2001 From: Lucio Franco Date: Fri, 1 Dec 2023 07:48:11 -0500 Subject: [PATCH] s3s-fs: fix path matching and add start_after (#112) This commit adds support for `start_after` and fixes some issues with `Path::start_with` being more strict than `str::start_with`. --- crates/s3s-fs/src/s3.rs | 19 +++++++++++++++++-- 1 file changed, 17 insertions(+), 2 deletions(-) diff --git a/crates/s3s-fs/src/s3.rs b/crates/s3s-fs/src/s3.rs index 79cf3882..0b9165e1 100644 --- a/crates/s3s-fs/src/s3.rs +++ b/crates/s3s-fs/src/s3.rs @@ -359,11 +359,17 @@ impl S3 for FileSystem { let file_path = entry.path(); let key = try_!(file_path.strip_prefix(&path)); let delimiter = input.delimiter.as_ref().map_or("/", |d| d.as_str()); - let Some(key_str) = normalize_path(key, delimiter) else { continue }; + let Some(key_str) = normalize_path(key, delimiter) else { + continue; + }; if let Some(ref prefix) = input.prefix { let prefix_path: PathBuf = prefix.split(delimiter).collect(); - if !key.starts_with(prefix_path) { + + let key_s = format!("{}", key.display()); + let prefix_path_s = format!("{}", prefix_path.display()); + + if !key_s.starts_with(&prefix_path_s) { continue; } } @@ -389,6 +395,15 @@ impl S3 for FileSystem { lhs_key.cmp(rhs_key) }); + let objects = if let Some(marker) = &input.start_after { + objects + .into_iter() + .skip_while(|n| n.key.as_deref().unwrap_or("") <= marker.as_str()) + .collect() + } else { + objects + }; + let key_count = try_!(i32::try_from(objects.len())); let output = ListObjectsV2Output {