1 use crate::PerformCrud;
2 use actix_web::web::Data;
3 use lemmy_api_common::{
5 get_local_user_view_from_jwt,
7 site::{EditSite, SiteResponse},
8 site_description_length_check,
10 use lemmy_db_schema::{
11 diesel_option_overwrite,
12 diesel_option_overwrite_to_url,
15 local_user::LocalUser,
16 site::{Site, SiteForm},
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};
24 #[async_trait::async_trait(?Send)]
25 impl PerformCrud for EditSite {
26 type Response = SiteResponse;
28 #[tracing::instrument(skip(context, websocket_id))]
31 context: &Data<LemmyContext>,
32 websocket_id: Option<ConnectionId>,
33 ) -> Result<SiteResponse, LemmyError> {
34 let data: &EditSite = self;
36 get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
38 check_slurs_opt(&data.name, &context.settings().slur_regex())?;
39 check_slurs_opt(&data.description, &context.settings().slur_regex())?;
41 // Make sure user is an admin
42 is_admin(&local_user_view)?;
44 let found_site = blocking(context.pool(), Site::read_simple).await??;
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)?;
52 if let Some(Some(desc)) = &description {
53 site_description_length_check(desc)?;
56 let site_form = SiteForm {
57 creator_id: found_site.creator_id,
58 name: data.name.to_owned().unwrap_or(found_site.name),
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,
71 private_instance: data.private_instance,
74 let update_site = blocking(context.pool(), move |conn| {
75 Site::update(conn, 1, &site_form)
78 .map_err(LemmyError::from)
79 .map_err(|e| e.with_message("couldnt_update_site"))?;
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.
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)
91 .map_err(LemmyError::from)
92 .map_err(|e| e.with_message("couldnt_set_all_registrations_accepted"))?;
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)
100 .map_err(LemmyError::from)
101 .map_err(|e| e.with_message("couldnt_set_all_email_verified"))?;
104 let site_view = blocking(context.pool(), SiteView::read).await??;
106 let res = SiteResponse { site_view };
108 context.chat_server().do_send(SendAllMessage {
109 op: UserOperationCrud::EditSite,
110 response: res.clone(),