mirror of
https://mau.dev/maunium/synapse.git
synced 2024-12-15 11:13:49 +01:00
Fix bug in remote thumbnail search (#8438)
#7124 changed the behaviour of remote thumbnails so that the thumbnailing method was included in the filename of the thumbnail. To support existing files, it included a fallback so that we would check the old filename if the new filename didn't exist. Unfortunately, it didn't apply this logic to storage providers, so any thumbnails stored on such a storage provider was broken.
This commit is contained in:
parent
695240d34a
commit
73d93039ff
2 changed files with 24 additions and 20 deletions
1
changelog.d/8438.bugfix
Normal file
1
changelog.d/8438.bugfix
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Fix a regression in v1.21.0rc1 which broke thumbnails of remote media.
|
|
@ -141,31 +141,34 @@ class MediaStorage:
|
||||||
Returns:
|
Returns:
|
||||||
Returns a Responder if the file was found, otherwise None.
|
Returns a Responder if the file was found, otherwise None.
|
||||||
"""
|
"""
|
||||||
|
paths = [self._file_info_to_path(file_info)]
|
||||||
|
|
||||||
path = self._file_info_to_path(file_info)
|
# fallback for remote thumbnails with no method in the filename
|
||||||
local_path = os.path.join(self.local_media_directory, path)
|
|
||||||
if os.path.exists(local_path):
|
|
||||||
return FileResponder(open(local_path, "rb"))
|
|
||||||
|
|
||||||
# Fallback for paths without method names
|
|
||||||
# Should be removed in the future
|
|
||||||
if file_info.thumbnail and file_info.server_name:
|
if file_info.thumbnail and file_info.server_name:
|
||||||
legacy_path = self.filepaths.remote_media_thumbnail_rel_legacy(
|
paths.append(
|
||||||
|
self.filepaths.remote_media_thumbnail_rel_legacy(
|
||||||
server_name=file_info.server_name,
|
server_name=file_info.server_name,
|
||||||
file_id=file_info.file_id,
|
file_id=file_info.file_id,
|
||||||
width=file_info.thumbnail_width,
|
width=file_info.thumbnail_width,
|
||||||
height=file_info.thumbnail_height,
|
height=file_info.thumbnail_height,
|
||||||
content_type=file_info.thumbnail_type,
|
content_type=file_info.thumbnail_type,
|
||||||
)
|
)
|
||||||
legacy_local_path = os.path.join(self.local_media_directory, legacy_path)
|
)
|
||||||
if os.path.exists(legacy_local_path):
|
|
||||||
return FileResponder(open(legacy_local_path, "rb"))
|
for path in paths:
|
||||||
|
local_path = os.path.join(self.local_media_directory, path)
|
||||||
|
if os.path.exists(local_path):
|
||||||
|
logger.debug("responding with local file %s", local_path)
|
||||||
|
return FileResponder(open(local_path, "rb"))
|
||||||
|
logger.debug("local file %s did not exist", local_path)
|
||||||
|
|
||||||
for provider in self.storage_providers:
|
for provider in self.storage_providers:
|
||||||
|
for path in paths:
|
||||||
res = await provider.fetch(path, file_info) # type: Any
|
res = await provider.fetch(path, file_info) # type: Any
|
||||||
if res:
|
if res:
|
||||||
logger.debug("Streaming %s from %s", path, provider)
|
logger.debug("Streaming %s from %s", path, provider)
|
||||||
return res
|
return res
|
||||||
|
logger.debug("%s not found on %s", path, provider)
|
||||||
|
|
||||||
return None
|
return None
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue