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:
@@ -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
|
||||||
|
@@ -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:
|
||||||
|
Reference in New Issue
Block a user