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
279 lines
12 KiB
Python
Executable File
279 lines
12 KiB
Python
Executable File
import os
|
||
from asyncio.exceptions import TimeoutError
|
||
from datetime import datetime, timedelta
|
||
|
||
from nonebot.adapters.onebot.v11 import ActionFailed
|
||
|
||
from configs.config import Config
|
||
from configs.path_config import IMAGE_PATH
|
||
from services.log import logger
|
||
from utils.http_utils import AsyncHttpx
|
||
from utils.manager import group_manager
|
||
from utils.utils import cn2py, get_bot
|
||
|
||
from .config import *
|
||
from .models.buff_prices import BuffPrice
|
||
from .models.open_cases_user import OpenCasesUser
|
||
|
||
url = "https://buff.163.com/api/market/goods"
|
||
# proxies = 'http://49.75.59.242:3128'
|
||
|
||
|
||
async def util_get_buff_price(case_name: str = "狂牙大行动") -> str:
|
||
cookie = {"session": Config.get_config("open_cases", "COOKIE")}
|
||
failed_list = []
|
||
case = cn2py(case_name)
|
||
if case_name == "狂牙大行动":
|
||
case_id = 1
|
||
elif case_name == "突围大行动":
|
||
case_id = 2
|
||
elif case_name == "命悬一线":
|
||
case_id = 3
|
||
elif case_name == "裂空":
|
||
case_id = 4
|
||
elif case_name == "光谱":
|
||
case_id = 5
|
||
else:
|
||
return "未查询到武器箱"
|
||
case = case.upper()
|
||
CASE_KNIFE = eval(case + "_CASE_KNIFE")
|
||
CASE_RED = eval(case + "_CASE_RED")
|
||
CASE_PINK = eval(case + "_CASE_PINK")
|
||
CASE_PURPLE = eval(case + "_CASE_PURPLE")
|
||
CASE_BLUE = eval(case + "_CASE_BLUE")
|
||
for total_list in [CASE_KNIFE, CASE_RED, CASE_PINK, CASE_PURPLE, CASE_BLUE]:
|
||
for skin in total_list:
|
||
if skin in [
|
||
"蝴蝶刀 | 无涂装",
|
||
"求生匕首 | 无涂装",
|
||
"流浪者匕首 | 无涂装",
|
||
"系绳匕首 | 无涂装",
|
||
"骷髅匕首 | 无涂装",
|
||
]:
|
||
skin = skin.split("|")[0].strip()
|
||
name_list = []
|
||
price_list = []
|
||
parameter = {"game": "csgo", "page_num": "1", "search": skin}
|
||
try:
|
||
response = await AsyncHttpx.get(
|
||
url,
|
||
proxy=Config.get_config("open_cases", "BUFF_PROXY"),
|
||
params=parameter,
|
||
cookies=cookie,
|
||
)
|
||
if response.status_code == 200:
|
||
data = response.json()["data"]
|
||
total_page = data["total_page"]
|
||
data = data["items"]
|
||
flag = False
|
||
if (
|
||
skin.find("|") == -1
|
||
): # in ['蝴蝶刀', '求生匕首', '流浪者匕首', '系绳匕首', '骷髅匕首']:
|
||
for i in range(1, total_page + 1):
|
||
name_list = []
|
||
price_list = []
|
||
parameter = {
|
||
"game": "csgo",
|
||
"page_num": f"{i}",
|
||
"search": skin,
|
||
}
|
||
res = await AsyncHttpx.get(
|
||
url, params=parameter, cookies=cookie
|
||
)
|
||
data = res.json()["data"]["items"]
|
||
for j in range(len(data)):
|
||
if data[j]["name"] in [f"{skin}(★)"]:
|
||
name = data[j]["name"]
|
||
price = data[j]["sell_reference_price"]
|
||
name_list.append(
|
||
name.split("(")[0].strip() + " | 无涂装"
|
||
)
|
||
price_list.append(price)
|
||
flag = True
|
||
break
|
||
if flag:
|
||
break
|
||
else:
|
||
try:
|
||
for _ in range(total_page):
|
||
for i in range(len(data)):
|
||
name = data[i]["name"]
|
||
price = data[i]["sell_reference_price"]
|
||
name_list.append(name)
|
||
price_list.append(price)
|
||
except Exception as e:
|
||
failed_list.append(skin)
|
||
logger.warning(f"{skin}更新失败")
|
||
else:
|
||
failed_list.append(skin)
|
||
logger.warning(f"{skin}更新失败")
|
||
except Exception:
|
||
failed_list.append(skin)
|
||
logger.warning(f"{skin}更新失败")
|
||
continue
|
||
for i in range(len(name_list)):
|
||
name = name_list[i].strip()
|
||
price = float(price_list[i])
|
||
if name.find("(★)") != -1:
|
||
name = name[: name.find("(")] + name[name.find(")") + 1 :]
|
||
if name.find("消音") != -1 and name.find("(S") != -1:
|
||
name = name.split("(")[0][:-4] + "(" + name.split("(")[1]
|
||
name = (
|
||
name.split("|")[0].strip() + " | " + name.split("|")[1].strip()
|
||
)
|
||
elif name.find("消音") != -1:
|
||
name = (
|
||
name.split("|")[0][:-5].strip()
|
||
+ " | "
|
||
+ name.split("|")[1].strip()
|
||
)
|
||
if name.find(" 18 ") != -1 and name.find("(S") != -1:
|
||
name = name.split("(")[0][:-5] + "(" + name.split("(")[1]
|
||
name = (
|
||
name.split("|")[0].strip() + " | " + name.split("|")[1].strip()
|
||
)
|
||
elif name.find(" 18 ") != -1:
|
||
name = (
|
||
name.split("|")[0][:-6].strip()
|
||
+ " | "
|
||
+ name.split("|")[1].strip()
|
||
)
|
||
if dbskin := await BuffPrice.get_or_none(skin_name=name):
|
||
if dbskin.update_date.date() == datetime.now().date():
|
||
continue
|
||
dbskin.case_id = case_id
|
||
dbskin.skin_price = price
|
||
dbskin.update_date = datetime.now()
|
||
await dbskin.save(
|
||
update_fields=["case_id", "skin_price", "update_date"]
|
||
)
|
||
logger.info(f"{name_list[i]}---------->成功更新")
|
||
result = None
|
||
if failed_list:
|
||
result = ""
|
||
for fail_skin in failed_list:
|
||
result += fail_skin + "\n"
|
||
return result[:-1] if result else "更新价格成功"
|
||
|
||
|
||
async def util_get_buff_img(case_name: str = "狂牙大行动") -> str:
|
||
cookie = {"session": Config.get_config("open_cases", "COOKIE")}
|
||
error_list = []
|
||
case = cn2py(case_name)
|
||
path = IMAGE_PATH / "cases/" / case
|
||
path.mkdir(exist_ok=True, parents=True)
|
||
case = case.upper()
|
||
CASE_KNIFE = eval(case + "_CASE_KNIFE")
|
||
CASE_RED = eval(case + "_CASE_RED")
|
||
CASE_PINK = eval(case + "_CASE_PINK")
|
||
CASE_PURPLE = eval(case + "_CASE_PURPLE")
|
||
CASE_BLUE = eval(case + "_CASE_BLUE")
|
||
for total_list in [CASE_KNIFE, CASE_RED, CASE_PINK, CASE_PURPLE, CASE_BLUE]:
|
||
for skin in total_list:
|
||
parameter = {"game": "csgo", "page_num": "1", "search": skin}
|
||
if skin in [
|
||
"蝴蝶刀 | 无涂装",
|
||
"求生匕首 | 无涂装",
|
||
"流浪者匕首 | 无涂装",
|
||
"系绳匕首 | 无涂装",
|
||
"骷髅匕首 | 无涂装",
|
||
]:
|
||
skin = skin.split("|")[0].strip()
|
||
logger.info(f"开始更新----->{skin}")
|
||
skin_name = ""
|
||
# try:
|
||
response = await AsyncHttpx.get(
|
||
url,
|
||
proxy=Config.get_config("open_cases", "BUFF_PROXY"),
|
||
params=parameter,
|
||
)
|
||
if response.status_code == 200:
|
||
data = response.json()["data"]
|
||
total_page = data["total_page"]
|
||
flag = False
|
||
if skin.find("|") == -1: # in ['蝴蝶刀', '求生匕首', '流浪者匕首', '系绳匕首', '骷髅匕首']:
|
||
for i in range(1, total_page + 1):
|
||
res = await AsyncHttpx.get(url, params=parameter)
|
||
data = res.json()["data"]["items"]
|
||
for j in range(len(data)):
|
||
if data[j]["name"] in [f"{skin}(★)"]:
|
||
img_url = data[j]["goods_info"]["icon_url"]
|
||
skin_name = cn2py(skin + "无涂装")
|
||
await AsyncHttpx.download_file(
|
||
img_url, path / f"{skin_name}.png"
|
||
)
|
||
flag = True
|
||
break
|
||
if flag:
|
||
break
|
||
else:
|
||
img_url = (await response.json())["data"]["items"][0]["goods_info"][
|
||
"icon_url"
|
||
]
|
||
skin_name += cn2py(skin.replace("|", "-").strip())
|
||
if await AsyncHttpx.download_file(
|
||
img_url, path / f"{skin_name}.png"
|
||
):
|
||
logger.info(f"------->写入 {skin} 成功")
|
||
else:
|
||
logger.info(f"------->写入 {skin} 失败")
|
||
result = None
|
||
if error_list:
|
||
result = ""
|
||
for err_skin in error_list:
|
||
result += err_skin + "\n"
|
||
return result[:-1] if result else "更新图片成功"
|
||
|
||
|
||
async def get_price(d_name):
|
||
cookie = {"session": Config.get_config("open_cases", "COOKIE")}
|
||
name_list = []
|
||
price_list = []
|
||
parameter = {"game": "csgo", "page_num": "1", "search": d_name}
|
||
try:
|
||
response = await AsyncHttpx.get(url, cookies=cookie, params=parameter)
|
||
if response.status_code == 200:
|
||
try:
|
||
data = response.json()["data"]
|
||
total_page = data["total_page"]
|
||
data = data["items"]
|
||
for _ in range(total_page):
|
||
for i in range(len(data)):
|
||
name = data[i]["name"]
|
||
price = data[i]["sell_reference_price"]
|
||
name_list.append(name)
|
||
price_list.append(price)
|
||
except Exception as e:
|
||
return "没有查询到...", 998
|
||
else:
|
||
return "访问失败!", response.status_code
|
||
except TimeoutError as e:
|
||
return "访问超时! 请重试或稍后再试!", 997
|
||
result = f"皮肤: {d_name}({len(name_list)})\n"
|
||
for i in range(len(name_list)):
|
||
result += name_list[i] + ": " + price_list[i] + "\n"
|
||
return result[:-1], 999
|
||
|
||
|
||
async def update_count_daily():
|
||
try:
|
||
await OpenCasesUser.all().update(today_open_total=0)
|
||
bot = get_bot()
|
||
gl = await bot.get_group_list()
|
||
gl = [g["group_id"] for g in gl]
|
||
for g in gl:
|
||
try:
|
||
await bot.send_group_msg(
|
||
group_id=g, message="[[_task|open_case_reset_remind]]今日开箱次数重置成功"
|
||
)
|
||
except ActionFailed:
|
||
logger.warning(f"{g} 群被禁言,无法发送 开箱重置提醒")
|
||
logger.info("今日开箱次数重置成功")
|
||
except Exception as e:
|
||
logger.error(f"开箱重置错误 e:{e}")
|
||
|
||
|
||
# 蝴蝶刀(★) | 噩梦之夜 (久经沙场)
|
||
if __name__ == "__main__":
|
||
print(util_get_buff_img("xxxx/"))
|