zulip/zerver/views/thumbnail.py

37 lines
1.2 KiB
Python

import re
from django.contrib.auth.models import AnonymousUser
from django.http import HttpRequest, HttpResponseBase, HttpResponseForbidden
from zerver.lib.typed_endpoint import typed_endpoint
from zerver.models import UserProfile
from zerver.views.upload import serve_file
@typed_endpoint
def backend_serve_thumbnail(
request: HttpRequest,
maybe_user_profile: UserProfile | AnonymousUser,
*,
url: str,
size: str,
) -> HttpResponseBase:
# This URL used to be passed arbitrary URLs, and pass them through
# Camo; we no longer support doing so, and instead return a 403.
#
# Modern thumbnailing uses URLs of the style
# `/user_uploads/thumbnail/.../300x200.webp`; this endpoint is
# kept for backward compatibility, and for future extension for
# thumbnailing external URLs.
upload_path_parts = re.match(r"user_uploads/(\d+)/(.*)", url)
if not upload_path_parts:
return HttpResponseForbidden()
realm_id_str = upload_path_parts[1]
path_id = upload_path_parts[2]
# We do not have ImageAttachment rows for historical uploads, so
# we cannot serve a "new" thumbnail for these requests; serve the
# full-size file.
return serve_file(request, maybe_user_profile, realm_id_str, path_id)