miui-auto-tasks/utils/data_model.py

163 lines
4.2 KiB
Python
Raw Normal View History

"""数据处理模型"""
from typing import (Any, Dict, NamedTuple, Optional)
from pydantic import BaseModel # pylint: disable=no-name-in-module
class ApiResultHandler(BaseModel):
"""
API返回的数据处理器
"""
content: Dict[str, Any]
"""API返回的JSON对象序列化以后的Dict对象"""
data: Dict[str, Any] = {}
"""API返回的数据体"""
message: str = ""
"""API返回的消息内容"""
status: Optional[int] = None
"""API返回的状态码"""
def __init__(self, content: Dict[str, Any]):
super().__init__(content=content)
for key in ["data", "entity"]:
if self.data == {}:
self.data = self.content.get(key, {})
else:
break
for key in ["code", "status"]:
if self.status is None:
self.status = self.content.get(key)
if self.status is None and isinstance(self.data, dict):
self.status = self.data.get(key)
for key in ["desc", "message"]:
if self.message == "":
self.message = self.content.get(key, "")
if self.message is None and isinstance(self.data, dict):
self.message = self.data.get(key)
@property
def success(self):
"""
是否成功
"""
return (self.status in [0, 200] or self.message in ["成功", "OK", "success"]) and not self.content.get("notificationUrl")
class LoginResultHandler(ApiResultHandler):
"""
登录API返回的数据处理器
"""
pwd: Optional[int] = None
"""登录状态"""
location: Optional[str] = None
"""登录成功后的跳转地址"""
def __init__(self, content: Dict[str, Any]):
super().__init__(content=content)
self.pwd = self.content.get("pwd")
self.location = self.content.get("location")
@property
def need_captcha(self):
"""
是否需要验证码
"""
return self.status == 87001 or "验证码" in self.message or self.content.get("notificationUrl")
@property
def pwd_wrong(self):
"""
密码错误
"""
return self.status == 70016
class DailyTasksResult(NamedTuple):
"""
每日任务API返回的数据处理器
"""
name: str
"""任务名称"""
showType: bool
"""任务状态"""
desc: Optional[str]
"""任务描述"""
class SignResultHandler(ApiResultHandler):
"""
签到API返回的数据处理器
"""
growth: Optional[str] = None
"""签到成功后的成长值"""
def __init__(self, content: Dict[str, Any]):
super().__init__(content=content)
self.growth = self.content.get("entity", {})
if isinstance(self.growth, dict):
self.growth = self.growth.get("score")
elif isinstance(self.growth, int):
self.growth = str(self.growth)
else:
self.growth = None
# pylint: disable=trailing-whitespace
def __bool__(self):
"""
签到是否成功
"""
return self.success
@property
def ck_invalid(self):
"""
cookie是否失效
"""
return self.status == 401
class TokenResultHandler(ApiResultHandler):
"""
TOKEN数据处理器
"""
token: str = ""
def __init__(self, content: Dict[str, Any]):
super().__init__(content=content)
self.token = self.data.get("token", "")
@property
def need_verify(self):
"""需要验证码"""
return self.data.get("result") is False and self.data.get("url")
@property
def success(self):
"""是否成功获取TOKEN"""
return self.token != ""
class GeetestResult(NamedTuple):
"""人机验证结果数据"""
validate: str
challenge: str
class UserInfoResult(BaseModel):
"""用户信息数据"""
title: str = "未知"
"""等级名称"""
point: int = 0
"""积分"""
def __init__(self, **kwargs):
if isinstance(kwargs, dict) and kwargs:
kwargs = kwargs.get("userInfo", {}).get("userGrowLevelInfo")
super().__init__(**kwargs)
else:
super().__init__()