mirror of
https://github.com/zhenxun-org/zhenxun_bot.git
synced 2025-12-15 14:22:55 +08:00
modified: basic_plugins/admin_bot_manage/admin_config.py modified: basic_plugins/admin_bot_manage/custom_welcome_message.py modified: basic_plugins/admin_bot_manage/timing_task.py modified: basic_plugins/apscheduler/__init__.py modified: basic_plugins/ban/__init__.py modified: basic_plugins/ban/data_source.py modified: basic_plugins/chat_history/chat_message.py modified: basic_plugins/chat_history/chat_message_handle.py modified: basic_plugins/group_handle/__init__.py modified: basic_plugins/hooks/_utils.py modified: basic_plugins/hooks/ban_hook.py modified: basic_plugins/hooks/chkdsk_hook.py modified: basic_plugins/init_plugin_config/__init__.py deleted: basic_plugins/init_plugin_config/init_group_manager.py modified: basic_plugins/invite_manager/__init__.py new file: basic_plugins/invite_manager/utils.py modified: basic_plugins/nickname.py modified: basic_plugins/plugin_shop/__init__.py modified: basic_plugins/plugin_shop/data_source.py modified: basic_plugins/scripts.py modified: basic_plugins/shop/__init__.py modified: basic_plugins/shop/buy.py modified: basic_plugins/shop/gold.py modified: basic_plugins/shop/my_props/__init__.py deleted: basic_plugins/shop/reset_today_gold.py modified: basic_plugins/shop/shop_handle/__init__.py modified: basic_plugins/shop/shop_handle/data_source.py modified: basic_plugins/shop/use/__init__.py modified: basic_plugins/shop/use/data_source.py modified: basic_plugins/super_cmd/__init__.py modified: basic_plugins/super_cmd/bot_friend_group.py modified: basic_plugins/super_cmd/clear_data.py modified: basic_plugins/super_cmd/exec_sql.py modified: basic_plugins/super_cmd/manager_group.py modified: basic_plugins/super_cmd/reload_setting.py modified: basic_plugins/super_cmd/set_admin_permissions.py deleted: basic_plugins/super_cmd/super_task_switch.py modified: basic_plugins/super_cmd/update_friend_group_info.py modified: basic_plugins/super_help/__init__.py modified: basic_plugins/update_info.py modified: configs/config.py modified: configs/utils/__init__.py modified: models/bag_user.py modified: models/ban_user.py modified: models/chat_history.py modified: models/friend_user.py modified: models/goods_info.py modified: models/group_info.py modified: models/group_member_info.py modified: models/level_user.py modified: models/sign_group_user.py modified: models/user_shop_gold_log.py modified: plugins/aconfig/__init__.py modified: plugins/ai/__init__.py modified: plugins/ai/data_source.py modified: plugins/bilibili_sub/__init__.py modified: plugins/bilibili_sub/data_source.py modified: plugins/bilibili_sub/model.py modified: plugins/black_word/__init__.py modified: plugins/black_word/model.py modified: plugins/black_word/utils.py modified: plugins/bt/data_source.py modified: plugins/genshin/almanac/__init__.py modified: plugins/genshin/material_remind/__init__.py modified: plugins/genshin/query_user/_models/__init__.py modified: plugins/genshin/query_user/_utils/__init__.py modified: plugins/genshin/query_user/bind/__init__.py modified: plugins/genshin/query_user/genshin_sign/__init__.py modified: plugins/genshin/query_user/genshin_sign/data_source.py modified: plugins/genshin/query_user/genshin_sign/init_task.py modified: plugins/genshin/query_user/mihoyobbs_sign/__init__.py modified: plugins/genshin/query_user/query_memo/__init__.py modified: plugins/genshin/query_user/query_memo/data_source.py modified: plugins/genshin/query_user/query_role/__init__.py modified: plugins/genshin/query_user/query_role/data_source.py modified: plugins/genshin/query_user/reset_today_query_user_data/__init__.py modified: plugins/genshin/query_user/resin_remind/__init__.py modified: plugins/genshin/query_user/resin_remind/init_task.py modified: plugins/gold_redbag/model.py modified: plugins/image_management/send_image/__init__.py modified: plugins/my_info/__init__.py modified: plugins/open_cases/models/buff_prices.py modified: plugins/open_cases/models/open_cases_user.py modified: plugins/open_cases/open_cases_c.py modified: plugins/open_cases/utils.py modified: plugins/parse_bilibili_json.py modified: plugins/pid_search.py modified: plugins/pix_gallery/__init__.py modified: plugins/pix_gallery/_data_source.py modified: plugins/pix_gallery/_model/omega_pixiv_illusts.py modified: plugins/pix_gallery/_model/pixiv.py modified: plugins/pix_gallery/_model/pixiv_keyword_user.py modified: plugins/pix_gallery/pix_add_keyword.py modified: plugins/pix_gallery/pix_pass_del_keyword.py modified: plugins/pix_gallery/pix_show_info.py modified: plugins/pix_gallery/pix_update.py modified: plugins/pixiv_rank_search/data_source.py modified: plugins/poke/__init__.py modified: plugins/russian/__init__.py modified: plugins/russian/data_source.py modified: plugins/russian/model.py modified: plugins/send_dinggong_voice/__init__.py modified: plugins/send_setu_/_model.py modified: plugins/send_setu_/send_setu/__init__.py modified: plugins/send_setu_/send_setu/data_source.py modified: plugins/send_setu_/update_setu/data_source.py modified: plugins/sign_in/goods_register.py modified: plugins/sign_in/group_user_checkin.py modified: plugins/sign_in/random_event.py modified: plugins/sign_in/utils.py modified: plugins/statistics/_model.py modified: plugins/statistics/statistics_handle.py modified: plugins/statistics/statistics_hook.py modified: plugins/update_picture.py modified: plugins/web_ui/api/request.py modified: plugins/word_bank/_model.py deleted: plugins/word_bank/_old_model.py modified: plugins/word_bank/_rule.py modified: plugins/word_bank/word_handle.py modified: plugins/word_clouds/data_source.py modified: resources/image/sign/sign_res/bar.png modified: resources/image/sign/sign_res/bar_white.png modified: services/db_context.py modified: services/log.py modified: utils/browser.py modified: utils/data_utils.py modified: utils/depends/__init__.py modified: utils/http_utils.py modified: utils/image_utils.py modified: utils/manager/admin_manager.py modified: utils/message_builder.py modified: utils/utils.py
177 lines
7.3 KiB
Python
Executable File
177 lines
7.3 KiB
Python
Executable File
import os
|
||
import shutil
|
||
from datetime import datetime
|
||
|
||
import nonebot
|
||
import ujson as json
|
||
from asyncpg.exceptions import UniqueViolationError
|
||
from nonebot import Driver
|
||
from PIL import UnidentifiedImageError
|
||
|
||
from configs.config import Config
|
||
from configs.path_config import IMAGE_PATH, TEMP_PATH, TEXT_PATH
|
||
from services.log import logger
|
||
from utils.http_utils import AsyncHttpx
|
||
from utils.image_utils import compressed_image, get_img_hash
|
||
from utils.utils import change_pixiv_image_links, get_bot
|
||
|
||
from .._model import Setu
|
||
|
||
driver: Driver = nonebot.get_driver()
|
||
|
||
_path = IMAGE_PATH
|
||
|
||
|
||
# 替换旧色图数据,修复local_id一直是50的问题
|
||
@driver.on_startup
|
||
async def update_old_setu_data():
|
||
path = TEXT_PATH
|
||
setu_data_file = path / "setu_data.json"
|
||
r18_data_file = path / "r18_setu_data.json"
|
||
if setu_data_file.exists() or r18_data_file.exists():
|
||
index = 0
|
||
r18_index = 0
|
||
count = 0
|
||
fail_count = 0
|
||
for file in [setu_data_file, r18_data_file]:
|
||
if file.exists():
|
||
data = json.load(open(file, "r", encoding="utf8"))
|
||
for x in data:
|
||
if file == setu_data_file:
|
||
idx = index
|
||
if "R-18" in data[x]["tags"]:
|
||
data[x]["tags"].remove("R-18")
|
||
else:
|
||
idx = r18_index
|
||
img_url = (
|
||
data[x]["img_url"].replace("i.pixiv.cat", "i.pximg.net")
|
||
if "i.pixiv.cat" in data[x]["img_url"]
|
||
else data[x]["img_url"]
|
||
)
|
||
# idx = r18_index if 'R-18' in data[x]["tags"] else index
|
||
try:
|
||
if not await Setu.exists(pid=data[x]["pid"], url=img_url):
|
||
await Setu.create(
|
||
local_id=idx,
|
||
title=data[x]["title"],
|
||
author=data[x]["author"],
|
||
pid=data[x]["pid"],
|
||
img_hash=data[x]["img_hash"],
|
||
img_url=img_url,
|
||
is_r18="R-18" in data[x]["tags"],
|
||
tags=",".join(data[x]["tags"]),
|
||
)
|
||
count += 1
|
||
if "R-18" in data[x]["tags"]:
|
||
r18_index += 1
|
||
else:
|
||
index += 1
|
||
logger.info(f'添加旧色图数据成功 PID:{data[x]["pid"]} index:{idx}....')
|
||
except UniqueViolationError:
|
||
fail_count += 1
|
||
logger.info(
|
||
f'添加旧色图数据失败,色图重复 PID:{data[x]["pid"]} index:{idx}....'
|
||
)
|
||
file.unlink()
|
||
setu_url_path = path / "setu_url.json"
|
||
setu_r18_url_path = path / "setu_r18_url.json"
|
||
if setu_url_path.exists():
|
||
setu_url_path.unlink()
|
||
if setu_r18_url_path.exists():
|
||
setu_r18_url_path.unlink()
|
||
logger.info(f"更新旧色图数据完成,成功更新数据:{count} 条,累计失败:{fail_count} 条")
|
||
|
||
|
||
# 删除色图rar文件夹
|
||
shutil.rmtree(IMAGE_PATH / "setu_rar", ignore_errors=True)
|
||
shutil.rmtree(IMAGE_PATH / "r18_rar", ignore_errors=True)
|
||
shutil.rmtree(IMAGE_PATH / "rar", ignore_errors=True)
|
||
|
||
headers = {
|
||
"User-Agent": "Mozilla/5.0 (Macintosh; Intel Mac OS X 10.6;"
|
||
" rv:2.0.1) Gecko/20100101 Firefox/4.0.1",
|
||
"Referer": "https://www.pixiv.net",
|
||
}
|
||
|
||
|
||
async def update_setu_img(flag: bool = False):
|
||
"""
|
||
更新色图
|
||
:param flag: 是否手动更新
|
||
"""
|
||
image_list = await Setu.all().order_by("local_id")
|
||
image_list.reverse()
|
||
_success = 0
|
||
error_info = []
|
||
error_type = []
|
||
count = 0
|
||
for image in image_list:
|
||
count += 1
|
||
path = _path / "_r18" if image.is_r18 else _path / "_setu"
|
||
local_image = path / f"{image.local_id}.jpg"
|
||
path.mkdir(exist_ok=True, parents=True)
|
||
TEMP_PATH.mkdir(exist_ok=True, parents=True)
|
||
if not local_image.exists() or not image.img_hash:
|
||
temp_file = TEMP_PATH / f"{image.local_id}.jpg"
|
||
if temp_file.exists():
|
||
temp_file.unlink()
|
||
url_ = change_pixiv_image_links(image.img_url)
|
||
try:
|
||
if not await AsyncHttpx.download_file(
|
||
url_, TEMP_PATH / f"{image.local_id}.jpg"
|
||
):
|
||
continue
|
||
_success += 1
|
||
try:
|
||
if (
|
||
os.path.getsize(
|
||
TEMP_PATH / f"{image.local_id}.jpg",
|
||
)
|
||
> 1024 * 1024 * 1.5
|
||
):
|
||
compressed_image(
|
||
TEMP_PATH / f"{image.local_id}.jpg",
|
||
path / f"{image.local_id}.jpg",
|
||
)
|
||
else:
|
||
logger.info(
|
||
f"不需要压缩,移动图片{TEMP_PATH}/{image.local_id}.jpg "
|
||
f"--> /{path}/{image.local_id}.jpg"
|
||
)
|
||
os.rename(
|
||
TEMP_PATH / f"{image.local_id}.jpg",
|
||
path / f"{image.local_id}.jpg",
|
||
)
|
||
except FileNotFoundError:
|
||
logger.warning(f"文件 {image.local_id}.jpg 不存在,跳过...")
|
||
continue
|
||
img_hash = str(get_img_hash(f"{path}/{image.local_id}.jpg"))
|
||
image.img_hash = img_hash
|
||
await image.save(update_fields=["img_hash"])
|
||
# await Setu.update_setu_data(image.pid, img_hash=img_hash)
|
||
except UnidentifiedImageError:
|
||
# 图片已删除
|
||
unlink = False
|
||
with open(local_image, "r") as f:
|
||
if "404 Not Found" in f.read():
|
||
unlink = True
|
||
if unlink:
|
||
local_image.unlink()
|
||
max_num = await Setu.delete_image(image.pid)
|
||
os.rename(path / f"{max_num}.jpg", local_image)
|
||
logger.warning(f"更新色图 PID:{image.pid} 404,已删除并替换")
|
||
except Exception as e:
|
||
_success -= 1
|
||
logger.error(f"更新色图 {image.local_id}.jpg 错误 {type(e)}: {e}")
|
||
if type(e) not in error_type:
|
||
error_type.append(type(e))
|
||
error_info.append(f"更新色图 {image.local_id}.jpg 错误 {type(e)}: {e}")
|
||
else:
|
||
logger.info(f"更新色图 {image.local_id}.jpg 已存在")
|
||
if _success or error_info or flag:
|
||
await get_bot().send_private_msg(
|
||
user_id=int(list(get_bot().config.superusers)[0]),
|
||
message=f'{str(datetime.now()).split(".")[0]} 更新 色图 完成,本地存在 {count} 张,实际更新 {_success} 张,'
|
||
f"以下为更新时未知错误:\n" + "\n".join(error_info),
|
||
)
|