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
125 lines
4.6 KiB
Python
125 lines
4.6 KiB
Python
import random
|
||
from datetime import datetime, timedelta
|
||
|
||
import nonebot
|
||
import pytz
|
||
from apscheduler.jobstores.base import ConflictingIdError
|
||
from nonebot import Driver
|
||
|
||
from models.group_member_info import GroupInfoUser
|
||
from services.log import logger
|
||
from utils.message_builder import at
|
||
from utils.utils import get_bot, scheduler
|
||
|
||
from .._models import Genshin
|
||
from ..mihoyobbs_sign import mihoyobbs_sign
|
||
from .data_source import genshin_sign
|
||
|
||
driver: Driver = nonebot.get_driver()
|
||
|
||
|
||
@driver.on_startup
|
||
async def _():
|
||
"""
|
||
启动时分配定时任务
|
||
"""
|
||
g_list = await Genshin.filter(auto_sign=True).all()
|
||
for u in g_list:
|
||
if u.auto_sign_time:
|
||
if date := await Genshin.random_sign_time(u.uid):
|
||
scheduler.add_job(
|
||
_sign,
|
||
"date",
|
||
run_date=date.replace(microsecond=0),
|
||
id=f"genshin_auto_sign_{u.uid}_{u.user_qq}_0",
|
||
args=[u.user_qq, u.uid, 0],
|
||
)
|
||
logger.info(
|
||
f"genshin_sign add_job:USER:{u.user_qq} UID:{u.uid} "
|
||
f"{date} 原神自动签到"
|
||
)
|
||
|
||
|
||
def add_job(user_id: int, uid: int, date: datetime):
|
||
try:
|
||
scheduler.add_job(
|
||
_sign,
|
||
"date",
|
||
run_date=date.replace(microsecond=0),
|
||
id=f"genshin_auto_sign_{uid}_{user_id}_0",
|
||
args=[user_id, uid, 0],
|
||
)
|
||
logger.debug(f"genshin_sign add_job:{date.replace(microsecond=0)} 原神自动签到")
|
||
except ConflictingIdError:
|
||
pass
|
||
|
||
|
||
async def _sign(user_id: int, uid: int, count: int):
|
||
"""
|
||
执行签到任务
|
||
:param user_id: 用户id
|
||
:param uid: uid
|
||
:param count: 执行次数
|
||
"""
|
||
try:
|
||
return_data = await mihoyobbs_sign(user_id)
|
||
except Exception as e:
|
||
logger.error(f"mihoyobbs_sign error:{e}")
|
||
return_data = "米游社签到失败,请尝试发送'米游社签到'进行手动签到"
|
||
if count < 3:
|
||
try:
|
||
msg = await genshin_sign(uid)
|
||
next_time = await Genshin.random_sign_time(uid)
|
||
msg += f"\n下一次签到时间为:{next_time.replace(microsecond=0)}"
|
||
logger.info(f"USER:{user_id} UID:{uid} 原神自动签到任务发生成功...")
|
||
try:
|
||
scheduler.add_job(
|
||
_sign,
|
||
"date",
|
||
run_date=next_time.replace(microsecond=0),
|
||
id=f"genshin_auto_sign_{uid}_{user_id}_0",
|
||
args=[user_id, uid, 0],
|
||
)
|
||
except ConflictingIdError:
|
||
msg += "\n定时任务设定失败..."
|
||
except Exception as e:
|
||
logger.error(f"USER:{user_id} UID:{uid} 原神自动签到任务发生错误 {type(e)}:{e}")
|
||
msg = None
|
||
if not msg:
|
||
now = datetime.now(pytz.timezone("Asia/Shanghai"))
|
||
if now.hour < 23:
|
||
random_hours = random.randint(1, 23 - now.hour)
|
||
next_time = now + timedelta(hours=random_hours)
|
||
scheduler.add_job(
|
||
_sign,
|
||
"date",
|
||
run_date=next_time.replace(microsecond=0),
|
||
id=f"genshin_auto_sign_{uid}_{user_id}_{count}",
|
||
args=[user_id, uid, count + 1],
|
||
)
|
||
msg = (
|
||
f"{now.replace(microsecond=0)} 原神"
|
||
f"签到失败,将在 {next_time.replace(microsecond=0)} 时重试!"
|
||
)
|
||
else:
|
||
msg = "今日原神签到失败,请手动签到..."
|
||
logger.debug(f"USER:{user_id} UID:{uid} 原神今日签到失败...")
|
||
else:
|
||
msg = "今日原神自动签到重试次数已达到3次,请手动签到。"
|
||
logger.debug(f"USER:{user_id} UID:{uid} 原神今日签到失败次数打到 3 次...")
|
||
bot = get_bot()
|
||
if bot:
|
||
if user_id in [x["user_id"] for x in await bot.get_friend_list()]:
|
||
await bot.send_private_msg(user_id=user_id, message=return_data)
|
||
await bot.send_private_msg(user_id=user_id, message=msg)
|
||
else:
|
||
if user := await Genshin.get_or_none(uid=uid):
|
||
group_id = user.bind_group
|
||
if not group_id:
|
||
if group_list := await GroupInfoUser.get_user_all_group(user_id):
|
||
group_id = group_list[0]
|
||
if group_id:
|
||
await bot.send_group_msg(
|
||
group_id=group_id, message=at(user_id) + msg
|
||
)
|