forked from Drop-OSS/archived-drop-app
* fix: submillisecond cache hits * fix: async object loading to hand control back to renderer * fix: clippy
52 lines
1.6 KiB
Rust
52 lines
1.6 KiB
Rust
use http::{header::CONTENT_TYPE, response::Builder as ResponseBuilder};
|
|
use log::warn;
|
|
use tauri::UriSchemeResponder;
|
|
|
|
use crate::{DB, database::db::DatabaseImpls};
|
|
|
|
use super::{
|
|
auth::generate_authorization_header,
|
|
cache::{ObjectCache, cache_object, get_cached_object},
|
|
};
|
|
|
|
pub async fn fetch_object(request: http::Request<Vec<u8>>, responder: UriSchemeResponder) {
|
|
// Drop leading /
|
|
let object_id = &request.uri().path()[1..];
|
|
|
|
let cache_result = get_cached_object::<ObjectCache>(object_id);
|
|
if let Ok(cache_result) = &cache_result
|
|
&& !cache_result.has_expired()
|
|
{
|
|
responder.respond(cache_result.into());
|
|
return;
|
|
}
|
|
|
|
let header = generate_authorization_header();
|
|
let client = reqwest::Client::new();
|
|
let url = format!("{}api/v1/client/object/{object_id}", DB.fetch_base_url());
|
|
let response = client.get(url).header("Authorization", header).send().await;
|
|
|
|
if response.is_err() {
|
|
match cache_result {
|
|
Ok(cache_result) => responder.respond(cache_result.into()),
|
|
Err(e) => {
|
|
warn!("{e}")
|
|
}
|
|
}
|
|
return;
|
|
}
|
|
let response = response.unwrap();
|
|
|
|
let resp_builder = ResponseBuilder::new().header(
|
|
CONTENT_TYPE,
|
|
response.headers().get("Content-Type").unwrap(),
|
|
);
|
|
let data = Vec::from(response.bytes().await.unwrap());
|
|
let resp = resp_builder.body(data).unwrap();
|
|
if cache_result.is_err() || cache_result.unwrap().has_expired() {
|
|
cache_object::<ObjectCache>(object_id, &resp.clone().into()).unwrap();
|
|
}
|
|
|
|
responder.respond(resp);
|
|
}
|