]> Untitled Git - lemmy.git/blob - crates/api_crud/src/site/update.rs
Add legal information (fixes #721) (#2273)
[lemmy.git] / crates / api_crud / src / site / update.rs
1 use crate::PerformCrud;
2 use actix_web::web::Data;
3 use lemmy_api_common::{
4   site::{EditSite, SiteResponse},
5   utils::{blocking, get_local_user_view_from_jwt, is_admin, site_description_length_check},
6 };
7 use lemmy_db_schema::{
8   source::{
9     local_user::LocalUser,
10     site::{Site, SiteForm},
11   },
12   traits::Crud,
13   utils::{diesel_option_overwrite, diesel_option_overwrite_to_url, naive_now},
14   ListingType,
15 };
16 use lemmy_db_views::structs::SiteView;
17 use lemmy_utils::{utils::check_slurs_opt, ConnectionId, LemmyError};
18 use lemmy_websocket::{messages::SendAllMessage, LemmyContext, UserOperationCrud};
19 use std::{default::Default, str::FromStr};
20
21 #[async_trait::async_trait(?Send)]
22 impl PerformCrud for EditSite {
23   type Response = SiteResponse;
24
25   #[tracing::instrument(skip(context, websocket_id))]
26   async fn perform(
27     &self,
28     context: &Data<LemmyContext>,
29     websocket_id: Option<ConnectionId>,
30   ) -> Result<SiteResponse, LemmyError> {
31     let data: &EditSite = self;
32     let local_user_view =
33       get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
34
35     // Make sure user is an admin
36     is_admin(&local_user_view)?;
37
38     let local_site = blocking(context.pool(), Site::read_local_site).await??;
39
40     let sidebar = diesel_option_overwrite(&data.sidebar);
41     let description = diesel_option_overwrite(&data.description);
42     let application_question = diesel_option_overwrite(&data.application_question);
43     let icon = diesel_option_overwrite_to_url(&data.icon)?;
44     let banner = diesel_option_overwrite_to_url(&data.banner)?;
45
46     check_slurs_opt(&data.name, &context.settings().slur_regex())?;
47     check_slurs_opt(&data.description, &context.settings().slur_regex())?;
48
49     if let Some(Some(desc)) = &description {
50       site_description_length_check(desc)?;
51     }
52
53     // Make sure if applications are required, that there is an application questionnaire
54     if data.require_application.unwrap_or(false)
55       && application_question.as_ref().unwrap_or(&None).is_none()
56     {
57       return Err(LemmyError::from_message("application_question_required"));
58     }
59
60     if let Some(default_post_listing_type) = &data.default_post_listing_type {
61       // only allow all or local as default listing types
62       let val = ListingType::from_str(default_post_listing_type);
63       if val != Ok(ListingType::All) && val != Ok(ListingType::Local) {
64         return Err(LemmyError::from_message(
65           "invalid_default_post_listing_type",
66         ));
67       }
68     }
69
70     let site_form = SiteForm {
71       name: data.name.to_owned().unwrap_or(local_site.name),
72       sidebar,
73       description,
74       icon,
75       banner,
76       updated: Some(naive_now()),
77       enable_downvotes: data.enable_downvotes,
78       open_registration: data.open_registration,
79       enable_nsfw: data.enable_nsfw,
80       community_creation_admin_only: data.community_creation_admin_only,
81       require_email_verification: data.require_email_verification,
82       require_application: data.require_application,
83       application_question,
84       private_instance: data.private_instance,
85       default_theme: data.default_theme.clone(),
86       default_post_listing_type: data.default_post_listing_type.clone(),
87       legal_information: data.legal_information.clone(),
88       ..SiteForm::default()
89     };
90
91     let update_site = blocking(context.pool(), move |conn| {
92       Site::update(conn, local_site.id, &site_form)
93     })
94     .await?
95     .map_err(|e| LemmyError::from_error_message(e, "couldnt_update_site"))?;
96
97     // TODO can't think of a better way to do this.
98     // If the server suddenly requires email verification, or required applications, no old users
99     // will be able to log in. It really only wants this to be a requirement for NEW signups.
100     // So if it was set from false, to true, you need to update all current users columns to be verified.
101
102     if !local_site.require_application && update_site.require_application {
103       blocking(context.pool(), move |conn| {
104         LocalUser::set_all_users_registration_applications_accepted(conn)
105       })
106       .await?
107       .map_err(|e| LemmyError::from_error_message(e, "couldnt_set_all_registrations_accepted"))?;
108     }
109
110     if !local_site.require_email_verification && update_site.require_email_verification {
111       blocking(context.pool(), move |conn| {
112         LocalUser::set_all_users_email_verified(conn)
113       })
114       .await?
115       .map_err(|e| LemmyError::from_error_message(e, "couldnt_set_all_email_verified"))?;
116     }
117
118     let site_view = blocking(context.pool(), SiteView::read_local).await??;
119
120     let res = SiteResponse { site_view };
121
122     context.chat_server().do_send(SendAllMessage {
123       op: UserOperationCrud::EditSite,
124       response: res.clone(),
125       websocket_id,
126     });
127
128     Ok(res)
129   }
130 }