Fixes discarding boosts

This commit is contained in:
Mouse Reeve 2021-02-16 12:31:27 -08:00
parent 3f1b62eb98
commit f5a022184f
3 changed files with 22 additions and 7 deletions

View file

@ -156,10 +156,14 @@ class ActivitypubMixin:
return recipients return recipients
def to_activity(self): def to_activity_dataclass(self):
''' convert from a model to an activity ''' ''' convert from a model to an activity '''
activity = generate_activity(self) activity = generate_activity(self)
return self.activity_serializer(**activity).serialize() return self.activity_serializer(**activity)
def to_activity(self):
''' convert from a model to a json activity '''
return self.to_activity_dataclass().serialize()
class ObjectMixin(ActivitypubMixin): class ObjectMixin(ActivitypubMixin):

View file

@ -102,6 +102,12 @@ class Status(OrderedCollectionPageMixin, BookWyrmModel):
@classmethod @classmethod
def ignore_activity(cls, activity): def ignore_activity(cls, activity):
''' keep notes if they are replies to existing statuses ''' ''' keep notes if they are replies to existing statuses '''
if activity.type == 'Announce':
# keep it if the booster or the boosted are local
boosted = activitypub.resolve_remote_id(activity.object, save=False)
return cls.ignore_activity(boosted.to_activity_dataclass())
# keep if it if it's a custom type
if activity.type != 'Note': if activity.type != 'Note':
return False return False
if cls.objects.filter( if cls.objects.filter(
@ -112,8 +118,8 @@ class Status(OrderedCollectionPageMixin, BookWyrmModel):
if activity.tag == MISSING or activity.tag is None: if activity.tag == MISSING or activity.tag is None:
return True return True
tags = [l['href'] for l in activity.tag if l['type'] == 'Mention'] tags = [l['href'] for l in activity.tag if l['type'] == 'Mention']
for tag in tags:
user_model = apps.get_model('bookwyrm.User', require_ready=True) user_model = apps.get_model('bookwyrm.User', require_ready=True)
for tag in tags:
if user_model.objects.filter( if user_model.objects.filter(
remote_id=tag, local=True).exists(): remote_id=tag, local=True).exists():
# we found a mention of a known use boost # we found a mention of a known use boost

View file

@ -519,7 +519,7 @@ class Inbox(TestCase):
'type': 'Announce', 'type': 'Announce',
'id': '%s/boost' % self.status.remote_id, 'id': '%s/boost' % self.status.remote_id,
'actor': self.remote_user.remote_id, 'actor': self.remote_user.remote_id,
'object': self.status.to_activity(), 'object': self.status.remote_id,
} }
with patch('bookwyrm.models.status.Status.ignore_activity') \ with patch('bookwyrm.models.status.Status.ignore_activity') \
as discarder: as discarder:
@ -535,16 +535,21 @@ class Inbox(TestCase):
@responses.activate @responses.activate
def test_handle_discarded_boost(self): def test_handle_discarded_boost(self):
''' test a boost of a mastodon status that will be discarded ''' ''' test a boost of a mastodon status that will be discarded '''
status = models.Status(
content='hi',
user=self.remote_user,
)
status.save(broadcast=False)
activity = { activity = {
'type': 'Announce', 'type': 'Announce',
'id': 'http://www.faraway.com/boost/12', 'id': 'http://www.faraway.com/boost/12',
'actor': self.remote_user.remote_id, 'actor': self.remote_user.remote_id,
'object': self.status.to_activity(), 'object': status.remote_id,
} }
responses.add( responses.add(
responses.GET, responses.GET,
'http://www.faraway.com/boost/12', status.remote_id,
json={'id': 'http://www.faraway.com/boost/12'}, json=status.to_activity(),
status=200) status=200)
views.inbox.activity_task(activity) views.inbox.activity_task(activity)
self.assertEqual(models.Boost.objects.count(), 0) self.assertEqual(models.Boost.objects.count(), 0)