2
0
mirror of https://github.com/Nick80835/microbot synced 2025-09-03 16:05:49 +00:00

add support for inline article results

This commit is contained in:
Nick80835
2020-05-25 14:04:56 -04:00
parent a8c8d4a25c
commit 91d1dba209
2 changed files with 77 additions and 27 deletions

View File

@@ -13,10 +13,11 @@ class CommandHandler():
self.inline_pattern_template = "(?is)^{0}(?: |$|_)(.*)" self.inline_pattern_template = "(?is)^{0}(?: |$|_)(.*)"
self.incoming_commands = {} self.incoming_commands = {}
self.inline_photo_commands = {} self.inline_photo_commands = {}
self.inline_article_commands = {}
self.logger = logger self.logger = logger
self.settings = settings self.settings = settings
client.add_event_handler(self.handle_incoming, events.NewMessage(incoming=True)) client.add_event_handler(self.handle_incoming, events.NewMessage(incoming=True))
client.add_event_handler(self.handle_inline_photo, events.InlineQuery()) client.add_event_handler(self.handle_inline, events.InlineQuery())
async def handle_incoming(self, event): async def handle_incoming(self, event):
prefix = escape(self.settings.get_config("cmd_prefix") or '.') prefix = escape(self.settings.get_config("cmd_prefix") or '.')
@@ -40,47 +41,82 @@ class CommandHandler():
await event.reply(f"`An error occurred in {value['function'].__name__}: {exception}`") await event.reply(f"`An error occurred in {value['function'].__name__}: {exception}`")
raise exception raise exception
async def handle_inline(self, event):
async def handle_inline_photo(self, event):
pattern_match = None
for key, value in self.inline_photo_commands.items(): for key, value in self.inline_photo_commands.items():
pattern_match = search(self.inline_pattern_template.format(key), event.text) pattern_match = search(self.inline_pattern_template.format(key), event.text)
if pattern_match: if pattern_match:
builder = event.builder await self.handle_inline_photo(event, pattern_match, value)
event.pattern_match = pattern_match return
event.args = pattern_match.groups()[-1]
url_list = await value["function"](event) for key, value in self.inline_article_commands.items():
pattern_match = search(self.inline_pattern_template.format(key), event.text)
if not url_list: if pattern_match:
continue await self.handle_inline_article(event, pattern_match, value)
return
photo_coros = [] await self.fallback_inline(event)
for url in url_list: async def handle_inline_photo(self, event, pattern_match, value):
try: builder = event.builder
photo_coros += [self.try_coro(builder.photo(url))] event.pattern_match = pattern_match
except: event.args = pattern_match.groups()[-1]
pass
if photo_coros: url_list = await value["function"](event)
photos = await asyncio.gather(*photo_coros)
else:
continue
try: if not url_list:
await event.answer([i for i in photos if i]) return
except:
pass
if not pattern_match: photo_coros = []
for url in url_list:
try: try:
await event.answer([await event.builder.article(title=key, text=f"{self.settings.get_config('cmd_prefix') or '.'}{value['default']}") for key, value in self.inline_photo_commands.items() if value["default"]]) photo_coros += [self.try_coro(builder.photo(url))]
except: except:
pass pass
if photo_coros:
photos = await asyncio.gather(*photo_coros)
else:
return
try:
await event.answer([i for i in photos if i])
except:
pass
async def handle_inline_article(self, event, pattern_match, value):
builder = event.builder
event.pattern_match = pattern_match
event.args = pattern_match.groups()[-1]
result_list = await value["function"](event)
if not result_list:
return
articles = []
for result in result_list:
try:
articles += [await builder.article(title=result["title"], description=result["description"], text=result["text"])]
except:
pass
try:
await event.answer([i for i in articles if i])
except:
pass
async def fallback_inline(self, event):
defaults_dict = {**self.inline_photo_commands, **self.inline_article_commands}
try:
await event.answer([await event.builder.article(title=key, text=f"{self.settings.get_config('cmd_prefix') or '.'}{value['default']}") for key, value in defaults_dict.items() if value["default"]])
except:
pass
async def try_coro(self, coro): async def try_coro(self, coro):
try: try:
return await coro return await coro

View File

@@ -35,6 +35,7 @@ class Loader():
def reload_all_modules(self): def reload_all_modules(self):
self.command_handler.incoming_commands = {} self.command_handler.incoming_commands = {}
self.command_handler.inline_photo_commands = {} self.command_handler.inline_photo_commands = {}
self.command_handler.inline_article_commands = {}
self.help_dict = {} self.help_dict = {}
errors = "" errors = ""
@@ -83,6 +84,19 @@ class Loader():
return decorator return decorator
def add_inline_article(self, pattern=None, **args):
pattern = args.get("pattern", pattern)
def decorator(func):
self.command_handler.inline_article_commands[pattern] = {
"function": func,
"default": args.get("default", None)
}
return func
return decorator
async def get_text(self, event, with_reply=True, return_msg=False, default=None): async def get_text(self, event, with_reply=True, return_msg=False, default=None):
if event.args: if event.args:
if return_msg: if return_msg: