2021-05-20 19:21:05 +08:00
|
|
|
|
from configs.path_config import IMAGE_PATH, TEMP_PATH
|
2021-07-30 21:21:51 +08:00
|
|
|
|
from utils.message_builder import image
|
2021-05-20 19:21:05 +08:00
|
|
|
|
from services.log import logger
|
|
|
|
|
|
from nonebot import on_command
|
|
|
|
|
|
from nonebot.rule import to_me
|
|
|
|
|
|
from nonebot.typing import T_State
|
2021-07-30 21:21:51 +08:00
|
|
|
|
from nonebot.adapters.cqhttp import Bot, MessageEvent, GroupMessageEvent
|
2021-05-20 19:21:05 +08:00
|
|
|
|
from configs.config import IMAGE_DIR_LIST
|
2021-06-30 19:50:55 +08:00
|
|
|
|
from utils.utils import is_number, cn2py
|
2021-08-17 23:17:08 +08:00
|
|
|
|
from pathlib import Path
|
2021-07-30 21:21:51 +08:00
|
|
|
|
import os
|
2021-05-20 19:21:05 +08:00
|
|
|
|
|
2021-07-30 21:21:51 +08:00
|
|
|
|
__plugin_name__ = "删除图片"
|
|
|
|
|
|
__plugin_usage__ = (
|
|
|
|
|
|
"删除图片帮助:\n\t"
|
|
|
|
|
|
"1.查看列表 --> 指令: 删除图片 列表/目录\n\t"
|
|
|
|
|
|
"2.删除图片 图库 id, 即在相应目录下删除图片\n\t\t示例: 删除图片 色图 1 "
|
|
|
|
|
|
)
|
2021-05-20 19:21:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
delete_img = on_command("删除图片", priority=5, rule=to_me(), block=True)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@delete_img.args_parser
|
2021-07-30 21:21:51 +08:00
|
|
|
|
async def parse(bot: Bot, event: MessageEvent, state: T_State):
|
|
|
|
|
|
if str(event.get_message()) in ["取消", "算了"]:
|
2021-05-20 19:21:05 +08:00
|
|
|
|
await delete_img.finish("已取消操作..", at_sender=True)
|
2021-07-30 21:21:51 +08:00
|
|
|
|
if state["_current_key"] in ["path"]:
|
2021-05-20 19:21:05 +08:00
|
|
|
|
if str(event.get_message()) not in IMAGE_DIR_LIST:
|
|
|
|
|
|
await delete_img.reject("此目录不正确,请重新输入目录!")
|
|
|
|
|
|
state[state["_current_key"]] = str(event.get_message())
|
2021-07-30 21:21:51 +08:00
|
|
|
|
if state["_current_key"] == "id":
|
2021-05-20 19:21:05 +08:00
|
|
|
|
if not is_number(str(event.get_message())):
|
|
|
|
|
|
await delete_img.reject("id不正确!请重新输入数字...")
|
|
|
|
|
|
state[state["_current_key"]] = str(event.get_message())
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@delete_img.handle()
|
2021-07-30 21:21:51 +08:00
|
|
|
|
async def _(bot: Bot, event: MessageEvent, state: T_State):
|
2021-05-20 19:21:05 +08:00
|
|
|
|
raw_arg = str(event.get_message()).strip()
|
|
|
|
|
|
if raw_arg:
|
|
|
|
|
|
args = raw_arg.split(" ")
|
2021-07-30 21:21:51 +08:00
|
|
|
|
if args[0] in ["帮助"]:
|
2021-05-20 19:21:05 +08:00
|
|
|
|
await delete_img.finish(__plugin_usage__)
|
|
|
|
|
|
if len(args) >= 2 and args[0] in IMAGE_DIR_LIST and is_number(args[1]):
|
2021-07-30 21:21:51 +08:00
|
|
|
|
state["path"] = args[0]
|
|
|
|
|
|
state["id"] = args[1]
|
2021-05-20 19:21:05 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@delete_img.got("path", prompt="请输入要删除的目标图库?")
|
|
|
|
|
|
@delete_img.got("id", prompt="请输入要删除的图片id?")
|
2021-07-30 21:21:51 +08:00
|
|
|
|
async def arg_handle(bot: Bot, event: MessageEvent, state: T_State):
|
|
|
|
|
|
path = cn2py(state["path"])
|
|
|
|
|
|
img_id = state["id"]
|
2021-08-17 23:17:08 +08:00
|
|
|
|
# path = IMAGE_PATH + path
|
|
|
|
|
|
path = Path(IMAGE_PATH) / path
|
|
|
|
|
|
temp = Path(IMAGE_PATH) / 'temp'
|
2021-05-20 19:21:05 +08:00
|
|
|
|
max_id = len(os.listdir(path)) - 1
|
|
|
|
|
|
if int(img_id) > max_id or int(img_id) < 0:
|
|
|
|
|
|
await delete_img.finish(f"Id超过上下限,上限:{max_id}", at_sender=True)
|
|
|
|
|
|
try:
|
2021-08-17 23:17:08 +08:00
|
|
|
|
if os.path.exists(temp / "delete.jpg"):
|
|
|
|
|
|
os.remove(temp / "delete.jpg")
|
2021-05-20 19:21:05 +08:00
|
|
|
|
logger.info("删除图片 delete.jpg 成功")
|
|
|
|
|
|
except Exception as e:
|
|
|
|
|
|
logger.warning(f"删除图片 delete.jpg 失败 e{e}")
|
|
|
|
|
|
try:
|
2021-08-17 23:17:08 +08:00
|
|
|
|
os.rename(path / f"{img_id}.jpg", temp / "delete.jpg")
|
|
|
|
|
|
logger.info(f"移动 {path}/{img_id}.jpg 移动成功")
|
2021-05-20 19:21:05 +08:00
|
|
|
|
except Exception as e:
|
2021-08-17 23:17:08 +08:00
|
|
|
|
logger.warning(f"{path}/{img_id}.jpg --> 移动失败 e:{e}")
|
|
|
|
|
|
if not os.path.exists(path / f"{img_id}.jpg"):
|
2021-05-20 19:21:05 +08:00
|
|
|
|
try:
|
|
|
|
|
|
if int(img_id) != max_id:
|
2021-08-17 23:17:08 +08:00
|
|
|
|
os.rename(path / f"{max_id}.jpg", path / f"{img_id}.jpg")
|
|
|
|
|
|
except FileExistsError as e:
|
|
|
|
|
|
logger.error(f"{path}/{max_id}.jpg 替换 {path}/{img_id}.jpg 失败 e:{e}")
|
|
|
|
|
|
logger.info(f"{path}/{max_id}.jpg 替换 {path}/{img_id}.jpg 成功")
|
2021-07-30 21:21:51 +08:00
|
|
|
|
logger.info(
|
|
|
|
|
|
f"USER {event.user_id} GROUP {event.group_id if isinstance(event, GroupMessageEvent) else 'private'}"
|
|
|
|
|
|
f" -> id: {img_id} 删除成功"
|
|
|
|
|
|
)
|
|
|
|
|
|
await delete_img.finish(
|
|
|
|
|
|
f"id: {img_id} 删除成功" + image("delete.jpg", TEMP_PATH), at_sender=True
|
|
|
|
|
|
)
|
2021-05-20 19:21:05 +08:00
|
|
|
|
await delete_img.finish(f"id: {img_id} 删除失败!")
|