mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2025-01-20 22:18:07 +00:00
Merge branch 'main' into production
This commit is contained in:
commit
6b667aa575
7 changed files with 69 additions and 27 deletions
|
@ -50,7 +50,7 @@ def get_or_create_connector(remote_id):
|
||||||
books_url='https://%s/book' % identifier,
|
books_url='https://%s/book' % identifier,
|
||||||
covers_url='https://%s/images/covers' % identifier,
|
covers_url='https://%s/images/covers' % identifier,
|
||||||
search_url='https://%s/search?q=' % identifier,
|
search_url='https://%s/search?q=' % identifier,
|
||||||
priority=3
|
priority=2
|
||||||
)
|
)
|
||||||
|
|
||||||
return load_connector(connector_info)
|
return load_connector(connector_info)
|
||||||
|
|
|
@ -84,7 +84,8 @@ class User(OrderedCollectionPageMixin, AbstractUser):
|
||||||
if self.avatar:
|
if self.avatar:
|
||||||
url = self.avatar.url
|
url = self.avatar.url
|
||||||
else:
|
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)
|
return activitypub.Image(url=url)
|
||||||
|
|
||||||
@property
|
@property
|
||||||
|
|
|
@ -52,7 +52,7 @@ def handle_remote_webfinger(query):
|
||||||
try:
|
try:
|
||||||
user = models.User.objects.get(username=query)
|
user = models.User.objects.get(username=query)
|
||||||
except models.User.DoesNotExist:
|
except models.User.DoesNotExist:
|
||||||
url = 'https://%s/.well-known/webfinger?resource=acct:@%s' % \
|
url = 'https://%s/.well-known/webfinger?resource=acct:%s' % \
|
||||||
(domain, query)
|
(domain, query)
|
||||||
try:
|
try:
|
||||||
response = requests.get(url)
|
response = requests.get(url)
|
||||||
|
|
|
@ -1,33 +1,67 @@
|
||||||
{% extends 'layout.html' %}
|
{% extends 'layout.html' %}
|
||||||
{% block content %}
|
{% block content %}
|
||||||
|
{% with book_results|first as local_results %}
|
||||||
<div class="block columns">
|
<div class="block columns">
|
||||||
<div class="column">
|
<div class="column">
|
||||||
<h2 class="title">Matching Books</h2>
|
<h2 class="title">Matching Books</h2>
|
||||||
{% for result_set in book_results %}
|
<section class="block">
|
||||||
|
{% if not local_results.results %}
|
||||||
|
<p>No books found for "{{ query }}"</p>
|
||||||
|
{% else %}
|
||||||
|
<ul>
|
||||||
|
{% for result in local_results.results %}
|
||||||
|
<li class="pd-4">
|
||||||
|
<a href="{{ result.key }}">{% include 'snippets/search_result_text.html' with result=result link=True %}</a>
|
||||||
|
</li>
|
||||||
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
|
{% endif %}
|
||||||
|
</section>
|
||||||
|
|
||||||
|
{% if book_results|slice:":1" and local_results.results %}
|
||||||
|
<div class="block">
|
||||||
|
<p>
|
||||||
|
Didn't find what you were looking for?
|
||||||
|
</p>
|
||||||
|
|
||||||
|
<input class="toggle-control" type="radio" name="more-results" id="fewer-results" checked>
|
||||||
|
<div class="toggle-content hidden">
|
||||||
|
<label class="button is-small" for="more-results">Show results from other catalogues</label>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
{% endif %}
|
||||||
|
|
||||||
|
<input class="toggle-control" type="radio" name="more-results" id="more-results" {% if not local_results.results %}checked{% endif %}>
|
||||||
|
<div class="toggle-content hidden">
|
||||||
|
{% for result_set in book_results|slice:"1:" %}
|
||||||
{% if result_set.results %}
|
{% if result_set.results %}
|
||||||
<section>
|
<section class="block">
|
||||||
{% if not result_set.connector.local %}
|
{% if not result_set.connector.local %}
|
||||||
<h3>
|
<h3 class="title is-5">
|
||||||
Results from <a href="{{ result_set.connector.base_url }}" target="_blank">{% if result_set.connector.name %}{{ result_set.connector.name }}{% else %}{{ result_set.connector.identifier }}{% endif %}</a>
|
Results from <a href="{{ result_set.connector.base_url }}" target="_blank">{% if result_set.connector.name %}{{ result_set.connector.name }}{% else %}{{ result_set.connector.identifier }}{% endif %}</a>
|
||||||
</h3>
|
</h3>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
|
||||||
|
<ul>
|
||||||
{% for result in result_set.results %}
|
{% for result in result_set.results %}
|
||||||
<div>
|
<li class="pb-4">
|
||||||
<form action="/resolve_book" method="POST">
|
<form action="/resolve_book" method="POST">
|
||||||
{% csrf_token %}
|
{% csrf_token %}
|
||||||
<input type="hidden" name="remote_id" value="{{ result.key }}">
|
<input type="hidden" name="remote_id" value="{{ result.key }}">
|
||||||
<button type="submit">{{ result.title }} by {{ result.author }} ({{ result.year }})</button>
|
<div>{% include 'snippets/search_result_text.html' with result=result link=False %}</div>
|
||||||
|
<button type="submit" class="button is-small is-link is-light">Import book</button>
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</li>
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
|
</ul>
|
||||||
</section>
|
</section>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
{% if not book_results %}
|
{% if local_results.results %}
|
||||||
<p>No books found for "{{ query }}"</p>
|
<label class="button is-small" for="fewer-results">Hide results from other catalogues</label>
|
||||||
{% endif %}
|
{% endif %}
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
<div class="column">
|
<div class="column">
|
||||||
<h2 class="title">Matching Users</h2>
|
<h2 class="title">Matching Users</h2>
|
||||||
{% if not user_results %}
|
{% if not user_results %}
|
||||||
|
@ -42,4 +76,5 @@
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
{% endwith %}
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
''' views for actions you can take in the application '''
|
''' views for actions you can take in the application '''
|
||||||
from io import BytesIO, TextIOWrapper
|
from io import BytesIO, TextIOWrapper
|
||||||
|
from uuid import uuid4
|
||||||
from PIL import Image
|
from PIL import Image
|
||||||
|
|
||||||
import dateutil.parser
|
import dateutil.parser
|
||||||
|
@ -201,8 +202,12 @@ def edit_profile(request):
|
||||||
output = BytesIO()
|
output = BytesIO()
|
||||||
cropped.save(output, format=image.format)
|
cropped.save(output, format=image.format)
|
||||||
ContentFile(output.getvalue())
|
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(
|
request.user.avatar.save(
|
||||||
form.files['avatar'].name,
|
filename,
|
||||||
ContentFile(output.getvalue())
|
ContentFile(output.getvalue())
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
|
@ -19,14 +19,14 @@ def webfinger(request):
|
||||||
if not resource and not resource.startswith('acct:'):
|
if not resource and not resource.startswith('acct:'):
|
||||||
return HttpResponseNotFound()
|
return HttpResponseNotFound()
|
||||||
|
|
||||||
username = resource.replace('acct:@', '')
|
username = resource.replace('acct:', '')
|
||||||
try:
|
try:
|
||||||
user = models.User.objects.get(username=username)
|
user = models.User.objects.get(username=username)
|
||||||
except models.User.DoesNotExist:
|
except models.User.DoesNotExist:
|
||||||
return HttpResponseNotFound('No account found')
|
return HttpResponseNotFound('No account found')
|
||||||
|
|
||||||
return JsonResponse({
|
return JsonResponse({
|
||||||
'subject': 'acct:@%s' % (user.username),
|
'subject': 'acct:%s' % (user.username),
|
||||||
'links': [
|
'links': [
|
||||||
{
|
{
|
||||||
'rel': 'self',
|
'rel': 'self',
|
||||||
|
|
|
@ -76,4 +76,5 @@ Connector.objects.create(
|
||||||
books_url='https://openlibrary.org',
|
books_url='https://openlibrary.org',
|
||||||
covers_url='https://covers.openlibrary.org',
|
covers_url='https://covers.openlibrary.org',
|
||||||
search_url='https://openlibrary.org/search?q=',
|
search_url='https://openlibrary.org/search?q=',
|
||||||
|
priority=3,
|
||||||
)
|
)
|
||||||
|
|
Loading…
Reference in a new issue