MTPyroger/pyrogram/api/errors/error.py

78 lines
2.5 KiB
Python
Raw Normal View History

2017-12-05 11:36:11 +00:00
# Pyrogram - Telegram MTProto API Client Library for Python
2018-01-01 12:21:23 +00:00
# Copyright (C) 2017-2018 Dan Tès <https://github.com/delivrance>
2017-12-05 11:36:11 +00:00
#
# This file is part of Pyrogram.
#
# 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.
#
# 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.
#
# You should have received a copy of the GNU Lesser General Public License
# along with Pyrogram. If not, see <http://www.gnu.org/licenses/>.
import re
from importlib import import_module
from pyrogram.api.types import RpcError
from .exceptions.all import exceptions
class Error(Exception):
2017-12-30 18:30:51 +00:00
"""This is the base exception class for all Telegram API related errors.
For a finer grained control, see the specific errors below.
"""
2017-12-05 11:36:11 +00:00
ID = None
CODE = None
NAME = None
MESSAGE = None
def __init__(self, x: int or RpcError = None, query_type: type = None):
super().__init__("[{} {}]: {}".format(self.CODE, self.ID or self.NAME, self.MESSAGE.format(x=x)))
try:
self.x = int(x)
except (ValueError, TypeError):
self.x = x
# TODO: Proper log unknown errors
if self.CODE == 520:
with open("unknown_errors.txt", "a") as f:
f.write("{}\t{}\t{}\n".format(x.error_code, x.error_message, query_type))
@staticmethod
def raise_it(rpc_error: RpcError, query_type: type):
code = rpc_error.error_code
if code not in exceptions:
raise UnknownError(rpc_error, query_type)
message = rpc_error.error_message
id = re.sub(r"_\d+", "_X", message)
if id not in exceptions[code]:
raise UnknownError(rpc_error, query_type)
x = re.search(r"_(\d+)", message)
x = x.group(1) if x is not None else x
raise getattr(
import_module("pyrogram.api.errors"),
exceptions[code][id]
)(x)
class UnknownError(Error):
2017-12-30 18:30:51 +00:00
"""This object represents an Unknown Error, that is, an error which
Pyrogram does not know anything about, yet.
"""
2017-12-05 11:36:11 +00:00
CODE = 520
2017-12-30 18:30:51 +00:00
""":obj:`int`: Error code"""
2017-12-05 11:36:11 +00:00
NAME = "Unknown error"
MESSAGE = "{x}"