]> Untitled Git - lemmy.git/blobdiff - crates/api_common/src/site.rs
Remove `actix_rt` & use standard tokio spawn (#3158)
[lemmy.git] / crates / api_common / src / site.rs
index faccb9f89e1c00b64a428af77bc4c0b4ffd4fee1..865acc0dc2f81bb84717bd82fc82c255b20f5e1a 100644 (file)
@@ -50,6 +50,7 @@ use ts_rs::TS;
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Searches the site, given a query string, and some optional filters.
 pub struct Search {
   pub q: String,
   pub community_id: Option<CommunityId>,
@@ -66,6 +67,8 @@ pub struct Search {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The search response, containing lists of the return type possibilities
+// TODO this should be redone as a list of tagged enums
 pub struct SearchResponse {
   pub type_: SearchType,
   pub comments: Vec<CommentView>,
@@ -77,7 +80,9 @@ pub struct SearchResponse {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Does an apub fetch for an object.
 pub struct ResolveObject {
+  /// Can be the full url, or a shortened version like: !fediverse@lemmy.ml
   pub q: String,
   pub auth: Sensitive<String>,
 }
@@ -87,6 +92,7 @@ pub struct ResolveObject {
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
 // TODO Change this to an enum
+/// The response of an apub object fetch.
 pub struct ResolveObjectResponse {
   pub comment: Option<CommentView>,
   pub post: Option<PostView>,
@@ -98,6 +104,7 @@ pub struct ResolveObjectResponse {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Fetches the modlog.
 pub struct GetModlog {
   pub mod_person_id: Option<PersonId>,
   pub community_id: Option<CommunityId>,
@@ -111,6 +118,8 @@ pub struct GetModlog {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The modlog fetch response.
+// TODO this should be redone as a list of tagged enums
 pub struct GetModlogResponse {
   pub removed_posts: Vec<ModRemovePostView>,
   pub locked_posts: Vec<ModLockPostView>,
@@ -133,6 +142,7 @@ pub struct GetModlogResponse {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Creates a site. Should be done after first running lemmy.
 pub struct CreateSite {
   pub name: String,
   pub sidebar: Option<String>,
@@ -167,7 +177,6 @@ pub struct CreateSite {
   pub rate_limit_search_per_second: Option<i32>,
   pub federation_enabled: Option<bool>,
   pub federation_debug: Option<bool>,
-  pub federation_worker_count: Option<i32>,
   pub captcha_enabled: Option<bool>,
   pub captcha_difficulty: Option<String>,
   pub allowed_instances: Option<Vec<String>>,
@@ -181,47 +190,77 @@ pub struct CreateSite {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Edits a site.
 pub struct EditSite {
   pub name: Option<String>,
   pub sidebar: Option<String>,
+  /// A shorter, one line description of your site.
   pub description: Option<String>,
+  /// A url for your site's icon.
   pub icon: Option<String>,
+  /// A url for your site's banner.
   pub banner: Option<String>,
+  /// Whether to enable downvotes.
   pub enable_downvotes: Option<bool>,
+  /// Whether to enable NSFW.
   pub enable_nsfw: Option<bool>,
+  /// Limits community creation to admins only.
   pub community_creation_admin_only: Option<bool>,
+  /// Whether to require email verification.
   pub require_email_verification: Option<bool>,
+  /// Your application question form. This is in markdown, and can be many questions.
   pub application_question: Option<String>,
+  /// Whether your instance is public, or private.
   pub private_instance: Option<bool>,
+  /// The default theme. Usually "browser"
   pub default_theme: Option<String>,
   pub default_post_listing_type: Option<ListingType>,
+  /// An optional page of legal information
   pub legal_information: Option<String>,
+  /// Whether to email admins when receiving a new application.
   pub application_email_admins: Option<bool>,
+  /// Whether to hide moderator names from the modlog.
   pub hide_modlog_mod_names: Option<bool>,
+  /// A list of allowed discussion languages.
   pub discussion_languages: Option<Vec<LanguageId>>,
+  /// A regex string of items to filter.
   pub slur_filter_regex: Option<String>,
+  /// The max length of actor names.
   pub actor_name_max_length: Option<i32>,
+  /// The number of messages allowed in a given time frame.
   pub rate_limit_message: Option<i32>,
   pub rate_limit_message_per_second: Option<i32>,
+  /// The number of posts allowed in a given time frame.
   pub rate_limit_post: Option<i32>,
   pub rate_limit_post_per_second: Option<i32>,
+  /// The number of registrations allowed in a given time frame.
   pub rate_limit_register: Option<i32>,
   pub rate_limit_register_per_second: Option<i32>,
+  /// The number of image uploads allowed in a given time frame.
   pub rate_limit_image: Option<i32>,
   pub rate_limit_image_per_second: Option<i32>,
+  /// The number of comments allowed in a given time frame.
   pub rate_limit_comment: Option<i32>,
   pub rate_limit_comment_per_second: Option<i32>,
+  /// The number of searches allowed in a given time frame.
   pub rate_limit_search: Option<i32>,
   pub rate_limit_search_per_second: Option<i32>,
+  /// Whether to enable federation.
   pub federation_enabled: Option<bool>,
+  /// Enables federation debugging.
   pub federation_debug: Option<bool>,
-  pub federation_worker_count: Option<i32>,
+  /// Whether to enable captchas for signups.
   pub captcha_enabled: Option<bool>,
+  /// The captcha difficulty. Can be easy, medium, or hard
   pub captcha_difficulty: Option<String>,
+  /// A list of allowed instances. If none are set, federation is open.
   pub allowed_instances: Option<Vec<String>>,
+  /// A list of blocked instances.
   pub blocked_instances: Option<Vec<String>>,
+  /// A list of taglines shown at the top of the front page.
   pub taglines: Option<Vec<String>>,
   pub registration_mode: Option<RegistrationMode>,
+  /// Whether to email admins for new reports.
   pub reports_email_admins: Option<bool>,
   pub auth: Sensitive<String>,
 }
@@ -230,6 +269,7 @@ pub struct EditSite {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Fetches the site.
 pub struct GetSite {
   pub auth: Option<Sensitive<String>>,
 }
@@ -237,42 +277,53 @@ pub struct GetSite {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The response for a site.
 pub struct SiteResponse {
   pub site_view: SiteView,
+  pub taglines: Vec<Tagline>,
 }
 
 #[skip_serializing_none]
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// An expanded response for a site.
 pub struct GetSiteResponse {
   pub site_view: SiteView,
   pub admins: Vec<PersonView>,
-  pub online: usize,
   pub version: String,
   pub my_user: Option<MyUserInfo>,
   pub all_languages: Vec<Language>,
   pub discussion_languages: Vec<LanguageId>,
+  /// A list of taglines shown at the top of the front page.
   pub taglines: Vec<Tagline>,
+  /// A list of custom emojis your site supports.
   pub custom_emojis: Vec<CustomEmojiView>,
 }
 
+#[skip_serializing_none]
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
-pub struct GetFederatedInstances {}
+/// Fetches the federated instances for your site.
+pub struct GetFederatedInstances {
+  pub auth: Option<Sensitive<String>>,
+}
 
 #[skip_serializing_none]
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// A response of federated instances.
 pub struct GetFederatedInstancesResponse {
-  pub federated_instances: Option<FederatedInstances>, // Federation may be disabled
+  /// Optional, because federation may be disabled.
+  pub federated_instances: Option<FederatedInstances>,
 }
 
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Your user info.
 pub struct MyUserInfo {
   pub local_user_view: LocalUserView,
   pub follows: Vec<CommunityFollowerView>,
@@ -285,6 +336,7 @@ pub struct MyUserInfo {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Leaves the admin team.
 pub struct LeaveAdmin {
   pub auth: Sensitive<String>,
 }
@@ -292,6 +344,7 @@ pub struct LeaveAdmin {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// A list of federated instances.
 pub struct FederatedInstances {
   pub linked: Vec<Instance>,
   pub allowed: Vec<Instance>,
@@ -302,6 +355,7 @@ pub struct FederatedInstances {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Purges a person from the database. This will delete all content attached to that person.
 pub struct PurgePerson {
   pub person_id: PersonId,
   pub reason: Option<String>,
@@ -312,6 +366,7 @@ pub struct PurgePerson {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Purges a community from the database. This will delete all content attached to that community.
 pub struct PurgeCommunity {
   pub community_id: CommunityId,
   pub reason: Option<String>,
@@ -322,6 +377,7 @@ pub struct PurgeCommunity {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Purges a post from the database. This will delete all content attached to that post.
 pub struct PurgePost {
   pub post_id: PostId,
   pub reason: Option<String>,
@@ -332,6 +388,7 @@ pub struct PurgePost {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Purges a comment from the database. This will delete all content attached to that comment.
 pub struct PurgeComment {
   pub comment_id: CommentId,
   pub reason: Option<String>,
@@ -341,6 +398,7 @@ pub struct PurgeComment {
 #[derive(Serialize, Deserialize)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The response for purged items.
 pub struct PurgeItemResponse {
   pub success: bool,
 }
@@ -349,6 +407,7 @@ pub struct PurgeItemResponse {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Fetches a list of registration applications.
 pub struct ListRegistrationApplications {
   /// Only shows the unread applications (IE those without an admin actor)
   pub unread_only: Option<bool>,
@@ -360,6 +419,7 @@ pub struct ListRegistrationApplications {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The list of registration applications.
 pub struct ListRegistrationApplicationsResponse {
   pub registration_applications: Vec<RegistrationApplicationView>,
 }
@@ -368,6 +428,7 @@ pub struct ListRegistrationApplicationsResponse {
 #[derive(Debug, Serialize, Deserialize, Clone, Default)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Approves a registration application.
 pub struct ApproveRegistrationApplication {
   pub id: i32,
   pub approve: bool,
@@ -378,6 +439,7 @@ pub struct ApproveRegistrationApplication {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The response of an action done to a registration application.
 pub struct RegistrationApplicationResponse {
   pub registration_application: RegistrationApplicationView,
 }
@@ -385,6 +447,7 @@ pub struct RegistrationApplicationResponse {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// Gets a count of unread registration applications.
 pub struct GetUnreadRegistrationApplicationCount {
   pub auth: Sensitive<String>,
 }
@@ -392,6 +455,7 @@ pub struct GetUnreadRegistrationApplicationCount {
 #[derive(Debug, Serialize, Deserialize, Clone)]
 #[cfg_attr(feature = "full", derive(TS))]
 #[cfg_attr(feature = "full", ts(export))]
+/// The count of unread registration applications.
 pub struct GetUnreadRegistrationApplicationCountResponse {
   pub registration_applications: i64,
 }