]> Untitled Git - lemmy.git/blob - crates/apub/src/protocol/mod.rs
37a29f8fa0c8e70d68445bb58311d5a9a131b392
[lemmy.git] / crates / apub / src / protocol / mod.rs
1 use activitystreams::object::kind::ImageType;
2 use serde::{Deserialize, Serialize};
3 use url::Url;
4
5 use lemmy_apub_lib::values::MediaTypeMarkdown;
6
7 pub mod activities;
8 pub(crate) mod collections;
9 pub(crate) mod objects;
10
11 #[derive(Clone, Debug, Deserialize, Serialize)]
12 #[serde(rename_all = "camelCase")]
13 pub struct Source {
14   pub(crate) content: String,
15   pub(crate) media_type: MediaTypeMarkdown,
16 }
17
18 #[derive(Clone, Debug, Deserialize, Serialize)]
19 #[serde(rename_all = "camelCase")]
20 pub struct ImageObject {
21   #[serde(rename = "type")]
22   pub(crate) kind: ImageType,
23   pub(crate) url: Url,
24 }
25
26 #[cfg(test)]
27 pub(crate) mod tests {
28   use crate::objects::tests::file_to_json_object;
29   use assert_json_diff::assert_json_include;
30   use serde::{de::DeserializeOwned, Serialize};
31   use std::collections::HashMap;
32
33   pub(crate) fn test_parse_lemmy_item<T: Serialize + DeserializeOwned + std::fmt::Debug>(
34     path: &str,
35   ) -> T {
36     let parsed = file_to_json_object::<T>(path);
37
38     // ensure that no field is ignored when parsing
39     let raw = file_to_json_object::<HashMap<String, serde_json::Value>>(path);
40     assert_json_include!(actual: &parsed, expected: raw);
41     parsed
42   }
43 }