suggest dont_cache if there are query params

This commit is contained in:
slonkazoid 2024-12-16 23:09:18 +03:00
parent 36b1eba839
commit 72c53b0923
Signed by: slonk
SSH key fingerprint: SHA256:tbZfJX4IOvZ0LGWOWu5Ijo8jfMPi78TU7x1VoEeCIjM

View file

@ -82,6 +82,7 @@ impl Blag {
name: Arc<str>, name: Arc<str>,
path: impl AsRef<Path>, path: impl AsRef<Path>,
query_json: String, query_json: String,
dont_cache: bool,
) -> Result<(PostMetadata, String, (Duration, Duration), bool), PostError> { ) -> Result<(PostMetadata, String, (Duration, Duration), bool), PostError> {
let start = Instant::now(); let start = Instant::now();
@ -90,6 +91,7 @@ impl Blag {
let mut cmd = tokio::process::Command::new(&*self.blag_bin) let mut cmd = tokio::process::Command::new(&*self.blag_bin)
.arg(path.as_ref()) .arg(path.as_ref())
.env("BLAG_QUERY", query_json) .env("BLAG_QUERY", query_json)
.env("DONT_CACHE", if dont_cache { "1" } else { "" })
.stdout(Stdio::piped()) .stdout(Stdio::piped())
.spawn() .spawn()
.map_err(|err| { .map_err(|err| {
@ -232,6 +234,7 @@ impl PostManager for Blag {
let mut hasher = DefaultHasher::new(); let mut hasher = DefaultHasher::new();
query_json.hash(&mut hasher); query_json.hash(&mut hasher);
let query_hash = hasher.finish(); let query_hash = hasher.finish();
let suggest_dont_cache = !query.is_empty();
let post = if let Some(cache) = &self.cache { let post = if let Some(cache) = &self.cache {
if let Some(CacheValue { meta, body, .. }) = if let Some(CacheValue { meta, body, .. }) =
@ -243,8 +246,9 @@ impl PostManager for Blag {
perf: RenderStats::Cached(start.elapsed()), perf: RenderStats::Cached(start.elapsed()),
} }
} else { } else {
let (meta, content, (parsed, rendered), dont_cache) = let (meta, content, (parsed, rendered), dont_cache) = self
self.render(name.clone(), path, query_json).await?; .render(name.clone(), path, query_json, suggest_dont_cache)
.await?;
let body = content.into(); let body = content.into();
if !dont_cache { if !dont_cache {
@ -266,8 +270,9 @@ impl PostManager for Blag {
} }
} }
} else { } else {
let (meta, content, (parsed, rendered), ..) = let (meta, content, (parsed, rendered), ..) = self
self.render(name, path, query_json).await?; .render(name, path, query_json, suggest_dont_cache)
.await?;
let total = start.elapsed(); let total = start.elapsed();
ReturnedPost::Rendered { ReturnedPost::Rendered {