Merge pull request #1185 from LemmyNet/federation-disable-downvotes

Respect disable downvotes setting when federating
This commit is contained in:
Dessalines 2020-10-09 13:58:29 -04:00 committed by GitHub
commit e61c3f0de3
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -16,6 +16,8 @@ use lemmy_db::{
comment_view::CommentView, comment_view::CommentView,
post::{PostForm, PostLike, PostLikeForm}, post::{PostForm, PostLike, PostLikeForm},
post_view::PostView, post_view::PostView,
site::Site,
Crud,
Likeable, Likeable,
}; };
use lemmy_structs::{blocking, comment::CommentResponse, post::PostResponse}; use lemmy_structs::{blocking, comment::CommentResponse, post::PostResponse};
@ -30,6 +32,14 @@ pub async fn receive_dislike(
activity: AnyBase, activity: AnyBase,
context: &LemmyContext, context: &LemmyContext,
) -> Result<HttpResponse, LemmyError> { ) -> Result<HttpResponse, LemmyError> {
let enable_downvotes = blocking(context.pool(), move |conn| {
Site::read(conn, 1).map(|s| s.enable_downvotes)
})
.await??;
if !enable_downvotes {
return Ok(HttpResponse::Ok().finish());
}
let dislike = Dislike::from_any_base(activity)?.context(location_info!())?; let dislike = Dislike::from_any_base(activity)?.context(location_info!())?;
match dislike.object().as_single_kind_str() { match dislike.object().as_single_kind_str() {
Some("Page") => receive_dislike_post(dislike, context).await, Some("Page") => receive_dislike_post(dislike, context).await,