MTPyroger/pyrogram/raw/core/future_salts.py

48 lines
1.5 KiB
Python
Raw Normal View History

2020-03-21 14:43:32 +00:00
# Pyrogram - Telegram MTProto API Client Library for Python
# Copyright (C) 2017-2020 Dan <https://github.com/delivrance>
2017-12-05 11:32:23 +00:00
#
2020-03-21 14:43:32 +00:00
# This file is part of Pyrogram.
2017-12-05 11:32:23 +00:00
#
2020-03-21 14:43:32 +00:00
# Pyrogram is free software: you can redistribute it and/or modify
# it under the terms of the GNU Lesser General Public License as published
# by the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
2017-12-05 11:32:23 +00:00
#
2020-03-21 14:43:32 +00:00
# Pyrogram is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Lesser General Public License for more details.
2017-12-05 11:32:23 +00:00
#
2020-03-21 14:43:32 +00:00
# You should have received a copy of the GNU Lesser General Public License
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.
2017-12-05 11:32:23 +00:00
from io import BytesIO
from typing import Any, List
2017-12-05 11:32:23 +00:00
from .future_salt import FutureSalt
from .primitives.int import Int, Long
2019-06-06 17:29:44 +00:00
from .tl_object import TLObject
2017-12-05 11:32:23 +00:00
2019-06-03 12:19:50 +00:00
class FutureSalts(TLObject):
ID = 0xAE500895
2017-12-05 11:32:23 +00:00
__slots__ = ["req_msg_id", "now", "salts"]
QUALNAME = "FutureSalts"
def __init__(self, req_msg_id: int, now: int, salts: List[FutureSalt]):
2017-12-05 11:32:23 +00:00
self.req_msg_id = req_msg_id
self.now = now
self.salts = salts
@staticmethod
def read(data: BytesIO, *args: Any) -> "FutureSalts":
req_msg_id = Long.read(data)
now = Int.read(data)
2017-12-05 11:32:23 +00:00
count = Int.read(data)
salts = [FutureSalt.read(data) for _ in range(count)]
2017-12-05 11:32:23 +00:00
return FutureSalts(req_msg_id, now, salts)