mirror of
https://github.com/bookwyrm-social/bookwyrm.git
synced 2024-09-27 05:50:05 +00:00
ddc35a7a52
- improve nginx config - fix DATA_UPLOAD_MAX_MEMORY_SIZE default not being an int - translate fallback value in id_to_username template tag - make location of setting to turn on user exports easier to locate for admins fixes #3227 fixes #3231 fixes #3232 fixes #3236
159 lines
4.8 KiB
Python
159 lines
4.8 KiB
Python
""" template filters for really common utilities """
|
|
import os
|
|
import re
|
|
from uuid import uuid4
|
|
from urllib.parse import urlparse
|
|
from django import template
|
|
from django.utils.safestring import mark_safe
|
|
from django.utils.translation import gettext_lazy as _
|
|
from django.templatetags.static import static
|
|
|
|
from bookwyrm.models import User
|
|
from bookwyrm.settings import INSTANCE_ACTOR_USERNAME
|
|
|
|
register = template.Library()
|
|
|
|
|
|
@register.filter(name="uuid")
|
|
def get_uuid(identifier):
|
|
"""for avoiding clashing ids when there are many forms"""
|
|
return f"{identifier}{uuid4()}"
|
|
|
|
|
|
@register.simple_tag(takes_context=False)
|
|
def join(*args):
|
|
"""concatenate an arbitrary set of values"""
|
|
return "_".join(str(a) for a in args)
|
|
|
|
|
|
@register.filter(name="username")
|
|
def get_user_identifier(user):
|
|
"""use localname for local users, username for remote"""
|
|
return user.localname if user.localname else user.username
|
|
|
|
|
|
@register.filter(name="user_from_remote_id")
|
|
def get_user_identifier_from_remote_id(remote_id):
|
|
"""get the local user id from their remote id"""
|
|
user = User.objects.get(remote_id=remote_id)
|
|
return user if user else None
|
|
|
|
|
|
@register.filter(name="book_title")
|
|
def get_title(book, too_short=5):
|
|
"""display the subtitle if the title is short"""
|
|
if not book:
|
|
return ""
|
|
title = book.title
|
|
if len(title) <= too_short and book.subtitle:
|
|
title = _("%(title)s: %(subtitle)s") % {
|
|
"title": title,
|
|
"subtitle": book.subtitle,
|
|
}
|
|
return title
|
|
|
|
|
|
@register.simple_tag(takes_context=False)
|
|
def comparison_bool(str1, str2, reverse=False):
|
|
"""idk why I need to write a tag for this, it returns a bool"""
|
|
if reverse:
|
|
return str1 != str2
|
|
return str1 == str2
|
|
|
|
|
|
@register.filter(is_safe=True)
|
|
def truncatepath(value, arg):
|
|
"""Truncate a path by removing all directories except the first and truncating"""
|
|
path = os.path.normpath(value.name)
|
|
path_list = path.split(os.sep)
|
|
try:
|
|
length = int(arg)
|
|
except ValueError: # invalid literal for int()
|
|
return path_list[-1] # Fail silently.
|
|
return f"{path_list[0]}/…{path_list[-1][-length:]}"
|
|
|
|
|
|
@register.simple_tag(takes_context=False)
|
|
def get_book_cover_thumbnail(book, size="medium", ext="jpg"):
|
|
"""Returns a book thumbnail at the specified size and extension,
|
|
with fallback if needed"""
|
|
if size == "":
|
|
size = "medium"
|
|
try:
|
|
cover_thumbnail = getattr(book, f"cover_bw_book_{size}_{ext}")
|
|
return cover_thumbnail.url
|
|
except OSError:
|
|
return static("images/no_cover.jpg")
|
|
|
|
|
|
@register.filter(name="get_isni_bio")
|
|
def get_isni_bio(existing, author):
|
|
"""Returns the isni bio string if an existing author has an isni listed"""
|
|
auth_isni = re.sub(r"\D", "", str(author.isni))
|
|
if len(existing) == 0:
|
|
return ""
|
|
for value in existing:
|
|
if hasattr(value, "bio") and auth_isni == re.sub(r"\D", "", str(value.isni)):
|
|
return mark_safe(f"Author of <em>{value.bio}</em>")
|
|
|
|
return ""
|
|
|
|
|
|
# pylint: disable=unused-argument
|
|
@register.filter(name="get_isni", needs_autoescape=True)
|
|
def get_isni(existing, author, autoescape=True):
|
|
"""Returns the isni ID if an existing author has an ISNI listing"""
|
|
auth_isni = re.sub(r"\D", "", str(author.isni))
|
|
if len(existing) == 0:
|
|
return ""
|
|
for value in existing:
|
|
if hasattr(value, "isni") and auth_isni == re.sub(r"\D", "", str(value.isni)):
|
|
isni = value.isni
|
|
return mark_safe(
|
|
f'<input type="text" name="isni-for-{author.id}" value="{isni}" hidden>'
|
|
)
|
|
return ""
|
|
|
|
|
|
@register.simple_tag(takes_context=False)
|
|
def id_to_username(user_id):
|
|
"""given an arbitrary remote id, return the username"""
|
|
if user_id:
|
|
url = urlparse(user_id)
|
|
domain = url.netloc
|
|
parts = url.path.split("/")
|
|
name = parts[-1]
|
|
value = f"{name}@{domain}"
|
|
|
|
return value
|
|
return _("a new user account")
|
|
|
|
|
|
@register.filter(name="get_file_size")
|
|
def get_file_size(file):
|
|
"""display the size of a file in human readable terms"""
|
|
|
|
try:
|
|
raw_size = os.stat(file.path).st_size
|
|
if raw_size < 1024:
|
|
return f"{raw_size} bytes"
|
|
if raw_size < 1024**2:
|
|
return f"{raw_size/1024:.2f} KB"
|
|
if raw_size < 1024**3:
|
|
return f"{raw_size/1024**2:.2f} MB"
|
|
return f"{raw_size/1024**3:.2f} GB"
|
|
except Exception: # pylint: disable=broad-except
|
|
return ""
|
|
|
|
|
|
@register.filter(name="get_user_permission")
|
|
def get_user_permission(user):
|
|
"""given a user, return their permission level"""
|
|
|
|
return user.groups.first() or "User"
|
|
|
|
|
|
@register.filter(name="is_instance_admin")
|
|
def is_instance_admin(localname):
|
|
"""Returns a boolean indicating whether the user is the instance admin account"""
|
|
return localname == INSTANCE_ACTOR_USERNAME
|