From da05b99bb8ce80391175689149a6587a8f89895d Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Tue, 15 Dec 2020 18:57:17 -0800 Subject: [PATCH] Fixes incoming shelve activity --- bookwyrm/activitypub/verbs.py | 4 ++-- bookwyrm/incoming.py | 1 - bookwyrm/models/shelf.py | 4 ++-- bookwyrm/tests/test_incoming.py | 22 ++++++++++++++++++++++ bw-dev | 3 ++- 5 files changed, 28 insertions(+), 6 deletions(-) diff --git a/bookwyrm/activitypub/verbs.py b/bookwyrm/activitypub/verbs.py index e890d81f..7c627927 100644 --- a/bookwyrm/activitypub/verbs.py +++ b/bookwyrm/activitypub/verbs.py @@ -3,7 +3,7 @@ from dataclasses import dataclass from typing import List from .base_activity import ActivityObject, Signature -from .book import Book +from .book import Edition @dataclass(init=False) class Verb(ActivityObject): @@ -73,7 +73,7 @@ class Add(Verb): @dataclass(init=False) class AddBook(Verb): '''Add activity that's aware of the book obj ''' - target: Book + target: Edition type: str = 'Add' diff --git a/bookwyrm/incoming.py b/bookwyrm/incoming.py index 9c8c2887..556c34a2 100644 --- a/bookwyrm/incoming.py +++ b/bookwyrm/incoming.py @@ -57,7 +57,6 @@ def shared_inbox(request): 'Announce': handle_boost, 'Add': { 'Edition': handle_add, - 'Work': handle_add, }, 'Undo': { 'Follow': handle_unfollow, diff --git a/bookwyrm/models/shelf.py b/bookwyrm/models/shelf.py index 68f3614f..69df43b4 100644 --- a/bookwyrm/models/shelf.py +++ b/bookwyrm/models/shelf.py @@ -3,7 +3,7 @@ import re from django.db import models from bookwyrm import activitypub -from .base_model import BookWyrmModel +from .base_model import ActivitypubMixin, BookWyrmModel from .base_model import OrderedCollectionMixin from . import fields @@ -51,7 +51,7 @@ class Shelf(OrderedCollectionMixin, BookWyrmModel): unique_together = ('user', 'identifier') -class ShelfBook(BookWyrmModel): +class ShelfBook(ActivitypubMixin, BookWyrmModel): ''' many to many join table for books and shelves ''' book = fields.ForeignKey( 'Edition', on_delete=models.PROTECT, activitypub_field='object') diff --git a/bookwyrm/tests/test_incoming.py b/bookwyrm/tests/test_incoming.py index d8e85ef2..a317ef71 100644 --- a/bookwyrm/tests/test_incoming.py +++ b/bookwyrm/tests/test_incoming.py @@ -433,6 +433,28 @@ class Incoming(TestCase): boosted_status=self.status, user=self.remote_user) incoming.handle_unboost(activity) + + def test_handle_add_book(self): + ''' shelving a book ''' + book = models.Edition.objects.create( + title='Test', remote_id='https://bookwyrm.social/book/37292') + shelf = models.Shelf.objects.create( + user=self.remote_user, name='Test Shelf') + shelf.remote_id = 'https://bookwyrm.social/user/mouse/shelf/to-read' + shelf.save() + + activity = { + "id": "https://bookwyrm.social/shelfbook/6189#add", + "type": "Add", + "actor": "hhttps://example.com/users/rat", + "object": "https://bookwyrm.social/book/37292", + "target": "https://bookwyrm.social/user/mouse/shelf/to-read", + "@context": "https://www.w3.org/ns/activitystreams" + } + incoming.handle_add(activity) + self.assertEqual(shelf.books.first(), book) + + def test_handle_update_user(self): ''' update an existing user ''' datafile = pathlib.Path(__file__).parent.joinpath( diff --git a/bw-dev b/bw-dev index 53c8e52d..bf5e8f75 100755 --- a/bw-dev +++ b/bw-dev @@ -57,7 +57,8 @@ case "$1" in clean ;; makemigrations) - execweb python manage.py makemigrations + shift 1 + execweb python manage.py makemigrations "$@" ;; migrate) execweb python manage.py rename_app fedireads bookwyrm