Don't re-define functions in a loop
This commit is contained in:
parent
0508585194
commit
af06deebc1
|
@ -8,20 +8,6 @@ from .. import config, help_dict, log_errors, session, slave, public_log_errors
|
|||
|
||||
help_text = ''
|
||||
|
||||
try:
|
||||
resp = requests.get('https://nekos.life/api/v2/endpoints')
|
||||
json = resp.json()
|
||||
except Exception:
|
||||
logging.exception('Cannot connect to nekos.life')
|
||||
else:
|
||||
for i in json:
|
||||
_, i = i.split(' ', 1)
|
||||
i = i.strip()
|
||||
if i.startswith('/api/v2/img/<\''):
|
||||
for i in os.path.basename(i)[1:-1].split(', '):
|
||||
i = i[1:-1]
|
||||
if 'v3' in i:
|
||||
continue
|
||||
def _generate(i):
|
||||
@Client.on_message(~filters.sticker & ~filters.via_bot & ~filters.edited & filters.me & filters.command(i, prefixes=config['config']['prefixes']))
|
||||
@log_errors
|
||||
|
@ -42,6 +28,21 @@ else:
|
|||
except Forbidden:
|
||||
await to_reply.reply_text(result.send_message.message, parse_mode=None)
|
||||
return func
|
||||
|
||||
try:
|
||||
resp = requests.get('https://nekos.life/api/v2/endpoints')
|
||||
json = resp.json()
|
||||
except Exception:
|
||||
logging.exception('Cannot connect to nekos.life')
|
||||
else:
|
||||
for i in json:
|
||||
_, i = i.split(' ', 1)
|
||||
i = i.strip()
|
||||
if i.startswith('/api/v2/img/<\''):
|
||||
for i in os.path.basename(i)[1:-1].split(', '):
|
||||
i = i[1:-1]
|
||||
if 'v3' in i:
|
||||
continue
|
||||
func = _generate(i)
|
||||
globals()[i] = func
|
||||
locals()[i] = func
|
||||
|
|
|
@ -5,6 +5,19 @@ from pyrogram import Client, filters
|
|||
from pyrogram.types import InputTextMessageContent, InlineQueryResultArticle, InlineQueryResultPhoto, InlineQueryResultAnimation
|
||||
from .. import log_errors, session, app_user_ids
|
||||
|
||||
def _generate(i):
|
||||
@Client.on_inline_query(filters.regex(f'^{i}$'))
|
||||
@log_errors
|
||||
async def func(client, inline_query):
|
||||
if inline_query.from_user.id not in app_user_ids:
|
||||
await inline_query.answer([InlineQueryResultArticle('...no', InputTextMessageContent('...no'))], cache_time=3600, is_personal=True)
|
||||
return
|
||||
async with session.get(f'https://nekos.life/api/v2/img/{i}') as resp:
|
||||
url = (await resp.json())['url']
|
||||
call = InlineQueryResultAnimation if '.gif' == os.path.splitext(url)[1] else InlineQueryResultPhoto
|
||||
await inline_query.answer([call(url, caption=url, parse_mode=None)], cache_time=0)
|
||||
return func
|
||||
|
||||
try:
|
||||
resp = requests.get('https://nekos.life/api/v2/endpoints')
|
||||
json = resp.json()
|
||||
|
@ -19,18 +32,6 @@ else:
|
|||
i = i[1:-1]
|
||||
if 'v3' in i:
|
||||
continue
|
||||
def _generate(i):
|
||||
@Client.on_inline_query(filters.regex(f'^{i}$'))
|
||||
@log_errors
|
||||
async def func(client, inline_query):
|
||||
if inline_query.from_user.id not in app_user_ids:
|
||||
await inline_query.answer([InlineQueryResultArticle('...no', InputTextMessageContent('...no'))], cache_time=3600, is_personal=True)
|
||||
return
|
||||
async with session.get(f'https://nekos.life/api/v2/img/{i}') as resp:
|
||||
url = (await resp.json())['url']
|
||||
call = InlineQueryResultAnimation if '.gif' == os.path.splitext(url)[1] else InlineQueryResultPhoto
|
||||
await inline_query.answer([call(url, caption=url, parse_mode=None)], cache_time=0)
|
||||
return func
|
||||
func = _generate(i)
|
||||
globals()[i] = func
|
||||
locals()[i] = func
|
||||
|
|
Loading…
Reference in New Issue