修复修改图库配置重载后上传图片时提示的图库与配置不符

This commit is contained in:
HibiKier 2023-05-23 23:49:18 +08:00
parent 7d86ff057c
commit 26db0fad85
6 changed files with 104 additions and 71 deletions

View File

@ -334,6 +334,7 @@ PS: **ARM平台** 请使用全量版 同时 **如果你的机器 RAM < 1G 可能
### 2023/5/23 ### 2023/5/23
* 修复群聊数据无法初始化 * 修复群聊数据无法初始化
* 修复修改图库配置重载后上传图片时提示的图库与配置不符
### 2023/5/22 ### 2023/5/22

View File

@ -1,14 +1,16 @@
from configs.path_config import IMAGE_PATH, TEMP_PATH import os
from utils.message_builder import image
from services.log import logger
from nonebot import on_command 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.rule import to_me
from nonebot.typing import T_State 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 configs.config import Config
from nonebot.params import CommandArg, Arg from configs.path_config import IMAGE_PATH, TEMP_PATH
import os from services.log import logger
from utils.message_builder import image
from utils.utils import cn2py, is_number
__zx_plugin_name__ = "删除图片 [Admin]" __zx_plugin_name__ = "删除图片 [Admin]"
__plugin_usage__ = """ __plugin_usage__ = """
@ -36,9 +38,10 @@ _path = IMAGE_PATH / "image_management"
@delete_img.handle() @delete_img.handle()
async def _(state: T_State, arg: Message = CommandArg()): 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() args = arg.extract_plain_text().strip().split()
if args: 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] state["path"] = args[0]
if len(args) > 1 and is_number(args[1]): if len(args) > 1 and is_number(args[1]):
state["id"] = args[1] state["id"] = args[1]
@ -49,16 +52,17 @@ async def _(state: T_State, arg: Message = CommandArg()):
async def arg_handle( async def arg_handle(
event: MessageEvent, event: MessageEvent,
state: T_State, state: T_State,
path: str = Arg("path"), path_: str = ArgStr("path"),
img_id: str = Arg("id"), img_id: str = ArgStr("id"),
): ):
if path in ["取消", "算了"] or img_id in ["取消", "算了"]: if path_ in ["取消", "算了"] or img_id in ["取消", "算了"]:
await delete_img.finish("已取消操作...") 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", "此目录不正确,请重新输入目录!") await delete_img.reject_arg("path", "此目录不正确,请重新输入目录!")
if not is_number(img_id): if not is_number(img_id):
await delete_img.reject_arg("id", "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(): if not path.exists() and (path.parent.parent / cn2py(state["path"])).exists():
path = path.parent.parent / cn2py(state["path"]) path = path.parent.parent / cn2py(state["path"])
max_id = len(os.listdir(path)) - 1 max_id = len(os.listdir(path)) - 1
@ -87,6 +91,10 @@ async def arg_handle(
f" -> id: {img_id} 删除成功" f" -> id: {img_id} 删除成功"
) )
await delete_img.finish( 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} 删除失败!") await delete_img.finish(f"id: {img_id} 删除失败!")

View File

@ -35,13 +35,14 @@ _path = IMAGE_PATH / "image_management"
@move_img.handle() @move_img.handle()
async def _(state: T_State, arg: Message = CommandArg()): 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() args = arg.extract_plain_text().strip().split()
if args: if args:
if n := len(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] state["source_path"] = args[0]
if n > 1: 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] state["destination_path"] = args[1]
if n > 2 and is_number(args[2]): if n > 2 and is_number(args[2]):
state["id"] = args[2] state["id"] = args[2]
@ -52,24 +53,25 @@ async def _(state: T_State, arg: Message = CommandArg()):
@move_img.got("id", prompt="要移动的图片id是") @move_img.got("id", prompt="要移动的图片id是")
async def _( async def _(
event: MessageEvent, event: MessageEvent,
source_path: str = ArgStr("source_path"), source_path_: str = ArgStr("source_path"),
destination_path: str = ArgStr("destination_path"), destination_path_: str = ArgStr("destination_path"),
img_id: str = ArgStr("id"), img_id: str = ArgStr("id"),
): ):
if ( if (
source_path in ["取消", "算了"] source_path_ in ["取消", "算了"]
or img_id in ["取消", "算了"] or img_id in ["取消", "算了"]
or destination_path in ["取消", "算了"] or destination_path_ in ["取消", "算了"]
): ):
await move_img.finish("已取消操作...") 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", "移除目录不正确,请重新输入!") 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", "移入目录不正确,请重新输入!") await move_img.reject_arg("destination_path", "移入目录不正确,请重新输入!")
if not is_number(img_id): if not is_number(img_id):
await move_img.reject_arg("id", "id不正确请重新输入数字...") await move_img.reject_arg("id", "id不正确请重新输入数字...")
source_path = _path / cn2py(source_path) source_path = _path / cn2py(source_path_)
destination_path = _path / cn2py(destination_path) destination_path = _path / cn2py(destination_path_)
if not source_path.exists(): if not source_path.exists():
if (source_path.parent.parent / cn2py(source_path.name)).exists(): if (source_path.parent.parent / cn2py(source_path.name)).exists():
source_path = source_path.parent.parent / cn2py(source_path.name) source_path = source_path.parent.parent / cn2py(source_path.name)

View File

@ -51,15 +51,16 @@ _path = IMAGE_PATH / "image_management"
@send_img.handle() @send_img.handle()
async def _(event: MessageEvent): async def _(event: MessageEvent):
image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST") or []
msg = get_message_text(event.json()).split() msg = get_message_text(event.json()).split()
gallery = msg[0] gallery = msg[0]
if gallery not in Config.get_config("image_management", "IMAGE_DIR_LIST"): if gallery not in image_dir_list:
return return
img_id = None img_id = None
if len(msg) > 1: if len(msg) > 1:
img_id = msg[1] img_id = msg[1]
path = _path / cn2py(gallery) 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(): if not path.exists() and (path.parent.parent / cn2py(gallery)).exists():
path = IMAGE_PATH / cn2py(gallery) path = IMAGE_PATH / cn2py(gallery)
else: else:
@ -76,9 +77,10 @@ async def _(event: MessageEvent):
result = image(path / f"{index}.jpg") result = image(path / f"{index}.jpg")
if result: if result:
logger.info( logger.info(
f"(USER {event.user_id}, GROUP " f"发送{cn2py(gallery)}:" + str(path / f"{index}.jpg"),
f"{event.group_id if isinstance(event, GroupMessageEvent) else 'private'}) " "发送图片",
f"发送{cn2py(gallery)}:" + result event.user_id,
getattr(event, "group_id", None),
) )
msg_id = await send_img.send( msg_id = await send_img.send(
f"id{index}" + result f"id{index}" + result
@ -92,9 +94,10 @@ async def _(event: MessageEvent):
) )
else: else:
logger.info( logger.info(
f"(USER {event.user_id}, GROUP " f"发送 {cn2py(gallery)} 失败",
f"{event.group_id if isinstance(event, GroupMessageEvent) else 'private'}) " "发送图片",
f"发送 {cn2py(gallery)} 失败" event.user_id,
getattr(event, "group_id", None),
) )
await send_img.finish(f"不想给你看Ov|") await send_img.finish(f"不想给你看Ov|")

View File

@ -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 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]" __zx_plugin_name__ = "上传图片 [Admin]"
__plugin_usage__ = """ __plugin_usage__ = """
@ -37,27 +40,37 @@ show_gallery = on_command("查看公开图库", priority=1, block=True)
@show_gallery.handle() @show_gallery.handle()
async def _(): async def _():
image_dir_list = Config.get_config("image_management", "IMAGE_DIR_LIST")
if not image_dir_list:
await show_gallery.finish("未发现任何图库")
x = "公开图库列表:\n" 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" x += f"\t{i+1}.{e}\n"
await show_gallery.send(x[:-1]) await show_gallery.send(x[:-1])
@upload_img.handle() @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() args = arg.extract_plain_text().strip()
img_list = get_message_img(event.json())
if args: if args:
if args in Config.get_config("image_management", "IMAGE_DIR_LIST"): if args in image_dir_list:
state["path"] = args state["path"] = args
if img_list: if img_list:
state["img_list"] = arg state["img_list"] = arg
state["dir_list"] = "\n-".join(image_dir_list)
@upload_img.got( @upload_img.got(
"path", "path",
prompt=f"请选择要上传的图库\n- " prompt=Message.template("请选择要上传的图库\n-{dir_list}"),
+ "\n- ".join(Config.get_config("image_management", "IMAGE_DIR_LIST")),
) )
@upload_img.got("img_list", prompt="图呢图呢图呢图呢GKD") @upload_img.got("img_list", prompt="图呢图呢图呢图呢GKD")
async def _( async def _(
@ -65,13 +78,13 @@ async def _(
event: MessageEvent, event: MessageEvent,
state: T_State, state: T_State,
path: str = ArgStr("path"), 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", "此目录不正确,请重新输入目录!") 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") await upload_img.reject_arg("img_list", "图呢图呢图呢图呢GKD")
img_list = get_message_img(img_list)
group_id = 0 group_id = 0
if isinstance(event, GroupMessageEvent): if isinstance(event, GroupMessageEvent):
group_id = event.group_id group_id = event.group_id
@ -81,37 +94,41 @@ async def _(
@continuous_upload_img.handle() @continuous_upload_img.handle()
async def _(event: MessageEvent, state: T_State): async def _(
path = get_message_img(event.json()) event: MessageEvent,
if path in Config.get_config("image_management", "IMAGE_DIR_LIST"): 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["path"] = path
state["img_list"] = [] state["img_list"] = []
state["dir_list"] = "\n-".join(image_dir_list)
@continuous_upload_img.got( @continuous_upload_img.got("path", prompt=Message.template("请选择要上传的图库\n-{dir_list}"))
"path",
prompt=f"请选择要上传的图库\n- "
+ "\n- ".join(Config.get_config("image_management", "IMAGE_DIR_LIST")),
)
@continuous_upload_img.got("img", prompt="图呢图呢图呢图呢GKD【发送stop为停止】") @continuous_upload_img.got("img", prompt="图呢图呢图呢图呢GKD【发送stop为停止】")
async def _( async def _(
event: MessageEvent, event: MessageEvent,
state: T_State, state: T_State,
img_list: List[str] = Arg("img_list"), collect_img_list: List[str] = Arg("img_list"),
path: str = ArgStr("path"), path: str = ArgStr("path"),
img: Message = Arg("img"), 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", "此目录不正确,请重新输入目录!") await upload_img.reject_arg("path", "此目录不正确,请重新输入目录!")
if not img.extract_plain_text() == "stop": if not img.extract_plain_text() == "stop":
img = get_message_img(img) if img_list:
if img: for i in img_list:
for i in img: collect_img_list.append(i)
img_list.append(i)
await upload_img.reject_arg("img", "图再来【发送stop为停止】") await upload_img.reject_arg("img", "图再来【发送stop为停止】")
group_id = 0 group_id = 0
if isinstance(event, GroupMessageEvent): if isinstance(event, GroupMessageEvent):
group_id = event.group_id group_id = event.group_id
await continuous_upload_img.send( 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)
) )

View File

@ -1,11 +1,11 @@
from configs.config import NICKNAME import os
from typing import List from typing import List
from configs.config import NICKNAME
from configs.path_config import IMAGE_PATH from configs.path_config import IMAGE_PATH
from services.log import logger from services.log import logger
from utils.utils import cn2py
from utils.http_utils import AsyncHttpx from utils.http_utils import AsyncHttpx
import os from utils.utils import cn2py
_path = IMAGE_PATH / "image_management" _path = IMAGE_PATH / "image_management"
@ -31,8 +31,10 @@ async def upload_image_to_local(
for img in failed_list: for img in failed_list:
failed_result += str(img) + "\n" failed_result += str(img) + "\n"
logger.info( 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: if failed_list:
return ( return (