diff --git a/Cargo.lock b/Cargo.lock index 887fae1936..5f1eb93e5d 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -1962,6 +1962,7 @@ dependencies = [ "serial_test", "sha2", "strum_macros", + "task-local-extensions", "tracing", "url", "uuid", diff --git a/crates/apub/Cargo.toml b/crates/apub/Cargo.toml index f8320c2800..095247c6d3 100644 --- a/crates/apub/Cargo.toml +++ b/crates/apub/Cargo.toml @@ -49,3 +49,4 @@ parking_lot = "0.12.0" serial_test = "0.6.0" assert-json-diff = "2.0.1" reqwest-middleware = "0.1.5" +task-local-extensions = "0.1.1" diff --git a/crates/apub/src/objects/mod.rs b/crates/apub/src/objects/mod.rs index e07eb4def5..3b7aab2cb6 100644 --- a/crates/apub/src/objects/mod.rs +++ b/crates/apub/src/objects/mod.rs @@ -55,6 +55,7 @@ pub(crate) fn verify_is_remote_object(id: &Url) -> Result<(), LemmyError> { #[cfg(test)] pub(crate) mod tests { use actix::Actor; + use anyhow::anyhow; use diesel::{ r2d2::{ConnectionManager, Pool}, PgConnection, @@ -71,9 +72,25 @@ pub(crate) mod tests { }; use lemmy_websocket::{chat_server::ChatServer, LemmyContext}; use parking_lot::Mutex; - use reqwest::Client; - use reqwest_middleware::ClientBuilder; + use reqwest::{Client, Request, Response}; + use reqwest_middleware::{ClientBuilder, Middleware, Next}; use std::sync::Arc; + use task_local_extensions::Extensions; + + struct BlockedMiddleware; + + /// A reqwest middleware which blocks all requests + #[async_trait::async_trait] + impl Middleware for BlockedMiddleware { + async fn handle( + &self, + _req: Request, + _extensions: &mut Extensions, + _next: Next<'_>, + ) -> reqwest_middleware::Result { + Err(anyhow!("Network requests not allowed").into()) + } + } // TODO: would be nice if we didnt have to use a full context for tests. pub(crate) fn init_context() -> LemmyContext { @@ -89,7 +106,7 @@ pub(crate) mod tests { .build() .unwrap(); - let client = ClientBuilder::new(client).build(); + let client = ClientBuilder::new(client).with(BlockedMiddleware).build(); let secret = Secret { id: 0, jwt_secret: "".to_string(),