From 4b7de93c9005893fede20dcc13637daf522b0a54 Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Sun, 1 Nov 2020 12:29:31 -0800 Subject: [PATCH 1/5] still tweaking webfinger syntax --- bookwyrm/outgoing.py | 2 +- bookwyrm/wellknown.py | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/bookwyrm/outgoing.py b/bookwyrm/outgoing.py index e9daa8fae..444b2e71d 100644 --- a/bookwyrm/outgoing.py +++ b/bookwyrm/outgoing.py @@ -52,7 +52,7 @@ def handle_remote_webfinger(query): try: user = models.User.objects.get(username=query) except models.User.DoesNotExist: - url = 'https://%s/.well-known/webfinger?resource=acct:@%s' % \ + url = 'https://%s/.well-known/webfinger?resource=acct:%s' % \ (domain, query) try: response = requests.get(url) diff --git a/bookwyrm/wellknown.py b/bookwyrm/wellknown.py index c17e10fc0..9daf31eef 100644 --- a/bookwyrm/wellknown.py +++ b/bookwyrm/wellknown.py @@ -19,14 +19,14 @@ def webfinger(request): if not resource and not resource.startswith('acct:'): return HttpResponseNotFound() - username = resource.replace('acct:@', '') + username = resource.replace('acct:', '') try: user = models.User.objects.get(username=username) except models.User.DoesNotExist: return HttpResponseNotFound('No account found') return JsonResponse({ - 'subject': 'acct:@%s' % (user.username), + 'subject': 'acct:%s' % (user.username), 'links': [ { 'rel': 'self', From 2b0b88802b4971cd300c16b3edbcc3431810419c Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Sun, 1 Nov 2020 12:36:56 -0800 Subject: [PATCH 2/5] Fixes weirdness in handling avatars - urls weren't serialized correctly for activitypub - the filename shouldn't have been preserved as-is --- bookwyrm/models/user.py | 3 ++- bookwyrm/view_actions.py | 7 ++++++- 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/bookwyrm/models/user.py b/bookwyrm/models/user.py index 6043faf46..21791411e 100644 --- a/bookwyrm/models/user.py +++ b/bookwyrm/models/user.py @@ -84,7 +84,8 @@ class User(OrderedCollectionPageMixin, AbstractUser): if self.avatar: url = self.avatar.url else: - url = 'https://%s/static/images/default_avi.jpg' % DOMAIN + url = '/static/images/default_avi.jpg' + url = 'https://%s%s' % (DOMAIN, url) return activitypub.Image(url=url) @property diff --git a/bookwyrm/view_actions.py b/bookwyrm/view_actions.py index e9a1171de..d6582ebc2 100644 --- a/bookwyrm/view_actions.py +++ b/bookwyrm/view_actions.py @@ -1,5 +1,6 @@ ''' views for actions you can take in the application ''' from io import BytesIO, TextIOWrapper +from uuid import uuid4 from PIL import Image import dateutil.parser @@ -201,8 +202,12 @@ def edit_profile(request): output = BytesIO() cropped.save(output, format=image.format) ContentFile(output.getvalue()) + + # set the name to a hash + extension = form.files['avatar'].name.split('.')[-1] + filename = '%s.%s' % (uuid4(), extension) request.user.avatar.save( - form.files['avatar'].name, + filename, ContentFile(output.getvalue()) ) From 277c0c4bfe67b3202542f2c8e5ec12580aad7052 Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Mon, 2 Nov 2020 08:48:58 -0800 Subject: [PATCH 3/5] Hide search results from external datasources --- bookwyrm/templates/search_results.html | 72 ++++++++++++++++++-------- 1 file changed, 51 insertions(+), 21 deletions(-) diff --git a/bookwyrm/templates/search_results.html b/bookwyrm/templates/search_results.html index bd5096fec..6c712349d 100644 --- a/bookwyrm/templates/search_results.html +++ b/bookwyrm/templates/search_results.html @@ -3,30 +3,60 @@

Matching Books

- {% for result_set in book_results %} - {% if result_set.results %} -
- {% if not result_set.connector.local %} -

- Results from {% if result_set.connector.name %}{{ result_set.connector.name }}{% else %}{{ result_set.connector.identifier }}{% endif %} -

- {% endif %} - +
+
- {% endif %} - {% endfor %} - {% if not book_results %} -

No books found for "{{ query }}"

- {% endif %} + +
+

+ Didn't find what you were looking for? +

+ + + +
+ + +

Matching Users

From 485f3831b912cd3d7a5005bf6f1ec8fbb53eea65 Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Mon, 2 Nov 2020 08:50:21 -0800 Subject: [PATCH 4/5] Priortize other instances over openlibrary --- bookwyrm/books_manager.py | 2 +- init_db.py | 1 + 2 files changed, 2 insertions(+), 1 deletion(-) diff --git a/bookwyrm/books_manager.py b/bookwyrm/books_manager.py index 37a31766c..461017a0e 100644 --- a/bookwyrm/books_manager.py +++ b/bookwyrm/books_manager.py @@ -50,7 +50,7 @@ def get_or_create_connector(remote_id): books_url='https://%s/book' % identifier, covers_url='https://%s/images/covers' % identifier, search_url='https://%s/search?q=' % identifier, - priority=3 + priority=2 ) return load_connector(connector_info) diff --git a/init_db.py b/init_db.py index ef11f8c5f..a7a45c20d 100644 --- a/init_db.py +++ b/init_db.py @@ -76,4 +76,5 @@ Connector.objects.create( books_url='https://openlibrary.org', covers_url='https://covers.openlibrary.org', search_url='https://openlibrary.org/search?q=', + priority=3, ) From 903e68f64a5c4eadcbfc6343ee3da5bd9dbbe81a Mon Sep 17 00:00:00 2001 From: Mouse Reeve Date: Mon, 2 Nov 2020 09:03:48 -0800 Subject: [PATCH 5/5] Show extended search results automatically for empty local results --- bookwyrm/templates/search_results.html | 19 ++++++++++++------- 1 file changed, 12 insertions(+), 7 deletions(-) diff --git a/bookwyrm/templates/search_results.html b/bookwyrm/templates/search_results.html index 6c712349d..14e5fbbd1 100644 --- a/bookwyrm/templates/search_results.html +++ b/bookwyrm/templates/search_results.html @@ -1,20 +1,24 @@ {% extends 'layout.html' %} {% block content %} +{% with book_results|first as local_results %}

Matching Books

+ {% if not local_results.results %} +

No books found for "{{ query }}"

+ {% else %} + {% endif %}
+ {% if book_results|slice:":1" and local_results.results %}

Didn't find what you were looking for? @@ -25,8 +29,9 @@

+ {% endif %} - +
@@ -72,4 +76,5 @@ {% endfor %}
+{% endwith %} {% endblock %}