PagerMaid-Modify/pagermaid/bots/captions.py
Xtao_dada a84e9633c8
🐛 Support bot and fix some bugs. (#135)
 支持通过 bot 登录来使用 pagermaid 功能。
🐛 批量修复错误。
2021-10-04 00:42:16 +08:00

207 lines
7.2 KiB
Python

""" PagerMaid module for adding captions to image. """
from os import remove
from magic import Magic
from pygments import highlight as syntax_highlight
from pygments.formatters import img
from pygments.lexers import guess_lexer
from telethon.errors import PhotoInvalidDimensionsError
from pagermaid import log, module_dir
from pagermaid.listener import listener
from pagermaid.utils import execute, upload_attachment, lang, alias_command
@listener(is_plugin=False, incoming=True, command=alias_command("convert"),
description=lang('convert_des'))
async def convert(context):
""" Converts image to png. """
reply = await context.get_reply_message()
msg = await context.reply(lang('convert_process'))
target_file_path = await context.download_media()
reply_id = context.reply_to_msg_id
if reply:
target_file_path = await context.client.download_media(
await context.get_reply_message()
)
if target_file_path is None:
await msg.edit(lang('convert_no_file'))
return
try:
result = await execute(f"{module_dir}/assets/caption.sh \"" + target_file_path +
"\" result.png" + " \"" + str("") +
"\" " + "\"" + str("") + "\"")
except TypeError:
await msg.edit(lang('convert_error'))
return
if not result:
await handle_failure(msg, target_file_path, 'convert_error')
return
try:
if not await upload_attachment("result.png", context.chat_id, reply_id):
await msg.edit(lang('convert_error'))
remove(target_file_path)
return
except PhotoInvalidDimensionsError:
await handle_failure(msg, target_file_path, 'convert_invalid')
return
remove(target_file_path)
remove("result.png")
await msg.delete()
@listener(is_plugin=False, incoming=True, command=alias_command("caption"),
description=lang('caption_des'),
parameters="<string>,<string> <image>")
async def caption(context):
""" Generates images with captions. """
msg = await context.reply(lang('caption_process'))
if context.arguments:
if ',' in context.arguments:
string_1, string_2 = context.arguments.split(',', 1)
else:
string_1 = context.arguments
string_2 = " "
else:
await msg.edit(lang('caption_error_grammer'))
return
reply = await context.get_reply_message()
target_file_path = await context.download_media()
reply_id = context.reply_to_msg_id
if reply:
target_file_path = await context.client.download_media(
await context.get_reply_message()
)
if target_file_path is None:
await msg.edit(lang('caption_no_file'))
return
if not target_file_path.endswith(".mp4"):
result = await execute(f"{module_dir}/assets/caption.sh \"{target_file_path}\" "
f"{module_dir}/assets/Impact-Regular.ttf "
f"\"{str(string_1)}\" \"{str(string_2)}\"")
result_file = "result.png"
else:
result = await execute(f"{module_dir}/assets/caption-gif.sh \"{target_file_path}\" "
f"{module_dir}/assets/Impact-Regular.ttf "
f"\"{str(string_1)}\" \"{str(string_2)}\"")
result_file = "result.gif"
if not result:
await handle_failure(msg, target_file_path, 'convert_error')
return
try:
if not await upload_attachment(result_file, context.chat_id, reply_id):
await msg.edit(lang('caption_error'))
remove(target_file_path)
return
except PhotoInvalidDimensionsError:
await handle_failure(msg, target_file_path, 'convert_invalid')
return
if string_2 != " ":
message = string_1 + "` 和 `" + string_2
else:
message = string_1
remove(target_file_path)
remove(result_file)
await msg.delete()
await log(f"{lang('caption_success1')} `{message}` {lang('caption_success2')}")
@listener(is_plugin=False, incoming=True, command=alias_command('ocr'),
description=lang('ocr_des'))
async def ocr(context):
""" Extracts texts from images. """
args = context.parameter
psm = 3
if len(context.parameter) >= 1:
try:
psm = int(args[0])
except ValueError:
pass
if not 0 <= int(psm) <= 13:
await context.reply(lang('ocr_psm_len_error'))
return
reply = await context.get_reply_message()
msg = await context.reply(lang('ocr_processing'))
if reply:
target_file_path = await context.client.download_media(
await context.get_reply_message()
)
else:
target_file_path = await context.download_media()
if target_file_path is None:
await msg.edit(lang('ocr_no_file'))
return
result = await execute(f"tesseract {target_file_path} stdout")
if not result:
await msg.edit(lang('ocr_no_result'))
try:
remove(target_file_path)
except FileNotFoundError:
pass
return
result = await execute(f"tesseract -c preserve_interword_spaces=1 -l chi_sim --psm {psm} \"{target_file_path}\" stdout 2>/dev/null", False)
await msg.edit(f"**{lang('ocr_result_hint')}: **\n{result}")
remove(target_file_path)
@listener(is_plugin=False, incoming=True, command=alias_command('highlight'),
description=lang('highlight_des'),
parameters="<string>")
async def highlight(context):
""" Generates syntax highlighted images. """
if context.fwd_from:
return
reply = await context.get_reply_message()
reply_id = None
msg = await context.reply(lang('highlight_processing'))
if reply:
reply_id = reply.id
target_file_path = await context.client.download_media(
await context.get_reply_message()
)
if target_file_path is None:
message = reply.text
else:
if Magic(mime=True).from_file(target_file_path) != 'text/plain':
message = reply.text
else:
with open(target_file_path, 'r') as file:
message = file.read()
remove(target_file_path)
else:
if context.arguments:
message = context.arguments
else:
await msg.edit(lang('highlight_no_file'))
return
lexer = guess_lexer(message)
try:
formatter = img.JpgImageFormatter(style="colorful")
except img.FontNotFound:
await msg.edit(lang('caption_error'))
return
except FileNotFoundError:
await msg.edit(lang('caption_error'))
return
try:
result = syntax_highlight(message, lexer, formatter, outfile=None)
except OSError:
await msg.edit(lang('caption_error'))
return
await msg.edit(lang('highlight_uploading'))
await context.client.send_file(
context.chat_id,
result,
reply_to=reply_id
)
await msg.delete()
async def handle_failure(context, target_file_path, name):
await context.edit(lang(name))
try:
remove("result.png")
remove(target_file_path)
except FileNotFoundError:
pass