support redirection on s3 endpoint #910

Open
trinity-1686a wants to merge 9 commits from trinity-1686a/garage:1686a/s3-redirects into next-v2
3 changed files with 11 additions and 13 deletions
Showing only changes of commit c939d2a936 - Show all commits

View file

@ -330,13 +330,11 @@ impl Condition {
impl Redirect { impl Redirect {
pub fn validate(&self) -> Result<(), Error> { pub fn validate(&self) -> Result<(), Error> {
if self.replace_prefix.is_some() { if self.replace_prefix.is_some() && self.replace_full.is_some() {
if self.replace_full.is_some() {
return Err(Error::bad_request( return Err(Error::bad_request(
"Bad XML: both ReplaceKeyPrefixWith and ReplaceKeyWith are set", "Bad XML: both ReplaceKeyPrefixWith and ReplaceKeyWith are set",
)); ));
} }
}
if let Some(ref protocol) = self.protocol { if let Some(ref protocol) = self.protocol {
if protocol.0 != "http" && protocol.0 != "https" { if protocol.0 != "http" && protocol.0 != "https" {
return Err(Error::bad_request("Bad XML: invalid protocol")); return Err(Error::bad_request("Bad XML: invalid protocol"));

View file

@ -90,21 +90,21 @@ mod v08 {
let mut res = String::new(); let mut res = String::new();
if let Some(hostname) = &self.hostname { if let Some(hostname) = &self.hostname {
if let Some(protocol) = &self.protocol { if let Some(protocol) = &self.protocol {
res.push_str(&protocol); res.push_str(protocol);
res.push_str("://"); res.push_str("://");
} else { } else {
res.push_str("//"); res.push_str("//");
} }
res.push_str(&hostname); res.push_str(hostname);
} }
res.push('/'); res.push('/');
if let Some(replace_key_prefix) = &self.replace_key_prefix { if let Some(replace_key_prefix) = &self.replace_key_prefix {
res.push_str(&replace_key_prefix); res.push_str(replace_key_prefix);
if let Some(suffix) = suffix { if let Some(suffix) = suffix {
res.push_str(suffix) res.push_str(suffix)
} }
} else if let Some(replace_key) = &self.replace_key { } else if let Some(replace_key) = &self.replace_key {
res.push_str(&replace_key) res.push_str(replace_key)
} }
res res
} }

View file

@ -476,8 +476,8 @@ impl RoutingResult {
/// which is also AWS S3 behavior. /// which is also AWS S3 behavior.
/// ///
/// Check: https://docs.aws.amazon.com/AmazonS3/latest/userguide/IndexDocumentSupport.html /// Check: https://docs.aws.amazon.com/AmazonS3/latest/userguide/IndexDocumentSupport.html
fn path_to_keys<'a>( fn path_to_keys(
path: &'a str, path: &str,
index: &str, index: &str,
routing_rules: &[RoutingRule], routing_rules: &[RoutingRule],
) -> Result<RoutingResult, Error> { ) -> Result<RoutingResult, Error> {
@ -488,7 +488,7 @@ fn path_to_keys<'a>(
None => return Err(Error::BadRequest("Path must start with a / (slash)".into())), None => return Err(Error::BadRequest("Path must start with a / (slash)".into())),
}; };
let is_bucket_root = base_key.len() == 0; let is_bucket_root = base_key.is_empty();
let is_trailing_slash = path_utf8.ends_with("/"); let is_trailing_slash = path_utf8.ends_with("/");
let key = if is_bucket_root || is_trailing_slash { let key = if is_bucket_root || is_trailing_slash {