mirror of
https://github.com/pyrogram/pyrogram
synced 2025-08-29 21:38:04 +00:00
Log unknown constructors
This commit is contained in:
parent
caecbef2f6
commit
0b6b598059
@ -16,6 +16,7 @@
|
|||||||
# You should have received a copy of the GNU Lesser General Public License
|
# You should have received a copy of the GNU Lesser General Public License
|
||||||
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.
|
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
import logging
|
||||||
from collections import OrderedDict
|
from collections import OrderedDict
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
from io import BytesIO
|
from io import BytesIO
|
||||||
@ -23,13 +24,23 @@ from json import JSONEncoder, dumps
|
|||||||
|
|
||||||
from ..all import objects
|
from ..all import objects
|
||||||
|
|
||||||
|
log = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class Object:
|
class Object:
|
||||||
all = {}
|
all = {}
|
||||||
|
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def read(b: BytesIO, *args):
|
def read(b: BytesIO, *args):
|
||||||
return Object.all[int.from_bytes(b.read(4), "little")].read(b, *args)
|
constructor_id = int.from_bytes(b.read(4), "little")
|
||||||
|
|
||||||
|
try:
|
||||||
|
return Object.all[constructor_id].read(b, *args)
|
||||||
|
except KeyError:
|
||||||
|
log.error("Unknown constructor found: {}. Full data: {}".format(
|
||||||
|
hex(constructor_id),
|
||||||
|
b.getvalue().hex())
|
||||||
|
)
|
||||||
|
|
||||||
def write(self, *args) -> bytes:
|
def write(self, *args) -> bytes:
|
||||||
pass
|
pass
|
||||||
|
Loading…
x
Reference in New Issue
Block a user