Skip to content

Commit

Permalink
feat: resolve asset based on full_path first in routing (#349)
Browse files Browse the repository at this point in the history
Signed-off-by: David Dal Busco <[email protected]>
  • Loading branch information
peterpeterparker authored Nov 29, 2023
1 parent d856cfc commit c1a15a1
Showing 1 changed file with 10 additions and 10 deletions.
20 changes: 10 additions & 10 deletions src/satellite/src/storage/routing.rs
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,16 @@ pub fn get_routing(

let MapUrl { path, token } = map_url(&url)?;

// We return the asset that matches the effective path
let asset: Option<(Asset, Memory)> = get_public_asset(path.clone(), token.clone());

match asset {
None => (),
Some(_) => {
return Ok(Routing::Default(RoutingDefault { url: path, asset }));
}
}

// ⚠️ Limitation: requesting an url without extension try to resolve first a corresponding asset
// e.g. /.well-known/hello -> try to find /.well-known/hello.html
// Therefore if a file without extension is uploaded to the storage, it is important to not upload an .html file with the same name next to it or a folder/index.html
Expand All @@ -42,16 +52,6 @@ pub fn get_routing(
}
}

// We return the asset that matches the effective path
let asset: Option<(Asset, Memory)> = get_public_asset(path.clone(), token.clone());

match asset {
None => (),
Some(_) => {
return Ok(Routing::Default(RoutingDefault { url: path, asset }));
}
}

if include_alternative_routing {
// Search for potential redirect
let redirect = get_routing_redirect(&path);
Expand Down

0 comments on commit c1a15a1

Please sign in to comment.