From 1063e44e625d72a78ef57eaadfcf5ce8c1678e27 Mon Sep 17 00:00:00 2001 From: metamuffin Date: Sun, 25 Aug 2024 01:13:23 +0200 Subject: very bad basic caching --- src/modules/cache.rs | 28 ++++++++++++++++++++++------ src/modules/mod.rs | 6 ++++-- 2 files changed, 26 insertions(+), 8 deletions(-) diff --git a/src/modules/cache.rs b/src/modules/cache.rs index d306ed1..03dc1be 100644 --- a/src/modules/cache.rs +++ b/src/modules/cache.rs @@ -14,11 +14,12 @@ use crate::{config::DynNode, error::ServiceError}; use anyhow::Result; use bytes::Bytes; use http::Response; -use http_body_util::BodyExt; +use http_body_util::{BodyExt, Full}; use serde::Deserialize; use serde_yaml::Value; use sha2::{Digest, Sha256}; use std::{collections::HashMap, future::Future, pin::Pin, sync::Arc}; +use tokio::sync::RwLock; pub struct CacheKind; @@ -28,7 +29,7 @@ struct CacheConfig { } struct Cache { - entries: HashMap<[u8; 32], Response>, + entries: RwLock>>, config: CacheConfig, } @@ -40,7 +41,7 @@ impl NodeKind for CacheKind { let config = serde_yaml::from_value::(config)?; Ok(Arc::new(Cache { config, - entries: HashMap::new(), + entries: HashMap::new().into(), })) } } @@ -60,13 +61,28 @@ impl Node for Cache { } let key: [u8; 32] = hasher.finalize().try_into().unwrap(); - if let Some(resp) = self.entries.get(&key) { - // Ok(resp.to_owned().map(|b| b.map_err(|e| match e {}).boxed())) + if let Some(resp) = self.entries.read().await.get(&key) { + return Ok(resp + .to_owned() + .map(|b| Full::new(b).map_err(|e| match e {}).boxed())); } let response = self.config.next.handle(context, request).await?; - Ok(response) + let h = response.headers().to_owned(); + let s = response.status().to_owned(); + let body = response.collect().await?.to_bytes(); + + let mut r1 = Response::new(Full::new(body.clone()).map_err(|e| match e {}).boxed()); + *r1.headers_mut() = h.clone(); + *r1.status_mut() = s.clone(); + + let mut r2 = Response::new(body); + *r2.headers_mut() = h; + *r2.status_mut() = s; + self.entries.write().await.insert(key, r2); + + Ok(r1) }) } } diff --git a/src/modules/mod.rs b/src/modules/mod.rs index 2494771..fc4d603 100644 --- a/src/modules/mod.rs +++ b/src/modules/mod.rs @@ -9,6 +9,7 @@ use std::{net::SocketAddr, pin::Pin, sync::Arc}; pub mod accesslog; pub mod auth; +pub mod cache; pub mod cgi; pub mod debug; pub mod error; @@ -16,12 +17,11 @@ pub mod file; pub mod files; pub mod headers; pub mod hosts; +pub mod loadbalance; pub mod paths; pub mod proxy; pub mod redirect; pub mod switch; -pub mod loadbalance; -pub mod cache; pub type NodeRequest = Request; pub type NodeResponse = Response>; @@ -42,6 +42,8 @@ pub static MODULES: &[&dyn NodeKind] = &[ &redirect::RedirectKind, &cgi::CgiKind, &debug::DebugKind, + &cache::CacheKind, + &loadbalance::LoadBalanceKind, ]; pub struct NodeContext { -- cgit v1.2.3-70-g09d2