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