Adds privacy and recipient details to list items

This commit is contained in:
Mouse Reeve 2021-04-08 14:53:45 -07:00
parent 1f930ba821
commit b1491c2ac6
4 changed files with 59 additions and 27 deletions

View file

@ -359,6 +359,20 @@ class CollectionItemMixin(ActivitypubMixin):
activity_serializer = activitypub.CollectionItem activity_serializer = activitypub.CollectionItem
@property
def privacy(self):
""" inherit the privacy of the list, or direct if pending """
collection_field = getattr(self, self.collection_field)
if self.approved:
return collection_field.privacy
return "direct"
@property
def recipients(self):
""" the owner of the list is a direct recipient """
collection_field = getattr(self, self.collection_field)
return [collection_field.user]
def save(self, *args, broadcast=True, **kwargs): def save(self, *args, broadcast=True, **kwargs):
""" broadcast updated """ """ broadcast updated """
# first off, we want to save normally no matter what # first off, we want to save normally no matter what

View file

@ -61,9 +61,7 @@ class ListItem(CollectionItemMixin, BookWyrmModel):
book = fields.ForeignKey( book = fields.ForeignKey(
"Edition", on_delete=models.PROTECT, activitypub_field="book" "Edition", on_delete=models.PROTECT, activitypub_field="book"
) )
book_list = models.ForeignKey( book_list = models.ForeignKey("List", on_delete=models.CASCADE)
"List", on_delete=models.CASCADE
)
user = fields.ForeignKey( user = fields.ForeignKey(
"User", on_delete=models.PROTECT, activitypub_field="actor" "User", on_delete=models.PROTECT, activitypub_field="actor"
) )

View file

@ -68,9 +68,7 @@ class ShelfBook(CollectionItemMixin, BookWyrmModel):
book = fields.ForeignKey( book = fields.ForeignKey(
"Edition", on_delete=models.PROTECT, activitypub_field="book" "Edition", on_delete=models.PROTECT, activitypub_field="book"
) )
shelf = models.ForeignKey( shelf = models.ForeignKey("Shelf", on_delete=models.PROTECT)
"Shelf", on_delete=models.PROTECT
)
user = fields.ForeignKey( user = fields.ForeignKey(
"User", on_delete=models.PROTECT, activitypub_field="actor" "User", on_delete=models.PROTECT, activitypub_field="actor"
) )

View file

@ -11,45 +11,67 @@ class List(TestCase):
def setUp(self): def setUp(self):
""" look, a list """ """ look, a list """
self.user = models.User.objects.create_user( self.local_user = models.User.objects.create_user(
"mouse", "mouse@mouse.mouse", "mouseword", local=True, localname="mouse" "mouse", "mouse@mouse.mouse", "mouseword", local=True, localname="mouse"
) )
with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"): work = models.Work.objects.create(title="hello")
self.list = models.List.objects.create(name="Test List", user=self.user) self.book = models.Edition.objects.create(title="hi", parent_work=work)
def test_remote_id(self, _): def test_remote_id(self, _):
""" shelves use custom remote ids """ """ shelves use custom remote ids """
expected_id = "https://%s/list/%d" % (settings.DOMAIN, self.list.id) with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
self.assertEqual(self.list.get_remote_id(), expected_id) book_list = models.List.objects.create(
name="Test List", user=self.local_user
)
expected_id = "https://%s/list/%d" % (settings.DOMAIN, book_list.id)
self.assertEqual(book_list.get_remote_id(), expected_id)
def test_to_activity(self, _): def test_to_activity(self, _):
""" jsonify it """ """ jsonify it """
activity_json = self.list.to_activity() with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
book_list = models.List.objects.create(
name="Test List", user=self.local_user
)
activity_json = book_list.to_activity()
self.assertIsInstance(activity_json, dict) self.assertIsInstance(activity_json, dict)
self.assertEqual(activity_json["id"], self.list.remote_id) self.assertEqual(activity_json["id"], book_list.remote_id)
self.assertEqual(activity_json["totalItems"], 0) self.assertEqual(activity_json["totalItems"], 0)
self.assertEqual(activity_json["type"], "BookList") self.assertEqual(activity_json["type"], "BookList")
self.assertEqual(activity_json["name"], "Test List") self.assertEqual(activity_json["name"], "Test List")
self.assertEqual(activity_json["owner"], self.user.remote_id) self.assertEqual(activity_json["owner"], self.local_user.remote_id)
def test_list_item(self, _): def test_list_item(self, _):
""" a list entry """ """ a list entry """
work = models.Work.objects.create(title="hello") with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
book = models.Edition.objects.create(title="hi", parent_work=work) book_list = models.List.objects.create(
name="Test List", user=self.local_user, privacy="unlisted"
)
item = models.ListItem.objects.create( item = models.ListItem.objects.create(
book_list=self.list, book_list=book_list,
book=book, book=self.book,
user=self.user, user=self.local_user,
) )
self.assertTrue(item.approved) self.assertTrue(item.approved)
self.assertEqual(item.privacy, "unlisted")
self.assertEqual(item.recipients, [self.local_user])
add_activity = item.to_add_activity() def test_list_item_pending(self, _):
self.assertEqual(add_activity["actor"], self.user.remote_id) """ a list entry """
self.assertEqual(add_activity["object"]["id"], book.remote_id) with patch("bookwyrm.models.activitypub_mixin.broadcast_task.delay"):
self.assertEqual(add_activity["target"], self.list.remote_id) book_list = models.List.objects.create(
name="Test List", user=self.local_user
)
remove_activity = item.to_remove_activity() item = models.ListItem.objects.create(
self.assertEqual(remove_activity["actor"], self.user.remote_id) book_list=book_list,
self.assertEqual(remove_activity["object"]["id"], book.remote_id) book=self.book,
self.assertEqual(remove_activity["target"], self.list.remote_id) user=self.local_user,
approved=False
)
self.assertFalse(item.approved)
self.assertEqual(item.book_list.privacy, "public")
self.assertEqual(item.privacy, "direct")
self.assertEqual(item.recipients, [self.local_user])