2020-03-16 21:02:05 -04:00
|
|
|
# SPDX-License-Identifier: GPL-2.0-or-later
|
2023-10-16 09:46:31 -04:00
|
|
|
|
|
|
|
import glob
|
|
|
|
from importlib import import_module, reload
|
|
|
|
from os.path import basename, dirname, isfile
|
|
|
|
from re import escape
|
|
|
|
|
|
|
|
from telethon import events
|
2020-05-04 12:39:09 -04:00
|
|
|
from telethon.tl.types import DocumentAttributeFilename
|
2023-10-16 09:46:31 -04:00
|
|
|
|
|
|
|
from .command_handler import CommandHandler
|
|
|
|
|
|
|
|
|
|
|
|
class Loader():
|
|
|
|
def __init__(self, client, logger, settings):
|
|
|
|
self.loaded_modules = []
|
|
|
|
self.all_modules = []
|
|
|
|
self.client = client
|
|
|
|
self.logger = logger
|
|
|
|
self.settings = settings
|
2020-04-16 16:26:05 -04:00
|
|
|
self.command_handler = CommandHandler(client, logger, settings)
|
2020-05-06 11:10:00 -04:00
|
|
|
self.help_dict = {}
|
2020-02-16 12:13:00 -05:00
|
|
|
self.botversion = "0.1.3"
|
2023-10-16 09:46:31 -04:00
|
|
|
|
|
|
|
def load_all_modules(self):
|
|
|
|
self._find_all_modules()
|
|
|
|
|
|
|
|
for module_name in self.all_modules:
|
|
|
|
self.loaded_modules.append(import_module("ubot.modules." + module_name))
|
|
|
|
|
|
|
|
def reload_all_modules(self):
|
|
|
|
self.command_handler.incoming_commands = {}
|
2020-05-06 11:10:00 -04:00
|
|
|
self.help_dict = {}
|
2023-10-16 09:46:31 -04:00
|
|
|
|
|
|
|
errors = ""
|
|
|
|
|
|
|
|
for module in self.loaded_modules:
|
|
|
|
try:
|
|
|
|
reload(module)
|
2020-04-17 11:29:58 -04:00
|
|
|
except ModuleNotFoundError:
|
|
|
|
pass
|
2023-10-16 09:46:31 -04:00
|
|
|
except Exception as exception:
|
|
|
|
errors += f"`Error while reloading {module.__name__} -> {exception}\n\n`"
|
|
|
|
raise exception
|
|
|
|
|
|
|
|
return errors or None
|
|
|
|
|
2020-05-02 17:04:27 -04:00
|
|
|
def add(self, pattern=None, **args):
|
|
|
|
pattern = args.get("pattern", pattern)
|
|
|
|
|
2023-10-16 09:46:31 -04:00
|
|
|
def decorator(func):
|
2020-05-06 11:10:00 -04:00
|
|
|
if func.__module__.split(".")[-1] in self.help_dict:
|
|
|
|
self.help_dict[func.__module__.split(".")[-1]] += [pattern]
|
|
|
|
else:
|
|
|
|
self.help_dict[func.__module__.split(".")[-1]] = [pattern]
|
|
|
|
|
2020-05-02 17:04:27 -04:00
|
|
|
self.command_handler.incoming_commands[pattern] = {
|
2020-04-16 16:26:05 -04:00
|
|
|
"function": func,
|
|
|
|
"noprefix": args.get('noprefix', False),
|
2020-05-05 19:51:55 -04:00
|
|
|
"sudo": args.get('sudo', False),
|
|
|
|
"extras": args.get('extras', None)
|
2020-04-16 16:26:05 -04:00
|
|
|
}
|
2023-10-16 09:46:31 -04:00
|
|
|
|
2020-04-17 16:34:12 -04:00
|
|
|
return func
|
|
|
|
|
2023-10-16 09:46:31 -04:00
|
|
|
return decorator
|
|
|
|
|
2020-05-04 12:39:09 -04:00
|
|
|
async def get_text(self, event, with_reply=True, return_msg=False, default=None):
|
|
|
|
if event.args:
|
|
|
|
if return_msg:
|
2020-05-04 19:08:13 -04:00
|
|
|
if event.is_reply:
|
|
|
|
return event.args, await event.get_reply_message()
|
|
|
|
|
2020-05-04 12:39:09 -04:00
|
|
|
return event.args, event
|
|
|
|
|
|
|
|
return event.args
|
|
|
|
elif event.is_reply and with_reply:
|
|
|
|
reply = await event.get_reply_message()
|
|
|
|
|
|
|
|
if return_msg:
|
|
|
|
return reply.text, reply
|
|
|
|
|
|
|
|
return reply.text
|
|
|
|
else:
|
|
|
|
if return_msg:
|
|
|
|
return default, event
|
|
|
|
|
|
|
|
return default
|
|
|
|
|
|
|
|
async def get_image(self, event):
|
|
|
|
if event and event.media:
|
|
|
|
if event.photo:
|
|
|
|
data = event.photo
|
|
|
|
elif event.document:
|
|
|
|
if DocumentAttributeFilename(file_name='AnimatedSticker.tgs') in event.media.document.attributes:
|
|
|
|
return False
|
|
|
|
if event.gif or event.video or event.audio or event.voice:
|
|
|
|
return False
|
|
|
|
data = event.media.document
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
return False
|
|
|
|
|
|
|
|
if not data or data is None:
|
|
|
|
return False
|
|
|
|
else:
|
|
|
|
return data
|
|
|
|
|
2023-10-16 09:46:31 -04:00
|
|
|
def _find_all_modules(self):
|
|
|
|
mod_paths = glob.glob(dirname(__file__) + "/modules/*.py")
|
|
|
|
|
|
|
|
self.all_modules = [
|
|
|
|
basename(f)[:-3] for f in mod_paths
|
|
|
|
if isfile(f) and f.endswith(".py")
|
|
|
|
]
|
|
|
|
|
|
|
|
system_index = self.all_modules.index("system")
|
|
|
|
self.all_modules.insert(0, self.all_modules.pop(system_index))
|