mirror of
https://github.com/PaiGramTeam/SIMNet.git
synced 2024-11-21 21:58:05 +00:00
✨ Support zzz ledger
This commit is contained in:
parent
c07234d94e
commit
3e936b7eb8
@ -46,7 +46,7 @@ class BaseDiaryClient(BaseClient):
|
|||||||
base_url = DETAIL_LEDGER_URL if detail else INFO_LEDGER_URL
|
base_url = DETAIL_LEDGER_URL if detail else INFO_LEDGER_URL
|
||||||
url = base_url.get_url(self.region, game)
|
url = base_url.get_url(self.region, game)
|
||||||
|
|
||||||
if self.region == Region.OVERSEAS or game == Game.STARRAIL:
|
if self.region == Region.OVERSEAS or game == Game.STARRAIL or game == Game.ZZZ:
|
||||||
params["uid"] = player_id
|
params["uid"] = player_id
|
||||||
params["region"] = recognize_server(player_id, game)
|
params["region"] = recognize_server(player_id, game)
|
||||||
elif self.region == Region.CHINESE:
|
elif self.region == Region.CHINESE:
|
||||||
@ -54,7 +54,7 @@ class BaseDiaryClient(BaseClient):
|
|||||||
params["bind_region"] = recognize_server(player_id, game)
|
params["bind_region"] = recognize_server(player_id, game)
|
||||||
else:
|
else:
|
||||||
raise TypeError(f"{self.region!r} is not a valid region.")
|
raise TypeError(f"{self.region!r} is not a valid region.")
|
||||||
if game == Game.STARRAIL:
|
if game in [Game.STARRAIL, Game.ZZZ]:
|
||||||
month = month or datetime.now(CN_TIMEZONE).strftime("%Y%m")
|
month = month or datetime.now(CN_TIMEZONE).strftime("%Y%m")
|
||||||
elif game == Game.GENSHIN:
|
elif game == Game.GENSHIN:
|
||||||
month = month or str(datetime.now(CN_TIMEZONE).month)
|
month = month or str(datetime.now(CN_TIMEZONE).month)
|
||||||
|
29
simnet/client/components/diary/zzz.py
Normal file
29
simnet/client/components/diary/zzz.py
Normal file
@ -0,0 +1,29 @@
|
|||||||
|
from typing import Optional
|
||||||
|
|
||||||
|
from simnet.client.components.diary.base import BaseDiaryClient
|
||||||
|
from simnet.models.zzz.diary import ZZZDiary
|
||||||
|
from simnet.utils.enums import Game
|
||||||
|
|
||||||
|
|
||||||
|
class ZZZDiaryClient(BaseDiaryClient):
|
||||||
|
"""ZZZ diary component."""
|
||||||
|
|
||||||
|
async def get_zzz_diary(
|
||||||
|
self,
|
||||||
|
player_id: Optional[int] = None,
|
||||||
|
*,
|
||||||
|
month: Optional[str] = None,
|
||||||
|
lang: Optional[str] = None,
|
||||||
|
) -> ZZZDiary:
|
||||||
|
"""Get a traveler's diary with earning details for the month.
|
||||||
|
|
||||||
|
Args:
|
||||||
|
player_id (int, optional): The player's ID. Defaults to None.
|
||||||
|
month (int, optional): The month to get the diary for. Defaults to None.
|
||||||
|
lang (str, optional): The language to get the diary in. Defaults to None.
|
||||||
|
|
||||||
|
Returns:
|
||||||
|
ZZZDiary: The diary for the month.
|
||||||
|
"""
|
||||||
|
data = await self.request_ledger(player_id, game=Game.ZZZ, month=month, lang=lang)
|
||||||
|
return ZZZDiary(**data)
|
@ -303,10 +303,12 @@ DETAIL_LEDGER_URL = GameRoute(
|
|||||||
overseas=dict(
|
overseas=dict(
|
||||||
genshin="https://sg-hk4e-api.hoyolab.com/event/ysledgeros/month_detail",
|
genshin="https://sg-hk4e-api.hoyolab.com/event/ysledgeros/month_detail",
|
||||||
hkrpg="https://sg-public-api.hoyolab.com/event/srledger/month_detail",
|
hkrpg="https://sg-public-api.hoyolab.com/event/srledger/month_detail",
|
||||||
|
nap="https://sg-public-api.hoyolab.com/event/nap_ledger/month_detail",
|
||||||
),
|
),
|
||||||
chinese=dict(
|
chinese=dict(
|
||||||
genshin="https://hk4e-api.mihoyo.com/event/ys_ledger/monthDetail",
|
genshin="https://hk4e-api.mihoyo.com/event/ys_ledger/monthDetail",
|
||||||
hkrpg="https://api-takumi.mihoyo.com/event/srledger/month_detail",
|
hkrpg="https://api-takumi.mihoyo.com/event/srledger/month_detail",
|
||||||
|
nap="https://api-takumi.mihoyo.com/event/nap_ledger/month_detail",
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -314,10 +316,12 @@ INFO_LEDGER_URL = GameRoute(
|
|||||||
overseas=dict(
|
overseas=dict(
|
||||||
genshin="https://sg-hk4e-api.hoyolab.com/event/ysledgeros/month_info",
|
genshin="https://sg-hk4e-api.hoyolab.com/event/ysledgeros/month_info",
|
||||||
hkrpg="https://sg-public-api.hoyolab.com/event/srledger/month_info",
|
hkrpg="https://sg-public-api.hoyolab.com/event/srledger/month_info",
|
||||||
|
nap="https://sg-public-api.hoyolab.com/event/nap_ledger/month_info",
|
||||||
),
|
),
|
||||||
chinese=dict(
|
chinese=dict(
|
||||||
genshin="https://hk4e-api.mihoyo.com/event/ys_ledger/monthInfo",
|
genshin="https://hk4e-api.mihoyo.com/event/ys_ledger/monthInfo",
|
||||||
hkrpg="https://api-takumi.mihoyo.com/event/srledger/month_info",
|
hkrpg="https://api-takumi.mihoyo.com/event/srledger/month_info",
|
||||||
|
nap="https://api-takumi.mihoyo.com/event/nap_ledger/month_info",
|
||||||
),
|
),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -3,6 +3,7 @@ from typing import Optional
|
|||||||
from simnet.client.components.auth import AuthClient
|
from simnet.client.components.auth import AuthClient
|
||||||
from simnet.client.components.chronicle.zzz import ZZZBattleChronicleClient
|
from simnet.client.components.chronicle.zzz import ZZZBattleChronicleClient
|
||||||
from simnet.client.components.daily import DailyRewardClient
|
from simnet.client.components.daily import DailyRewardClient
|
||||||
|
from simnet.client.components.diary.zzz import ZZZDiaryClient
|
||||||
from simnet.client.components.lab import LabClient
|
from simnet.client.components.lab import LabClient
|
||||||
from simnet.client.components.self_help.zzz import ZZZSelfHelpClient
|
from simnet.client.components.self_help.zzz import ZZZSelfHelpClient
|
||||||
from simnet.client.components.verify import VerifyClient
|
from simnet.client.components.verify import VerifyClient
|
||||||
@ -15,6 +16,7 @@ __all__ = ("ZZZClient",)
|
|||||||
class ZZZClient(
|
class ZZZClient(
|
||||||
ZZZBattleChronicleClient,
|
ZZZBattleChronicleClient,
|
||||||
ZZZWishClient,
|
ZZZWishClient,
|
||||||
|
ZZZDiaryClient,
|
||||||
ZZZSelfHelpClient,
|
ZZZSelfHelpClient,
|
||||||
DailyRewardClient,
|
DailyRewardClient,
|
||||||
AuthClient,
|
AuthClient,
|
||||||
|
98
simnet/models/zzz/diary.py
Normal file
98
simnet/models/zzz/diary.py
Normal file
@ -0,0 +1,98 @@
|
|||||||
|
from typing import List
|
||||||
|
|
||||||
|
from pydantic import Field
|
||||||
|
|
||||||
|
from simnet.models.base import APIModel
|
||||||
|
from simnet.models.diary import BaseDiary
|
||||||
|
|
||||||
|
__all__ = (
|
||||||
|
"ZZZDiaryDataList",
|
||||||
|
"ZZZDiaryActionCategory",
|
||||||
|
"ZZZMonthDiaryData",
|
||||||
|
"ZZZDiary",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class ZZZDiaryDataList(APIModel):
|
||||||
|
"""List of diary data.
|
||||||
|
|
||||||
|
Attributes:
|
||||||
|
id: Data ID.
|
||||||
|
name: Data name.
|
||||||
|
amount: Amount of data.
|
||||||
|
"""
|
||||||
|
|
||||||
|
id: str = Field(alias="data_type")
|
||||||
|
name: str = Field(alias="data_name")
|
||||||
|
amount: int = Field(alias="count")
|
||||||
|
|
||||||
|
|
||||||
|
class ZZZDiaryActionCategory(APIModel):
|
||||||
|
"""Diary category for PolychromesData .
|
||||||
|
|
||||||
|
Attributes:
|
||||||
|
action: Category name.
|
||||||
|
amount: Amount of rails_pass.
|
||||||
|
percentage: Percentage of rails_pass.
|
||||||
|
"""
|
||||||
|
|
||||||
|
action: str
|
||||||
|
amount: int = Field(alias="num")
|
||||||
|
percentage: int = Field(alias="percent")
|
||||||
|
|
||||||
|
@property
|
||||||
|
def name(self) -> str:
|
||||||
|
return {
|
||||||
|
"growth_rewards": "成长奖励",
|
||||||
|
"daily_activity_rewards": "日常活跃奖励",
|
||||||
|
"mail_rewards": "邮件奖励",
|
||||||
|
"event_rewards": "活动奖励",
|
||||||
|
"hollow_rewards": "零号空洞奖励",
|
||||||
|
"shiyu_rewards": "式舆防卫战奖励",
|
||||||
|
"other_rewards": "其他奖励",
|
||||||
|
}.get(self.action, "其他奖励")
|
||||||
|
|
||||||
|
|
||||||
|
class ZZZMonthDiaryData(APIModel):
|
||||||
|
"""Diary data for a month.
|
||||||
|
|
||||||
|
Attributes:
|
||||||
|
categories: List of diary categories.
|
||||||
|
"""
|
||||||
|
|
||||||
|
list: List[ZZZDiaryDataList]
|
||||||
|
categories: List[ZZZDiaryActionCategory] = Field(alias="income_components")
|
||||||
|
|
||||||
|
|
||||||
|
class ZZZDiaryRoleInfo(APIModel):
|
||||||
|
"""Role info for a diary."""
|
||||||
|
|
||||||
|
nickname: str
|
||||||
|
avatar: str
|
||||||
|
|
||||||
|
|
||||||
|
class ZZZDiary(BaseDiary):
|
||||||
|
"""Traveler's diary.
|
||||||
|
|
||||||
|
Attributes:
|
||||||
|
data: Diary data for a month.
|
||||||
|
optional_month: Optional month.
|
||||||
|
current_month: Current month.
|
||||||
|
data_month: Data month.
|
||||||
|
"""
|
||||||
|
|
||||||
|
data: ZZZMonthDiaryData = Field(alias="month_data")
|
||||||
|
optional_month: List[str]
|
||||||
|
current_month: str
|
||||||
|
data_month: str
|
||||||
|
role_info: ZZZDiaryRoleInfo
|
||||||
|
|
||||||
|
@property
|
||||||
|
def data_id(self) -> int:
|
||||||
|
"""Get the data ID."""
|
||||||
|
return self.month
|
||||||
|
|
||||||
|
@property
|
||||||
|
def month_data(self) -> ZZZMonthDiaryData:
|
||||||
|
"""Diary data for a month."""
|
||||||
|
return self.data
|
Loading…
Reference in New Issue
Block a user