2025-05-07 17:04:08 +08:00
|
|
|
import json
|
|
|
|
|
|
|
|
|
|
from zhenxun.services.log import logger
|
|
|
|
|
|
2025-05-27 18:15:11 +08:00
|
|
|
from . import config
|
|
|
|
|
from .request import g_pRequestManager
|
|
|
|
|
|
2025-05-07 17:04:08 +08:00
|
|
|
|
|
|
|
|
class CJsonManager:
|
|
|
|
|
def __init__(self):
|
|
|
|
|
self.m_pItem = {}
|
|
|
|
|
self.m_pLevel = {}
|
|
|
|
|
self.m_pSoil = {}
|
2025-05-27 18:15:11 +08:00
|
|
|
self.m_pSign = {}
|
2025-05-07 17:04:08 +08:00
|
|
|
|
|
|
|
|
async def init(self) -> bool:
|
|
|
|
|
if not await self.initItem():
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
if not await self.initLevel():
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
if not await self.initSoil():
|
|
|
|
|
return False
|
|
|
|
|
|
2025-05-29 18:20:03 +08:00
|
|
|
return await self.initSignInFile()
|
2025-05-07 17:04:08 +08:00
|
|
|
|
2025-05-27 18:15:11 +08:00
|
|
|
async def initItem(self) -> bool:
|
2025-05-07 17:04:08 +08:00
|
|
|
try:
|
|
|
|
|
with open(
|
2025-05-27 18:15:11 +08:00
|
|
|
config.g_sConfigPath / "item.json",
|
2025-05-07 17:04:08 +08:00
|
|
|
encoding="utf-8",
|
|
|
|
|
) as file:
|
|
|
|
|
self.m_pItem = json.load(file)
|
|
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
except FileNotFoundError:
|
|
|
|
|
logger.warning("item.json 打开失败")
|
|
|
|
|
return False
|
|
|
|
|
except json.JSONDecodeError as e:
|
|
|
|
|
logger.warning(f"item.json JSON格式错误: {e}")
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
async def initLevel(self) -> bool:
|
|
|
|
|
try:
|
|
|
|
|
with open(
|
2025-05-27 18:15:11 +08:00
|
|
|
config.g_sConfigPath / "level.json",
|
2025-05-07 17:04:08 +08:00
|
|
|
encoding="utf-8",
|
|
|
|
|
) as file:
|
|
|
|
|
self.m_pLevel = json.load(file)
|
|
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
except FileNotFoundError:
|
|
|
|
|
logger.warning("level.json 打开失败")
|
|
|
|
|
return False
|
|
|
|
|
except json.JSONDecodeError as e:
|
|
|
|
|
logger.warning(f"level.json JSON格式错误: {e}")
|
|
|
|
|
return False
|
|
|
|
|
|
|
|
|
|
async def initSoil(self) -> bool:
|
|
|
|
|
try:
|
|
|
|
|
with open(
|
2025-05-27 18:15:11 +08:00
|
|
|
config.g_sConfigPath / "soil.json",
|
2025-05-07 17:04:08 +08:00
|
|
|
encoding="utf-8",
|
|
|
|
|
) as file:
|
|
|
|
|
self.m_pSoil = json.load(file)
|
|
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
except FileNotFoundError:
|
|
|
|
|
logger.warning("soil.json 打开失败")
|
|
|
|
|
return False
|
|
|
|
|
except json.JSONDecodeError as e:
|
|
|
|
|
logger.warning(f"soil.json JSON格式错误: {e}")
|
|
|
|
|
return False
|
|
|
|
|
|
2025-05-29 18:20:03 +08:00
|
|
|
async def initSignInFile(self) -> bool:
|
|
|
|
|
if not await g_pRequestManager.initSignInFile():
|
|
|
|
|
config.g_bSignStatus = False
|
|
|
|
|
|
|
|
|
|
return False
|
|
|
|
|
else:
|
2025-06-29 01:45:24 +08:00
|
|
|
result = await self.initSign()
|
|
|
|
|
|
|
|
|
|
config.g_bSignStatus = result
|
|
|
|
|
|
|
|
|
|
return result
|
2025-05-29 18:20:03 +08:00
|
|
|
|
2025-05-27 18:15:11 +08:00
|
|
|
async def initSign(self) -> bool:
|
|
|
|
|
try:
|
|
|
|
|
with open(
|
|
|
|
|
config.g_sSignInPath,
|
|
|
|
|
encoding="utf-8",
|
|
|
|
|
) as file:
|
|
|
|
|
self.m_pSign = json.load(file)
|
|
|
|
|
|
|
|
|
|
return True
|
|
|
|
|
except FileNotFoundError:
|
|
|
|
|
logger.warning("sign_in.json 打开失败")
|
|
|
|
|
return False
|
|
|
|
|
except json.JSONDecodeError as e:
|
|
|
|
|
logger.warning(f"sign_in.json JSON格式错误: {e}")
|
|
|
|
|
return False
|
|
|
|
|
|
2025-06-06 10:56:22 +08:00
|
|
|
|
2025-05-07 17:04:08 +08:00
|
|
|
g_pJsonManager = CJsonManager()
|