mirror of
https://github.com/PaiGramTeam/PaiGram.git
synced 2024-11-29 02:57:22 +00:00
🐛 修复角色素材部分角色缺失
This commit is contained in:
parent
83f09cd00f
commit
683c3ce4aa
@ -45,19 +45,40 @@ class GameStrategyService:
|
|||||||
return artwork_info.results.image_url_list[0]
|
return artwork_info.results.image_url_list[0]
|
||||||
|
|
||||||
|
|
||||||
class GameMaterialService(GameStrategyService):
|
class GameMaterialService:
|
||||||
def __init__(self, cache: GameCache, collections: Optional[List[int]] = None):
|
def __init__(self, cache: GameCache, collections: Optional[List[int]] = None):
|
||||||
super().__init__(cache, collections)
|
self._cache = cache
|
||||||
|
self._hyperion = Hyperion()
|
||||||
self._collections = [428421, 1164644] if collections is None else collections
|
self._collections = [428421, 1164644] if collections is None else collections
|
||||||
self._special = ['雷电将军', '珊瑚宫心海', '菲谢尔', '托马', '八重神子', '九条裟罗', '辛焱', '神里绫华']
|
self._special = ['雷电将军', '珊瑚宫心海', '菲谢尔', '托马', '八重神子', '九条裟罗', '辛焱', '神里绫华']
|
||||||
|
|
||||||
|
async def _get_material_from_hyperion(self, collection_id: int, character_name: str) -> int:
|
||||||
|
post_id: int = -1
|
||||||
|
post_full_in_collection = await self._hyperion.get_post_full_in_collection(collection_id)
|
||||||
|
if post_full_in_collection.error:
|
||||||
|
return post_id
|
||||||
|
for post_data in post_full_in_collection.data["posts"]:
|
||||||
|
topics = post_data["topics"]
|
||||||
|
for topic in topics:
|
||||||
|
if character_name == topic["name"]:
|
||||||
|
post_id = int(post_data["post"]["post_id"])
|
||||||
|
break
|
||||||
|
if post_id != -1:
|
||||||
|
break
|
||||||
|
subject = post_data["post"]["subject"]
|
||||||
|
if character_name in subject:
|
||||||
|
post_id = int(post_data["post"]["post_id"])
|
||||||
|
if post_id != -1:
|
||||||
|
break
|
||||||
|
return post_id
|
||||||
|
|
||||||
async def get_material(self, character_name: str) -> str:
|
async def get_material(self, character_name: str) -> str:
|
||||||
cache = await self._cache.get_url_list(character_name)
|
cache = await self._cache.get_url_list(character_name)
|
||||||
if len(cache) >= 1:
|
if len(cache) >= 1:
|
||||||
return cache[-1]
|
return cache[-1]
|
||||||
|
|
||||||
for collection_id in self._collections:
|
for collection_id in self._collections:
|
||||||
post_id = await self._get_strategy_from_hyperion(collection_id, character_name)
|
post_id = await self._get_material_from_hyperion(collection_id, character_name)
|
||||||
if post_id != -1:
|
if post_id != -1:
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
@ -66,4 +87,11 @@ class GameMaterialService(GameStrategyService):
|
|||||||
artwork_info = await self._hyperion.get_artwork_info(2, post_id)
|
artwork_info = await self._hyperion.get_artwork_info(2, post_id)
|
||||||
await self._cache.set_url_list(character_name, artwork_info.results.image_url_list)
|
await self._cache.set_url_list(character_name, artwork_info.results.image_url_list)
|
||||||
image_url_list = artwork_info.results.image_url_list
|
image_url_list = artwork_info.results.image_url_list
|
||||||
return image_url_list[2] if character_name in self._special else image_url_list[1]
|
if len(image_url_list) == 0:
|
||||||
|
return ""
|
||||||
|
elif len(image_url_list) == 1:
|
||||||
|
return image_url_list[0]
|
||||||
|
elif character_name in self._special:
|
||||||
|
return image_url_list[2]
|
||||||
|
else:
|
||||||
|
return image_url_list[1]
|
||||||
|
@ -59,7 +59,7 @@ class Material(BasePlugins):
|
|||||||
Log.info(f"用户 {user.full_name}[{user.id}] 查询角色培养素材命令请求 || 参数 {character_name}")
|
Log.info(f"用户 {user.full_name}[{user.id}] 查询角色培养素材命令请求 || 参数 {character_name}")
|
||||||
await message.reply_chat_action(ChatAction.UPLOAD_PHOTO)
|
await message.reply_chat_action(ChatAction.UPLOAD_PHOTO)
|
||||||
file_path = await url_to_file(url, "")
|
file_path = await url_to_file(url, "")
|
||||||
caption = "From 米游社 友人A " \
|
caption = "From 米游社 " \
|
||||||
f"查看 [原图]({url})"
|
f"查看 [原图]({url})"
|
||||||
await message.reply_photo(photo=open(file_path, "rb"), caption=caption, filename=f"{character_name}.png",
|
await message.reply_photo(photo=open(file_path, "rb"), caption=caption, filename=f"{character_name}.png",
|
||||||
allow_sending_without_reply=True, parse_mode=ParseMode.MARKDOWN_V2)
|
allow_sending_without_reply=True, parse_mode=ParseMode.MARKDOWN_V2)
|
||||||
|
Loading…
Reference in New Issue
Block a user