diff --git a/pingora-core/src/protocols/ssl/mod.rs b/pingora-core/src/protocols/ssl/mod.rs index f1ce8b955..4f6f928cc 100644 --- a/pingora-core/src/protocols/ssl/mod.rs +++ b/pingora-core/src/protocols/ssl/mod.rs @@ -236,7 +236,7 @@ impl ALPN { } } - pub(crate) fn from_wire_selected(raw: &[u8]) -> Option { + pub fn from_wire_selected(raw: &[u8]) -> Option { match raw { b"http/1.1" => Some(Self::H1), b"h2" => Some(Self::H2), diff --git a/pingora-proxy/examples/ctx.rs b/pingora-proxy/examples/ctx.rs index 4838391e3..46628b23f 100644 --- a/pingora-proxy/examples/ctx.rs +++ b/pingora-proxy/examples/ctx.rs @@ -43,7 +43,7 @@ fn check_beta_user(req: &pingora_http::RequestHeader) -> bool { #[async_trait] impl ProxyHttp for MyProxy { type CTX = MyCtx; - fn new_ctx(&self) -> Self::CTX { + fn new_ctx(&self, _session: &Session) -> Self::CTX { MyCtx { beta_user: false } } diff --git a/pingora-proxy/examples/gateway.rs b/pingora-proxy/examples/gateway.rs index 0bd53306d..581e53862 100644 --- a/pingora-proxy/examples/gateway.rs +++ b/pingora-proxy/examples/gateway.rs @@ -36,7 +36,7 @@ pub struct MyGateway { #[async_trait] impl ProxyHttp for MyGateway { type CTX = (); - fn new_ctx(&self) -> Self::CTX {} + fn new_ctx(&self, _session: &Session) -> Self::CTX {} async fn request_filter(&self, session: &mut Session, _ctx: &mut Self::CTX) -> Result { if session.req_header().uri.path().starts_with("/login") diff --git a/pingora-proxy/examples/load_balancer.rs b/pingora-proxy/examples/load_balancer.rs index 614981d60..0d599ecb7 100644 --- a/pingora-proxy/examples/load_balancer.rs +++ b/pingora-proxy/examples/load_balancer.rs @@ -30,7 +30,7 @@ pub struct LB(Arc>); #[async_trait] impl ProxyHttp for LB { type CTX = (); - fn new_ctx(&self) -> Self::CTX {} + fn new_ctx(&self, _session: &Session) -> Self::CTX {} async fn upstream_peer(&self, _session: &mut Session, _ctx: &mut ()) -> Result> { let upstream = self diff --git a/pingora-proxy/examples/modify_response.rs b/pingora-proxy/examples/modify_response.rs index 6730f7186..bea3fa535 100644 --- a/pingora-proxy/examples/modify_response.rs +++ b/pingora-proxy/examples/modify_response.rs @@ -43,7 +43,7 @@ pub struct MyCtx { #[async_trait] impl ProxyHttp for Json2Yaml { type CTX = MyCtx; - fn new_ctx(&self) -> Self::CTX { + fn new_ctx(&self, _session: &Session) -> Self::CTX { MyCtx { buffer: vec![] } } diff --git a/pingora-proxy/examples/multi_lb.rs b/pingora-proxy/examples/multi_lb.rs index 1321c2079..ab9cef305 100644 --- a/pingora-proxy/examples/multi_lb.rs +++ b/pingora-proxy/examples/multi_lb.rs @@ -31,7 +31,7 @@ struct Router { #[async_trait] impl ProxyHttp for Router { type CTX = (); - fn new_ctx(&self) {} + fn new_ctx(&self, _session: &Session) {} async fn upstream_peer(&self, session: &mut Session, _ctx: &mut ()) -> Result> { // determine LB cluster based on request uri diff --git a/pingora-proxy/examples/use_module.rs b/pingora-proxy/examples/use_module.rs index 4404768f9..ca1af6c8f 100644 --- a/pingora-proxy/examples/use_module.rs +++ b/pingora-proxy/examples/use_module.rs @@ -83,7 +83,7 @@ pub struct MyProxy; #[async_trait] impl ProxyHttp for MyProxy { type CTX = (); - fn new_ctx(&self) -> Self::CTX {} + fn new_ctx(&self, _session: &Session) -> Self::CTX {} // This function is only called once when the server starts fn init_downstream_modules(&self, modules: &mut HttpModules) { diff --git a/pingora-proxy/src/lib.rs b/pingora-proxy/src/lib.rs index a02b23fc1..0202b446e 100644 --- a/pingora-proxy/src/lib.rs +++ b/pingora-proxy/src/lib.rs @@ -100,7 +100,7 @@ pub struct HttpProxy { } impl HttpProxy { - fn new(inner: SV, conf: Arc) -> Self { + pub fn new(inner: SV, conf: Arc) -> Self { HttpProxy { inner, client_upstream: Connector::new(Some(ConnectorOptions::from_server_conf(&conf))), @@ -691,8 +691,8 @@ where session.set_keepalive(None); session.subrequest_ctx.replace(sub_req_ctx); + let ctx = self.inner.new_ctx(&session); trace!("processing subrequest"); - let ctx = self.inner.new_ctx(); self.process_request(session, ctx).await; trace!("subrequest done"); } @@ -710,7 +710,6 @@ where shutdown: &ShutdownWatch, ) -> Option { let session = Box::new(session); - // TODO: keepalive pool, use stack let mut session = match self.handle_new_request(session).await { Some(downstream_session) => Session::new(downstream_session, &self.downstream_modules), @@ -725,7 +724,7 @@ where session.set_keepalive(Some(60)); } - let ctx = self.inner.new_ctx(); + let ctx = self.inner.new_ctx(&session); self.process_request(session, ctx).await } diff --git a/pingora-proxy/src/proxy_trait.rs b/pingora-proxy/src/proxy_trait.rs index 2d99567eb..346d218a2 100644 --- a/pingora-proxy/src/proxy_trait.rs +++ b/pingora-proxy/src/proxy_trait.rs @@ -28,7 +28,7 @@ pub trait ProxyHttp { type CTX; /// Define how the `ctx` should be created. - fn new_ctx(&self) -> Self::CTX; + fn new_ctx(&self, session: &Session) -> Self::CTX; /// Define where the proxy should send the request to. /// diff --git a/pingora-proxy/tests/utils/server_utils.rs b/pingora-proxy/tests/utils/server_utils.rs index ec1a96277..3375ecf7e 100644 --- a/pingora-proxy/tests/utils/server_utils.rs +++ b/pingora-proxy/tests/utils/server_utils.rs @@ -28,6 +28,8 @@ use pingora_cache::{ }; use pingora_core::apps::{HttpServerApp, HttpServerOptions}; use pingora_core::modules::http::compression::ResponseCompression; +use pingora_core::protocols::http::client::HttpSession; +use pingora_core::protocols::http::ServerSession; use pingora_core::protocols::{l4::socket::SocketAddr, Digest}; use pingora_core::server::configuration::Opt; use pingora_core::services::Service; @@ -108,7 +110,7 @@ fn response_filter_common( #[async_trait] impl ProxyHttp for ExampleProxyHttps { type CTX = CTX; - fn new_ctx(&self) -> Self::CTX { + fn new_ctx(&self, session: &Session) -> Self::CTX { CTX::default() } @@ -205,7 +207,7 @@ pub struct ExampleProxyHttp {} #[async_trait] impl ProxyHttp for ExampleProxyHttp { type CTX = CTX; - fn new_ctx(&self) -> Self::CTX { + fn new_ctx(&self, session: &Session) -> Self::CTX { CTX::default() } @@ -338,7 +340,7 @@ pub struct ExampleProxyCache {} #[async_trait] impl ProxyHttp for ExampleProxyCache { type CTX = CacheCTX; - fn new_ctx(&self) -> Self::CTX { + fn new_ctx(&self, session: &Session) -> Self::CTX { CacheCTX { upstream_status: None, }