From 26db0fad855a4755f93b382e31b51038cc5d12c0 Mon Sep 17 00:00:00 2001 From: HibiKier <775757368@qq.com> Date: Tue, 23 May 2023 23:49:18 +0800 Subject: [PATCH] =?UTF-8?q?=E4=BF=AE=E5=A4=8D=E4=BF=AE=E6=94=B9=E5=9B=BE?= =?UTF-8?q?=E5=BA=93=E9=85=8D=E7=BD=AE=E9=87=8D=E8=BD=BD=E5=90=8E=E4=B8=8A?= =?UTF-8?q?=E4=BC=A0=E5=9B=BE=E7=89=87=E6=97=B6=E6=8F=90=E7=A4=BA=E7=9A=84?= =?UTF-8?q?=E5=9B=BE=E5=BA=93=E4=B8=8E=E9=85=8D=E7=BD=AE=E4=B8=8D=E7=AC=A6?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- README.md | 1 + .../image_management/delete_image/__init__.py | 36 ++++---- .../image_management/move_image/__init__.py | 22 ++--- .../image_management/send_image/__init__.py | 19 +++-- .../image_management/upload_image/__init__.py | 83 +++++++++++-------- .../upload_image/data_source.py | 14 ++-- 6 files changed, 104 insertions(+), 71 deletions(-) diff --git a/README.md b/README.md index b49d4384..ca5dcad6 100644 --- a/README.md +++ b/README.md @@ -334,6 +334,7 @@ PS: **ARM平台** 请使用全量版 同时 **如果你的机器 RAM < 1G 可能 ### 2023/5/23 * 修复群聊数据无法初始化 +* 修复修改图库配置重载后上传图片时提示的图库与配置不符 ### 2023/5/22 diff --git a/plugins/image_management/delete_image/__init__.py b/plugins/image_management/delete_image/__init__.py index b8ad9385..9f7d5d22 100755 --- a/plugins/image_management/delete_image/__init__.py +++ b/plugins/image_management/delete_image/__init__.py @@ -1,14 +1,16 @@ -from configs.path_config import IMAGE_PATH, TEMP_PATH -from utils.message_builder import image -from services.log import logger +import os + from nonebot import on_command +from nonebot.adapters.onebot.v11 import GroupMessageEvent, Message, MessageEvent +from nonebot.params import Arg, ArgStr, CommandArg from nonebot.rule import to_me from nonebot.typing import T_State -from nonebot.adapters.onebot.v11 import MessageEvent, GroupMessageEvent, Message -from utils.utils import is_number, cn2py + from configs.config import Config -from nonebot.params import CommandArg, Arg -import os +from configs.path_config import IMAGE_PATH, TEMP_PATH +from services.log import logger +from utils.message_builder import image +from utils.utils import cn2py, is_number __zx_plugin_name__ = "删除图片 [Admin]" __plugin_usage__ = """ @@ -36,9 +38,10 @@ _path = IMAGE_PATH / "image_management" @delete_img.handle() async def _(state: T_State, arg: Message = CommandArg()): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] args = arg.extract_plain_text().strip().split() if args: - if args[0] in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if args[0] in image_dir_list: state["path"] = args[0] if len(args) > 1 and is_number(args[1]): state["id"] = args[1] @@ -49,16 +52,17 @@ async def _(state: T_State, arg: Message = CommandArg()): async def arg_handle( event: MessageEvent, state: T_State, - path: str = Arg("path"), - img_id: str = Arg("id"), + path_: str = ArgStr("path"), + img_id: str = ArgStr("id"), ): - if path in ["取消", "算了"] or img_id in ["取消", "算了"]: + if path_ in ["取消", "算了"] or img_id in ["取消", "算了"]: await delete_img.finish("已取消操作...") - if path not in Config.get_config("image_management", "IMAGE_DIR_LIST"): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] + if path_ not in image_dir_list: await delete_img.reject_arg("path", "此目录不正确,请重新输入目录!") if not is_number(img_id): await delete_img.reject_arg("id", "id不正确!请重新输入数字...") - path = _path / cn2py(path) + path = _path / cn2py(path_) if not path.exists() and (path.parent.parent / cn2py(state["path"])).exists(): path = path.parent.parent / cn2py(state["path"]) max_id = len(os.listdir(path)) - 1 @@ -87,6 +91,10 @@ async def arg_handle( f" -> id: {img_id} 删除成功" ) await delete_img.finish( - f"id: {img_id} 删除成功" + image(TEMP_PATH / f"{event.user_id}_delete.jpg",), at_sender=True + f"id: {img_id} 删除成功" + + image( + TEMP_PATH / f"{event.user_id}_delete.jpg", + ), + at_sender=True, ) await delete_img.finish(f"id: {img_id} 删除失败!") diff --git a/plugins/image_management/move_image/__init__.py b/plugins/image_management/move_image/__init__.py index 1283d157..d8d9c039 100755 --- a/plugins/image_management/move_image/__init__.py +++ b/plugins/image_management/move_image/__init__.py @@ -35,13 +35,14 @@ _path = IMAGE_PATH / "image_management" @move_img.handle() async def _(state: T_State, arg: Message = CommandArg()): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] args = arg.extract_plain_text().strip().split() if args: if n := len(args): - if args[0] in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if args[0] in image_dir_list: state["source_path"] = args[0] if n > 1: - if args[1] in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if args[1] in image_dir_list: state["destination_path"] = args[1] if n > 2 and is_number(args[2]): state["id"] = args[2] @@ -52,24 +53,25 @@ async def _(state: T_State, arg: Message = CommandArg()): @move_img.got("id", prompt="要移动的图片id是?") async def _( event: MessageEvent, - source_path: str = ArgStr("source_path"), - destination_path: str = ArgStr("destination_path"), + source_path_: str = ArgStr("source_path"), + destination_path_: str = ArgStr("destination_path"), img_id: str = ArgStr("id"), ): if ( - source_path in ["取消", "算了"] + source_path_ in ["取消", "算了"] or img_id in ["取消", "算了"] - or destination_path in ["取消", "算了"] + or destination_path_ in ["取消", "算了"] ): await move_img.finish("已取消操作...") - if source_path not in Config.get_config("image_management", "IMAGE_DIR_LIST"): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] + if source_path_ not in image_dir_list: await move_img.reject_arg("source_path", "移除目录不正确,请重新输入!") - if destination_path not in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if destination_path_ not in image_dir_list: await move_img.reject_arg("destination_path", "移入目录不正确,请重新输入!") if not is_number(img_id): await move_img.reject_arg("id", "id不正确!请重新输入数字...") - source_path = _path / cn2py(source_path) - destination_path = _path / cn2py(destination_path) + source_path = _path / cn2py(source_path_) + destination_path = _path / cn2py(destination_path_) if not source_path.exists(): if (source_path.parent.parent / cn2py(source_path.name)).exists(): source_path = source_path.parent.parent / cn2py(source_path.name) diff --git a/plugins/image_management/send_image/__init__.py b/plugins/image_management/send_image/__init__.py index 4adb9390..2f5ab68d 100755 --- a/plugins/image_management/send_image/__init__.py +++ b/plugins/image_management/send_image/__init__.py @@ -51,15 +51,16 @@ _path = IMAGE_PATH / "image_management" @send_img.handle() async def _(event: MessageEvent): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] msg = get_message_text(event.json()).split() gallery = msg[0] - if gallery not in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if gallery not in image_dir_list: return img_id = None if len(msg) > 1: img_id = msg[1] path = _path / cn2py(gallery) - if gallery in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if gallery in image_dir_list: if not path.exists() and (path.parent.parent / cn2py(gallery)).exists(): path = IMAGE_PATH / cn2py(gallery) else: @@ -76,9 +77,10 @@ async def _(event: MessageEvent): result = image(path / f"{index}.jpg") if result: logger.info( - f"(USER {event.user_id}, GROUP " - f"{event.group_id if isinstance(event, GroupMessageEvent) else 'private'}) " - f"发送{cn2py(gallery)}:" + result + f"发送{cn2py(gallery)}:" + str(path / f"{index}.jpg"), + "发送图片", + event.user_id, + getattr(event, "group_id", None), ) msg_id = await send_img.send( f"id:{index}" + result @@ -92,9 +94,10 @@ async def _(event: MessageEvent): ) else: logger.info( - f"(USER {event.user_id}, GROUP " - f"{event.group_id if isinstance(event, GroupMessageEvent) else 'private'}) " - f"发送 {cn2py(gallery)} 失败" + f"发送 {cn2py(gallery)} 失败", + "发送图片", + event.user_id, + getattr(event, "group_id", None), ) await send_img.finish(f"不想给你看Ov|") diff --git a/plugins/image_management/upload_image/__init__.py b/plugins/image_management/upload_image/__init__.py index 4dd2059e..7e7c25e0 100755 --- a/plugins/image_management/upload_image/__init__.py +++ b/plugins/image_management/upload_image/__init__.py @@ -1,13 +1,16 @@ -from nonebot import on_command -from nonebot.rule import to_me -from nonebot.typing import T_State -from nonebot.adapters.onebot.v11 import Bot, MessageEvent, GroupMessageEvent, Message -from configs.config import Config -from utils.utils import get_message_img -from .data_source import upload_image_to_local -from nonebot.params import CommandArg, Arg, ArgStr from typing import List +from nonebot import on_command +from nonebot.adapters.onebot.v11 import Bot, GroupMessageEvent, Message, MessageEvent +from nonebot.params import Arg, ArgStr, CommandArg +from nonebot.rule import to_me +from nonebot.typing import T_State + +from configs.config import Config +from utils.depends import ImageList +from utils.utils import get_message_img + +from .data_source import upload_image_to_local __zx_plugin_name__ = "上传图片 [Admin]" __plugin_usage__ = """ @@ -37,27 +40,37 @@ show_gallery = on_command("查看公开图库", priority=1, block=True) @show_gallery.handle() async def _(): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") + if not image_dir_list: + await show_gallery.finish("未发现任何图库") x = "公开图库列表:\n" - for i, e in enumerate(Config.get_config("image_management", "IMAGE_DIR_LIST")): + for i, e in enumerate(image_dir_list): x += f"\t{i+1}.{e}\n" await show_gallery.send(x[:-1]) @upload_img.handle() -async def _(event: MessageEvent, state: T_State, arg: Message = CommandArg()): +async def _( + event: MessageEvent, + state: T_State, + arg: Message = CommandArg(), + img_list: List[str] = ImageList(), +): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") + if not image_dir_list: + await show_gallery.finish("未发现任何图库") args = arg.extract_plain_text().strip() - img_list = get_message_img(event.json()) if args: - if args in Config.get_config("image_management", "IMAGE_DIR_LIST"): + if args in image_dir_list: state["path"] = args if img_list: state["img_list"] = arg + state["dir_list"] = "\n-".join(image_dir_list) @upload_img.got( "path", - prompt=f"请选择要上传的图库\n- " - + "\n- ".join(Config.get_config("image_management", "IMAGE_DIR_LIST")), + prompt=Message.template("请选择要上传的图库\n-{dir_list}"), ) @upload_img.got("img_list", prompt="图呢图呢图呢图呢!GKD!") async def _( @@ -65,13 +78,13 @@ async def _( event: MessageEvent, state: T_State, path: str = ArgStr("path"), - img_list: Message = Arg("img_list"), + img_list: List[str] = ImageList(), ): - if path not in Config.get_config("image_management", "IMAGE_DIR_LIST"): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] + if path not in image_dir_list: await upload_img.reject_arg("path", "此目录不正确,请重新输入目录!") - if not get_message_img(img_list): + if not img_list: await upload_img.reject_arg("img_list", "图呢图呢图呢图呢!GKD!") - img_list = get_message_img(img_list) group_id = 0 if isinstance(event, GroupMessageEvent): group_id = event.group_id @@ -81,37 +94,41 @@ async def _( @continuous_upload_img.handle() -async def _(event: MessageEvent, state: T_State): - path = get_message_img(event.json()) - if path in Config.get_config("image_management", "IMAGE_DIR_LIST"): +async def _( + event: MessageEvent, + state: T_State, + arg: Message = CommandArg(), + img_list: List[str] = ImageList(), +): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] + path = arg.extract_plain_text().strip() + if path in image_dir_list: state["path"] = path state["img_list"] = [] + state["dir_list"] = "\n-".join(image_dir_list) -@continuous_upload_img.got( - "path", - prompt=f"请选择要上传的图库\n- " - + "\n- ".join(Config.get_config("image_management", "IMAGE_DIR_LIST")), -) +@continuous_upload_img.got("path", prompt=Message.template("请选择要上传的图库\n-{dir_list}")) @continuous_upload_img.got("img", prompt="图呢图呢图呢图呢!GKD!【发送‘stop’为停止】") async def _( event: MessageEvent, state: T_State, - img_list: List[str] = Arg("img_list"), + collect_img_list: List[str] = Arg("img_list"), path: str = ArgStr("path"), img: Message = Arg("img"), + img_list: List[str] = ImageList(), ): - if path not in Config.get_config("image_management", "IMAGE_DIR_LIST"): + image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or [] + if path not in image_dir_list: await upload_img.reject_arg("path", "此目录不正确,请重新输入目录!") if not img.extract_plain_text() == "stop": - img = get_message_img(img) - if img: - for i in img: - img_list.append(i) + if img_list: + for i in img_list: + collect_img_list.append(i) await upload_img.reject_arg("img", "图再来!!【发送‘stop’为停止】") group_id = 0 if isinstance(event, GroupMessageEvent): group_id = event.group_id await continuous_upload_img.send( - await upload_image_to_local(img_list, path, event.user_id, group_id) + await upload_image_to_local(collect_img_list, path, event.user_id, group_id) ) diff --git a/plugins/image_management/upload_image/data_source.py b/plugins/image_management/upload_image/data_source.py index a9718f32..b04b3e77 100755 --- a/plugins/image_management/upload_image/data_source.py +++ b/plugins/image_management/upload_image/data_source.py @@ -1,11 +1,11 @@ -from configs.config import NICKNAME +import os from typing import List + +from configs.config import NICKNAME from configs.path_config import IMAGE_PATH from services.log import logger -from utils.utils import cn2py from utils.http_utils import AsyncHttpx -import os - +from utils.utils import cn2py _path = IMAGE_PATH / "image_management" @@ -31,8 +31,10 @@ async def upload_image_to_local( for img in failed_list: failed_result += str(img) + "\n" logger.info( - f"USER {user_id} GROUP {group_id}" - f" 上传图片至 {_path_name} 共 {len(img_list)} 张,失败 {len(failed_list)} 张,id={success_id[:-1]}" + f"上传图片至 {_path_name} 共 {len(img_list)} 张,失败 {len(failed_list)} 张,id={success_id[:-1]}", + "上传图片", + user_id, + group_id, ) if failed_list: return (