mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-11 01:35:28 +00:00
Better blocking checks
This commit is contained in:
parent
8cf7da4b19
commit
f974b9b895
1 changed files with 32 additions and 16 deletions
|
@ -1,6 +1,6 @@
|
||||||
''' defines relationships between users '''
|
''' defines relationships between users '''
|
||||||
from django.apps import apps
|
from django.apps import apps
|
||||||
from django.db import models, transaction
|
from django.db import models, transaction, IntegrityError
|
||||||
from django.db.models import Q
|
from django.db.models import Q
|
||||||
|
|
||||||
from bookwyrm import activitypub
|
from bookwyrm import activitypub
|
||||||
|
@ -60,6 +60,20 @@ class UserFollows(ActivitypubMixin, UserRelationship):
|
||||||
status = 'follows'
|
status = 'follows'
|
||||||
activity_serializer = activitypub.Follow
|
activity_serializer = activitypub.Follow
|
||||||
|
|
||||||
|
def save(self, *args, **kwargs):
|
||||||
|
''' really really don't let a user follow someone who blocked them '''
|
||||||
|
# blocking in either direction is a no-go
|
||||||
|
if UserBlocks.objects.filter(
|
||||||
|
Q(
|
||||||
|
user_subject=self.user_subject,
|
||||||
|
user_object=self.user_object,
|
||||||
|
) | Q(
|
||||||
|
user_subject=self.user_object,
|
||||||
|
user_object=self.user_subject,
|
||||||
|
)
|
||||||
|
).exists():
|
||||||
|
raise IntegrityError()
|
||||||
|
super().save(*args, **kwargs)
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def from_request(cls, follow_request):
|
def from_request(cls, follow_request):
|
||||||
|
@ -78,23 +92,25 @@ class UserFollowRequest(ActivitypubMixin, UserRelationship):
|
||||||
|
|
||||||
def save(self, *args, broadcast=True, **kwargs):
|
def save(self, *args, broadcast=True, **kwargs):
|
||||||
''' make sure the follow or block relationship doesn't already exist '''
|
''' make sure the follow or block relationship doesn't already exist '''
|
||||||
try:
|
# don't create a request if a follow already exists
|
||||||
UserFollows.objects.get(
|
if UserFollows.objects.filter(
|
||||||
user_subject=self.user_subject,
|
user_subject=self.user_subject,
|
||||||
user_object=self.user_object,
|
user_object=self.user_object,
|
||||||
)
|
).exists():
|
||||||
# blocking in either direction is a no-go
|
raise IntegrityError()
|
||||||
UserBlocks.objects.get(
|
# blocking in either direction is a no-go
|
||||||
user_subject=self.user_subject,
|
if UserBlocks.objects.filter(
|
||||||
user_object=self.user_object,
|
Q(
|
||||||
)
|
user_subject=self.user_subject,
|
||||||
UserBlocks.objects.get(
|
user_object=self.user_object,
|
||||||
user_subject=self.user_object,
|
) | Q(
|
||||||
user_object=self.user_subject,
|
user_subject=self.user_object,
|
||||||
)
|
user_object=self.user_subject,
|
||||||
return None
|
)
|
||||||
except (UserFollows.DoesNotExist, UserBlocks.DoesNotExist):
|
).exists():
|
||||||
super().save(*args, **kwargs)
|
raise IntegrityError()
|
||||||
|
|
||||||
|
super().save(*args, **kwargs)
|
||||||
|
|
||||||
if broadcast and self.user_subject.local and not self.user_object.local:
|
if broadcast and self.user_subject.local and not self.user_object.local:
|
||||||
self.broadcast(self.to_activity(), self.user_subject)
|
self.broadcast(self.to_activity(), self.user_subject)
|
||||||
|
|
Loading…
Reference in a new issue