forked from Deuxfleurs/garage
move Redirect::compute_target to standalone function in web_server.rs
This commit is contained in:
parent
6ccfbb2986
commit
22487ceddf
2 changed files with 26 additions and 28 deletions
|
@ -85,31 +85,6 @@ mod v08 {
|
||||||
pub replace_key: Option<String>,
|
pub replace_key: Option<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl Redirect {
|
|
||||||
pub fn compute_target(&self, suffix: Option<&str>) -> String {
|
|
||||||
let mut res = String::new();
|
|
||||||
if let Some(hostname) = &self.hostname {
|
|
||||||
if let Some(protocol) = &self.protocol {
|
|
||||||
res.push_str(protocol);
|
|
||||||
res.push_str("://");
|
|
||||||
} else {
|
|
||||||
res.push_str("//");
|
|
||||||
}
|
|
||||||
res.push_str(hostname);
|
|
||||||
}
|
|
||||||
res.push('/');
|
|
||||||
if let Some(replace_key_prefix) = &self.replace_key_prefix {
|
|
||||||
res.push_str(replace_key_prefix);
|
|
||||||
if let Some(suffix) = suffix {
|
|
||||||
res.push_str(suffix)
|
|
||||||
}
|
|
||||||
} else if let Some(replace_key) = &self.replace_key {
|
|
||||||
res.push_str(replace_key)
|
|
||||||
}
|
|
||||||
res
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
#[derive(PartialEq, Eq, Clone, Debug, Serialize, Deserialize)]
|
#[derive(PartialEq, Eq, Clone, Debug, Serialize, Deserialize)]
|
||||||
pub struct CorsRule {
|
pub struct CorsRule {
|
||||||
pub id: Option<String>,
|
pub id: Option<String>,
|
||||||
|
|
|
@ -28,7 +28,7 @@ use garage_api::s3::error::{
|
||||||
};
|
};
|
||||||
use garage_api::s3::get::{handle_get_without_ctx, handle_head_without_ctx};
|
use garage_api::s3::get::{handle_get_without_ctx, handle_head_without_ctx};
|
||||||
|
|
||||||
use garage_model::bucket_table::RoutingRule;
|
use garage_model::bucket_table::{self, RoutingRule};
|
||||||
use garage_model::garage::Garage;
|
use garage_model::garage::Garage;
|
||||||
|
|
||||||
use garage_table::*;
|
use garage_table::*;
|
||||||
|
@ -518,7 +518,7 @@ fn path_to_keys(
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
};
|
};
|
||||||
let mut target = routing_rule.redirect.compute_target(suffix);
|
let mut target = compute_redirect_target(&routing_rule.redirect, suffix);
|
||||||
let query_alternative_key =
|
let query_alternative_key =
|
||||||
status_code == StatusCode::OK || status_code == StatusCode::NOT_FOUND;
|
status_code == StatusCode::OK || status_code == StatusCode::NOT_FOUND;
|
||||||
let redirect_on_error =
|
let redirect_on_error =
|
||||||
|
@ -560,7 +560,7 @@ fn path_to_keys(
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
let target = routing_rule.redirect.compute_target(None);
|
let target = compute_redirect_target(&routing_rule.redirect, None);
|
||||||
return Ok(RoutingResult::Redirect {
|
return Ok(RoutingResult::Redirect {
|
||||||
url: target,
|
url: target,
|
||||||
code: status_code,
|
code: status_code,
|
||||||
|
@ -601,6 +601,29 @@ const PATH_ENCODING_SET: &percent_encoding::AsciiSet = &percent_encoding::CONTRO
|
||||||
.add(b'{')
|
.add(b'{')
|
||||||
.add(b'}');
|
.add(b'}');
|
||||||
|
|
||||||
|
fn compute_redirect_target(redirect: &bucket_table::Redirect, suffix: Option<&str>) -> String {
|
||||||
|
let mut res = String::new();
|
||||||
|
if let Some(hostname) = &redirect.hostname {
|
||||||
|
if let Some(protocol) = &redirect.protocol {
|
||||||
|
res.push_str(protocol);
|
||||||
|
res.push_str("://");
|
||||||
|
} else {
|
||||||
|
res.push_str("//");
|
||||||
|
}
|
||||||
|
res.push_str(hostname);
|
||||||
|
}
|
||||||
|
res.push('/');
|
||||||
|
if let Some(replace_key_prefix) = &redirect.replace_key_prefix {
|
||||||
|
res.push_str(replace_key_prefix);
|
||||||
|
if let Some(suffix) = suffix {
|
||||||
|
res.push_str(suffix)
|
||||||
|
}
|
||||||
|
} else if let Some(replace_key) = &redirect.replace_key {
|
||||||
|
res.push_str(replace_key)
|
||||||
|
}
|
||||||
|
res
|
||||||
|
}
|
||||||
|
|
||||||
#[cfg(test)]
|
#[cfg(test)]
|
||||||
mod tests {
|
mod tests {
|
||||||
use super::*;
|
use super::*;
|
||||||
|
|
Loading…
Reference in a new issue