mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-06 15:28:53 +00:00
Fixes discarding boosts
This commit is contained in:
parent
3f1b62eb98
commit
f5a022184f
3 changed files with 22 additions and 7 deletions
|
@ -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):
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
Loading…
Reference in a new issue