mirror of
https://github.com/LonamiWebs/Telethon.git
synced 2025-01-27 01:34:29 +03:00
46 lines
1.3 KiB
Python
46 lines
1.3 KiB
Python
import gzip
|
|
import struct
|
|
|
|
from .. import TLObject, TLRequest
|
|
|
|
|
|
class GzipPacked(TLObject):
|
|
CONSTRUCTOR_ID = 0x3072cfa1
|
|
|
|
def __init__(self, data):
|
|
self.data = data
|
|
|
|
@staticmethod
|
|
def gzip_if_smaller(content_related, data):
|
|
"""Calls bytes(request), and based on a certain threshold,
|
|
optionally gzips the resulting data. If the gzipped data is
|
|
smaller than the original byte array, this is returned instead.
|
|
|
|
Note that this only applies to content related requests.
|
|
"""
|
|
if content_related and len(data) > 512:
|
|
gzipped = bytes(GzipPacked(data))
|
|
return gzipped if len(gzipped) < len(data) else data
|
|
else:
|
|
return data
|
|
|
|
def __bytes__(self):
|
|
return struct.pack('<I', GzipPacked.CONSTRUCTOR_ID) + \
|
|
TLObject.serialize_bytes(gzip.compress(self.data))
|
|
|
|
@staticmethod
|
|
def read(reader):
|
|
constructor = reader.read_int(signed=False)
|
|
assert constructor == GzipPacked.CONSTRUCTOR_ID
|
|
return gzip.decompress(reader.tgread_bytes())
|
|
|
|
@classmethod
|
|
def from_reader(cls, reader):
|
|
return GzipPacked(gzip.decompress(reader.tgread_bytes()))
|
|
|
|
def to_dict(self):
|
|
return {
|
|
'_': 'GzipPacked',
|
|
'data': self.data
|
|
}
|