]> Untitled Git - lemmy.git/blob - crates/apub/src/objects/mod.rs
Merge pull request #1978 from LemmyNet/asonix/reqwest-middleware
[lemmy.git] / crates / apub / src / objects / mod.rs
1 use crate::protocol::Source;
2 use html2md::parse_html;
3
4 pub mod comment;
5 pub mod community;
6 pub mod person;
7 pub mod post;
8 pub mod private_message;
9
10 pub(crate) fn get_summary_from_string_or_source(
11   raw: &Option<String>,
12   source: &Option<Source>,
13 ) -> Option<String> {
14   if let Some(source) = &source {
15     Some(source.content.clone())
16   } else {
17     raw.as_ref().map(|s| parse_html(s))
18   }
19 }
20
21 #[cfg(test)]
22 pub(crate) mod tests {
23   use actix::Actor;
24   use background_jobs::QueueHandle;
25   use diesel::{
26     r2d2::{ConnectionManager, Pool},
27     PgConnection,
28   };
29   use lemmy_db_schema::{
30     establish_unpooled_connection,
31     get_database_url_from_env,
32     source::secret::Secret,
33   };
34   use lemmy_utils::{
35     rate_limit::{rate_limiter::RateLimiter, RateLimit},
36     request::build_user_agent,
37     settings::structs::Settings,
38     LemmyError,
39   };
40   use lemmy_websocket::{chat_server::ChatServer, LemmyContext};
41   use reqwest::Client;
42   use reqwest_middleware::ClientBuilder;
43   use serde::de::DeserializeOwned;
44   use std::{fs::File, io::BufReader, sync::Arc};
45   use tokio::sync::Mutex;
46
47   // TODO: would be nice if we didnt have to use a full context for tests.
48   //       or at least write a helper function so this code is shared with main.rs
49   pub(crate) fn init_context(activity_queue: QueueHandle) -> LemmyContext {
50     // call this to run migrations
51     establish_unpooled_connection();
52     let settings = Settings::init().unwrap();
53     let rate_limiter = RateLimit {
54       rate_limiter: Arc::new(Mutex::new(RateLimiter::default())),
55       rate_limit_config: settings.rate_limit.to_owned().unwrap_or_default(),
56     };
57     let client = Client::builder()
58       .user_agent(build_user_agent(&settings))
59       .build()
60       .unwrap();
61
62     let client = ClientBuilder::new(client).build();
63     let secret = Secret {
64       id: 0,
65       jwt_secret: "".to_string(),
66     };
67     let db_url = match get_database_url_from_env() {
68       Ok(url) => url,
69       Err(_) => settings.get_database_url(),
70     };
71     let manager = ConnectionManager::<PgConnection>::new(&db_url);
72     let pool = Pool::builder()
73       .max_size(settings.database.pool_size)
74       .build(manager)
75       .unwrap_or_else(|_| panic!("Error connecting to {}", db_url));
76     async fn x() -> Result<String, LemmyError> {
77       Ok("".to_string())
78     }
79     let chat_server = ChatServer::startup(
80       pool.clone(),
81       rate_limiter,
82       |_, _, _, _| Box::pin(x()),
83       |_, _, _, _| Box::pin(x()),
84       client.clone(),
85       activity_queue.clone(),
86       settings.clone(),
87       secret.clone(),
88     )
89     .start();
90     LemmyContext::create(pool, chat_server, client, activity_queue, settings, secret)
91   }
92
93   pub(crate) fn file_to_json_object<T: DeserializeOwned>(path: &str) -> T {
94     let file = File::open(path).unwrap();
95     let reader = BufReader::new(file);
96     serde_json::from_reader(reader).unwrap()
97   }
98 }