]> Untitled Git - lemmy.git/blob - crates/apub/src/objects/mod.rs
Make activity queue worker count configurable, log stats (#2113)
[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 instance;
7 pub mod person;
8 pub mod post;
9 pub mod private_message;
10
11 pub(crate) fn get_summary_from_string_or_source(
12   raw: &Option<String>,
13   source: &Option<Source>,
14 ) -> Option<String> {
15   if let Some(source) = &source {
16     Some(source.content.clone())
17   } else {
18     raw.as_ref().map(|s| parse_html(s))
19   }
20 }
21
22 #[cfg(test)]
23 pub(crate) mod tests {
24   use actix::Actor;
25   use diesel::{
26     r2d2::{ConnectionManager, Pool},
27     PgConnection,
28   };
29   use lemmy_apub_lib::activity_queue::create_activity_queue;
30   use lemmy_db_schema::{
31     establish_unpooled_connection,
32     get_database_url_from_env,
33     source::secret::Secret,
34   };
35   use lemmy_utils::{
36     rate_limit::{rate_limiter::RateLimiter, RateLimit},
37     request::build_user_agent,
38     settings::structs::Settings,
39     LemmyError,
40   };
41   use lemmy_websocket::{chat_server::ChatServer, LemmyContext};
42   use reqwest::Client;
43   use reqwest_middleware::ClientBuilder;
44   use std::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() -> LemmyContext {
50     let client = reqwest::Client::new().into();
51     // activity queue isnt used in tests, so worker count makes no difference
52     let queue_manager = create_activity_queue(client, 4);
53     let activity_queue = queue_manager.queue_handle().clone();
54     // call this to run migrations
55     establish_unpooled_connection();
56     let settings = Settings::init().unwrap();
57     let rate_limiter = RateLimit {
58       rate_limiter: Arc::new(Mutex::new(RateLimiter::default())),
59       rate_limit_config: settings.rate_limit.to_owned().unwrap_or_default(),
60     };
61     let client = Client::builder()
62       .user_agent(build_user_agent(&settings))
63       .build()
64       .unwrap();
65
66     let client = ClientBuilder::new(client).build();
67     let secret = Secret {
68       id: 0,
69       jwt_secret: "".to_string(),
70     };
71     let db_url = match get_database_url_from_env() {
72       Ok(url) => url,
73       Err(_) => settings.get_database_url(),
74     };
75     let manager = ConnectionManager::<PgConnection>::new(&db_url);
76     let pool = Pool::builder()
77       .max_size(settings.database.pool_size)
78       .build(manager)
79       .unwrap_or_else(|_| panic!("Error connecting to {}", db_url));
80     async fn x() -> Result<String, LemmyError> {
81       Ok("".to_string())
82     }
83     let chat_server = ChatServer::startup(
84       pool.clone(),
85       rate_limiter,
86       |_, _, _, _| Box::pin(x()),
87       |_, _, _, _| Box::pin(x()),
88       client.clone(),
89       activity_queue.clone(),
90       settings.clone(),
91       secret.clone(),
92     )
93     .start();
94     LemmyContext::create(pool, chat_server, client, activity_queue, settings, secret)
95   }
96 }