3 object::{kind::ImageType, Tombstone, TombstoneExt},
6 use chrono::NaiveDateTime;
7 use html2md::parse_html;
8 use lemmy_apub_lib::values::MediaTypeMarkdown;
9 use lemmy_utils::{utils::convert_datetime, LemmyError};
10 use serde::{Deserialize, Serialize};
17 pub mod private_message;
19 #[derive(Clone, Debug, Deserialize, Serialize)]
20 #[serde(rename_all = "camelCase")]
23 media_type: MediaTypeMarkdown,
26 #[derive(Clone, Debug, Deserialize, Serialize)]
27 #[serde(rename_all = "camelCase")]
28 pub struct ImageObject {
29 #[serde(rename = "type")]
34 /// Updated is actually the deletion time
35 fn create_tombstone<T>(
38 updated: Option<NaiveDateTime>,
40 ) -> Result<Tombstone, LemmyError>
45 if let Some(updated) = updated {
46 let mut tombstone = Tombstone::new();
47 tombstone.set_id(object_id);
48 tombstone.set_former_type(former_type.to_string());
49 tombstone.set_deleted(convert_datetime(updated));
52 Err(anyhow!("Cant convert to tombstone because updated time was None.").into())
55 Err(anyhow!("Cant convert object to tombstone if it wasnt deleted").into())
59 fn get_summary_from_string_or_source(
61 source: &Option<Source>,
63 if let Some(source) = &source {
64 Some(source.content.clone())
66 raw.as_ref().map(|s| parse_html(s))
75 r2d2::{ConnectionManager, Pool},
78 use lemmy_apub_lib::activity_queue::create_activity_queue;
79 use lemmy_db_schema::{
80 establish_unpooled_connection,
81 get_database_url_from_env,
82 source::secret::Secret,
85 rate_limit::{rate_limiter::RateLimiter, RateLimit},
86 request::build_user_agent,
87 settings::structs::Settings,
89 use lemmy_websocket::{chat_server::ChatServer, LemmyContext};
91 use serde::de::DeserializeOwned;
92 use std::{fs::File, io::BufReader, sync::Arc};
93 use tokio::sync::Mutex;
95 // TODO: would be nice if we didnt have to use a full context for tests.
96 // or at least write a helper function so this code is shared with main.rs
97 pub(crate) fn init_context() -> LemmyContext {
98 // call this to run migrations
99 establish_unpooled_connection();
100 let settings = Settings::init().unwrap();
101 let rate_limiter = RateLimit {
102 rate_limiter: Arc::new(Mutex::new(RateLimiter::default())),
103 rate_limit_config: settings.rate_limit.to_owned().unwrap_or_default(),
105 let client = Client::builder()
106 .user_agent(build_user_agent(&settings))
109 let activity_queue = create_activity_queue();
110 let secret = Secret {
112 jwt_secret: "".to_string(),
114 let db_url = match get_database_url_from_env() {
116 Err(_) => settings.get_database_url(),
118 let manager = ConnectionManager::<PgConnection>::new(&db_url);
119 let pool = Pool::builder()
120 .max_size(settings.database.pool_size)
122 .unwrap_or_else(|_| panic!("Error connecting to {}", db_url));
123 async fn x() -> Result<String, LemmyError> {
126 let chat_server = ChatServer::startup(
129 |_, _, _, _| Box::pin(x()),
130 |_, _, _, _| Box::pin(x()),
132 activity_queue.clone(),
137 LemmyContext::create(pool, chat_server, client, activity_queue, settings, secret)
140 pub(crate) fn file_to_json_object<T: DeserializeOwned>(path: &str) -> T {
141 let file = File::open(path).unwrap();
142 let reader = BufReader::new(file);
143 serde_json::from_reader(reader).unwrap()