Skip to content

Commit

Permalink
pyrofork: Ignore excluded plugins
Browse files Browse the repository at this point in the history
Signed-off-by: wulan17 <[email protected]>
  • Loading branch information
wulan17 committed Sep 10, 2024
1 parent 0f3313a commit b5da602
Showing 1 changed file with 22 additions and 36 deletions.
58 changes: 22 additions & 36 deletions pyrogram/client.py
Original file line number Diff line number Diff line change
Expand Up @@ -852,7 +852,7 @@ def load_plugins(self):
if self.plugins:
plugins = self.plugins.copy()

for option in ["include", "exclude"]:
for option in ["include", "exclude", "exclude_dir"]:
if plugins.get(option, []):
plugins[option] = [
(i.split()[0], i.split()[1:] or None)
Expand All @@ -865,11 +865,26 @@ def load_plugins(self):
root = plugins["root"]
include = plugins.get("include", [])
exclude = plugins.get("exclude", [])
exclude_plugins = []
exclude_dirs = []
if exclude:
for i in exclude:
plugin = root.replace(".", "/") + "/" + i.replace(".", "/")
if Path(plugin).is_dir():
exclude_dirs.append(plugin + "/")
else:
exclude_plugins.append(plugin + ".py")

count = 0

if not include:
for path in sorted(Path(root.replace(".", "/")).rglob("*.py")):
if exclude_dirs and any(str(path).startswith(i) for i in exclude_dirs):
log.info(f"[{self.name}] [LOAD] Ignoring excluded plugins {path}")
continue
if exclude_plugins and str(path) in exclude_plugins:
log.info(f"[{self.name}] [LOAD] Ignoring excluded plugins {path}")
continue
module_path = '.'.join(path.parent.parts + (path.stem,))
module = import_module(module_path)

Expand All @@ -889,6 +904,12 @@ def load_plugins(self):
else:
for path, handlers in include:
module_path = root.replace("/",".") + "." + path
if exclude_dirs and any(module_path.startswith(i) for i in exclude_dirs):
log.info(f"[{self.name}] [LOAD] Ignoring excluded plugins {module_path}")
continue
if exclude_plugins and module_path+".py" in exclude_plugins:
log.info(f"[{self.name}] [LOAD] Ignoring excluded plugins {module_path}")
continue
warn_non_existent_functions = True

try:
Expand Down Expand Up @@ -921,41 +942,6 @@ def load_plugins(self):
log.warning('[{}] [LOAD] Ignoring non-existent function "{}" from "{}"'.format(
self.name, name, module_path))

if exclude:
for path, handlers in exclude:
module_path = root.replace("/",".") + "." + path
warn_non_existent_functions = True

try:
module = import_module(module_path)
except ImportError:
log.warning('[%s] [UNLOAD] Ignoring non-existent module "%s"', self.name, module_path)
continue

if "__path__" in dir(module):
log.warning('[%s] [UNLOAD] Ignoring namespace "%s"', self.name, module_path)
continue

if handlers is None:
handlers = vars(module).keys()
warn_non_existent_functions = False

for name in handlers:
# noinspection PyBroadException
try:
for handler, group in getattr(module, name).handlers:
if isinstance(handler, Handler) and isinstance(group, int):
self.remove_handler(handler, group)

log.info('[{}] [UNLOAD] {}("{}") from group {} in "{}"'.format(
self.name, type(handler).__name__, name, group, module_path))

count -= 1
except Exception:
if warn_non_existent_functions:
log.warning('[{}] [UNLOAD] Ignoring non-existent function "{}" from "{}"'.format(
self.name, name, module_path))

if count > 0:
log.info('[{}] Successfully loaded {} plugin{} from "{}"'.format(
self.name, count, "s" if count > 1 else "", root))
Expand Down

0 comments on commit b5da602

Please sign in to comment.