mirror of
https://github.com/LonamiWebs/Telethon.git
synced 2025-10-24 12:41:02 +03:00
Allow disabling the EntityDatabase fully or partially
This commit is contained in:
parent
99cc0778bb
commit
4f2a44231a
|
@ -8,8 +8,15 @@ from ..tl.types import User, Chat, Channel
|
||||||
|
|
||||||
|
|
||||||
class EntityDatabase:
|
class EntityDatabase:
|
||||||
def __init__(self, input_list=None, enabled=True):
|
def __init__(self, input_list=None, enabled=True, enabled_full=True):
|
||||||
|
"""Creates a new entity database with an initial load of "Input"
|
||||||
|
entities, if any.
|
||||||
|
|
||||||
|
If 'enabled', input entities will be saved. The whole entity
|
||||||
|
will be saved if both 'enabled' and 'enabled_full' are True.
|
||||||
|
"""
|
||||||
self.enabled = enabled
|
self.enabled = enabled
|
||||||
|
self.enabled_full = enabled_full
|
||||||
|
|
||||||
self._lock = Lock()
|
self._lock = Lock()
|
||||||
self._entities = {} # marked_id: user|chat|channel
|
self._entities = {} # marked_id: user|chat|channel
|
||||||
|
@ -63,10 +70,11 @@ class EntityDatabase:
|
||||||
new_input[utils.get_peer_id(p, add_mark=True)] = \
|
new_input[utils.get_peer_id(p, add_mark=True)] = \
|
||||||
getattr(p, 'access_hash', 0) # chats won't have hash
|
getattr(p, 'access_hash', 0) # chats won't have hash
|
||||||
|
|
||||||
if isinstance(e, User) \
|
if self.enabled_full:
|
||||||
or isinstance(e, Chat) \
|
if isinstance(e, User) \
|
||||||
or isinstance(e, Channel):
|
or isinstance(e, Chat) \
|
||||||
new.append(e)
|
or isinstance(e, Channel):
|
||||||
|
new.append(e)
|
||||||
except ValueError:
|
except ValueError:
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
@ -78,7 +86,8 @@ class EntityDatabase:
|
||||||
return len(self._input_entities) != before
|
return len(self._input_entities) != before
|
||||||
|
|
||||||
def _add_full_entity(self, entity):
|
def _add_full_entity(self, entity):
|
||||||
"""Adds a "full" entity (User, Chat or Channel, not "Input*").
|
"""Adds a "full" entity (User, Chat or Channel, not "Input*"),
|
||||||
|
despite the value of self.enabled and self.enabled_full.
|
||||||
|
|
||||||
Not to be confused with UserFull, ChatFull, or ChannelFull,
|
Not to be confused with UserFull, ChatFull, or ChannelFull,
|
||||||
"full" means simply not "Input*".
|
"full" means simply not "Input*".
|
||||||
|
|
Loading…
Reference in New Issue
Block a user