mirror of
https://github.com/PaiGramTeam/PamGram.git
synced 2024-11-29 09:07:13 +00:00
124 lines
6.2 KiB
Python
124 lines
6.2 KiB
Python
import datetime
|
|
import os
|
|
from typing import Optional
|
|
|
|
from genshin import DataNotPublic
|
|
from telegram import Update, InlineKeyboardButton, InlineKeyboardMarkup
|
|
from telegram.constants import ChatAction
|
|
from telegram.ext import CommandHandler, MessageHandler, ConversationHandler, filters, CallbackContext
|
|
|
|
from core.baseplugin import BasePlugin
|
|
from core.cookies.error import CookiesNotFoundError
|
|
from core.cookies.services import CookiesService
|
|
from core.plugin import Plugin, handler
|
|
from core.template.services import RenderResult, TemplateService
|
|
from core.user.error import UserNotFoundError
|
|
from core.user.services import UserService
|
|
from utils.decorators.error import error_callable
|
|
from utils.decorators.restricts import restricts
|
|
from utils.helpers import get_genshin_client
|
|
from utils.log import logger
|
|
|
|
|
|
class DailyNote(Plugin, BasePlugin):
|
|
"""每日便签"""
|
|
|
|
def __init__(
|
|
self,
|
|
user_service: UserService = None,
|
|
cookies_service: CookiesService = None,
|
|
template_service: TemplateService = None,
|
|
):
|
|
self.template_service = template_service
|
|
self.cookies_service = cookies_service
|
|
self.user_service = user_service
|
|
self.current_dir = os.getcwd()
|
|
|
|
async def _get_daily_note(self, client) -> RenderResult:
|
|
daily_info = await client.get_genshin_notes(client.uid)
|
|
day = datetime.datetime.now().strftime("%m-%d %H:%M") + " 星期" + "一二三四五六日"[datetime.datetime.now().weekday()]
|
|
resin_recovery_time = (
|
|
daily_info.resin_recovery_time.strftime("%m-%d %H:%M")
|
|
if daily_info.max_resin - daily_info.current_resin
|
|
else None
|
|
)
|
|
realm_recovery_time = (
|
|
(datetime.datetime.now().astimezone() + daily_info.remaining_realm_currency_recovery_time).strftime(
|
|
"%m-%d %H:%M"
|
|
)
|
|
if daily_info.max_realm_currency - daily_info.current_realm_currency
|
|
else None
|
|
)
|
|
remained_time = None
|
|
for i in daily_info.expeditions:
|
|
if remained_time:
|
|
if remained_time < i.remaining_time:
|
|
remained_time = i.remaining_time
|
|
else:
|
|
remained_time = i.remaining_time
|
|
if remained_time:
|
|
remained_time = (datetime.datetime.now().astimezone() + remained_time).strftime("%m-%d %H:%M")
|
|
transformer, transformer_ready, transformer_recovery_time = False, None, None
|
|
if daily_info.remaining_transformer_recovery_time is not None:
|
|
transformer = True
|
|
transformer_ready = daily_info.remaining_transformer_recovery_time.total_seconds() == 0
|
|
transformer_recovery_time = daily_info.transformer_recovery_time.strftime("%m-%d %H:%M")
|
|
daily_data = {
|
|
"uid": client.uid,
|
|
"day": day,
|
|
"resin_recovery_time": resin_recovery_time,
|
|
"current_resin": daily_info.current_resin,
|
|
"max_resin": daily_info.max_resin,
|
|
"realm_recovery_time": realm_recovery_time,
|
|
"current_realm_currency": daily_info.current_realm_currency,
|
|
"max_realm_currency": daily_info.max_realm_currency,
|
|
"claimed_commission_reward": daily_info.claimed_commission_reward,
|
|
"completed_commissions": daily_info.completed_commissions,
|
|
"max_commissions": daily_info.max_commissions,
|
|
"expeditions": bool(daily_info.expeditions),
|
|
"remained_time": remained_time,
|
|
"current_expeditions": len(daily_info.expeditions),
|
|
"max_expeditions": daily_info.max_expeditions,
|
|
"remaining_resin_discounts": daily_info.remaining_resin_discounts,
|
|
"max_resin_discounts": daily_info.max_resin_discounts,
|
|
"transformer": transformer,
|
|
"transformer_ready": transformer_ready,
|
|
"transformer_recovery_time": transformer_recovery_time,
|
|
}
|
|
render_result = await self.template_service.render(
|
|
"genshin/daily_note/daily_note.html", daily_data, {"width": 600, "height": 548}, full_page=False, ttl=8 * 60
|
|
)
|
|
return render_result
|
|
|
|
@handler(CommandHandler, command="dailynote", block=False)
|
|
@handler(MessageHandler, filters=filters.Regex("^当前状态(.*)"), block=False)
|
|
@restricts(30)
|
|
@error_callable
|
|
async def command_start(self, update: Update, context: CallbackContext) -> Optional[int]:
|
|
user = update.effective_user
|
|
message = update.effective_message
|
|
logger.info(f"用户 {user.full_name}[{user.id}] 查询游戏状态命令请求")
|
|
try:
|
|
client = await get_genshin_client(user.id)
|
|
render_result = await self._get_daily_note(client)
|
|
except (UserNotFoundError, CookiesNotFoundError):
|
|
buttons = [[InlineKeyboardButton("点我绑定账号", url=f"https://t.me/{context.bot.username}?start=set_cookie")]]
|
|
if filters.ChatType.GROUPS.filter(message):
|
|
reply_message = await message.reply_text(
|
|
"未查询到您所绑定的账号信息,请先私聊派蒙绑定账号", reply_markup=InlineKeyboardMarkup(buttons)
|
|
)
|
|
self._add_delete_message_job(context, reply_message.chat_id, reply_message.message_id, 30)
|
|
|
|
self._add_delete_message_job(context, message.chat_id, message.message_id, 30)
|
|
else:
|
|
await message.reply_text("未查询到您所绑定的账号信息,请先绑定账号", reply_markup=InlineKeyboardMarkup(buttons))
|
|
return
|
|
except DataNotPublic:
|
|
reply_message = await message.reply_text("查询失败惹,可能是便签功能被禁用了?请尝试通过米游社或者 hoyolab 获取一次便签信息后重试。")
|
|
if filters.ChatType.GROUPS.filter(message):
|
|
self._add_delete_message_job(context, reply_message.chat_id, reply_message.message_id, 300)
|
|
self._add_delete_message_job(context, message.chat_id, message.message_id, 300)
|
|
return ConversationHandler.END
|
|
await message.reply_chat_action(ChatAction.UPLOAD_PHOTO)
|
|
await render_result.reply_photo(message, filename=f"{client.uid}.png", allow_sending_without_reply=True)
|