Make sure application questionaire is required. Fixes #2189
Also fix local image domain check. Was failing for blank strings / replaces.
This commit is contained in:
parent
65cac21713
commit
37c834725c
6 changed files with 36 additions and 31 deletions
|
@ -176,9 +176,6 @@ impl Perform for SaveUserSettings {
|
||||||
let local_user_view =
|
let local_user_view =
|
||||||
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
||||||
|
|
||||||
check_image_has_local_domain(&data.avatar)?;
|
|
||||||
check_image_has_local_domain(&data.banner)?;
|
|
||||||
|
|
||||||
let avatar = diesel_option_overwrite_to_url(&data.avatar)?;
|
let avatar = diesel_option_overwrite_to_url(&data.avatar)?;
|
||||||
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
||||||
let bio = diesel_option_overwrite(&data.bio);
|
let bio = diesel_option_overwrite(&data.bio);
|
||||||
|
@ -188,6 +185,9 @@ impl Perform for SaveUserSettings {
|
||||||
let email_deref = data.email.as_deref().map(|e| e.to_owned());
|
let email_deref = data.email.as_deref().map(|e| e.to_owned());
|
||||||
let email = diesel_option_overwrite(&email_deref);
|
let email = diesel_option_overwrite(&email_deref);
|
||||||
|
|
||||||
|
check_image_has_local_domain(avatar.as_ref().unwrap_or(&None))?;
|
||||||
|
check_image_has_local_domain(banner.as_ref().unwrap_or(&None))?;
|
||||||
|
|
||||||
if let Some(Some(email)) = &email {
|
if let Some(Some(email)) = &email {
|
||||||
let previous_email = local_user_view.local_user.email.clone().unwrap_or_default();
|
let previous_email = local_user_view.local_user.email.clone().unwrap_or_default();
|
||||||
// Only send the verification email if there was an email change
|
// Only send the verification email if there was an email change
|
||||||
|
|
|
@ -7,7 +7,7 @@ pub mod websocket;
|
||||||
|
|
||||||
use crate::site::FederatedInstances;
|
use crate::site::FederatedInstances;
|
||||||
use lemmy_db_schema::{
|
use lemmy_db_schema::{
|
||||||
newtypes::{CommunityId, LocalUserId, PersonId, PostId},
|
newtypes::{CommunityId, DbUrl, LocalUserId, PersonId, PostId},
|
||||||
source::{
|
source::{
|
||||||
comment::Comment,
|
comment::Comment,
|
||||||
community::Community,
|
community::Community,
|
||||||
|
@ -41,7 +41,6 @@ use lemmy_utils::{
|
||||||
};
|
};
|
||||||
use rosetta_i18n::{Language, LanguageId};
|
use rosetta_i18n::{Language, LanguageId};
|
||||||
use tracing::warn;
|
use tracing::warn;
|
||||||
use url::Url;
|
|
||||||
|
|
||||||
pub async fn blocking<F, T>(pool: &DbPool, f: F) -> Result<T, LemmyError>
|
pub async fn blocking<F, T>(pool: &DbPool, f: F) -> Result<T, LemmyError>
|
||||||
where
|
where
|
||||||
|
@ -580,10 +579,9 @@ pub async fn remove_user_data_in_community(
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn check_image_has_local_domain(url: &Option<String>) -> Result<(), LemmyError> {
|
pub fn check_image_has_local_domain(url: &Option<DbUrl>) -> Result<(), LemmyError> {
|
||||||
if let Some(url) = url {
|
if let Some(url) = url {
|
||||||
let settings = Settings::get();
|
let settings = Settings::get();
|
||||||
let url = Url::parse(url)?;
|
|
||||||
let domain = url.domain().expect("url has domain");
|
let domain = url.domain().expect("url has domain");
|
||||||
if domain != settings.hostname {
|
if domain != settings.hostname {
|
||||||
return Err(LemmyError::from_message("image_not_local"));
|
return Err(LemmyError::from_message("image_not_local"));
|
||||||
|
|
|
@ -61,11 +61,15 @@ impl PerformCrud for CreateCommunity {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Check to make sure the icon and banners are urls
|
||||||
|
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
||||||
|
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
||||||
|
|
||||||
check_slurs(&data.name, &context.settings().slur_regex())?;
|
check_slurs(&data.name, &context.settings().slur_regex())?;
|
||||||
check_slurs(&data.title, &context.settings().slur_regex())?;
|
check_slurs(&data.title, &context.settings().slur_regex())?;
|
||||||
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
||||||
check_image_has_local_domain(&data.icon)?;
|
check_image_has_local_domain(icon.as_ref().unwrap_or(&None))?;
|
||||||
check_image_has_local_domain(&data.banner)?;
|
check_image_has_local_domain(banner.as_ref().unwrap_or(&None))?;
|
||||||
|
|
||||||
if !is_valid_actor_name(&data.name, context.settings().actor_name_max_length) {
|
if !is_valid_actor_name(&data.name, context.settings().actor_name_max_length) {
|
||||||
return Err(LemmyError::from_message("invalid_community_name"));
|
return Err(LemmyError::from_message("invalid_community_name"));
|
||||||
|
@ -83,10 +87,6 @@ impl PerformCrud for CreateCommunity {
|
||||||
return Err(LemmyError::from_message("community_already_exists"));
|
return Err(LemmyError::from_message("community_already_exists"));
|
||||||
}
|
}
|
||||||
|
|
||||||
// Check to make sure the icon and banners are urls
|
|
||||||
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
|
||||||
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
|
||||||
|
|
||||||
// When you create a community, make sure the user becomes a moderator and a follower
|
// When you create a community, make sure the user becomes a moderator and a follower
|
||||||
let keypair = generate_actor_keypair()?;
|
let keypair = generate_actor_keypair()?;
|
||||||
|
|
||||||
|
|
|
@ -36,10 +36,13 @@ impl PerformCrud for EditCommunity {
|
||||||
let local_user_view =
|
let local_user_view =
|
||||||
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
||||||
|
|
||||||
|
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
||||||
|
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
||||||
|
|
||||||
check_slurs_opt(&data.title, &context.settings().slur_regex())?;
|
check_slurs_opt(&data.title, &context.settings().slur_regex())?;
|
||||||
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
||||||
check_image_has_local_domain(&data.icon)?;
|
check_image_has_local_domain(icon.as_ref().unwrap_or(&None))?;
|
||||||
check_image_has_local_domain(&data.banner)?;
|
check_image_has_local_domain(banner.as_ref().unwrap_or(&None))?;
|
||||||
|
|
||||||
// Verify its a mod (only mods can edit it)
|
// Verify its a mod (only mods can edit it)
|
||||||
let community_id = data.community_id;
|
let community_id = data.community_id;
|
||||||
|
@ -58,9 +61,6 @@ impl PerformCrud for EditCommunity {
|
||||||
})
|
})
|
||||||
.await??;
|
.await??;
|
||||||
|
|
||||||
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
|
||||||
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
|
||||||
|
|
||||||
let community_form = CommunityForm {
|
let community_form = CommunityForm {
|
||||||
name: read_community.name,
|
name: read_community.name,
|
||||||
title: data.title.to_owned().unwrap_or(read_community.title),
|
title: data.title.to_owned().unwrap_or(read_community.title),
|
||||||
|
|
|
@ -48,19 +48,19 @@ impl PerformCrud for CreateSite {
|
||||||
let local_user_view =
|
let local_user_view =
|
||||||
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
||||||
|
|
||||||
check_slurs(&data.name, &context.settings().slur_regex())?;
|
|
||||||
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
|
||||||
check_image_has_local_domain(&data.icon)?;
|
|
||||||
check_image_has_local_domain(&data.banner)?;
|
|
||||||
|
|
||||||
// Make sure user is an admin
|
|
||||||
is_admin(&local_user_view)?;
|
|
||||||
|
|
||||||
let sidebar = diesel_option_overwrite(&data.sidebar);
|
let sidebar = diesel_option_overwrite(&data.sidebar);
|
||||||
let description = diesel_option_overwrite(&data.description);
|
let description = diesel_option_overwrite(&data.description);
|
||||||
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
||||||
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
||||||
|
|
||||||
|
check_slurs(&data.name, &context.settings().slur_regex())?;
|
||||||
|
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
||||||
|
check_image_has_local_domain(icon.as_ref().unwrap_or(&None))?;
|
||||||
|
check_image_has_local_domain(banner.as_ref().unwrap_or(&None))?;
|
||||||
|
|
||||||
|
// Make sure user is an admin
|
||||||
|
is_admin(&local_user_view)?;
|
||||||
|
|
||||||
if let Some(Some(desc)) = &description {
|
if let Some(Some(desc)) = &description {
|
||||||
site_description_length_check(desc)?;
|
site_description_length_check(desc)?;
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,11 +37,6 @@ impl PerformCrud for EditSite {
|
||||||
let local_user_view =
|
let local_user_view =
|
||||||
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
get_local_user_view_from_jwt(&data.auth, context.pool(), context.secret()).await?;
|
||||||
|
|
||||||
check_slurs_opt(&data.name, &context.settings().slur_regex())?;
|
|
||||||
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
|
||||||
check_image_has_local_domain(&data.icon)?;
|
|
||||||
check_image_has_local_domain(&data.banner)?;
|
|
||||||
|
|
||||||
// Make sure user is an admin
|
// Make sure user is an admin
|
||||||
is_admin(&local_user_view)?;
|
is_admin(&local_user_view)?;
|
||||||
|
|
||||||
|
@ -53,10 +48,22 @@ impl PerformCrud for EditSite {
|
||||||
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
let icon = diesel_option_overwrite_to_url(&data.icon)?;
|
||||||
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
let banner = diesel_option_overwrite_to_url(&data.banner)?;
|
||||||
|
|
||||||
|
check_slurs_opt(&data.name, &context.settings().slur_regex())?;
|
||||||
|
check_slurs_opt(&data.description, &context.settings().slur_regex())?;
|
||||||
|
check_image_has_local_domain(icon.as_ref().unwrap_or(&None))?;
|
||||||
|
check_image_has_local_domain(banner.as_ref().unwrap_or(&None))?;
|
||||||
|
|
||||||
if let Some(Some(desc)) = &description {
|
if let Some(Some(desc)) = &description {
|
||||||
site_description_length_check(desc)?;
|
site_description_length_check(desc)?;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Make sure if applications are required, that there is an application questionnaire
|
||||||
|
if data.require_application.unwrap_or(false)
|
||||||
|
&& application_question.as_ref().unwrap_or(&None).is_none()
|
||||||
|
{
|
||||||
|
return Err(LemmyError::from_message("application_question_required"));
|
||||||
|
}
|
||||||
|
|
||||||
let site_form = SiteForm {
|
let site_form = SiteForm {
|
||||||
name: data.name.to_owned().unwrap_or(local_site.name),
|
name: data.name.to_owned().unwrap_or(local_site.name),
|
||||||
sidebar,
|
sidebar,
|
||||||
|
|
Loading…
Reference in a new issue