mirror of
https://github.com/LonamiWebs/Telethon.git
synced 2025-01-27 01:34:29 +03:00
Workaround file references by using empty byte strings for cache
They seem to work for now, so until there is a need to update it, cache will just rely on empty byte strings for the file_reference.
This commit is contained in:
parent
b66c1e6084
commit
fc46e1ec20
|
@ -15,6 +15,18 @@ from ..tl import types, functions, custom
|
|||
__log__ = logging.getLogger(__name__)
|
||||
|
||||
|
||||
class _CacheType:
|
||||
"""Like functools.partial but pretends to be the wrapped class."""
|
||||
def __init__(self, cls):
|
||||
self._cls = cls
|
||||
|
||||
def __call__(self, *args, **kwargs):
|
||||
return self._cls(*args, file_reference=b'', **kwargs)
|
||||
|
||||
def __eq__(self, other):
|
||||
return self._cls == other
|
||||
|
||||
|
||||
class UploadMethods(ButtonMethods, MessageParseMethods, UserMethods):
|
||||
|
||||
# region Public methods
|
||||
|
@ -332,7 +344,7 @@ class UploadMethods(ButtonMethods, MessageParseMethods, UserMethods):
|
|||
hash_md5.update(file)
|
||||
if use_cache:
|
||||
cached = self.session.get_file(
|
||||
hash_md5.digest(), file_size, cls=use_cache
|
||||
hash_md5.digest(), file_size, cls=_CacheType(use_cache)
|
||||
)
|
||||
if cached:
|
||||
return cached
|
||||
|
|
Loading…
Reference in New Issue
Block a user