mirror of
https://github.com/LonamiWebs/Telethon.git
synced 2024-11-26 11:23:46 +03:00
Fix setattr for events.NewMessage/custom.Message
This commit is contained in:
parent
0a3151175d
commit
b2ed6caff4
|
@ -129,6 +129,8 @@ class NewMessage(EventBuilder):
|
|||
available members and methods.
|
||||
"""
|
||||
def __init__(self, message):
|
||||
# Having to override __setattr__ makes things... complicated
|
||||
self.__dict__['_init'] = False
|
||||
if not message.out and isinstance(message.to_id, types.PeerUser):
|
||||
# Incoming message (e.g. from a bot) has to_id=us, and
|
||||
# from_id=bot (the actual "chat" from an user's perspective).
|
||||
|
@ -145,9 +147,13 @@ class NewMessage(EventBuilder):
|
|||
super()._set_client(client)
|
||||
self.message = custom.Message(
|
||||
client, self.message, self._entities, None)
|
||||
self._init = True
|
||||
|
||||
def __getattr__(self, item):
|
||||
return getattr(self.message, item)
|
||||
|
||||
def __setattr__(self, name, value):
|
||||
return setattr(self.original_message, name, value)
|
||||
if self._init:
|
||||
setattr(self.__dict__['message'], name, value)
|
||||
else:
|
||||
super().__setattr__(name, value)
|
||||
|
|
|
@ -19,7 +19,10 @@ class Message:
|
|||
in the original :tl:`Message`.
|
||||
"""
|
||||
def __init__(self, client, original, entities, input_chat):
|
||||
self.__dict__['_init'] = False
|
||||
# Share the original dictionary. Modifications to this
|
||||
# object should also be reflected in the original one.
|
||||
# This way there's no need to worry about get/setattr.
|
||||
self.__dict__ = original.__dict__
|
||||
self.original_message = original
|
||||
self.stringify = self.original_message.stringify
|
||||
self.to_dict = self.original_message.to_dict
|
||||
|
@ -43,7 +46,6 @@ class Message:
|
|||
elif fwd.channel_id:
|
||||
self._fwd_from_entity = entities.get(get_peer_id(
|
||||
types.PeerChannel(fwd.channel_id)))
|
||||
self._init = True
|
||||
|
||||
def __new__(cls, client, original, entities, input_chat):
|
||||
if isinstance(original, types.Message):
|
||||
|
@ -53,15 +55,6 @@ class Message:
|
|||
else:
|
||||
return cls
|
||||
|
||||
def __getattr__(self, item):
|
||||
return getattr(self.original_message, item)
|
||||
|
||||
def __setattr__(self, name, value):
|
||||
if not self._init or name in self.__dict__:
|
||||
self.__dict__[name] = value
|
||||
else:
|
||||
setattr(self.original_message, name, value)
|
||||
|
||||
def __str__(self):
|
||||
return str(self.original_message)
|
||||
|
||||
|
|
Loading…
Reference in New Issue
Block a user